| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160 |
- <?php
- namespace PhpOffice\PhpSpreadsheetTests\Reader\Security;
- use PhpOffice\PhpSpreadsheet\Reader\Security\XmlScanner;
- use PhpOffice\PhpSpreadsheet\Reader\Xls;
- use PhpOffice\PhpSpreadsheet\Reader\Xlsx;
- use PHPUnit\Framework\TestCase;
- use XMLReader;
- class XmlScannerTest extends TestCase
- {
- protected function setUp(): void
- {
- // php 8.+ deprecated libxml_disable_entity_loader() - It's on by default
- if (\PHP_VERSION_ID < 80000) {
- libxml_disable_entity_loader(false);
- }
- }
- /**
- * @dataProvider providerValidXML
- *
- * @param mixed $filename
- * @param mixed $expectedResult
- */
- public function testValidXML($filename, $expectedResult, bool $libxmlDisableEntityLoader): void
- {
- // php 8.+ deprecated libxml_disable_entity_loader() - It's on by default
- if (\PHP_VERSION_ID < 80000) {
- $oldDisableEntityLoaderState = libxml_disable_entity_loader($libxmlDisableEntityLoader);
- }
- $reader = XmlScanner::getInstance(new \PhpOffice\PhpSpreadsheet\Reader\Xml());
- $result = $reader->scanFile($filename);
- self::assertEquals($expectedResult, $result);
- // php 8.+ deprecated libxml_disable_entity_loader() - It's on by default
- if (isset($oldDisableEntityLoaderState)) {
- libxml_disable_entity_loader($oldDisableEntityLoaderState);
- }
- }
- public function providerValidXML(): array
- {
- $tests = [];
- $glob = glob('tests/data/Reader/Xml/XEETestValid*.xml');
- self::assertNotFalse($glob);
- foreach ($glob as $file) {
- $filename = realpath($file);
- $expectedResult = file_get_contents($file);
- $tests[basename($file) . '_libxml_entity_loader_disabled'] = [$filename, $expectedResult, true];
- $tests[basename($file) . '_libxml_entity_loader_enabled'] = [$filename, $expectedResult, false];
- }
- return $tests;
- }
- /**
- * @dataProvider providerInvalidXML
- *
- * @param mixed $filename
- */
- public function testInvalidXML($filename, bool $libxmlDisableEntityLoader): void
- {
- $this->expectException(\PhpOffice\PhpSpreadsheet\Reader\Exception::class);
- // php 8.+ deprecated libxml_disable_entity_loader() - It's on by default
- if (\PHP_VERSION_ID < 80000) {
- libxml_disable_entity_loader($libxmlDisableEntityLoader);
- }
- $reader = XmlScanner::getInstance(new \PhpOffice\PhpSpreadsheet\Reader\Xml());
- $expectedResult = 'FAILURE: Should throw an Exception rather than return a value';
- $result = $reader->scanFile($filename);
- self::assertEquals($expectedResult, $result);
- // php 8.+ deprecated libxml_disable_entity_loader() - It's on by default
- if (\PHP_VERSION_ID < 80000) {
- self::assertEquals($libxmlDisableEntityLoader, libxml_disable_entity_loader());
- }
- }
- public function providerInvalidXML(): array
- {
- $tests = [];
- $glob = glob('tests/data/Reader/Xml/XEETestInvalidUTF*.xml');
- self::assertNotFalse($glob);
- foreach ($glob as $file) {
- $filename = realpath($file);
- $tests[basename($file) . '_libxml_entity_loader_disabled'] = [$filename, true];
- $tests[basename($file) . '_libxml_entity_loader_enabled'] = [$filename, false];
- }
- return $tests;
- }
- public function testGetSecurityScannerForXmlBasedReader(): void
- {
- $fileReader = new Xlsx();
- $scanner = $fileReader->getSecurityScanner();
- // Must return an object...
- self::assertIsObject($scanner);
- // ... of the correct type
- self::assertInstanceOf(XmlScanner::class, $scanner);
- }
- public function testGetSecurityScannerForNonXmlBasedReader(): void
- {
- $fileReader = new Xls();
- $scanner = $fileReader->getSecurityScanner();
- // Must return a null...
- self::assertNull($scanner);
- }
- /**
- * @dataProvider providerValidXMLForCallback
- *
- * @param mixed $filename
- * @param mixed $expectedResult
- */
- public function testSecurityScanWithCallback($filename, $expectedResult): void
- {
- $fileReader = new Xlsx();
- $scanner = $fileReader->getSecurityScanner();
- $scanner->setAdditionalCallback('strrev');
- $xml = $scanner->scanFile($filename);
- self::assertEquals(strrev($expectedResult), $xml);
- }
- public function providerValidXMLForCallback(): array
- {
- $tests = [];
- $glob = glob('tests/data/Reader/Xml/SecurityScannerWithCallback*.xml');
- self::assertNotFalse($glob);
- foreach ($glob as $file) {
- $tests[basename($file)] = [realpath($file), file_get_contents($file)];
- }
- return $tests;
- }
- public function testLibxmlDisableEntityLoaderIsRestoredWithoutShutdown(): void
- {
- $reader = new Xlsx();
- unset($reader);
- $reader = new XMLReader();
- $opened = $reader->open('tests/data/Reader/Xml/SecurityScannerWithCallbackExample.xml');
- self::assertTrue($opened);
- }
- public function testEncodingAllowsMixedCase(): void
- {
- $scanner = new XmlScanner();
- $output = $scanner->scan($input = '<?xml version="1.0" encoding="utf-8"?><foo>bar</foo>');
- self::assertSame($input, $output);
- }
- }
|