diff --git a/.github/workflows/main.yml b/.github/workflows/main.yml index 34ab0e8..a445051 100644 --- a/.github/workflows/main.yml +++ b/.github/workflows/main.yml @@ -13,7 +13,7 @@ jobs: strategy: matrix: operating-system: [ubuntu-latest] - php-versions: ['5.6', '7.0', '7.1', '7.2', '7.3', '7.4'] + php-versions: [ '7.4', '8.0', '8.1', '8.2', '8.3' ] name: PHP ${{ matrix.php-versions }} Test on ${{ matrix.operating-system }} steps: - name: Checkout @@ -38,18 +38,14 @@ jobs: - name: Run scripts run: | mkdir -p build/logs - ./vendor/bin/phpunit --coverage-clover build/logs/clover.xml - - name: Coverage - env: - COVERALLS_REPO_TOKEN: ${{ secrets.GITHUB_TOKEN }} - run: vendor/bin/php-coveralls -v + composer run-script test - name: Notification if: always() id: slack uses: wingify/slack-github-action@v1.15.1-wingify with: - channel-id: "fs-review-team" - slack-message: " Test on *PHP-${{ matrix.php-versions }}* and *${{ matrix.operating-system }}* got *${{job.status}}* ${{job.status == 'success' && ':heavy_check_mark:' || ':x:'}} \nCommit: `${{github.event.head_commit.message}}`. \nCheck the latest build: https://github.com/wingify/vwo-php-sdk/actions" + channel-id: "vwo-fs-fme-sdk-job-status" + slack-message: " Test on *PHP-${{ matrix.php-versions }}* and *${{ matrix.operating-system }}* got *${{job.status}}* ${{job.status == 'success' && ':heavy_check_mark:' || ':x:'}} \nCommit: `${{github.event.head_commit.message}}`. \nCheck the latest build: https://github.com/wingify/vwo-fme-php-sdk/actions" color: "${{job.status == 'success' && '#00FF00' || '#FF0000'}}" env: SLACK_BOT_TOKEN: ${{ secrets.SLACK_NOTIFICATIONS_BOT_TOKEN }} diff --git a/.gitignore b/.gitignore index fecec65..8c493af 100644 --- a/.gitignore +++ b/.gitignore @@ -6,3 +6,4 @@ composer.phar composer.lock coverage/ .vscode/ +*.cache diff --git a/composer.json b/composer.json index edc3ffa..a8e1b8a 100644 --- a/composer.json +++ b/composer.json @@ -1,6 +1,6 @@ { "name": "vwo/vwo-fme-php-sdk", - "version": "1.1.0", + "version": "1.2.0", "keywords": ["vwo", "fme", "sdk"], "license": "Apache-2.0", "authors": [{ @@ -32,6 +32,6 @@ "test": ["./vendor/bin/phpunit"] }, "require-dev": { - "phpunit/phpunit": "^11.2" + "phpunit/phpunit": "^9.5" } } diff --git a/src/Packages/SegmentationEvaluator/Evaluators/SegmentOperandEvaluator.php b/src/Packages/SegmentationEvaluator/Evaluators/SegmentOperandEvaluator.php index fbb1eab..6081c6d 100644 --- a/src/Packages/SegmentationEvaluator/Evaluators/SegmentOperandEvaluator.php +++ b/src/Packages/SegmentationEvaluator/Evaluators/SegmentOperandEvaluator.php @@ -188,7 +188,12 @@ public function extractResult($operandType, $operandValue, $tagValue) { } break; case SegmentOperandValueEnum::REGEX_VALUE: - $result = preg_match('/' . $operandValue . '/', $tagValue); + // Check if operandValue is a valid regex pattern + if (@preg_match('/' . $operandValue . '/', '') === false) { + $result = false; + } else { + $result = preg_match('/' . $operandValue . '/', $tagValue); + } break; case SegmentOperandValueEnum::EQUAL_VALUE: $result = $tagValue === $operandValue; @@ -200,4 +205,4 @@ public function extractResult($operandType, $operandValue, $tagValue) { return $result; } -} +} \ No newline at end of file diff --git a/src/Services/CampaignDecisionService.php b/src/Services/CampaignDecisionService.php index 17e6118..1bfbf36 100644 --- a/src/Services/CampaignDecisionService.php +++ b/src/Services/CampaignDecisionService.php @@ -94,9 +94,10 @@ public function getDecision($campaign, $settings, $context) { LogManager::instance()->debug("For userId:{$context['user']['id']} of Campaign:{$campaign->getKey()}, segment was missing, hence skipping segmentation"); return true; } else { + $customVariables = isset($context['user']['customVariables']) ? $context['user']['customVariables'] : []; $preSegmentationResult = SegmentationManager::Instance()->validateSegmentation( $segments, - $context['user']['customVariables'], + $customVariables, $settings, $context['user'] // array( diff --git a/tests/e2e/GetFlagTest.php b/tests/e2e/GetFlagTest.php index 3b5b6c6..a565b8c 100644 --- a/tests/e2e/GetFlagTest.php +++ b/tests/e2e/GetFlagTest.php @@ -86,43 +86,60 @@ protected function runSingleTest($testData, $storageMap = null) if ($storageMap !== null) { $storageData = $storageMap->get($testData['featureKey'], $testData['context']['id']); - $this->assertNull($storageData['rolloutKey']); - $this->assertNull($storageData['rolloutVariationId']); - $this->assertNull($storageData['experimentKey']); - $this->assertNull($storageData['experimentVariationId']); + if ($storageData === null) { + $this->assertNull($storageData); + } else { + $this->assertNull($storageData['rolloutKey']); + $this->assertNull($storageData['rolloutVariationId']); + $this->assertNull($storageData['experimentKey']); + $this->assertNull($storageData['experimentVariationId']); + } } $featureFlag = $vwoClient->getFlag($testData['featureKey'], $testData['context']); - $this->assertEquals($testData['expectation']['isEnabled'], $featureFlag->isEnabled()); + $this->assertEquals($testData['expectation']['isEnabled'], $featureFlag->isEnabled()); $this->assertEquals($testData['expectation']['intVariable'], $featureFlag->getVariable('int', 1)); - $this->assertEquals($testData['expectation']['stringVariable'], $featureFlag->getVariable('string', 'VWO')); - $this->assertEquals($testData['expectation']['floatVariable'], $featureFlag->getVariable('float', 1.1)); + $this->assertEquals($testData['expectation']['stringVariable'], $featureFlag->getVariable('string', 'VWO')); + $this->assertEquals($testData['expectation']['floatVariable'], $featureFlag->getVariable('float', 1.1)); $this->assertEquals($testData['expectation']['booleanVariable'], $featureFlag->getVariable('boolean', false)); - $this->assertEquals($testData['expectation']['jsonVariable'], json_decode(json_encode($featureFlag->getVariable('json', [])), true)); + $this->assertEquals($testData['expectation']['jsonVariable'], json_decode(json_encode($featureFlag->getVariable('json', [])), true)); if ($storageMap !== null) { $storageData = $storageMap->get($testData['featureKey'], $testData['context']['id']); - $this->assertEquals($testData['expectation']['storageData']['rolloutKey'], $storageData['rolloutKey']); - $this->assertEquals($testData['expectation']['storageData']['rolloutVariationId'], $storageData['rolloutVariationId']); - $this->assertEquals($testData['expectation']['storageData']['experimentKey'], $storageData['experimentKey']); - $this->assertEquals($testData['expectation']['storageData']['experimentVariationId'], $storageData['experimentVariationId']); + if ($storageData !== null) { + if (isset($testData['expectation']['storageData']['rolloutKey'])) { + $this->assertEquals($testData['expectation']['storageData']['rolloutKey'], $storageData['rolloutKey']); + } + if (isset($testData['expectation']['storageData']['rolloutVariationId'])) { + $this->assertEquals($testData['expectation']['storageData']['rolloutVariationId'], $storageData['rolloutVariationId']); + } + if (isset($testData['expectation']['storageData']['experimentKey'])) { + $this->assertEquals($testData['expectation']['storageData']['experimentKey'], $storageData['experimentKey']); + } + if (isset($testData['expectation']['storageData']['experimentVariationId'])) { + $this->assertEquals($testData['expectation']['storageData']['experimentVariationId'], $storageData['experimentVariationId']); + } + } } } } -class TestStorageService { +class TestStorageService +{ private $map = []; - public function get($featureKey, $userId) { + public function get($featureKey, $userId) + { $key = $featureKey . '_' . $userId; //echo 'Stored data: ' . $key . "\n"; return isset($this->map[$key]) ? $this->map[$key] : null; } - public function set($data) { + public function set($data) + { $key = $data['featureKey'] . '_' . $data['user']; //echo 'Data to store: ' . json_encode($data) . "\n"; - + $this->map[$key] = [ 'rolloutKey' => $data['rolloutKey'], 'rolloutVariationId' => $data['rolloutVariationId'], @@ -132,4 +149,4 @@ public function set($data) { //dump("data in set", $this->map[$key]); return true; } -} +} \ No newline at end of file