ansitest/SMART/smarttest-wrapper.sh
2021-04-10 12:50:06 -05:00

62 lines
1.6 KiB
Bash

#!/bin/bash
# grab dates when smart tests will complete, convert to seconds, sort and display latest time
PATH=/sbin:/var/root/bin:/var/root/bin/boojum:/root/bin:/root/bin/boojum:/usr/local/bin:/usr/local/sbin:/usr/sbin:/bin:/usr/bin:/usr/X11R6/bin
# TODO comment if smart already running
monthly-smart.sh
sleep 2
sortf=/tmp/smartdates.txt
tmpf=/tmp/smartdates-tmp.txt
sorted=/tmp/smartdates-seconds.txt
# clearit
> $sortf
> $tmpf
> $sorted
grep 'will complete' ~/smartlog.log > $sortf
# convert dates to seconds and sort
OIFS=$IFS
IFS='
'
# REF: https://stackoverflow.com/questions/1092631/get-current-time-in-seconds-since-the-epoch-on-linux-bash
for dt in $(awk '{print $6" "$7" "$8" "$9}' $sortf); do
dtos=$(date -d "$dt" +%s)
# echo "$dtos,$dt" |tee -a $tmpf
echo "$dtos,$dt" >> $tmpf
done
sort -n $tmpf -o $sorted
tail -n 1 $sorted |awk -F',' '{print "Check SMART logs after: "$2}' |tee -a ~/smartlog.log
# TODO schedule stage2 ~15 minutes after latest (convert to seconds)
nrsecs=$(tail -n 1 $sorted |awk -F',' '{print $1}')
let nrsecs=$nrsecs+900 # add 15 min (15*60)
ftrdt=$(date --date @"$nrsecs")
# Sun Jan 14 01:34:06 CST 2018
#at -M
# cleanup
/bin/rm -f $tmpf $sortf
IFS=$OIFS
exit;
1 2 3 4 5 6 7 8 9
Test will complete after Sun Jan 14 01:17:06 2018
Test will complete after Sat Jan 13 22:59:06 2018
Test will complete after Sat Jan 13 22:55:06 2018
Test will complete after Sat Jan 13 21:33:06 2018
Test will complete after Sun Jan 14 01:19:06 2018
Test will complete after Sat Jan 13 22:11:06 2018
Check SMART logs after: 01:19:06
TODO @ xx:xx # monthly-smart.sh stage2; less ~/smartlog-attrib-shortreport.log