Skip to content

Merge pull request #970 from maykinmedia/feature/967-clear-toelichtin… #1808

Merge pull request #970 from maykinmedia/feature/967-clear-toelichtin…

Merge pull request #970 from maykinmedia/feature/967-clear-toelichtin… #1808

Workflow file for this run

name: Run CI
# Run this workflow every time a new commit pushed to your repository
on:
push:
branches:
- master
tags:
- '*'
pull_request:
workflow_dispatch:
env:
IMAGE_NAME: maykinmedia/sdg-invoervoorziening
DJANGO_SETTINGS_MODULE: sdg.conf.ci
jobs:
tests:
name: Run the Django test suite
runs-on: ubuntu-latest
services:
postgres:
image: postgres:12
env:
POSTGRES_HOST_AUTH_METHOD: trust
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
redis:
image: redis:6
ports:
- 6379:6379
steps:
- uses: actions/checkout@v3
- uses: actions/setup-python@v4
with:
python-version: '3.10.8'
- uses: actions/setup-node@v3
with:
node-version: '12'
- name: Install OS dependencies
run: |
sudo apt-get update
sudo apt-get install libxml2-dev libxmlsec1-dev libxmlsec1-openssl gettext -y
- name: Install dependencies
run: |
pip install -r requirements/setuptools.txt
pip install -r requirements/ci.txt
- name: Build frontend
run: |
cp -r /opt/hostedtoolcache/Python/3.10.8/x64 venv
npm ci
npm run build
env:
VIRTUAL_ENV: venv # rijkshuisstijl
- name: Run tests
run: |
python src/manage.py collectstatic --noinput --link
make trans
coverage run src/manage.py test src
env:
DJANGO_SETTINGS_MODULE: sdg.conf.ci
SECRET_KEY: dummy
DB_USER: postgres
DB_PASSWORD: ''
- name: Publish coverage report
uses: codecov/codecov-action@v1
- name: Generate OAS
run: |
python src/manage.py spectacular --validate --fail-on-warn --file openapi.yaml
- name: Store generated OAS
uses: actions/upload-artifact@v2
with:
name: sdg-oas
path: openapi.yaml
retention-days: 1
# docs:
# name: Build and check documentation
# runs-on: ubuntu-latest
# steps:
# - uses: actions/checkout@v2
# - uses: actions/setup-python@v2
# with:
# python-version: '3.10'
# - name: Install OS dependencies
# run: |
# sudo apt-get update
# sudo apt-get install libxml2-dev libxmlsec1-dev libxmlsec1-openssl
# - name: Install dependencies
# run: |
# pip install -r requirements/setuptools.txt
# pip install -r requirements/ci.txt
# - name: Build and test docs
# working-directory: docs
# run: pytest check_sphinx.py -v --tb=auto
docker_build:
name: Build Docker image
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- name: Set tag
id: vars
run: |
# Strip git ref prefix from version
VERSION=$(echo "${{ github.ref }}" | sed -e 's,.*/\(.*\),\1,')
# Strip "v" prefix from tag name (if present at all)
[[ "${{ github.ref }}" == "refs/tags/"* ]] && VERSION=$(echo $VERSION | sed -e 's/^v//')
# Use Docker `latest` tag convention
[ "$VERSION" == "master" ] && VERSION=latest
echo ::set-output name=tag::${VERSION}
echo ::set-output name=git_hash::${GITHUB_SHA}
- name: Build the Docker image
run: |
docker build . \
--tag $IMAGE_NAME:$RELEASE_VERSION \
--build-arg COMMIT_HASH=${{ steps.vars.outputs.git_hash }} \
--build-arg RELEASE=${RELEASE_VERSION}
env:
RELEASE_VERSION: ${{ steps.vars.outputs.tag }}
- name: Save Docker image
if: github.event_name == 'push' # Only needed for docker-push job
run: docker image save -o image.tar $IMAGE_NAME:${{ steps.vars.outputs.tag }}
- name: Store Docker image artifact
if: github.event_name == 'push' # Only needed for docker-push job
uses: actions/upload-artifact@v2
with:
name: docker-image
path: image.tar
retention-days: 1
oas-up-to-date:
needs: tests
name: Check for unexpected OAS changes
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- name: Download generated OAS
uses: actions/download-artifact@v2
with:
name: sdg-oas
- name: Check for OAS changes
run: |
diff openapi.yaml src/openapi.yaml
oas-lint:
needs: oas-up-to-date
name: Validate OAS
runs-on: ubuntu-latest
steps:
- name: Download generated OAS
uses: actions/download-artifact@v2
with:
name: sdg-oas
- name: Use Node.js
uses: actions/setup-node@v3
with:
node-version: '12'
- name: Install spectral
run: npm install -g @stoplight/[email protected]
- name: Run OAS linter
run: spectral lint ./openapi.yaml
oas-postman:
needs: oas-up-to-date
name: Generate Postman collection from OAS
runs-on: ubuntu-latest
steps:
- name: Download generated OAS
uses: actions/download-artifact@v2
with:
name: sdg-oas
- name: Use Node.js
uses: actions/setup-node@v3
with:
node-version: '12'
- name: Install dependencies
run: npm install -g openapi-to-postmanv2
- name: Create tests folder
run: mkdir -p ./tests/postman
- name: Generate Postman collection
run: openapi2postmanv2 -s ./openapi.yaml -o ./tests/postman/collection.json --pretty
oas-generate-sdks:
needs: oas-up-to-date
name: Generate SDKs from OAS
runs-on: ubuntu-latest
steps:
- name: Download generated OAS
uses: actions/download-artifact@v2
with:
name: sdg-oas
- name: Use Node.js
uses: actions/setup-node@v3
with:
node-version: '12'
- name: Install dependencies
run: npm install -g @openapitools/[email protected]
- name: Validate schema
run: openapi-generator-cli validate -i ./openapi.yaml
- name: Generate Java client
run: openapi-generator-cli generate -i ./openapi.yaml --global-property=modelTests=false,apiTests=false,modelDocs=false,apiDocs=false \
-o ./sdks/java -g java --additional-properties=dateLibrary=java8,java8=true,optionalProjectFile=false,optionalAssemblyInfo=false
- name: Generate .NET Full Framework client
run: openapi-generator-cli generate -i ./openapi.yaml --global-property=modelTests=false,apiTests=false,modelDocs=false,apiDocs=false \
-o ./sdks/net -g csharp --additional-properties=optionalProjectFile=false,optionalAssemblyInfo=false
- name: Generate Python client
run: openapi-generator-cli generate -i ./openapi.yaml --global-property=modelTests=false,apiTests=false,modelDocs=false,apiDocs=false \
-o ./sdks/python -g python --additional-properties=optionalProjectFile=false,optionalAssemblyInfo=false+
docker_push:
needs:
- tests
- docker_build
- oas-lint
- oas-postman
- oas-generate-sdks
name: Push Docker image
runs-on: ubuntu-latest
if: github.event_name == 'push' # Exclude PRs
steps:
- uses: actions/checkout@v3
- name: Download built image
uses: actions/download-artifact@v2
with:
name: docker-image
- name: Set tag
id: vars
run: |
# Strip git ref prefix from version
VERSION=$(echo "${{ github.ref }}" | sed -e 's,.*/\(.*\),\1,')
# Strip "v" prefix from tag name (if present at all)
[[ "${{ github.ref }}" == "refs/tags/"* ]] && VERSION=$(echo $VERSION | sed -e 's/^v//')
# Use Docker `latest` tag convention
[ "$VERSION" == "master" ] && VERSION=latest
echo ::set-output name=tag::${VERSION}
- name: Load image
run: |
docker image load -i image.tar
- name: Log into registry
run: echo "${{ secrets.DOCKER_TOKEN }}" | docker login -u ${{ secrets.DOCKER_USERNAME }} --password-stdin
- name: Push the Docker image
env:
RELEASE_VERSION: ${{ steps.vars.outputs.tag }}
run: docker push $IMAGE_NAME:$RELEASE_VERSION
- uses: actions-ecosystem/action-regex-match@v2
id: regex-match
with:
text: ${{ steps.vars.outputs.tag }}
regex: '^\d\.\d\.\d$'
- name: Trigger deployment
env:
RELEASE_VERSION: ${{ steps.vars.outputs.tag }}
run: |
curl -XPOST -u "${{ secrets.SDG_DEPLOYMENT_REPO_ACCESS_TOKEN }}" -H "Accept:application/vnd.github" -H "Content-Type:application/json" ${{ secrets.SDG_DEPLOYMENT_REPO_URL }} --data "{\"ref\": \"main\", \"inputs\": {\"version\": \"$RELEASE_VERSION\"}}"
if: ${{ steps.regex-match.outputs.match != '' }}