#!/usr/bin/env bash # This script runs e2e tests for Canary, B/G and A/B initialization, analysis and promotion # Prerequisites: Kubernetes Kind and Istio set -o errexit echo '>>> Create latency metric template' cat <>> Initialising canaries' cat <>> Waiting for primary to be ready' retries=50 count=0 ok=false until ${ok}; do kubectl -n test get canary/podinfo | grep 'Initialized' && ok=true || ok=false sleep 5 count=$(($count + 1)) if [[ ${count} -eq ${retries} ]]; then kubectl -n istio-system logs deployment/flagger echo "No more retries left" exit 1 fi done echo '✔ Canary initialization test passed' passed=$(kubectl -n test get svc/podinfo -oyaml 2>&1 | { grep annotations-test || true; }) if [ -z "$passed" ]; then echo -e '\u2716 podinfo annotations test failed' exit 1 fi passed=$(kubectl -n test get svc/podinfo -oyaml 2>&1 | { grep labels-test || true; }) if [ -z "$passed" ]; then echo -e '\u2716 podinfo labels test failed' exit 1 fi passed=$(kubectl -n test get svc/podinfo -o jsonpath='{.spec.selector.app}' 2>&1 | { grep podinfo-primary || true; }) if [ -z "$passed" ]; then echo -e '\u2716 podinfo selector test failed' exit 1 fi echo '✔ Canary service custom metadata test passed' echo '>>> Triggering canary deployment' kubectl -n test set image deployment/podinfo podinfod=ghcr.io/stefanprodan/podinfo:6.0.1 echo '>>> Waiting for canary promotion' retries=50 count=0 ok=false until ${ok}; do kubectl -n test describe deployment/podinfo-primary | grep '6.0.1' && ok=true || ok=false sleep 10 kubectl -n istio-system logs deployment/flagger --tail 1 count=$(($count + 1)) if [[ ${count} -eq ${retries} ]]; then kubectl -n test describe deployment/podinfo kubectl -n test describe deployment/podinfo-primary kubectl -n istio-system logs deployment/flagger echo "No more retries left" exit 1 fi done echo '>>> Waiting for canary finalization' retries=50 count=0 ok=false until ${ok}; do kubectl -n test get canary/podinfo | grep 'Succeeded' && ok=true || ok=false sleep 5 count=$(($count + 1)) if [[ ${count} -eq ${retries} ]]; then kubectl -n istio-system logs deployment/flagger echo "No more retries left" exit 1 fi done echo '✔ Canary promotion test passed' if [[ "$1" = "canary" ]]; then exit 0 fi cat <>> Triggering B/G deployment' kubectl -n test set image deployment/podinfo podinfod=ghcr.io/stefanprodan/podinfo:6.0.2 echo '>>> Waiting for B/G promotion' retries=50 count=0 ok=false until ${ok}; do kubectl -n test describe deployment/podinfo-primary | grep '6.0.2' && ok=true || ok=false sleep 10 kubectl -n istio-system logs deployment/flagger --tail 1 count=$(($count + 1)) if [[ ${count} -eq ${retries} ]]; then kubectl -n test describe deployment/podinfo kubectl -n test describe deployment/podinfo-primary kubectl -n istio-system logs deployment/flagger echo "No more retries left" exit 1 fi done echo '>>> Waiting for B/G finalization' retries=50 count=0 ok=false until ${ok}; do kubectl -n test get canary/podinfo | grep 'Succeeded' && ok=true || ok=false sleep 5 count=$(($count + 1)) if [[ ${count} -eq ${retries} ]]; then kubectl -n istio-system logs deployment/flagger echo "No more retries left" exit 1 fi done echo '✔ B/G promotion test passed' cat <>> Triggering A/B testing' kubectl -n test set image deployment/podinfo podinfod=ghcr.io/stefanprodan/podinfo:6.0.3 echo '>>> Waiting for A/B testing promotion' retries=50 count=0 ok=false until ${ok}; do kubectl -n test describe deployment/podinfo-primary | grep '6.0.3' && ok=true || ok=false sleep 10 kubectl -n istio-system logs deployment/flagger --tail 1 count=$(($count + 1)) if [[ ${count} -eq ${retries} ]]; then kubectl -n test describe deployment/podinfo kubectl -n test describe deployment/podinfo-primary kubectl -n istio-system logs deployment/flagger echo "No more retries left" exit 1 fi done echo '✔ A/B testing promotion test passed' cat <>> Waiting for finalizers to be present' retries=50 count=0 ok=false until ${ok}; do kubectl get canary podinfo -n test -o jsonpath='{.metadata.finalizers}' | grep "finalizer.flagger.app" && ok=true || ok=false sleep 10 count=$(($count + 1)) if [[ ${count} -eq ${retries} ]]; then kubectl -n test describe canary/podinfo echo "No more retries left" exit 1 fi done kubectl delete canary podinfo -n test echo '>>> Waiting for primary to revert' retries=50 count=0 ok=false until ${ok}; do kubectl get deployment podinfo -n test -o jsonpath='{.spec.replicas}' | grep 1 && ok=true || ok=false sleep 10 kubectl -n istio-system logs deployment/flagger --tail 10 count=$(($count + 1)) if [[ ${count} -eq ${retries} ]]; then kubectl -n test describe canary/podinfo echo "No more retries left" exit 1 fi done echo '✔ Delete testing passed' cat <>> Waiting for canary to initialize' retries=50 count=0 ok=false until ${ok}; do kubectl -n test get canary/podinfo | grep 'Initialized' && ok=true || ok=false sleep 5 count=$(($count + 1)) if [[ ${count} -eq ${retries} ]]; then kubectl -n istio-system logs deployment/flagger echo "No more retries left" exit 1 fi done kubectl delete canary podinfo -n test echo '>>> Waiting for revert' retries=50 count=0 ok=false until ${ok}; do kubectl get svc/podinfo vs/podinfo -n test -o jsonpath="{range .items[*]}{.metadata.name}{'\n'}{end}" | wc -l | grep 2 && ok=true || ok=false sleep 10 kubectl -n istio-system logs deployment/flagger --tail 10 count=$(($count + 1)) if [[ ${count} -eq ${retries} ]]; then kubectl -n test describe canary/podinfo kubectl -n test describe svc/podinfo kubectl -n test describe vs/podinfo echo "No more retries left" exit 1 fi done echo '✔ Revert testing passed' kubectl -n istio-system logs deployment/flagger echo '✔ All tests passed'