-
Notifications
You must be signed in to change notification settings - Fork 4
244 lines (206 loc) · 6.07 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
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
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
name: ci
on:
workflow_dispatch:
push:
branches:
- main
tags:
- "*"
pull_request:
branches:
- main
env:
AWS_ACCOUNT_ID: ${{ secrets.PROD_AWS_ACCOUNT_NUMBER }}
AWS_REGION: us-west-2
permissions:
id-token: write # This is required for requesting the JWT
contents: write # This is required for actions/checkout
jobs:
build:
name: build
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- uses: actions/setup-node@v3
with:
node-version: 18
cache: npm
- run: npm ci
# Separate cache for build dir, we reuse it in release publish workflow
- name: Cache build output
if: startsWith(github.ref, 'refs/tags/v')
uses: actions/cache@v3
id: build-cache
with:
path: dist
key: ${{ runner.os }}-${{ github.sha }}
- name: Confirm build works
if: steps.build-cache.outputs.cache-hit != 'true'
run: npm run build
# Persist produced build dir:
# - this is not for releases, but for quick testing during the dev
# - action artifacts can be downloaded for 90 days, then are removed by github
- name: Attach produced build to Github Action
uses: actions/upload-artifact@v2
with:
name: saturn-${{ github.sha }}
path: dist
if-no-files-found: error
build-webui:
name: build-webui
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- uses: actions/setup-node@v3
with:
node-version: 18
cache: npm
- run: npm ci
# Separate cache for build dir, we reuse it in release publish workflow
- name: Cache build output
if: startsWith(github.ref, 'refs/tags/v')
uses: actions/cache@v3
id: build-cache
with:
path: dist
key: ${{ runner.os }}-${{ github.sha }}-webui
- name: Confirm build works
if: steps.build-cache.outputs.cache-hit != 'true'
run: npm run build
# Persist produced build dir:
# - this is not for releases, but for quick testing during the dev
# - action artifacts can be downloaded for 90 days, then are removed by github
- name: Attach produced build to Github Action
uses: actions/upload-artifact@v2
with:
name: saturn-webui-${{ github.sha }}
path: dist
if-no-files-found: error
test-unit:
name: "test:unit"
needs: [build, build-webui]
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- uses: actions/setup-node@v3
with:
node-version: 18
cache: npm
- run: npm ci
- name: Run unit tests
run: npm run test:unit
test-e2e:
name: "test:e2e"
needs: [build, build-webui]
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- uses: actions/setup-node@v3
with:
node-version: 18
cache: npm
- run: npm ci
- name: Run E2E tests
run: npm run test:e2e
- name: Run WebUI E2E tests
run: npm run test:webui-e2e
# separate check for TS
typecheck:
name: typecheck
needs: [build, build-webui]
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- uses: actions/setup-node@v3
with:
node-version: 18
cache: npm
- run: npm ci
- name: Fancy Typecheck with GH annotations
uses: gozala/[email protected]
with:
project: tsconfig.json
# make sure local check is also ok
- name: Userland check
run: npm run typecheck
# separate check for eslint
eslint:
name: eslint
needs: [build, build-webui]
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- uses: actions/setup-node@v3
with:
node-version: 18
cache: npm
- run: npm ci
- name: ESLint
run: npm run eslint
release-webui:
if: startsWith(github.ref, 'refs/tags/v')
name: release-webui
needs: [build, build-webui, test-unit, test-e2e, typecheck, eslint]
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- uses: actions/setup-node@v3
with:
node-version: 18
cache: npm
# Reuse tag build
- name: Cache build dir
uses: actions/cache@v3
id: build-cache
with:
path: dist
key: ${{ runner.os }}-${{ github.sha }}-webui
- name: Install and Build 🔧
if: steps.build-cache.outputs.cache-hit != 'true'
run: |
npm ci
npm run build
- name: Create archive
run: |
cd dist
tar -czf ../saturn-webui.tar.gz *
- name: Release
uses: softprops/action-gh-release@v1
with:
files: saturn-webui.tar.gz
deploy:
if: startsWith(github.ref, 'refs/tags/v')
name: deploy
needs: [build, build-webui, test-unit, test-e2e, typecheck, eslint]
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- name: Configure AWS Credentials
uses: aws-actions/configure-aws-credentials@v1
with:
aws-region: ${{ env.AWS_REGION }}
role-to-assume: arn:aws:iam::${{ secrets.PROD_AWS_ACCOUNT_NUMBER }}:role/L1-dashboard-ci
- uses: actions/setup-node@v3
with:
node-version: 18
cache: npm
# Reuse tag build
- name: Cache build dir
uses: actions/cache@v3
id: build-cache
with:
path: dist
key: ${{ runner.os }}-${{ github.sha }}
- name: Install and Build 🔧
if: steps.build-cache.outputs.cache-hit != 'true'
run: |
npm ci
npm run build
- name: Push to S3
env:
BUCKET: filecoin-saturn
run: |
aws s3 cp dist/index.html s3://$BUCKET/index.html \
--cache-control "no-cache" --only-show-errors
aws s3 cp dist/assets s3://$BUCKET/assets/ --recursive \
--cache-control "public, max-age=2592000" --only-show-errors