...
1. Подготовьте VM со следующими параметрами:
CPU - 4
Memory Память - 8GB
Hard disk HDD - 100GB
Have to use DEBUG build, where we have debug macro
Create user:
if you created a user at the vm preparation stage, then skip this step.
Code Block |
---|
|
sudo useradd -m -d /var/ztest -g staff -s /bin/bash ztest
# add password for remote ssh
sudo passwd ztest |
Add user to sudo:
if you created a user at the vm preparation stage, then skip this step.
...
...
Если есть дебажный макрос, используйте версию DEBUG
Процесс подготовки описан в этой инструкции.
Info |
---|
Note : Если согласно инструкции Вы уже создали раньше на этой машине dilos_BASE, и не выходил ещё новый стабильный билд, то выполните команду: beadm activate dilos_BASE
В противном случае если у Вас есть уже dilos_ISO_orig, то выполните команду: beadm activate dilos_ISO_orig
Перезагрузитесь и начните выполнять инструкцию с пункта Шаг 6. Подготовка машины для запуска тестов: reboot
Если же у Вас нет ни одного их этих двух BE, то инструкцию следует выполнять с самого начала. |
Info |
---|
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. Установите пакеты, необходимые для тестов LIBC:
Info |
---|
Note : Если Вы уже поставили их на предыдущем шаге в процессе подготовки машины к запуску, то можно перейти сразу к следующему шагу. |
Code Block |
---|
|
sudo apt update
reboot
sudo apt install system-test-libctest testrunner pythonpython3 build-essential |
...
3. Залогиньтесь под эккаунтом ztest и запустите тесты:
Code Block |
---|
|
sudo /opt/libc-tests/bin/libctest |
Wait for about 5 minutes and found full logs atПодождите минут 5, пока тесты закончатся, и Вы найдёте логи здесь:
/var/tmp/test_results/<ISO TIME>
Test run script
...
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/libc-stability.\$(date +%F-%T).txt"
echo "=== Stability libc 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/libc-test
|
...
.\$i.txt"
uname -a > \${LOG}
echo "IP Address : \${ipa}" >> \${LOG}
/opt/libc-tests/bin/libctest 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}
sed -n '/Results Summary/,/Log directory:/p' \${LOG} > a.tmp
echo "---------------------------------------------------------" >> a.tmp
echo "" >> a.tmp
cat \${LOG} >> a.tmp
mv -f a.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/libc-test.\$(date +%F-%T).txt"
uname -a > a.tmp
echo "IP Address : \${ipa}" >> a.tmp
echo "" >> a.tmp
/opt/libc-tests/bin/libctest
|
...
...
...
...
-a \${LOG}
sed -n '/Results Summary/,/Log directory:/p' \${LOG} >> a.tmp
fail=\$(sed -n '/^FAIL[ \\t]*/p' a.tmp | sed 's/^FAIL[ \\t]*//; s/[ \\t]*\$//')
pass=\$(sed -n '/^PASS[ \\t]*/p' a.tmp | 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" >> a.tmp
echo "---------------------------------------------------------" >> a.tmp
echo "" >> a.tmp
cat \${LOG} >> a.tmp
mv -f a.tmp \${LOG}
fi
EOT
ztest@zone:~# sed -i '/./!d' test-script.sh && chmod 777 test-script.sh
Тестовый скрипт можно запустить в одиночном режиме, т.е. когда все тесты выполняются один раз (./test-script.sh без параметров). Тогда после запуска этого скрипта в файле /var/tmp/libc-test.<ISO TIME>.txt Вы найдёте лог в формате, в котором он публикуется в Test Results. |
...
См. beadm, Запуск в режиме стабильности