Smoke testing flavors on infra cluster tm (prefix tm) #18
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 test infra flavors | |
run-name: >- | |
${{ | |
format('Smoke testing flavors on infra cluster {0} (prefix {1})', | |
inputs.cluster, | |
inputs.prefix | |
) | |
}} | |
on: | |
workflow_dispatch: | |
inputs: | |
cluster: | |
description: Infra cluster to run smoke test on (in acs-team-temp-dev project) | |
required: true | |
prefix: | |
description: Prefix added to the clusters created for the smoke test (maximum 7 chars) | |
default: ist | |
required: true | |
jobs: | |
debug: | |
runs-on: ubuntu-latest | |
steps: | |
- name: Show inputs | |
run: | | |
echo "Cluster: ${{ inputs.cluster }}" | |
echo "Prefix: ${{ inputs.prefix }}" | |
create-cluster: | |
runs-on: ubuntu-latest | |
outputs: | |
cluster-name: ${{ steps.determine-cluster-name.outputs.cluster-name }} | |
steps: | |
- name: Determine cluster name | |
id: determine-cluster-name | |
run: | | |
echo "cluster-name=daily-smoke-test-$(date +%s)" >> ${GITHUB_OUTPUT} | |
- uses: stackrox/actions/infra/create-cluster@v1 | |
with: | |
token: ${{ secrets.INFRA_TOKEN }} | |
flavor: gke-default | |
name: ${{ steps.determine-cluster-name.outputs.cluster-name }} | |
lifespan: 8h | |
wait: true | |
- name: Checkout | |
uses: actions/checkout@v4 | |
with: | |
fetch-depth: 0 | |
ref: ${{ github.event.pull_request.head.sha }} | |
path: go/src/github.com/stackrox/infra | |
- name: Authenticate to GCloud | |
uses: google-github-actions/auth@v2 | |
with: | |
credentials_json: ${{ secrets.INFRA_CI_AUTOMATION_GCP_SA }} | |
- name: Set up Cloud SDK | |
uses: "google-github-actions/setup-gcloud@v2" | |
with: | |
install_components: "gke-gcloud-auth-plugin" | |
- name: Download production infractl | |
uses: stackrox/actions/infra/install-infractl@v1 | |
- name: Download artifacts | |
run: | | |
/github/home/.local/bin/infractl artifacts "${{ steps.determine-cluster-name.outputs.cluster-name }}" -d /github/home/artifacts >> "$GITHUB_STEP_SUMMARY" | |
kubectl get nodes -o wide || true | |
- name: Deploy infra to smoke test cluster | |
run: | | |
ENVIRONMENT=development TEST_MODE=true make install-argo clean-argo-config install-monitoring helm-deploy | |
smoke-test: | |
runs-on: ubuntu-latest | |
needs: [create-cluster] | |
env: | |
KUBECONFIG: /home/runner/artifacts/kubeconfig | |
INFRA_TOKEN_PROD: ${{ secrets.INFRA_TOKEN }} | |
INFRA_TOKEN_DEV: ${{ secrets.INFRA_TOKEN_DEV }} | |
USE_GKE_GCLOUD_AUTH_PLUGIN: "True" | |
strategy: | |
matrix: | |
flavors: [ | |
{name: "demo", "args": "", "uniqueness": "a"}, | |
{name: "aks", "args": "", "uniqueness": "b"}, | |
{name: "aro", "args": "", "uniqueness": "c"}, | |
{name: "eks", "args": "user-arns=arn:aws:iam::393282794030:user/[email protected]", "uniqueness": "d"}, | |
{name: "gke", "args": "", "uniqueness": "e"}, | |
{name: "ibmroks", "args": "", "uniqueness": "f"}, | |
{name: "ocp-4", "args": "", "uniqueness": "g"}, | |
{name: "ocp-4-demo", "args": "", "uniqueness": "h"}, | |
{name: "ocp-4-perf-scale", "args": "", "uniqueness": "i"}, | |
{name: "ocp-3", "args": "", "uniqueness": "j"}, | |
{name: "osd-on-aws", "args": "", "uniqueness": "k"}, | |
{name: "osd-on-gcp", "args": "", "uniqueness": "l"}, | |
{name: "qa-demo", "args": "main-image=quay.io/rhacs-eng/main:4.3.4", "uniqueness": "m"}, | |
{name: "rosa", "args": "", "uniqueness": "n"}, | |
{name: "rosahcp", "args": "", "uniqueness": "o"}, | |
] | |
fail-fast: false | |
steps: | |
- name: Authenticate to GCloud | |
uses: google-github-actions/auth@v2 | |
with: | |
credentials_json: ${{ secrets.INFRA_CI_AUTOMATION_GCP_SA }} | |
- name: Set up Cloud SDK | |
uses: "google-github-actions/setup-gcloud@v2" | |
with: | |
install_components: "gke-gcloud-auth-plugin" | |
- name: Download production infractl | |
uses: stackrox/actions/infra/install-infractl@v1 | |
- name: Download artifacts for cluster ${{ needs.create-cluster.outputs.cluster-name }} | |
env: | |
INFRA_TOKEN: ${{ env.INFRA_TOKEN_PROD }} | |
run: | | |
set -uo pipefail | |
infractl artifacts "${{ needs.create-cluster.outputs.cluster-name }}" -d "/home/runner/artifacts" >> "$GITHUB_STEP_SUMMARY" | |
kubectl -n infra port-forward svc/infra-server-service 8443:8443 & | |
sleep 10 | |
- name: Create infra cluster for ${{ matrix.flavors.name }} | |
uses: stackrox/actions/infra/create-cluster@v1 | |
with: | |
token: ${{ env.INFRA_TOKEN_DEV }} | |
flavor: ${{ matrix.flavors.name }} | |
name: ${{ inputs.prefix }}${{ matrix.flavors.uniqueness }}-${{ matrix.flavors.name }} | |
lifespan: 2h | |
wait: true | |
endpoint: localhost:8443 | |
insecure: true | |
args: ${{ matrix.flavors.args }} | |
no-slack: true |