forked from bcgov/sbc-pay
-
Notifications
You must be signed in to change notification settings - Fork 0
140 lines (121 loc) · 3.77 KB
/
bcol-api-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
name: BCOL API CI
on:
pull_request:
branches:
- main
- release/*
paths:
- "bcol-api/**"
defaults:
run:
shell: bash
working-directory: ./bcol-api
jobs:
setup-job:
runs-on: ubuntu-20.04
if: github.repository == 'bcgov/sbc-pay'
steps:
- uses: actions/checkout@v4
- run: "true"
linting:
needs: setup-job
runs-on: ubuntu-20.04
strategy:
matrix:
python-version: [3.12]
steps:
- uses: actions/checkout@v4
- name: Set up Python ${{ matrix.python-version }}
uses: actions/setup-python@v5
with:
python-version: ${{ matrix.python-version }}
- name: Install dependencies
run: |
sudo apt update
sudo apt install libsasl2-dev libldap2-dev libssl-dev --yes
make setup
- name: Lint with pylint
id: pylint
run: |
make pylint
- name: Lint with flake8
id: flake8
run: |
make flake8
testing:
needs: setup-job
env:
FLASK_ENV: "testing"
JWT_OIDC_ISSUER: "http://localhost:8081/auth/realms/demo"
JWT_OIDC_WELL_KNOWN_CONFIG: "http://localhost:8081/auth/realms/demo/.well-known/openid-configuration"
JWT_OIDC_ALGORITHMS: "RS256"
JWT_OIDC_AUDIENCE: "sbc-auth-web"
JWT_OIDC_CLIENT_SECRET: "1111111111"
JWT_OIDC_JWKS_CACHE_TIMEOUT: "6000"
BCOL_QUERY_PROFILE_WSDL_URL: "https://appsd1.bconline.gov.bc.ca/access/services/QueryProfile/wsdl/QueryProfile.wsdl"
BCOL_PAYMENTS_WSDL_URL: "https://appsd1.bconline.gov.bc.ca/account/services/DebitAccount/wsdl/DebitAccount.wsdl"
BCOL_LDAP_SERVER: "fake"
BCOL_LDAP_USER_DN_PATTERN: "fake"
BCOL_DEBIT_ACCOUNT_VERSION: "fake"
BCOL_LINK_CODE: "000"
BCOL_APPLIED_CHARGE_WSDL_URL: "https://appsd1.bconline.gov.bc.ca/account/services/AppliedCharge?wsdl"
TOKEN_EXPIRY_PERIOD: 7
EMAIL_SECURITY_PASSWORD_SALT: "my_pwd_salt"
EMAIL_TOKEN_SECRET_KEY: "mySecretKey"
USE_TEST_KEYCLOAK_DOCKER: "YES"
USE_DOCKER_MOCK: "YES"
STAFF_ADMIN_EMAIL: "[email protected]"
runs-on: ubuntu-20.04
strategy:
matrix:
python-version: [3.12]
services:
postgres:
image: postgres:12
env:
POSTGRES_USER: postgres
POSTGRES_PASSWORD: postgres
POSTGRES_DB: postgres
ports:
- 5432:5432
# needed because the postgres container does not provide a healthcheck
options: --health-cmd pg_isready --health-interval 10s --health-timeout 5s --health-retries 5
steps:
- uses: actions/checkout@v4
- name: Set up Python ${{ matrix.python-version }}
uses: actions/setup-python@v5
with:
python-version: ${{ matrix.python-version }}
- name: Install docker-compose
run: |
sudo curl -L https://github.com/docker/compose/releases/latest/download/docker-compose-$(uname -s)-$(uname -m) -o /usr/local/bin/docker-compose
sudo chmod +x /usr/local/bin/docker-compose
docker-compose version
- name: Install dependencies
run: |
sudo apt update
sudo apt install libsasl2-dev libldap2-dev libssl-dev --yes
make setup
- name: Test with pytest
id: test
run: |
make test
- name: Upload coverage to Codecov
uses: codecov/codecov-action@v3
with:
file: ./bcol-api/coverage.xml
flags: bcolapi
name: codecov-bcol-api
fail_ci_if_error: false
build-check:
needs: setup-job
runs-on: ubuntu-20.04
strategy:
matrix:
python-version: [3.12]
steps:
- uses: actions/checkout@v4
- name: build to check strictness
id: build
run: |
make build-nc