-
Notifications
You must be signed in to change notification settings - Fork 4
83 lines (71 loc) · 2.4 KB
/
build.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
name: Build
on:
push:
branches:
- 'master'
- 'develop'
- 'feature/**'
- 'release/**'
- 'hotfix/**'
- 'ci/**'
jobs:
compile:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v1
- uses: actions/setup-node@v1
with:
node-version: 12.x
- name: Cache node_modules
id: cache_node_modules
uses: actions/cache@v1
with:
path: node_modules
key: ${{ runner.os }}-node-${{ hashFiles('**/yarn.lock') }}
- if: steps.cache_node_modules.outputs.cache-hit != 'true'
run: yarn install
- run: yarn run compile
test_coverage:
needs: compile
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v1
- uses: actions/setup-node@v1
with:
node-version: '12'
- name: Cache node_modules
id: cache_node_modules
uses: actions/cache@v1
with:
path: node_modules
key: ${{ runner.os }}-node-${{ hashFiles('**/yarn.lock') }}
- if: steps.cache_node_modules.outputs.cache-hit != 'true'
run: yarn install
- run: yarn run test_coverage
deploy_aws:
if: contains(github.ref, 'refs/heads/develop') || contains(github.ref, 'refs/heads/master') || contains(github.ref, 'refs/heads/release') || contains(github.ref, 'refs/heads/ci')
needs: [compile,test_coverage]
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v1
- uses: actions/setup-node@v1
with:
node-version: '12'
- name: Cache node_modules
id: cache_node_modules
uses: actions/cache@v1
with:
path: node_modules
key: ${{ runner.os }}-node-${{ hashFiles('**/yarn.lock') }}
- if: steps.cache_node_modules.outputs.cache-hit != 'true'
run: yarn install
- run: npx cryptfile decrypt_all cfg=.cryptfile.cfg pw=${{ secrets.CRYPTFILE_PASSWORD }}
- run: |
mkdir ~/.aws
echo "[default]
aws_access_key_id=${{ secrets.AWS_DEPLOY_KEY }}
aws_secret_access_key=${{ secrets.AWS_DEPLOY_SECRET }}" >> ~/.aws/credentials
- if: contains(github.ref, 'refs/heads/develop') || contains(github.ref, 'refs/heads/ci') || contains(github.ref, 'refs/heads/release')
run: ENV=staging yarn run deploy_aws
- if: contains(github.ref, 'refs/heads/master')
run: ENV=production yarn run deploy_aws