summaryrefslogtreecommitdiff
path: root/tools/run-test-valgrind.sh
diff options
context:
space:
mode:
Diffstat (limited to 'tools/run-test-valgrind.sh')
-rwxr-xr-xtools/run-test-valgrind.sh93
1 files changed, 84 insertions, 9 deletions
diff --git a/tools/run-test-valgrind.sh b/tools/run-test-valgrind.sh
index ff5bc44ce3..424f633d06 100755
--- a/tools/run-test-valgrind.sh
+++ b/tools/run-test-valgrind.sh
@@ -1,19 +1,93 @@
-#!/bin/sh
+#!/bin/bash
+
+die() {
+ echo "$@"
+ exit 5
+}
+
+SCRIPT_PATH="${SCRIPT_PATH:-$(readlink -f "$(dirname "$0")")}"
-LIBTOOL="$1"; shift
-VALGRIND="$1"; shift
-SUPPRESSIONS="$1"; shift
VALGRIND_ERROR=37
-if [ "$1" = "--launch-dbus" ]; then
+if [ "$1" == "--called-from-make" ]; then
+ shift
+ NMTST_LIBTOOL=($1 --mode=execute); shift
+ NMTST_VALGRIND="$1"; shift
+ SUPPRESSIONS="$1"; shift
+ if [ "$1" = "--launch-dbus" ]; then
+ NMTST_LAUNCH_DBUS=yes
+ shift
+ else
+ NMTST_LAUNCH_DBUS=no
+ fi
+ TEST="$1"; shift
+else
+ if [ -n "${NMTST_LIBTOOL-:x}" ]; then
+ NMTST_LIBTOOL=(sh "$SCRIPT_PATH/../libtool" --mode=execute)
+ elif [ -n "${NMTST_LIBTOOL-x}" ]; then
+ NMTST_LIBTOOL=()
+ else
+ NMTST_LIBTOOL=($NMTST_LIBTOOL --mode=execute)
+ fi
+ for a in "$@"; do
+ case "$a" in
+ "--launch-dbus")
+ NMTST_LAUNCH_DBUS=yes
+ shift
+ ;;
+ "--no-launch-dbus"|"-D")
+ NMTST_LAUNCH_DBUS=no
+ shift
+ ;;
+ "--no-libtool")
+ NMTST_LIBTOOL=()
+ shift
+ ;;
+ "--")
+ shift
+ break
+ ;;
+ *)
+ break
+ ;;
+ esac
+ done
+ # we support calling the script directly. In this case,
+ # only pass the path to the test to run.
+ TEST="$1"; shift
+ NMTST_VALGRIND="${NMTST_VALGRIND:-valgrind}"
+ if [ "$SUPPRESSIONS" == "" ]; then
+ SUPPRESSIONS="$SCRIPT_PATH/../valgrind.suppressions"
+ fi
+
+ [ -x "$TEST" ] || die "Test \"$TEST\" does not exist"
+
+ TEST_PATH="$(readlink -f "$(dirname "$TEST")")"
+
+ if [ -n "${NMTST_LAUNCH_DBUS-x}" ]; then
+ # autodetect whether to launch D-Bus based on the test path.
+ if [[ $TEST_PATH == */libnm/tests || $TEST_PATH == */libnm-glib/tests ]]; then
+ NMTST_LAUNCH_DBUS=yes
+ else
+ NMTST_LAUNCH_DBUS=no
+ fi
+ fi
+
+ # some tests require you to cd into the base directory.
+ # do that.
+ if [ "$NMTST_VALGRIND_NO_CD" == "" ]; then
+ cd "$TEST_PATH"
+ TEST="./$(basename "$TEST")"
+ fi
+fi
+
+if [ "$NMTST_LAUNCH_DBUS" == "yes" ]; then
# Spawn DBus
eval `dbus-launch --sh-syntax`
trap "kill $DBUS_SESSION_BUS_PID" EXIT
- shift
fi
-TEST="$1"
if [ "$NMTST_NO_VALGRIND" != "" ]; then
- "$@"
+ "$TEST" "$@"
exit $?
fi
@@ -21,7 +95,7 @@ LOGFILE="valgrind-`echo "$TEST" | tr -cd '[:alpha:]-'`.log"
export G_SLICE=always-malloc
export G_DEBUG=gc-friendly
-$LIBTOOL --mode=execute "$VALGRIND" \
+"${NMTST_LIBTOOL[@]}" "$NMTST_VALGRIND" \
--quiet \
--error-exitcode=$VALGRIND_ERROR \
--leak-check=full \
@@ -29,6 +103,7 @@ $LIBTOOL --mode=execute "$VALGRIND" \
--suppressions="$SUPPRESSIONS" \
--num-callers=100 \
--log-file="$LOGFILE" \
+ "$TEST" \
"$@"
RESULT=$?