2022-07-13 08:04:46 -04:00
|
|
|
name: Constellation destroy
|
2022-05-03 05:15:53 -04:00
|
|
|
description: "Destroy a running Constellation cluster."
|
2022-10-27 10:57:54 -04:00
|
|
|
|
2022-11-09 04:28:34 -05:00
|
|
|
inputs:
|
|
|
|
kubeconfig:
|
|
|
|
description: "The kubeconfig for the cluster."
|
|
|
|
required: true
|
2023-12-15 04:37:29 -05:00
|
|
|
clusterCreation:
|
|
|
|
description: "How the infrastructure for the e2e test was created. One of [cli, self-managed, terraform]."
|
|
|
|
default: "cli"
|
2023-11-14 07:25:52 -05:00
|
|
|
gcpClusterDeleteServiceAccount:
|
|
|
|
description: "Service account with permissions to delete a Constellation cluster on GCP."
|
|
|
|
required: true
|
|
|
|
azureClusterDeleteCredentials:
|
|
|
|
description: "Azure credentials authorized to delete a Constellation cluster."
|
|
|
|
required: true
|
|
|
|
cloudProvider:
|
|
|
|
description: "Either 'aws', 'azure' or 'gcp'."
|
|
|
|
required: true
|
2022-11-09 04:28:34 -05:00
|
|
|
|
2022-05-03 05:15:53 -04:00
|
|
|
runs:
|
2022-10-27 10:57:54 -04:00
|
|
|
using: "composite"
|
2022-05-03 05:15:53 -04:00
|
|
|
steps:
|
2022-11-09 04:28:34 -05:00
|
|
|
- name: Delete persistent volumes
|
|
|
|
if: inputs.kubeconfig != ''
|
2022-10-27 10:57:54 -04:00
|
|
|
shell: bash
|
2022-11-09 04:28:34 -05:00
|
|
|
env:
|
|
|
|
KUBECONFIG: ${{ inputs.kubeconfig }}
|
|
|
|
PV_DELETION_TIMEOUT: "120" # 2 minutes timeout for pv deletion
|
2022-10-27 10:57:54 -04:00
|
|
|
run: |
|
|
|
|
ELAPSED=0
|
|
|
|
echo "::group::Wait for PV deletion"
|
2022-11-09 04:28:34 -05:00
|
|
|
|
|
|
|
# Scrap namespaces that contain PVCs
|
|
|
|
for namespace in `kubectl get namespace --no-headers=true -o custom-columns=":metadata.name"`; do
|
2022-12-09 05:51:38 -05:00
|
|
|
if [[ `kubectl get pvc -n $namespace --no-headers=true -o custom-columns=":metadata.name" | wc -l` -gt 0 ]]; then
|
2022-11-09 04:28:34 -05:00
|
|
|
kubectl delete namespace $namespace --wait
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
|
2022-12-09 05:51:38 -05:00
|
|
|
until [[ "$(kubectl get pv -o json | jq '.items | length')" == "0" ]] || [[ $ELAPSED -gt $PV_DELETION_TIMEOUT ]];
|
2022-10-27 10:57:54 -04:00
|
|
|
do
|
2022-11-09 04:28:34 -05:00
|
|
|
echo $(kubectl get pv -o json | jq '.items | length') PV remaining..
|
|
|
|
sleep 1
|
|
|
|
ELAPSED=$((ELAPSED+1))
|
2022-10-27 10:57:54 -04:00
|
|
|
done
|
2022-12-09 05:51:38 -05:00
|
|
|
if [[ $ELAPSED -gt $PV_DELETION_TIMEOUT ]]; then
|
2022-11-09 04:28:34 -05:00
|
|
|
echo "Timed out waiting for PV deletion.."
|
|
|
|
exit 1
|
2022-10-27 10:57:54 -04:00
|
|
|
fi
|
|
|
|
echo "::endgroup::"
|
|
|
|
|
2023-11-14 07:25:52 -05:00
|
|
|
- name: Login to GCP (Cluster service account)
|
|
|
|
if: inputs.cloudProvider == 'gcp'
|
|
|
|
uses: ./.github/actions/login_gcp
|
|
|
|
with:
|
|
|
|
service_account: ${{ inputs.gcpClusterDeleteServiceAccount }}
|
|
|
|
|
|
|
|
- name: Login to AWS (Cluster role)
|
|
|
|
if: inputs.cloudProvider == 'aws'
|
|
|
|
uses: aws-actions/configure-aws-credentials@010d0da01d0b5a38af31e9c3470dbfdabdecca3a # v4.0.1
|
|
|
|
with:
|
|
|
|
role-to-assume: arn:aws:iam::795746500882:role/GithubActionsE2ECluster
|
|
|
|
aws-region: eu-central-1
|
|
|
|
# extend token expiry to 6 hours to ensure constellation can terminate
|
|
|
|
role-duration-seconds: 21600
|
|
|
|
|
|
|
|
- name: Login to Azure (Cluster service principal)
|
|
|
|
if: inputs.cloudProvider == 'azure'
|
|
|
|
uses: ./.github/actions/login_azure
|
|
|
|
with:
|
|
|
|
azure_credentials: ${{ inputs.azureClusterDeleteCredentials }}
|
|
|
|
|
2022-10-27 10:57:54 -04:00
|
|
|
- name: Constellation terminate
|
2023-12-15 04:37:29 -05:00
|
|
|
if: inputs.clusterCreation != 'self-managed'
|
2022-10-27 10:57:54 -04:00
|
|
|
shell: bash
|
2023-04-28 05:25:45 -04:00
|
|
|
run: |
|
2023-08-16 05:34:58 -04:00
|
|
|
constellation terminate --yes --tf-log=DEBUG
|
2023-10-27 03:37:26 -04:00
|
|
|
|
|
|
|
- name: Constellation terminate (self-managed)
|
2023-12-15 04:37:29 -05:00
|
|
|
if: inputs.clusterCreation == 'self-managed'
|
2023-10-27 03:37:26 -04:00
|
|
|
shell: bash
|
|
|
|
working-directory: ${{ github.workspace }}/e2e-infra
|
|
|
|
run: |
|
|
|
|
terraform init
|
|
|
|
terraform destroy -auto-approve
|
2023-10-31 07:45:10 -04:00
|
|
|
|
|
|
|
rm -f ${{ github.workspace }}/constellation-state.yaml
|
|
|
|
rm -f ${{ github.workspace }}/constellation-admin.conf
|