From 41929a76ce2e20b0118050f108cef3834681dfbc Mon Sep 17 00:00:00 2001 From: Pascal Birchler Date: Wed, 18 Oct 2023 16:38:31 +0200 Subject: [PATCH 1/2] Run tests against SQLite --- .github/workflows/reusable-testing.yml | 17 ++++++++++++----- 1 file changed, 12 insertions(+), 5 deletions(-) diff --git a/.github/workflows/reusable-testing.yml b/.github/workflows/reusable-testing.yml index aa7d02a..8d015e5 100644 --- a/.github/workflows/reusable-testing.yml +++ b/.github/workflows/reusable-testing.yml @@ -85,6 +85,7 @@ jobs: php: ['7.0', '7.1', '7.2', '7.3', '7.4', '8.0', '8.1', '8.2'] wp: ['latest'] mysql: ['8.0'] + dbtype: ['mysql', 'sqlite'] include: - php: '7.0' wp: 'trunk' @@ -122,13 +123,17 @@ jobs: - php: '8.3' wp: 'trunk' mysql: '8.0' + - php: '8.2' + wp: 'trunk' + dbtype: 'sqlite' runs-on: ubuntu-20.04 - continue-on-error: ${{ matrix.php == '8.3' }} + continue-on-error: ${{ matrix.php == '8.3' || matrix.dbtype == 'sqlite' }} services: mysql: - image: mysql:${{ matrix.mysql }} + # Workaround to not start MySQL service if not needed. + image: ${{ matrix.dbtype !== 'sqlite' && format('mysql:{0}', matrix.mysql) || '' }} ports: - 3306 options: --health-cmd="mysqladmin ping" --health-interval=30s --health-timeout=10s --health-retries=5 -e MYSQL_ROOT_PASSWORD=root -e MYSQL_DATABASE=wp_cli_test --entrypoint sh mysql:${{ matrix.mysql }} -c "exec docker-entrypoint.sh mysqld --default-authentication-plugin=mysql_native_password" @@ -177,11 +182,11 @@ jobs: custom-cache-suffix: $(date -u "+%Y-%m") - name: Start MySQL server - if: ${{ matrix.php >= inputs.minimum-php && steps.check_files.outputs.files_exists == 'true' }} + if: ${{ matrix.dbtype !== 'sqlite' && matrix.php >= inputs.minimum-php && steps.check_files.outputs.files_exists == 'true' }} run: sudo systemctl start mysql - name: Configure DB environment - if: ${{ matrix.php >= inputs.minimum-php && steps.check_files.outputs.files_exists == 'true' }} + if: ${{ matrix.dbtype !== 'sqlite' && matrix.php >= inputs.minimum-php && steps.check_files.outputs.files_exists == 'true' }} run: | echo "MYSQL_HOST=127.0.0.1" >> $GITHUB_ENV echo "MYSQL_TCP_PORT=${{ job.services.mysql.ports['3306'] }}" >> $GITHUB_ENV @@ -193,17 +198,19 @@ jobs: echo "WP_CLI_TEST_DBHOST=127.0.0.1:${{ job.services.mysql.ports['3306'] }}" >> $GITHUB_ENV - name: Prepare test database - if: ${{ matrix.php >= inputs.minimum-php && steps.check_files.outputs.files_exists == 'true' }} + if: ${{ matrix.dbtype !== 'sqlite' && matrix.php >= inputs.minimum-php && steps.check_files.outputs.files_exists == 'true' }} run: composer prepare-tests - name: Check Behat environment if: ${{ matrix.php >= inputs.minimum-php && steps.check_files.outputs.files_exists == 'true' }} env: WP_VERSION: '${{ matrix.wp }}' + DB_TYPE: ${{ matrix.dbtype }} || 'mysql' run: WP_CLI_TEST_DEBUG_BEHAT_ENV=1 composer behat - name: Run Behat if: ${{ matrix.php >= inputs.minimum-php && steps.check_files.outputs.files_exists == 'true' }} env: WP_VERSION: '${{ matrix.wp }}' + DB_TYPE: ${{ matrix.dbtype }} || 'mysql' run: composer behat || composer behat-rerun From 4db87c755ff7af0fb03e0971d0e3da01942d84c7 Mon Sep 17 00:00:00 2001 From: Alain Schlesser Date: Thu, 19 Oct 2023 01:36:25 +0200 Subject: [PATCH 2/2] Adapt env variable name for wp-cli-tests 4.2.0 --- .github/workflows/reusable-testing.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/workflows/reusable-testing.yml b/.github/workflows/reusable-testing.yml index 8d015e5..6ef4e29 100644 --- a/.github/workflows/reusable-testing.yml +++ b/.github/workflows/reusable-testing.yml @@ -205,12 +205,12 @@ jobs: if: ${{ matrix.php >= inputs.minimum-php && steps.check_files.outputs.files_exists == 'true' }} env: WP_VERSION: '${{ matrix.wp }}' - DB_TYPE: ${{ matrix.dbtype }} || 'mysql' + WP_CLI_TEST_DBTYPE: ${{ matrix.dbtype }} || 'mysql' run: WP_CLI_TEST_DEBUG_BEHAT_ENV=1 composer behat - name: Run Behat if: ${{ matrix.php >= inputs.minimum-php && steps.check_files.outputs.files_exists == 'true' }} env: WP_VERSION: '${{ matrix.wp }}' - DB_TYPE: ${{ matrix.dbtype }} || 'mysql' + WP_CLI_TEST_DBTYPE: ${{ matrix.dbtype }} || 'mysql' run: composer behat || composer behat-rerun