From 97ce3ff5c76da12d4eda75cf9eca57e736529f26 Mon Sep 17 00:00:00 2001 From: bybai Date: Sun, 18 Oct 2015 22:58:33 -0400 Subject: [PATCH] fix delete raild failed with wait_for_ipr_device_status: command not found --- xCAT-genesis-scripts/bin/raidutils | 73 ++++++++++++++++++++++++++++++ 1 file changed, 73 insertions(+) diff --git a/xCAT-genesis-scripts/bin/raidutils b/xCAT-genesis-scripts/bin/raidutils index 45aeb61ed..f4211f30b 100755 --- a/xCAT-genesis-scripts/bin/raidutils +++ b/xCAT-genesis-scripts/bin/raidutils @@ -1319,6 +1319,79 @@ function sort_devices_by_resource_path { return 0 } +######################################################################################### +# +# wait to check ipr device status +# usage: wait_for_ipr_device_status "tryCnt= tryInt= cmd=" +# +######################################################################################### +function wait_for_ipr_device_status { + local tryCnt=1 + local tryInt=10 + local cmd="true" + + # parser input arguments + while [ -n "$1" ]; + do + local key=`echo "$1" | $cut -s -d= -f1` + if [ "$key" = "tryCnt" ] || \ + [ "$key" = "tryInt" ] || \ + [ "$key" = "cmd" ]; then + local val=`echo "$1" | $cut -s -d= -f2-` + eval "$key=\"$val\"" + elif [ "$1" = "--" ]; then + shift + sgs="$*" + break + fi + shift + done + sgs=`echo "$sgs" | $sed -e "s/,/ /g"` + local cnt=0 + local lines + while [ $cnt -lt $tryCnt -o $tryCnt -le 0 ]; + do + # sleep for specific interval for next cycle + [ $cnt -gt 0 ] && $sleep $tryInt + + lines=`check_ipr_device_status $sgs` + local status_lines="" + local neg=0 + local sg + for sg in $sgs + do + local _sg_status=`echo "$lines" | grep "^$sg=" | $cut -d= -f2- -s` + echo "$_sg_status" | eval $cmd >&2 + if [ $? -ne 0 ]; then + neg=1 + status_lines="${status_lines}${status_lines:+,}status[$sg]=\"$_sg_status\"" + fi + done + + # break out if NO negative matching + # or, try next loop + if [ $neg -eq 0 ]; then + break + else + log_status "Wait for device status at time \""`date "+%Y-%m-%d %H:%M:%S"`"\": $status_lines, expect: \"$cmd\"." + fi + + ((cnt+=1)) + done + test $cnt -lt $tryCnt -o $tryCnt -le 0 + local rc=$? + + # log for debug + if [ $rc -eq 0 ]; then + log_info "Wait for status on devices: \"$sgs\" succeed! (expected: \"$cmd\")" + else + log_warn "Wait for status on devices: \"$sgs\" failed! (expected: \"$cmd\")" + echo "$lines" | $sed -e 's/^/last device status: >> /g' | log_lines debug + fi + + return $rc +} + ###################################################### #