| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283 |
- <?php
- namespace PhpOffice\PhpSpreadsheetTests\Reader\Xlsx;
- use PhpOffice\PhpSpreadsheet\Cell\Coordinate;
- use PhpOffice\PhpSpreadsheet\Cell\DataValidation;
- use PhpOffice\PhpSpreadsheet\IOFactory;
- use PhpOffice\PhpSpreadsheet\Reader\Xlsx;
- use PhpOffice\PhpSpreadsheet\Shared\File;
- use PhpOffice\PhpSpreadsheet\Style\Conditional;
- use PhpOffice\PhpSpreadsheet\Style\Style;
- use PhpOffice\PhpSpreadsheet\Worksheet\AutoFilter;
- use PhpOffice\PhpSpreadsheet\Worksheet\PageSetup;
- use PHPUnit\Framework\TestCase;
- class XlsxTest extends TestCase
- {
- const XLSX_PRECISION = 1.0E-8;
- public function testLoadXlsxRowColumnAttributes(): void
- {
- $filename = 'tests/data/Reader/XLSX/rowColumnAttributeTest.xlsx';
- $reader = new Xlsx();
- $spreadsheet = $reader->load($filename);
- $worksheet = $spreadsheet->getActiveSheet();
- for ($row = 1; $row <= 4; ++$row) {
- self::assertEquals($row * 5 + 10, floor($worksheet->getRowDimension($row)->getRowHeight()));
- }
- self::assertFalse($worksheet->getRowDimension(5)->getVisible());
- for ($column = 1; $column <= 4; ++$column) {
- $columnAddress = Coordinate::stringFromColumnIndex($column);
- self::assertEquals(
- $column * 2 + 2,
- floor($worksheet->getColumnDimension($columnAddress)->getWidth())
- );
- }
- self::assertFalse($worksheet->getColumnDimension('E')->getVisible());
- }
- public function testLoadXlsxWithStyles(): void
- {
- $expectedColours = [
- 1 => ['A' => 'C00000', 'C' => 'FF0000', 'E' => 'FFC000'],
- 3 => ['A' => '7030A0', 'C' => 'FFFFFF', 'E' => 'FFFF00'],
- 5 => ['A' => '002060', 'C' => 'FFFFFF', 'E' => '92D050'],
- 7 => ['A' => '0070C0', 'C' => '00B0F0', 'E' => '00B050'],
- ];
- $filename = 'tests/data/Reader/XLSX/stylesTest.xlsx';
- $reader = new Xlsx();
- $spreadsheet = $reader->load($filename);
- $worksheet = $spreadsheet->getActiveSheet();
- for ($row = 1; $row <= 8; $row += 2) {
- for ($column = 'A'; $column !== 'G'; ++$column, ++$column) {
- self::assertEquals(
- $expectedColours[$row][$column],
- $worksheet->getStyle($column . $row)->getFill()->getStartColor()->getRGB()
- );
- }
- }
- }
- /**
- * Test load Xlsx file without styles.xml.
- */
- public function testLoadXlsxWithoutStyles(): void
- {
- $filename = 'tests/data/Reader/XLSX/issue.2246a.xlsx';
- $reader = new Xlsx();
- $spreadsheet = $reader->load($filename);
- $tempFilename = File::temporaryFilename();
- $writer = IOFactory::createWriter($spreadsheet, 'Xlsx');
- $writer->save($tempFilename);
- $reader = new Xlsx();
- $reloadedSpreadsheet = $reader->load($tempFilename);
- unlink($tempFilename);
- $reloadedWorksheet = $reloadedSpreadsheet->getActiveSheet();
- self::assertEquals('TipoDato', $reloadedWorksheet->getCell('A1')->getValue());
- }
- /**
- * Test load Xlsx file with empty styles.xml.
- */
- public function testLoadXlsxWithEmptyStyles(): void
- {
- $filename = 'tests/data/Reader/XLSX/issue.2246b.xlsx';
- $reader = new Xlsx();
- $spreadsheet = $reader->load($filename);
- $tempFilename = File::temporaryFilename();
- $writer = IOFactory::createWriter($spreadsheet, 'Xlsx');
- $writer->save($tempFilename);
- $reader = new Xlsx();
- $reloadedSpreadsheet = $reader->load($tempFilename);
- unlink($tempFilename);
- $reloadedWorksheet = $reloadedSpreadsheet->getActiveSheet();
- self::assertEquals('TipoDato', $reloadedWorksheet->getCell('A1')->getValue());
- }
- public function testLoadXlsxAutofilter(): void
- {
- $filename = 'tests/data/Reader/XLSX/autofilterTest.xlsx';
- $reader = new Xlsx();
- $spreadsheet = $reader->load($filename);
- $worksheet = $spreadsheet->getActiveSheet();
- $autofilter = $worksheet->getAutoFilter();
- self::assertInstanceOf(AutoFilter::class, $autofilter);
- self::assertEquals('A1:D57', $autofilter->getRange());
- self::assertEquals(
- AutoFilter\Column::AUTOFILTER_FILTERTYPE_FILTER,
- $autofilter->getColumn('A')->getFilterType()
- );
- }
- public function testLoadXlsxPageSetup(): void
- {
- $filename = 'tests/data/Reader/XLSX/pageSetupTest.xlsx';
- $reader = new Xlsx();
- $spreadsheet = $reader->load($filename);
- $worksheet = $spreadsheet->getActiveSheet();
- $pageMargins = $worksheet->getPageMargins();
- // Convert from inches to cm for testing
- self::assertEqualsWithDelta(2.5, $pageMargins->getTop() * 2.54, self::XLSX_PRECISION);
- self::assertEqualsWithDelta(3.3, $pageMargins->getLeft() * 2.54, self::XLSX_PRECISION);
- self::assertEqualsWithDelta(3.3, $pageMargins->getRight() * 2.54, self::XLSX_PRECISION);
- self::assertEqualsWithDelta(1.3, $pageMargins->getHeader() * 2.54, self::XLSX_PRECISION);
- self::assertEquals(PageSetup::PAPERSIZE_A4, $worksheet->getPageSetup()->getPaperSize());
- self::assertEquals(['A10', 'A20', 'A30', 'A40', 'A50'], array_keys($worksheet->getBreaks()));
- }
- public function testLoadXlsxConditionalFormatting(): void
- {
- $filename = 'tests/data/Reader/XLSX/conditionalFormattingTest.xlsx';
- $reader = new Xlsx();
- $spreadsheet = $reader->load($filename);
- $worksheet = $spreadsheet->getActiveSheet();
- $conditionalStyle = $worksheet->getCell('B2')->getStyle()->getConditionalStyles();
- self::assertNotEmpty($conditionalStyle);
- $conditionalRule = $conditionalStyle[0];
- self::assertNotEmpty($conditionalRule->getConditions());
- self::assertEquals(Conditional::CONDITION_CELLIS, $conditionalRule->getConditionType());
- self::assertEquals(Conditional::OPERATOR_BETWEEN, $conditionalRule->getOperatorType());
- self::assertEquals(['200', '400'], $conditionalRule->getConditions());
- self::assertInstanceOf(Style::class, $conditionalRule->getStyle());
- }
- public function testLoadXlsxDataValidation(): void
- {
- $filename = 'tests/data/Reader/XLSX/dataValidationTest.xlsx';
- $reader = new Xlsx();
- $spreadsheet = $reader->load($filename);
- $worksheet = $spreadsheet->getActiveSheet();
- self::assertTrue($worksheet->getCell('B3')->hasDataValidation());
- }
- /*
- * Test for load drop down lists of another sheet.
- * Pull #2150, issue #2149
- */
- public function testLoadXlsxDataValidationOfAnotherSheet(): void
- {
- $filename = 'tests/data/Reader/XLSX/dataValidation2Test.xlsx';
- $reader = new Xlsx();
- $spreadsheet = $reader->load($filename);
- $worksheet = $spreadsheet->getActiveSheet();
- // same sheet
- $validationCell = $worksheet->getCell('B5');
- self::assertTrue($validationCell->hasDataValidation());
- self::assertSame(DataValidation::TYPE_LIST, $validationCell->getDataValidation()->getType());
- self::assertSame('$A$5:$A$7', $validationCell->getDataValidation()->getFormula1());
- // another sheet
- $validationCell = $worksheet->getCell('B14');
- self::assertTrue($validationCell->hasDataValidation());
- self::assertSame(DataValidation::TYPE_LIST, $validationCell->getDataValidation()->getType());
- self::assertSame('Feuil2!$A$3:$A$5', $validationCell->getDataValidation()->getFormula1());
- }
- /**
- * Test load Xlsx file without cell reference.
- *
- * @doesNotPerformAssertions
- */
- public function testLoadXlsxWithoutCellReference(): void
- {
- $filename = 'tests/data/Reader/XLSX/without_cell_reference.xlsx';
- $reader = new Xlsx();
- $reader->load($filename);
- }
- /**
- * Test load Xlsx file and use a read filter.
- */
- public function testLoadWithReadFilter(): void
- {
- $filename = 'tests/data/Reader/XLSX/without_cell_reference.xlsx';
- $reader = new Xlsx();
- $reader->setReadFilter(new OddColumnReadFilter());
- $data = $reader->load($filename)->getActiveSheet()->toArray();
- $ref = [1.0, null, 3.0, null, 5.0, null, 7.0, null, 9.0, null];
- for ($i = 0; $i < 10; ++$i) {
- self::assertEquals($ref, \array_slice($data[$i], 0, 10, true));
- }
- }
- /**
- * Test load Xlsx file with drawing having double attributes.
- *
- * @doesNotPerformAssertions
- */
- public function testLoadXlsxWithDoubleAttrDrawing(): void
- {
- $filename = 'tests/data/Reader/XLSX/double_attr_drawing.xlsx';
- $reader = new Xlsx();
- $reader->load($filename);
- }
- /**
- * Test correct save and load xlsx files with empty drawings.
- * Such files can be generated by Google Sheets.
- */
- public function testLoadSaveWithEmptyDrawings(): void
- {
- $filename = 'tests/data/Reader/XLSX/empty_drawing.xlsx';
- $reader = new Xlsx();
- $excel = $reader->load($filename);
- $resultFilename = File::temporaryFilename();
- $writer = new \PhpOffice\PhpSpreadsheet\Writer\Xlsx($excel);
- $writer->save($resultFilename);
- $excel = $reader->load($resultFilename);
- unlink($resultFilename);
- // Fake assert. The only thing we need is to ensure the file is loaded without exception
- self::assertNotNull($excel);
- }
- /**
- * Test if all whitespace is removed from a style definition string.
- * This is needed to parse it into properties with the correct keys.
- *
- * @dataProvider providerStripsWhiteSpaceFromStyleString
- */
- public function testStripsWhiteSpaceFromStyleString(string $string): void
- {
- $string = Xlsx::stripWhiteSpaceFromStyleString($string);
- self::assertEquals(preg_match('/\s/', $string), 0);
- }
- public function providerStripsWhiteSpaceFromStyleString(): array
- {
- return [
- ['position:absolute;margin-left:424.5pt;margin-top:169.5pt;width:67.5pt;
- height:13.5pt;z-index:5;mso-wrap-style:tight'],
- ['position:absolute;margin-left:424.5pt;margin-top:169.5pt;width:67.5pt;
- height:13.5pt;z-index:5;mso-wrap-style:tight'],
- ['position:absolute; margin-left:424.5pt; margin-top:169.5pt; width:67.5pt;
- height:13.5pt;z-index:5;mso-wrap-style:tight'],
- ];
- }
- }
|