builds/infra-features-gke-mesh-gateways-prod.yaml (82 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-features-gke-mesh-gateways-prod
substitutions:
_PROJECT_ID: ${PROJECT_ID}
steps:
# ASM gateways installation
# Docs:
# 1. Enabling multi-cluster Gateways -> https://cloud.google.com/kubernetes-engine/docs/how-to/enabling-multi-cluster-gateways
- name: "gcr.io/cloud-builders/gcloud"
id: "infra-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
for CTX in gke_${_PROJECT_ID}_$${GKE_PROD_REGION_1}_$${GKE_PROD1_NAME} gke_${_PROJECT_ID}_$${GKE_PROD_REGION_1}_$${GKE_PROD2_NAME} gke_${_PROJECT_ID}_$${GKE_PROD_REGION_1}_$${GKE_PROD3_NAME} gke_${_PROJECT_ID}_$${GKE_PROD_REGION_2}_$${GKE_PROD4_NAME} gke_${_PROJECT_ID}_$${GKE_PROD_REGION_2}_$${GKE_PROD5_NAME} gke_${_PROJECT_ID}_$${GKE_PROD_REGION_2}_$${GKE_PROD6_NAME}
do
echo -e "Checking ASM gateways status for $$CTX..."
kubectl --context=$$CTX wait --for=condition=Available deployment asm-ingressgateway -n asm-ingress-gw --timeout 5m
done