From: Todd Malsbary Date: Wed, 3 Nov 2021 17:45:04 +0000 (-0700) Subject: Add wait command to VM e2etest site X-Git-Url: https://gerrit.akraino.org/r/gitweb?a=commitdiff_plain;h=refs%2Fchanges%2F01%2F4501%2F2;p=icn.git Add wait command to VM e2etest site Signed-off-by: Todd Malsbary Change-Id: I06a273149ccbd10f22d38963e103505fe20d4169 --- diff --git a/deploy/site/vm/vm.sh b/deploy/site/vm/vm.sh index 29c601c..14f9319 100755 --- a/deploy/site/vm/vm.sh +++ b/deploy/site/vm/vm.sh @@ -26,10 +26,36 @@ function clean { helm -n metal3 uninstall machines } +function is_cluster_ready { + [[ $(kubectl -n metal3 get cluster e2etest -o jsonpath='{.status.conditions[?(@.type=="Ready")].status}') == "True" ]] +} + +function are_kustomizations_ready { + [[ $(kubectl --kubeconfig=${BUILDDIR}/e2etest-admin.conf get Kustomization -n flux-system -o jsonpath='{range .items[*]}{.status.conditions[?(@.type=="Ready")].status}{"\n"}{end}' | grep -c -v True) == 0 ]] +} + +function are_helmreleases_ready { + [[ $(kubectl --kubeconfig=${BUILDDIR}/e2etest-admin.conf get HelmRelease -n flux-system -o jsonpath='{range .items[*]}{.status.conditions[?(@.type=="Ready")].status}{"\n"}{end}' | grep -c -v True) == 0 ]] +} + +function wait_for_all_ready { + WAIT_FOR_INTERVAL=60s + wait_for is_cluster_ready + clusterctl -n metal3 get kubeconfig e2etest >${BUILDDIR}/e2etest-admin.conf + chmod 600 ${BUILDDIR}/e2etest-admin.conf + # TODO The following checks are not ideal: resources created by + # operators aren't detected here, but this is the best that can be + # currently done + WAIT_FOR_INTERVAL=30s + wait_for are_kustomizations_ready + wait_for are_helmreleases_ready +} + case $1 in "build") build ;; "clean") clean ;; "deploy") deploy ;; + "wait") wait_for_all_ready ;; *) cat <