This repository has been archived by the owner on Oct 14, 2024. It is now read-only.
NOISSUE - Add property based testing to auth API #115
Workflow file for this run
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
# Copyright (c) Abstract Machines | |
# SPDX-License-Identifier: Apache-2.0 | |
name: Property Based Tests | |
on: | |
push: | |
branches: | |
- main | |
paths: | |
- ".github/workflows/api-tests.yml" | |
- "api/**" | |
- "auth/api/http/**" | |
- "bootstrap/api**" | |
- "certs/api/**" | |
- "consumers/notifiers/api/**" | |
- "http/api/**" | |
- "invitations/api/**" | |
- "provision/api/**" | |
- "readers/api/**" | |
- "things/api/**" | |
- "twins/api/**" | |
- "users/api/**" | |
pull_request: | |
branches: | |
- main | |
paths: | |
- ".github/workflows/api-tests.yml" | |
- "api/**" | |
- "auth/api/http/**" | |
- "bootstrap/api**" | |
- "certs/api/**" | |
- "consumers/notifiers/api/**" | |
- "http/api/**" | |
- "invitations/api/**" | |
- "provision/api/**" | |
- "readers/api/**" | |
- "things/api/**" | |
- "twins/api/**" | |
- "users/api/**" | |
env: | |
TOKENS_URL: http://localhost:9002/users/tokens/issue | |
DOMAINS_URL: http://localhost:8189/domains | |
USER_IDENTITY: [email protected] | |
USER_SECRET: 12345678 | |
DOMAIN_NAME: demo-test | |
USERS_URL: http://localhost:9002 | |
THINGS_URL: http://localhost:9000 | |
INVITATIONS_URL: http://localhost:9020 | |
AUTH_URL: http://localhost:8189 | |
jobs: | |
api-test: | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout Code | |
uses: actions/checkout@v4 | |
- name: Install Go | |
uses: actions/setup-go@v4 | |
with: | |
go-version: 1.21.x | |
cache-dependency-path: "go.sum" | |
- name: Build images | |
run: make all -j $(nproc) && make dockers_dev -j $(nproc) | |
- name: Start containers | |
run: make run up args="-d" && sleep 10 | |
- name: Set access token | |
run: | | |
export USER_TOKEN=$(curl -sSX POST $TOKENS_URL -H "Content-Type: application/json" -d "{\"identity\": \"$USER_IDENTITY\",\"secret\": \"$USER_SECRET\"}" | jq -r .access_token) | |
export DOMAIN_ID=$(curl -sSX POST $DOMAINS_URL -H "Content-Type: application/json" -H "Authorization: Bearer $USER_TOKEN" -d "{\"name\":\"$DOMAIN_NAME\",\"alias\":\"$DOMAIN_NAME\"}" | jq -r .id) | |
export USER_TOKEN=$(curl -sSX POST $TOKENS_URL -H "Content-Type: application/json" -d "{\"identity\": \"$USER_IDENTITY\",\"secret\": \"$USER_SECRET\",\"domain_id\": \"$DOMAIN_ID\"}" | jq -r .access_token) | |
echo "USER_TOKEN=$USER_TOKEN" >> $GITHUB_ENV | |
- name: Check for changes in specific paths | |
uses: dorny/paths-filter@v2 | |
id: changes | |
with: | |
filters: | | |
auth: | |
- ".github/workflows/api-tests.yml" | |
- "api/openapi/auth.yml" | |
- "auth/api/http/**" | |
bootstrap: | |
- ".github/workflows/api-tests.yml" | |
- "api/openapi/bootstrap.yml" | |
- "bootstrap/api/**" | |
certs: | |
- ".github/workflows/api-tests.yml" | |
- "api/openapi/certs.yml" | |
- "certs/api/**" | |
notifiers: | |
- ".github/workflows/api-tests.yml" | |
- "api/openapi/notifiers.yml" | |
- "consumers/notifiers/api/**" | |
http: | |
- ".github/workflows/api-tests.yml" | |
- "api/openapi/http.yml" | |
- "http/api/**" | |
invitations: | |
- ".github/workflows/api-tests.yml" | |
- "api/openapi/invitations.yml" | |
- "invitations/api/**" | |
provision: | |
- ".github/workflows/api-tests.yml" | |
- "api/openapi/provision.yml" | |
- "provision/api/**" | |
readers: | |
- ".github/workflows/api-tests.yml" | |
- "api/openapi/readers.yml" | |
- "readers/api/**" | |
things: | |
- ".github/workflows/api-tests.yml" | |
- "api/openapi/things.yml" | |
- "things/api/**" | |
twins: | |
- ".github/workflows/api-tests.yml" | |
- "api/openapi/twins.yml" | |
- "twins/api/**" | |
users: | |
- ".github/workflows/api-tests.yml" | |
- "api/openapi/users.yml" | |
- "users/api/**" | |
- name: Run Users API tests | |
if: steps.changes.outputs.users == 'true' | |
uses: schemathesis/action@v1 | |
with: | |
schema: api/openapi/users.yml | |
base-url: ${{ env.USERS_URL }} | |
checks: all | |
report: false | |
args: '--header "Authorization: Bearer ${{ env.USER_TOKEN }}" --contrib-unique-data --contrib-openapi-formats-uuid --hypothesis-suppress-health-check=filter_too_much --stateful=links' | |
- name: Run Things API tests | |
if: steps.changes.outputs.things == 'true' | |
uses: schemathesis/action@v1 | |
with: | |
schema: api/openapi/things.yml | |
base-url: ${{ env.THINGS_URL }} | |
checks: all | |
report: false | |
args: '--header "Authorization: Bearer ${{ env.USER_TOKEN }}" --contrib-unique-data --contrib-openapi-formats-uuid --hypothesis-suppress-health-check=filter_too_much --stateful=links' | |
- name: Run Invitations API tests | |
if: steps.changes.outputs.invitations == 'true' | |
uses: schemathesis/action@v1 | |
with: | |
schema: api/openapi/invitations.yml | |
base-url: ${{ env.INVITATIONS_URL }} | |
checks: all | |
report: false | |
args: '--header "Authorization: Bearer ${{ env.USER_TOKEN }}" --contrib-unique-data --contrib-openapi-formats-uuid --hypothesis-suppress-health-check=filter_too_much --stateful=links' | |
- name: Run Auth API tests | |
if: steps.changes.outputs.auth == 'true' | |
uses: schemathesis/action@v1 | |
with: | |
schema: api/openapi/auth.yml | |
base-url: ${{ env.AUTH_URL }} | |
checks: all | |
report: false | |
args: '--header "Authorization: Bearer ${{ env.USER_TOKEN }}" --contrib-unique-data --contrib-openapi-formats-uuid --hypothesis-suppress-health-check=filter_too_much --stateful=links' | |
- name: Stop containers | |
if: always() | |
run: make run down args="-v" |