mirror of
https://gitlab.freedesktop.org/dbus/dbus.git
synced 2026-01-03 13:50:16 +01:00
These tests are very reliant on their custom LOG_COMPILER, which AX_VALGRIND_CHECK replaces. Signed-off-by: Simon McVittie <smcv@collabora.com> Reviewed-by: Philip Withnall <withnall@endlessm.com> Bug: https://bugs.freedesktop.org/show_bug.cgi?id=107194
141 lines
3.7 KiB
C
141 lines
3.7 KiB
C
#include <config.h>
|
|
#include <dbus/dbus-valgrind-internal.h>
|
|
#include "../test-utils.h"
|
|
|
|
static void die (const char *message,
|
|
...) _DBUS_GNUC_NORETURN _DBUS_GNUC_PRINTF (1, 2);
|
|
|
|
static void
|
|
die (const char *message, ...)
|
|
{
|
|
va_list args;
|
|
va_start (args, message);
|
|
vfprintf (stderr, message, args);
|
|
va_end (args);
|
|
exit (1);
|
|
}
|
|
|
|
typedef struct TestServiceData TestServiceData;
|
|
|
|
struct TestServiceData
|
|
{
|
|
DBusLoop *loop;
|
|
char *private_addr;
|
|
};
|
|
|
|
static void
|
|
new_connection_callback (DBusServer *server,
|
|
DBusConnection *new_connection,
|
|
void *data)
|
|
{
|
|
TestServiceData *testdata = data;
|
|
|
|
if (!test_connection_try_setup (testdata->loop, new_connection))
|
|
dbus_connection_close (new_connection);
|
|
}
|
|
|
|
static DBusHandlerResult
|
|
filter_session_message (DBusConnection *connection,
|
|
DBusMessage *message,
|
|
void *user_data)
|
|
{
|
|
TestServiceData *testdata = user_data;
|
|
|
|
if (dbus_message_is_method_call (message,
|
|
"org.freedesktop.DBus.TestSuite.PrivServer",
|
|
"GetPrivateAddress"))
|
|
{
|
|
DBusMessage *reply;
|
|
|
|
reply = dbus_message_new_method_return (message);
|
|
if (reply == NULL)
|
|
die ("OOM");
|
|
if (!dbus_message_append_args (reply, DBUS_TYPE_STRING,
|
|
&(testdata->private_addr),
|
|
DBUS_TYPE_INVALID))
|
|
die ("OOM");
|
|
|
|
if (!dbus_connection_send (connection, reply, NULL))
|
|
die ("Error sending message");
|
|
|
|
dbus_message_unref (reply);
|
|
|
|
return DBUS_HANDLER_RESULT_HANDLED;
|
|
}
|
|
else if (dbus_message_is_method_call (message,
|
|
"org.freedesktop.DBus.TestSuite.PrivServer",
|
|
"Quit"))
|
|
{
|
|
fprintf (stderr, "server exiting loop\n");
|
|
_dbus_loop_quit (testdata->loop);
|
|
return DBUS_HANDLER_RESULT_HANDLED;
|
|
}
|
|
return DBUS_HANDLER_RESULT_NOT_YET_HANDLED;
|
|
}
|
|
|
|
int
|
|
main (int argc, char *argv[])
|
|
{
|
|
DBusServer *server;
|
|
DBusError error;
|
|
DBusLoop *loop;
|
|
DBusConnection *session;
|
|
TestServiceData *testdata;
|
|
|
|
if (RUNNING_ON_VALGRIND)
|
|
{
|
|
printf ("1..0 # SKIP Not ready to run under valgrind yet\n");
|
|
return 0;
|
|
}
|
|
|
|
dbus_error_init (&error);
|
|
|
|
loop = _dbus_loop_new ();
|
|
|
|
testdata = dbus_new (TestServiceData, 1);
|
|
testdata->loop = loop;
|
|
|
|
session = dbus_bus_get (DBUS_BUS_SESSION, &error);
|
|
if (!session)
|
|
die ("couldn't access session bus");
|
|
|
|
test_connection_setup (loop, session);
|
|
|
|
dbus_bus_request_name (session, "org.freedesktop.DBus.TestSuite.PrivServer", 0, &error);
|
|
if (dbus_error_is_set (&error))
|
|
die ("couldn't request name: %s", error.message);
|
|
|
|
if (!dbus_connection_add_filter (session, filter_session_message, testdata, NULL))
|
|
die ("couldn't add filter");
|
|
|
|
#ifdef DBUS_CMAKE
|
|
server = dbus_server_listen (TEST_LISTEN, &error);
|
|
#else
|
|
server = dbus_server_listen ("unix:tmpdir=/tmp", &error);
|
|
#endif
|
|
if (!server)
|
|
die ("%s", error.message);
|
|
testdata->private_addr = dbus_server_get_address (server);
|
|
fprintf (stderr, "test server listening on %s\n", testdata->private_addr);
|
|
|
|
dbus_server_set_new_connection_function (server, new_connection_callback,
|
|
testdata, NULL);
|
|
|
|
test_server_setup (loop, server);
|
|
|
|
fprintf (stderr, "server running mainloop\n");
|
|
_dbus_loop_run (loop);
|
|
fprintf (stderr, "server mainloop quit\n");
|
|
|
|
test_server_shutdown (loop, server);
|
|
|
|
test_connection_shutdown (loop, session);
|
|
|
|
dbus_connection_unref (session);
|
|
|
|
_dbus_loop_unref (loop);
|
|
|
|
dbus_free (testdata);
|
|
|
|
return 0;
|
|
}
|