chore(workflow): fix cleanup task when run failed (#42) Signed-off-by: Jay Chen <[email protected]> #35
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: Smoke | |
run-name: ${{ github.event_name == 'pull_request' && github.event.pull_request.title || (github.event_name == 'push' && github.event.head_commit.message || format( 'smoke test on {0} {1}', (inputs.product_name || 'kuma'), (inputs.product_version || ''))) }} | |
on: | |
pull_request: {} | |
push: | |
branches: | |
- main | |
workflow_dispatch: | |
inputs: | |
product_name: | |
description: "the product to test, supported values are kuma and kong-mesh" | |
required: false | |
type: string | |
default: kuma | |
product_version: | |
description: "full version of the product you want to test, for example: 2.9.2" | |
required: false | |
type: string | |
default: 2.9.2 | |
environments: | |
description: "types of environment you want to test on, for example: kind,gke,eks" | |
required: false | |
type: string | |
default: kind,gke | |
env: | |
SMOKE_PRODUCT_NAME: ${{ inputs.product_name || 'kuma' }} | |
SMOKE_PRODUCT_VERSION: ${{ inputs.product_version || '2.9.2' }} | |
CI_TOOLS_DIR: "/home/runner/work/kuma-smoke/.ci_tools" | |
jobs: | |
check: | |
name: Check | |
runs-on: ubuntu-latest | |
outputs: | |
env_types: ${{ steps.make-env-type-array.outputs.env_types }} | |
steps: | |
- name: checkout | |
uses: actions/checkout@v4 | |
- name: setup go | |
uses: actions/setup-go@v5 | |
with: | |
go-version-file: 'go.mod' | |
- name: make dev/tools | |
run: make dev/tools | |
- name: make check | |
run: make check | |
- name: golangci-lint | |
uses: golangci/golangci-lint-action@v6 | |
with: | |
version: latest | |
args: --timeout=10m --verbose | |
skip-cache: true | |
- id: make-env-type-array | |
name: make env matrix | |
env: | |
env_types: ${{ inputs.environments || 'kind' }} | |
run: | | |
TYPES_JSON=$(echo -n "[\"$env_types\"]" | tr ' ' ',' | sed 's/,/","/g') | |
echo "env_types=${TYPES_JSON}" >> "$GITHUB_OUTPUT" | |
build-test: | |
name: Build and test | |
timeout-minutes: 60 | |
needs: | |
- check | |
runs-on: ubuntu-latest | |
env: | |
SMOKE_ENV_TYPE: ${{ matrix.envPlatform }} | |
GOOGLE_PROJECT: ${{ secrets.GOOGLE_PROJECT }} | |
GOOGLE_LOCATION: ${{ secrets.GOOGLE_LOCATION }} | |
GOOGLE_APPLICATION_CREDENTIALS: ${{ secrets.GOOGLE_APPLICATION_CREDENTIALS }} | |
AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }} | |
AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }} | |
AWS_SESSION_TOKEN: ${{ secrets.AWS_SESSION_TOKEN }} | |
AWS_REGION: ${{ secrets.AWS_REGION }} | |
strategy: | |
matrix: | |
envPlatform: ${{ fromJSON( needs.check.outputs.env_types ) }} | |
fail-fast: false | |
if: ${{ !contains(github.event.pull_request.labels.*.name, 'ci/skip-test') }} | |
steps: | |
- name: fail on missing required settings | |
if: ${{ (matrix.envPlatform == 'gke' && env.GOOGLE_PROJECT == '') || (matrix.envPlatform == 'eks' && env.AWS_ACCESS_KEY_ID == '') }} | |
run: | | |
echo 'Required settings are missing to run tests on platform ${{ matrix.envPlatform }}' | |
exit 1 | |
- name: checkout | |
uses: actions/checkout@v4 | |
- name: setup go | |
uses: actions/setup-go@v5 | |
with: | |
go-version-file: 'go.mod' | |
- name: make dev/tools | |
run: | | |
make dev/tools | |
echo "${CI_TOOLS_DIR}/bin" >> $GITHUB_PATH | |
- name: make build | |
run: make build | |
- name: make run | |
run: make run | |
- name: make cleanup-kubernetes | |
if: always() | |
run: make cleanup-kubernetes | |
- uses: actions/upload-artifact@65c4c4a1ddee5b72f698fdd19549f0f0fb45cf08 # v4.6.0 | |
if: always() | |
with: | |
name: smoke-report-${{ matrix.envPlatform }} | |
if-no-files-found: ignore | |
path: | | |
raw-report.json | |
build/debug-output/*.log | |
retention-days: ${{ github.event_name == 'pull_request' && 7 || 15 }} | |
# we need a unified way to be the "expected check" by the GitHub branch production rule | |
finalize: | |
name: Finalize | |
needs: ["check", "build-test"] | |
timeout-minutes: 10 | |
if: ${{ always() }} | |
runs-on: ubuntu-latest | |
steps: | |
- name: "Halt if there are previous failures" | |
run: |- | |
echo "results: ${{ toJson(needs.*.result) }}" | |
# for some reason, GH Action will always trigger a downstream job even if there are errors in a dependent job | |
# so we manually check it here. An example could be found here: https://github.com/kumahq/kuma/actions/runs/7044980149 | |
[[ ${{ contains(needs.*.result, 'failure')|| contains(needs.*.result, 'cancelled') }} == "true" ]] && exit 1 | |
echo "All dependent jobs succeeded" |