From e687aa81c313bd742b39a53b8eb181e316257700 Mon Sep 17 00:00:00 2001 From: Aleksander Zaruczewski Date: Tue, 19 Dec 2023 14:56:18 +0200 Subject: [PATCH] ci(test): proper project name prefix var substitution (#1485) --- .github/workflows/acceptance-tests.yml | 16 +++++++++------- .github/workflows/examples-tests.yml | 11 ++++++----- .github/workflows/sweep.yml | 17 +++++++++++++---- tools/selproj/README.md | 4 ++-- tools/selproj/main.go | 2 +- tools/selproj/selectproject.go | 2 +- tools/selproj/selectproject_test.go | 2 +- 7 files changed, 33 insertions(+), 21 deletions(-) diff --git a/.github/workflows/acceptance-tests.yml b/.github/workflows/acceptance-tests.yml index 0f7c34252..3b0526f50 100644 --- a/.github/workflows/acceptance-tests.yml +++ b/.github/workflows/acceptance-tests.yml @@ -13,21 +13,21 @@ concurrency: cancel-in-progress: true jobs: - setup_aiven_project: + setup_aiven_project_suffix: runs-on: ubuntu-latest outputs: - project_name: ${{ steps.selproj.outputs.project_name }} + project_name_suffix: ${{ steps.selproj.outputs.project_name_suffix }} steps: - uses: actions/checkout@v4 - id: selproj - run: echo "project_name=$(make ci-selproj)" >> $GITHUB_OUTPUT + run: echo "project_name_suffix=$(make -s ci-selproj | tr -d '\n')" >> $GITHUB_OUTPUT env: AIVEN_TOKEN: ${{ secrets.AIVEN_TOKEN }} AIVEN_PROJECT_NAME_PREFIX: ${{ secrets.AIVEN_PROJECT_NAME_PREFIX }} acceptance_tests: - needs: setup_aiven_project + needs: setup_aiven_project_suffix runs-on: ubuntu-latest strategy: max-parallel: 5 @@ -83,14 +83,15 @@ jobs: - run: make test-acc env: AIVEN_TOKEN: ${{ secrets.AIVEN_TOKEN }} - AIVEN_PROJECT_NAME: ${{ needs.setup_aiven_project.outputs.project_name }} + AIVEN_PROJECT_NAME: >- + ${{ secrets.AIVEN_PROJECT_NAME_PREFIX }}${{ needs.setup_aiven_project_suffix.outputs.project_name_suffix }} AIVEN_ORGANIZATION_NAME: ${{ secrets.AIVEN_ORGANIZATION_NAME }} AIVEN_ACCOUNT_NAME: ${{ secrets.AIVEN_ORGANIZATION_NAME }} PKG: ${{ matrix.pkg }} sweep: if: always() - needs: [acceptance_tests, setup_aiven_project] + needs: [acceptance_tests, setup_aiven_project_suffix] runs-on: ubuntu-latest steps: - uses: softprops/turnstyle@v1 @@ -123,6 +124,7 @@ jobs: command: make sweep env: AIVEN_TOKEN: ${{ secrets.AIVEN_TOKEN }} - AIVEN_PROJECT_NAME: ${{ needs.setup_aiven_project.outputs.project_name }} + AIVEN_PROJECT_NAME: >- + ${{ secrets.AIVEN_PROJECT_NAME_PREFIX }}${{ needs.setup_aiven_project_suffix.outputs.project_name_suffix }} AIVEN_ORGANIZATION_NAME: ${{ secrets.AIVEN_ORGANIZATION_NAME }} AIVEN_ACCOUNT_NAME: ${{ secrets.AIVEN_ORGANIZATION_NAME }} diff --git a/.github/workflows/examples-tests.yml b/.github/workflows/examples-tests.yml index 3841ce08b..9aaacbd74 100644 --- a/.github/workflows/examples-tests.yml +++ b/.github/workflows/examples-tests.yml @@ -13,21 +13,21 @@ concurrency: cancel-in-progress: true jobs: - setup_aiven_project: + setup_aiven_project_suffix: runs-on: ubuntu-latest outputs: - project_name: ${{ steps.selproj.outputs.project_name }} + project_name_suffix: ${{ steps.selproj.outputs.project_name_suffix }} steps: - uses: actions/checkout@v4 - id: selproj - run: echo "project_name=$(make ci-selproj)" >> $GITHUB_OUTPUT + run: echo "project_name_suffix=$(make -s ci-selproj | tr -d '\n')" >> $GITHUB_OUTPUT env: AIVEN_TOKEN: ${{ secrets.AIVEN_TOKEN }} AIVEN_PROJECT_NAME_PREFIX: ${{ secrets.AIVEN_PROJECT_NAME_PREFIX }} examples_tests: - needs: setup_aiven_project + needs: setup_aiven_project_suffix runs-on: ubuntu-latest steps: - uses: softprops/turnstyle@v1 @@ -55,4 +55,5 @@ jobs: - run: make test-examples env: AIVEN_TOKEN: ${{ secrets.AIVEN_TOKEN }} - AIVEN_PROJECT_NAME: ${{ needs.setup_aiven_project.outputs.project_name }} + AIVEN_PROJECT_NAME: >- + ${{ secrets.AIVEN_PROJECT_NAME_PREFIX }}${{ needs.setup_aiven_project_suffix.outputs.project_name_suffix }} diff --git a/.github/workflows/sweep.yml b/.github/workflows/sweep.yml index 73555352f..b905883ae 100644 --- a/.github/workflows/sweep.yml +++ b/.github/workflows/sweep.yml @@ -9,14 +9,23 @@ permissions: contents: read concurrency: - group: ci-${{ github.ref }} - cancel-in-progress: false + group: ci-${{ github.head_ref || github.ref }} + cancel-in-progress: true jobs: sweep: runs-on: ubuntu-latest + strategy: + max-parallel: 2 + matrix: + aiven_project_name_suffix: [ + '', + '-2', + '-3', + '-4', + '-5', + ] steps: - - uses: actions/checkout@v4 with: fetch-depth: 0 @@ -32,4 +41,4 @@ jobs: command: make sweep env: AIVEN_TOKEN: ${{ secrets.AIVEN_TOKEN }} - AIVEN_PROJECT_NAME: ${{ secrets.AIVEN_PROJECT_NAME }} + AIVEN_PROJECT_NAME: ${{ secrets.AIVEN_PROJECT_NAME_PREFIX }}${{ matrix.aiven_project_name_suffix }} diff --git a/tools/selproj/README.md b/tools/selproj/README.md index 3dd0ac5b9..643e302eb 100644 --- a/tools/selproj/README.md +++ b/tools/selproj/README.md @@ -1,6 +1,6 @@ # selproj -A tool to select an empty project from a list of projects using a prefix. +A tool to select an empty project's suffix from a list of projects using a prefix. ## Usage @@ -17,7 +17,7 @@ The tool requires the following environment variables to be set: ```text $ AIVEN_TOKEN=... AIVEN_PROJECT_NAME_PREFIX=test go run -tags tools . -test-project-2 +-project-2 ``` ## Testing diff --git a/tools/selproj/main.go b/tools/selproj/main.go index 0e56a2cb7..86cf49494 100644 --- a/tools/selproj/main.go +++ b/tools/selproj/main.go @@ -34,5 +34,5 @@ func main() { panic(err) } - fmt.Print(selectedProject) + fmt.Println(selectedProject) } diff --git a/tools/selproj/selectproject.go b/tools/selproj/selectproject.go index 0cc91f3bb..3a46e0c9f 100644 --- a/tools/selproj/selectproject.go +++ b/tools/selproj/selectproject.go @@ -29,7 +29,7 @@ func selectProject(ctx context.Context, client AivenClient, prefix string) (stri } if len(services) == 0 { - return project.Name, nil + return strings.TrimPrefix(project.Name, prefix), nil } } diff --git a/tools/selproj/selectproject_test.go b/tools/selproj/selectproject_test.go index 3670c09c8..8783a9ab4 100644 --- a/tools/selproj/selectproject_test.go +++ b/tools/selproj/selectproject_test.go @@ -52,7 +52,7 @@ func TestSelectProject_Basic(t *testing.T) { assert.NoError(t, err, "selectProject should not return an error") assert.Equal( - t, "test-project-2", projectName, "selectProject should return the correct project name", + t, "-project-2", projectName, "selectProject should return the correct project name", ) }