-
Notifications
You must be signed in to change notification settings - Fork 0
123 lines (119 loc) · 4.11 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
name: CI/CD
on:
pull_request:
branches:
- "main"
push:
branches:
- "main"
release:
types: [published]
jobs:
test_functions:
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v2
- uses: actions/setup-python@v2
with:
python-version: "3.12"
- name: Install dependencies
run: pip install -r requirements.txt -r requirements-dev.txt
- name: Test
run: python -m pytest
working-directory: database
- uses: ravsamhq/notify-slack-action@v2
if: always()
with:
status: ${{ job.status }}
notification_title: "${{github.sha}} has {status_message}"
message_format: "{emoji} *{job}* {status_message}"
footer: "<{repo_url}|{repo}> | <{run_url}|View job>"
env:
SLACK_WEBHOOK_URL: ${{ secrets.SLACK_WEBHOOK_URL }}
code-style:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v2
- uses: actions/setup-python@v2
with:
python-version: "3.12"
- uses: pre-commit/[email protected]
- uses: ravsamhq/notify-slack-action@v2
if: always()
with:
status: ${{ job.status }}
notification_title: "${{github.sha}} has {status_message}"
message_format: "{emoji} *{job}* {status_message}"
footer: "<{repo_url}|{repo}> | <{run_url}|View job>"
env:
SLACK_WEBHOOK_URL: ${{ secrets.SLACK_WEBHOOK_URL }}
build-and-deploy-lambda-functions:
runs-on: ubuntu-latest
needs: test_functions
if: github.ref == 'refs/heads/main' || startsWith(github.ref, 'refs/tags/release')
steps:
- uses: actions/checkout@v2
- uses: actions/setup-python@v2
with:
python-version: "3.12"
- name: Build zip files for lambda
run: make build-lambda
- name: Configure AWS Credentials
uses: aws-actions/configure-aws-credentials@v1
with:
aws-access-key-id: ${{ secrets.AWS_LAMBDA_UPLOAD_ACCESS_KEY_ID }}
aws-secret-access-key: ${{ secrets.AWS_LAMBDA_UPLOAD_SECRET_ACCESS_KEY }}
aws-region: ${{ secrets.AWS_REGION }}
- name: Update dev lambda functions
if: github.ref == 'refs/heads/main'
run: make prefix=hame-dev update-lambda -C infra
- name: Report to slack
if: github.ref == 'refs/heads/main'
uses: slackapi/[email protected]
with:
payload: |
{
"text": "dev lambda functions updated to ${{github.sha}}"
}
env:
SLACK_WEBHOOK_URL: ${{ secrets.SLACK_WEBHOOK_URL }}
- name: Update dev database
if: github.ref == 'refs/heads/main'
run: make prefix=hame-dev migrate-db -C infra
- name: Report to slack
if: github.ref == 'refs/heads/main'
uses: slackapi/[email protected]
with:
payload: |
{
"text": "dev database updated to ${{github.sha}}"
}
env:
SLACK_WEBHOOK_URL: ${{ secrets.SLACK_WEBHOOK_URL }}
# - name: Update production lambda functions
# if: startsWith(github.ref, 'refs/tags/release')
# run: make prefix=tarmo-tampere update-lambda -C infra
# - name: Report to slack
# if: startsWith(github.ref, 'refs/tags/release')
# uses: slackapi/[email protected]
# with:
# payload: |
# {
# "text": "TAMPERE lambda functions updated to ${{github.sha}}"
# }
# env:
# SLACK_WEBHOOK_URL: ${{ secrets.SLACK_WEBHOOK_URL }}
# - name: Update production database
# if: startsWith(github.ref, 'refs/tags/release')
# run: make prefix=tarmo-tampere migrate-db -C infra
# - name: Report to slack
# if: startsWith(github.ref, 'refs/tags/release')
# uses: slackapi/[email protected]
# with:
# payload: |
# {
# "text": "TAMPERE database updated to ${{github.sha}}"
# }
# env:
# SLACK_WEBHOOK_URL: ${{ secrets.SLACK_WEBHOOK_URL }}