Build/Test Tools: Enable running the tests on PHP 8.1.

PHP 8.1 is expected to be released at the end of November 2021.

Enabling the tests to run in CI on PHP 8.1 allows us to get WordPress ready in time.

As an interim measure, while working through the PHP 8.1 issues, separate conditional steps are added to run the tests on PHP 8.1 with the `continue-on-error` option. That allows the test builds to show as "successful" if all non-PHP 8.1 test runs pass.

Follow-up to [51517], [51543], [51545], [51574], [51582], [51586].

Props jrf.
Fixes #53891. See #53635.

git-svn-id: https://develop.svn.wordpress.org/trunk@51588 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
Sergey Biryukov 2021-08-09 20:03:52 +00:00
parent b9351465d6
commit 232c30f18e
3 changed files with 51 additions and 8 deletions

View File

@ -63,7 +63,7 @@ jobs:
strategy:
fail-fast: false
matrix:
php: [ '5.6.20', '7.0', '7.1', '7.2', '7.3', '7.4', '8.0' ]
php: [ '5.6.20', '7.0', '7.1', '7.2', '7.3', '7.4', '8.0', '8.1' ]
os: [ ubuntu-latest ]
memcached: [ false ]
split_slow: [ false ]
@ -95,6 +95,7 @@ jobs:
memcached: false
multisite: false
report: true
env:
LOCAL_PHP: ${{ matrix.php }}-fpm
LOCAL_PHP_MEMCACHED: ${{ matrix.memcached }}
@ -142,7 +143,7 @@ jobs:
docker-compose run --rm php composer --version
# Install using `composer update` as there is no `composer.lock` file.
if [ ${{ env.LOCAL_PHP }} == '8.0-fpm' ]; then
if [ ${{ env.LOCAL_PHP }} == '8.1-fpm' ]; then
docker-compose run --rm php composer update --ignore-platform-reqs
else
docker-compose run --rm php composer update
@ -187,7 +188,7 @@ jobs:
run: npm run env:install
- name: Run slow PHPUnit tests
if: ${{ matrix.split_slow }}
if: ${{ matrix.php != '8.1' && matrix.split_slow }}
run: npm run test:php-composer -- --verbose -c ${{ env.PHPUNIT_CONFIG }} --group ${{ env.SLOW_TESTS }}
- name: Run PHPUnit tests for single site excluding slow tests
@ -199,26 +200,64 @@ jobs:
run: npm run test:php-composer -- --verbose -c ${{ env.PHPUNIT_CONFIG }} --exclude-group ${{ env.SLOW_TESTS }},ajax,ms-files,ms-excluded,oembed-headers
- name: Run PHPUnit tests
if: ${{ matrix.php >= '7.0' }}
if: ${{ matrix.php >= '7.0' && matrix.php != '8.1' }}
run: npm run test:php-composer -- --verbose -c ${{ env.PHPUNIT_CONFIG }}
- name: Run AJAX tests
if: ${{ ! matrix.split_slow }}
if: ${{ matrix.php != '8.1' && ! matrix.split_slow }}
run: npm run test:php-composer -- --verbose -c ${{ env.PHPUNIT_CONFIG }} --group ajax
- name: Run ms-files tests as a multisite install
if: ${{ matrix.multisite && ! matrix.split_slow }}
if: ${{ matrix.php != '8.1' && matrix.multisite && ! matrix.split_slow }}
run: npm run test:php-composer -- --verbose -c tests/phpunit/multisite.xml --group ms-files
- name: Run external HTTP tests
if: ${{ ! matrix.multisite && ! matrix.split_slow }}
if: ${{ matrix.php != '8.1' && ! matrix.multisite && ! matrix.split_slow }}
run: npm run test:php-composer -- --verbose -c phpunit.xml.dist --group external-http
# __fakegroup__ is excluded to force PHPUnit to ignore the <exclude> settings in phpunit.xml.dist.
- name: Run (xDebug) tests
if: ${{ ! matrix.split_slow }}
if: ${{ matrix.php != '8.1' && ! matrix.split_slow }}
run: LOCAL_PHP_XDEBUG=true npm run test:php-composer -- -v --group xdebug --exclude-group __fakegroup__
#### Duplicate set of test runs specifically for PHP 8.1 while WP is not yet compatible. ####
# Splitting off the test runs for PHP 8.1 allows us to apply "continue-on-error" to the job steps,
# which will prevent the builds from showing as "failed" when they only fail on PHP 8.1.
# This block should be removed once all PHP 8.1 test failures have been fixed.
# When the block is removed, the conditions in the block above should also be adjusted back
# to their original values.
- name: Run slow PHPUnit tests
if: ${{ matrix.php == '8.1' && matrix.split_slow }}
continue-on-error: true
run: npm run test:php-composer -- --verbose -c ${{ env.PHPUNIT_CONFIG }} --group ${{ env.SLOW_TESTS }}
- name: Run PHPUnit tests
if: ${{ matrix.php == '8.1' }}
continue-on-error: true
run: npm run test:php-composer -- --verbose -c ${{ env.PHPUNIT_CONFIG }}
- name: Run AJAX tests
if: ${{ matrix.php == '8.1' && ! matrix.split_slow }}
continue-on-error: true
run: npm run test:php-composer -- --verbose -c ${{ env.PHPUNIT_CONFIG }} --group ajax
- name: Run ms-files tests as a multisite install
if: ${{ matrix.php == '8.1' && matrix.multisite && ! matrix.split_slow }}
continue-on-error: true
run: npm run test:php-composer -- --verbose -c tests/phpunit/multisite.xml --group ms-files
- name: Run external HTTP tests
if: ${{ matrix.php == '8.1' && ! matrix.multisite && ! matrix.split_slow }}
continue-on-error: true
run: npm run test:php-composer -- --verbose -c phpunit.xml.dist --group external-http
# __fakegroup__ is excluded to force PHPUnit to ignore the <exclude> settings in phpunit.xml.dist.
- name: Run (xDebug) tests
if: ${{ matrix.php == '8.1' && ! matrix.split_slow }}
continue-on-error: true
run: LOCAL_PHP_XDEBUG=true npm run test:php-composer -- -v --group xdebug --exclude-group __fakegroup__
#### End of duplicate set of test runs. ####
- name: Ensure version-controlled files are not modified or deleted
run: git diff --exit-code

View File

@ -1,2 +1,4 @@
display_errors = On
error_reporting = -1
upload_max_filesize = 1G
post_max_size = 1G

View File

@ -1,3 +1,5 @@
display_errors = On
error_reporting = -1
upload_max_filesize = 1G
post_max_size = 1G