Lock file maintenance #804
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
# See https://github.com/laminas/laminas-continuous-integration-action | |
# Generates a job matrix based on current dependencies and supported version | |
# ranges, then runs all those jobs | |
name: "Continuous Integration" | |
on: | |
pull_request: | |
push: | |
jobs: | |
matrix: | |
name: Generate job matrix | |
runs-on: ubuntu-latest | |
outputs: | |
matrix: ${{ steps.matrix.outputs.matrix }} | |
steps: | |
- name: Gather CI configuration | |
id: matrix | |
uses: laminas/[email protected] | |
qa: | |
name: QA Checks | |
needs: [ matrix ] | |
runs-on: ${{ matrix.operatingSystem }} | |
strategy: | |
fail-fast: false | |
matrix: ${{ fromJSON(needs.matrix.outputs.matrix) }} | |
steps: | |
- name: ${{ matrix.name }} | |
uses: laminas/[email protected] | |
env: | |
"GITHUB_TOKEN": ${{ secrets.GITHUB_TOKEN }} | |
"INFECTION_DASHBOARD_API_KEY": ${{ secrets.INFECTION_DASHBOARD_API_KEY }} | |
"STRYKER_DASHBOARD_API_KEY": ${{ secrets.STRYKER_DASHBOARD_API_KEY }} | |
with: | |
job: ${{ matrix.job }} | |
# we need to run `bin/roave-infection-static-analysis-plugin` as a manually configured | |
# step here, since the tool is not in `composer.json` `require` for | |
# `laminas/laminas-ci-matrix-action` to detect (it's the source repo, in fact). | |
mutation-tests: | |
name: "Mutation tests" | |
runs-on: ${{ matrix.operating-system }} | |
strategy: | |
matrix: | |
dependencies: | |
- "locked" | |
php-version: | |
- "8.1" | |
- "8.2" | |
operating-system: | |
- "ubuntu-latest" | |
steps: | |
- name: "Checkout" | |
uses: "actions/checkout@v4" | |
- name: "Install PHP" | |
uses: "shivammathur/[email protected]" | |
with: | |
coverage: "xdebug" | |
php-version: "${{ matrix.php-version }}" | |
ini-values: memory_limit=-1, zend.assertions=1 | |
- name: "Cache dependencies" | |
uses: "actions/cache@v3" | |
with: | |
path: | | |
~/.composer/cache | |
vendor | |
key: "php-${{ matrix.php-version }}-${{ matrix.dependencies }}" | |
restore-keys: "php-${{ matrix.php-version }}-${{ matrix.dependencies }}" | |
- name: "Install lowest dependencies" | |
if: ${{ matrix.dependencies == 'lowest' }} | |
run: "composer update --prefer-lowest --no-interaction --no-progress" | |
- name: "Install highest dependencies" | |
if: ${{ matrix.dependencies == 'highest' }} | |
run: "composer update --no-interaction --no-progress" | |
- name: "Install locked dependencies" | |
if: ${{ matrix.dependencies == 'locked' }} | |
run: "composer install --no-interaction --no-progress" | |
- name: "Infection" | |
run: "bin/roave-infection-static-analysis-plugin --threads=$(nproc)" | |
env: | |
INFECTION_BADGE_API_KEY: ${{ secrets.INFECTION_BADGE_API_KEY }} | |
STRYKER_DASHBOARD_API_KEY: ${{ secrets.STRYKER_DASHBOARD_API_KEY }} |