Add additional ready check to NFD addon 67/4767/3
authorTodd Malsbary <todd.malsbary@intel.com>
Thu, 17 Mar 2022 16:54:27 +0000 (09:54 -0700)
committerTodd Malsbary <todd.malsbary@intel.com>
Thu, 17 Mar 2022 21:21:37 +0000 (14:21 -0700)
Signed-off-by: Todd Malsbary <todd.malsbary@intel.com>
Change-Id: I80fd99b2cb4b11ba32272b2741bcea14951ce875

deploy/addons/addons.sh

index c8a6808..f2aa57e 100755 (executable)
@@ -85,7 +85,9 @@ function is_addon_ready {
     local -r addon=$1
     local -r cluster_name=${CLUSTER_NAME:-icn}
     local -r cluster_kubeconfig="${BUILDDIR}/${cluster_name}.conf"
-    [[ $(kubectl --kubeconfig=${cluster_kubeconfig} -n kud get Kustomization/${addon} -o jsonpath='{.status.conditions[?(@.type=="Ready")].status}') == "True" ]]
+    if [[ $(kubectl --kubeconfig=${cluster_kubeconfig} -n kud get Kustomization/${addon} -o jsonpath='{.status.conditions[?(@.type=="Ready")].status}') != "True" ]]; then
+       return 1
+    fi
 
     # Additional addon specific checks
     case ${addon} in
@@ -94,6 +96,11 @@ function is_addon_ready {
                kubectl --kubeconfig=${cluster_kubeconfig} get cmk-nodereport ${node}
            done
            ;;
+       "node-feature-discovery")
+           node_name=$(kubectl --kubeconfig=${cluster_kubeconfig} get nodes -o jsonpath='{range .items[*]}{.metadata.name} {.spec.taints[?(@.effect=="NoSchedule")].effect}{"\n"}{end}' | awk 'NF==1 {print $0;exit}')
+           kernel_version=$(kubectl --kubeconfig=${cluster_kubeconfig} get node ${node_name} -o jsonpath='{.metadata.labels.feature\.node\.kubernetes\.io/kernel-version\.major}')
+           [[ -n ${kernel_version} ]]
+           ;;
     esac
 }