From 5b37c6012bf8aa2559cdfa6bc0eef90171c7ca14 Mon Sep 17 00:00:00 2001 From: Anton Fedurtsya Date: Tue, 14 Nov 2023 16:31:16 +0200 Subject: [PATCH] OXDEV-7557 Fix possible collection encoding error Signed-off-by: Anton Fedurtsya --- .../Exception/CollectionEncodingException.php | 14 +++++++ src/Setting/Service/ThemeSettingService.php | 24 ++++++++++-- .../Unit/Service/ThemeSettingServiceTest.php | 39 +++++++++++++++++-- 3 files changed, 69 insertions(+), 8 deletions(-) create mode 100644 src/Setting/Exception/CollectionEncodingException.php diff --git a/src/Setting/Exception/CollectionEncodingException.php b/src/Setting/Exception/CollectionEncodingException.php new file mode 100644 index 0000000..6154a00 --- /dev/null +++ b/src/Setting/Exception/CollectionEncodingException.php @@ -0,0 +1,14 @@ +themeSettingRepository->getCollection($name, $themeId); - return new StringSetting($name, json_encode($collectionString)); + $collection = $this->themeSettingRepository->getCollection($name, $themeId); + + return new StringSetting($name, $this->jsonEncodeCollection($collection)); } public function getAssocCollectionSetting(ID $name, string $themeId): StringSetting { - $assocCollectionString = $this->themeSettingRepository->getAssocCollection($name, $themeId); - return new StringSetting($name, json_encode($assocCollectionString)); + $assocCollection = $this->themeSettingRepository->getAssocCollection($name, $themeId); + + return new StringSetting($name, $this->jsonEncodeCollection($assocCollection)); + } + + /** + * @throws CollectionEncodingException + */ + private function jsonEncodeCollection(array $collection): string + { + $jsonValue = json_encode($collection); + + if ($jsonValue === false) { + throw new CollectionEncodingException(); + } + return $jsonValue; } /** diff --git a/tests/Unit/Service/ThemeSettingServiceTest.php b/tests/Unit/Service/ThemeSettingServiceTest.php index d3b2651..bbd5b6e 100644 --- a/tests/Unit/Service/ThemeSettingServiceTest.php +++ b/tests/Unit/Service/ThemeSettingServiceTest.php @@ -3,6 +3,7 @@ namespace OxidEsales\GraphQL\ConfigurationAccess\Tests\Unit\Service; use OxidEsales\GraphQL\ConfigurationAccess\Setting\Enum\FieldType; +use OxidEsales\GraphQL\ConfigurationAccess\Setting\Exception\CollectionEncodingException; use OxidEsales\GraphQL\ConfigurationAccess\Setting\Exception\InvalidCollection; use OxidEsales\GraphQL\ConfigurationAccess\Setting\Infrastructure\ThemeSettingRepositoryInterface; use OxidEsales\GraphQL\ConfigurationAccess\Setting\Service\ThemeSettingService; @@ -99,16 +100,18 @@ public function testGetThemeSettingSelect(): void public function testGetThemeSettingCollection(): void { $serviceCollectionSetting = $this->getCollectionSetting(); + $nameID = new ID('arraySetting'); + $themeId = 'awesomeTheme'; $repository = $this->createMock(ThemeSettingRepositoryInterface::class); $repository->expects($this->once()) ->method('getCollection') + ->with($nameID, $themeId) ->willReturn(['nice', 'values']); $settingService = new ThemeSettingService($repository); - $nameID = new ID('arraySetting'); - $collectionSetting = $settingService->getCollectionSetting($nameID, 'awesomeTheme'); + $collectionSetting = $settingService->getCollectionSetting($nameID, $themeId); $this->assertEquals($serviceCollectionSetting, $collectionSetting); } @@ -116,20 +119,48 @@ public function testGetThemeSettingCollection(): void public function testGetThemeSettingAssocCollection(): void { $serviceAssocCollectionSetting = $this->getAssocCollectionSetting(); + $nameID = new ID('aarraySetting'); + $themeId = 'awesomeTheme'; $repository = $this->createMock(ThemeSettingRepositoryInterface::class); $repository->expects($this->once()) ->method('getAssocCollection') + ->with($nameID, $themeId) ->willReturn(['first' => '10', 'second' => '20', 'third' => '50']); $settingService = new ThemeSettingService($repository); - $nameID = new ID('aarraySetting'); - $assocCollectionSetting = $settingService->getAssocCollectionSetting($nameID, 'awesomeTheme'); + $assocCollectionSetting = $settingService->getAssocCollectionSetting($nameID, $themeId); $this->assertEquals($serviceAssocCollectionSetting, $assocCollectionSetting); } + /** @dataProvider collectionEncodingExceptionDataProvider */ + public function testCollectionEncodingExceptionThrown(string $repositoryMethod, string $serviceMethod): void + { + $nameID = new ID('arraySetting'); + $themeId = 'awesomeTheme'; + $repositoryResponse = [&$repositoryResponse]; + + $repository = $this->createMock(ThemeSettingRepositoryInterface::class); + $repository->expects($this->once()) + ->method($repositoryMethod) + ->with($nameID, $themeId) + ->willReturn($repositoryResponse); + + $sut = new ThemeSettingService($repository); + + $this->expectException(CollectionEncodingException::class); + + $sut->$serviceMethod($nameID, $themeId); + } + + public function collectionEncodingExceptionDataProvider(): \Generator + { + yield ['repositoryMethod' => 'getCollection', 'serviceMethod' => 'getCollectionSetting']; + yield ['repositoryMethod' => 'getAssocCollection', 'serviceMethod' => 'getAssocCollectionSetting']; + } + public function testListThemeSettings(): void { $themeId = 'awesomeTheme';