Skip to content

Continuous Integration #128

Continuous Integration

Continuous Integration #128

name: "Continuous Integration"
on:
workflow_dispatch:
pull_request:
push:
branches:
- '[0-9]+.[0-9]+.x'
- 'master'
schedule:
- cron: "42 9 * * 1"
jobs:
psalm:
name: "Static Analysis"
runs-on: ubuntu-latest
strategy:
matrix:
php-version:
- "8.1"
- "8.2"
- "8.3"
steps:
- name: "Checkout"
uses: "actions/checkout@v4"
- name: "Install PHP"
uses: "shivammathur/setup-php@v2"
with:
php-version: "${{ matrix.php-version }}"
- uses: ramsey/composer-install@v3
- name: "Run psalm"
run: "vendor/bin/psalm --long-progress --output-format=github --report=psalm.sarif --php-version=${{ matrix.php-version }}"
- name: "Upload SARIF file"
uses: github/codeql-action/upload-sarif@v3
continue-on-error: true
with:
sarif_file: psalm.sarif
codestyle:
name: "Code Style"
runs-on: ubuntu-latest
strategy:
matrix:
php-version:
- "8.1"
deps:
- "latest"
coverage:
- "false"
steps:
- name: "Checkout"
uses: "actions/checkout@v4"
- name: "Install PHP"
uses: "shivammathur/setup-php@v2"
with:
php-version: "${{ matrix.php-version }}"
coverage: "pcov"
ini-values: "zend.assertions=1"
extensions: "bcmath, gmp"
- uses: ramsey/composer-install@v3
- name: "Run PHPCS check"
run: "composer cs-check"
phpunit:
name: "PHPUnit"
runs-on: ubuntu-latest
strategy:
matrix:
php-version:
- "8.1"
- "8.2"
- "8.3"
- "8.4"
deps:
- "latest"
include:
- php-version: "8.1"
deps: "lowest"
steps:
- name: "Checkout"
uses: "actions/checkout@v4"
- name: "Install PHP"
uses: "shivammathur/setup-php@v2"
with:
php-version: "${{ matrix.php-version }}"
coverage: "pcov"
ini-values: "zend.assertions=1"
extensions: "bcmath, gmp"
- uses: ramsey/composer-install@v3
with:
dependency-versions: ${{ matrix.deps }}
composer-options: '--ignore-platform-req=php+'
- name: "Run PHPUnit with coverage"
run: "vendor/bin/phpunit -c phpunit.xml.dist --coverage-clover=coverage-report.xml"
- name: Upload code coverage
uses: codecov/codecov-action@v5
with:
files: coverage-report.xml
token: ${{ secrets.CODECOV_TOKEN }}
fail_ci_if_error: true