This repository was archived by the owner on Dec 6, 2022. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 4
186 lines (163 loc) · 6.36 KB
/
ci_cd.yml
File metadata and controls
186 lines (163 loc) · 6.36 KB
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
name: Build docker image and update service on RTUITLab virtual machine
on:
push:
branches:
- master
env:
# Ask DevOps about SERVICE_NAME value
SERVICE_NAME_API: schedule-rtu_api
SERVICE_NAME_OLD: schedule-rtu_old
SERVICE_NAME_PROXY: schedule-rtu_proxy
SERVICE_NAME_REFRESH_INVOKER: schedule-rtu_refresh-invoker
# Name of github package. Recommendations:
# ghcr.io/rtuitlab/ - must have
# YOUR-STACK-NAME/ - not to store your package in root of RTUITLab organization packages
# YOUR-SERVICE-NAME - to recognize your package
IMAGE_NAME_API: ghcr.io/rtuitlab/schedule-rtu/api
IMAGE_NAME_OLD: ghcr.io/rtuitlab/schedule-rtu/old
IMAGE_NAME_PROXY: ghcr.io/rtuitlab/schedule-rtu/proxy
IMAGE_NAME_REFRESH_INVOKER: ghcr.io/rtuitlab/schedule-rtu/refresh-invoker
jobs:
test:
runs-on: ubuntu-latest
env:
DATABASE_URL: 'sqlite:///./sql_app.db'
APP_SECRET: 'test_secret'
ROOT_PATH: '/api'
steps:
- uses: actions/checkout@v2
- name: Set up Python 3.10
uses: actions/setup-python@v2
with:
python-version: 3.10.2
- name: Install dependencies
run: |
python -m pip install --upgrade pip
pip install -r requirements.txt
- name: Test with pytest
run: |
pytest -s --asyncio-mode=strict
build-api:
needs: [ test ]
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v2
- name: Build image
run: docker build --file Dockerfile --tag $IMAGE_NAME_API ./
- name: Log in to registry
run: echo "${{ secrets.GITHUB_TOKEN }}" | docker login ghcr.io -u ${{ github.actor }} --password-stdin
- name: Push image
run: |
docker tag $IMAGE_NAME_API $IMAGE_NAME_API:latest
docker tag $IMAGE_NAME_API $IMAGE_NAME_API:${{ github.run_number }}
docker push $IMAGE_NAME_API:latest
docker push $IMAGE_NAME_API:${{ github.run_number }}
deploy-api:
needs: [ build-api ]
runs-on: ubuntu-latest
steps:
- name: Update service
uses: appleboy/ssh-action@master
env:
IMAGE: ${{ env.IMAGE_NAME_API }}:${{ github.run_number }}
SERVICE: ${{ env.SERVICE_NAME_API }}
with:
host: ${{ secrets.RTUITLAB_MANAGER_VM_HOST }}
username: ${{ secrets.RTUITLAB_MANAGER_VM_USERNAME }}
key: ${{ secrets.RTUITLAB_MANAGER_VM_SSH_KEY }}
envs: IMAGE,SERVICE
script: docker service update --image $IMAGE $SERVICE --with-registry-auth
build-old:
needs: [ test ]
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v2
- name: Build image
run: docker build --file old/Dockerfile --tag $IMAGE_NAME_OLD old/
- name: Log in to registry
run: echo "${{ secrets.GITHUB_TOKEN }}" | docker login ghcr.io -u ${{ github.actor }} --password-stdin
- name: Push image
run: |
docker tag $IMAGE_NAME_OLD $IMAGE_NAME_OLD:latest
docker tag $IMAGE_NAME_OLD $IMAGE_NAME_OLD:${{ github.run_number }}
docker push $IMAGE_NAME_OLD:latest
docker push $IMAGE_NAME_OLD:${{ github.run_number }}
deploy-old:
needs: [ build-old ]
runs-on: ubuntu-latest
steps:
- name: Update service
uses: appleboy/ssh-action@master
env:
IMAGE: ${{ env.IMAGE_NAME_OLD }}:${{ github.run_number }}
SERVICE: ${{ env.SERVICE_NAME_OLD }}
with:
host: ${{ secrets.RTUITLAB_MANAGER_VM_HOST }}
username: ${{ secrets.RTUITLAB_MANAGER_VM_USERNAME }}
key: ${{ secrets.RTUITLAB_MANAGER_VM_SSH_KEY }}
envs: IMAGE,SERVICE
script: docker service update --image $IMAGE $SERVICE --with-registry-auth
build-proxy:
needs: [ test ]
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v2
- name: Build image
run: docker build --file proxy/Dockerfile --tag $IMAGE_NAME_PROXY proxy/
- name: Log in to registry
run: echo "${{ secrets.GITHUB_TOKEN }}" | docker login ghcr.io -u ${{ github.actor }} --password-stdin
- name: Push image
run: |
docker tag $IMAGE_NAME_PROXY $IMAGE_NAME_PROXY:latest
docker tag $IMAGE_NAME_PROXY $IMAGE_NAME_PROXY:${{ github.run_number }}
docker push $IMAGE_NAME_PROXY:latest
docker push $IMAGE_NAME_PROXY:${{ github.run_number }}
deploy-proxy:
needs: [ build-proxy ]
runs-on: ubuntu-latest
steps:
- name: Update service
uses: appleboy/ssh-action@master
env:
IMAGE: ${{ env.IMAGE_NAME_PROXY }}:${{ github.run_number }}
SERVICE: ${{ env.SERVICE_NAME_PROXY }}
with:
host: ${{ secrets.RTUITLAB_MANAGER_VM_HOST }}
username: ${{ secrets.RTUITLAB_MANAGER_VM_USERNAME }}
key: ${{ secrets.RTUITLAB_MANAGER_VM_SSH_KEY }}
envs: IMAGE,SERVICE
script: docker service update --image $IMAGE $SERVICE --with-registry-auth
build-refresh-invoker:
needs: [ test ]
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v2
- name: Build image
run: docker build --file refresh_invoker/Dockerfile --tag $IMAGE_NAME_REFRESH_INVOKER refresh_invoker/
- name: Log in to registry
run: echo "${{ secrets.GITHUB_TOKEN }}" | docker login ghcr.io -u ${{ github.actor }} --password-stdin
- name: Push image
run: |
docker tag $IMAGE_NAME_REFRESH_INVOKER $IMAGE_NAME_REFRESH_INVOKER:latest
docker tag $IMAGE_NAME_REFRESH_INVOKER $IMAGE_NAME_REFRESH_INVOKER:${{ github.run_number }}
docker push $IMAGE_NAME_REFRESH_INVOKER:latest
docker push $IMAGE_NAME_REFRESH_INVOKER:${{ github.run_number }}
deploy-refresh-invoker:
needs: [ build-refresh-invoker ]
runs-on: ubuntu-latest
steps:
- name: Update service
uses: appleboy/ssh-action@master
env:
IMAGE: ${{ env.IMAGE_NAME_REFRESH_INVOKER }}:${{ github.run_number }}
SERVICE: ${{ env.SERVICE_NAME_REFRESH_INVOKER }}
with:
host: ${{ secrets.RTUITLAB_MANAGER_VM_HOST }}
username: ${{ secrets.RTUITLAB_MANAGER_VM_USERNAME }}
key: ${{ secrets.RTUITLAB_MANAGER_VM_SSH_KEY }}
envs: IMAGE,SERVICE
script: docker service update --image $IMAGE $SERVICE --with-registry-auth