builds/infra-destroy-features-mesh-gateways.yaml (101 lines of code) (raw):

# Copyright 2022 Google LLC # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. timeout: 7200s # 2hr tags: - infra-destroy-acm-resources substitutions: _PROJECT_ID: ${PROJECT_ID} steps: # Deleting the ASM gateways resources installed through ACM - name: "gcr.io/cloud-builders/gcloud" id: "delete-infra-features-gke-mesh-gateways" dir: "infra/asm" entrypoint: bash args: - -c - | export PROJECT_NUMBER=$(gcloud projects describe ${_PROJECT_ID} --format 'value(projectNumber)') echo -e "PROJECT_NUMBER is $${PROJECT_NUMBER}" git config --global user.email "cloudbuild-ci@cloudbuild.gserviceaccount.com" git config --global user.name "cloudbuild-ci" gcloud source repos clone config --project=${_PROJECT_ID} cd config rm -rf * git add . && git commit -am "Deleting ASM gateways" git push # Checking if ACM resource changes are synced to cluster - name: "gcr.io/cloud-builders/gcloud" id: "infra-verify-delete-features-gke-mesh-gateways-prod" dir: "infra" entrypoint: bash args: - -c - | source vars.sh gsutil cp gs://config-management-release/released/latest/linux_amd64/nomos nomos chmod +x nomos touch konfig && export KUBECONFIG=konfig while [[ $(gcloud container clusters list --project ${_PROJECT_ID} --filter "STATUS=RUNNING AND resourceLabels.env:prod" --format="value(name)"| wc -l | awk '{print $1}') != "6" ]]; do echo "Waiting for all the clusters to be RUNNING." sleep 5 done gcloud container clusters get-credentials $${GKE_PROD1_NAME} --zone $${GKE_PROD_REGION_1} --project ${_PROJECT_ID} gcloud container clusters get-credentials $${GKE_PROD2_NAME} --zone $${GKE_PROD_REGION_1} --project ${_PROJECT_ID} gcloud container clusters get-credentials $${GKE_PROD3_NAME} --zone $${GKE_PROD_REGION_1} --project ${_PROJECT_ID} gcloud container clusters get-credentials $${GKE_PROD4_NAME} --zone $${GKE_PROD_REGION_2} --project ${_PROJECT_ID} gcloud container clusters get-credentials $${GKE_PROD5_NAME} --zone $${GKE_PROD_REGION_2} --project ${_PROJECT_ID} gcloud container clusters get-credentials $${GKE_PROD6_NAME} --zone $${GKE_PROD_REGION_2} --project ${_PROJECT_ID} gcloud container clusters get-credentials $${GKE_CONFIG_NAME} --zone $${GKE_CONFIG_REGION} --project ${_PROJECT_ID} export PROD1_NOMOS_STATUS=0 until [[ $$PROD1_NOMOS_STATUS == "SYNCED" ]] do export PROD1_NOMOS_STATUS=$(./nomos status --contexts gke_${_PROJECT_ID}_$${GKE_PROD_REGION_1}_$${GKE_PROD1_NAME} | sed -n 6p | awk '{print $1;}') echo -e "PROD1_NOMOS_STATUS is $$PROD1_NOMOS_STATUS" sleep 5 done export PROD2_NOMOS_STATUS=0 until [[ $$PROD2_NOMOS_STATUS == "SYNCED" ]] do export PROD2_NOMOS_STATUS=$(./nomos status --contexts gke_${_PROJECT_ID}_$${GKE_PROD_REGION_1}_$${GKE_PROD2_NAME} | sed -n 6p | awk '{print $1;}') echo -e "PROD2_NOMOS_STATUS is $$PROD2_NOMOS_STATUS" sleep 5 done export PROD3_NOMOS_STATUS=0 until [[ $$PROD3_NOMOS_STATUS == "SYNCED" ]] do export PROD3_NOMOS_STATUS=$(./nomos status --contexts gke_${_PROJECT_ID}_$${GKE_PROD_REGION_1}_$${GKE_PROD3_NAME} | sed -n 6p | awk '{print $1;}') echo -e "PROD3_NOMOS_STATUS is $$PROD3_NOMOS_STATUS" sleep 5 done export PROD4_NOMOS_STATUS=0 until [[ $$PROD4_NOMOS_STATUS == "SYNCED" ]] do export PROD4_NOMOS_STATUS=$(./nomos status --contexts gke_${_PROJECT_ID}_$${GKE_PROD_REGION_2}_$${GKE_PROD4_NAME} | sed -n 6p | awk '{print $1;}') echo -e "PROD4_NOMOS_STATUS is $$PROD4_NOMOS_STATUS" sleep 5 done export PROD5_NOMOS_STATUS=0 until [[ $$PROD5_NOMOS_STATUS == "SYNCED" ]] do export PROD5_NOMOS_STATUS=$(./nomos status --contexts gke_${_PROJECT_ID}_$${GKE_PROD_REGION_2}_$${GKE_PROD5_NAME} | sed -n 6p | awk '{print $1;}') echo -e "PROD5_NOMOS_STATUS is $$PROD5_NOMOS_STATUS" sleep 5 done export PROD6_NOMOS_STATUS=0 until [[ $$PROD6_NOMOS_STATUS == "SYNCED" ]] do export PROD6_NOMOS_STATUS=$(./nomos status --contexts gke_${_PROJECT_ID}_$${GKE_PROD_REGION_2}_$${GKE_PROD6_NAME} | sed -n 6p | awk '{print $1;}') echo -e "PROD6_NOMOS_STATUS is $$PROD6_NOMOS_STATUS" sleep 5 done export CONFIG_NOMOS_STATUS=0 until [[ $$CONFIG_NOMOS_STATUS == "SYNCED" ]] do export CONFIG_NOMOS_STATUS=$(./nomos status --contexts gke_${_PROJECT_ID}_$${GKE_CONFIG_REGION}_$${GKE_CONFIG_NAME} | sed -n 6p | awk '{print $1;}') echo -e "CONFIG_NOMOS_STATUS is $$CONFIG_NOMOS_STATUS" sleep 5 done # Disable multicluster ingress feature - name: "gcr.io/cloud-builders/gke-deploy" id: "infra-features-gke-gateway-config-cluster" entrypoint: bash dir: infra args: - -c - | gcloud container fleet ingress disable --project=${_PROJECT_ID}