From fa6e18e283c1a4a3a77319b41eaf2adda41e2819 Mon Sep 17 00:00:00 2001 From: plum-lihui Date: Fri, 15 Apr 2022 20:32:52 +0800 Subject: [PATCH] [test: support valgrind run all sim cases, and save valgrind log file] --- tests/script/runAllSimCases.sh | 66 +++++++++++++++++++++++++++-- tests/script/sh/exec.sh | 9 ++-- tests/script/test.sh | 2 +- tests/script/tsim/insert/basic0.sim | 2 +- 4 files changed, 70 insertions(+), 9 deletions(-) diff --git a/tests/script/runAllSimCases.sh b/tests/script/runAllSimCases.sh index e1eea1cc38..70f2f86115 100755 --- a/tests/script/runAllSimCases.sh +++ b/tests/script/runAllSimCases.sh @@ -1,4 +1,4 @@ -#!/bin/bash +!/bin/bash ################################################## # @@ -8,13 +8,73 @@ set -e #set -x +VALGRIND=0 +LOG_BK_DIR=/data/valgrind_log_backup # 192.168.0.203 +while getopts "v:r" arg +do + case $arg in + v) + VALGRIND=1 + ;; + r) + LOG_BK_DIR=$(echo $OPTARG) + ;; + ?) #unknow option + echo "unkonw argument" + exit 1 + ;; + esac +done + +echo "VALGRIND: $VALGRIND, LOG_BK_DIR: $LOG_BK_DIR" + +CURRENT_DIR=`pwd` +TSIM_LOG_DIR=$CURRENT_DIR/../../sim/tsim/log +TAOSD_LOG_DIR=$CURRENT_DIR/../../sim + +echo "tsim log dir: $TSIM_LOG_DIR" +echo "taosd log dir: $TAOSD_LOG_DIR" + +if [[ $VALGRIND -eq 1 ]]; then + if [ -d ${LOG_BK_DIR} ]; then + rm -rf ${LOG_BK_DIR}/* + else + mkdir -p $LOG_BK_DIR/ + fi +fi while read line do firstChar=`echo ${line:0:1}` if [[ -n "$line" ]] && [[ $firstChar != "#" ]]; then - echo "======== $line ========" - $line + if [[ $VALGRIND -eq 1 ]]; then + echo "======== $line -v ========" + $line -v + + # move all valgrind log files of the sim case to valgrind back dir + # get current sim case name for + result=`echo ${line%sim*}` + result=`echo ${result#*/}` + result=`echo ${result#*/}` + result=`echo ${result////-}` + tsimLogFile=valgrind-${result}sim.log + + echo "cp ${TSIM_LOG_DIR}/valgrind-tsim.log ${LOG_BK_DIR}/${tsimLogFile} " + cp ${TSIM_LOG_DIR}/valgrind-tsim.log ${LOG_BK_DIR}/${tsimLogFile} + cp ${TAOSD_LOG_DIR}/dnode1/log/valgrind*.log ${LOG_BK_DIR}/ ||: + cp ${TAOSD_LOG_DIR}/dnode2/log/valgrind*.log ${LOG_BK_DIR}/ ||: + cp ${TAOSD_LOG_DIR}/dnode3/log/valgrind*.log ${LOG_BK_DIR}/ ||: + cp ${TAOSD_LOG_DIR}/dnode4/log/valgrind*.log ${LOG_BK_DIR}/ ||: + cp ${TAOSD_LOG_DIR}/dnode5/log/valgrind*.log ${LOG_BK_DIR}/ ||: + cp ${TAOSD_LOG_DIR}/dnode6/log/valgrind*.log ${LOG_BK_DIR}/ ||: + cp ${TAOSD_LOG_DIR}/dnode7/log/valgrind*.log ${LOG_BK_DIR}/ ||: + cp ${TAOSD_LOG_DIR}/dnode8/log/valgrind*.log ${LOG_BK_DIR}/ ||: + cp ${TAOSD_LOG_DIR}/dnode9/log/valgrind*.log ${LOG_BK_DIR}/ ||: + + else + echo "======== $line ========" + $line + fi fi done < ./jenkins/basic.txt diff --git a/tests/script/sh/exec.sh b/tests/script/sh/exec.sh index 50ded73555..606f778920 100755 --- a/tests/script/sh/exec.sh +++ b/tests/script/sh/exec.sh @@ -97,13 +97,14 @@ if [ "$CLEAR_OPTION" = "clear" ]; then fi if [ "$EXEC_OPTON" = "start" ]; then - echo "ExcuteCmd:" $EXE_DIR/taosd -c $CFG_DIR - + #echo "ExcuteCmd:" $EXE_DIR/taosd -c $CFG_DIR if [ "$VALGRIND_OPTION" = "true" ]; then TT=`date +%s` - mkdir ${LOG_DIR}/${TT} - nohup valgrind --log-file=${LOG_DIR}/${TT}/valgrind.log --tool=memcheck --leak-check=full --show-reachable=no --track-origins=yes --show-leak-kinds=all -v --workaround-gcc296-bugs=yes $EXE_DIR/taosd -c $CFG_DIR > /dev/null 2>&1 & + #mkdir ${LOG_DIR}/${TT} + echo "nohup valgrind --log-file=${LOG_DIR}/valgrind-taosd-${TT}.log --tool=memcheck --leak-check=full --show-reachable=no --track-origins=yes --show-leak-kinds=all -v --workaround-gcc296-bugs=yes $EXE_DIR/taosd -c $CFG_DIR > /dev/null 2>&1 &" + nohup valgrind --log-file=${LOG_DIR}/valgrind-taosd-${TT}.log --tool=memcheck --leak-check=full --show-reachable=no --track-origins=yes --show-leak-kinds=all -v --workaround-gcc296-bugs=yes $EXE_DIR/taosd -c $CFG_DIR > /dev/null 2>&1 & else + echo "nohup $EXE_DIR/taosd -c $CFG_DIR > /dev/null 2>&1 &" nohup $EXE_DIR/taosd -c $CFG_DIR > /dev/null 2>&1 & fi diff --git a/tests/script/test.sh b/tests/script/test.sh index f5a9e4187b..27fa4933e0 100755 --- a/tests/script/test.sh +++ b/tests/script/test.sh @@ -126,7 +126,7 @@ if [ -n "$FILE_NAME" ]; then echo "------------------------------------------------------------------------" if [ $VALGRIND -eq 1 ]; then echo valgrind --tool=memcheck --leak-check=full --show-reachable=no --track-origins=yes --show-leak-kinds=all -v --workaround-gcc296-bugs=yes --log-file=${CODE_DIR}/../script/valgrind.log $PROGRAM -c $CFG_DIR -f $FILE_NAME -v - valgrind --tool=memcheck --leak-check=full --show-reachable=no --track-origins=yes --show-leak-kinds=all -v --workaround-gcc296-bugs=yes --log-file=${CODE_DIR}/../script/valgrind.log $PROGRAM -c $CFG_DIR -f $FILE_NAME -v + valgrind --tool=memcheck --leak-check=full --show-reachable=no --track-origins=yes --show-leak-kinds=all -v --workaround-gcc296-bugs=yes --log-file=${LOG_DIR}/valgrind-tsim.log $PROGRAM -c $CFG_DIR -f $FILE_NAME -v else if [[ $MULTIPROCESS -eq 1 ]];then echo "ExcuteCmd(multiprocess):" $PROGRAM -m -c $CFG_DIR -f $FILE_NAME diff --git a/tests/script/tsim/insert/basic0.sim b/tests/script/tsim/insert/basic0.sim index 1ae8b372dc..94bd0f1ecf 100644 --- a/tests/script/tsim/insert/basic0.sim +++ b/tests/script/tsim/insert/basic0.sim @@ -537,4 +537,4 @@ endi #endi -#system sh/exec.sh -n dnode1 -s stop -x SIGINT +system sh/exec.sh -n dnode1 -s stop -x SIGINT