|  | 
|  | 1 | +<?php | 
|  | 2 | + | 
|  | 3 | +declare(strict_types=1); | 
|  | 4 | + | 
|  | 5 | +namespace PhpOffice\PhpSpreadsheetTests\Reader; | 
|  | 6 | + | 
|  | 7 | +use PhpOffice\PhpSpreadsheet\Exception as SpreadsheetException; | 
|  | 8 | +use PhpOffice\PhpSpreadsheet\IOFactory; | 
|  | 9 | +use PhpOffice\PhpSpreadsheet\Reader; | 
|  | 10 | +use PHPUnit\Framework\Attributes\DataProvider; | 
|  | 11 | +use PHPUnit\Framework\TestCase; | 
|  | 12 | + | 
|  | 13 | +class CreateBlankSheetIfNoneReadTest extends TestCase | 
|  | 14 | +{ | 
|  | 15 | +    #[DataProvider('providerIdentify')] | 
|  | 16 | +    public function testExceptionIfNoSheet(string $file, string $expectedName, string $expectedClass): void | 
|  | 17 | +    { | 
|  | 18 | +        $this->expectException(SpreadsheetException::class); | 
|  | 19 | +        $this->expectExceptionMessage('out of bounds index: 0'); | 
|  | 20 | +        $actual = IOFactory::identify($file); | 
|  | 21 | +        self::assertSame($expectedName, $actual); | 
|  | 22 | +        $reader = IOFactory::createReaderForFile($file); | 
|  | 23 | +        self::assertSame($expectedClass, $reader::class); | 
|  | 24 | +        $sheetlist = ['Unknown sheetname']; | 
|  | 25 | +        $reader->setLoadSheetsOnly($sheetlist); | 
|  | 26 | +        $reader->load($file); | 
|  | 27 | +    } | 
|  | 28 | + | 
|  | 29 | +    #[DataProvider('providerIdentify')] | 
|  | 30 | +    public function testCreateSheetIfNoSheet(string $file, string $expectedName, string $expectedClass): void | 
|  | 31 | +    { | 
|  | 32 | +        $actual = IOFactory::identify($file); | 
|  | 33 | +        self::assertSame($expectedName, $actual); | 
|  | 34 | +        $reader = IOFactory::createReaderForFile($file); | 
|  | 35 | +        self::assertSame($expectedClass, $reader::class); | 
|  | 36 | +        $reader->setCreateBlankSheetIfNoneRead(true); | 
|  | 37 | +        $sheetlist = ['Unknown sheetname']; | 
|  | 38 | +        $reader->setLoadSheetsOnly($sheetlist); | 
|  | 39 | +        $spreadsheet = $reader->load($file); | 
|  | 40 | +        $sheet = $spreadsheet->getActiveSheet(); | 
|  | 41 | +        self::assertSame('Worksheet', $sheet->getTitle()); | 
|  | 42 | +        self::assertCount(1, $spreadsheet->getAllSheets()); | 
|  | 43 | +        $spreadsheet->disconnectWorksheets(); | 
|  | 44 | +    } | 
|  | 45 | + | 
|  | 46 | +    public static function providerIdentify(): array | 
|  | 47 | +    { | 
|  | 48 | +        return [ | 
|  | 49 | +            ['samples/templates/26template.xlsx', 'Xlsx', Reader\Xlsx::class], | 
|  | 50 | +            ['samples/templates/GnumericTest.gnumeric', 'Gnumeric', Reader\Gnumeric::class], | 
|  | 51 | +            ['samples/templates/30template.xls', 'Xls', Reader\Xls::class], | 
|  | 52 | +            ['samples/templates/OOCalcTest.ods', 'Ods', Reader\Ods::class], | 
|  | 53 | +            ['samples/templates/excel2003.xml', 'Xml', Reader\Xml::class], | 
|  | 54 | +        ]; | 
|  | 55 | +    } | 
|  | 56 | + | 
|  | 57 | +    public function testUsingFlage(): void | 
|  | 58 | +    { | 
|  | 59 | +        $file = 'samples/templates/26template.xlsx'; | 
|  | 60 | +        $reader = IOFactory::createReaderForFile($file); | 
|  | 61 | +        $sheetlist = ['Unknown sheetname']; | 
|  | 62 | +        $reader->setLoadSheetsOnly($sheetlist); | 
|  | 63 | +        $spreadsheet = $reader->load($file, Reader\BaseReader::CREATE_BLANK_SHEET_IF_NONE_READ); | 
|  | 64 | +        $sheet = $spreadsheet->getActiveSheet(); | 
|  | 65 | +        self::assertSame('Worksheet', $sheet->getTitle()); | 
|  | 66 | +        self::assertCount(1, $spreadsheet->getAllSheets()); | 
|  | 67 | +        $spreadsheet->disconnectWorksheets(); | 
|  | 68 | +    } | 
|  | 69 | +} | 
0 commit comments