summaryrefslogtreecommitdiff
path: root/qpid/cpp/src/tests/run_test
blob: 6ec1fd892bf793110f74a8b3773266ad7adbbccd (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
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
#!/bin/bash

# Licensed to the Apache Software Foundation (ASF) under one
# or more contributor license agreements.  See the NOTICE file
# distributed with this work for additional information
# regarding copyright ownership.  The ASF licenses this file
# to you under the Apache License, Version 2.0 (the
# "License"); you may not use this file except in compliance
# with the License.  You may obtain a copy of the License at
# 
#   http://www.apache.org/licenses/LICENSE-2.0
# 
# Unless required by applicable law or agreed to in writing,
# software distributed under the License is distributed on an
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
# KIND, either express or implied.  See the License for the
# specific language governing permissions and limitations
# under the License.
#

#
# 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 and is not empty 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.
#

srcdir=`dirname $0`
source ./test_env.sh
source $srcdir/vg_check

# Export variables from makefile.
export srcdir

# Set QPID_PORT if qpidd.port exists.
test -s qpidd.port && QPID_PORT=`cat qpidd.port`
export QPID_PORT

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

VG_LOG="`basename $1`.vglog"
rm -f $VG_LOG*

# Use VALGRIND_OPTS="--gen-suppressions=all" to generated suppressions
VALGRIND_OPTS="$VALGRIND_OPTS
--leak-check=full
--demangle=yes
--suppressions=$srcdir/.valgrind.supp
--num-callers=25
--log-file=$VG_LOG --
"
ERROR=0
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 $VALGRIND_OPTS"
    # Hide output unless there's an error.
    $LIBTOOL --mode=execute $VALGRIND "$@" 2>&1 || ERROR=1
    test -n "$VALGRIND" && { vg_check $VG_LOG* || ERROR=1 ; }
elif file $1 | grep -q text; then
    # This is a non-libtool shell script, just execute it.
    exec "$@"
else
    # This is a real executable, valgrind it.
    test -n "$VALGRIND" && VALGRIND="$VALGRIND $VALGRIND_OPTS"
    # Hide output unless there's an error.
    $VALGRIND "$@" 2>&1 || ERROR=1
    test -n "$VALGRIND" && { vg_check $VG_LOG* || ERROR=1 ; }
fi

exit $ERROR