test(e2e): run all test/e2e tests #1157
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: "build-test-distribute" | |
on: | |
push: | |
branches: ["master", "release-*", "!*-merge-master"] | |
tags: ["*"] | |
pull_request: | |
branches: ["master", "release-*"] | |
concurrency: | |
group: ${{ github.head_ref || github.run_id }} | |
cancel-in-progress: true | |
env: | |
# This is automatically managed by CI | |
K8S_MIN_VERSION: v1.23.17-k3s1 | |
K8S_MAX_VERSION: v1.28.1-k3s1 | |
GH_OWNER: ${{ github.repository_owner }} | |
KUMA_DIR: "." | |
CI_TOOLS_DIR: /home/runner/work/kuma/kuma/.ci_tools | |
jobs: | |
check: | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1 | |
with: | |
fetch-depth: 0 | |
- uses: actions/setup-go@0c52d547c9bc32b1aa3301fd7a9cb496313a4491 # v5.0.0 | |
with: | |
go-version-file: go.mod | |
cache: false | |
- uses: actions/cache@704facf57e6136b1bc63b828d79edcd491f0ee84 # v3.3.2 | |
with: | |
path: | | |
${{ env.CI_TOOLS_DIR }} | |
key: ${{ runner.os }}-${{ runner.arch }}-devtools-${{ hashFiles('mk/dependencies/deps.lock') }} | |
restore-keys: | | |
${{ runner.os }}-${{ runner.arch }}-devtools | |
- run: | | |
make dev/tools | |
- uses: golangci/golangci-lint-action@3a919529898de77ec3da873e3063ca4b10e7f5cc # v3.7.0 | |
with: | |
args: --fix=false --verbose | |
version: v1.54.1 | |
- run: | | |
make clean | |
- run: | | |
make check | |
test: | |
runs-on: ubuntu-latest | |
if: ${{ ! contains(github.event.pull_request.labels.*.name, 'ci/skip-test') }} | |
steps: | |
- uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1 | |
with: | |
fetch-depth: 0 | |
- name: "Check if should run on all arch/os combinations" | |
if: github.event_name == 'push' || contains(github.event.pull_request.labels.*.name, 'ci/run-full-matrix') | |
run: | | |
echo 'RUN_FULL_MATRIX=true' > .run-full-matrix | |
echo 'RUN_FULL_MATRIX=true' >> $GITHUB_ENV | |
- uses: actions/setup-go@0c52d547c9bc32b1aa3301fd7a9cb496313a4491 # v5.0.0 | |
with: | |
go-version-file: go.mod | |
cache-dependency-path: | | |
.run-full-matrix | |
go.sum | |
- uses: actions/cache@704facf57e6136b1bc63b828d79edcd491f0ee84 # v3.3.2 | |
with: | |
path: | | |
${{ env.CI_TOOLS_DIR }} | |
key: ${{ runner.os }}-${{ runner.arch }}-devtools-${{ hashFiles('mk/dependencies/deps.lock') }} | |
restore-keys: | | |
${{ runner.os }}-${{ runner.arch }}-devtools | |
- run: | | |
make dev/tools | |
- name: Free up disk space for the Runner | |
run: | | |
echo "Disk usage before cleanup" | |
sudo df -h | |
echo "Removing big directories" | |
sudo rm -rf /usr/share/dotnet /usr/local/lib/android /opt/ghc | |
echo "Removing images" | |
docker system prune --all -f | |
echo "Disk usage after cleanup" | |
sudo df -h | |
- name: Run tests | |
run: | | |
make test TEST_REPORTS=1 | |
- name: Save test reports | |
uses: actions/upload-artifact@c7d193f32edcb7bfad88892161225aeda64e9392 # v4.0.0 | |
with: | |
name: test-reports | |
path: build/reports | |
retention-days: 7 | |
distributions: | |
needs: ["check", "test", "test_e2e", "test_e2e_env"] | |
if: ${{ always() }} | |
runs-on: ubuntu-latest | |
steps: | |
- name: "Halt due to previous failures" | |
if: ${{ contains(needs.*.result, 'failure')|| contains(needs.*.result, 'cancelled') }} | |
run: | | |
exit 1 | |
# for some reason, GH Action will always trigger a downstream job even if there are errors in an dependent job | |
# so we manually check it here. An example could be found here: https://github.com/kumahq/kuma/actions/runs/7044980149 | |
- uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1 | |
with: | |
fetch-depth: 0 | |
- name: "Check if should run on all arch/os combinations" | |
if: github.event_name == 'push' || contains(github.event.pull_request.labels.*.name, 'ci/run-full-matrix') | |
run: | | |
echo 'RUN_FULL_MATRIX=true' > .run-full-matrix | |
echo 'RUN_FULL_MATRIX=true' >> $GITHUB_ENV | |
- name: "Set switches based on if run full matrix" | |
if: ${{ env.RUN_FULL_MATRIX == 'true' }} | |
id: set-full-matrix-switches | |
run: | | |
echo 'ENABLED_GOARCHES=arm64 amd64' >> $GITHUB_ENV | |
echo 'ENABLED_GOOSES=linux darwin' >> $GITHUB_ENV | |
- name: "Check if force push" | |
if: github.event_name == 'push' || contains(github.event.pull_request.labels.*.name, 'ci/force-publish') | |
run: | | |
echo 'ALLOW_PUSH=true' >> $GITHUB_ENV | |
- name: Install dependencies for cross builds | |
run: | | |
sudo apt-get update; sudo apt-get install -y qemu-user-static binfmt-support | |
- uses: actions/setup-go@0c52d547c9bc32b1aa3301fd7a9cb496313a4491 # v5.0.0 | |
with: | |
go-version-file: go.mod | |
cache-dependency-path: | | |
.run-full-matrix | |
go.sum | |
- uses: actions/cache@704facf57e6136b1bc63b828d79edcd491f0ee84 # v3.3.2 | |
with: | |
path: | | |
${{ env.CI_TOOLS_DIR }} | |
key: ${{ runner.os }}-${{ runner.arch }}-devtools-${{ hashFiles('mk/dependencies/deps.lock') }} | |
restore-keys: | | |
${{ runner.os }}-${{ runner.arch }}-devtools | |
- name: Free up disk space for the Runner | |
run: | | |
echo "Disk usage before cleanup" | |
sudo df -h | |
echo "Removing big directories" | |
sudo rm -rf /usr/share/dotnet /usr/local/lib/android /opt/ghc | |
echo "Removing images" | |
docker system prune --all -f | |
echo "Disk usage after cleanup" | |
sudo df -h | |
- run: | | |
make build | |
- run: | | |
make -j build/distributions | |
- name: Install dependencies for cross builds | |
run: | | |
sudo apt-get update; sudo apt-get install -y qemu-user-static binfmt-support | |
- run: | | |
make -j images | |
make -j docker/save | |
- name: Run container structure test | |
if: ${{ !contains(github.event.pull_request.labels.*.name, 'ci/skip-container-structure-test') && !contains(github.event.pull_request.labels.*.name, 'ci/skip-test') }} | |
run: | | |
make test/container-structure | |
- name: Inspect created tars | |
run: | | |
for i in build/distributions/out/*.tar.gz; do echo $i; tar -tvf $i; done | |
- name: Publish distributions to Pulp | |
env: | |
PULP_USERNAME: ${{ vars.PULP_USERNAME }} | |
PULP_PASSWORD: ${{ secrets.PULP_PASSWORD }} | |
CLOUDSMITH_API_KEY: ${{ secrets.CLOUDSMITH_API_KEY }} | |
run: | | |
make publish/pulp | |
- name: Publish images | |
env: | |
DOCKER_API_KEY: ${{ secrets.DOCKER_API_KEY }} | |
DOCKER_USERNAME: ${{ vars.DOCKER_USERNAME }} | |
run: |- | |
make docker/login | |
# ensure we always logout | |
function on_exit() { | |
make docker/logout | |
} | |
trap on_exit EXIT | |
make docker/push | |
make docker/manifest | |
- name: package-helm-chart | |
id: package-helm | |
env: | |
HELM_DEV: ${{ !startsWith(github.event.ref, 'refs/tags/') }} | |
GH_USER: "github-actions[bot]" | |
GH_EMAIL: "<41898282+github-actions[bot]@users.noreply.github.com>" | |
run: | | |
make helm/update-version | |
git config user.name "${GH_USER}" | |
git config user.email "${GH_EMAIL}" | |
git add -u deployments/charts | |
# This commit never ends up in the repo | |
git commit --allow-empty -m "ci(helm): update versions" | |
# To get an idea of what's in the commit to debug | |
git show | |
make helm/package | |
PKG_FILENAME=$(find .cr-release-packages -type f -printf "%f\n") | |
echo "filename=${PKG_FILENAME}" >> $GITHUB_OUTPUT | |
- name: Upload packaged chart | |
uses: actions/upload-artifact@c7d193f32edcb7bfad88892161225aeda64e9392 # v4.0.0 | |
with: | |
name: ${{ steps.package-helm.outputs.filename }} | |
path: .cr-release-packages/${{ steps.package-helm.outputs.filename }} | |
retention-days: ${{ github.event_name == 'pull_request' && 1 || 30 }} | |
# Everything from here is only running on releases. | |
# Ideally we'd finish the workflow early but this isn't possible: https://github.com/actions/runner/issues/662 | |
- name: Generate GitHub app token | |
id: github-app-token | |
if: ${{ startsWith(github.event.ref, 'refs/tags/') }} | |
uses: tibdex/github-app-token@3beb63f4bd073e61482598c45c71c1019b59b73a # v2.1.0 | |
with: | |
app_id: ${{ secrets.APP_ID }} | |
private_key: ${{ secrets.APP_PRIVATE_KEY }} | |
- name: Release chart | |
if: ${{ startsWith(github.event.ref, 'refs/tags/') }} | |
env: | |
GITHUB_APP: "true" | |
GH_TOKEN: ${{ steps.github-app-token.outputs.token }} | |
run: make helm/release | |
gen_e2e_matrix: | |
runs-on: ubuntu-latest | |
if: ${{ !contains(github.event.pull_request.labels.*.name, 'ci/skip-test') && !contains(github.event.pull_request.labels.*.name, 'ci/skip-e2e-test') }} | |
outputs: | |
matrix: ${{ steps.generate-matrix.outputs.matrix }} | |
steps: | |
- name: "Check if should run on all arch/os combinations" | |
if: github.event_name == 'push' || contains(github.event.pull_request.labels.*.name, 'ci/run-full-matrix') | |
run: | | |
echo 'RUN_FULL_MATRIX=true' > .run-full-matrix | |
echo 'RUN_FULL_MATRIX=true' >> $GITHUB_ENV | |
- id: generate-matrix | |
name: Generate matrix | |
env: | |
BASE_MATRIX: |- | |
{ | |
"test_e2e": { | |
"target": [""], | |
"k8sVersion": ["kindIpv6", "${{ env.K8S_MIN_VERSION }}", "${{ env.K8S_MAX_VERSION }}"], | |
"arch": ["amd64"], | |
"parallelism": [3], | |
"cniNetworkPlugin": ["flannel"], | |
"legacyKDS": [false] | |
}, | |
"test_e2e_env": { | |
"target": ["kubernetes", "universal", "multizone"], | |
"k8sVersion": ["kind", "kindIpv6", "${{ env.K8S_MIN_VERSION }}", "${{ env.K8S_MAX_VERSION }}"], | |
"arch": ["amd64"], | |
"parallelism": [1], | |
"cniNetworkPlugin": ["flannel"], | |
"legacyKDS": [false], | |
"exclude":[ | |
{"target": "kubernetes", "k8sVersion":"kind"}, | |
{"target": "multizone", "k8sVersion":"kind"}, | |
{"target":"universal", "k8sVersion":"${{ env.K8S_MIN_VERSION }}"}, | |
{"target":"universal", "k8sVersion":"${{ env.K8S_MAX_VERSION }}"} | |
], | |
"include":[ | |
{"legacyKDS": true, "k8sVersion": "${{ env.K8S_MAX_VERSION }}", "target": "multizone", "arch": "amd64"}, | |
{"k8sVersion": "${{ env.K8S_MAX_VERSION }}", "target": "multizone", "arch": "arm64"}, | |
{"k8sVersion": "${{ env.K8S_MAX_VERSION }}", "target": "kubernetes", "arch": "arm64"}, | |
{"k8sVersion": "${{ env.K8S_MAX_VERSION }}", "target": "universal", "arch": "arm64"}, | |
{"cniNetworkPlugin": "calico", "k8sVersion": "${{ env.K8S_MAX_VERSION }}", "target": "multizone", "arch": "amd64"} | |
] | |
} | |
} | |
OVERRIDE_JQ_CMD: |- | |
.test_e2e.k8sVersion = ["${{ env.K8S_MAX_VERSION }}"] | |
| .test_e2e_env.include = [] | |
| .test_e2e_env.exclude += [{"arch": "arm64"}, {"k8sVersion": "kindIpv6"}, {"k8sVersion": "${{ env.K8S_MIN_VERSION}}"}] | |
run: |- | |
BASE_MATRIX_ALL='${{ env.BASE_MATRIX }}' | |
if [[ "${RUN_FULL_MATRIX}" != "true" ]]; then | |
BASE_MATRIX_ALL=$(echo $BASE_MATRIX_ALL | jq -r '${{ env.OVERRIDE_JQ_CMD }}') | |
fi | |
echo "final matrix: $BASE_MATRIX_ALL" | |
echo "matrix<<EOF" >> $GITHUB_OUTPUT | |
echo "$BASE_MATRIX_ALL" >> $GITHUB_OUTPUT | |
echo "EOF" >> $GITHUB_OUTPUT | |
test_e2e: | |
needs: ["gen_e2e_matrix"] | |
if: fromJSON(needs.gen_e2e_matrix.outputs.matrix).test_e2e | |
strategy: | |
matrix: ${{ fromJSON(needs.gen_e2e_matrix.outputs.matrix).test_e2e }} | |
fail-fast: false | |
uses: ./.github/workflows/e2e.yaml | |
with: | |
matrix: ${{ toJSON(matrix) }} | |
secrets: | |
circleCIToken: ${{ secrets.CIRCLECI_TOKEN }} | |
test_e2e_env: | |
needs: ["gen_e2e_matrix"] | |
if: fromJSON(needs.gen_e2e_matrix.outputs.matrix).test_e2e_env | |
strategy: | |
matrix: ${{ fromJSON(needs.gen_e2e_matrix.outputs.matrix).test_e2e_env }} | |
fail-fast: false | |
uses: ./.github/workflows/e2e.yaml | |
with: | |
matrix: ${{ toJSON(matrix) }} | |
secrets: | |
circleCIToken: ${{ secrets.CIRCLECI_TOKEN }} |