-
Notifications
You must be signed in to change notification settings - Fork 4
112 lines (92 loc) · 2.5 KB
/
policy-engine.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
name: '@app/policy-engine CI'
on:
push:
paths:
- apps/policy-engine/**
- .github/workflows/policy-engine.yml
- jest.config.ts
- jest.preset.js
- .eslintrc.json
- .prettierrc
- package.json
- package-lock.json
jobs:
build-and-test:
name: Build and test
runs-on: ubuntu-latest
services:
postgres:
image: postgres:14
ports:
- '5432:5432'
env:
POSTGRES_USER: postgres
POSTGRES_PASSWORD: postgres
options: >-
--health-cmd pg_isready
--health-interval 10s
--health-timeout 5s
--health-retries 5
steps:
- name: Checkout
uses: actions/checkout@master
- name: Install Node.js
uses: actions/setup-node@v3
with:
node-version: '20.4.0'
- name: Install Open Policy Agent CLI
uses: open-policy-agent/setup-opa@v2
with:
version: latest
- name: Install dependencies
run: |
make install/ci
- name: Code format
shell: bash
run: |
make policy-engine/format/check
make policy-engine/lint/check
- name: Setup database and Prisma types
shell: bash
run: |
make policy-engine/copy-default-env
make policy-engine/test/db/setup
make policy-engine/db/generate-types
- name: Test types
shell: bash
run: |
make policy-engine/test/type
- name: Test unit
shell: bash
run: |
make policy-engine/test/unit
- name: Test integration
shell: bash
run: |
make policy-engine/test/integration
- name: Test E2E
shell: bash
run: |
make policy-engine/test/e2e
- name: Send Slack notification on failure
if: failure() && github.ref == 'refs/heads/main'
uses: 8398a7/action-slack@v3
with:
username: GitHub
author_name: '@app/policy-engine CI failed'
status: ${{ job.status }}
fields: message,commit,author
env:
SLACK_WEBHOOK_URL: ${{ secrets.SLACK_WEBHOOK }}
opa-rego:
name: Open Agent Policy CI
runs-on: ubuntu-latest
steps:
- name: Check out repository code
uses: actions/checkout@v3
- name: Setup OPA
uses: open-policy-agent/setup-opa@v2
with:
version: latest
- name: Test rego
run: make policy-engine/rego/test