Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

...

Code Block
languagebash
sudo apt update
reboot
sudo apt install system-test-utiltest testrunner python3 build-essential libjedec1 libdemangle-sys1 diagnostic-pci bc

...

Info

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 > tmp.log

folder="\$(grep 'Log directory:' tmp.log | sed 's/Log directory:[ \\t]*//; s/[ \\t]*\$//')"

sudo rm -f tmp.log

LOG1="\${folder}/log"

rt=\$(sed '/^Test: /!d;s/ \\[[A-Z]*\\]//;s/^.*\\[//;s/\\].*//' \${LOG1})

pass=\$(sed -n '/ Tests passed:/p' \${LOG1} | sed 's/^.*Tests passed:[ \\t]*//;s/[ \\t]*\$//')

total=\$(sed -n '/ Tests ran:/p' \${LOG1} | sed 's/^.*Tests ran:[ \\t]*//;s/[ \\t]*\$//')

percent=\$(echo "scale=1; \${pass}*100.0/\${total}" | bc)

folder=\$(sed -n '/ output directory:/p' \${LOG1} | 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}

cat \${LOG1} 2>&1 | /usr/bin/tee -a \${LOG}

if [ "\${percent}" == "100.0" ]; then

sudo rm -f \${LOG}

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 "---------------------------------------- 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]*\$//')

utotal=0

if [ "\${pass}" != "" ]; then

utotal=\$((\${utotal} + \${pass}))

fi

if [ "\${fail}" != "" ]; then

utotal=\$((\${utotal} + \${fail}))

fi

echo "---------------------------------------- MDB --------------------------------------" 2>&1 | /usr/bin/tee -a \${LOG}

/opt/util-tests/bin/utiltest -c /opt/util-tests/runfiles/mdb.run > tmp.log

folder="\$(grep 'Log directory:' tmp.log | sed 's/Log directory:[ \\t]*//; s/[ \\t]*\$//')"

sudo rm -f tmp.log

LOG1="\${folder}/log"

tm=\$(sed '/^Test: /!d;s/ \\[[A-Z]*\\]//;s/^.*\\[//;s/\\].*//' \${LOG1})

mtotal=\$(sed -n '/ Tests ran:/p' \${LOG1} | sed 's/^.*Tests ran:[ \\t]*//;s/[ \\t]*\$//')

if [[ "\$mtotal" == "" ]]; then

mtotal=0

fi

total=\$((\${utotal} + \${mtotal}))

echo "TOTAL TESTS: \$total" >> u.tmp

echo "---------------------------------------------------------" >> u.tmp

echo "UTIL TESTS: \$utotal" >> u.tmp

sed -n '/Results Summary/,/Log directory:/p' \${LOG} >> u.tmp

echo "---------------------------------------------------------" >> u.tmp

echo "MDB TESTS: \$mtotal" >> u.tmp

pass=\$(sed -n '/ Tests passed:/p' \${LOG1} | sed 's/^.*Tests passed:[ \\t]*//;s/[ \\t]*\$//')

result=\$(echo "scale=1; \${pass}*100.0/\${mtotal}" | bc)

folder=\$(sed -n '/ output directory:/p' \${LOG1} | sed 's/^.* output directory:[ \\t]*//;s/[ \\t]*\$//')

sed -n '/ Tests passed:/,/ Tests ran:/p' \${LOG1} | 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

cat \${LOG1} 2>&1 | /usr/bin/tee -a 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> - номер цикла.

4. Если Вы хотите запустить только MDB тесты:

...

Info

Note : Аналогично, MDB тесты можно запустить при помощи тестового скрипта. Его точно так же можно создать либо в текстовом редакторе, либо при помощи команды:

ztest@zone:~# cat > test-script-mdb.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/mdb-stability.\$(date +%F-%T).txt"

echo "=== Stability 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}

LOG="/var/tmp/mdb-test.\$i.txt"

uname -a > \${LOG}

echo "IP Address : \${ipa}" >> \${LOG}

/opt/util-tests/bin/utiltest -c /opt/util-tests/runfiles/mdb.run > tmp.log

folder="\$(grep 'Log directory:' tmp.log | sed 's/Log directory:[ \\t]*//; s/[ \\t]*\$//')"

sudo rm -f tmp.log

LOG1="\${folder}/log"

rt=\$(sed '/^Test: /!d;s/ \\[[A-Z]*\]//;s/^.*\\[//;s/\\].*//' \${LOG1})

pass=\$(sed -n '/ Tests passed:/p' \${LOG1} | sed 's/^.*Tests passed:[ \\t]*//;s/[ \\t]*\$//')

total=$(sed -n '/ Tests ran:/p' \${LOG1} | sed 's/^.*Tests ran:[ \t]*//;s/[ \t]*$//')

percent=\$(echo "scale=1; \${pass}*100.0/\${total}" | bc)

folder=\$(sed -n '/ output directory:/p' \${LOG1} | sed 's/^.* output directory:[ \\t]*//;s/[ \\t]*\$//')

echo " Percent passed: \${percent}" >> \${CLOG}

echo " Running Time: \${rt}" >> \${CLOG}

sed -n '/ Tests passed:/,/ Tests ran:/p' \${LOG1} | 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 "" >> u.tmp

cat \${LOG1} 2>&1 | /usr/bin/tee -a u.tmp

mv -f u.tmp \${LOG}

if [ "\${percent}" == "100.0" ]; then

sudo rm -f \${LOG}

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/mdb-test.\$(date +%F-%T).txt"

uname -a > u.tmp

echo "IP Address : \${ipa}" >> u.tmp

echo "" >> u.tmp

/opt/util-tests/bin/utiltest -c /opt/util-tests/runfiles/mdb.run > tmp.log

folder="\$(grep 'Log directory:' tmp.log | sed 's/Log directory:[ \\t]*//; s/[ \\t]*\$//')"

sudo rm -f tmp.log

LOG1="\${folder}/log"

tm=\$(sed '/^Test: /!d;s/ \\[[A-Z]*\\]//;s/^.*\\[//;s/\\].*//' \${LOG1})

pass=\$(sed -n '/ Tests passed:/p' \${LOG1} | sed 's/^.*Tests passed:[ \\t]*//;s/[ \\t]*\$//')

total=\$(sed -n '/ Tests ran:/p' \${LOG1} | sed 's/^.*Tests ran:[ \\t]*//;s/[ \\t]*\$//')

echo "TOTAL TESTS: \$total" >> u.tmp

result=\$(echo "scale=1; \${pass}*100.0/\${total}" | bc)

folder=\$(sed -n '/ output directory:/p' \${LOG1} | sed 's/^.* output directory:[ \\t]*//;s/[ \\t]*\$//')

sed -n '/ Tests passed:/,/ Tests ran:/p' \${LOG1} | 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 \${LOG1} 2>&1 | /usr/bin/tee -a u.tmp

mv -f u.tmp \${LOG}

fi

EOT

ztest@zone:~# sed -i '/./!d' test-script-mdb.sh && chmod 777 test-script-mdb.sh

Соответственно, логи будут находиться в файле /var/tmp/mdb-test.<ISO TIME>.txt или файлах /var/tmp/mdb-stability.<ISO TIME>.txt и /var/tmp/mdb-test.<N>.txt, в зависимости от режима запуска.

...

См. beadm, Запуск в режиме стабильности