Skip to content

Commit

Permalink
Merge pull request #738 from wayofdev/feat/infra-dx
Browse files Browse the repository at this point in the history
  • Loading branch information
lotyp committed May 26, 2024
2 parents 918b337 + 837213d commit efe5351
Show file tree
Hide file tree
Showing 7 changed files with 386 additions and 79 deletions.
78 changes: 0 additions & 78 deletions .github/workflows/ci.yml.dist

This file was deleted.

87 changes: 87 additions & 0 deletions .github/workflows/dependency-analysis.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,87 @@
---

name: 🔐 Dependency analysis

on: # yamllint disable-line rule:truthy
push:
branches:
- master
paths:
- 'config/**'
- 'src/**'
- 'tests/**'
- '.php-cs-fixer.dist.php'
- 'composer.json'
- 'composer.lock'
- 'composer-require-checker.json'
pull_request:
branches:
- master
paths:
- 'config/**'
- 'src/**'
- 'tests/**'
- '.php-cs-fixer.dist.php'
- 'composer.json'
- 'composer.lock'
- 'composer-require-checker.json'

jobs:
dependency-analysis:
timeout-minutes: 4
runs-on: ${{ matrix.os }}
concurrency:
cancel-in-progress: true
group: dependency-analysis-${{ github.workflow }}-${{ github.event.pull_request.number || github.ref }}
strategy:
fail-fast: true
matrix:
os:
- ubuntu-latest
php-version:
- '8.2'
dependencies:
- locked

steps:
- name: 📦 Check out the codebase
uses: actions/[email protected]

- name: 🛠️ Setup PHP
uses: shivammathur/[email protected]
with:
php-version: ${{ matrix.php-version }}
extensions: none, ctype, dom, json, mbstring, simplexml, tokenizer, xml, xmlwriter, pdo, curl, fileinfo, pdo_mysql
ini-values: error_reporting=E_ALL
coverage: none
tools: phive

- name: 🛠️ Setup problem matchers
run: echo "::add-matcher::${{ runner.tool_cache }}/php.json"

- name: 🤖 Validate composer.json and composer.lock
run: composer validate --ansi --strict

- name: 🔍 Get composer cache directory
uses: wayofdev/gh-actions/actions/composer/[email protected]

- name: ♻️ Restore cached dependencies installed with composer
uses: actions/[email protected]
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
uses: wayofdev/gh-actions/actions/composer/[email protected]
with:
dependencies: ${{ matrix.dependencies }}

- name: 📥 Install dependencies with phive
uses: wayofdev/gh-actions/actions/phive/[email protected]
with:
phive-home: '.phive'
trust-gpg-keys: 0xC00543248C87FB13,0x033E5F8D801A2F8D

- name: 🔬 Run maglnet/composer-require-checker
run: .phive/composer-require-checker check --ansi --config-file="$(pwd)/composer-require-checker.json" --verbose
12 changes: 12 additions & 0 deletions .github/workflows/static-analysis.yml
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,12 @@ on: # yamllint disable-line rule:truthy
- 'src/**'
- 'tests/**'
- '.php-cs-fixer.dist.php'
- 'composer.json'
- 'composer.lock'
- 'phpstan.neon.dist'
- 'phpstan-baseline.neon'
- 'psalm.xml'
- 'psalm-baseline.xml'
pull_request:
branches:
- master
Expand All @@ -17,6 +23,12 @@ on: # yamllint disable-line rule:truthy
- 'src/**'
- 'tests/**'
- '.php-cs-fixer.dist.php'
- 'composer.json'
- 'composer.lock'
- 'phpstan.neon.dist'
- 'phpstan-baseline.neon'
- 'psalm.xml'
- 'psalm-baseline.xml'

name: 🔍 Static analysis

Expand Down
94 changes: 94 additions & 0 deletions .github/workflows/testing-mssql.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,94 @@
---

on: # yamllint disable-line rule:truthy
pull_request:
branches:
- master
push:
branches:
- master

name: 🧪 Testing (MSSQL - SQLServer)

env:
DB_HOST: 127.0.0.1
DB_PORT: 11433
DB_USERNAME: SA
DB_PASSWORD: 'SSpaSS__1_123'
DB_CONNECTION: sqlserver
DB_DATABASE: tempdb

jobs:
test-sqlserver:
timeout-minutes: 4
runs-on: ${{ matrix.os }}
concurrency:
cancel-in-progress: true
group: test-sqlserver-${{ github.workflow }}-${{ github.event.pull_request.number || github.ref }}-${{ matrix.php-version }}-${{ matrix.dependencies }}
strategy:
fail-fast: true
matrix:
os:
- 'ubuntu-latest'
php-version:
- '8.2'
dependencies:
- locked
sqlserver-version:
- '2022-latest'

services:
sqlserver:
image: mcr.microsoft.com/mssql/server:${{ matrix.sqlserver-version }}
env:
ACCEPT_EULA: 'Y'
SA_PASSWORD: 'SSpaSS__1_123'
options: >-
--health-cmd "/opt/mssql-tools/bin/sqlcmd -S localhost -U SA -P 'SSpaSS__1_123' -l 30 -Q 'SELECT 1'"
--health-interval 3s
--health-timeout 1s
--health-retries 10
ports:
- 11433:1433

steps:
- name: 📦 Check out the codebase
uses: actions/[email protected]

- name: 🛠️ Setup PHP
uses: shivammathur/[email protected]
with:
php-version: ${{ matrix.php-version }}
extensions: none, ctype, dom, json, mbstring, simplexml, tokenizer, xml, xmlwriter, pdo, curl, fileinfo, pdo_mysql, pdo_sqlsrv
ini-values: error_reporting=E_ALL
coverage: none

- name: 🛠️ Setup problem matchers
run: |
echo "::add-matcher::${{ runner.tool_cache }}/php.json"
echo "::add-matcher::${{ runner.tool_cache }}/phpunit.json"
- name: 🤖 Validate composer.json and composer.lock
run: composer validate --ansi --strict

- name: 🔍 Get composer cache directory
uses: wayofdev/gh-actions/actions/composer/[email protected]

- name: ♻️ Restore cached dependencies installed with composer
uses: actions/[email protected]
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: 🗑️ Remove PHP platform configuration
if: "matrix.dependencies != 'locked'"
run: composer config platform.php --ansi --unset

- name: 📥 Install "${{ matrix.dependencies }}" dependencies
uses: wayofdev/gh-actions/actions/composer/[email protected]
with:
dependencies: ${{ matrix.dependencies }}

- name: 🧪 Run phpunit tests with Pest
run: composer test
97 changes: 97 additions & 0 deletions .github/workflows/testing-mysql.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,97 @@
---

on: # yamllint disable-line rule:truthy
pull_request:
branches:
- master
push:
branches:
- master

name: 🧪 Testing (MySQL)

env:
DB_HOST: 127.0.0.1
DB_PORT: 13306
DB_USERNAME: cycle
DB_PASSWORD: ${{ secrets.DB_PASSWORD }}
DB_CONNECTION: mysql
DB_DATABASE: default

jobs:
test-mysql:
timeout-minutes: 4
runs-on: ${{ matrix.os }}
concurrency:
cancel-in-progress: true
group: test-mysql-${{ github.workflow }}-${{ github.event.pull_request.number || github.ref }}-${{ matrix.php-version }}-${{ matrix.dependencies }}
strategy:
fail-fast: true
matrix:
os:
- 'ubuntu-latest'
php-version:
- '8.2'
dependencies:
- locked
mysql-version:
- latest

services:
mysql:
image: mysql:${{ matrix.mysql-version }}
env:
MYSQL_ROOT_HOST: '%'
MYSQL_USER: 'cycle'
MYSQL_PASSWORD: ${{ secrets.DB_PASSWORD }}
MYSQL_ROOT_PASSWORD: ${{ secrets.DB_PASSWORD }}
MYSQL_DATABASE: 'default'
options: >-
--health-cmd="mysqladmin ping"
--health-interval 10s
--health-timeout 5s
--health-retries 5
ports:
- 13306:3306

steps:
- name: 📦 Check out the codebase
uses: actions/[email protected]

- name: 🛠️ Setup PHP
uses: shivammathur/[email protected]
with:
php-version: ${{ matrix.php-version }}
extensions: none, ctype, dom, json, mbstring, simplexml, tokenizer, xml, xmlwriter, pdo, curl, fileinfo, pdo_mysql
ini-values: error_reporting=E_ALL
coverage: none

- name: 🛠️ Setup problem matchers
run: |
echo "::add-matcher::${{ runner.tool_cache }}/php.json"
echo "::add-matcher::${{ runner.tool_cache }}/phpunit.json"
- name: 🤖 Validate composer.json and composer.lock
run: composer validate --ansi --strict

- name: 🔍 Get composer cache directory
uses: wayofdev/gh-actions/actions/composer/[email protected]

- name: ♻️ Restore cached dependencies installed with composer
uses: actions/[email protected]
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: 🗑️ Remove PHP platform configuration
if: "matrix.dependencies != 'locked'"
run: composer config platform.php --ansi --unset

- name: 📥 Install "${{ matrix.dependencies }}" dependencies
uses: wayofdev/gh-actions/actions/composer/[email protected]
with:
dependencies: ${{ matrix.dependencies }}

- name: 🧪 Run phpunit tests with Pest
run: composer test
Loading

0 comments on commit efe5351

Please sign in to comment.