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 18 Next »

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

  • CPU - 4

  • Память - 8GB

  • HDD - 100GB (для установки программного обеспечения) SATA

  • Три дополнительных HDD - 8GB (для тестов zfs) SATA или NVME

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

Имена других пулов

Не создавайте пулов с именами, которые могут использоваться в тестах, т.е. testpool*. В противном случае тесты могут работать неверно.

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

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. Установите пакеты, необходимые для тестов ZFS:

apt update
apt install system-test-zfstest testrunner system-file-system-zfs-tests python3

3. Отредактируйте файл /etc/sudoers:

sudo -E /usr/bin/sed -i.bak '/secure_path/a\Defaults exempt_group+=staff' /etc/sudoers
sudo -E /usr/bin/sed -i.bak 's/ requiretty/ !requiretty/' /etc/sudoers

4. Залогиньтесь под эккаунтом ztest и запустите скрипт z.sh:

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

ztest@zone:~# cat > z.sh <<EOT

#!/bin/bash

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

sudo /sbin/zpool destroy testpool

sudo -E /usr/sbin/svcadm disable -s svc:/system/fmd:default

sudo -E find /var/fm/fmd -type f -exec rm {} \\;

sudo -E /usr/sbin/svcadm enable svc:/system/fmd:default

# we need 3 x 8G drives with 512b sector size

export DISKS="\$1 \$2 \$3"

export KEEP="rpool data"

export ZFS_USE_ONLY_DISKS=yes

#remove partition on disks

for D in \$DISKS

do

sudo -E /usr/bin/dd if=/dev/null of=/dev/dsk/\${D}p0 bs=512 count=512K

done

# cleanup drives before tests:

sudo -E /sbin/zpool create -f test123321 \$DISKS

sudo -E /sbin/zpool destroy test123321

sudo -E rm -rf /tmp/mnt* /tmp/ufs.* /tmp/log.* /tmp/tmp.* /tmp/rst* /tmp/tmpfs*

test -d /var/tmp/test_results && sudo rm -rf /var/tmp/test_results

sudo -E /usr/sbin/devfsadm -C

uname -a > z.tmp

echo "Disk IDs : \$DISKS" 2>&1 | /usr/bin/tee -a z.tmp

# run tests

START_TIME=\$(date +%s)

/bin/ksh /opt/zfs-tests/bin/zfstest \$* 2>&1 | /usr/bin/tee -a \${LOG}

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 2>&1 | /usr/bin/tee -a \${LOG}

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

skip=\$(sed -n '/^SKIP[ \\t]*/p' z.tmp | sed 's/^SKIP[ \\t]*//; s/[*\\t]*\$//')

fail=\$(sed -n '/^FAIL[ \\t]*/p' z.tmp | sed 's/^FAIL[ \\t]*//; s/[*\\t]*\$//')

pass=\$(sed -n '/^PASS[ \\t]*/p' z.tmp | sed 's/^PASS[ \\t]*//; s/[*\\t]*\$//')

total=\$((\$skip + \$fail + \$pass))

echo "TOTAL TESTS $total" >> z.tmp

echo "---------------------------------------------------------" >> z.tmp

echo "" >> z.tmp

cat \${LOG} >> z.tmp

mv -f z.tmp \${LOG}

EOT

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

Тогда после запуска этого скрипта в файле /var/tmp/zfstest.<ISO TIME>.txt Вы найдёте лог в формате, в котором он публикуется в Test Results.

Перед запуском скрипта нужно получить ID трёх 8-Гигабайтных дисков, установленных на этой VM. Это можно сделать командой diskinfo, после чего запустить тестовый скрипт, указав в параметрах ID, полученные из столбца DISK, например:

ztest@zone:~# sudo diskinfo -p
TYPE    DISK                                   VID      PID              SIZE            RMV SSD
SATA    c2t0d0                                 VMware   Virtual SATA Ha> 107374182400    no  no 
SATA    c2t1d0                                 VMware   Virtual SATA Ha> 8589934592      no  no 
SATA    c2t2d0                                 VMware   Virtual SATA Ha> 8589934592      no  no 
SATA    c2t3d0                                 VMware   Virtual SATA Ha> 8589934592      no  no 
ztest@zone:~# ./z.sh c2t1d0 c2t2d0 c2t3d0

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

/var/tmp/test_results/<ISO TIME>

Вы можете также подключаться при помощи утилиты SCREEN. Тогда Ваша команда будет выглядеть как:

ztest@zone:~# screen ./z.sh <disk1> <disk2> <disk3>

Далее Вы сможете так же отключиться в любой момент по нажатию Ctrl-A d и подключиться обратно в новой сессии SSH по:

ztest@zone:~# screen -r


См. beadm


  • No labels