123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292 |
- name: CI
- on:
- - pull_request
- - push
- permissions:
- contents: read # to fetch code (actions/checkout)
- concurrency:
- group: ci-${{ github.head_ref || github.run_id }} # will be canceled on subsequent pushes in pull requests but not branches
- cancel-in-progress: true
- env:
- PHP_MAX: '8.3'
- PHP_MIN: '7.4'
- jobs:
- entrypoint-low-php-compat:
- name: Entrypoint low-PHP compat
- runs-on: 'ubuntu-24.04'
- steps:
- - name: Checkout code
- uses: actions/checkout@v4
- - name: Setup PHP
- uses: ./.github/composite-actions/setup-php
- with:
- version: 7.0
- - name: Verify entrypoint file(s) can be run on low-end unsupported runtime
- run: php -l $(cat composer.json | jq -r '.bin[]')
- tests:
- continue-on-error: ${{ matrix.operating-system == 'macos-latest' }}
- strategy:
- fail-fast: false
- matrix:
- include:
- - operating-system: 'ubuntu-24.04'
- php-version: '7.4'
- job-description: 'Fixer with lowest deps'
- run-fixer: 'yes'
- composer-flags: '--prefer-lowest' # should be checked on the lowest supported PHP version
- execute-flex-with-symfony-version: '^5' # explicit check for Symfony 5.x compatibility
- - operating-system: 'ubuntu-24.04'
- php-version: '7.4'
- job-description: 'tests with lowest deps'
- run-tests: 'yes'
- composer-flags: '--prefer-lowest' # should be checked on the lowest supported PHP version
- execute-flex-with-symfony-version: '^5' # explicit check for Symfony 5.x compatibility
- - operating-system: 'ubuntu-24.04'
- php-version: '8.0'
- job-description: 'Fixer'
- run-fixer: 'yes'
- - operating-system: 'ubuntu-24.04'
- php-version: '8.0'
- job-description: 'tests'
- run-tests: 'yes'
- - operating-system: 'ubuntu-24.04'
- php-version: '8.1'
- job-description: 'Fixer with Symfony ^6'
- run-fixer: 'yes'
- execute-flex-with-symfony-version: '^6' # explicit check for Symfony 6.x compatibility
- - operating-system: 'ubuntu-24.04'
- php-version: '8.1'
- job-description: 'tests with Symfony ^6'
- run-tests: 'yes'
- execute-flex-with-symfony-version: '^6' # explicit check for Symfony 6.x compatibility
- - operating-system: 'ubuntu-24.04'
- php-version: '8.2'
- job-description: 'Fixer'
- run-fixer: 'yes'
- - operating-system: 'ubuntu-24.04'
- php-version: '8.2'
- job-description: 'tests'
- run-tests: 'yes'
- - operating-system: 'ubuntu-24.04'
- php-version: '8.3'
- job-description: 'Fixer'
- run-fixer: 'yes'
- - operating-system: 'ubuntu-24.04'
- php-version: '8.3'
- job-description: 'tests'
- run-tests: 'yes'
- - operating-system: 'ubuntu-24.04'
- php-version: '8.3'
- job-description: 'Fixer with migration rules'
- run-fixer: 'yes'
- run-migration-rules: 'yes' # should be checked on the highest supported PHP version
- - operating-system: 'ubuntu-24.04'
- php-version: '8.3'
- job-description: 'tests with migration rules'
- run-tests: 'yes'
- run-migration-rules: 'yes' # should be checked on the highest supported PHP version
- - operating-system: 'ubuntu-24.04'
- php-version: '8.3'
- job-description: 'Fixer with Symfony ^7'
- run-fixer: 'yes'
- execute-flex-with-symfony-version: '^7' # explicit check for Symfony 7.x compatibility
- - operating-system: 'ubuntu-24.04'
- php-version: '8.3'
- job-description: 'tests with Symfony ^7'
- run-tests: 'yes'
- execute-flex-with-symfony-version: '^7' # explicit check for Symfony 7.x compatibility
- - operating-system: 'ubuntu-24.04'
- php-version: '8.3'
- job-description: 'code coverage'
- run-tests: 'yes'
- collect-code-coverage: 'yes'
- - operating-system: 'ubuntu-24.04'
- php-version: '8.3'
- job-description: 'mutation tests'
- run-mutation-tests: 'yes'
- - operating-system: 'windows-latest'
- php-version: '8.3'
- job-description: 'Fixer on Windows'
- run-fixer: 'yes'
- FAST_LINT_TEST_CASES: 1 # we need full syntax check on one job at least, no need to do it on additional
- - operating-system: 'windows-latest'
- php-version: '8.3'
- job-description: 'tests on Windows'
- run-tests: 'yes'
- FAST_LINT_TEST_CASES: 1 # we need full syntax check on one job at least, no need to do it on additional systems
- - operating-system: 'macos-latest'
- php-version: '8.3'
- job-description: 'Fixer on macOS'
- run-fixer: 'yes'
- FAST_LINT_TEST_CASES: 1 # we need full syntax check on one job at least, no need to do it on additional systems
- - operating-system: 'macos-latest'
- php-version: '8.3'
- job-description: 'tests on macOS'
- run-tests: 'yes'
- FAST_LINT_TEST_CASES: 1 # we need full syntax check on one job at least, no need to do it on additional
- - operating-system: 'ubuntu-24.04'
- php-version: '8.4'
- job-description: 'Fixer'
- run-fixer: 'yes'
- PHP_CS_FIXER_IGNORE_ENV: 1
- - operating-system: 'ubuntu-24.04'
- php-version: '8.4'
- job-description: 'tests'
- run-tests: 'yes'
- PHP_CS_FIXER_IGNORE_ENV: 1
- name: PHP ${{ matrix.php-version }} ${{ matrix.job-description }}
- runs-on: ${{ matrix.operating-system }}
- steps:
- - name: Checkout code
- uses: actions/checkout@v4
- - name: Remove Infection requirement if not needed
- # TODO: Fix it properly. It somehow stopped working on MacOS (Composer not available)
- if: matrix.operating-system != 'macos-latest' && matrix.run-mutation-tests != 'yes'
- run: composer remove --dev infection/infection --no-update
- - name: Setup PHP with Composer deps
- uses: ./.github/composite-actions/setup-php-with-composer-deps
- with:
- os: ${{ runner.os }}
- php: ${{ matrix.php-version }}
- php-coverage: ${{ matrix.collect-code-coverage || matrix.run-mutation-tests }}
- composer-flags: ${{ matrix.composer-flags }}
- composer-flex-with-symfony-version: ${{ matrix.execute-flex-with-symfony-version }}
- # Execute migration rules before running tests and self-fixing,
- # so we know that our codebase is future-ready.
- # Should be checked on the highest supported PHP version.
- - name: Run PHP CS Fixer with migration rules
- if: env.PHP_MAX == matrix.php-version && matrix.run-migration-rules == 'yes'
- env:
- PHP_CS_FIXER_FUTURE_MODE: 1
- run: php php-cs-fixer fix --diff --config .php-cs-fixer.php-highest.php
- - name: Custom PHPUnit config for code coverage
- if: matrix.collect-code-coverage == 'yes' || matrix.run-mutation-tests
- run: sed -e 's/enforceTimeLimit="true"/enforceTimeLimit="false"/g' -e 's/coverage/source/g' phpunit.xml.dist > phpunit.xml
- - name: Disable time limit for tests under Windows # due to https://github.com/sebastianbergmann/phpunit/issues/5589
- if: matrix.operating-system == 'windows-latest'
- run: (Get-Content phpunit.xml.dist) -replace 'enforceTimeLimit="true"', 'enforceTimeLimit="false"' | Out-File phpunit.xml
- - name: Fix PHP 8.4 deprecations for tests
- if: matrix.run-tests == 'yes' && matrix.php-version == '8.4'
- env:
- PHP_CS_FIXER_IGNORE_ENV: ${{ matrix.PHP_CS_FIXER_IGNORE_ENV }}
- run: php php-cs-fixer fix --rules=no_unreachable_default_argument_value,nullable_type_declaration_for_default_null_value --diff vendor
- - name: Run tests
- if: matrix.run-tests == 'yes' && matrix.collect-code-coverage != 'yes'
- env:
- PHP_CS_FIXER_IGNORE_ENV: ${{ matrix.PHP_CS_FIXER_IGNORE_ENV }}
- FAST_LINT_TEST_CASES: ${{ matrix.FAST_LINT_TEST_CASES }}
- run: vendor/bin/paraunit run --testsuite unit,integration
- - name: Run tests with "short_open_tag" enabled
- if: matrix.run-tests == 'yes' && matrix.collect-code-coverage != 'yes'
- env:
- PHP_CS_FIXER_IGNORE_ENV: ${{ matrix.PHP_CS_FIXER_IGNORE_ENV }}
- FAST_LINT_TEST_CASES: ${{ matrix.FAST_LINT_TEST_CASES }}
- run: composer test:short-open-tag
- - name: Run tests and collect code coverage
- if: matrix.run-tests == 'yes' && matrix.collect-code-coverage == 'yes'
- env:
- FAST_LINT_TEST_CASES: 1
- run: vendor/bin/paraunit coverage --testsuite unit --pass-through=--exclude-group=covers-nothing --clover=build/logs/clover.xml
- - name: Run mutation tests (Infection)
- # Run only on pull requests because we run mutations tests only for diff between branches
- if: github.event_name == 'pull_request' && matrix.run-mutation-tests == 'yes'
- env:
- FAST_LINT_TEST_CASES: 1
- run: |
- git fetch origin $GITHUB_BASE_REF
- vendor/bin/infection --threads=max --map-source-class-to-test --git-diff-lines --git-diff-base=origin/$GITHUB_BASE_REF --ignore-msi-with-no-mutations --only-covered
- - name: Upload coverage results to Coveralls
- if: matrix.run-tests == 'yes' && matrix.collect-code-coverage == 'yes'
- env:
- COVERALLS_REPO_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- run: php vendor/bin/php-coveralls --verbose
- - name: Run PHP CS Fixer
- if: matrix.run-fixer == 'yes'
- env:
- PHP_CS_FIXER_IGNORE_ENV: ${{ matrix.PHP_CS_FIXER_IGNORE_ENV }}
- PHP_CS_FIXER_FUTURE_MODE: 1
- run: php php-cs-fixer check --diff -v
- # Should be checked on the lowest supported PHP version.
- # If any type can be converted from PHPDoc to native type on lowest supported PHP, we should commit such change.
- - name: Run PHP CS Fixer with PHPDoc to type rules
- if: env.PHP_MIN == matrix.php-version && matrix.run-fixer == 'yes'
- env:
- PHP_CS_FIXER_FUTURE_MODE: 1
- run: php php-cs-fixer check --diff -vvv --config .php-cs-fixer.php-lowest.php
- deployment:
- needs: tests
- name: Deployment checks
- runs-on: 'ubuntu-24.04'
- env:
- php-version: '8.3'
- steps:
- - name: Checkout code
- uses: actions/checkout@v4
- - name: Setup PHP with Composer deps
- uses: ./.github/composite-actions/setup-php-with-composer-deps
- with:
- os: ${{ runner.os }}
- php: ${{ env.php-version }}
- - name: Cache dev-tools
- uses: actions/cache@v4
- with:
- path: dev-tools/bin/
- key: Build-${{ hashFiles('dev-tools/build.sh') }}
- - name: Build phar
- run: ./dev-tools/build.sh
- - name: Run smoke tests
- env:
- FAST_LINT_TEST_CASES: 1
- run: vendor/bin/phpunit --testsuite smoke
|