-
Notifications
You must be signed in to change notification settings - Fork 7
99 lines (83 loc) · 2.32 KB
/
continuous-integration.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
name: "Continuous Integration"
on:
workflow_dispatch:
pull_request:
push:
branches:
- '[0-9]+.[0-9]+.x'
- 'master'
schedule:
- cron: "45 9 * * 1"
jobs:
psalm:
name: "Static Analysis"
runs-on: ubuntu-latest
strategy:
matrix:
php-version:
- "8.2"
steps:
- name: "Checkout"
uses: "actions/checkout@v4"
- name: "Install PHP"
uses: "shivammathur/setup-php@v2"
with:
php-version: "${{ matrix.php-version }}"
- name: Install dependencies
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@v2
continue-on-error: true
with:
sarif_file: psalm.sarif
phpunit:
name: "PHPUnit"
runs-on: ubuntu-latest
strategy:
matrix:
php-version:
- "7.4"
- "8.0"
- "8.1"
- "8.2"
- "8.3"
- "8.4"
deps:
- "highest"
codestyle:
- "false"
include:
- php-version: "8.2"
deps: "locked"
codestyle: "true"
- php-version: "7.4"
deps: "lowest"
codestyle: "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"
- name: Install dependencies
uses: ramsey/composer-install@v3
with:
dependency-versions: "${{ matrix.deps }}"
composer-options: '--ignore-platform-req=php+'
- name: "Run PHPCS check"
run: "composer cs-check"
if: "${{ matrix.codestyle == 'true' }}"
- 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
fail_ci_if_error: true
token: ${{ secrets.CODECOV_TOKEN }}