fi
fi
AS_IF([test "$with_valgrind" != "no"],
- AC_SUBST(VALGRIND_RULES, 'LOG_COMPILER = "$(top_srcdir)/tools/run-test-valgrind.sh" "$(LIBTOOL)" "$(with_valgrind)" '"$with_valgrind_suppressions"),
+ AC_SUBST(VALGRIND_RULES, 'LOG_COMPILER = "$(top_srcdir)/tools/run-test-valgrind.sh" --called-from-make "$(LIBTOOL)" "$(with_valgrind)" '"$with_valgrind_suppressions"),
AC_SUBST(VALGRIND_RULES, []))
AM_CONDITIONAL(WITH_VALGRIND, test "${with_valgrind}" != "no")
-#!/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
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 \
--suppressions="$SUPPRESSIONS" \
--num-callers=100 \
--log-file="$LOGFILE" \
+ "$TEST" \
"$@"
RESULT=$?