123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081 |
- <?php
- /**
- * Copyright © Magento, Inc. All rights reserved.
- * See COPYING.txt for license details.
- */
- namespace Magento\Framework\Xml\Test\Unit;
- use Magento\Framework\Xml\Security;
- /**
- * Class SecurityTest
- *
- * Test for class \Magento\Framework\Xml\Security
- */
- class SecurityTest extends \PHPUnit\Framework\TestCase
- {
- /**
- * @var Security
- */
- protected $security;
- /**
- * Set up
- *
- * @return void
- */
- protected function setUp()
- {
- $this->security = new Security();
- }
- /**
- * Run test scan method
- *
- * @param string $xmlContent
- * @param bool $expectedResult
- *
- * @dataProvider dataProviderTestScan
- */
- public function testScan($xmlContent, $expectedResult)
- {
- $this->assertEquals($expectedResult, $this->security->scan($xmlContent));
- }
- /**
- * Data provider for testScan
- *
- * @return array
- */
- public function dataProviderTestScan()
- {
- return [
- [
- 'xmlContent' => '<?xml version="1.0"?><test></test>',
- 'expectedResult' => true
- ],
- [
- 'xmlContent' => '<!DOCTYPE note SYSTEM "Note.dtd"><?xml version="1.0"?><test></test>',
- 'expectedResult' => false
- ],
- [
- 'xmlContent' => '<?xml version="1.0"?>
- <!DOCTYPE test [
- <!ENTITY value "value">
- <!ENTITY value1 "&value;&value;&value;&value;&value;&value;&value;&value;&value;&value;">
- <!ENTITY value2 "&value1;&value1;&value1;&value1;&value1;&value1;&value1;&value1;&value1;&value1;">
- ]>
- <test>&value2;</test>',
- 'expectedResult' => false
- ],
- [
- 'xmlContent' => '<!DOCTYPE html><?xml version="1.0"?><test></test>',
- 'expectedResult' => false
- ],
- [
- 'xmlContent' => '',
- 'expectedResult' => false
- ]
- ];
- }
- }
|