X-Git-Url: https://gerrit.akraino.org/r/gitweb?a=blobdiff_plain;f=deploy%2Fsite%2Fvm%2Fvm.sh;h=14f9319a357aaff4d07fae853bde731674e6a15b;hb=47623705343c39416af4b272ff01b36ae097ddb7;hp=29c601c2164d47c1d916b28091d2804fb9ef4c04;hpb=b5e361cfb202f7e02cb91eac76ba553d074b93fe;p=icn.git 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 <