Skip to end of metadata
Go to start of metadata

You are viewing an old version of this page. View the current version.

Compare with Current View Page History

« Previous Version 24 Next »

1. Подготовьте VM со следующими параметрами:

  • CPU - 4

  • Память - 8GB

  • HDD - 100GB

  • Если есть дебажный макрос, используйте версию DEBUG

Процесс подготовки описан в этой инструкции.

Note : Если согласно инструкции Вы уже создали раньше на этой машине dilos_BASE, и не выходил ещё новый стабильный билд, то выполните команду:

beadm activate dilos_BASE

В противном случае если у Вас есть уже dilos_ISO_orig, то выполните команду:

beadm activate dilos_ISO_orig

Перезагрузитесь и начните выполнять инструкцию с пункта Шаг 6. Подготовка машины для запуска тестов:

reboot

Если же у Вас нет ни одного их этих двух BE, то инструкцию следует выполнять с самого начала.

Note : Если Вы забыли создать пользователя ztest согласно инструкции, создайте его сейчас:

sudo useradd -m -d /var/ztest -g staff -s /bin/bash ztest

sudo passwd ztest

echo "ztest ALL=(ALL:ALL) NOPASSWD: ALL" >> /etc/sudoers.d/ztest

2. Установите пакеты, необходимые для тестов UTIL & MDB:

Note : Если Вы уже поставили их на предыдущем шаге в процессе подготовки машины к запуску, то можно перейти сразу к следующему шагу.

sudo apt update
sudo apt install system-test-utiltest testrunner python3 build-essential libjedec1 libdemangle-sys1 diagnostic-pci

3. Залогиньтесь под эккаунтом ztest и запустите тесты:

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

Подождите несколько секунд, пока тесты закончатся, и Вы найдёте логи здесь:

/var/tmp/test_results/<ISO TIME>

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

ztest@zone:~# cat > test-script.sh <<EOT

#!/bin/bash

if [ -n "\$1" ]; then

for (( i=1; i<=\$1; i++ ))

do

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

uname -a > \${LOG}

/opt/util-tests/bin/utiltest 2>&1 | /usr/bin/tee -a \${LOG}

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

uname -a > \${LOG1}

/opt/util-tests/bin/utiltest -c /opt/util-tests/runfiles/mdb.run 2>&1 | /usr/bin/tee -a \${LOG1}

sudo rm -r -f /var/tmp/test_results

done

else

LOG="/var/tmp/util-test.\$(date +%F-%T).txt"

uname -a > \${LOG}

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

/opt/util-tests/bin/utiltest 2>&1 | /usr/bin/tee -a \${LOG}

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}

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 тесты:

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

Логи здесь /var/tmp/test_results/<ISO TIME>

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

ztest@zone:~# cat > test-script-mdb.sh <<EOT

#!/bin/bash

if [ -n "\$1" ]; then

CLOG="/var/tmp/mdb-stability.\$(date +%F-%T).txt"

echo "=== Stability mdb tests \$(date +%F-%T) ===" > \${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}

/opt/util-tests/bin/utiltest -c /opt/util-tests/runfiles/mdb.run 2>&1 | /usr/bin/tee -a \${LOG}

percent="\$(grep 'Percent passed:' \${LOG} | sed 's/Percent passed:[ \\t]*//; s/[ \\t]*\$//')"

folder="\$(grep 'Log directory:' \${LOG} | sed 's/Log directory:[ \\t]*//; s/[ \\t]*\$//')"

rt="\$(grep 'Running Time:' \${LOG} | sed 's/Running Time:[ \\t]*//; s/[ \\t]*\$//')"

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

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

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

uname -a > \${LOG}

/opt/util-tests/bin/utiltest -c /opt/util-tests/runfiles/mdb.run 2>&1 | /usr/bin/tee -a \${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

  • No labels