name: CI | Run NVIDIA GPU kubernetes tests on arm64 on: workflow_call: inputs: registry: required: true type: string repo: required: true type: string tag: required: true type: string pr-number: required: true type: string commit-hash: required: false type: string target-branch: required: false type: string default: "" secrets: NGC_API_KEY: required: true permissions: {} jobs: run-nvidia-gpu-tests-on-amd64: strategy: fail-fast: false matrix: vmm: - qemu-nvidia-gpu k8s: - kubeadm runs-on: amd64-nvidia-a100 env: DOCKER_REGISTRY: ${{ inputs.registry }} DOCKER_REPO: ${{ inputs.repo }} DOCKER_TAG: ${{ inputs.tag }} GH_PR_NUMBER: ${{ inputs.pr-number }} KATA_HYPERVISOR: ${{ matrix.vmm }} KUBERNETES: ${{ matrix.k8s }} USING_NFD: "false" K8S_TEST_HOST_TYPE: all steps: - uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2 with: ref: ${{ inputs.commit-hash }} fetch-depth: 0 persist-credentials: false - name: Rebase atop of the latest target branch run: | ./tests/git-helper.sh "rebase-atop-of-the-latest-target-branch" env: TARGET_BRANCH: ${{ inputs.target-branch }} - name: Deploy Kata timeout-minutes: 10 run: bash tests/integration/kubernetes/gha-run.sh deploy-kata - name: Install `bats` run: bash tests/integration/kubernetes/gha-run.sh install-bats - name: Run tests timeout-minutes: 30 run: bash tests/integration/kubernetes/gha-run.sh run-nv-tests env: NGC_API_KEY: ${{ secrets.NGC_API_KEY }} - name: Collect artifacts ${{ matrix.vmm }} if: always() run: bash tests/integration/kubernetes/gha-run.sh collect-artifacts continue-on-error: true - name: Archive artifacts ${{ matrix.vmm }} uses: actions/upload-artifact@ea165f8d65b6e75b540449e92b4886f43607fa02 # v4.6.2 with: name: k8s-tests-${{ matrix.vmm }}-${{ matrix.k8s }}-${{ inputs.tag }} path: /tmp/artifacts retention-days: 1 - name: Delete kata-deploy if: always() timeout-minutes: 5 run: bash tests/integration/kubernetes/gha-run.sh cleanup