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
|