From b3739252ffbe01434046b47daa4614ab958f5de9 Mon Sep 17 00:00:00 2001 From: Todd Malsbary Date: Wed, 3 Nov 2021 10:45:04 -0700 Subject: [PATCH] Add wait command to VM e2etest site Signed-off-by: Todd Malsbary Change-Id: I06a273149ccbd10f22d38963e103505fe20d4169 --- deploy/site/vm/vm.sh | 27 +++++++++++++++++++++++++++ 1 file changed, 27 insertions(+) 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 <