summaryrefslogtreecommitdiff
path: root/qpid/cpp/src/tests/run_test
blob: deb22b44503d881dc68a69a903947ef90438c1dd (plain)
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
#!/bin/sh
#
# Set up environment and run a test executable or script.
#
# Output nothing if test passes, show the output if it fails and
# leave output in <test>.log for examination.  
#
# If qpidd.port exists run test with QPID_PORT=`cat qpidd.port`
# 
# If $VALGRIND if is set run under valgrind. If there are valgrind
# erros show valgrind output, also leave it in <test>.valgrind for
# examination.
#

vg_failed() {
    cat $VG_LOG 1>&2
    echo $1 1>&2
    exit 1
}

vg_check()
{
    test -f $VG_LOG || vg_failed Valgrind log file $VG_LOG missing.
    # Ensure there is an ERROR SUMMARY line.
    grep -E '^==[0-9]+== ERROR SUMMARY:' $VG_LOG > /dev/null || \
	vg_failed "No valgrind ERROR SUMMARY line in $$vg_failed."
    # Ensure that the number of errors is 0.
    grep -E '^==[0-9]+== ERROR SUMMARY: [^0]' $VG_LOG > /dev/null && \
	vg_failed "Valgrind reported errors in $vg_out; see above." 
    # Check for leaks.
    grep -E '^==[0-9]+== +.* lost: [^0]' $VG_LOG && \
	vg_failed "Found memory leaks (see log file, $VG_LOG); see above."
    true
}

# Export variables from makefile.
export VALGRIND srcdir

# Export QPID_PORT if qpidd.port exists.
test -f qpidd.port && export QPID_PORT=`cat qpidd.port`

VG_LOG="$1.vglog"
TEST_LOG="$1.log"
rm -f $VG_LOG $TEST_LOG

if grep -l "^# Generated by .*libtool" "$1" >/dev/null 2>&1; then
    # This is a libtool "executable". Valgrind it if VALGRIND specified.
    test -n "$VALGRIND" && VALGRIND="$VALGRIND --log-file-exactly=$VG_LOG --"
    # Hide output unless there's an error.
    libtool --mode=execute "$VALGRIND" "$@" >$TEST_LOG 2>&1 || {
	ERROR=$?
	cat $TEST_LOG  
    }
    test -n "$VALGRIND" && vg_check
else
    # This is a non-libtool shell script, just execute it.
    exec "$@"
fi

if test -z "$ERROR"; then
    # Clean up logs if there was no error.
    rm -f $VG_LOG $TEST_LOG
    exit 0
else
    exit $ERROR
fi