forked from matrixorigin/mo-tester
-
Notifications
You must be signed in to change notification settings - Fork 0
/
run.sh
executable file
·134 lines (124 loc) · 5.57 KB
/
run.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
#!/usr/bin/env bash
if [[ $# -eq 0 ]];then
echo "No parameters provided,the mo-tester will run with parameters defined in the run.yml file. "
fi
TIMES=1
while getopts ":p:m:t:r:i:e:s:ogfnch" opt
do
case $opt in
p)
PATHC="path=${OPTARG}"
echo -e "The path of the cases that need to be executed by mo-tester : ${OPTARG}"
;;
m)
METHOD="method=${OPTARG}"
echo -e "The method that mo-tester will run with :${OPTARG}"
;;
t)
expr ${OPTARG} "+" 10 &> /dev/null
if [ $? -ne 0 ]; then
echo 'The times ['${OPTARG}'] is not a number'
exit 1
fi
TIMES=${OPTARG}
echo -e "The times that mo-tester execute cases for : ${OPTARG}"
;;
r)
RATE="rate=${OPTARG}"
echo -e "The success rate that test cases should reach : ${OPTARG}"
;;
i)
INCLUDE="include=${OPTARG}"
echo -e "Only script files in the path which name contain one of the : {${OPTARG}} will be executed"
;;
e)
EXCLUDE="exclude=${OPTARG}"
echo -e "Script files in the path which name contain one of the : {${OPTARG}} will be not executed"
;;
s)
RESOURCE="resource=${OPTARG}"
echo -e "Script files in the path which name contain one of the : {${OPTARG}} will be not executed"
;;
g)
IGNORE="ignore"
echo -e "SQL commands which is marked with ignore-flag will not be executed"
;;
f)
FORCE="force"
;;
n)
NOMETA="nometa"
echo -e "The meta data of the resultset will be ignored when comparing the resut"
;;
c)
CHECK="check"
echo -e "The meta data of the resultset will be ignored when comparing the resut"
;;
o)
PPROF="pprof"
echo -e "If a query timeout, mo-tester will collect the pprof info from mo"
;;
h)
echo -e "Usage: bash run.sh [option] [param] ...\nExcute test cases task"
echo -e " -p set the path of test cases needed to be executed by mo-tester"
echo -e " -m set the method that mo-tester will run with"
echo -e " -t set the times that mo-tester will execute cases for, must be numeric, default is 1"
echo -e " -r set The success rate that test cases should reach"
echo -e " -i set the including list, and only script files in the path which name contain one of the list will be excuted,if more than one,seperated by ,"
echo -e " -e set the excluding list, and script files in the path which name contain one of the list will not be excuted,if more than one,seperated by ,"
echo -e " -s set the resource path that mo-tester use to store resources, and can be refered to $resources in test file"
echo -e " -g means SQL commands which is marked with [bvt:issue] flag will not be executed,this flag starts with [-- @bvt:issue#{issueNO.}],and ends with [-- @bvt:issue],eg:"
echo -e " -- @bvt:issue#3236"
echo -e " select date_add("1997-12-31 23:59:59",INTERVAL "-10000:1" HOUR_MINUTE);"
echo -e " select date_add("1997-12-31 23:59:59",INTERVAL "-100 1" YEAR_MONTH);"
echo -e " -- @bvt:issue"
echo -e " Those two sql commands are associated with the issue#3236,and they will not been executed in bvt test,until the flag is removed when the issue#3236 is fixed."
echo -e " -n means the meta data of the resultset will be ignored when comparing the resut"
echo -e " -c check whether the case scripts match the result file"
echo -e " -o if a query timeout, mo-tester will collect the pprof info from mo"
echo -e "Examples:"
echo " bash run.sh -p case -m run -t script -r 100 -i select,subquery -e substring -g"
echo "For more support,please email to dong.su@matrixorigin.io"
exit 1
;;
?)
echo "Unkown parameter,please use -h to get help."
exit 1;;
esac
done
WORKSPACE=$(cd `dirname $0`; pwd)
MO_YAML=$WORKSPACE/mo.yml
RUN_YAML=$WORKSPACE/run.yml
LIB_WORKSPACE=$WORKSPACE/lib
function boot {
local libJars libJar
for libJar in `find ${LIB_WORKSPACE} -name "*.jar"`
do
libJars=${libJars}:${libJar}
done
if [ ${TIMES} -eq 1 ]; then
echo "This test will be only run for 1 times" | tee -a ${WORKSPACE}/log/run.log
java -Xms1024M -Xmx1024M -cp ${libJars} \
-Dconf.yml=${MO_YAML} \
-Drun.yml=${RUN_YAML} \
io.mo.Tester ${PATHC} ${METHOD} ${TYPE} ${RATE} ${INCLUDE} ${EXCLUDE} ${IGNORE} ${NOMETA} ${CHECK} ${RESOURCE} ${FORCE} ${PPROF}
else
echo "This test will be run for ${TIMES} times"
for i in $(seq 1 ${TIMES})
do
echo "The ${i} turn test has started, please wait......." | tee -a ${WORKSPACE}/log/run.log
java -Xms1024M -Xmx1024M -cp ${libJars} \
-Dconf.yml=${MO_YAML} \
-Drun.yml=${RUN_YAML} \
io.mo.Tester ${PATHC} ${METHOD} ${TYPE} ${RATE} ${INCLUDE} ${EXCLUDE} ${IGNORE} ${NOMETA} ${CHECK} ${RESOURCE} ${FORCE} ${PPROF}
echo "The ${i} turn test has ended, and test report is in ./report/${i} dir." | tee -a ${WORKSPACE}/run.log
mkdir -p ${WORKSPACE}/${MOTESTER_DIR}/report/${i}/
mv ${WORKSPACE}/${MOTESTER_DIR}/report/*.txt ${WORKSPACE}/${MOTESTER_DIR}/report/${i}/
done
fi
#java -Xms1024M -Xmx1024M -cp ${libJars} \
# -Dconf.yml=${MO_YAML} \
# -Drun.yml=${RUN_YAML} \
# io.mo.Tester ${PATHC} ${METHOD} ${TYPE} ${RATE} ${INCLUDE} ${EXCLUDE} ${IGNORE} ${NOMETA} ${CHECK} ${RESOURCE} ${FORCE}
}
boot