Skip to content

trigger tests against keycloak 26.0.7 #358

trigger tests against keycloak 26.0.7

trigger tests against keycloak 26.0.7 #358

Workflow file for this run

name: wipac ci/cd
on:
push:
branches:
- '**'
tags-ignore:
- '**'
jobs:
flake8:
needs: []
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- uses: actions/setup-python@v4
- uses: WIPACrepo/[email protected]
py-setup:
runs-on: ubuntu-latest
steps:
- name: checkout
uses: actions/checkout@v3
with:
token: ${{ secrets.PERSONAL_ACCESS_TOKEN }}
- uses: WIPACrepo/[email protected]
py-versions:
needs: [py-setup]
runs-on: ubuntu-latest
outputs:
matrix: ${{ steps.versions.outputs.matrix }}
steps:
- uses: actions/checkout@v3
- id: versions
uses: WIPACrepo/[email protected]
pip-install:
needs: [py-versions]
runs-on: ubuntu-latest
strategy:
max-parallel: 4
fail-fast: false
matrix:
versions: ${{ fromJSON(needs.py-versions.outputs.matrix) }}
steps:
- uses: actions/checkout@v3
- uses: actions/setup-python@v4
with:
python-version: ${{ matrix.versions }}
- run: |
pip install --upgrade pip wheel setuptools
pip install .
py-tests:
needs: [py-versions]
runs-on: ubuntu-latest
services:
keycloak:
image: ghcr.io/wipacrepo/keycloak-rest-services:test-keycloak-master
env:
KEYCLOAK_ADMIN: admin
KEYCLOAK_ADMIN_PASSWORD: admin
CMD: start-dev
ports:
- 8080:8080
mongo:
image: mongo:4.0
ports:
- 27017:27017
env:
KEYCLOAK_URL: http://localhost:8080
USERNAME: admin
PASSWORD: admin
steps:
- uses: actions/checkout@v3
- uses: actions/setup-python@v4
with:
python-version: ${{ fromJSON(needs.py-versions.outputs.matrix)[0] }}
- name: Setup Dependencies
run: |
pip install --upgrade pip wheel setuptools
pip install .[tests]
- name: Run Tests
run: |
python -m pytest tests --tb=short --log-level=INFO -v
web-tests:
needs: [py-versions]
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- uses: actions/setup-python@v4
with:
python-version: ${{ fromJSON(needs.py-versions.outputs.matrix)[0] }}
- name: Setup Dependencies
run: |
pip install --upgrade pip wheel setuptools
pip install .
- name: Run Tests
run: |
python -m user_mgmt.test_server &
docker run --network=host -v $PWD:/e2e -w /e2e cypress/included:9.5.4
release:
if: ${{ github.ref == 'refs/heads/master' || github.ref == 'refs/heads/main' }}
needs: [pip-install, py-tests, web-tests]
runs-on: ubuntu-latest
concurrency: release
steps:
- uses: actions/checkout@v3
with:
fetch-depth: 0
token: ${{ secrets.PERSONAL_ACCESS_TOKEN }}
- name: Python Semantic Release
uses: relekang/[email protected]
with:
github_token: ${{ secrets.PERSONAL_ACCESS_TOKEN }}
# DOES NOT GO TO PYPI
#repository_username: __token__
#repository_password: ${{ secrets.PYPI_TOKEN }}
docker:
name: "Docker Image"
needs: [pip-install, py-tests, web-tests]
runs-on: ubuntu-latest
steps:
- name: Checkout Project
uses: actions/checkout@v3
- name: Docker meta
id: docker_meta
uses: docker/metadata-action@v4
with:
images: |
ghcr.io/WIPACRepo/user-management
tags: |
type=ref,event=branch
type=semver,pattern={{major}}
type=semver,pattern={{major}}.{{minor}}
type=semver,pattern={{major}}.{{minor}}.{{patch}}
- name: Login to GitHub Container Registry
uses: docker/login-action@v2
if: ${{ github.event_name != 'pull_request' }}
with:
registry: ghcr.io
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}
- name: Push Docker Image
uses: docker/build-push-action@v4
with:
context: .
push: ${{ github.event_name != 'pull_request' }}
tags: ${{ steps.docker_meta.outputs.tags }}
labels: ${{ steps.docker_meta.outputs.labels }}