Skip to content

Merge pull request #1482 from ergebnis/dependabot/github_actions/stef… #4508

Merge pull request #1482 from ergebnis/dependabot/github_actions/stef…

Merge pull request #1482 from ergebnis/dependabot/github_actions/stef… #4508

Workflow file for this run

# https://docs.github.com/en/actions
name: "Integrate"
on: # yamllint disable-line rule:truthy
pull_request: null
push:
branches:
- "main"
jobs:
code-coverage:
name: "Code Coverage"
runs-on: "ubuntu-latest"
timeout-minutes: 5
strategy:
matrix:
php-version:
- "8.3"
dependencies:
- "locked"
steps:
- name: "Checkout"
uses: "actions/checkout@v4.2.2"
- name: "Set up PHP"
uses: "shivammathur/setup-php@2.32.0"
with:
coverage: "xdebug"
extensions: "none, ctype, curl, dom, iconv, json, mbstring, pdo, pdo_pgsql, pdo_sqlite, phar, simplexml, tokenizer, xml, xmlwriter"
php-version: "${{ matrix.php-version }}"
- name: "Set up problem matchers for PHP"
run: "echo \"::add-matcher::${{ runner.tool_cache }}/php.json\""
- name: "Set up problem matchers for phpunit/phpunit"
run: "echo \"::add-matcher::${{ runner.tool_cache }}/phpunit.json\""
- name: "Validate composer.json and composer.lock"
run: "composer validate --ansi --strict"
- name: "Determine composer cache directory"
uses: "ergebnis/.github/actions/composer/determine-cache-directory@1.9.2"
- name: "Cache dependencies installed with composer"
uses: "actions/cache@v4.2.0"
with:
path: "${{ env.COMPOSER_CACHE_DIR }}"
key: "php-${{ matrix.php-version }}-composer-${{ matrix.dependencies }}-${{ hashFiles('composer.lock') }}"
restore-keys: "php-${{ matrix.php-version }}-composer-${{ matrix.dependencies }}-"
- name: "Install ${{ matrix.dependencies }} dependencies with composer"
uses: "ergebnis/.github/actions/composer/install@1.9.2"
with:
dependencies: "${{ matrix.dependencies }}"
- name: "Collect code coverage with Xdebug and phpunit/phpunit"
env:
XDEBUG_MODE: "coverage"
run: "vendor/bin/phpunit --colors=always --configuration=test/Unit/phpunit.xml --coverage-clover=.build/phpunit/logs/clover.xml"
- name: "Send code coverage report to codecov.io"
uses: "codecov/codecov-action@v5.1.2"
with:
files: ".build/phpunit/logs/clover.xml"
token: "${{ secrets.CODECOV_TOKEN }}"
coding-standards:
name: "Coding Standards"
runs-on: "ubuntu-latest"
timeout-minutes: 5
strategy:
matrix:
php-version:
- "8.3"
dependencies:
- "locked"
steps:
- name: "Checkout"
uses: "actions/checkout@v4.2.2"
- name: "Lint YAML files"
uses: "ibiqlik/action-yamllint@v3.1.1"
with:
config_file: ".yamllint.yaml"
file_or_dir: "."
strict: true
- name: "Set up PHP"
uses: "shivammathur/setup-php@2.32.0"
with:
coverage: "none"
extensions: "none, ctype, curl, dom, iconv, json, mbstring, pdo, pdo_pgsql, pdo_sqlite, phar, simplexml, tokenizer, xml, xmlwriter"
php-version: "${{ matrix.php-version }}"
- name: "Set up problem matchers for PHP"
run: "echo \"::add-matcher::${{ runner.tool_cache }}/php.json\""
- name: "Validate composer.json and composer.lock"
run: "composer validate --ansi --strict"
- name: "Determine composer cache directory"
uses: "ergebnis/.github/actions/composer/determine-cache-directory@1.9.2"
- name: "Cache dependencies installed with composer"
uses: "actions/cache@v4.2.0"
with:
path: "${{ env.COMPOSER_CACHE_DIR }}"
key: "php-${{ matrix.php-version }}-composer-${{ matrix.dependencies }}-${{ hashFiles('composer.lock') }}"
restore-keys: "php-${{ matrix.php-version }}-composer-${{ matrix.dependencies }}-"
- name: "Install ${{ matrix.dependencies }} dependencies with composer"
uses: "ergebnis/.github/actions/composer/install@1.9.2"
with:
dependencies: "${{ matrix.dependencies }}"
- name: "Run ergebnis/composer-normalize"
run: "composer normalize --ansi --dry-run"
- name: "Run symplify/config-transformer"
run: "vendor/bin/config-transformer switch-format --ansi --dry-run config/"
- name: "Cache cache directory for friendsofphp/php-cs-fixer"
uses: "actions/cache@v4.2.0"
with:
path: ".build/php-cs-fixer"
key: "php-${{ matrix.php-version }}-php-cs-fixer-${{ github.ref_name }}"
restore-keys: |
php-${{ matrix.php-version }}-php-cs-fixer-main
php-${{ matrix.php-version }}-php-cs-fixer-
- name: "Run friendsofphp/php-cs-fixer"
run: "vendor/bin/php-cs-fixer fix --ansi --config=.php-cs-fixer.php --diff --dry-run --show-progress=dots --verbose"
dependency-analysis:
name: "Dependency Analysis"
runs-on: "ubuntu-latest"
timeout-minutes: 5
strategy:
matrix:
php-version:
- "8.3"
dependencies:
- "locked"
steps:
- name: "Checkout"
uses: "actions/checkout@v4.2.2"
- name: "Set up PHP"
uses: "shivammathur/setup-php@2.32.0"
with:
coverage: "none"
extensions: "none, ctype, curl, dom, iconv, json, mbstring, pdo, pdo_pgsql, pdo_sqlite, phar, simplexml, tokenizer, xml, xmlwriter"
php-version: "${{ matrix.php-version }}"
tools: "phive"
- name: "Set up problem matchers for PHP"
run: "echo \"::add-matcher::${{ runner.tool_cache }}/php.json\""
- name: "Validate composer.json and composer.lock"
run: "composer validate --ansi --strict"
- name: "Determine composer cache directory"
uses: "ergebnis/.github/actions/composer/determine-cache-directory@1.9.2"
- name: "Cache dependencies installed with composer"
uses: "actions/cache@v4.2.0"
with:
path: "${{ env.COMPOSER_CACHE_DIR }}"
key: "php-${{ matrix.php-version }}-composer-${{ matrix.dependencies }}-${{ hashFiles('composer.lock') }}"
restore-keys: "php-${{ matrix.php-version }}-composer-${{ matrix.dependencies }}-"
- name: "Install ${{ matrix.dependencies }} dependencies with composer"
uses: "ergebnis/.github/actions/composer/install@1.9.2"
with:
dependencies: "${{ matrix.dependencies }}"
- name: "Install dependencies with phive"
uses: "ergebnis/.github/actions/phive/install@1.9.2"
with:
trust-gpg-keys: "0x033E5F8D801A2F8D"
- name: "Run maglnet/composer-require-checker"
run: ".phive/composer-require-checker check --ansi --config-file=$(pwd)/composer-require-checker.json --verbose"
mutation-tests:
name: "Mutation Tests"
runs-on: "ubuntu-latest"
timeout-minutes: 5
strategy:
matrix:
php-version:
- "8.3"
dependencies:
- "locked"
env:
APP_ENV: "test"
steps:
- name: "Checkout"
uses: "actions/checkout@v4.2.2"
- name: "Set up PHP"
uses: "shivammathur/setup-php@2.32.0"
with:
coverage: "xdebug"
extensions: "none, ctype, curl, dom, iconv, json, mbstring, pdo, pdo_pgsql, pdo_sqlite, phar, simplexml, tokenizer, xml, xmlwriter"
php-version: "${{ matrix.php-version }}"
- name: "Set up problem matchers for PHP"
run: "echo \"::add-matcher::${{ runner.tool_cache }}/php.json\""
- name: "Validate composer.json and composer.lock"
run: "composer validate --ansi --strict"
- name: "Determine composer cache directory"
uses: "ergebnis/.github/actions/composer/determine-cache-directory@1.9.2"
- name: "Cache dependencies installed with composer"
uses: "actions/cache@v4.2.0"
with:
path: "${{ env.COMPOSER_CACHE_DIR }}"
key: "php-${{ matrix.php-version }}-composer-${{ matrix.dependencies }}-${{ hashFiles('composer.lock') }}"
restore-keys: "php-${{ matrix.php-version }}-composer-${{ matrix.dependencies }}-"
- name: "Install ${{ matrix.dependencies }} dependencies with composer"
uses: "ergebnis/.github/actions/composer/install@1.9.2"
with:
dependencies: "${{ matrix.dependencies }}"
- name: "Dump environment variables"
run: "composer dump-env ${{ env.APP_ENV }} --ansi"
- name: "Warm up cache"
run: "bin/console cache:warmup --ansi"
- name: "Run mutation tests with Xdebug and infection/infection"
env:
XDEBUG_MODE: "coverage"
run: "vendor/bin/infection --ansi --configuration=infection.json --logger-github"
refactoring:
name: "Refactoring"
runs-on: "ubuntu-latest"
timeout-minutes: 5
strategy:
matrix:
php-version:
- "8.3"
dependencies:
- "locked"
steps:
- name: "Checkout"
uses: "actions/checkout@v4.2.2"
- name: "Set up PHP"
uses: "shivammathur/setup-php@2.32.0"
with:
coverage: "none"
extensions: "none, ctype, curl, dom, iconv, intl, json, mbstring, pdo, pdo_pgsql, pdo_sqlite, phar, simplexml, tokenizer, xml, xmlwriter"
php-version: "${{ matrix.php-version }}"
- name: "Set up problem matchers for PHP"
run: "echo \"::add-matcher::${{ runner.tool_cache }}/php.json\""
- name: "Validate composer.json and composer.lock"
run: "composer validate --ansi --strict"
- name: "Determine composer cache directory"
uses: "ergebnis/.github/actions/composer/determine-cache-directory@1.9.2"
- name: "Cache dependencies installed with composer"
uses: "actions/cache@v4.2.0"
with:
path: "${{ env.COMPOSER_CACHE_DIR }}"
key: "php-${{ matrix.php-version }}-composer-${{ matrix.dependencies }}-${{ hashFiles('composer.lock') }}"
restore-keys: "php-${{ matrix.php-version }}-composer-${{ matrix.dependencies }}-"
- name: "Install ${{ matrix.dependencies }} dependencies with composer"
uses: "ergebnis/.github/actions/composer/install@1.9.2"
with:
dependencies: "${{ matrix.dependencies }}"
- name: "Cache cache directory for rector/rector"
uses: "actions/cache@v4.2.0"
with:
path: ".build/rector"
key: "php-${{ matrix.php-version }}-rector-${{ github.ref_name }}"
restore-keys: |
php-${{ matrix.php-version }}-rector-main
php-${{ matrix.php-version }}-rector-
- name: "Run automated refactoring with rector/rector"
run: "vendor/bin/rector --ansi --config=rector.php --dry-run"
security-analysis:
name: "Security Analysis"
runs-on: "ubuntu-latest"
timeout-minutes: 5
strategy:
matrix:
php-version:
- "8.3"
dependencies:
- "locked"
steps:
- name: "Checkout"
uses: "actions/checkout@v4.2.2"
- name: "Set up PHP"
uses: "shivammathur/setup-php@2.32.0"
with:
coverage: "none"
extensions: "none, ctype, curl, dom, iconv, json, mbstring, pdo, pdo_pgsql, pdo_sqlite, phar, simplexml, tokenizer, xml, xmlwriter"
php-version: "${{ matrix.php-version }}"
- name: "Set up problem matchers for PHP"
run: "echo \"::add-matcher::${{ runner.tool_cache }}/php.json\""
- name: "Validate composer.json and composer.lock"
run: "composer validate --ansi --strict"
- name: "Determine composer cache directory"
uses: "ergebnis/.github/actions/composer/determine-cache-directory@1.9.2"
- name: "Cache dependencies installed with composer"
uses: "actions/cache@v4.2.0"
with:
path: "${{ env.COMPOSER_CACHE_DIR }}"
key: "php-${{ matrix.php-version }}-composer-${{ matrix.dependencies }}-${{ hashFiles('composer.lock') }}"
restore-keys: "php-${{ matrix.php-version }}-composer-${{ matrix.dependencies }}-"
- name: "Install ${{ matrix.dependencies }} dependencies with composer"
uses: "ergebnis/.github/actions/composer/install@1.9.2"
with:
dependencies: "${{ matrix.dependencies }}"
- name: "Check installed packages for security vulnerability advisories"
run: "composer audit --ansi"
static-code-analysis:
name: "Static Code Analysis"
runs-on: "ubuntu-latest"
timeout-minutes: 5
strategy:
matrix:
php-version:
- "8.3"
dependencies:
- "locked"
env:
APP_ENV: "test"
steps:
- name: "Checkout"
uses: "actions/checkout@v4.2.2"
- name: "Set up PHP"
uses: "shivammathur/setup-php@2.32.0"
with:
coverage: "none"
extensions: "none, ctype, curl, dom, iconv, json, mbstring, opcache, pcntl, pdo, pdo_pgsql, pdo_sqlite, phar, posix, simplexml, tokenizer, xml, xmlwriter"
php-version: "${{ matrix.php-version }}"
- name: "Set up problem matchers for PHP"
run: "echo \"::add-matcher::${{ runner.tool_cache }}/php.json\""
- name: "Validate composer.json and composer.lock"
run: "composer validate --ansi --strict"
- name: "Determine composer cache directory"
uses: "ergebnis/.github/actions/composer/determine-cache-directory@1.9.2"
- name: "Cache dependencies installed with composer"
uses: "actions/cache@v4.2.0"
with:
path: "${{ env.COMPOSER_CACHE_DIR }}"
key: "php-${{ matrix.php-version }}-composer-${{ matrix.dependencies }}-${{ hashFiles('composer.lock') }}"
restore-keys: "php-${{ matrix.php-version }}-composer-${{ matrix.dependencies }}-"
- name: "Install ${{ matrix.dependencies }} dependencies with composer"
uses: "ergebnis/.github/actions/composer/install@1.9.2"
with:
dependencies: "${{ matrix.dependencies }}"
- name: "Dump environment variables"
run: "composer dump-env ${{ env.APP_ENV }} --ansi"
- name: "Warm up cache"
run: "bin/console cache:warmup --ansi"
- name: "Run vimeo/psalm"
run: "vendor/bin/psalm --config=psalm.xml --output-format=github --shepherd --show-info=false --stats --threads=4"
symfony-flex:
name: "Symfony Flex"
runs-on: "ubuntu-latest"
timeout-minutes: 5
strategy:
matrix:
php-version:
- "8.3"
dependencies:
- "locked"
steps:
- name: "Checkout"
uses: "actions/checkout@v4.2.2"
- name: "Set up PHP"
uses: "shivammathur/setup-php@2.32.0"
with:
coverage: "none"
extensions: "none, ctype, curl, dom, iconv, json, mbstring, pdo, pdo_pgsql, pdo_sqlite, phar, simplexml, tokenizer, xml, xmlwriter"
php-version: "${{ matrix.php-version }}"
- name: "Determine composer cache directory"
uses: "ergebnis/.github/actions/composer/determine-cache-directory@1.9.2"
- name: "Cache dependencies installed with composer"
uses: "actions/cache@v4.2.0"
with:
path: "${{ env.COMPOSER_CACHE_DIR }}"
key: "php-${{ matrix.php-version }}-composer-${{ matrix.dependencies }}-${{ hashFiles('composer.lock') }}"
restore-keys: "php-${{ matrix.php-version }}-composer-${{ matrix.dependencies }}-"
- name: "Install ${{ matrix.dependencies }} dependencies with composer"
uses: "ergebnis/.github/actions/composer/install@1.9.2"
with:
dependencies: "${{ matrix.dependencies }}"
- name: "Synchronize symfony/flex recipes"
run: "composer symfony:sync-recipes --ansi"
- name: "Verify that symfony.lock is up-to-date"
run: |
diff=$(git diff symfony.lock)
if [[ "${diff}" != "" ]]; then
echo "::error file=symfony.lock::symfony.lock is not up-to-date."
exit 1
fi
tests:
name: "Tests"
runs-on: "ubuntu-latest"
timeout-minutes: 5
strategy:
matrix:
php-version:
- "8.3"
dependencies:
- "locked"
services:
database-default:
env:
POSTGRES_USER: "postgres"
POSTGRES_PASSWORD: "postgres"
POSTGRES_DB: "default"
image: "postgres:16"
ports:
- "5432:5432"
options: >-
--health-cmd pg_isready
--health-interval 10s
--health-retries 3
--health-timeout 5s
env:
APP_ENV: "test"
CONNECTION_NAME_DEFAULT: "default"
ENTITY_MANAGER_NAME_DEFAULT: "default"
steps:
- name: "Checkout"
uses: "actions/checkout@v4.2.2"
- name: "Set up PHP"
uses: "shivammathur/setup-php@2.32.0"
with:
coverage: "none"
extensions: "none, ctype, curl, dom, iconv, json, mbstring, pdo, pdo_pgsql, pdo_sqlite, phar, simplexml, tokenizer, xml, xmlwriter"
php-version: "${{ matrix.php-version }}"
- name: "Set up problem matchers for PHP"
run: "echo \"::add-matcher::${{ runner.tool_cache }}/php.json\""
- name: "Set up problem matchers for phpunit/phpunit"
run: "echo \"::add-matcher::${{ runner.tool_cache }}/phpunit.json\""
- name: "Validate composer.json and composer.lock"
run: "composer validate --ansi --strict"
- name: "Determine composer cache directory"
uses: "ergebnis/.github/actions/composer/determine-cache-directory@1.9.2"
- name: "Cache dependencies installed with composer"
uses: "actions/cache@v4.2.0"
with:
path: "${{ env.COMPOSER_CACHE_DIR }}"
key: "php-${{ matrix.php-version }}-composer-${{ matrix.dependencies }}-${{ hashFiles('composer.lock') }}"
restore-keys: "php-${{ matrix.php-version }}-composer-${{ matrix.dependencies }}-"
- name: "Install ${{ matrix.dependencies }} dependencies with composer"
uses: "ergebnis/.github/actions/composer/install@1.9.2"
with:
dependencies: "${{ matrix.dependencies }}"
- name: "Dump environment variables"
run: "composer dump-env ${{ env.APP_ENV }} --ansi"
- name: "Warm up cache"
run: "bin/console cache:warmup --ansi"
- name: "Show Doctrine migration status"
run: "bin/console doctrine:migrations:status --ansi"
- name: "Run Doctrine migrations"
run: "bin/console doctrine:migrations:migrate --allow-no-migration --ansi --no-interaction"
- name: "Validate Doctrine schema"
run: "bin/console doctrine:schema:validate --ansi --em=${{ env.ENTITY_MANAGER_NAME_DEFAULT }}"
- name: "Run auto-review tests with phpunit/phpunit"
run: "vendor/bin/phpunit --colors=always --configuration=test/AutoReview/phpunit.xml"
- name: "Run unit tests with phpunit/phpunit"
run: "vendor/bin/phpunit --colors=always --configuration=test/Unit/phpunit.xml"
- name: "Run integration tests with phpunit/phpunit"
run: "vendor/bin/phpunit --colors=always --configuration=test/Integration/phpunit.xml"
- name: "Run functional tests with phpunit/phpunit"
run: "vendor/bin/phpunit --colors=always --configuration=test/Functional/phpunit.xml"