3 #include "test-utils.h"
9 static dbus_bool_t already_quit = FALSE;
10 static dbus_bool_t hello_from_self_reply_received = FALSE;
17 _dbus_loop_quit (loop);
22 static void die (const char *message) _DBUS_GNUC_NORETURN;
25 die (const char *message)
27 fprintf (stderr, "*** test-service: %s", message);
32 check_hello_from_self_reply (DBusPendingCall *pcall,
36 DBusMessage *echo_message, *echo_reply = NULL;
38 DBusConnection *connection;
42 dbus_error_init (&error);
44 connection = dbus_bus_get (DBUS_BUS_STARTER, &error);
45 if (connection == NULL)
47 fprintf (stderr, "*** Failed to open connection to activating message bus: %s\n",
49 dbus_error_free (&error);
54 echo_message = (DBusMessage *)user_data;
56 reply = dbus_pending_call_steal_reply (pcall);
58 type = dbus_message_get_type (reply);
60 if (type == DBUS_MESSAGE_TYPE_METHOD_RETURN)
63 printf ("Reply from HelloFromSelf received\n");
65 if (!dbus_message_get_args (echo_message,
70 echo_reply = dbus_message_new_error (echo_message,
74 if (echo_reply == NULL)
80 echo_reply = dbus_message_new_method_return (echo_message);
81 if (echo_reply == NULL)
84 if (!dbus_message_append_args (echo_reply,
90 if (!dbus_connection_send (connection, echo_reply, NULL))
93 dbus_message_unref (echo_reply);
95 else if (dbus_set_error_from_message (&error, reply))
97 printf ("Error type in reply: %s\n", error.message);
99 if (strcmp (error.name, DBUS_ERROR_NO_MEMORY) != 0)
101 echo_reply = dbus_message_new_error (echo_reply,
105 if (echo_reply == NULL)
108 if (!dbus_connection_send (connection, echo_reply, NULL))
111 dbus_message_unref (echo_reply);
113 dbus_error_free (&error);
116 _dbus_assert_not_reached ("Unexpected message received");
118 hello_from_self_reply_received = TRUE;
120 dbus_message_unref (reply);
121 dbus_message_unref (echo_message);
122 dbus_pending_call_unref (pcall);
123 dbus_connection_unref (connection);
126 static DBusHandlerResult
127 handle_run_hello_from_self (DBusConnection *connection,
128 DBusMessage *message)
131 DBusMessage *reply, *self_message;
132 DBusPendingCall *pcall;
135 _dbus_verbose ("sending reply to Echo method\n");
137 dbus_error_init (&error);
139 if (!dbus_message_get_args (message,
141 DBUS_TYPE_STRING, &s,
144 reply = dbus_message_new_error (message,
151 if (!dbus_connection_send (connection, reply, NULL))
154 dbus_message_unref (reply);
156 return DBUS_HANDLER_RESULT_NOT_YET_HANDLED;
158 printf ("Sending HelloFromSelf\n");
160 _dbus_verbose ("*** Sending message to self\n");
161 self_message = dbus_message_new_method_call ("org.freedesktop.DBus.TestSuiteEchoService",
162 "/org/freedesktop/TestSuite",
163 "org.freedesktop.TestSuite",
166 if (self_message == NULL)
169 if (!dbus_connection_send_with_reply (connection, self_message, &pcall, -1))
172 dbus_message_ref (message);
173 if (!dbus_pending_call_set_notify (pcall, check_hello_from_self_reply, (void *)message, NULL))
176 printf ("Sent HelloFromSelf\n");
177 return DBUS_HANDLER_RESULT_HANDLED;
180 static DBusHandlerResult
181 handle_echo (DBusConnection *connection,
182 DBusMessage *message)
188 _dbus_verbose ("sending reply to Echo method\n");
190 dbus_error_init (&error);
192 if (!dbus_message_get_args (message,
194 DBUS_TYPE_STRING, &s,
197 reply = dbus_message_new_error (message,
204 if (!dbus_connection_send (connection, reply, NULL))
207 dbus_message_unref (reply);
209 return DBUS_HANDLER_RESULT_NOT_YET_HANDLED;
212 reply = dbus_message_new_method_return (message);
216 if (!dbus_message_append_args (reply,
217 DBUS_TYPE_STRING, &s,
221 if (!dbus_connection_send (connection, reply, NULL))
224 fprintf (stderr, "Echo service echoed string: \"%s\"\n", s);
226 dbus_message_unref (reply);
228 return DBUS_HANDLER_RESULT_HANDLED;
231 static DBusHandlerResult
232 handle_delay_echo (DBusConnection *connection,
233 DBusMessage *message)
239 _dbus_verbose ("sleeping for a short time\n");
241 _dbus_sleep_milliseconds (50);
243 _dbus_verbose ("sending reply to DelayEcho method\n");
245 dbus_error_init (&error);
247 if (!dbus_message_get_args (message,
249 DBUS_TYPE_STRING, &s,
252 reply = dbus_message_new_error (message,
259 if (!dbus_connection_send (connection, reply, NULL))
262 dbus_message_unref (reply);
264 return DBUS_HANDLER_RESULT_NOT_YET_HANDLED;
267 reply = dbus_message_new_method_return (message);
271 if (!dbus_message_append_args (reply,
272 DBUS_TYPE_STRING, &s,
276 if (!dbus_connection_send (connection, reply, NULL))
279 fprintf (stderr, "DelayEcho service echoed string: \"%s\"\n", s);
281 dbus_message_unref (reply);
283 return DBUS_HANDLER_RESULT_HANDLED;
288 path_unregistered_func (DBusConnection *connection,
291 /* connection was finalized */
294 static DBusHandlerResult
295 path_message_func (DBusConnection *connection,
296 DBusMessage *message,
299 if (dbus_message_is_method_call (message,
300 "org.freedesktop.TestSuite",
302 return handle_echo (connection, message);
303 else if (dbus_message_is_method_call (message,
304 "org.freedesktop.TestSuite",
306 return handle_delay_echo (connection, message);
307 else if (dbus_message_is_method_call (message,
308 "org.freedesktop.TestSuite",
312 return DBUS_HANDLER_RESULT_HANDLED;
314 else if (dbus_message_is_method_call (message,
315 "org.freedesktop.TestSuite",
318 /* Emit the Foo signal */
322 _dbus_verbose ("emitting signal Foo\n");
324 signal = dbus_message_new_signal ("/org/freedesktop/TestSuite",
325 "org.freedesktop.TestSuite",
331 if (!dbus_message_append_args (signal,
332 DBUS_TYPE_DOUBLE, &v_DOUBLE,
336 if (!dbus_connection_send (connection, signal, NULL))
339 return DBUS_HANDLER_RESULT_HANDLED;
342 else if (dbus_message_is_method_call (message,
343 "org.freedesktop.TestSuite",
346 return handle_run_hello_from_self (connection, message);
348 else if (dbus_message_is_method_call (message,
349 "org.freedesktop.TestSuite",
353 printf ("Received the HelloFromSelf message\n");
355 reply = dbus_message_new_method_return (message);
359 if (!dbus_connection_send (connection, reply, NULL))
362 return DBUS_HANDLER_RESULT_HANDLED;
365 return DBUS_HANDLER_RESULT_NOT_YET_HANDLED;
368 static DBusObjectPathVTable
370 path_unregistered_func,
376 static const char* echo_path = "/org/freedesktop/TestSuite" ;
378 static DBusHandlerResult
379 filter_func (DBusConnection *connection,
380 DBusMessage *message,
383 if (dbus_message_is_signal (message,
384 DBUS_INTERFACE_LOCAL,
388 return DBUS_HANDLER_RESULT_HANDLED;
392 return DBUS_HANDLER_RESULT_NOT_YET_HANDLED;
402 DBusConnection *connection;
405 dbus_bool_t do_fork = FALSE;
409 name = "org.freedesktop.DBus.TestSuiteEchoService";
415 do_fork = strcmp (argv[2], "fork") == 0;
419 /* The bare minimum for simulating a program "daemonizing"; the intent
420 * is to test services which move from being legacy init scripts to
421 * activated services.
422 * https://bugzilla.redhat.com/show_bug.cgi?id=545267
434 dbus_error_init (&error);
435 connection = dbus_bus_get (DBUS_BUS_STARTER, &error);
436 if (connection == NULL)
438 fprintf (stderr, "*** Failed to open connection to activating message bus: %s\n",
440 dbus_error_free (&error);
444 loop = _dbus_loop_new ();
448 if (!test_connection_setup (loop, connection))
451 if (!dbus_connection_add_filter (connection,
452 filter_func, NULL, NULL))
455 if (!dbus_connection_register_object_path (connection,
463 if (!dbus_connection_get_object_path_data (connection, echo_path, &d))
465 if (d != (void*) 0xdeadbeef)
466 die ("dbus_connection_get_object_path_data() doesn't seem to work right\n");
469 result = dbus_bus_request_name (connection, name,
471 if (dbus_error_is_set (&error))
473 fprintf (stderr, "Error %s\n", error.message);
474 _dbus_verbose ("*** Failed to acquire service: %s\n",
476 dbus_error_free (&error);
480 if (result != DBUS_REQUEST_NAME_REPLY_PRIMARY_OWNER)
482 fprintf (stderr, "Unable to acquire service: code %d\n", result);
483 _dbus_verbose ("*** Failed to acquire service: %d\n", result);
487 _dbus_verbose ("*** Test service entering main loop\n");
488 _dbus_loop_run (loop);
490 test_connection_shutdown (loop, connection);
492 dbus_connection_remove_filter (connection, filter_func, NULL);
494 dbus_connection_unref (connection);
496 _dbus_loop_unref (loop);
501 _dbus_verbose ("*** Test service exiting\n");