deps: update nix lock file #40
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: e2e test | |
on: | |
workflow_dispatch: | |
inputs: | |
skip-undeploy: | |
description: "Skip undeploy" | |
required: false | |
type: boolean | |
default: false | |
pull_request: | |
paths-ignore: | |
- dev-docs/** | |
- docs/** | |
- rfc/** | |
- tools/asciinema/** | |
- tools/vale/** | |
env: | |
container_registry: ghcr.io/edgelesssys | |
azure_resource_group: contrast-ci | |
DO_NOT_TRACK: 1 | |
jobs: | |
test_matrix: | |
strategy: | |
matrix: | |
platform: | |
- name: AKS-CLH-SNP | |
runner: ubuntu-22.04 | |
self-hosted: false | |
- name: K3s-QEMU-SNP | |
runner: SNP | |
self-hosted: true | |
- name: K3s-QEMU-TDX | |
runner: TDX | |
self-hosted: true | |
test_name: [servicemesh, openssl, policy, workloadsecret] | |
exclude: | |
# We don't have policies on K3s-qemu yet, so there's no point in | |
# running those tests. | |
- platform: | |
name: K3s-QEMU-SNP | |
runner: SNP | |
self-hosted: true | |
test_name: policy | |
- platform: | |
name: K3s-QEMU-TDX | |
runner: TDX | |
self-hosted: true | |
test_name: policy | |
fail-fast: false | |
name: "${{ matrix.platform.name }} / ${{ matrix.test_name }}" | |
runs-on: ${{ matrix.platform.runner }} | |
permissions: | |
contents: read | |
packages: write | |
steps: | |
- uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7 | |
- if: ${{ !matrix.platform.self-hosted }} | |
uses: ./.github/actions/setup_nix | |
with: | |
githubToken: ${{ secrets.GITHUB_TOKEN }} | |
cachixToken: ${{ secrets.CACHIX_AUTH_TOKEN }} | |
- name: Log in to ghcr.io Container registry | |
uses: docker/login-action@9780b0c442fbb1117ed29e0efdff1e18412f7567 # v3.3.0 | |
with: | |
registry: ghcr.io | |
username: ${{ github.actor }} | |
password: ${{ secrets.GITHUB_TOKEN }} | |
- if: ${{ !matrix.platform.self-hosted }} | |
name: Login to Azure | |
uses: azure/login@6c251865b4e6290e7b78be643ea2d005bc51f69a # v2.1.1 | |
with: | |
creds: ${{ secrets.CONTRAST_CI_INFRA_AZURE }} | |
- uses: nicknovitski/nix-develop@a2060d116a50b36dfab02280af558e73ab52427d # v1.1.0 | |
- name: Create justfile.env | |
run: | | |
cat <<EOF > justfile.env | |
container_registry=${{ env.container_registry }} | |
azure_resource_group=${{ env.azure_resource_group }} | |
EOF | |
- if: ${{ !matrix.platform.self-hosted }} | |
name: Get credentials for CI cluster | |
run: | | |
just get-credentials | |
- if: ${{ !matrix.platform.self-hosted }} | |
name: Set sync environment | |
run: | | |
sync_ip=$(kubectl get svc sync -o jsonpath='{.status.loadBalancer.ingress[0].ip}') | |
echo "SYNC_ENDPOINT=http://$sync_ip:8080" | tee -a "$GITHUB_ENV" | |
sync_uuid=$(kubectl get configmap sync-server-fifo -o jsonpath='{.data.uuid}') | |
echo "SYNC_FIFO_UUID=$sync_uuid" | tee -a "$GITHUB_ENV" | |
- name: Build and prepare deployments | |
run: | | |
just coordinator initializer port-forwarder openssl service-mesh-proxy node-installer ${{ matrix.platform.name }} | |
- name: E2E Test | |
run: | | |
nix run .#scripts.get-logs workspace/e2e.namespace & | |
nix shell -L .#contrast.e2e --command ${{ matrix.test_name }}.test -test.v \ | |
--image-replacements workspace/just.containerlookup \ | |
--namespace-file workspace/e2e.namespace \ | |
--platform ${{ matrix.platform.name }} \ | |
--skip-undeploy="${{ inputs.skip-undeploy && 'true' || 'false' }}" | |
- name: Upload logs | |
if: always() | |
uses: actions/upload-artifact@50769540e7f4bd5e21e526ee35c689e35e0d6874 # v4.4.0 | |
with: | |
name: e2e_pod_logs-${{ matrix.platform.name }}-${{ matrix.test_name }} | |
path: workspace/namespace-logs | |
- name: Cleanup | |
if: cancelled() && !inputs.skip-undeploy | |
run: | | |
kubectl delete ns "$(cat workspace/e2e.namespace)" --timeout 5m |