blob: 6eadc06c7032cd09dd2de2d625f6b1c22c450246 [file] [log] [blame]
Frédéric Lécaille51e01b52018-11-29 21:41:42 +01001#!/bin/sh
PiBa-NL72504042018-11-27 22:26:38 +01002
Christopher Faulet8d67cf82018-12-18 22:41:20 +01003_help()
4{
PiBa-NL72504042018-11-27 22:26:38 +01005 cat << EOF
6### run-regtests.sh ###
7 Running run-regtests.sh --help shows this information about how to use it
8
9 Run without parameters to run all tests in the current folder (including subfolders)
10 run-regtests.sh
11
12 Provide paths to run tests from (including subfolders):
13 run-regtests.sh ./tests1 ./tests2
14
15 Parameters:
Frédéric Lécaille43361232019-01-11 10:10:21 +010016 --j <NUM>, To run vtest with multiple jobs / threads for a faster overall result
PiBa-NL72504042018-11-27 22:26:38 +010017 run-regtests.sh ./fasttest --j 16
18
19 --v, to run verbose
Frédéric Lécaille43361232019-01-11 10:10:21 +010020 run-regtests.sh --v, disables the default vtest 'quiet' parameter
PiBa-NL72504042018-11-27 22:26:38 +010021
Ilya Shipitsin856aabc2020-04-16 23:51:34 +050022 --debug to show test logs on standard output (implies --v)
Christopher Faulet2a7cf922018-12-19 10:22:01 +010023 run-regtests.sh --debug
24
Christopher Faulet9c6df5e2018-12-19 10:25:07 +010025 --keep-logs to keep all log directories (by default kept if test fails)
26 run-regtests.sh --keep-logs
27
Frédéric Lécaille43361232019-01-11 10:10:21 +010028 --vtestparams <ARGS>, passes custom ARGS to vtest
29 run-regtests.sh --vtestparams "-n 10"
PiBa-NL72504042018-11-27 22:26:38 +010030
Frédéric Lécailledc1a3bd2019-03-29 15:07:24 +010031 --type <reg tests types> filter the types of the tests to be run, depending on
32 the commented REGTESTS_TYPE variable value in each VTC file.
Christopher Faulet1eee6ca2019-12-11 16:26:11 +010033 The value of REGTESTS_TYPE supported are: default, slow, bug, broken, devel
34 and experimental. When not specified, it is set to 'default' as default value.
Frédéric Lécailledc1a3bd2019-03-29 15:07:24 +010035
36 run-regtest.sh --type slow,default
37
Christopher Faulet8d0fdf52018-12-19 10:18:40 +010038 --clean to cleanup previous reg-tests log directories and exit
39 run-regtests.sh --clean
40
PiBa-NL72504042018-11-27 22:26:38 +010041 Including text below into a .vtc file will check for its requirements
42 related to haproxy's target and compilation options
Bertrand Jacquin7e30b502019-05-16 22:15:31 +010043 # Below targets are not capable of completing this test successfully
PiBa-NL72504042018-11-27 22:26:38 +010044 #EXCLUDE_TARGET=freebsd, abns sockets are not available on freebsd
45
46 #EXCLUDE_TARGETS=dos,freebsd,windows
47
Bertrand Jacquin7e30b502019-05-16 22:15:31 +010048 # Below option is required to complete this test successfully
PiBa-NL72504042018-11-27 22:26:38 +010049 #REQUIRE_OPTION=OPENSSL, this test needs OPENSSL compiled in.
Christopher Faulet7e245df2018-12-21 15:18:02 +010050 #REQUIRE_OPTIONS=ZLIB|SLZ,OPENSSL,LUA
PiBa-NL72504042018-11-27 22:26:38 +010051
William Dauchyaabde712021-01-09 17:26:20 +010052 #REQUIRE_SERVICE=prometheus-exporter
53 #REQUIRE_SERVICES=prometheus-exporter,foo
54
PiBa-NL72504042018-11-27 22:26:38 +010055 # To define a range of versions that a test can run with:
56 #REQUIRE_VERSION=0.0
57 #REQUIRE_VERSION_BELOW=99.9
58
Frédéric Lécaille43361232019-01-11 10:10:21 +010059 Configure environment variables to set the haproxy and vtest binaries to use
PiBa-NL72504042018-11-27 22:26:38 +010060 setenv HAPROXY_PROGRAM /usr/local/sbin/haproxy
Frédéric Lécaille43361232019-01-11 10:10:21 +010061 setenv VTEST_PROGRAM /usr/local/bin/vtest
Willy Tarreaua4009cd2020-12-16 10:39:20 +010062 setenv HAPROXY_ARGS "-dM -de -m 50"
Frederic Lecailled4f36e32018-12-13 22:15:05 +010063 or
64 export HAPROXY_PROGRAM=/usr/local/sbin/haproxy
Frédéric Lécaille43361232019-01-11 10:10:21 +010065 export VTEST_PROGRAM=/usr/local/bin/vtest
Willy Tarreaua4009cd2020-12-16 10:39:20 +010066 export HAPROXY_ARGS="-dM -de -m 50"
PiBa-NL72504042018-11-27 22:26:38 +010067EOF
Christopher Faulet8d67cf82018-12-18 22:41:20 +010068 exit 0
69}
PiBa-NL72504042018-11-27 22:26:38 +010070
Frederic Lecailled4f36e32018-12-13 22:15:05 +010071add_range_to_test_list()
72{
73 level0="*.vtc"
74 level1="h*.vtc"
75 level2="s*.vtc"
76 level3="l*.vtc"
77 level4="b*.vtc"
78 level5="k*.vtc"
79 level6="e*.vtc"
80
81 new_range=$(echo $1 | tr '-' ' ')
82 non_digit=$(echo $new_range | grep '[^0-9 ]')
83 if [ -n "$non_digit" ] ; then
84 return
85 fi
86 if [ "$new_range" = "$1" ] ; then
87 if [ $1 -gt 6 ] ; then
88 return
89 fi
90 eval echo '$'level$1
91 return
92 fi
93 if [ -z "$new_range" ] ; then
94 return
95 fi
96 list=
97 for l in $(seq $new_range) ; do
98 if [ -n "l" ] ; then
99 if [ -z "$list" ] ; then
100 list="$(eval echo '$'level${l})"
101 else
102 list="$list $(eval echo '$'level${l})"
103 fi
104 fi
105 done
106
107 echo $list
108}
109
PiBa-NL72504042018-11-27 22:26:38 +0100110_startswith() {
111 _str="$1"
112 _sub="$2"
113 echo "$_str" | grep "^$_sub" >/dev/null 2>&1
114}
115
116_findtests() {
117 set -f
PiBa-NL72504042018-11-27 22:26:38 +0100118
William Lallemandc1ddcaf2021-02-05 11:27:54 +0100119 REGTESTS_TYPES="${REGTESTS_TYPES:-default,bug,devel,slow}"
Frédéric Lécailledc1a3bd2019-03-29 15:07:24 +0100120 any_test=$(echo $REGTESTS_TYPES | grep -cw "any")
121 for i in $( find "$1" -name *.vtc ); do
PiBa-NL72504042018-11-27 22:26:38 +0100122 skiptest=
Willy Tarreau939193a2018-12-06 15:49:27 +0100123 require_version="$(sed -ne 's/^#REQUIRE_VERSION=//p' "$i")"
124 require_version_below="$(sed -ne 's/^#REQUIRE_VERSION_BELOW=//p' "$i")"
Christopher Faulet7e245df2018-12-21 15:18:02 +0100125 require_options="$(sed -ne 's/^#REQUIRE_OPTIONS=//p' "$i" | sed -e 's/,/ /g')"
William Dauchyaabde712021-01-09 17:26:20 +0100126 require_services="$(sed -ne 's/^#REQUIRE_SERVICES=//p' "$i" | sed -e 's/,/ /g')"
Christopher Faulet7e245df2018-12-21 15:18:02 +0100127 exclude_targets="$(sed -ne 's/^#EXCLUDE_TARGETS=//p' "$i" | sed -e 's/,/ /g')"
Frédéric Lécailledc1a3bd2019-03-29 15:07:24 +0100128 if [ $any_test -ne 1 ] ; then
129 regtest_type="$(sed -ne 's/^#REGTEST_TYPE=//p' "$i")"
130 if [ -z $regtest_type ] ; then
131 regtest_type=default
132 fi
133 if ! $(echo $REGTESTS_TYPES | grep -wq $regtest_type) ; then
134 echo " Skip $i because its type '"$regtest_type"' is excluded"
135 skiptest=1
136 fi
137 fi
Christopher Faulet7e245df2018-12-21 15:18:02 +0100138
139 requiredoption="$(sed -ne 's/^#REQUIRE_OPTION=//p' "$i" | sed -e 's/,.*//')"
140 if [ -n "$requiredoption" ]; then
141 require_options="$require_options $requiredoption"
142 fi
143
William Dauchyaabde712021-01-09 17:26:20 +0100144 requiredservice="$(sed -ne 's/^#REQUIRE_SERVICE=//p' "$i" | sed -e 's/,.*//')"
145 if [ -n "$requiredservice" ]; then
146 require_services="$require_services $requiredservice"
147 fi
148
Christopher Faulet7e245df2018-12-21 15:18:02 +0100149 excludedtarget="$(sed -ne 's/^#EXCLUDE_TARGET=//p' "$i" | sed -e 's/,.*//')"
150 if [ -n "$excludedtarget" ]; then
151 exclude_targets="$exclude_targets $excludedtarget"
152 fi
PiBa-NL72504042018-11-27 22:26:38 +0100153
154 if [ -n "$require_version" ]; then
155 if [ $(_version "$HAPROXY_VERSION") -lt $(_version "$require_version") ]; then
156 echo " Skip $i because option haproxy is version: $HAPROXY_VERSION"
157 echo " REASON: this test requires at least version: $require_version"
158 skiptest=1
159 fi
160 fi
161 if [ -n "$require_version_below" ]; then
162 if [ $(_version "$HAPROXY_VERSION") -ge $(_version "$require_version_below") ]; then
163 echo " Skip $i because option haproxy is version: $HAPROXY_VERSION"
164 echo " REASON: this test requires a version below: $require_version_below"
165 skiptest=1
166 fi
167 fi
168
Christopher Faulet7e245df2018-12-21 15:18:02 +0100169 for excludedtarget in $exclude_targets; do
170 if [ "$excludedtarget" = "$TARGET" ]; then
171 echo " Skip $i because haproxy is compiled for the excluded target $TARGET"
PiBa-NL72504042018-11-27 22:26:38 +0100172 skiptest=1
173 fi
174 done
Christopher Faulet7e245df2018-12-21 15:18:02 +0100175
176 for requiredoption in $require_options; do
177 alternatives=$(echo "$requiredoption" | sed -e 's/|/ /g')
178 found=
179 for alt in $alternatives; do
Willy Tarreau87586e12019-03-27 13:52:39 +0100180 if echo "$FEATURES" | grep -qw "\+$alt"; then
Christopher Faulet7e245df2018-12-21 15:18:02 +0100181 found=1;
182 fi
183 done
184 if [ -z $found ]; then
185 echo " Skip $i because haproxy is not compiled with the required option $requiredoption"
PiBa-NL72504042018-11-27 22:26:38 +0100186 skiptest=1
187 fi
188 done
PiBa-NL72504042018-11-27 22:26:38 +0100189
William Dauchyaabde712021-01-09 17:26:20 +0100190 for requiredservice in $require_services; do
191 alternatives=$(echo "$requiredservice" | sed -e 's/|/ /g')
192 found=
193 for alt in $alternatives; do
William Dauchy44884342021-01-10 21:13:05 +0100194 if echo "$SERVICES" | grep -qw "$alt"; then
William Dauchyaabde712021-01-09 17:26:20 +0100195 found=1;
196 fi
197 done
198 if [ -z $found ]; then
199 echo " Skip $i because haproxy is not compiled with the required service $requiredservice"
200 skiptest=1
201 fi
202 done
203
PiBa-NL72504042018-11-27 22:26:38 +0100204 if [ -z $skiptest ]; then
205 echo " Add test: $i"
206 testlist="$testlist $i"
207 fi
208 done
209}
210
Christopher Faulet8d0fdf52018-12-19 10:18:40 +0100211_cleanup()
212{
213 DIRS=$(find "${TESTDIR}" -maxdepth 1 -type d -name "haregtests-*" -exec basename {} \; 2>/dev/null)
214 if [ -z "${DIRS}" ]; then
215 echo "No reg-tests log directory found"
216 else
217 echo "Cleanup following reg-tests log directories:"
218 for d in ${DIRS}; do
219 echo " o ${TESTDIR}/$d"
220 done
221 read -p "Continue (y/n)?" reply
222 case "$reply" in
223 y|Y)
224 for d in ${DIRS}; do
225 rm -r "${TESTDIR}/$d"
226 done
227 echo "done"
228 exit 0
229 ;;
230 *)
231 echo "aborted"
232 exit 1
233 ;;
234 esac
235 fi
236}
237
238
PiBa-NL72504042018-11-27 22:26:38 +0100239_process() {
PiBa-NL72504042018-11-27 22:26:38 +0100240 while [ ${#} -gt 0 ]; do
241 if _startswith "$1" "-"; then
242 case "${1}" in
243 --j)
244 jobcount="$2"
245 shift
246 ;;
Frédéric Lécaille43361232019-01-11 10:10:21 +0100247 --vtestparams)
248 vtestparams="$2"
PiBa-NL72504042018-11-27 22:26:38 +0100249 shift
250 ;;
251 --v)
252 verbose=""
Christopher Faulet2a7cf922018-12-19 10:22:01 +0100253 ;;
254 --debug)
255 verbose=""
256 debug="-v"
PiBa-NL72504042018-11-27 22:26:38 +0100257 ;;
Christopher Faulet9c6df5e2018-12-19 10:25:07 +0100258 --keep-logs)
259 keep_logs="-L"
260 ;;
Frédéric Lécailledc1a3bd2019-03-29 15:07:24 +0100261 --type)
262 REGTESTS_TYPES="$2"
263 shift
264 ;;
Christopher Faulet8d0fdf52018-12-19 10:18:40 +0100265 --clean)
266 _cleanup
267 exit 0
268 ;;
Christopher Faulet8d67cf82018-12-18 22:41:20 +0100269 --help)
270 _help
271 ;;
PiBa-NL72504042018-11-27 22:26:38 +0100272 *)
273 echo "Unknown parameter : $1"
Christopher Faulet8d67cf82018-12-18 22:41:20 +0100274 exit 1
PiBa-NL72504042018-11-27 22:26:38 +0100275 ;;
276 esac
277 else
Christopher Faulet8d67cf82018-12-18 22:41:20 +0100278 REGTESTS="${REGTESTS} $1"
PiBa-NL72504042018-11-27 22:26:38 +0100279 fi
280 shift 1
281 done
PiBa-NL72504042018-11-27 22:26:38 +0100282}
283
284_version() {
285 echo "$@" | awk -F. '{ printf("%d%03d%03d%03d\012", $1,$2,$3,$4); }';
286}
287
PiBa-NL72504042018-11-27 22:26:38 +0100288
Frédéric Lécaille51e01b52018-11-29 21:41:42 +0100289HAPROXY_PROGRAM="${HAPROXY_PROGRAM:-${PWD}/haproxy}"
Willy Tarreaua4009cd2020-12-16 10:39:20 +0100290HAPROXY_ARGS="${HAPROXY_ARGS--dM}"
Frédéric Lécaille43361232019-01-11 10:10:21 +0100291VTEST_PROGRAM="${VTEST_PROGRAM:-vtest}"
Christopher Faulet8d0fdf52018-12-19 10:18:40 +0100292TESTDIR="${TMPDIR:-/tmp}"
Christopher Faulet8d67cf82018-12-18 22:41:20 +0100293REGTESTS=""
294
295jobcount=""
296verbose="-q"
Christopher Faulet2a7cf922018-12-19 10:22:01 +0100297debug=""
Christopher Faulet9c6df5e2018-12-19 10:25:07 +0100298keep_logs="-l"
Christopher Faulet8d67cf82018-12-18 22:41:20 +0100299testlist=""
300
301_process "$@";
302
303echo ""
304echo "########################## Preparing to run tests ##########################"
PiBa-NL72504042018-11-27 22:26:38 +0100305
306preparefailed=
307if ! [ -x "$(command -v $HAPROXY_PROGRAM)" ]; then
308 echo "haproxy not found in path, please specify HAPROXY_PROGRAM environment variable"
309 preparefailed=1
310fi
Frédéric Lécaille43361232019-01-11 10:10:21 +0100311if ! [ -x "$(command -v $VTEST_PROGRAM)" ]; then
312 echo "vtest not found in path, please specify VTEST_PROGRAM environment variable"
PiBa-NL72504042018-11-27 22:26:38 +0100313 preparefailed=1
314fi
315if [ $preparefailed ]; then
316 exit 1
317fi
318
William Dauchyaabde712021-01-09 17:26:20 +0100319{ read HAPROXY_VERSION; read TARGET; read FEATURES; read SERVICES; } << EOF
Willy Tarreau5f3448f2021-05-09 06:12:41 +0200320$($HAPROXY_PROGRAM $HAPROXY_ARGS -vv | grep 'HA-\?Proxy version\|TARGET.*=\|^Feature\|^Available services' | sed 's/.* [:=] //')
PiBa-NL72504042018-11-27 22:26:38 +0100321EOF
322
323HAPROXY_VERSION=$(echo $HAPROXY_VERSION | cut -d " " -f 3)
324echo "Testing with haproxy version: $HAPROXY_VERSION"
325
326TESTRUNDATETIME="$(date '+%Y-%m-%d_%H-%M-%S')"
327
Frédéric Lécaille51e01b52018-11-29 21:41:42 +0100328mkdir -p "$TESTDIR" || exit 1
Christopher Faulet8d0fdf52018-12-19 10:18:40 +0100329TESTDIR=$(mktemp -d "$TESTDIR/haregtests-$TESTRUNDATETIME.XXXXXX") || exit 1
PiBa-NL72504042018-11-27 22:26:38 +0100330
Frédéric Lécaille51e01b52018-11-29 21:41:42 +0100331export TMPDIR="$TESTDIR"
332export HAPROXY_PROGRAM="$HAPROXY_PROGRAM"
Willy Tarreaua4009cd2020-12-16 10:39:20 +0100333if [ -n "$HAPROXY_ARGS" ]; then
334 export HAPROXY_ARGS
335fi
PiBa-NL72504042018-11-27 22:26:38 +0100336
PiBa-NL72504042018-11-27 22:26:38 +0100337echo "Target : $TARGET"
Willy Tarreau87586e12019-03-27 13:52:39 +0100338echo "Options : $FEATURES"
William Dauchyaabde712021-01-09 17:26:20 +0100339echo "Services : $SERVICES"
PiBa-NL72504042018-11-27 22:26:38 +0100340
341echo "########################## Gathering tests to run ##########################"
Christopher Fauletfa6798f2018-12-19 11:22:04 +0100342
Christopher Faulet8d67cf82018-12-18 22:41:20 +0100343if [ -z "$REGTESTS" ]; then
Willy Tarreauca8df4c2019-04-23 16:09:50 +0200344 _findtests reg-tests/
Christopher Faulet8d67cf82018-12-18 22:41:20 +0100345else
346 for t in $REGTESTS; do
347 _findtests $t
348 done
349fi
PiBa-NL72504042018-11-27 22:26:38 +0100350
Frédéric Lécaille43361232019-01-11 10:10:21 +0100351echo "########################## Starting vtest ##########################"
PiBa-NL72504042018-11-27 22:26:38 +0100352echo "Testing with haproxy version: $HAPROXY_VERSION"
353_vtresult=0
354if [ -n "$testlist" ]; then
355 if [ -n "$jobcount" ]; then
356 jobcount="-j $jobcount"
357 fi
Tim Duesterhusa9334df2021-05-31 23:07:29 +0200358 cmd="$VTEST_PROGRAM -b $((2<<20)) -k -t 10 $keep_logs $verbose $debug $jobcount $vtestparams $testlist"
Christopher Faulet1ecf0ea2018-12-18 22:47:23 +0100359 eval $cmd
PiBa-NL72504042018-11-27 22:26:38 +0100360 _vtresult=$?
361else
362 echo "No tests found that meet the required criteria"
363fi
Christopher Faulet9c6df5e2018-12-19 10:25:07 +0100364
365
366if [ $_vtresult -eq 0 ]; then
Bertrand Jacquin7e30b502019-05-16 22:15:31 +0100367 # all tests were successful, removing tempdir (the last part.)
Christopher Faulet9c6df5e2018-12-19 10:25:07 +0100368 # ignore errors is the directory is not empty or if it does not exist
369 rmdir "$TESTDIR" 2>/dev/null
370fi
371
372if [ -d "${TESTDIR}" ]; then
373 echo "########################## Gathering results ##########################"
Frédéric Lécaille51e01b52018-11-29 21:41:42 +0100374 export TESTDIR
375 find "$TESTDIR" -type d -name "vtc.*" -exec sh -c 'for i; do
376 if [ ! -e "$i/LOG" ] ; then continue; fi
Christopher Faulet9c6df5e2018-12-19 10:25:07 +0100377
Frédéric Lécaille51e01b52018-11-29 21:41:42 +0100378 cat <<- EOF | tee -a "$TESTDIR/failedtests.log"
379$(echo "###### $(cat "$i/INFO") ######")
380$(echo "## test results in: \"$i\"")
Frédéric Lécaillef9a48ef2019-01-08 11:30:28 +0100381$(grep -E -- "^(----|\* diag)" "$i/LOG")
PiBa-NL72504042018-11-27 22:26:38 +0100382EOF
Frédéric Lécaille51e01b52018-11-29 21:41:42 +0100383 done' sh {} +
PiBa-NL72504042018-11-27 22:26:38 +0100384fi
Christopher Faulet9c6df5e2018-12-19 10:25:07 +0100385
386exit $_vtresult