123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218 |
- <?php
- /*
- * This file is part of the Symfony package.
- *
- * (c) Fabien Potencier <fabien@symfony.com>
- *
- * For the full copyright and license information, please view the LICENSE
- * file that was distributed with this source code.
- */
- namespace Symfony\Component\Config\Tests\Util;
- use PHPUnit\Framework\TestCase;
- use Symfony\Component\Config\Util\XmlUtils;
- class XmlUtilsTest extends TestCase
- {
- public function testLoadFile()
- {
- $fixtures = __DIR__.'/../Fixtures/Util/';
- try {
- XmlUtils::loadFile($fixtures.'invalid.xml');
- $this->fail();
- } catch (\InvalidArgumentException $e) {
- $this->assertContains('ERROR 77', $e->getMessage());
- }
- try {
- XmlUtils::loadFile($fixtures.'document_type.xml');
- $this->fail();
- } catch (\InvalidArgumentException $e) {
- $this->assertContains('Document types are not allowed', $e->getMessage());
- }
- try {
- XmlUtils::loadFile($fixtures.'invalid_schema.xml', $fixtures.'schema.xsd');
- $this->fail();
- } catch (\InvalidArgumentException $e) {
- $this->assertContains('ERROR 1845', $e->getMessage());
- }
- try {
- XmlUtils::loadFile($fixtures.'invalid_schema.xml', 'invalid_callback_or_file');
- $this->fail();
- } catch (\InvalidArgumentException $e) {
- $this->assertContains('XSD file or callable', $e->getMessage());
- }
- $mock = $this->getMockBuilder(__NAMESPACE__.'\Validator')->getMock();
- $mock->expects($this->exactly(2))->method('validate')->will($this->onConsecutiveCalls(false, true));
- try {
- XmlUtils::loadFile($fixtures.'valid.xml', [$mock, 'validate']);
- $this->fail();
- } catch (\InvalidArgumentException $e) {
- $this->assertRegExp('/The XML file ".+" is not valid\./', $e->getMessage());
- }
- $this->assertInstanceOf('DOMDocument', XmlUtils::loadFile($fixtures.'valid.xml', [$mock, 'validate']));
- $this->assertSame([], libxml_get_errors());
- }
- /**
- * @expectedException \Symfony\Component\Config\Util\Exception\InvalidXmlException
- * @expectedExceptionMessage The XML is not valid
- */
- public function testParseWithInvalidValidatorCallable()
- {
- $fixtures = __DIR__.'/../Fixtures/Util/';
- $mock = $this->getMockBuilder(__NAMESPACE__.'\Validator')->getMock();
- $mock->expects($this->once())->method('validate')->willReturn(false);
- XmlUtils::parse(file_get_contents($fixtures.'valid.xml'), [$mock, 'validate']);
- }
- public function testLoadFileWithInternalErrorsEnabled()
- {
- $internalErrors = libxml_use_internal_errors(true);
- $this->assertSame([], libxml_get_errors());
- $this->assertInstanceOf('DOMDocument', XmlUtils::loadFile(__DIR__.'/../Fixtures/Util/invalid_schema.xml'));
- $this->assertSame([], libxml_get_errors());
- libxml_clear_errors();
- libxml_use_internal_errors($internalErrors);
- }
- /**
- * @dataProvider getDataForConvertDomToArray
- */
- public function testConvertDomToArray($expected, $xml, $root = false, $checkPrefix = true)
- {
- $dom = new \DOMDocument();
- $dom->loadXML($root ? $xml : '<root>'.$xml.'</root>');
- $this->assertSame($expected, XmlUtils::convertDomElementToArray($dom->documentElement, $checkPrefix));
- }
- public function getDataForConvertDomToArray()
- {
- return [
- [null, ''],
- ['bar', 'bar'],
- [['bar' => 'foobar'], '<foo bar="foobar" />', true],
- [['foo' => null], '<foo />'],
- [['foo' => 'bar'], '<foo>bar</foo>'],
- [['foo' => ['foo' => 'bar']], '<foo foo="bar"/>'],
- [['foo' => ['foo' => 0]], '<foo><foo>0</foo></foo>'],
- [['foo' => ['foo' => 'bar']], '<foo><foo>bar</foo></foo>'],
- [['foo' => ['foo' => 'bar', 'value' => 'text']], '<foo foo="bar">text</foo>'],
- [['foo' => ['attr' => 'bar', 'foo' => 'text']], '<foo attr="bar"><foo>text</foo></foo>'],
- [['foo' => ['bar', 'text']], '<foo>bar</foo><foo>text</foo>'],
- [['foo' => [['foo' => 'bar'], ['foo' => 'text']]], '<foo foo="bar"/><foo foo="text" />'],
- [['foo' => ['foo' => ['bar', 'text']]], '<foo foo="bar"><foo>text</foo></foo>'],
- [['foo' => 'bar'], '<foo><!-- Comment -->bar</foo>'],
- [['foo' => 'text'], '<foo xmlns:h="http://www.example.org/bar" h:bar="bar">text</foo>'],
- [['foo' => ['bar' => 'bar', 'value' => 'text']], '<foo xmlns:h="http://www.example.org/bar" h:bar="bar">text</foo>', false, false],
- [['attr' => 1, 'b' => 'hello'], '<foo:a xmlns:foo="http://www.example.org/foo" xmlns:h="http://www.example.org/bar" attr="1" h:bar="bar"><foo:b>hello</foo:b><h:c>2</h:c></foo:a>', true],
- ];
- }
- /**
- * @dataProvider getDataForPhpize
- */
- public function testPhpize($expected, $value)
- {
- $this->assertSame($expected, XmlUtils::phpize($value));
- }
- public function getDataForPhpize()
- {
- return [
- ['', ''],
- [null, 'null'],
- [true, 'true'],
- [false, 'false'],
- [null, 'Null'],
- [true, 'True'],
- [false, 'False'],
- [0, '0'],
- [1, '1'],
- [-1, '-1'],
- [0777, '0777'],
- [255, '0xFF'],
- [100.0, '1e2'],
- [-120.0, '-1.2E2'],
- [-10100.1, '-10100.1'],
- ['-10,100.1', '-10,100.1'],
- ['1234 5678 9101 1121 3141', '1234 5678 9101 1121 3141'],
- ['1,2,3,4', '1,2,3,4'],
- ['11,22,33,44', '11,22,33,44'],
- ['11,222,333,4', '11,222,333,4'],
- ['1,222,333,444', '1,222,333,444'],
- ['11,222,333,444', '11,222,333,444'],
- ['111,222,333,444', '111,222,333,444'],
- ['1111,2222,3333,4444,5555', '1111,2222,3333,4444,5555'],
- ['foo', 'foo'],
- [6, '0b0110'],
- ];
- }
- public function testLoadEmptyXmlFile()
- {
- $file = __DIR__.'/../Fixtures/foo.xml';
- if (method_exists($this, 'expectException')) {
- $this->expectException('InvalidArgumentException');
- $this->expectExceptionMessage(sprintf('File %s does not contain valid XML, it is empty.', $file));
- } else {
- $this->setExpectedException('InvalidArgumentException', sprintf('File %s does not contain valid XML, it is empty.', $file));
- }
- XmlUtils::loadFile($file);
- }
- // test for issue https://github.com/symfony/symfony/issues/9731
- public function testLoadWrongEmptyXMLWithErrorHandler()
- {
- $originalDisableEntities = libxml_disable_entity_loader(false);
- $errorReporting = error_reporting(-1);
- set_error_handler(function ($errno, $errstr) {
- throw new \Exception($errstr, $errno);
- });
- $file = __DIR__.'/../Fixtures/foo.xml';
- try {
- try {
- XmlUtils::loadFile($file);
- $this->fail('An exception should have been raised');
- } catch (\InvalidArgumentException $e) {
- $this->assertEquals(sprintf('File %s does not contain valid XML, it is empty.', $file), $e->getMessage());
- }
- } finally {
- restore_error_handler();
- error_reporting($errorReporting);
- }
- $disableEntities = libxml_disable_entity_loader(true);
- libxml_disable_entity_loader($disableEntities);
- libxml_disable_entity_loader($originalDisableEntities);
- $this->assertFalse($disableEntities);
- // should not throw an exception
- XmlUtils::loadFile(__DIR__.'/../Fixtures/Util/valid.xml', __DIR__.'/../Fixtures/Util/schema.xsd');
- }
- }
- interface Validator
- {
- public function validate();
- }
|