From 295475481fc1095243f1139f306b6a7bf69ce059 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ji=C5=99=C3=AD=20Suchomel?= Date: Mon, 4 Feb 2019 18:22:05 +0100 Subject: [PATCH] Report the reason why the script hits a timeout. Also small code cleanup and bit more consistency to the commands and variables. Change-Id: I7bb1a9e3bafc105c17010dc145adfb3a166e945e --- tools/deployment/common/wait-for-pods.sh | 28 +++++++++++++++--------- 1 file changed, 18 insertions(+), 10 deletions(-) diff --git a/tools/deployment/common/wait-for-pods.sh b/tools/deployment/common/wait-for-pods.sh index f6ea65769d..0ba8d76142 100755 --- a/tools/deployment/common/wait-for-pods.sh +++ b/tools/deployment/common/wait-for-pods.sh @@ -16,28 +16,36 @@ set -e # From Kolla-Kubernetes, orginal authors Kevin Fox & Serguei Bezverkhi -# Default wait timeout is 600 seconds +# Default wait timeout is 900 seconds end=$(date +%s) -if ! [ -z $2 ]; then - end=$((end + $2)) -else - end=$((end + 900)) -fi +timeout=${2:-900} +end=$((end + timeout)) while true; do kubectl get pods --namespace=$1 -o json | jq -r \ '.items[].status.phase' | grep Pending > /dev/null && \ - PENDING=True || PENDING=False + PENDING="True" || PENDING="False" query='.items[]|select(.status.phase=="Running")' query="$query|.status.containerStatuses[].ready" kubectl get pods --namespace=$1 -o json | jq -r "$query" | \ grep false > /dev/null && READY="False" || READY="True" - kubectl get jobs -o json --namespace=$1 | jq -r \ + kubectl get jobs --namespace=$1 -o json | jq -r \ '.items[] | .spec.completions == .status.succeeded' | \ grep false > /dev/null && JOBR="False" || JOBR="True" [ $PENDING == "False" -a $READY == "True" -a $JOBR == "True" ] && \ break || true sleep 5 now=$(date +%s) - [ $now -gt $end ] && echo containers failed to start. && \ - kubectl get pods --namespace $1 -o wide && exit -1 + if [ $now -gt $end ] ; then + echo "Containers failed to start after $timeout seconds" + echo + kubectl get pods --namespace $1 -o wide + echo + if [ $PENDING == "True" ] ; then + echo "Some pods are in pending state:" + kubectl get pods --field-selector=status.phase=Pending -n $1 -o wide + fi + [ $READY == "False" ] && echo "Some pods are not ready" + [ $JOBR == "False" ] && echo "Some jobs have not succeeded" + exit -1 + fi done