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 Clean up when done by removing test state directory (see -V)
11 -D Show diff between failed/expected test output (some tests only)
12 -e Exit on the first test failure
13 -H No headers - for running single test with other wrapper
14 -I <count> Iterate tests <count> times, exiting on failure (implies -e, -N)
15 -N Don't print summary of tests results after running all tests
16 -q Quiet - don't show tests being run (still displays summary)
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 state directory
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 ######################################################################
41 export TEST_VERBOSE
=false
42 export TEST_COMMAND_TRACE
=false
43 export TEST_CAT_RESULTS_OPTS
=""
44 export TEST_DIFF_RESULTS
=false
45 export TEST_LOCAL_DAEMONS
46 [ -n "$TEST_LOCAL_DAEMONS" ] || TEST_LOCAL_DAEMONS
=3
47 export TEST_CLEANUP
=false
48 export TEST_TIMEOUT
=3600
49 export TEST_SOCKET_WRAPPER_SO_PATH
=""
51 while getopts "AcCDehHI:NqS:T:vV:xX?" opt
; do
53 A
) TEST_CAT_RESULTS_OPTS
="-A" ;;
54 c
) TEST_LOCAL_DAEMONS
="" ;;
55 C
) TEST_CLEANUP
=true
;;
56 D
) TEST_DIFF_RESULTS
=true
;;
57 e
) exit_on_fail
=true
;;
59 I
) max_iterations
="$OPTARG" ; exit_on_fail
=true
; with_summary
=false
;;
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_state_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"
184 CTDB_TEST_SUITE_DIR
=$
(dirname "$f")
185 export CTDB_TEST_SUITE_DIR
186 # This expands the most probable problem cases like "." and "..".
187 if [ "$(dirname "$CTDB_TEST_SUITE_DIR")" = "." ] ; then
188 CTDB_TEST_SUITE_DIR
=$
(cd "$CTDB_TEST_SUITE_DIR" && pwd)
191 # Set CTDB_TEST_TMP_DIR
193 # Determine the relative test suite subdirectory. The top-level
194 # test directory needs to be a prefix of the test suite directory,
195 # so make absolute versions of both.
196 local test_dir test_suite_dir reldir
197 test_dir
=$
(cd "$CTDB_TEST_DIR" && pwd)
198 test_suite_dir
=$
(cd "$CTDB_TEST_SUITE_DIR" && pwd)
199 reldir
="${test_suite_dir#${test_dir}/}"
201 export CTDB_TEST_TMP_DIR
="${test_state_dir}/${reldir}"
202 rm -rf "$CTDB_TEST_TMP_DIR"
203 mkdir
-p "$CTDB_TEST_TMP_DIR"
205 tests_total
=$
((tests_total
+ 1))
207 ctdb_test_run
"$f" | show_progress
209 if [ $status -eq 0 ] ; then
210 tests_passed
=$
((tests_passed
+ 1))
212 tests_failed
=$
((tests_failed
+ 1))
214 if $with_summary ; then
216 if [ $status -eq 0 ] ; then
221 echo "$t $f" >>"$summary_file"
225 find_and_run_one_test
()
230 local f
="${dir}${dir:+/}${t}"
232 if [ -d "$f" ] ; then
234 for i
in "${f%/}/"*".sh" ; do
235 # Only happens if test removed (unlikely) or empty directory
236 if [ ! -f "$i" ] ; then
240 if $exit_on_fail && [ $status -ne 0 ] ; then
244 # No tests found? Not a tests directory! Not found...
245 [ -n "$status" ] || status
=127
246 elif [ -f "$f" ] ; then
257 for f
in "${tests[@]}" ; do
258 find_and_run_one_test
"$f"
260 if [ $status -eq 127 ] ; then
261 # Find the the top-level tests directory
262 d
=$
(cd "$TEST_SCRIPTS_DIR" && echo "$PWD")
263 if [ -z "$d" ] ; then
264 local t
="$TEST_SCRIPTS_DIR"
265 die
"Unable to find TEST_SCRIPTS_DIR=\"${t}\""
267 tests_dir
=$
(dirname "$d")
268 # Strip off current directory from beginning,
269 # if there, just to make paths more friendly.
270 tests_dir
="${tests_dir#${PWD}/}"
271 find_and_run_one_test
"$f" "$tests_dir"
274 if [ $status -eq 127 ] ; then
275 die
"test \"$f\" is not recognised"
278 if $exit_on_fail && [ $status -ne 0 ] ; then
284 export CTDB_TEST_MODE
="yes"
286 # Following 2 lines may be modified by installation script
287 CTDB_TESTS_ARE_INSTALLED
=false
288 CTDB_TEST_DIR
=$
(dirname "$0")
289 export CTDB_TESTS_ARE_INSTALLED CTDB_TEST_DIR
291 if [ -z "$test_state_dir" ] ; then
292 if $CTDB_TESTS_ARE_INSTALLED ; then
293 test_state_dir
=$
(mktemp
-d)
295 test_state_dir
="${CTDB_TEST_DIR}/var"
298 mkdir
-p "$test_state_dir"
300 summary_file
="${test_state_dir}/.summary"
303 export TEST_SCRIPTS_DIR
="${CTDB_TEST_DIR}/scripts"
316 # If no tests specified then run some defaults
317 if [ -z "$1" ] ; then
318 if [ -n "$TEST_LOCAL_DAEMONS" ] ; then
321 set -- simple complex
327 if $TEST_CLEANUP ; then
328 echo "Removing test state directory: ${test_state_dir}"
329 rm -rf "$test_state_dir"
331 echo "Not cleaning up test state directory: ${test_state_dir}"
335 trap "do_cleanup ; exit 130" SIGINT
336 trap "do_cleanup ; exit 143" SIGTERM
341 if [ "$f" = "UNIT" ] ; then
342 for t
in $unit_tests ; do
351 # Special case: -I 0 means iterate forever (until failure)
352 while [ "$max_iterations" -eq 0 ] ||
[ $iterations -lt "$max_iterations" ] ; do
353 iterations
=$
((iterations
+ 1))
355 if [ "$max_iterations" -ne 1 ] ; then
357 echo "##################################################"
358 echo "ITERATION ${iterations}"
359 echo "##################################################"
363 run_tests
"${tests[@]}"
366 if [ $status -ne 0 ] ; then
371 if $with_summary ; then
372 if [ $status -eq 0 ] ||
! $exit_on_fail ; then
376 echo "${tests_passed}/${tests_total} tests passed"
379 rm -f "$summary_file"
385 if $no_header ||
$exit_on_fail ; then
387 elif [ $tests_failed -gt 0 ] ; then