mirror of
https://gh.wpcy.net/https://github.com/WordPress/WordPress-Coding-Standards.git
synced 2026-04-26 00:02:20 +08:00
As things were, when testing against "dev" versions, only PHPCS "dev" was used, while WPCS now has more dependencies, i.e. PHPCSUtils and PHPCSExtra.
This commit updates the workflows to take that into account better.
It also improves the readability of the workflows by using multi-line command in a few places.
Notes:
* This renames the `phpcs_version` matrix variable to `dependencies` in all workflows to make it clear this is not just about PHPCS itself, but about all dependencies.
* The CS check for the own codebase is always run against "dev" versions of all dependencies as an early detection system for upstream issues.
* The "Ruleset" checks are run against low/stable/dev.
* The fixer conflict check is run against dev only, as conflicts detected cannot be fixed anymore in already released versions.
* The "quick check" now only runs against low/stable.
* The "test" run run against both low/stable by default and now has some extra builds against "dev" versions.
- These extra builds could be set to "continue on error", but I've chosen not to do so as if any issues are detected, they should be fixed asap as they will impact WPCS sooner rather than later.
- Code coverage will now be run against low/high PHP with low/stable dependencies and no longer against dev.
* Also note that, while the "quick test"/"test" runs shouldn't need PHPCSExtra, as that is a dependency used only in the ruleset, not in our sniff code, I've still included PHPCSExtra in the upgrade/downgrade block for consistency.
These changes do mean that the "required build"/branch protection will need to be updated (again) before the PR can be merged.
I will do so once the PR has been approved.
76 lines
2.5 KiB
YAML
76 lines
2.5 KiB
YAML
name: Quick Tests
|
|
|
|
on:
|
|
push:
|
|
branches-ignore:
|
|
- main
|
|
paths-ignore:
|
|
- '**.md'
|
|
# Allow manually triggering the workflow.
|
|
workflow_dispatch:
|
|
|
|
# Cancels all previous workflow runs for the same branch that have not yet completed.
|
|
concurrency:
|
|
# The concurrency group contains the workflow name and the branch name.
|
|
group: ${{ github.workflow }}-${{ github.ref }}
|
|
cancel-in-progress: true
|
|
|
|
jobs:
|
|
# Performs some quick tests.
|
|
# This is a much quicker test suite which only runs the unit tests and linting
|
|
# against the low/high supported PHP/PHPCS combinations.
|
|
quick-tests:
|
|
runs-on: ubuntu-latest
|
|
strategy:
|
|
matrix:
|
|
php: [ '5.4', 'latest' ]
|
|
dependencies: [ 'lowest', 'stable' ]
|
|
|
|
name: QTest - PHP ${{ matrix.php }} on PHPCS ${{ matrix.dependencies }}
|
|
|
|
steps:
|
|
- name: Checkout repository
|
|
uses: actions/checkout@v4
|
|
|
|
- name: Set up PHP
|
|
uses: shivammathur/setup-php@v2
|
|
with:
|
|
php-version: ${{ matrix.php }}
|
|
# With stable PHPCS dependencies, allow for PHP deprecation notices.
|
|
# Unit tests don't need to fail on those for stable releases where those issues won't get fixed anymore.
|
|
ini-values: error_reporting=-1, display_errors=On
|
|
coverage: ${{ github.ref_name == 'develop' && 'xdebug' || 'none' }}
|
|
|
|
- name: Install Composer dependencies
|
|
uses: ramsey/composer-install@v2
|
|
with:
|
|
# Bust the cache at least once a month - output format: YYYY-MM.
|
|
custom-cache-suffix: $(date -u "+%Y-%m")
|
|
|
|
- name: "Composer: downgrade PHPCS dependencies for tests (lowest)"
|
|
if: ${{ matrix.dependencies == 'lowest' }}
|
|
run: >
|
|
composer update --prefer-lowest --no-scripts --no-interaction
|
|
squizlabs/php_codesniffer
|
|
phpcsstandards/phpcsutils
|
|
phpcsstandards/phpcsextra
|
|
|
|
- name: Lint PHP files against parse errors
|
|
if: ${{ matrix.dependencies == 'stable' }}
|
|
run: composer lint -- --checkstyle
|
|
|
|
- name: Run the unit tests without code coverage
|
|
if: ${{ github.ref_name != 'develop' }}
|
|
run: composer run-tests
|
|
|
|
- name: Run the unit tests with code coverage
|
|
if: ${{ github.ref_name == 'develop' }}
|
|
run: composer coverage
|
|
|
|
- name: Send coverage report to Codecov
|
|
if: ${{ success() && github.ref_name == 'develop' }}
|
|
uses: codecov/codecov-action@v3
|
|
with:
|
|
files: ./build/logs/clover.xml
|
|
fail_ci_if_error: true
|
|
verbose: true
|