Skip to content

Add test coverage for authorization request evaluation #208

Add test coverage for authorization request evaluation

Add test coverage for authorization request evaluation #208

Workflow file for this run

name: '@app/authz CI'
on:
push:
paths:
- apps/authz/**
- .github/workflows/authz_ci.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
redis:
image: redis
ports:
- '6379:6379'
env:
REDIS_PORT: 6379
options: >-
--health-cmd "redis-cli ping"
--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 dependencies
run: |
make install/ci
- name: Code format
shell: bash
run: |
make authz/format/check
make authz/lint/check
# TODO: Finish once the authz-node has a database.
- name: Setup database and Prisma types
shell: bash
run: |
make authz/copy-default-env
# make orchestration/test/db/setup
# Generate the orchestration Prisma client types to prevent the type
# tests to fail.
# make orchestration/db/generate-types
- name: Test types
shell: bash
run: |
make authz/test/type
- name: Test unit
shell: bash
run: |
make authz/test/unit
- name: Test integration
shell: bash
run: |
make authz/test/integration
# - name: Test E2E
# shell: bash
# run: |
# make orchestration/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/authz 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: Run OPA Tests
run: make authz/rego/test