Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.
Code Block
languagebash
#!/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"    >> ${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 2>&1 | /usr/bin/tee -a ${LOG}> tmp.log
           percentfolder="$(sed '/- UTILS -/,/-  MDB  -/d' ${LOG} | grep 'PercentLog passeddirectory:' tmp.log | sed 's/PercentLog passeddirectory:[ \t]*//; s/[ \t]*$//')"
        echosudo "rm -f tmp.log
 MDB percent passed:   ${percent}" >> LOG1="${CLOGfolder}/log"
        folderrt="$(sed '/- UTILS -/,/-  MDB  -/d' ${LOG} | grep 'Log directory:' | sed 's/Log directory:[ \t]*//; s/[ \t]*$//')"^Test: /!d;s/ \[[A-Z]*\]//;s/^.*\[//;s/\].*//' ${LOG1})
        END_TIMEpass=$(date +%s)
        delta=$(($END_TIME - $START_TIME)sed -n '/ Tests passed:/p' ${LOG1} | sed 's/^.*Tests passed:[ \t]*//;s/[ \t]*$//')
        sectotal=$(($deltased % 60))
        let "amin = $delta / 60"
        let "hour = $amin / 60"-n '/ Tests ran:/p' ${LOG1} | sed 's/^.*Tests ran:[ \t]*//;s/[ \t]*$//')
        percent=$(echo "scale=1; ${pass}*100.0/${total}" | bc)
        minfolder=$(($amin%60))
        printf "    Running time:sed -n '/ output directory:/p' ${LOG1} | sed 's/^.* output directory:[ \t]*//;s/[ \t]*$//')    
       %02d:%02d:%02d\n" $hour $min $sec >> ${CLOG}
        sed -n '/Results Summary/,/Log directory:/p' ${LOG} > a.tmp echo "    MDB percent passed:   ${percent}" >> ${CLOG}
        END_TIME=$(date +%s)
         echo "---------------------------------------------------------" >> a.tmpdelta=$(($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
         echo "" >> a.tmputotal=$((${utotal} + ${pass}))
    fi
    if cat[ "${LOGfail}" >> a.tmp
 != "" ]; then
      mv -f a.tmp  utotal=$((${LOGutotal} + ${fail}))
    fi
 if [ "${percent}" == "100.0%" ]; then
            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 > elsetmp.log
            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 > 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]*$//')
    total=$((${utotal} + ${mtotal}))
    echo "TOTAL TESTS: $total" >> u.tmp
    echo "---------------------------------------------------------" >> u.tmp
    echo "IPUTIL Address TESTS: ${ipa} $utotal" >> u.tmp
     echo ""sed -n '/Results Summary/,/Log directory:/p' ${LOG} >> 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]*$//')-" >> u.tmp
    echo "MDB TESTS:   $mtotal" >> u.tmp
    pass=$(sed -n '/^PASS[ \t]* Tests passed:/p' ${LOGLOG1} | sed 's/^PASS^.*Tests passed:[ \t]*//; s/[ \t]*$//')
    totalresult=0
    if [ "${pass}" != "" ]; then
        total=$((${total} + ${pass}))
    fi
    if [ "${fail}" != "" ]; then
        total=$((${total} + ${fail}))
    fi
    echo "TOTAL TESTS: $total"$(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 "----------------------------------------  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}
    sed -n '/Results Summary/,/Log directory:/p' ${LOG}" >> 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