180 lines
5.3 KiB
Bash
Executable File
180 lines
5.3 KiB
Bash
Executable File
#!/bin/bash
|
|
|
|
today=`date +"%Y%m%d"`
|
|
TDINTERNAL_DIR=/home/shuduo/work/taosdata/TDinternal
|
|
TDINTERNAL_TEST_REPORT=$TDINTERNAL_DIR/community/tests/tdinternal-report-$today.log
|
|
|
|
# Color setting
|
|
RED='\033[0;31m'
|
|
GREEN='\033[1;32m'
|
|
GREEN_DARK='\033[0;32m'
|
|
GREEN_UNDERLINE='\033[4;32m'
|
|
NC='\033[0m'
|
|
|
|
function buildTDinternal {
|
|
echo "check if TDinternal need build"
|
|
cd $TDINTERNAL_DIR
|
|
NEED_COMPILE=0
|
|
# git remote update
|
|
REMOTE_COMMIT=`git rev-parse --short remotes/origin/develop`
|
|
LOCAL_COMMIT=`git rev-parse --short @`
|
|
echo " LOCAL: $LOCAL_COMMIT"
|
|
echo "REMOTE: $REMOTE_COMMIT"
|
|
if [ "$LOCAL_COMMIT" == "$REMOTE_COMMIT" ]; then
|
|
echo "TDinternal repo is up-to-date"
|
|
else
|
|
echo "repo need to pull"
|
|
# git pull
|
|
|
|
# NEED_COMPILE=1
|
|
fi
|
|
|
|
# git submodule update --init --recursive
|
|
cd $TDINTERNAL_DIR/community
|
|
TDENGINE_REMOTE_COMMIT=`git rev-parse --short remotes/origin/develop`
|
|
TDENGINE_LOCAL_COMMIT=`git rev-parse --short @`
|
|
if [ "$TDENGINE_LOCAL_COMMIT" == "$TDENGINE_REMOTE_COMMIT" ]; then
|
|
echo "community repo is up-to-date"
|
|
else
|
|
echo "repo need to pull"
|
|
# git checkout develop
|
|
# git pull
|
|
# NEED_COMPILE=1
|
|
fi
|
|
|
|
cd $TDINTERNAL_DIR/debug
|
|
|
|
if [[ $NEED_COMPILE -eq 1 ]]; then
|
|
LOCAL_COMMIT=`git rev-parse --short @`
|
|
rm -rf *
|
|
cmake .. > /dev/null
|
|
make > /dev/null
|
|
fi
|
|
|
|
make install > /dev/null
|
|
}
|
|
|
|
function runUniqueCaseOneByOne {
|
|
while read -r line; do
|
|
if [[ $line =~ ^./test.sh* ]]; then
|
|
case=`echo $line | awk '{print $NF}'`
|
|
start_time=`date +%s`
|
|
./test.sh -f $case > /dev/null 2>&1 && \
|
|
echo -e "${GREEN}$case success${NC}" | tee -a $TDINTERNAL_TEST_REPORT || \
|
|
echo -e "${RED}$case failed${NC}" | tee -a $TDINTERNAL_TEST_REPORT
|
|
end_time=`date +%s`
|
|
echo execution time of $case was `expr $end_time - $start_time`s. | tee -a $TDINTERNAL_TEST_REPORT
|
|
fi
|
|
done < $1
|
|
}
|
|
|
|
function runPyCaseOneByOne {
|
|
while read -r line; do
|
|
if [[ $line =~ ^python.* ]]; then
|
|
if [[ $line != *sleep* ]]; then
|
|
case=`echo $line|awk '{print $NF}'`
|
|
start_time=`date +%s`
|
|
$line > /dev/null 2>&1 && ret=0 || ret=1
|
|
end_time=`date +%s`
|
|
|
|
if [[ ret -eq 0 ]]; then
|
|
echo -e "${GREEN}$case success${NC}" | tee -a pytest-out.log
|
|
else
|
|
casename=`echo $case|sed 's/\//\-/g'`
|
|
find $TDINTERNAL_DIR/community/sim -name "*log" -exec tar czf $TDINTERNAL_DIR/fulltest-$today-$casename.log.tar.gz {} +
|
|
echo -e "${RED}$case failed and log saved${NC}" | tee -a pytest-out.log
|
|
fi
|
|
echo execution time of $case was `expr $end_time - $start_time`s. | tee -a pytest-out.log
|
|
else
|
|
$line > /dev/null 2>&1
|
|
fi
|
|
fi
|
|
done < $1
|
|
}
|
|
|
|
function runTest {
|
|
echo "Run Test"
|
|
cd $TDINTERNAL_DIR/community/tests/script
|
|
[ -d $TDINTERNAL_DIR/sim ] && rm -rf $TDINTERNAL_DIR/sim
|
|
|
|
[ -f $TDINTERNAL_TEST_REPORT ] && rm $TDINTERNAL_TEST_REPORT
|
|
|
|
runUniqueCaseOneByOne jenkins/basic.txt
|
|
|
|
totalSuccess=`grep 'success' $TDINTERNAL_TEST_REPORT | wc -l`
|
|
|
|
if [ "$totalSuccess" -gt "0" ]; then
|
|
echo -e "\n${GREEN} ### Total $totalSuccess TDinternal case(s) succeed! ### ${NC}" | tee -a $TDINTERNAL_TEST_REPORT
|
|
fi
|
|
|
|
totalFailed=`grep 'failed\|fault' $TDINTERNAL_TEST_REPORT | wc -l`
|
|
if [ "$totalFailed" -ne "0" ]; then
|
|
echo -e "${RED} ### Total $totalFailed TDinternal case(s) failed! ### ${NC}\n" | tee -a $TDINTERNAL_TEST_REPORT
|
|
# exit $totalPyFailed
|
|
fi
|
|
|
|
cd $TDINTERNAL_DIR/community/tests/pytest
|
|
[ -d $TDINTERNAL_DIR/community/sim ] && rm -rf $TDINTERNAL_DIR/community/sim
|
|
[ -f pytest-out.log ] && rm -f pytest-out.log
|
|
|
|
/usr/bin/time -f "Total spent: %e" ./test-all.sh full python | tee -a $TDINTERNAL_TEST_REPORT
|
|
runPyCaseOneByOne fulltest.sh
|
|
|
|
totalPySuccess=`grep 'success' pytest-out.log | wc -l`
|
|
totalPyFailed=`grep 'failed\|fault' pytest-out.log | wc -l`
|
|
|
|
cat pytest-out.log >> $TDINTERNAL_TEST_REPORT
|
|
if [ "$totalPySuccess" -gt "0" ]; then
|
|
echo -e "\n${GREEN} ### Total $totalPySuccess python case(s) succeed! ### ${NC}" \
|
|
| tee -a $TDINTERNAL_TEST_REPORT
|
|
fi
|
|
|
|
if [ "$totalPyFailed" -ne "0" ]; then
|
|
echo -e "\n${RED} ### Total $totalPyFailed python case(s) failed! ### ${NC}" \
|
|
| tee -a $TDINTERNAL_TEST_REPORT
|
|
fi
|
|
}
|
|
|
|
function sendReport {
|
|
echo "Send Report"
|
|
receiver="sdsang@taosdata.com, sangshuduo@gmail.com, pxiao@taosdata.com"
|
|
mimebody="MIME-Version: 1.0\nContent-Type: text/html; charset=utf-8\n"
|
|
|
|
cd $TDINTERNAL_DIR
|
|
|
|
sed -i 's/\x1b\[[0-9;]*m//g' $TDINTERNAL_TEST_REPORT
|
|
BODY_CONTENT=`cat $TDINTERNAL_TEST_REPORT`
|
|
|
|
cd $TDINTERNAL_DIR
|
|
tar czf fulltest-$today.tar.gz fulltest-$today-*.log.tar.gz
|
|
|
|
echo -e "to: ${receiver}\nsubject: TDinternal test report ${today}, commit ID: ${LOCAL_COMMIT}\n\n${today}:\n${BODY_CONTENT}" | \
|
|
(cat - && uuencode $TDINTERNAL_TEST_REPORT tdinternal-report-$today.log) | \
|
|
ssmtp "${receiver}" && echo "Report Sent!"
|
|
}
|
|
|
|
function stopTaosd {
|
|
echo "Stop taosd"
|
|
systemctl stop taosd
|
|
PID=`ps -ef|grep -w taosd | grep -v grep | awk '{print $2}'`
|
|
while [ -n "$PID" ]
|
|
do
|
|
pkill -KILL -x taosd
|
|
sleep 1
|
|
PID=`ps -ef|grep -w taosd | grep -v grep | awk '{print $2}'`
|
|
done
|
|
}
|
|
|
|
WORK_DIR=/home/shuduo/work/taosdata
|
|
|
|
date >> $WORK_DIR/cron.log
|
|
echo "Run Test for TDinternal" | tee -a $WORK_DIR/cron.log
|
|
|
|
buildTDinternal
|
|
runTest
|
|
sendReport
|
|
stopTaosd
|
|
|
|
date >> $WORK_DIR/cron.log
|
|
echo "End of TDinternal Test" | tee -a $WORK_DIR/cron.log
|