Added notes on OIDC #158
Workflow file for this run
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
on: pull_request | |
name: Review | |
jobs: | |
test-composer-install: | |
runs-on: ubuntu-latest | |
strategy: | |
fail-fast: false | |
matrix: | |
php: ["8.1"] | |
name: Validate composer (PHP ${{ matrix.php}}) | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v3 | |
- name: Setup PHP, with composer and extensions | |
uses: shivammathur/setup-php@v2 | |
with: | |
php-version: ${{ matrix.php}} | |
extensions: apcu, ctype, iconv, imagick, json, redis, soap, xmlreader, zip | |
coverage: none | |
- name: Get composer cache directory | |
id: composer-cache | |
run: echo "dir=$(composer config cache-files-dir)" >> $GITHUB_OUTPUT | |
- name: Cache dependencies | |
uses: actions/cache@v3 | |
with: | |
path: ${{ steps.composer-cache.outputs.dir }} | |
key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.lock') }} | |
restore-keys: ${{ runner.os }}-composer- | |
- name: Validate composer files | |
run: composer validate composer.json --strict | |
- name: '[prod] Composer install with exported .env variables' | |
run: | | |
set -a && source .env && set +a | |
APP_ENV=prod composer install --no-dev -o | |
- name: Reset composer install | |
run: rm -rf ./vendor | |
- name: '[dev] Composer install with exported .env variables' | |
run: | | |
set -a && source .env && set +a | |
APP_ENV=dev composer install | |
- name: Normalize composer files | |
run: composer normalize --dry-run | |
validate-doctrine-schema: | |
runs-on: ubuntu-latest | |
env: | |
DATABASE_URL: mysql://db:[email protected]:3306/db?serverVersion=mariadb-10.5.0 | |
strategy: | |
fail-fast: false | |
matrix: | |
php: ["8.1"] | |
name: Validate Doctrine Schema (PHP ${{ matrix.php}}) | |
services: | |
mariadb: | |
image: mariadb:10.5 | |
env: | |
MYSQL_USER: db | |
MYSQL_PASSWORD: db | |
MYSQL_DATABASE: db | |
MYSQL_ROOT_PASSWORD: db | |
ports: | |
- 3306:3306 | |
options: --health-cmd="mysqladmin ping" --health-interval=10s --health-timeout=5s --health-retries=3 | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v3 | |
- name: Setup PHP, with composer and extensions | |
uses: shivammathur/setup-php@v2 | |
with: | |
php-version: ${{ matrix.php}} | |
extensions: apcu, ctype, iconv, imagick, json, redis, soap, xmlreader, zip | |
coverage: none | |
- name: Get composer cache directory | |
id: composer-cache | |
run: echo "dir=$(composer config cache-files-dir)" >> $GITHUB_OUTPUT | |
- name: Cache dependencies | |
uses: actions/cache@v3 | |
with: | |
path: ${{ steps.composer-cache.outputs.dir }} | |
key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.lock') }} | |
restore-keys: ${{ runner.os }}-composer | |
- name: 'Composer install with exported .env variables' | |
run: | | |
set -a && source .env && set +a | |
APP_ENV=prod composer install --no-dev -o | |
- name: Run Doctrine Migrations | |
run: APP_ENV=prod php bin/console doctrine:migrations:migrate --no-interaction | |
- name: Setup messenger "failed" doctrine transport to ensure db schema is updated | |
run: APP_ENV=prod php bin/console messenger:setup-transports failed | |
- name: Validate Doctrine schema | |
run: APP_ENV=prod php bin/console doctrine:schema:validate | |
php-cs-fixer: | |
runs-on: ubuntu-latest | |
strategy: | |
fail-fast: false | |
matrix: | |
php: ["8.1"] | |
name: PHP Coding Standards Fixer (PHP ${{ matrix.php }}) | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v3 | |
- name: Setup PHP, with composer and extensions | |
uses: shivammathur/setup-php@v2 | |
with: | |
php-version: ${{ matrix.php}} | |
extensions: apcu, ctype, iconv, imagick, json, redis, soap, xmlreader, zip | |
coverage: none | |
- name: Get composer cache directory | |
id: composer-cache | |
run: echo "dir=$(composer config cache-files-dir)" >> $GITHUB_OUTPUT | |
- name: Cache dependencies | |
uses: actions/cache@v3 | |
with: | |
path: ${{ steps.composer-cache.outputs.dir }} | |
key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.lock') }} | |
restore-keys: ${{ runner.os }}-composer | |
- name: Install Dependencies | |
run: composer install -q --no-ansi --no-interaction --no-scripts --no-suggest --no-progress --prefer-dist | |
- name: php-cs-fixer | |
run: phpdbg -qrr ./vendor/bin/php-cs-fixer fix --dry-run | |
phpunit: | |
runs-on: ubuntu-latest | |
services: | |
mariadb: | |
image: mariadb:10.5 | |
ports: | |
- 3306 | |
env: | |
MYSQL_USER: db | |
MYSQL_PASSWORD: db | |
MYSQL_DATABASE: db_test | |
MYSQL_ROOT_PASSWORD: password | |
options: --health-cmd="mysqladmin ping" --health-interval=5s --health-timeout=2s --health-retries=3 | |
strategy: | |
fail-fast: false | |
matrix: | |
php: ["8.1"] | |
name: PHP Unit tests (PHP ${{ matrix.php }}) | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v3 | |
- name: Setup PHP, with composer and extensions | |
uses: shivammathur/setup-php@v2 | |
with: | |
php-version: ${{ matrix.php}} | |
extensions: apcu, ctype, iconv, imagick, json, redis, soap, xmlreader, zip | |
coverage: none | |
- name: Get composer cache directory | |
id: composer-cache | |
run: echo "dir=$(composer config cache-files-dir)" >> $GITHUB_OUTPUT | |
- name: Cache dependencies | |
uses: actions/cache@v3 | |
with: | |
path: ${{ steps.composer-cache.outputs.dir }} | |
key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.lock') }} | |
restore-keys: ${{ runner.os }}-composer | |
- name: Install Dependencies | |
run: composer install -q --no-ansi --no-interaction --no-scripts --no-suggest --no-progress --prefer-dist | |
- name: PHP Unit | |
env: | |
PORT: ${{ job.services.mariadb.ports[3306] }} | |
run: DATABASE_URL="mysql://db:[email protected]:$PORT/db?serverVersion=mariadb-10.5.13" composer run tests | |
apispec: | |
runs-on: ubuntu-latest | |
name: API Specification validation | |
strategy: | |
fail-fast: false | |
matrix: | |
php: ["8.1"] | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v3 | |
with: | |
fetch-depth: 2 | |
- name: Setup PHP, with composer and extensions | |
uses: shivammathur/setup-php@v2 | |
with: | |
php-version: ${{ matrix.php}} | |
extensions: apcu, ctype, iconv, imagick, json, redis, soap, xmlreader, zip | |
coverage: none | |
- name: Get composer cache directory | |
id: composer-cache | |
run: echo "dir=$(composer config cache-files-dir)" >> $GITHUB_OUTPUT | |
- name: Cache dependencies | |
uses: actions/cache@v3 | |
with: | |
path: ${{ steps.composer-cache.outputs.dir }} | |
key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.lock') }} | |
restore-keys: ${{ runner.os }}-composer | |
- name: Install Dependencies | |
run: composer install -q --no-ansi --no-interaction --no-scripts --no-suggest --no-progress --prefer-dist | |
- name: Export specifications (yaml) | |
run: bin/console api:openapi:export --yaml --output=public/api-spec-v1.yaml --no-interaction | |
- name: Check for changes in specifications (yaml) | |
run: git diff --diff-filter=ACMRT --exit-code public/api-spec-v1.yaml | |
fixtures: | |
runs-on: ubuntu-latest | |
name: Load fixtures | |
strategy: | |
fail-fast: false | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v3 | |
with: | |
fetch-depth: 2 | |
- name: Install site | |
run: | | |
docker network create frontend | |
docker compose pull | |
docker compose up --detach | |
docker compose exec --user=root phpfpm composer install | |
docker compose exec phpfpm bin/console doctrine:migrations:migrate --no-interaction | |
- name: Load fixtures | |
run: | | |
docker compose exec phpfpm composer fixtures | |
build-assets: | |
runs-on: ubuntu-latest | |
name: Build assets | |
strategy: | |
fail-fast: false | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v3 | |
with: | |
fetch-depth: 2 | |
- name: Build assets | |
run: | | |
docker network create frontend | |
docker compose run --rm node yarn install | |
docker compose run --rm node yarn build | |
changelog: | |
runs-on: ubuntu-latest | |
name: Changelog should be updated | |
strategy: | |
fail-fast: false | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v3 | |
with: | |
fetch-depth: 2 | |
- name: Git fetch | |
run: git fetch | |
- name: Check that changelog has been updated. | |
run: git diff --exit-code origin/develop -- CHANGELOG.md && exit 1 || exit 0 |