Completed
Push — master ( 0e8d0b...b4cd42 )
by
unknown
43s queued 34s
created

CsvLineEndingTest::providerEndings2()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 4
Code Lines 2

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
eloc 2
c 0
b 0
f 0
dl 0
loc 4
rs 10
cc 1
nc 1
nop 0
1
<?php
2
3
declare(strict_types=1);
4
5
namespace PhpOffice\PhpSpreadsheetTests\Reader\Csv;
6
7
use PhpOffice\PhpSpreadsheet\Reader\Csv;
8
use PhpOffice\PhpSpreadsheet\Shared\File;
9
use PHPUnit\Framework\Attributes\DataProvider;
10
use PHPUnit\Framework\TestCase;
11
12
class CsvLineEndingTest extends TestCase
13
{
14
    private string $tempFile = '';
15
16
    private static bool $alwaysFalse = false;
17
18
    protected function tearDown(): void
19
    {
20
        if ($this->tempFile !== '') {
21
            unlink($this->tempFile);
22
            $this->tempFile = '';
23
        }
24
    }
25
26
    #[DataProvider('providerEndings')]
27
    #[DataProvider('providerEndings2')]
28
    public function testEndings(string $ending, int $version = PHP_VERSION_ID): void
29
    {
30
        if ($ending === "\r" && $version >= 90000) {
31
            self::markTestSkipped('Mac line endings not supported for Php9+');
32
        }
33
        $this->tempFile = $filename = File::temporaryFilename();
34
        $data = ['123', '456', '789'];
35
        file_put_contents($filename, implode($ending, $data));
36
        $reader = new Csv();
37
        if (Csv::DEFAULT_TEST_AUTODETECT === self::$alwaysFalse) {
38
            $reader->setTestAutoDetect(true);
39
        }
40
        $spreadsheet = $reader->load($filename);
41
        $sheet = $spreadsheet->getActiveSheet();
42
        self::assertEquals($data[0], $sheet->getCell('A1')->getValue());
43
        self::assertEquals($data[1], $sheet->getCell('A2')->getValue());
44
        self::assertEquals($data[2], $sheet->getCell('A3')->getValue());
45
        $spreadsheet->disconnectWorksheets();
46
    }
47
48
    #[DataProvider('providerEndings')]
49
    public function testEndingsNoDetect(string $ending): void
50
    {
51
        $this->tempFile = $filename = File::temporaryFilename();
52
        $data = ['123', '456', '789'];
53
        file_put_contents($filename, implode($ending, $data));
54
        $reader = new Csv();
55
        self::assertSame(self::$alwaysFalse, Csv::DEFAULT_TEST_AUTODETECT);
56
        $spreadsheet = $reader->load($filename);
57
        $sheet = $spreadsheet->getActiveSheet();
58
        if ($ending === "\r") {
59
            // Can't handle Mac line endings without autoDetect
60
            self::assertEquals(implode("\n", $data), $sheet->getCell('A1')->getValue());
61
            self::assertNull($sheet->getCell('A2')->getValue());
62
            self::assertNull($sheet->getCell('A3')->getValue());
63
        } else {
64
            self::assertEquals($data[0], $sheet->getCell('A1')->getValue());
65
            self::assertEquals($data[1], $sheet->getCell('A2')->getValue());
66
            self::assertEquals($data[2], $sheet->getCell('A3')->getValue());
67
        }
68
        $spreadsheet->disconnectWorksheets();
69
    }
70
71
    public static function providerEndings(): array
72
    {
73
        return [
74
            'Unix endings' => ["\n"],
75
            'Mac endings' => ["\r"],
76
            'Windows endings' => ["\r\n"],
77
        ];
78
    }
79
80
    public static function providerEndings2(): array
81
    {
82
        return [
83
            'Mac endings Php9+' => ["\r", 90000],
84
        ];
85
    }
86
}
87