path #63
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
name: Integration test | |
on: | |
push: | |
branches: | |
- '**' | |
jobs: | |
manifest_check: | |
runs-on: ubuntu-20.04 | |
steps: | |
- uses: actions/checkout@v2.3.4 | |
- uses: cachix/install-nix-action@v27 | |
with: | |
nix_path: nixpkgs=https://github.com/NixOS/nixpkgs/archive/08ef0f28e3a41424b92ba1d203de64257a9fca6a.tar.gz | |
- name: Install dependencies in environment | |
run: nix-env --install ./integration_test/default.nix | |
- name: Validate integration test manifest | |
run: kustomize build integration_test | |
# | kubeconform -strict -kubernetes-version 1.17.9 | |
integration_test: | |
timeout-minutes: 45 | |
needs: manifest_check | |
runs-on: ubuntu-20.04 | |
steps: | |
- uses: actions/checkout@v2 | |
- uses: cachix/install-nix-action@v27 | |
with: | |
nix_path: nixpkgs=https://github.com/NixOS/nixpkgs/archive/08ef0f28e3a41424b92ba1d203de64257a9fca6a.tar.gz | |
- name: Install dependencies | |
run: nix-env ---install ./integration_test/default.nix | |
- name: Start cluster | |
run: minikube start --driver=docker --kubernetes-version=v1.21.5 | |
# - name: Start cluster | |
# run: |- | |
# # - --k3s-server-arg args according to | |
# # https://k3d.io/faq/faq/#solved-nodes-fail-to-start-or-get-stuck-in-notready-state-with-log-nf_conntrack_max-permission-denied | |
# # - We deploy our own for increased portability across k8s distributions | |
# k3d cluster create \ | |
# --wait \ | |
# --no-lb \ | |
# --no-rollback \ | |
# --k3s-server-arg "--kube-proxy-arg=conntrack-max-per-core=0" \ | |
# --k3s-agent-arg "--kube-proxy-arg=conntrack-max-per-core=0" \ | |
# --k3s-server-arg "--disable=traefik" \ | |
# --k3s-server-arg "--disable=metrics-server" \ | |
# --k3s-server-arg "--disable-cloud-controller" \ | |
# --kubeconfig-update-default \ | |
# --kubeconfig-switch-context \ | |
# --image=rancher/k3s:v1.17.9-k3s1 \ | |
# int-test | |
- name: Deploy | |
run: |- | |
skaffold run -p integration-test | |
- name: Wait for kube api server to process and create all resources | |
# This is because the wait step that follows this one does this: | |
# 1. retrieve list of pods | |
# 2. wait for list of pods | |
# Unfortunately, the list of pods might not be complete at step (1), as all pods may not yet | |
# be created, meaning the list of pods waited on in step (2) is not complete. We therefore | |
# wait some time here to allow that to finish before we retrieve the list of pods to wait on. | |
# 30s should be more than enough. | |
run: sleep 30s | |
- name: Wait for deployment readiness | |
# Skaffold is supposed to do this, but for whatever reason, does not. At the time of writing, | |
# investigating this was not a priority. | |
run: timeout 1500 kubectl wait --for=condition=Ready pod --all --timeout=1200s | |
- name: Port-forward the portal frontend ingress | |
run: kubectl port-forward -n ingress-nginx --address 0.0.0.0 svc/ingress-nginx-controller 3000:80 & | |
- name: Port-forward voodoo-doll | |
run: kubectl port-forward --address 0.0.0.0 voodoo-doll 3030 & | |
- name: Install test dependencies | |
working-directory: integration_test/tests | |
run: |- | |
npm ci | |
- name: Run tests | |
working-directory: integration_test/tests | |
run: |- | |
POSITIONS_MICROFRONTEND_ENDPOINT="http://localhost:3000" npm run test:headless | |
- name: Archive test report | |
if: ${{ always() }} | |
uses: actions/upload-artifact@v2 | |
with: | |
name: test-report | |
path: integration_test/tests/report.html | |
- name: Print docker containers to check any issues with the cluster | |
if: ${{ failure() }} | |
run: docker ps | |
- name: Print voodoo doll logs | |
if: ${{ always() }} | |
run: kubectl logs voodoo-doll | |
- name: Print resources | |
if: ${{ always() }} | |
run: kubectl get svc,deploy,sts,pv,pvc,configmap,job,pod -A | |
- name: Describe resources | |
if: ${{ always() }} | |
run: kubectl describe svc,deploy,sts,pv,pvc,configmap,job,pod -A | |
- name: Print secret values | |
if: ${{ always() }} | |
run: |- | |
kubectl get secrets -o json | jq -r '.items[] | { name: .metadata.name, data: .data | map_values(@base64d) }' |