Blame test/run-test.sh

Packit 130fc8
#! /bin/bash
Packit 130fc8
Packit 130fc8
# Copyright (C) 2006 Red Hat Inc. <http://www.redhat.com/>
Packit 130fc8
# Copyright (C) 2006-2007 Collabora Ltd. <http://www.collabora.co.uk/>
Packit 130fc8
#
Packit 130fc8
# Permission is hereby granted, free of charge, to any person
Packit 130fc8
# obtaining a copy of this software and associated documentation
Packit 130fc8
# files (the "Software"), to deal in the Software without
Packit 130fc8
# restriction, including without limitation the rights to use, copy,
Packit 130fc8
# modify, merge, publish, distribute, sublicense, and/or sell copies
Packit 130fc8
# of the Software, and to permit persons to whom the Software is
Packit 130fc8
# furnished to do so, subject to the following conditions:
Packit 130fc8
#
Packit 130fc8
# The above copyright notice and this permission notice shall be
Packit 130fc8
# included in all copies or substantial portions of the Software.
Packit 130fc8
#
Packit 130fc8
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
Packit 130fc8
# EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
Packit 130fc8
# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
Packit 130fc8
# NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
Packit 130fc8
# HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
Packit 130fc8
# WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
Packit 130fc8
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
Packit 130fc8
# DEALINGS IN THE SOFTWARE.
Packit 130fc8
Packit 130fc8
set -e
Packit 130fc8
Packit 130fc8
failed=
Packit 130fc8
skipped=
Packit 130fc8
Packit 130fc8
echo "DBUS_TOP_SRCDIR=$DBUS_TOP_SRCDIR"
Packit 130fc8
echo "DBUS_TOP_BUILDDIR=$DBUS_TOP_BUILDDIR"
Packit 130fc8
echo "PYTHONPATH=$PYTHONPATH"
Packit 130fc8
echo "PYTHON=${PYTHON:=python}"
Packit 130fc8
Packit 130fc8
if ! [ -d "$DBUS_TEST_TMPDIR" ]; then
Packit 130fc8
  DBUS_TEST_TMPDIR="$(mktemp -d)"
Packit 130fc8
  if ! [ -d "$DBUS_TEST_TMPDIR" ]; then
Packit 130fc8
    echo "failed to create temporary directory (install mktemp?)" >&2
Packit 130fc8
    exit 1
Packit 130fc8
  fi
Packit 130fc8
fi
Packit 130fc8
Packit 130fc8
if ! "$PYTHON" -c 'from gi.repository import GLib'; then
Packit 130fc8
  echo "could not import python-gi"
Packit 130fc8
  exit 77
Packit 130fc8
fi
Packit 130fc8
Packit 130fc8
dbus-monitor > "$DBUS_TEST_TMPDIR"/monitor.log &
Packit 130fc8
Packit 130fc8
#echo "running the examples"
Packit 130fc8
Packit 130fc8
#$PYTHON "$DBUS_TOP_SRCDIR"/examples/example-service.py &
Packit 130fc8
#$PYTHON "$DBUS_TOP_SRCDIR"/examples/example-signal-emitter.py &
Packit 130fc8
#$PYTHON "$DBUS_TOP_SRCDIR"/examples/list-system-services.py --session ||
Packit 130fc8
#  die "list-system-services.py --session failed!"
Packit 130fc8
#$PYTHON "$DBUS_TOP_SRCDIR"/examples/example-async-client.py ||
Packit 130fc8
#  die "example-async-client failed!"
Packit 130fc8
#$PYTHON "$DBUS_TOP_SRCDIR"/examples/example-client.py --exit-service ||
Packit 130fc8
#  die "example-client failed!"
Packit 130fc8
#$PYTHON "$DBUS_TOP_SRCDIR"/examples/example-signal-recipient.py --exit-service ||
Packit 130fc8
#  die "example-signal-recipient failed!"
Packit 130fc8
Packit 130fc8
echo "running cross-test (for better diagnostics use mjj29's dbus-test)"
Packit 130fc8
Packit 130fc8
$PYTHON "$DBUS_TOP_SRCDIR"/test/cross-test-server.py > "$DBUS_TEST_TMPDIR"/cross-server.log &
Packit 130fc8
cross_test_server_pid="$!"
Packit 130fc8
Packit 130fc8
$PYTHON "$DBUS_TOP_SRCDIR"/test/wait-for-name.py org.freedesktop.DBus.Binding.TestServer
Packit 130fc8
Packit 130fc8
e=0
Packit 130fc8
$PYTHON "$DBUS_TOP_SRCDIR"/test/cross-test-client.py > "$DBUS_TEST_TMPDIR"/cross-client.log || e=$?
Packit 130fc8
echo "test-client exit status: $e"
Packit 130fc8
Packit 130fc8
if test "$e" = 77; then
Packit 130fc8
  echo "cross-test-client exited $e, marking as skipped"
Packit 130fc8
  skipped=yes
Packit 130fc8
elif grep . "$DBUS_TEST_TMPDIR"/cross-client.log >/dev/null; then
Packit 130fc8
  echo "OK, cross-test-client produced some output"
Packit 130fc8
else
Packit 130fc8
  echo "cross-test-client produced no output" >&2
Packit 130fc8
  failed=yes
Packit 130fc8
fi
Packit 130fc8
Packit 130fc8
if test "$e" = 77; then
Packit 130fc8
  echo "test-client exited $e, marking as skipped"
Packit 130fc8
  skipped=yes
Packit 130fc8
elif grep . "$DBUS_TEST_TMPDIR"/cross-server.log >/dev/null; then
Packit 130fc8
  echo "OK, cross-test-server produced some output"
Packit 130fc8
else
Packit 130fc8
  echo "cross-test-server produced no output" >&2
Packit 130fc8
  failed=yes
Packit 130fc8
fi
Packit 130fc8
Packit 130fc8
if grep fail "$DBUS_TEST_TMPDIR"/cross-client.log; then
Packit 130fc8
  failed=yes
Packit 130fc8
else
Packit 130fc8
  echo "  - cross-test client reported no failures"
Packit 130fc8
fi
Packit 130fc8
Packit 130fc8
if grep untested "$DBUS_TEST_TMPDIR"/cross-server.log; then
Packit 130fc8
  failed=yes
Packit 130fc8
else
Packit 130fc8
  echo "  - cross-test server reported no untested functions"
Packit 130fc8
fi
Packit 130fc8
Packit 130fc8
echo "waiting for cross-test server to exit"
Packit 130fc8
if wait "$cross_test_server_pid"; then
Packit 130fc8
  echo "cross-test server: exit status 0"
Packit 130fc8
else
Packit 130fc8
  echo "cross-test server: exit status $?"
Packit 130fc8
  failed=yes
Packit 130fc8
fi
Packit 130fc8
Packit 130fc8
echo "==== client log ===="
Packit 130fc8
cat "$DBUS_TEST_TMPDIR"/cross-client.log
Packit 130fc8
echo "==== end ===="
Packit 130fc8
Packit 130fc8
echo "==== server log ===="
Packit 130fc8
cat "$DBUS_TEST_TMPDIR"/cross-server.log
Packit 130fc8
echo "==== end ===="
Packit 130fc8
Packit 130fc8
rm -f "$DBUS_TEST_TMPDIR"/test-service.log
Packit 130fc8
rm -f "$DBUS_TEST_TMPDIR"/cross-client.log
Packit 130fc8
rm -f "$DBUS_TEST_TMPDIR"/cross-server.log
Packit 130fc8
rm -f "$DBUS_TEST_TMPDIR"/monitor.log
Packit 130fc8
Packit 130fc8
if test -n "$skipped"; then
Packit 130fc8
  exit 77
Packit 130fc8
fi
Packit 130fc8
if test -n "$failed"; then
Packit 130fc8
  exit 1
Packit 130fc8
fi
Packit 130fc8
exit 0