| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293 |
- <?php
- namespace PhpOffice\PhpSpreadsheetTests\Reader\Csv;
- use PhpOffice\PhpSpreadsheet\IOFactory;
- use PhpOffice\PhpSpreadsheet\Reader\Csv;
- use PHPUnit\Framework\TestCase;
- class CsvCallbackTest extends TestCase
- {
- protected function tearDown(): void
- {
- Csv::setConstructorCallback(null);
- }
- /**
- * @param mixed $obj
- */
- public function callbackDoNothing($obj): void
- {
- self::assertInstanceOf(Csv::class, $obj);
- }
- public function testCallbackDoNothing(): void
- {
- Csv::setConstructorCallback([$this, 'callbackDoNothing']);
- $filename = 'tests/data/Reader/CSV/encoding.iso88591.csv';
- $reader = new Csv();
- $reader->setInputEncoding(Csv::GUESS_ENCODING);
- $spreadsheet = $reader->load($filename);
- $sheet = $spreadsheet->getActiveSheet();
- self::assertEquals('Å', $sheet->getCell('A1')->getValue());
- }
- public function callbackSetFallbackEncoding(Csv $reader): void
- {
- $reader->setFallbackEncoding('ISO-8859-2');
- $reader->setInputEncoding(Csv::GUESS_ENCODING);
- $reader->setEscapeCharacter((version_compare(PHP_VERSION, '7.4') < 0) ? "\x0" : '');
- }
- public function testFallbackEncodingDefltIso2(): void
- {
- Csv::setConstructorCallback([$this, 'callbackSetFallbackEncoding']);
- $filename = 'tests/data/Reader/CSV/premiere.win1252.csv';
- $reader = new Csv();
- $spreadsheet = $reader->load($filename);
- $sheet = $spreadsheet->getActiveSheet();
- self::assertEquals('premičre', $sheet->getCell('A1')->getValue());
- self::assertEquals('sixičme', $sheet->getCell('C2')->getValue());
- }
- public function testIOFactory(): void
- {
- Csv::setConstructorCallback([$this, 'callbackSetFallbackEncoding']);
- $filename = 'tests/data/Reader/CSV/premiere.win1252.csv';
- $spreadsheet = IOFactory::load($filename);
- $sheet = $spreadsheet->getActiveSheet();
- self::assertEquals('premičre', $sheet->getCell('A1')->getValue());
- self::assertEquals('sixičme', $sheet->getCell('C2')->getValue());
- }
- public function testNonFallbackEncoding(): void
- {
- Csv::setConstructorCallback([$this, 'callbackSetFallbackEncoding']);
- $filename = 'tests/data/Reader/CSV/premiere.utf16be.csv';
- $reader = new Csv();
- $spreadsheet = $reader->load($filename);
- $sheet = $spreadsheet->getActiveSheet();
- self::assertEquals('première', $sheet->getCell('A1')->getValue());
- self::assertEquals('sixième', $sheet->getCell('C2')->getValue());
- }
- public function testDefaultEscape(): void
- {
- self::assertNull(Csv::getConstructorCallback());
- $filename = 'tests/data/Reader/CSV/escape.csv';
- $spreadsheet = IOFactory::load($filename);
- $sheet = $spreadsheet->getActiveSheet();
- // this is not how Excel views the file
- self::assertEquals('a\"hello', $sheet->getCell('A1')->getValue());
- }
- public function testBetterEscape(): void
- {
- Csv::setConstructorCallback([$this, 'callbackSetFallbackEncoding']);
- $filename = 'tests/data/Reader/CSV/escape.csv';
- $spreadsheet = IOFactory::load($filename);
- $sheet = $spreadsheet->getActiveSheet();
- // this is how Excel views the file
- self::assertEquals('a\"hello;hello;hello;\"', $sheet->getCell('A1')->getValue());
- }
- }
|