From 813405f080713d62f91faef060c95cb045650600 Mon Sep 17 00:00:00 2001 From: Moritz Sanft <58110325+msanft@users.noreply.github.com> Date: Fri, 3 Nov 2023 16:27:28 +0100 Subject: [PATCH] ci: share e2e workflow (#2550) * re-use workflow in internal LB e2e test Signed-off-by: Moritz Sanft <58110325+msanft@users.noreply.github.com> * add self-managed infra workfloww Signed-off-by: Moritz Sanft <58110325+msanft@users.noreply.github.com> --------- Signed-off-by: Moritz Sanft <58110325+msanft@users.noreply.github.com> --- .github/workflows/e2e-test-internal-lb.yml | 88 +++++++ .../workflows/e2e-test-manual-internal.yml | 229 ------------------ .github/workflows/e2e-test-self-managed.yml | 88 +++++++ .../{e2e-test-manual.yml => e2e-test.yml} | 11 +- 4 files changed, 186 insertions(+), 230 deletions(-) create mode 100644 .github/workflows/e2e-test-internal-lb.yml delete mode 100644 .github/workflows/e2e-test-manual-internal.yml create mode 100644 .github/workflows/e2e-test-self-managed.yml rename .github/workflows/{e2e-test-manual.yml => e2e-test.yml} (96%) diff --git a/.github/workflows/e2e-test-internal-lb.yml b/.github/workflows/e2e-test-internal-lb.yml new file mode 100644 index 0000000000..6fb1ca33ea --- /dev/null +++ b/.github/workflows/e2e-test-internal-lb.yml @@ -0,0 +1,88 @@ +name: e2e test internal LB + +on: + workflow_dispatch: + inputs: + nodeCount: + description: "Number of nodes to use in the cluster. Given in format `:`." + default: "3:2" + type: string + cloudProvider: + description: "Which cloud provider to use." + type: choice + options: + - "gcp" + - "azure" + - "aws" + default: "azure" + required: true + runner: + description: "Architecture of the runner that executes the CLI" + type: choice + options: + - "ubuntu-22.04" + - "macos-12" + default: "ubuntu-22.04" + test: + description: "The test to run." + type: choice + options: + - "sonobuoy quick" + - "sonobuoy full" + - "autoscaling" + - "lb" + - "perf-bench" + - "verify" + - "recover" + - "malicious join" + - "nop" + required: true + kubernetesVersion: + description: "Kubernetes version to create the cluster from." + default: "1.27" + required: true + cliVersion: + description: "Version of a released CLI to download. Leave empty to build the CLI from the checked out ref." + type: string + default: "" + required: false + imageVersion: + description: "Full name of OS image (CSP independent image version UID). Leave empty for latest debug image on main." + type: string + default: "" + required: false + machineType: + description: "Override VM machine type. Leave as 'default' or empty to use the default VM type for the selected cloud provider." + type: string + default: "default" + required: false + regionZone: + description: "Region or zone to create the cluster in. Leave empty for default region/zone." + type: string + git-ref: + description: "Git ref to checkout." + type: string + default: "head" + required: false + +jobs: + e2e-test: + permissions: + id-token: write + checks: write + contents: read + packages: write + secrets: inherit + uses: ./.github/workflows/e2e-test.yml + with: + nodeCount: ${{ inputs.nodeCount }} + cloudProvider: ${{ inputs.cloudProvider }} + runner: ${{ inputs.runner }} + test: ${{ inputs.test }} + kubernetesVersion: ${{ inputs.kubernetesVersion }} + cliVersion: ${{ inputs.cliVersion }} + imageVersion: ${{ inputs.imageVersion }} + machineType: ${{ inputs.machineType }} + regionZone: ${{ inputs.regionZone }} + git-ref: ${{ inputs.git-ref }} + internalLoadBalancer: true diff --git a/.github/workflows/e2e-test-manual-internal.yml b/.github/workflows/e2e-test-manual-internal.yml deleted file mode 100644 index d9297f22e8..0000000000 --- a/.github/workflows/e2e-test-manual-internal.yml +++ /dev/null @@ -1,229 +0,0 @@ -name: e2e test manual internal LB - -on: - workflow_dispatch: - inputs: - nodeCount: - description: "Number of nodes to use in the cluster. Given in format `:`." - default: "3:2" - type: string - cloudProvider: - description: "Which cloud provider to use." - type: choice - options: - - "gcp" - - "azure" - - "aws" - default: "azure" - required: true - test: - description: "The test to run." - type: choice - options: - - "sonobuoy quick" - - "sonobuoy full" - - "autoscaling" - - "lb" - - "perf-bench" - - "verify" - - "recover" - - "malicious join" - - "nop" - required: true - kubernetesVersion: - description: "Kubernetes version to create the cluster from." - default: "1.27" - required: true - cliVersion: - description: "Version of a released CLI to download. Leave empty to build the CLI from the checked out ref." - type: string - default: "" - required: false - imageVersion: - description: "Full name of OS image (CSP independent image version UID). Leave empty for latest debug image on main." - type: string - default: "" - required: false - workflow_call: - inputs: - nodeCount: - description: "Number of nodes to use in the cluster. Given in format `:`." - default: "3:2" - type: string - cloudProvider: - description: "Which cloud provider to use." - type: string - required: true - test: - description: "The test to run." - type: string - required: true - kubernetesVersion: - description: "Kubernetes version to create the cluster from." - type: string - required: true - cliVersion: - description: "Version of a released CLI to download. Leave empty to build the CLI from the checked out ref." - type: string - default: "" - required: false - imageVersion: - description: "Full name of OS image (CSP independent image version UID). Leave empty for latest debug image on main." - type: string - default: "" - required: false - -jobs: - split-nodeCount: - name: Split nodeCount - runs-on: ubuntu-22.04 - permissions: - id-token: write - contents: read - outputs: - workerNodes: ${{ steps.split-nodeCount.outputs.workerNodes }} - controlPlaneNodes: ${{ steps.split-nodeCount.outputs.controlPlaneNodes }} - steps: - - name: Split nodeCount - id: split-nodeCount - shell: bash - run: | - nodeCount="${{ inputs.nodeCount }}" - workerNodes="${nodeCount##*:}" - controlPlaneNodes="${nodeCount%%:*}" - - if [[ -z "${workerNodes}" ]] || [[ -z "{controlPlaneNodes}" ]]; then - echo "Invalid nodeCount input: '${nodeCount}'." - exit 1 - fi - - echo "workerNodes=${workerNodes}" | tee -a "$GITHUB_OUTPUT" - echo "controlPlaneNodes=${controlPlaneNodes}" | tee -a "$GITHUB_OUTPUT" - - find-latest-image: - name: Select image - runs-on: ubuntu-22.04 - permissions: - id-token: write - contents: read - outputs: - image: ${{ steps.find-latest-image.outputs.output }}${{ steps.check-input.outputs.image }} - steps: - - name: Check input - id: check-input - shell: bash - run: | - if [[ -z "${{ inputs.imageVersion }}" ]]; then - echo "Using latest debug image from main." - exit 0 - else - echo "image=${{ inputs.imageVersion }}" | tee -a "$GITHUB_OUTPUT" - fi - - - name: Checkout head - if: inputs.imageVersion == '' - uses: actions/checkout@c85c95e3d7251135ab7dc9ce3241c5835cc595a9 # v3.5.3 - with: - ref: ${{ !github.event.pull_request.head.repo.fork && github.head_ref || '' }} - - - name: Login to AWS - if: inputs.imageVersion == '' - uses: aws-actions/configure-aws-credentials@010d0da01d0b5a38af31e9c3470dbfdabdecca3a # v4.0.1 - with: - role-to-assume: arn:aws:iam::795746500882:role/GithubConstellationVersionsAPIRead - aws-region: eu-central-1 - - - name: Find latest image - id: find-latest-image - if: inputs.imageVersion == '' - uses: ./.github/actions/versionsapi - with: - command: latest - ref: main - stream: debug - - - name: Is debug image? - id: isDebugImage - shell: bash - run: | - case "${{ inputs.imageVersion }}" in - "") - ;; - *"/stream/debug/"*) - ;; - *) - echo "Only debug images are supported for internal LB tests." - exit 1 - ;; - esac - - e2e-test-manual: - runs-on: ubuntu-22.04 - permissions: - id-token: write - checks: write - contents: read - packages: write - needs: [find-latest-image, split-nodeCount] - if: always() && !cancelled() - steps: - - name: Install basic tools (macOS) - if: runner.os == 'macOS' - shell: bash - run: brew install coreutils kubectl bash terraform - - - name: Checkout head - uses: actions/checkout@c85c95e3d7251135ab7dc9ce3241c5835cc595a9 # v3.5.3 - with: - ref: ${{ !github.event.pull_request.head.repo.fork && github.head_ref || '' }} - - - name: Run manual E2E test - id: e2e_test - uses: ./.github/actions/e2e_test - with: - workerNodesCount: ${{ needs.split-nodeCount.outputs.workerNodes }} - controlNodesCount: ${{ needs.split-nodeCount.outputs.controlPlaneNodes }} - cloudProvider: ${{ inputs.cloudProvider }} - gcpProject: ${{ secrets.GCP_E2E_PROJECT }} - gcpClusterCreateServiceAccount: "constellation-e2e-cluster@constellation-331613.iam.gserviceaccount.com" - gcpIAMCreateServiceAccount: "constellation-iam-e2e@constellation-331613.iam.gserviceaccount.com" - gcpInClusterServiceAccountKey: ${{ secrets.GCP_CLUSTER_SERVICE_ACCOUNT }} - test: ${{ inputs.test }} - kubernetesVersion: ${{ inputs.kubernetesVersion }} - awsOpenSearchDomain: ${{ secrets.AWS_OPENSEARCH_DOMAIN }} - awsOpenSearchUsers: ${{ secrets.AWS_OPENSEARCH_USER }} - awsOpenSearchPwd: ${{ secrets.AWS_OPENSEARCH_PWD }} - osImage: ${{ needs.find-latest-image.outputs.image }} - cliVersion: ${{ inputs.cliVersion }} - isDebugImage: true - buildBuddyApiKey: ${{ secrets.BUILDBUDDY_ORG_API_KEY }} - azureClusterCreateCredentials: ${{ secrets.AZURE_E2E_CLUSTER_CREDENTIALS }} - azureIAMCreateCredentials: ${{ secrets.AZURE_E2E_IAM_CREDENTIALS }} - registry: ghcr.io - githubToken: ${{ secrets.GITHUB_TOKEN }} - cosignPassword: ${{ secrets.COSIGN_PASSWORD }} - cosignPrivateKey: ${{ secrets.COSIGN_PRIVATE_KEY }} - fetchMeasurements: ${{ contains(needs.find-latest-image.outputs.image, '/stream/stable/') }} - internalLoadBalancer: true - selfManagedInfra: "false" - - - name: Always terminate cluster - if: always() - uses: ./.github/actions/constellation_destroy - with: - kubeconfig: ${{ steps.e2e_test.outputs.kubeconfig }} - selfManagedInfra: "false" - - - name: Always delete IAM configuration - if: always() - uses: ./.github/actions/constellation_iam_destroy - with: - cloudProvider: ${{ inputs.cloudProvider }} - azureCredentials: ${{ secrets.AZURE_E2E_IAM_CREDENTIALS }} - gcpServiceAccount: "constellation-iam-e2e@constellation-331613.iam.gserviceaccount.com" - - - name: Always upload Terraform logs - if: always() - uses: ./.github/actions/upload_terraform_logs - with: - artifactNameSuffix: ${{ steps.e2e_test.outputs.namePrefix }} diff --git a/.github/workflows/e2e-test-self-managed.yml b/.github/workflows/e2e-test-self-managed.yml new file mode 100644 index 0000000000..8f85f4a716 --- /dev/null +++ b/.github/workflows/e2e-test-self-managed.yml @@ -0,0 +1,88 @@ +name: e2e test self managed infrastructure + +on: + workflow_dispatch: + inputs: + nodeCount: + description: "Number of nodes to use in the cluster. Given in format `:`." + default: "3:2" + type: string + cloudProvider: + description: "Which cloud provider to use." + type: choice + options: + - "gcp" + - "azure" + - "aws" + default: "azure" + required: true + runner: + description: "Architecture of the runner that executes the CLI" + type: choice + options: + - "ubuntu-22.04" + - "macos-12" + default: "ubuntu-22.04" + test: + description: "The test to run." + type: choice + options: + - "sonobuoy quick" + - "sonobuoy full" + - "autoscaling" + - "lb" + - "perf-bench" + - "verify" + - "recover" + - "malicious join" + - "nop" + required: true + kubernetesVersion: + description: "Kubernetes version to create the cluster from." + default: "1.27" + required: true + cliVersion: + description: "Version of a released CLI to download. Leave empty to build the CLI from the checked out ref." + type: string + default: "" + required: false + imageVersion: + description: "Full name of OS image (CSP independent image version UID). Leave empty for latest debug image on main." + type: string + default: "" + required: false + machineType: + description: "Override VM machine type. Leave as 'default' or empty to use the default VM type for the selected cloud provider." + type: string + default: "default" + required: false + regionZone: + description: "Region or zone to create the cluster in. Leave empty for default region/zone." + type: string + git-ref: + description: "Git ref to checkout." + type: string + default: "head" + required: false + +jobs: + e2e-test: + permissions: + id-token: write + checks: write + contents: read + packages: write + secrets: inherit + uses: ./.github/workflows/e2e-test.yml + with: + nodeCount: ${{ inputs.nodeCount }} + cloudProvider: ${{ inputs.cloudProvider }} + runner: ${{ inputs.runner }} + test: ${{ inputs.test }} + kubernetesVersion: ${{ inputs.kubernetesVersion }} + cliVersion: ${{ inputs.cliVersion }} + imageVersion: ${{ inputs.imageVersion }} + machineType: ${{ inputs.machineType }} + regionZone: ${{ inputs.regionZone }} + git-ref: ${{ inputs.git-ref }} + selfManagedInfra: true diff --git a/.github/workflows/e2e-test-manual.yml b/.github/workflows/e2e-test.yml similarity index 96% rename from .github/workflows/e2e-test-manual.yml rename to .github/workflows/e2e-test.yml index a32f5147a5..89e22afa25 100644 --- a/.github/workflows/e2e-test-manual.yml +++ b/.github/workflows/e2e-test.yml @@ -107,6 +107,14 @@ on: description: "Git ref to checkout." type: string required: true + internalLoadBalancer: + description: "Enable internal load balancer for the cluster." + type: boolean + default: false + selfManagedInfra: + description: "Use self-managed infrastructure." + type: boolean + default: false jobs: split-nodeCount: @@ -260,7 +268,8 @@ jobs: cosignPassword: ${{ secrets.COSIGN_PASSWORD }} cosignPrivateKey: ${{ secrets.COSIGN_PRIVATE_KEY }} fetchMeasurements: ${{ contains(needs.find-latest-image.outputs.image, '/stream/stable/') }} - selfManagedInfra: "false" + internalLoadBalancer: ${{ inputs.internalLoadBalancer }} + selfManagedInfra: ${{ inputs.selfManagedInfra }} - name: Always terminate cluster if: always()