From 7b5da9b4af0bcc97ca1e73ce2d49e8fc4d03efc6 Mon Sep 17 00:00:00 2001 From: Pascal Querner Date: Sun, 17 Mar 2024 15:59:35 +0100 Subject: [PATCH] feat: add allow list for regexp; alter tests now includes "-" and "_" as default allowed values next to A-Z (regexp) --- .../Core/Helper/EnvironmentConfigLoader.php | 33 +++-- .../Helper/EnvironmentConfigLoaderTest.php | 129 +++++++++++++----- 2 files changed, 119 insertions(+), 43 deletions(-) diff --git a/app/code/core/Mage/Core/Helper/EnvironmentConfigLoader.php b/app/code/core/Mage/Core/Helper/EnvironmentConfigLoader.php index 14bb7be4c7c..901febc5946 100644 --- a/app/code/core/Mage/Core/Helper/EnvironmentConfigLoader.php +++ b/app/code/core/Mage/Core/Helper/EnvironmentConfigLoader.php @@ -26,6 +26,10 @@ class Mage_Core_Helper_EnvironmentConfigLoader extends Mage_Core_Helper_Abstract protected const CONFIG_KEY_DEFAULT = 'DEFAULT'; protected const CONFIG_KEY_WEBSITES = 'WEBSITES'; protected const CONFIG_KEY_STORES = 'STORES'; + /** + * To be used as regex condition + */ + protected const ALLOWED_CHARS = ['A-Z', '-', '_']; protected array $envStore = []; @@ -61,14 +65,7 @@ public function overrideEnvironment(Varien_Simplexml_Config $xmlConfig) continue; } - $configKeyParts = array_filter( - explode( - static::ENV_KEY_SEPARATOR, - $configKey - ), - 'trim' - ); - list($_, $scope) = $configKeyParts; + list($configKeyParts, $scope) = $this->getConfigKey($configKey); switch ($scope) { case static::CONFIG_KEY_DEFAULT: @@ -88,19 +85,33 @@ public function overrideEnvironment(Varien_Simplexml_Config $xmlConfig) } } + public function getConfigKey(string $configKey): array + { + $configKeyParts = array_filter( + explode( + static::ENV_KEY_SEPARATOR, + $configKey + ), + 'trim' + ); + list($_, $scope) = $configKeyParts; + return array($configKeyParts, $scope); + } + public function isConfigKeyValid(string $configKey): bool { if (!str_starts_with($configKey, static::ENV_STARTS_WITH)) { return false; } - $sectionGroupFieldRegexp = '([A-Z_]*)'; + $sectionGroupFieldRegexp = sprintf('([%s]*)', implode('', static::ALLOWED_CHARS)); + $allowedChars = sprintf('[%s]', implode('', static::ALLOWED_CHARS)); $regexp = '/' . static::ENV_STARTS_WITH . static::ENV_KEY_SEPARATOR . '(WEBSITES' . static::ENV_KEY_SEPARATOR - . '[A-Z_]+|DEFAULT|STORES' . static::ENV_KEY_SEPARATOR . '[A-Z_]+)' + . $allowedChars . '+|DEFAULT|STORES' . static::ENV_KEY_SEPARATOR . $allowedChars . '+)' . static::ENV_KEY_SEPARATOR . $sectionGroupFieldRegexp . static::ENV_KEY_SEPARATOR . $sectionGroupFieldRegexp . static::ENV_KEY_SEPARATOR . $sectionGroupFieldRegexp . '/'; - // /OPENMAGE_CONFIG__(WEBSITES__[A-Z_]+|DEFAULT|STORES__[A-Z_]+)__([A-Z_]*)__([A-Z_]+)__([A-Z_]+)/ + // /OPENMAGE_CONFIG__(WEBSITES__[A-Z-_]+|DEFAULT|STORES__[A-Z-_]+)__([A-Z-_]*)__([A-Z-_]*)__([A-Z-_]*)/ return preg_match($regexp, $configKey); } diff --git a/dev/tests/unit/Mage/Core/Helper/EnvironmentConfigLoaderTest.php b/dev/tests/unit/Mage/Core/Helper/EnvironmentConfigLoaderTest.php index 0d23c829c14..0e9516a8bdc 100644 --- a/dev/tests/unit/Mage/Core/Helper/EnvironmentConfigLoaderTest.php +++ b/dev/tests/unit/Mage/Core/Helper/EnvironmentConfigLoaderTest.php @@ -28,6 +28,16 @@ public function testBuildNodePath() $this->assertEquals('default/general/store_information/name', $nodePath); } + public function test_xml_has_test_strings() + { + $xmlStruct = $this->getTestXml(); + $xml = new \Varien_Simplexml_Config(); + $xml->loadString($xmlStruct); + $this->assertEquals('test_default', (string)$xml->getNode('default/general/store_information/name')); + $this->assertEquals('test_website', (string)$xml->getNode('websites/base/general/store_information/name')); + $this->assertEquals('test_store', (string)$xml->getNode('stores/german/general/store_information/name')); + } + /** * @dataProvider env_overrides_correct_config_keys * @test @@ -41,31 +51,16 @@ public function env_overrides_for_valid_config_keys(array $config) $xml = new \Varien_Simplexml_Config(); $xml->loadString($xmlStruct); - $this->assertEquals('test_default', (string)$xml->getNode('default/general/store_information/name')); - $this->assertEquals('test_website', (string)$xml->getNode('websites/base/general/store_information/name')); - $this->assertEquals('test_store', (string)$xml->getNode('stores/german/general/store_information/name')); - // act $loader = new Mage_Core_Helper_EnvironmentConfigLoader(); $loader->setEnvStore([ - $config['path'] => $config['value'] + $config['env_path'] => $config['value'] ]); $loader->overrideEnvironment($xml); - switch ($config['case']) { - case 'DEFAULT': - $defaultValue = $xmlDefault->getNode('default/general/store_information/name'); - $valueAfterOverride = $xml->getNode('default/general/store_information/name'); - break; - case 'STORE': - $defaultValue = $xmlDefault->getNode('stores/german/general/store_information/name'); - $valueAfterOverride = $xml->getNode('stores/german/general/store_information/name'); - break; - case 'WEBSITE': - $defaultValue = $xmlDefault->getNode('websites/base/general/store_information/name'); - $valueAfterOverride = $xml->getNode('websites/base/general/store_information/name'); - break; - } + $configPath = $config['xml_path']; + $defaultValue = $xmlDefault->getNode($configPath); + $valueAfterOverride = $xml->getNode($configPath); // assert $this->assertNotEquals((string)$defaultValue, (string)$valueAfterOverride, 'Default value was not overridden.'); @@ -74,28 +69,70 @@ public function env_overrides_for_valid_config_keys(array $config) public function env_overrides_correct_config_keys(): array { $defaultPath = 'OPENMAGE_CONFIG__DEFAULT__GENERAL__STORE_INFORMATION__NAME'; + $websitePath = 'OPENMAGE_CONFIG__WEBSITES__BASE__GENERAL__STORE_INFORMATION__NAME'; + $websiteWithDashPath = 'OPENMAGE_CONFIG__WEBSITES__BASE-AT__GENERAL__STORE_INFORMATION__NAME'; + $websiteWithUnderscorePath = 'OPENMAGE_CONFIG__WEBSITES__BASE_CH__GENERAL__STORE_INFORMATION__NAME'; + + $storeWithDashPath = 'OPENMAGE_CONFIG__STORES__GERMAN-AT__GENERAL__STORE_INFORMATION__NAME'; + $storeWithUnderscorePath = 'OPENMAGE_CONFIG__STORES__GERMAN_CH__GENERAL__STORE_INFORMATION__NAME'; $storePath = 'OPENMAGE_CONFIG__STORES__GERMAN__GENERAL__STORE_INFORMATION__NAME'; + return [ [ - 'Case DEFAULT with ' . $defaultPath . ' overrides.' => [ - 'case' => 'DEFAULT', - 'path' => $defaultPath, - 'value' => 'default_new_value' + 'Case DEFAULT overrides.' => [ + 'case' => 'DEFAULT', + 'xml_path' => 'default/general/store_information/name', + 'env_path' => $defaultPath, + 'value' => 'default_new_value' ] ], [ - 'Case STORE with ' . $storePath . ' overrides.' => [ - 'case' => 'STORE', - 'path' => $storePath, - 'value' => 'store_new_value' + 'Case STORE overrides.' => [ + 'case' => 'STORE', + 'xml_path' => 'stores/german/general/store_information/name', + 'env_path' => $storePath, + 'value' => 'store_new_value' ] ], [ - 'Case WEBSITE with ' . $websitePath . ' overrides.' => [ - 'case' => 'WEBSITE', - 'path' => $websitePath, - 'value' => 'website_new_value' + 'Case STORE overrides.' => [ + 'case' => 'STORE', + 'xml_path' => 'stores/german-at/general/store_information/name', + 'env_path' => $storeWithDashPath, + 'value' => 'store_new_value' + ] + ], + [ + 'Case STORE overrides.' => [ + 'case' => 'STORE', + 'xml_path' => 'stores/german_ch/general/store_information/name', + 'env_path' => $storeWithUnderscorePath, + 'value' => 'store_new_value' + ] + ], + [ + 'Case WEBSITE overrides.' => [ + 'case' => 'WEBSITE', + 'xml_path' => 'websites/base/general/store_information/name', + 'env_path' => $websitePath, + 'value' => 'website_new_value' + ] + ], + [ + 'Case WEBSITE overrides.' => [ + 'case' => 'WEBSITE', + 'xml_path' => 'websites/base_ch/general/store_information/name', + 'env_path' => $websiteWithUnderscorePath, + 'value' => 'website_new_value' + ] + ], + [ + 'Case WEBSITE overrides.' => [ + 'case' => 'WEBSITE', + 'xml_path' => 'websites/base-at/general/store_information/name', + 'env_path' => $websiteWithDashPath, + 'value' => 'website_new_value' ] ] ]; @@ -105,7 +142,7 @@ public function env_overrides_correct_config_keys(): array * @dataProvider env_does_not_override_on_wrong_config_keys * @test */ - public function env_does_not_override_for_valid_config_keys(array $config) + public function env_does_not_override_for_invalid_config_keys(array $config) { $xmlStruct = $this->getTestXml(); @@ -198,6 +235,20 @@ public function getTestXml(): string + + + + test_website + + + + + + + test_website + + + @@ -207,6 +258,20 @@ public function getTestXml(): string + + + + test_store + + + + + + + test_store + + + XML;