-
Notifications
You must be signed in to change notification settings - Fork 1
135 lines (115 loc) · 3.98 KB
/
push-main.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
name: push-main
on:
push:
branches:
- main
jobs:
test:
runs-on: ubuntu-22.04
steps:
- name: Checkout
uses: actions/checkout@v2
- name: Install deps
run: |
pip3 install -r requirements_api.txt -r requirements_worker.txt -r requirements_dev.txt
- name: Bring up stack
run: make up-dbs && sleep 30
- name: Check stack
run: make ps
- name: Run tests with coverage
run: make test-coverage
# - uses: codecov/codecov-action@v4
# with:
# token: ${{ secrets.CODECOV_TOKEN }}
# files: ./coverage.xml
# fail_ci_if_error: true
docker:
runs-on: ubuntu-22.04
needs: test
outputs:
tag: ${{ steps.source.outputs.TAG }}
steps:
- name: Checkout
uses: actions/checkout@v2
- id: last
uses: pozetroninc/github-action-get-latest-release@master
with:
repository: ${{ github.repository }}
- name: Tag name
id: source
run: |
echo ::set-output name=TAG::${{ steps.last.outputs.release }}-${{ github.run_number }}
- name: Login to DockerHub
uses: docker/login-action@v1
with:
username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_TOKEN }}
- name: Build and push API
uses: docker/build-push-action@v2
with:
context: .
file: ./Dockerfile
target: prod
push: true
build-args: |
SERVICE_NAME=api
tags: sudoblock/icon-governance-api:latest, sudoblock/icon-governance-api:${{ steps.source.outputs.TAG }}
- name: Build and push worker
uses: docker/build-push-action@v2
with:
context: .
file: ./Dockerfile
target: prod
push: true
build-args: |
SERVICE_NAME=worker
tags: sudoblock/icon-governance-worker:latest, sudoblock/icon-governance-worker:${{ steps.source.outputs.TAG }}
push_refs:
runs-on: ubuntu-22.04
needs: docker
strategy:
max-parallel: 1
matrix:
include:
- cluster: prod-ams
network_name: mainnet
network_version: v2
- cluster: prod-ams
network_name: lisbon
network_version: v2
- cluster: prod-ams
network_name: berlin
network_version: v2
steps:
- name: Checkout charts repo
uses: actions/checkout@v2
with:
repository: sudoblockio/icon-charts
ref: main
path: charts
token: ${{ secrets.ICON_CHARTS_PAT }}
- name: Update API ${{ matrix.cluster }}/${{ matrix.network_name }}-${{ matrix.network_version }} deployment values file
uses: fjogeleit/yaml-update-action@master
with:
workDir: charts
repository: sudoblockio/icon-charts
valueFile: 'deployments/${{ matrix.cluster }}/${{ matrix.network_name }}-${{ matrix.network_version }}/governance/tags.yaml'
propertyPath: 'api.image.tag'
value: ${{needs.docker.outputs.tag}}
branch: main
createPR: 'false'
updateFile: true
commitChange: false
- name: Update worker ${{ matrix.cluster }}/${{ matrix.network_name }}-${{ matrix.network_version }} deployment values file
uses: fjogeleit/yaml-update-action@master
with:
workDir: charts
repository: sudoblockio/icon-charts
valueFile: 'deployments/${{ matrix.cluster }}/${{ matrix.network_name }}-${{ matrix.network_version }}/governance/tags.yaml'
propertyPath: 'worker.image.tag'
value: ${{needs.docker.outputs.tag}}
branch: main
createPR: 'false'
updateFile: true
message: "governance ${{ matrix.cluster }}/${{ matrix.network_name }}-${{ matrix.network_version }} deployment image version to ${{needs.docker.outputs.tag}}"
token: '${{ secrets.ICON_CHARTS_PAT }}'