Note : Тесты можно запустить при помощи тестового скрипта. Его можно создать либо в текстовом редакторе, либо при помощи команды: ztest@zone:~# cat > test-script.sh <<EOT
#!/bin/bash
ipa=\$(sudo ifconfig | grep -A 1 vmxnet3s0 | sed '1d; s/^[ \\t]*inet[ \\t]*//; s/[ \\t]*netmask.*\$//')
if [ -n "\$1" ]; then
CLOG="/var/tmp/util-stability.\$(date +%F-%T).txt"
echo "================== Stability util & mdb tests \$(date +%F-%T) ==================" > \${CLOG}
uname -a >> \${CLOG}
echo "IP Address : \${ipa}" >> \${CLOG}
for (( i=1; i<=\$1; i++ ))
do
echo "--------------------------------------- Pass \${i} ------------------------------------" 2>&1 | /usr/bin/tee -a \${CLOG}
START_TIME=\$(date +%s)
LOG="/var/tmp/util-test.\$i.txt"
uname -a > \${LOG}
echo "IP Address : \${ipa}" >> \${LOG}
echo "---------------------------------------- UTILS --------------------------------------" 2>&1 | /usr/bin/tee -a \${LOG}
/opt/util-tests/bin/utiltest 2>&1 | /usr/bin/tee -a \${LOG}
percent="\$(grep 'Percent passed:' \${LOG} | sed 's/Percent passed:[ \\t]*//; s/[ \\t]*\$//')"
echo " UTILS percent passed: \${percent}" >> \${CLOG}
folder="\$(grep 'Log directory:' \${LOG} | sed 's/Log directory:[ \\t]*//; s/[ \\t]*\$//')"
if [ "\${percent}" != "100.0%" ]; then
END_TIME=\$(date +%s)
delta=\$((\$END_TIME - \$START_TIME))
sec=\$((\$delta % 60))
let "amin = \$delta / 60"
let "hour = \$amin / 60"
min=\$((\$amin%60))
printf " Running time: %02d:%02d:%02d\\n" $hour $min $sec >> \${CLOG}
echo " PASS \${i} IS FAILED! (See \${LOG})" >> \${CLOG}
echo "Fault on \${i} pass! Just \${percent} are successfull. You can find logs in \${folder}." 2>&1 | /usr/bin/tee -a \${LOG}
exit 1
fi
sudo rm -r -f \${folder}
echo "---------------------------------------- MDB --------------------------------------" 2>&1 | /usr/bin/tee -a \${LOG}
/opt/util-tests/bin/utiltest -c /opt/util-tests/runfiles/mdb.run 2>&1 | /usr/bin/tee -a \${LOG} percenttmp.log
folder="\$(sed '/- UTILS -/,/- MDB -/d' \${LOG} | grep 'Percent passed:' grep 'Log directory:' tmp.log | sed 's/Percent passedLog directory:[ \\t]*//; s/[ \\t]*\$//')"
echo " MDB percent passed: sudo rm -f tmp.log
cat \${percentfolder}" /log >> \${CLOGLOG}
LOG="\${folder}/log" rt="\$(sed '/- UTILS -/,/- MDB -/d' \${LOG} | grep 'Log directory:' ^Test: /!d;s/ \\[[A-Z]*\\]//;s/^.*\\[//;s/\\].*//' \${LOG}) pass=\$(sed -n '/ Tests passed:/p' \${LOG} | sed 's/Log directory^.*Tests passed:[ \\t]*//;s/[ \\t]*\$//')" END_TIME total=\$(date +%s)
delta=\$((\$END_TIME - \$START_TIME))
sec=\$((\$delta % 60))
let "amin = \$delta / 60"
let "hour = \$amin / 60"
min=\$((\$amin%60))
printf " Running time: %02d:%02d:%02d\\n" \$hour \$min \$sec >> \${CLOG}
sed -n '/Results Summary/,/Log directory:/p' \${LOG} > u.tmp
echo "---------------------------------------------------------" >> u.tmp
echo "" >> u.tmp
cat \${LOG} >> u.tmp
mv -f u.tmp \${LOG}
if [ "\${percent}" == "100.0%" ]; then
sudo rm -r -f \${folder}
else
echo " PASS \${i} IS FAILED! (See \${LOG})" >> \${CLOG}
echo "Fault on \${i} pass! Just \${percent} are successfull. You can find logs in \${folder}." 2>&1 | /usr/bin/tee -a \${LOG}
exit 1
fi
done
else
LOG="/var/tmp/util-test.\$(date +%F-%T).txt"
uname -a > u.tmp
echo "IP Address : \${ipa}" >> u.tmp
echo "" >> u.tmp
echo "sed -n '/ Tests ran:/p' \${LOG} | sed 's/^.*Tests ran:[ \\t]*//;s/[ \\t]*\$//')
percent=$(echo "scale=1; \${pass}*100.0/\${total}" | bc)
folder=\$(sed -n '/ output directory:/p' \${LOG} | sed 's/^.* output directory:[ \\t]*//;s/[ \\t]*\$//')
echo " MDB percent passed: \${percent}" >> \${CLOG}
END_TIME=\$(date +%s)
delta=\$((\$END_TIME - \$START_TIME)) sec=\$((\$delta % 60))
let "amin = \$delta / 60"
let "hour = \$amin / 60"
min=\$((\$amin%60))
printf " Running time: %02d:%02d:%02d\\n" \$hour \$min \$sec >> \${CLOG}
sed -n '/ Tests passed:/,/ Tests ran:/p' \${LOG} | sed 's/^.*Tests passed:[ \\t]*/PASS \\t/;s/^.*Tests failed:[ \\t]*/FAIL \\t/;s/^.*Tests ran:[ \\t]*/TOTAL\\t/' > u.tmp
echo "------------------------------------------------------------- UTILS --------------------------------------" 2>&1 | /usr/bin/tee -a \${LOG} /opt/util-tests/bin/utiltest " >> u.tmp
echo "" >> u.tmp
cat \${LOG} >> u.tmp
mv -f u.tmp \${LOG}
if [ "\${percent}" == "100.0%" ]; then
sudo rm -r -f \${folder}
else
echo " PASS \${i} IS FAILED! (See \${LOG})" >> \${CLOG}
echo "Fault on \${i} pass! Just \${percent} are successfull. You can find logs in \${folder}." 2>&1 | /usr/bin/tee -a \${LOG}
fail=\$(sed -n '/^FAIL[ \\t]*/p' \${LOG} | sed 's/^FAIL[ \\t]*//; s/[ \\t]*\$//')
pass=\$(sed -n '/^PASS[ \\t]*/p' \ exit 1
fi
done
else
LOG="/var/tmp/util-test.\$(date +%F-%T).txt"
uname -a > u.tmp
echo "IP Address : \${ipa}" >> u.tmp
echo "" >> u.tmp
echo "---------------------------------------- UTILS --------------------------------------" 2>&1 | /usr/bin/tee -a \${LOG}
/opt/util-tests/bin/utiltest 2>&1 | /usr/bin/tee -a \${LOG}
fail=\$(sed -n '/^FAIL[ \\t]*/p' \${LOG} | sed 's/^FAIL[ \\t]*//; s/[ \\t]*\$//')
pass=\$(sed -n '/^PASS[ \\t]*/p' \${LOG} | sed 's/^PASS[ \\t]*//; s/[ \\t]*\$//')
total=0
if [ "\${pass}" != "" ]; then
total=\$((\${total} + \${pass}))
fi
if [ "\${fail}" != "" ]; then
total=\$((\${total} + \${fail}))
fi
echo "TOTAL TESTS: \$total" >> u.tmp
echo "---------------------------------------- MDB --------------------------------------" 2>&1 | /usr/bin/tee -a \${LOG}
/opt/util-tests/bin/utiltest -c /opt/util-tests/runfiles/mdb.run 2>&1 | /usr/bin/tee -a tmp.log
folder="\$(grep 'Log directory:' tmp.log | sed 's/Log directory:[ \\t]*//; s/[ \\t]*\$//')"
sudo rm -f tmp.log
cat \${folder}/log >> \${LOG}
LOG="\${folder}/log"
tm=\$(sed '/^Test: /!d;s/ \\[[A-Z]*\\]//;s/^.*\\[//;s/\\].*//' \${LOG})
pass=\$(sed -n '/ Tests passed:/p' \${LOG} | sed 's/^PASS/^.*Tests passed:[ \\t]*//;s/[ \\t]*\$//')
total=0
if [ "\${pass}" != "" ]; then
total=\$((\${total} + \${pass}))
fi
if [ "\${fail}" != "" ]; then ]*\$//')
total=\$((sed -n '/ Tests ran:/p' \${total} + \${fail}))
fi
LOG} | sed 's/^.*Tests ran:[ \\t]*//;s/[ \\t]*\$//')
echo "TOTAL TESTS: \$total" >> u.tmp
echo "---------------------------------------- MDB --------------------------------------" 2>&1 | /usr/bin/tee -a \${LOG}
/opt/util-tests/bin/utiltest -c /opt/util-tests/runfiles/mdb.run 2>&1 | /usr/bin/tee -a \${LOG}
sed -n '/Results Summary/,/Log directory:/p' \${LOG} tmp
result=\$(echo "scale=1; \${pass}*100.0/\${total}" | bc)
folder=$(sed -n '/ output directory:/p' \${LOG} | sed 's/^.* output directory:[ \\t]*//;s/[ \\t]*\$//')
sed -n '/ Tests passed:/,/ Tests ran:/p' \${LOG} | sed 's/^.*Tests passed:[ \\t]*/PASS \\t/;s/^.*Tests failed:[ \\t]*/FAIL \\t/;s/^.*Tests ran:[ \\t]*/TOTAL\\t/' >> u.tmp
echo "" >> u.tmp
echo "Running Time: 00:\${tm}" >> u.tmp
echo "Percent passed: \${result}" >> u.tmp
echo "Log directory: \${folder}" >> u.tmp
echo "---------------------------------------------------------" >> u.tmp
echo "" >> u.tmp
cat \${LOG} >> u.tmp
mv -f u.tmp \${LOG}
fi
EOT
ztest@zone:~# sed -i '/./!d' test-script.sh && chmod 777 test-script.sh
Тестовый скрипт можно запустить в одиночном режиме, т.е. когда все тесты выполняются один раз (./test-script.sh без параметров). Тогда после запуска этого скрипта в файле /var/tmp/util-test.<ISO TIME>.txt Вы найдёте лог в формате, в котором он публикуется в Test Results. Второй вариант запуска - для проверки стабильности работы util & mdb. В этом случае нужно задать количество повторений (например, для запуска 1000 циклов - ./test-script.sh 1000 ). Теперь после запуска скрипта в папке /var/tmp Вы найдёте логи в виде util-test.<N>.txt и mdb-test.<N>.txt, где <N> - номер цикла. |