-
Notifications
You must be signed in to change notification settings - Fork 3
150 lines (116 loc) · 4.14 KB
/
ci.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
name: CI
on:
push:
branches:
- master
pull_request:
branches:
- master
jobs:
static:
runs-on: ubuntu-latest
env:
APP_ENV: test
TRUSTED_PROXIES: ''
steps:
- name: Checkout code
uses: actions/checkout@v2
- name: Set up PHP
uses: shivammathur/setup-php@v2
with:
php-version: 8.2
- name: Set up Node.js
uses: actions/setup-node@v2
with:
node-version: '18'
- name: Run PHP security checks
uses: symfonycorp/security-checker-action@v5
- name: Run JS security checks
run: npm run audit:high
- name: Install Composer dependencies
run: composer install --no-interaction --no-progress --ignore-platform-reqs
- name: Install Node.js dependencies
run: yarn install --immutable
- name: Cache warmup for PHPStan
run: php bin/console cache:warmup --env=dev
- name: Run PHPStan
run: php bin/phpstan analyse --no-progress --memory-limit 1G src
- name: Lint YAML
run: bin/console lint:yaml config
- name: Lint Twig
run: bin/console lint:twig templates
- name: Lint Container
run: bin/console lint:container
- name: Lint JS
run: yarn lint:js
- name: Lint CSS
run: yarn lint:css
- name: Run PHPUnit tests
run: |
mkdir -p public/build
printf "{}" > public/build/manifest.json
bin/simple-phpunit
deploy_staging:
runs-on: ubuntu-latest
needs: static
if: github.ref == 'refs/heads/master'
environment: staging
env:
APP_ENV: dev
TRUSTED_PROXIES: ''
steps:
- name: Checkout code
uses: actions/checkout@v2
- name: Set up PHP
uses: shivammathur/setup-php@v2
with:
php-version: 8.2
- name: Set up Node.js
uses: actions/setup-node@v2
with:
node-version: '18'
- name: Run PHP security checks
uses: symfonycorp/security-checker-action@v5
- name: Run JS security checks
run: npm run audit:high
- name: Install Composer dependencies
run: composer install --classmap-authoritative --no-interaction --no-progress --ignore-platform-reqs
- name: Install Node.js dependencies
run: yarn install --immutable
- name: Build assets
run: yarn build --mode development
- name: Deploy to staging
run: |
# Add your deployment script here
deploy_prod:
runs-on: ubuntu-latest
needs: static
if: github.ref == 'refs/heads/master'
environment: production
env:
APP_ENV: prod
TRUSTED_PROXIES: ''
steps:
- name: Checkout code
uses: actions/checkout@v2
- name: Set up PHP
uses: shivammathur/setup-php@v2
with:
php-version: 8.2
- name: Set up Node.js
uses: actions/setup-node@v2
with:
node-version: '18'
- name: Run PHP security checks
uses: symfonycorp/security-checker-action@v5
- name: Run JS security checks
run: npm run audit:high
- name: Install Composer dependencies
run: composer install --no-dev --classmap-authoritative --no-interaction --no-progress --ignore-platform-reqs
- name: Install Node.js dependencies
run: yarn install --immutable
- name: Build assets
run: yarn build
- name: Deploy to production
run: |
# Add your deployment script here