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}