summaryrefslogtreecommitdiff
path: root/cpp/src/tests/run_test
blob: 0f59509dab6db79b40cf05e3508cd69cd5fa8fdb (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
#!/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.
#

source `dirname $0`/vg_check


# Export variables from makefile.
export VALGRIND srcdir

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

# Avoid silly libtool error messages if these are not defined
test -z "$LC_ALL" && export LC_ALL=
test -z "$LC_CTYPE" && export LC_CTYPE=
test -z "$LC_COLLATE" && export LC_COLLATE=
test -z "$LC_MESSAGES" && export LC_MESSAGES=

VG_LOG="$1.vglog"
rm -f $VG_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 "$@" 2>&1 || ERROR=$?
    test -n "$VALGRIND" && vg_check
else
    # This is a non-libtool shell script, just execute it.
    export VALGRIND srcdir
    exec "$@"
fi

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