forked from bcgov/sbc-auth
-
Notifications
You must be signed in to change notification settings - Fork 0
86 lines (78 loc) · 2.47 KB
/
auth-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
name: Auth API CI
on:
pull_request:
branches:
- development
paths:
- "auth-api/**"
jobs:
auth-api-ci:
runs-on: ubuntu-20.04
defaults:
run:
shell: bash
working-directory: ./auth-api
if: github.repository == 'bcgov/sbc-auth'
env:
FLASK_ENV: "testing"
DATABASE_TEST_URL: "postgresql://postgres:postgres@localhost:5432/postgres"
JWT_OIDC_TEST_ISSUER: "http://localhost:8081/auth/realms/demo"
JWT_OIDC_TEST_WELL_KNOWN_CONFIG: "http://localhost:8081/auth/realms/demo/.well-known/openid-configuration"
JWT_OIDC_TEST_ALGORITHMS: "RS256"
JWT_OIDC_TEST_AUDIENCE: "sbc-auth-web"
JWT_OIDC_TEST_CLIENT_SECRET: "1111111111"
JWT_OIDC_TEST_JWKS_CACHE_TIMEOUT: "6000"
KEYCLOAK_TEST_ADMIN_CLIENTID: "sbc-auth-admin"
KEYCLOAK_TEST_ADMIN_SECRET: "2222222222"
KEYCLOAK_TEST_AUTH_AUDIENCE: "sbc-auth-web"
KEYCLOAK_TEST_AUTH_CLIENT_SECRET: "1111111111"
KEYCLOAK_TEST_BASE_URL: "http://localhost:8081"
KEYCLOAK_TEST_REALMNAME: "demo"
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]"
strategy:
matrix:
python-version: [3.8]
services:
postgres:
image: postgres:11
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@v2
- name: Set up Python ${{ matrix.python-version }}
uses: actions/setup-python@v1
with:
python-version: ${{ matrix.python-version }}
- name: Install dependencies
run: |
make setup
- name: Lint with pylint
run: |
make lint
- name: Lint with flake8
run: |
make flake8
- name: Test with pytest
run: |
make test
- name: Upload coverage to Codecov
uses: codecov/codecov-action@v1
with:
file: ./auth-api/coverage.xml
flags: authapi
name: codecov-auth-api
fail_ci_if_error: true
- name: build to check strictness
run: |
make build-nc