From 3fd73a279d2705714ca545f37cfe13805027dea5 Mon Sep 17 00:00:00 2001 From: Mike Chu <104384559+mikechu-optimizely@users.noreply.github.com> Date: Thu, 10 Aug 2023 17:28:00 -0400 Subject: [PATCH] [FSSDK-9573] Fix: Deprecation warning (#279) * Add PHP pack ext * Add missing field definition * Add missing field definition * Add phpunit test runner ext * Change to use consistent _privateFieldNaming * Add gitlens * Fix rename Didn't have a proper refactor ext/function * Update copyright header * Refactor CI slightly * Add back EOL for file --- .devcontainer/devcontainer.json | 5 +++- .github/workflows/php.yml | 25 +++++++++++-------- .../HTTPProjectConfigManager.php | 21 ++++++++++------ 3 files changed, 32 insertions(+), 19 deletions(-) diff --git a/.devcontainer/devcontainer.json b/.devcontainer/devcontainer.json index 8730012b..81a3f58d 100644 --- a/.devcontainer/devcontainer.json +++ b/.devcontainer/devcontainer.json @@ -18,7 +18,10 @@ "extensions": [ "bmewburn.vscode-intelephense-client", "xdebug.php-debug", - "DEVSENSE.composer-php-vscode" + "DEVSENSE.composer-php-vscode", + "xdebug.php-pack", + "recca0120.vscode-phpunit", + "eamodio.gitlens" ] } } diff --git a/.github/workflows/php.yml b/.github/workflows/php.yml index 574c3a53..109abb8a 100644 --- a/.github/workflows/php.yml +++ b/.github/workflows/php.yml @@ -11,7 +11,8 @@ jobs: name: Linting runs-on: ubuntu-latest steps: - - uses: actions/checkout@v3 + - name: Checkout code + uses: actions/checkout@v3 - name: Set up PHP uses: shivammathur/setup-php@v2 with: @@ -25,28 +26,24 @@ jobs: name: Source Clear Scan runs-on: ubuntu-latest steps: - - uses: actions/checkout@v2 + - name: Checkout code + uses: actions/checkout@v3 - name: Source clear scan env: SRCCLR_API_TOKEN: ${{ secrets.SRCCLR_API_TOKEN }} run: curl -sSL https://download.sourceclear.com/ci.sh | bash -s – scan - integration_tests: - name: Integration Tests - uses: optimizely/php-sdk/.github/workflows/integration_test.yml@master - secrets: - CI_USER_TOKEN: ${{ secrets.CI_USER_TOKEN }} - TRAVIS_COM_TOKEN: ${{ secrets.TRAVIS_COM_TOKEN }} - unit_tests: name: Unit Tests ${{ matrix.php-versions }} + needs: [ linting, source_clear ] runs-on: ubuntu-latest strategy: fail-fast: false matrix: php-versions: [ '8.1', '8.2' ] steps: - - uses: actions/checkout@v3 + - name: Checkout code + uses: actions/checkout@v3 - name: Set up PHP v${{ matrix.php-versions }} uses: shivammathur/setup-php@v2 with: @@ -77,3 +74,11 @@ jobs: run: | composer global require php-coveralls/php-coveralls php-coveralls --coverage_clover=./build/logs/clover.xml -v + + integration_tests: + name: Integration Tests + needs: [ unit_tests ] + uses: optimizely/php-sdk/.github/workflows/integration_test.yml@master + secrets: + CI_USER_TOKEN: ${{ secrets.CI_USER_TOKEN }} + TRAVIS_COM_TOKEN: ${{ secrets.TRAVIS_COM_TOKEN }} diff --git a/src/Optimizely/ProjectConfigManager/HTTPProjectConfigManager.php b/src/Optimizely/ProjectConfigManager/HTTPProjectConfigManager.php index 7b962aee..83e5f839 100644 --- a/src/Optimizely/ProjectConfigManager/HTTPProjectConfigManager.php +++ b/src/Optimizely/ProjectConfigManager/HTTPProjectConfigManager.php @@ -1,12 +1,12 @@ _logger = $logger ?: new NoOpLogger(); $this->_errorHandler = $errorHandler ?: new NoOpErrorHandler(); $this->_notificationCenter = $notificationCenter ?: new NotificationCenter($this->_logger, $this->_errorHandler); - $this->datafileAccessToken = $datafileAccessToken; - $this->isDatafileAccessTokenValid = Validator::validateNonEmptyString($this->datafileAccessToken); + $this->_datafileAccessToken = $datafileAccessToken; + $this->_isDatafileAccessTokenValid = Validator::validateNonEmptyString($this->_datafileAccessToken); $this->httpClient = new HttpClient(); $this->_url = $this->getUrl($sdkKey, $url, $urlTemplate); @@ -136,7 +141,7 @@ protected function getUrl($sdkKey, $url, $urlTemplate) } if (!Validator::validateNonEmptyString($urlTemplate)) { - if ($this->isDatafileAccessTokenValid) { + if ($this->_isDatafileAccessTokenValid) { $urlTemplate = ProjectConfigManagerConstants::AUTHENTICATED_DATAFILE_URL_TEMPLATE; } else { $urlTemplate = ProjectConfigManagerConstants::DEFAULT_DATAFILE_URL_TEMPLATE; @@ -179,8 +184,8 @@ protected function fetchDatafile() } // Add Authorization header if access token available. - if ($this->isDatafileAccessTokenValid) { - $headers['Authorization'] = "Bearer {$this->datafileAccessToken}"; + if ($this->_isDatafileAccessTokenValid) { + $headers['Authorization'] = "Bearer {$this->_datafileAccessToken}"; } $options = [