Update contrib.
1 /* Portion Copyright © 2008 Nokia Corporation and/or its subsidiary(-ies). All rights reserved.*/
2 #include "test-utils.h"
5 static dbus_bool_t already_quit = FALSE;
6 static dbus_bool_t hello_from_self_reply_received = FALSE;
13 _dbus_loop_quit (loop);
19 die (const char *message)
21 fprintf (stderr, "*** test-service: %s", message);
26 check_hello_from_self_reply (DBusPendingCall *pcall,
30 DBusMessage *echo_message, *echo_reply = NULL;
32 DBusConnection *connection;
36 dbus_error_init (&error);
38 connection = dbus_bus_get (DBUS_BUS_STARTER, &error);
39 if (connection == NULL)
41 fprintf (stderr, "*** Failed to open connection to activating message bus: %s\n",
43 dbus_error_free (&error);
48 echo_message = (DBusMessage *)user_data;
50 reply = dbus_pending_call_steal_reply (pcall);
52 type = dbus_message_get_type (reply);
54 if (type == DBUS_MESSAGE_TYPE_METHOD_RETURN)
57 printf ("Reply from HelloFromSelf received\n");
59 if (!dbus_message_get_args (echo_message,
64 echo_reply = dbus_message_new_error (echo_message,
68 if (echo_reply == NULL)
74 echo_reply = dbus_message_new_method_return (echo_message);
75 if (echo_reply == NULL)
78 if (!dbus_message_append_args (echo_reply,
84 if (!dbus_connection_send (connection, echo_reply, NULL))
87 dbus_message_unref (echo_reply);
89 else if (type == DBUS_MESSAGE_TYPE_ERROR)
91 dbus_set_error_from_message (&error, reply);
92 printf ("Error type in reply: %s\n", error.message);
94 if (strcmp (error.name, DBUS_ERROR_NO_MEMORY) != 0)
96 echo_reply = dbus_message_new_error (echo_reply,
100 if (echo_reply == NULL)
103 if (!dbus_connection_send (connection, echo_reply, NULL))
106 dbus_message_unref (echo_reply);
108 dbus_error_free (&error);
111 _dbus_assert_not_reached ("Unexpected message received\n");
113 hello_from_self_reply_received = TRUE;
115 dbus_message_unref (reply);
116 dbus_message_unref (echo_message);
117 dbus_pending_call_unref (pcall);
118 dbus_connection_unref (connection);
121 static DBusHandlerResult
122 handle_run_hello_from_self (DBusConnection *connection,
123 DBusMessage *message)
126 DBusMessage *reply, *self_message;
127 DBusPendingCall *pcall;
130 _dbus_verbose ("sending reply to Echo method\n");
132 dbus_error_init (&error);
134 if (!dbus_message_get_args (message,
136 DBUS_TYPE_STRING, &s,
139 reply = dbus_message_new_error (message,
146 if (!dbus_connection_send (connection, reply, NULL))
149 dbus_message_unref (reply);
151 return DBUS_HANDLER_RESULT_NOT_YET_HANDLED;
153 printf ("Sending HelloFromSelf\n");
155 _dbus_verbose ("*** Sending message to self\n");
156 self_message = dbus_message_new_method_call ("org.freedesktop.DBus.TestSuiteEchoService",
157 "/org/freedesktop/TestSuite",
158 "org.freedesktop.TestSuite",
161 if (self_message == NULL)
164 if (!dbus_connection_send_with_reply (connection, self_message, &pcall, -1))
167 dbus_message_ref (message);
168 if (!dbus_pending_call_set_notify (pcall, check_hello_from_self_reply, (void *)message, NULL))
171 printf ("Sent HelloFromSelf\n");
172 return DBUS_HANDLER_RESULT_HANDLED;
175 static DBusHandlerResult
176 handle_echo (DBusConnection *connection,
177 DBusMessage *message)
183 _dbus_verbose ("sending reply to Echo method\n");
185 dbus_error_init (&error);
187 if (!dbus_message_get_args (message,
189 DBUS_TYPE_STRING, &s,
192 reply = dbus_message_new_error (message,
199 if (!dbus_connection_send (connection, reply, NULL))
202 dbus_message_unref (reply);
204 return DBUS_HANDLER_RESULT_NOT_YET_HANDLED;
207 reply = dbus_message_new_method_return (message);
211 if (!dbus_message_append_args (reply,
212 DBUS_TYPE_STRING, &s,
216 if (!dbus_connection_send (connection, reply, NULL))
219 fprintf (stderr, "Echo service echoed string: \"%s\"\n", s);
221 dbus_message_unref (reply);
223 return DBUS_HANDLER_RESULT_HANDLED;
227 path_unregistered_func (DBusConnection *connection,
230 /* connection was finalized */
233 static DBusHandlerResult
234 path_message_func (DBusConnection *connection,
235 DBusMessage *message,
238 if (dbus_message_is_method_call (message,
239 "org.freedesktop.TestSuite",
241 return handle_echo (connection, message);
242 else if (dbus_message_is_method_call (message,
243 "org.freedesktop.TestSuite",
247 return DBUS_HANDLER_RESULT_HANDLED;
249 else if (dbus_message_is_method_call (message,
250 "org.freedesktop.TestSuite",
253 /* Emit the Foo signal */
257 _dbus_verbose ("emitting signal Foo\n");
259 signal = dbus_message_new_signal ("/org/freedesktop/TestSuite",
260 "org.freedesktop.TestSuite",
266 if (!dbus_message_append_args (signal,
267 DBUS_TYPE_DOUBLE, &v_DOUBLE,
271 if (!dbus_connection_send (connection, signal, NULL))
274 return DBUS_HANDLER_RESULT_HANDLED;
277 else if (dbus_message_is_method_call (message,
278 "org.freedesktop.TestSuite",
281 return handle_run_hello_from_self (connection, message);
283 else if (dbus_message_is_method_call (message,
284 "org.freedesktop.TestSuite",
288 printf ("Received the HelloFromSelf message\n");
290 reply = dbus_message_new_method_return (message);
294 if (!dbus_connection_send (connection, reply, NULL))
297 return DBUS_HANDLER_RESULT_HANDLED;
300 return DBUS_HANDLER_RESULT_NOT_YET_HANDLED;
303 static DBusObjectPathVTable
305 path_unregistered_func,
311 static const char* echo_path = "/org/freedesktop/TestSuite" ;
313 static DBusHandlerResult
314 filter_func (DBusConnection *connection,
315 DBusMessage *message,
318 if (dbus_message_is_signal (message,
319 DBUS_INTERFACE_LOCAL,
323 return DBUS_HANDLER_RESULT_HANDLED;
327 return DBUS_HANDLER_RESULT_NOT_YET_HANDLED;
335 int result,bus_get = 1;
336 DBusConnection *connection;
338 dbus_error_init (&error);
339 connection = dbus_bus_get(DBUS_BUS_SESSION, &error);
340 if(connection == NULL)
343 dbus_error_free(&error);
344 /*test-service.exe spawned by dbus_daemon_tets_main was returning NULL for dbus_bus_get(), work around for this is to use below API */
345 connection = dbus_connection_open_private ("tcp:host=localhost,port=12436", &error);
348 if (connection == NULL)
350 fprintf (stderr, "*** Failed to open connection to activating message bus: %s\n",
352 dbus_error_free (&error);
359 if (!dbus_bus_register (connection, &error))
362 //_dbus_connection_close_possibly_shared (connection);
363 dbus_connection_unref (connection);
367 loop = _dbus_loop_new ();
371 if (!test_connection_setup (loop, connection))
374 if (!dbus_connection_add_filter (connection,
375 filter_func, NULL, NULL))
378 if (!dbus_connection_register_object_path (connection,
386 if (!dbus_connection_get_object_path_data (connection, echo_path, &d))
388 if (d != (void*) 0xdeadbeef)
389 die ("dbus_connection_get_object_path_data() doesn't seem to work right\n");
392 result = dbus_bus_request_name (connection, "org.freedesktop.DBus.TestSuiteEchoService",
394 if (dbus_error_is_set (&error))
396 fprintf (stderr, "Error %s\n", error.message);
397 _dbus_verbose ("*** Failed to acquire service: %s\n",
399 dbus_error_free (&error);
403 _dbus_verbose ("*** Test service entering main loop\n");
404 _dbus_loop_run (loop);
406 test_connection_shutdown (loop, connection);
408 dbus_connection_remove_filter (connection, filter_func, NULL);
411 dbus_connection_close(connection);
413 dbus_connection_unref (connection);
415 _dbus_loop_unref (loop);
421 _dbus_verbose ("*** Test service exiting\n");