Skip to end of metadata
Go to start of metadata

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

Compare with Current View Version History

« Previous Version 2 Current »

#!/bin/bash

boot_zone() {
    echo "Shutting down zone $1..." 2>&1 | /usr/bin/tee -a ${3}
    sudo zoneadm -z $1 halt2>&1 | /usr/bin/tee -a ${3}
    echo "Cleaning zone $1 dataset..." 2>&1 | /usr/bin/tee -a ${3}
    sudo zoneadm -z $1 uninstall -F 2>&1 | /usr/bin/tee -a ${3}
    sudo zfs destroy -fr rpool/zones/$1 2>&1 | /usr/bin/tee -a ${3}
    echo "Booting zone $1..." 2>&1 | /usr/bin/tee -a ${3}
    sudo zoneadm -z $1 clone $1-orig 2>&1 | /usr/bin/tee -a ${3}
    sudo zoneadm -z $1 boot 2>&1 | /usr/bin/tee -a ${3}
    ip=""
    while [ "${ip}" == "" ] || [ "${ip}" == "0.0.0.0" ]
    do
        ip=$(sudo zlogin -l root $1 ifconfig | grep -A 1 "${2}" | sed "/${2}/d; s/^[ \t]*inet[ \t]*//; s/[ \t]*netmask.*$//")
    done
    echo "Zone:$1 ------> $2:$ip" 2>&1 | /usr/bin/tee -a ${3}
}
echo Starting tests...
ipa=$(sudo ifconfig | grep -A 1 vmxnet3s0 | sed '1d; s/^[ \t]*inet[ \t]*//; s/[ \t]*netmask.*$//')
if [ -n "$1" ]; then
    CLOG="/var/tmp/net-stability.$(date +%F-%T).txt"
    echo "=== Stability net 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/net-test.$i.txt"
        uname -a > ${LOG}
        echo "IP Address : ${ipa}" >> ${LOG}
        echo "" >> ${LOG}
        echo ----------------------------- Booting zones... ---------------------- 2>&1 | /usr/bin/tee -a ${LOG}
        boot_zone cz int1 ${LOG}
        boot_zone sz int2 ${LOG}
        boot_zone rz int3 ${LOG}
        echo "" >> ${LOG}
        echo ----------------------------- IP Address ---------------------- 2>&1 | /usr/bin/tee -a ${LOG}
        sudo ifconfig | grep -A 1 vmxnet3s0 2>&1 | /usr/bin/tee -a ${LOG}
        echo ------------------------------- Zones ------------------------- 2>&1 | /usr/bin/tee -a ${LOG}
        sudo zoneadm list -v 2>&1 | /usr/bin/tee -a ${LOG}
        echo ---------------------------- DHCP Server ---------------------- 2>&1 | /usr/bin/tee -a ${LOG}
        sudo svcs -z dhcp isc-dhcp-server 2>&1 | /usr/bin/tee -a ${LOG}
        echo ------------------------------- Tests ------------------------- 2>&1 | /usr/bin/tee -a ${LOG}
        sudo /opt/net-tests/bin/nettest /var/tmp 2>&1 | /usr/bin/tee -a /var/tmp/a.tmp
        percent="$(grep 'Percent passed:' /var/tmp/a.tmp | sed 's/Percent passed:[ \t]*//; s/[ \t]*$//')"
        folder="$(grep 'Log directory:' /var/tmp/a.tmp | sed 's/Log directory:[ \t]*//; s/[ \t]*$//')"
        rt="$(grep 'Running Time:' /var/tmp/a.tmp | sed 's/Running Time:[ \t]*//; s/[ \t]*$//')"
        echo " Percent passed: ${percent}" >> ${CLOG}
        echo " Running Time: ${rt}" >> ${CLOG}
        sed -n '/Results Summary/,/Log directory:/p' /var/tmp/a.tmp >> ${LOG}
        echo "" >> ${LOG}
        cat /var/tmp/a.tmp >> ${LOG}
        rm -f /var/tmp/a.tmp
        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/nettest.$(date +%F-%T).txt"
    uname -a > ${LOG}
    echo "IP Address : ${ipa}" >> ${LOG}
    echo "" >> ${LOG}
    echo ----------------------------- Booting zones... ---------------------- 2>&1 | /usr/bin/tee -a ${LOG}
    boot_zone cz int1 ${LOG} ${LOG}
    boot_zone sz int2 ${LOG} ${LOG}
    boot_zone rz int3    echo "" >> ${LOG}
    echo ----------------------------- IP Address ---------------------- 2>&1 | /usr/bin/tee -a ${LOG}
    sudo ifconfig | grep -A 1 vmxnet3s0 2>&1 | /usr/bin/tee -a ${LOG}
    echo ------------------------------- Zones ------------------------- 2>&1 | /usr/bin/tee -a ${LOG}
    sudo zoneadm list -v 2>&1 | /usr/bin/tee -a ${LOG}
    echo ---------------------------- DHCP Server ---------------------- 2>&1 | /usr/bin/tee -a ${LOG}
    sudo svcs -z dhcp isc-dhcp-server 2>&1 | /usr/bin/tee -a ${LOG}
    echo ------------------------------- Tests ------------------------- 2>&1 | /usr/bin/tee -a ${LOG}
    sudo /opt/net-tests/bin/nettest /var/tmp 2>&1 | /usr/bin/tee -a /var/tmp/a.tmp
    sed -n '/Results Summary/,/Log directory:/p' /var/tmp/a.tmp >> ${LOG}
    fail=$(sed -n '/^FAIL[ \t]*/p' /var/tmp/a.tmp | sed 's/^FAIL[ \t]*//; s/[ \t]*$//')
    pass=$(sed -n '/^PASS[ \t]*/p' /var/tmp/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}" >> ${LOG}
    echo "" >> ${LOG}
    cat /var/tmp/a.tmp >> ${LOG}
    rm -f /var/tmp/a.tmp
fi
  • No labels