forked from squizlabs/PHP_CodeSniffer
-
Notifications
You must be signed in to change notification settings - Fork 1
205 lines (163 loc) · 6.43 KB
/
test-requirements-check.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
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
name: Test requirements check
on:
# Run on pushes to master and on pull requests which touch files related to the requirements check.
# No need to run this workflow when there are only irrelevant changes.
push:
# branches:
# - master
# tags:
# - '**'
paths:
# TODO: verify!!!
- '.github/workflows/test-requirements-check.yml'
- '.github/workflows/reusable-build-phar.yml'
- 'bin/phpcs'
- 'bin/phpcbf'
- 'requirements.php'
- 'scripts/**'
pull_request:
paths:
- '.github/workflows/test-requirements-check.yml'
- '.github/workflows/reusable-build-phar.yml'
- 'bin/phpcs'
- 'bin/phpcbf'
- 'requirements.php'
- 'scripts/**'
# Allow manually triggering the workflow.
workflow_dispatch:
# Cancels all previous workflow runs for the same branch that have not yet completed.
concurrency:
# The concurrency group contains the workflow name and the branch name.
group: ${{ github.workflow }}-${{ github.ref }}
cancel-in-progress: true
jobs:
# Make sure that the files involved in the requirements check don't contain parse errors
# for the PHP versions supported by the requirements check to prevent the tests being run
# failing on the parse errors instead of on the requirements check
# (which would easily go unnoticed).
lint:
runs-on: ubuntu-latest
strategy:
matrix:
php: ['5.3', '5.4', '5.5', '5.6', '7.0', '7.1']
name: "Lint: PHP ${{ matrix.php }}"
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Install PHP
uses: shivammathur/setup-php@v2
with:
php-version: ${{ matrix.php }}
coverage: none
- name: "Lint bin/phpcs"
run: php -l ./bin/phpcs
- name: "Lint bin/phpcbf"
run: php -l ./bin/phpcbf
- name: "Lint requirements.php"
run: php -l ./requirements.php
# The matrix for these tests should be the same for the "plain" file test as for the PHAR test.
# This matrix, however, is quite complex, so maintaining it manually would be pretty error prone.
# So this job uses a PHP script to generate the matrix based on a fixed set of variables.
#
# The resulting matrix contains builds which combine the following variables:
# - os: ubuntu / windows
# - cmd: phpcs / phpcbf
# - php: 7.2 (minimum PHP version for 4.x), latest and nightly with the required extensions (should pass the check).
# - php: 5.3 (minimum for the requirements check) and 7.1 with the required extension (should fail the PHP version check).
# - php: 7.2 (minimum PHP version for 4.x), latest and nightly WITHOUT the required extension (should fail the check for extensions).
#
# Each combination also contains a "expect" key to set the expectations for success / failure.
#
# The scripts involved in generating the matrix can be found in the `/scripts/` directory.
prepare-matrix:
needs: lint
name: Get test matrix
runs-on: ubuntu-latest
outputs:
matrix: ${{ steps.set-matrix.outputs.MATRIX }}
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Install PHP
uses: shivammathur/setup-php@v2
with:
php-version: 'latest'
ini-values: 'error_reporting=-1, display_errors=On'
coverage: none
- name: Set matrix
id: set-matrix
run: echo "MATRIX=$(php scripts/get-requirements-check-matrix.php)" >> "$GITHUB_OUTPUT"
- name: "DEBUG: show generated matrix"
run: echo ${{ steps.set-matrix.outputs.MATRIX }}
# Test that the requirements check works correctly when using a Composer install or git clone of PHPCS.
test-plain:
needs: prepare-matrix
strategy:
fail-fast: false
matrix: ${{ fromJson(needs.prepare-matrix.outputs.matrix) }}
name: "Plain: ${{ matrix.cmd == 'phpcs' && 'cs' || 'cbf' }} / ${{ matrix.php }} / ${{ matrix.name }} (${{ matrix.os == 'ubuntu-latest' && 'nix' || 'Win' }})"
continue-on-error: ${{ matrix.php == 'nightly' }}
runs-on: ${{ matrix.os }}
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Install PHP
uses: shivammathur/setup-php@v2
with:
php-version: ${{ matrix.php }}
ini-values: 'error_reporting=-1, display_errors=On'
extensions: ${{ matrix.extensions }}
coverage: none
env:
fail-fast: true
- name: Run the test
id: check
continue-on-error: true
run: php "bin/${{ matrix.cmd }}" --version
- name: Check the result of a successful test against expectation
if: ${{ steps.check.outcome == 'success' && matrix.expect == 'fail' }}
run: exit 1
- name: Check the result of a failed test against expectation
if: ${{ steps.check.outcome != 'success' && matrix.expect == 'success' }}
run: exit 1
build-phars:
needs: lint
name: "Build Phar on PHP 8.0"
uses: ./.github/workflows/reusable-build-phar.yml
with:
uploadArtifacts: true
# Test that the requirements check works correctly when using a PHPCS/PHPCBF PHAR file.
test-phar:
needs: [prepare-matrix, build-phars]
strategy:
fail-fast: false
matrix: ${{ fromJson(needs.prepare-matrix.outputs.matrix) }}
name: "PHAR: ${{ matrix.cmd == 'phpcs' && 'cs' || 'cbf' }} / ${{ matrix.php }} / ${{ matrix.name }} (${{ matrix.os == 'ubuntu-latest' && 'nix' || 'Win' }})"
continue-on-error: ${{ matrix.php == 'nightly' }}
runs-on: ${{ matrix.os }}
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Install PHP
uses: shivammathur/setup-php@v2
with:
php-version: ${{ matrix.php }}
ini-values: 'error_reporting=-1, display_errors=On'
extensions: ${{ matrix.extensions }}
coverage: none
env:
fail-fast: true
- name: Download the phar
uses: actions/download-artifact@v4
with:
name: ${{ matrix.cmd }}-phar
- name: Run the test
id: check
continue-on-error: true
run: php ${{ matrix.cmd }}.phar --version
- name: Check the result of a successful test against expectation
if: ${{ steps.check.outcome == 'success' && matrix.expect == 'fail' }}
run: exit 1
- name: Check the result of a failed test against expectation
if: ${{ steps.check.outcome != 'success' && matrix.expect == 'success' }}
run: exit 1