5 Usage: $0 [OPTIONS] [TESTS]
8 -A Use "cat -A" to print test output (only some tests)
9 -c Run integration tests on a cluster
10 -C Remove TEST_VAR_DIR when done
11 -d Print descriptions of tests instead of filenames (dodgy!)
12 -D Show diff between failed/expected test output (some tests only)
13 -e Exit on the first test failure
14 -H No headers - for running single test with other wrapper
15 -N Don't print summary of tests results after running all tests
16 -q Quiet - don't show tests being run (hint: use with -s)
17 -S <lib> Use socket wrapper library <lib> for local integration tests
18 -v Verbose - print test output for non-failures (only some tests)
19 -V <dir> Use <dir> as TEST_VAR_DIR
20 -x Trace this script with the -x option
21 -X Trace certain scripts run by tests using -x (only some tests)
26 # Print a message and exit.
29 echo "$1" >&2 ; exit "${2:-1}"
32 ######################################################################
40 export TEST_VERBOSE
=false
41 export TEST_COMMAND_TRACE
=false
42 export TEST_CAT_RESULTS_OPTS
=""
43 export TEST_DIFF_RESULTS
=false
44 export TEST_LOCAL_DAEMONS
45 [ -n "$TEST_LOCAL_DAEMONS" ] || TEST_LOCAL_DAEMONS
=3
46 export TEST_VAR_DIR
=""
47 export TEST_CLEANUP
=false
48 export TEST_TIMEOUT
=3600
49 export TEST_SOCKET_WRAPPER_SO_PATH
=""
51 while getopts "AcCdDehHNqS:T:vV:xX?" opt
; do
53 A
) TEST_CAT_RESULTS_OPTS
="-A" ;;
54 c
) TEST_LOCAL_DAEMONS
="" ;;
55 C
) TEST_CLEANUP
=true
;;
56 d
) with_desc
=true
;; # 4th line of output is description
57 D
) TEST_DIFF_RESULTS
=true
;;
58 e
) exit_on_fail
=true
;;
60 N
) with_summary
=false
;;
62 S
) TEST_SOCKET_WRAPPER_SO_PATH
="$OPTARG" ;;
63 T
) TEST_TIMEOUT
="$OPTARG" ;;
64 v
) TEST_VERBOSE
=true
;;
65 V
) TEST_VAR_DIR
="$OPTARG" ;;
67 X
) TEST_COMMAND_TRACE
=true
;;
73 case $
(basename "$0") in
75 # Running on a cluster... same as -c
81 show_progress
() { cat >/dev
/null
; }
83 show_progress
() { cat ; }
86 ######################################################################
92 teststarttime
=$
(date '+%s')
95 echo "--==--==--==--==--==--==--==--==--==--==--==--==--==--==--==--==--==--==--"
96 echo "Running test $name ($(date '+%T'))"
97 echo "--==--==--==--==--==--==--==--==--==--==--==--==--==--==--==--==--==--==--"
102 local name
="$1" ; shift
103 local status
="$1" ; shift
104 # "$@" is command-line
106 local interp
="SKIPPED"
107 local statstr
=" (reason $*)"
108 if [ -n "$status" ] ; then
109 if [ "$status" -eq 0 ] ; then
113 elif [ "$status" -eq 124 ] ; then
115 statstr
=" (status $status)"
118 statstr
=" (status $status)"
122 testduration
=$
(($
(date +%s
) - teststarttime
))
124 echo "=========================================================================="
125 echo "TEST ${interp}: ${name}${statstr} (duration: ${testduration}s)"
126 echo "=========================================================================="
132 local name
="$1" ; shift
134 [ -n "$1" ] ||
set -- "$name"
136 $no_header || ctdb_test_begin
"$name"
139 if [ -x "$1" ] ; then
140 timeout
"$TEST_TIMEOUT" "$@" || status
=$?
142 echo "TEST IS NOT EXECUTABLE"
146 $no_header || ctdb_test_end
"$name" "$status" "$*"
151 ######################################################################
157 if ! type mktemp
>/dev
/null
2>&1 ; then
158 # Not perfect, but it will do...
162 if [ "$1" = "-d" ] ; then
165 local t
="${TMPDIR:-/tmp}/tmp.$$.$RANDOM"
178 tf
=$
(mktemp
) || die
"mktemp failed for tf - is TMPDIR missing?"
179 sf
=$
(mktemp
) || die
"mktemp failed for sf - is TMPDIR missing?"
187 tests_total
=$
((tests_total
+ 1))
189 ctdb_test_run
"$f" |
tee "$tf" | show_progress
191 if [ $status -eq 0 ] ; then
192 tests_passed
=$
((tests_passed
+ 1))
194 tests_failed
=$
((tests_failed
+ 1))
196 if $with_summary ; then
198 if [ $status -eq 0 ] ; then
204 desc
=$
(tail -n +4 "$tf" |
head -n 1)
211 find_and_run_one_test
()
216 local f
="${dir}${dir:+/}${t}"
218 if [ -d "$f" ] ; then
220 for i
in "${f%/}/"*".sh" ; do
221 # Only happens if test removed (unlikely) or empty directory
222 if [ ! -f "$i" ] ; then
226 if $exit_on_fail && [ $status -ne 0 ] ; then
230 # No tests found? Not a tests directory! Not found...
231 [ -n "$status" ] || status
=127
232 elif [ -f "$f" ] ; then
239 export CTDB_TEST_MODE
="yes"
241 # Following 2 lines may be modified by installation script
242 CTDB_TESTS_ARE_INSTALLED
=false
243 CTDB_TEST_DIR
=$
(dirname "$0")
244 export CTDB_TESTS_ARE_INSTALLED CTDB_TEST_DIR
246 if [ -z "$TEST_VAR_DIR" ] ; then
247 if $CTDB_TESTS_ARE_INSTALLED ; then
248 TEST_VAR_DIR
=$
(mktemp
-d)
250 TEST_VAR_DIR
="${CTDB_TEST_DIR}/var"
253 mkdir
-p "$TEST_VAR_DIR"
255 export TEST_SCRIPTS_DIR
="${CTDB_TEST_DIR}/scripts"
268 # If no tests specified then run some defaults
269 if [ -z "$1" ] ; then
270 if [ -n "$TEST_LOCAL_DAEMONS" ] ; then
273 set -- simple complex
279 if $TEST_CLEANUP ; then
280 echo "Removing TEST_VAR_DIR=$TEST_VAR_DIR"
281 rm -rf "$TEST_VAR_DIR"
283 echo "Not cleaning up TEST_VAR_DIR=$TEST_VAR_DIR"
287 trap "do_cleanup ; exit 130" SIGINT
288 trap "do_cleanup ; exit 143" SIGTERM
293 if [ "$f" = "UNIT" ] ; then
294 for t
in $unit_tests ; do
302 for f
in "${tests[@]}" ; do
303 find_and_run_one_test
"$f"
305 if [ $status -eq 127 ] ; then
306 # Find the the top-level tests directory
307 d
=$
(cd "$TEST_SCRIPTS_DIR" && echo "$PWD")
308 if [ -z "$d" ] ; then
309 die
"Unable to find TEST_SCRIPTS_DIR=\"${TEST_SCRIPTS_DIR}\""
311 tests_dir
=$
(dirname "$d")
312 # Strip off current directory from beginning, if there, just
313 # to make paths more friendly.
314 tests_dir
=${tests_dir#$PWD/}
315 find_and_run_one_test
"$f" "$tests_dir"
318 if [ $status -eq 127 ] ; then
319 die
"test \"$f\" is not recognised"
322 if $exit_on_fail && [ $status -ne 0 ] ; then
329 if $with_summary ; then
333 echo "${tests_passed}/${tests_total} tests passed"
342 if $no_header ||
$exit_on_fail ; then
344 elif [ $tests_failed -gt 0 ] ; then