From ee2ed4accc79de163d2c2c333738900456a61169 Mon Sep 17 00:00:00 2001 From: Stacky McStackface Date: Thu, 7 Nov 2024 14:13:01 +0000 Subject: [PATCH 1/4] chore: Generated commit to update templated files since the last template run up to stackabletech/operator-templating@52c2678a798008a68fbd62046a04e7ef281a7a09 Reference-to: stackabletech/operator-templating@52c2678 (Add integration test workflow) --- .github/workflows/integration-test.yml | 93 ++++++++++++++++++++++++++ .github/workflows/pr_pre-commit.yaml | 2 +- renovate.json | 2 +- scripts/run-tests | 6 +- 4 files changed, 99 insertions(+), 4 deletions(-) create mode 100644 .github/workflows/integration-test.yml diff --git a/.github/workflows/integration-test.yml b/.github/workflows/integration-test.yml new file mode 100644 index 00000000..5633532c --- /dev/null +++ b/.github/workflows/integration-test.yml @@ -0,0 +1,93 @@ +--- +name: Integration Test +run-name: | + Integration Test on ${{ inputs.test-platform }}-${{ inputs.test-architecture }} (${{ inputs.test-run == 'all' && 'all' || format('{0}={1}', inputs.test-run, inputs.test-parameter) }}) + +on: + schedule: + # At 00:00 on Sunday. See: https://crontab.guru/#0_0_*_*_0 + - cron: "0 0 * * 0" + workflow_dispatch: + inputs: + test-platform: + description: | + The test platform to run on (kind doesn't support `arm64`) + required: true + type: choice + options: + - kind-1.31.0 + - kind-1.30.3 + - aks-1.29 + - aks-1.28 + - aks-1.27 + - eks-1.29 + - eks-1.28 + - eks-1.27 + - gke-1.29 + - gke-1.28 + - gke-1.27 + - okd-4.15 + - okd-4.14 + - okd-4.13 + test-architecture: + description: | + The architecture the tests will run on + required: true + type: choice + options: + - amd64 + - arm64 + test-run: + description: Type of test run + required: true + type: choice + options: + - all + - test-suite + - test + test-parameter: + description: Parameter to `--test-suite` or `--test` (ignored for `all`) + default: smoke + +jobs: + test: + name: Run Integration Test + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7 + with: + submodules: recursive + + - name: Run Integration Test + id: test + uses: stackabletech/actions/run-integration-test@5b66858af3597c4ea34f9b33664b8034a1d28427 # v0.3.0 + with: + test-platform: ${{ inputs.test-platform }}-${{ inputs.test-architecture }} + test-run: ${{ inputs.test-run }} + test-parameter: ${{ inputs.test-parameter }} + replicated-api-token: ${{ secrets.REPLICATED_API_TOKEN }} + + - name: Send Notification + if: ${{ failure() }} + env: + SLACK_BOT_TOKEN: ${{ secrets.SLACK_INTEGRATION_TEST_TOKEN }} + uses: slackapi/slack-github-action@37ebaef184d7626c5f204ab8d3baff4262dd30f0 # v1.27.0 + with: + channel-id: "C07UYJYSMSN" # notifications-integration-tests + payload: | + { + "text": "Integration Test *${{ github.repository }}* failed", + "attachments": [ + { + "pretext": "Started at ${{ steps.test.outputs.start-time }}, failed at ${{ steps.test.outputs.end-time }}", + "color": "#aa0000", + "actions": [ + { + "type": "button", + "text": "Go to integration test run", + "url": "${{ github.server_url }}/${{ github.repository }}/actions/runs/${{ github.run_id }}" + } + ] + } + ] + } diff --git a/.github/workflows/pr_pre-commit.yaml b/.github/workflows/pr_pre-commit.yaml index c9e94843..1442383b 100644 --- a/.github/workflows/pr_pre-commit.yaml +++ b/.github/workflows/pr_pre-commit.yaml @@ -23,7 +23,7 @@ jobs: with: fetch-depth: 0 submodules: recursive - - uses: stackabletech/actions/run-pre-commit@e8781161bc1eb037198098334cec6061fe24b6c3 # v0.0.2 + - uses: stackabletech/actions/run-pre-commit@5b66858af3597c4ea34f9b33664b8034a1d28427 # v0.3.0 with: python-version: ${{ env.PYTHON_VERSION }} rust: ${{ env.RUST_TOOLCHAIN_VERSION }} diff --git a/renovate.json b/renovate.json index de754167..f28373c7 100644 --- a/renovate.json +++ b/renovate.json @@ -3,5 +3,5 @@ "extends": [ "local>stackabletech/.github:renovate-config" ], - "ignorePaths": [".github/workflows/build.yml", ".github/workflows/general_daily_security.yml", ".github/workflows/pr_pre-commit.yaml"] + "ignorePaths": [".github/workflows/build.yml", ".github/workflows/general_daily_security.yml", ".github/workflows/integration-test.yml", ".github/workflows/pr_pre-commit.yaml"] } diff --git a/scripts/run-tests b/scripts/run-tests index 3f41d2db..31b8e7ae 100755 --- a/scripts/run-tests +++ b/scripts/run-tests @@ -313,7 +313,7 @@ def maybe_install_release(skip_release: bool, release_file: str) -> None: raise TestRunnerException() -def gen_tests(test_suite: str) -> None: +def gen_tests(test_suite: str, namespace: str) -> None: try: beku_cmd = [ "beku", @@ -328,6 +328,8 @@ def gen_tests(test_suite: str) -> None: ] if test_suite: beku_cmd.extend(["--suite", test_suite]) + if namespace: + beku_cmd.extend(["--namespace", namespace]) logging.debug(f"Running : {beku_cmd}") subprocess.run( @@ -386,7 +388,7 @@ def main(argv) -> int: opts = parse_args(argv[1:]) logging.basicConfig(encoding="utf-8", level=opts.log_level) have_requirements() - gen_tests(opts.test_suite) + gen_tests(opts.test_suite, opts.namespace) with release_file(opts.operator, opts.skip_operator) as f: maybe_install_release(opts.skip_release, f) if opts.skip_tests: From 66ec174c228a2dd749491a6ea898cad0dae6cf5a Mon Sep 17 00:00:00 2001 From: Nick Larsen Date: Thu, 7 Nov 2024 16:39:19 +0100 Subject: [PATCH 2/4] chore: Add integration test config file --- tests/infrastructure.yaml | 1 + 1 file changed, 1 insertion(+) create mode 100644 tests/infrastructure.yaml diff --git a/tests/infrastructure.yaml b/tests/infrastructure.yaml new file mode 100644 index 00000000..6f8d6d02 --- /dev/null +++ b/tests/infrastructure.yaml @@ -0,0 +1 @@ +instance-size: medium From c370773d4dc57fa23e923dab4e71ae9d5ab8ee39 Mon Sep 17 00:00:00 2001 From: Nick Larsen Date: Thu, 7 Nov 2024 17:23:14 +0100 Subject: [PATCH 3/4] chore(ci): Set test parameters for scheduled runs --- .github/workflows/integration-test.yml | 27 +++++++++++++++++++++++--- 1 file changed, 24 insertions(+), 3 deletions(-) diff --git a/.github/workflows/integration-test.yml b/.github/workflows/integration-test.yml index 5633532c..9a6ef2c0 100644 --- a/.github/workflows/integration-test.yml +++ b/.github/workflows/integration-test.yml @@ -3,6 +3,16 @@ name: Integration Test run-name: | Integration Test on ${{ inputs.test-platform }}-${{ inputs.test-architecture }} (${{ inputs.test-run == 'all' && 'all' || format('{0}={1}', inputs.test-run, inputs.test-parameter) }}) +env: + DEFAULT_TEST_PLATFORM: kind-1.31.0 + DEFAULT_TEST_ARCHITECTURE: amd64 + DEFAULT_TEST_RUN: all + DEFAULT_TEST_PARAMETER: "" # Unused when the test-run is 'all' + TEST_PLATFORM: ${{ inputs.test-platform }} + TEST_ARCHITECTURE: ${{ inputs.test-architecture }} + TEST_RUN: ${{ inputs.test-run }} + TEST_PARAMETER: ${{ inputs.test-parameter }} + on: schedule: # At 00:00 on Sunday. See: https://crontab.guru/#0_0_*_*_0 @@ -54,6 +64,17 @@ jobs: name: Run Integration Test runs-on: ubuntu-latest steps: + - name: Override integration test options for scheduled run + if: github.event_name == 'schedule' + shell: bash + run: | + set -euo pipefail + + echo "TEST_PLATFORM=$DEFAULT_TEST_PLATFORM" | tee -a "$GITHUB_ENV" + echo "TEST_ARCHITECTURE=$DEFAULT_TEST_ARCHITECTURE" | tee -a "$GITHUB_ENV" + echo "TEST_RUN=$DEFAULT_TEST_RUN" | tee -a "$GITHUB_ENV" + echo "TEST_PARAMETER=$DEFAULT_TEST_PARAMETER" | tee -a "$GITHUB_ENV" + - uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7 with: submodules: recursive @@ -62,9 +83,9 @@ jobs: id: test uses: stackabletech/actions/run-integration-test@5b66858af3597c4ea34f9b33664b8034a1d28427 # v0.3.0 with: - test-platform: ${{ inputs.test-platform }}-${{ inputs.test-architecture }} - test-run: ${{ inputs.test-run }} - test-parameter: ${{ inputs.test-parameter }} + test-platform: ${{ env.TEST_PLATFORM }}-${{ env.TEST_ARCHITECTURE }} + test-run: ${{ env.TEST_RUN }} + test-parameter: ${{ env.TEST_PARAMETER }} replicated-api-token: ${{ secrets.REPLICATED_API_TOKEN }} - name: Send Notification From 5c585b0f9258d4d8813dee6cc01ac77acb0ff14c Mon Sep 17 00:00:00 2001 From: Andrew Kenworthy Date: Fri, 13 Dec 2024 11:32:48 +0100 Subject: [PATCH 4/4] updated action ref and infra config --- .github/workflows/integration-test.yml | 2 +- tests/infrastructure.yaml | 3 +++ 2 files changed, 4 insertions(+), 1 deletion(-) diff --git a/.github/workflows/integration-test.yml b/.github/workflows/integration-test.yml index 24eb3372..d39c62ba 100644 --- a/.github/workflows/integration-test.yml +++ b/.github/workflows/integration-test.yml @@ -86,7 +86,7 @@ jobs: - name: Run Integration Test id: test - uses: stackabletech/actions/run-integration-test@5901c3b1455488820c4be367531e07c3c3e82538 # v0.4.0 + uses: stackabletech/actions/run-integration-test@17f66b09ca4dffa0db4274e3a65f5b9d5e25a60f # vTBD with: test-platform: ${{ env.TEST_PLATFORM }}-${{ env.TEST_ARCHITECTURE }} test-run: ${{ env.TEST_RUN }} diff --git a/tests/infrastructure.yaml b/tests/infrastructure.yaml index 6f8d6d02..c89db66b 100644 --- a/tests/infrastructure.yaml +++ b/tests/infrastructure.yaml @@ -1 +1,4 @@ instance-size: medium +disk: 100 +nodes: 5 +parallelism: 1