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/mdb-stability.$(date +%F-%T).txt"
    echo "=== Stability 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}
        LOG="/var/tmp/mdb-test.$i.txt"
        uname -a > ${LOG}
        echo "IP Address : ${ipa}" >> ${LOG}
        /opt/util-tests/bin/utiltest -c /opt/util-tests/runfiles/mdb.run 2>&1 | /usr/bin/tee -a ${LOG}
        percentfolder="$(sed '/- UTILS -/,/-  MDB  -/d' ${LOG} | grep 'Percent passed: 'Log directory:' | sed 's/Log directory:[ \t]*//; s/[ \t]*$//')"
        LOG="${folder}/log"
        rt=$(sed '/^Test: /!d;s/ \[[A-Z]*\]//;s/^.*\[//;s/\].*//' ${LOG})
        pass=$(sed -n '/ Tests passed:/p' ${LOG} | sed 's/Percent^.*Tests passed:[ \t]*//; s/[ \t]*$//')"
        foldertotal="$(grepsed -n 'Log/ Tests directoryran:/p' ${LOG} | sed 's/Log directory^.*Tests ran:[ \t]*//; s/[ \t]*$//')
        percent=$(echo "scale=1; ${pass}*100.0/${total}" | bc)
        rtfolder="$(grepsed -n 'Running/ output Timedirectory:/p' ${LOG} | sed 's/Running Time^.* output directory:[ \t]*//; s/[ \t]*$//')"    
        echo " Percent passed: ${percent}" >> ${CLOG}
        echo " Running Time: ${rt}" >> ${CLOG}
        sed -n '/Results Tests Summarypassed:/,/Log Tests directoryran:/p' ${LOG} > | sed 's/^.*Tests passed:[ \t]*/PASS \t/;s/^.*Tests failed:[ \t]*/FAIL \t/;s/^.*Tests ran:[ \t]*/TOTAL\t/' >> u.tmp
        echo "---------------------------------------------------------" >> u.tmp
        echo "" >> u.tmp
        cat ${LOG} >> u.tmp
        mv -f a.tmp ${LOG}
        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 > u.tmp
    echo "IP Address : ${ipa}" >> u.tmp
    echo "" >> u.tmp
    /opt/util-tests/bin/utiltest -c /opt/util-tests/runfiles/mdb.run 2>&1 | /usr/bin/tee -a ${LOG}
    failfolder="$(sed '/-n '/^FAIL[ \t]*/p UTILS -/,/-  MDB  -/d' ${LOG} | grep 'Log directory:' | sed 's/^FAILLog directory:[ \t]*//; s/[ \t]*$//')"
    LOG="${folder}/log"
    tm=$(sed '/^Test: /!d;s/ \[[A-Z]*\]//;s/^.*\[//;s/\].*//' ${LOG})
    pass=$(sed -n '/^PASS[ \t]* Tests passed:/p' ${LOG} | sed 's/^PASS^.*Tests passed:[ \t]*//; s/[ \t]*$//')
    total=0$(sed -n '/   if [ "${pass}" != "" ]; then
   Tests ran:/p' ${LOG} | sed 's/^.*Tests ran:[ \t]*//;s/[ \t]*$//')
    echo "TOTAL TESTS: $total" >> u.tmp
    totalresult=$((echo "scale=1; ${total} + pass}*100.0/${passtotal}))" | bc)
  fi  folder=$(sed -n '/ if [ "output directory:/p' ${fail}" != "" ]; thenLOG} | sed 's/^.* output directory:[ \t]*//;s/[ \t]*$//')
    sed -n '/ Tests  total=$((${total} + ${fail}))
    fipassed:/,/ Tests ran:/p' ${LOG} | sed 's/^.*Tests passed:[ \t]*/PASS \t/;s/^.*Tests failed:[ \t]*/FAIL \t/;s/^.*Tests ran:[ \t]*/TOTAL\t/' >> u.tmp
    echo "" >> u.tmp
    echo "TOTAL TESTS: $totalRunning Time:	00:${tm}" >> u.tmp
    echo "Percent passed:	${result}"  sed -n '/Results Summary/,/>> u.tmp
    echo "Log directory:/p' 	00:${LOGfolder}" >> u.tmp
    echo "---------------------------------------------------------" >> u.tmp
    echo "" >> u.tmp
    cat ${LOG} >> u.tmp
    mv -f u.tmp ${LOG}
fi

...