From 04a5e89054b1fac29d00fa14a65dc8a6bf0bf952 Mon Sep 17 00:00:00 2001 From: Makar Sichevoi Date: Thu, 9 Nov 2023 09:04:37 +0200 Subject: [PATCH] fix: feature flag for xml editor --- config/default/xmlEditor.conf.php | 2 - .../unit/models/classes/xml/XmlEditorTest.php | 79 +++++++++++++------ 2 files changed, 55 insertions(+), 26 deletions(-) diff --git a/config/default/xmlEditor.conf.php b/config/default/xmlEditor.conf.php index 13ee5af7a..6ae74cd75 100644 --- a/config/default/xmlEditor.conf.php +++ b/config/default/xmlEditor.conf.php @@ -20,8 +20,6 @@ * */ -declare(strict_types=1); - use oat\taoQtiTest\models\xmlEditor\XmlEditor; return [XmlEditor::OPTION_XML_EDITOR_LOCK => true]; diff --git a/test/unit/models/classes/xml/XmlEditorTest.php b/test/unit/models/classes/xml/XmlEditorTest.php index bd00d89d9..723b84633 100644 --- a/test/unit/models/classes/xml/XmlEditorTest.php +++ b/test/unit/models/classes/xml/XmlEditorTest.php @@ -20,11 +20,13 @@ namespace oat\taoQtiTest\test\unit\models\classes\xml; +use common_ext_Extension; +use common_ext_ExtensionsManager; use core_kernel_classes_Resource; -use oat\generis\test\TestCase; use oat\tao\model\featureFlag\FeatureFlagChecker; use oat\taoQtiTest\models\xmlEditor\XmlEditor; use PHPUnit\Framework\MockObject\MockObject; +use PHPUnit\Framework\TestCase as UnitTestCase; use qtism\data\storage\xml\XmlDocument; use qtism\data\storage\xml\XmlStorageException; use SplObjectStorage; @@ -33,7 +35,7 @@ use taoQtiTest_models_classes_QtiTestServiceException; use Zend\ServiceManager\ServiceLocatorInterface; -class XmlEditorTest extends TestCase +class XmlEditorTest extends UnitTestCase { /** @var XmlDocument */ private $xmlDoc; @@ -41,8 +43,11 @@ class XmlEditorTest extends TestCase /** @var core_kernel_classes_Resource|MockObject */ private $testResourceMock; - /** @var ServiceLocatorInterface */ - private $serviceLocatorMock; + /** @var common_ext_ExtensionsManager|MockObject */ + private $extensionsManagerMock; + + /** @var common_ext_Extension|MockObject */ + private $extensionMock; /** @var taoQtiTest_models_classes_QtiTestService|MockObject */ private $qtiTestServiceMock; @@ -57,26 +62,34 @@ public function setUp(): void $this->xmlDoc = $doc; $this->testResourceMock = $this->createMock(core_kernel_classes_Resource::class); - + $this->extensionMock = $this->createMock(common_ext_Extension::class); + $this->extensionsManagerMock = $this->createMock(common_ext_ExtensionsManager::class); + $this->extensionsManagerMock + ->expects(self::once()) + ->method('getExtensionById') + ->with('taoQtiTest') + ->willReturn($this->extensionMock); $this->qtiTestServiceMock = $this->createMock(taoQtiTest_models_classes_QtiTestService::class); $this->qtiTestServiceMock ->method('getDoc') ->with($this->testResourceMock) ->willReturn($this->xmlDoc); - $this->featureFlagCheckerMock = $this->createMock(FeatureFlagChecker::class); - - $this->serviceLocatorMock = $this->getServiceLocatorMock([ - taoQtiTest_models_classes_QtiTestService::class => $this->qtiTestServiceMock, - FeatureFlagChecker::class => $this->featureFlagCheckerMock, - ]); } public function testGetTestXml() { - $service = new XmlEditor(); - $service->setServiceLocator($this->serviceLocatorMock); - $xmlString = $service->getTestXml($this->testResourceMock); + $this->extensionMock + ->expects(self::once()) + ->method('getConfig') + ->with('xmlEditor') + ->willReturn([XmlEditor::OPTION_XML_EDITOR_LOCK => true]); + + $serviceXmlEditor = new XmlEditor( + $this->extensionsManagerMock, $this->qtiTestServiceMock, $this->featureFlagCheckerMock + ); + + $xmlString = $serviceXmlEditor->getTestXml($this->testResourceMock); $this->assertEquals($this->xmlDoc->saveToString(), $xmlString); } @@ -87,15 +100,27 @@ public function testGetTestXml() */ public function testSaveStringTest() { - $service = new XmlEditor(); + $this->extensionMock + ->expects(self::once()) + ->method('getConfig') + ->with('xmlEditor') + ->willReturn([XmlEditor::OPTION_XML_EDITOR_LOCK => true]); + + $serviceXmlEditor = new XmlEditor( + $this->extensionsManagerMock, $this->qtiTestServiceMock, $this->featureFlagCheckerMock + ); // phpcs:disable Generic.Files.LineLength $xmlMock = <<<'EOL' - + - - + + EOL; @@ -164,20 +189,26 @@ public function testSaveStringTest() ->method('saveJsonTest') ->with($this->testResourceMock, json_encode($expectArrayTest)); - $service->setServiceLocator($this->serviceLocatorMock); - $service->saveStringTest($this->testResourceMock, $xmlMock); + $serviceXmlEditor->saveStringTest($this->testResourceMock, $xmlMock); } public function testIsLocked() { - $service = new XmlEditor([XmlEditor::OPTION_XML_EDITOR_LOCK => false]); - $service->setServiceLocator($this->serviceLocatorMock); + $this->extensionMock + ->expects(self::once()) + ->method('getConfig') + ->with('xmlEditor') + ->willReturn([XmlEditor::OPTION_XML_EDITOR_LOCK => false]); + + $serviceXmlEditor = new XmlEditor( + $this->extensionsManagerMock, $this->qtiTestServiceMock, $this->featureFlagCheckerMock + ); $this->featureFlagCheckerMock ->method('isEnabled') - ->with('XML_EDITOR_ENABLED') + ->with('FEATURE_FLAG_XML_EDITOR_ENABLED') ->willReturn(true); - $this->assertEquals(false, $service->isLocked()); + $this->assertEquals(false, $serviceXmlEditor->isLocked()); } }