Skip to content

Commit

Permalink
[feat] Add CI job to run tests
Browse files Browse the repository at this point in the history
  • Loading branch information
DefCon-007 committed Feb 12, 2024
1 parent 1d6b371 commit 0d7b0d5
Show file tree
Hide file tree
Showing 4 changed files with 111 additions and 4 deletions.
10 changes: 10 additions & 0 deletions .github/.ci-env-config
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
ENVIRONMENT_NAME=k8s
DB_ENGINE=django.db.backends.mysql
DB_NAME=test
DB_USER=testuser
DB_PASSWORD=testpassword
DB_HOST=mysql
DB_PORT=3306
DJANGO_SECRET_KEY=secret
DEBUG=false
ROOT_URLCONF=urls.production
92 changes: 92 additions & 0 deletions .github/workflows/build-and-test.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,92 @@
name: Build and Test

on:
push:
branches:
- '**'

jobs:
build:
runs-on: ubuntu-latest

steps:
- uses: rlespinasse/github-slug-action@v4
- name: Check Out Repo
uses: actions/checkout@v2

- name: Login to Docker Hub
uses: docker/login-action@v1
with:
username: ${{ secrets.K6_DOCKERHUB_USERNAME }}
password: ${{ secrets.K6_DOCKERHUB_TOKEN }}
- name: Set up Docker Buildx
id: buildx
uses: docker/setup-buildx-action@v1

- name: Build and push
id: docker_build
uses: docker/build-push-action@v2
with:
context: ./
file: ./k8s/Dockerfile
cache-from: type=gha,scope=dev
cache-to: type=gha,scope=dev,mode=max
push: true
tags: |
${{ github.repository }}:${{ env.GITHUB_REF_NAME_SLUG }}-dev
${{ github.repository }}:${{ github.sha }}-dev
- name: Image digest
run: echo ${{ steps.docker_build.outputs.digest }}

Run-Tests:
runs-on: ubuntu-latest
needs: [build]
services:
test-api:
image: ${{ github.repository }}:${{ github.sha }}-dev
credentials:
username: ${{ secrets.K6_DOCKERHUB_USERNAME }}
password: ${{ secrets.K6_DOCKERHUB_TOKEN }}
env:
ENVIRONMENT_NAME: 'k8s'
ENGINE: 'django.db.backends.mysql'
NAME: 'test'
USER: 'testuser'
PASSWORD: 'testpassword'
HOST: 'mysql'
PORT: '3306'
DJANGO_SECRET_KEY: 'secret'
DEBUG: "false"
ROOT_URLCONF: "urls.production"
ports:
- 80:8000
# options: >-
# --health-cmd "curl --fail http://localhost:80"
# --health-interval 10s
# --health-timeout 5s
# --health-retries 5
mysql:
image: mysql:5.7
env:
MYSQL_DATABASE: test
MYSQL_USER: testuser
MYSQL_PASSWORD: testpassword
MYSQL_ROOT_PASSWORD: testrootpass
ports:
- 3306:3306
options: --health-cmd="mysqladmin ping" --health-interval=10s --health-timeout=5s --health-retries=3
steps:
- name: Checkout
uses: actions/checkout@v1
- name: Login to DockerHub
uses: docker/login-action@v1
with:
username: ${{ secrets.K6_DOCKERHUB_USERNAME }}
password: ${{ secrets.K6_DOCKERHUB_TOKEN }}
- name: Apply database migrations
run: |
docker run --env-file ${{ github.workspace }}/.github/.ci-env-config --network ${{ job.container.network }} ${{ github.repository }}:${{ github.sha }}-dev sh -c "python manage.py collectstatic --noinput -v1 && python manage.py migrate && python manage.py loaddata fixtures/initial.json"
- name: Run k6 test
run: |
docker run --env BASE_URL="http://localhost:80" --network host -v ${{ github.workspace }}:/data/ grafana/k6:latest run /data/k6_tests/api_demo.js
3 changes: 3 additions & 0 deletions k6_tests/api_demo.js
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,9 @@ export function setup() {
password,
email: username,
});
console.log("Create user response ");
console.log(resp.status);
console.log(resp.body);
check(resp, auth.registerChecks());
}

Expand Down
10 changes: 6 additions & 4 deletions project/settings/api/__init__.py
Original file line number Diff line number Diff line change
@@ -1,14 +1,16 @@
from os import environ

env = environ.get("ENVIRONMENT_NAME")
if env == 'dev':
if env == "dev":
from .dev import *
elif env == 'k8s':
elif env == "k8s":
# In k8s setup settings come from env vars, specified in the Deployment api object and
# configured in k8s ConfigMap or ExternalSecret api objects.
# Quering secrets from AWS Secret Manager is the responsibility of the k8s cluster.
# Quering secrets from AWS Secret Manager is the responsibility of the k8s cluster.
print("Loading k8s settings")
print(environ)
from .k8s import *
elif not env:
from .default import *
else:
raise Exception(f'ENVIRONMENT_NAME env incorrect: {env}')
raise Exception(f"ENVIRONMENT_NAME env incorrect: {env}")

0 comments on commit 0d7b0d5

Please sign in to comment.