index 7bba1515361f804e8444ed717485e87a210841b3..8206ddfd5d21bad444dbf3a40b395556ebd59a02 100644 (file)
TOP_SRCDIR="$( readlink -f "$( dirname "$0" )/../.." )"
TESTDIR="$( mktemp -d )"
-trap "rm -rf '$TESTDIR'" EXIT
+trap "rm -rf '$TESTDIR'; test -z \$SYSDBD_PID || kill \$SYSDBD_PID" EXIT
mkdir "$TESTDIR/backend"
cp "$TOP_SRCDIR/t/integration/.libs/mock_plugin.so" "$TESTDIR/backend"
-cp "$TOP_SRCDIR"/src/.libs/sysdb "$TESTDIR"
-cp "$TOP_SRCDIR"/src/.libs/sysdbd "$TESTDIR"
-cp "$TOP_SRCDIR"/src/.libs/libsysdb*.so* "$TESTDIR"
+cp "$TOP_SRCDIR"/src/sysdb "$TESTDIR"
+cp "$TOP_SRCDIR"/src/sysdbd "$TESTDIR"
MEMCHECK="valgrind --quiet --tool=memcheck --error-exitcode=1"
MEMCHECK="$MEMCHECK --trace-children=yes"
MEMCHECK="$MEMCHECK --track-fds=yes"
MEMCHECK="$MEMCHECK --leak-check=full"
+MEMCHECK="$MEMCHECK --suppressions=$TOP_SRCDIR/t/valgrind.suppress"
+MEMCHECK="$MEMCHECK --gen-suppressions=all"
SYSDBD_CONF="$TESTDIR/sysdbd.conf"
SOCKET_FILE="$TESTDIR/sock"
PLUGIN_DIR="$TESTDIR"
+SYSDB_USER="$( id -un )"
+
function run_sysdb() {
- LD_PRELOAD=$TESTDIR/libsysdbclient.so $MEMCHECK \
- "$TESTDIR/sysdb" -U mockuser "$@"
+ $MEMCHECK "$TESTDIR/sysdb" -U $SYSDB_USER "$@"
+}
+
+function run_sysdb_nouser() {
+ $MEMCHECK "$TESTDIR/sysdb" "$@"
}
function run_sysdbd() {
- LD_PRELOAD=$TESTDIR/libsysdb.so $MEMCHECK "$TESTDIR/sysdbd" "$@"
+ $MEMCHECK "$TESTDIR/sysdbd" "$@" &
+ SYSDBD_PID=$!
+}
+
+function run_sysdbd_foreground() {
+ $MEMCHECK "$TESTDIR/sysdbd" "$@"
+}
+
+function stop_sysdbd() {
+ if test -z "$SYSDBD_PID"; then
+ echo "Cannot stop sysdbd; PID unknown" >&2
+ exit 1
+ fi
+ kill $SYSDBD_PID
+ wait $SYSDBD_PID
+ SYSDBD_PID=''
}
function wait_for_sysdbd() {
+ local socket="$SOCKET_FILE"
local i
for (( i=0; i<10; i++ )); do
- if test -e "$SOCKET_FILE"; then
+ if test -e "$socket"; then
break
fi
sleep 1
fi
}
+# vim: set tw=78 sw=4 ts=4 noexpandtab :