diff options
| author | Havoc Pennington <hp@redhat.com> | 2003-10-21 05:46:52 +0000 | 
|---|---|---|
| committer | Havoc Pennington <hp@redhat.com> | 2003-10-21 05:46:52 +0000 | 
| commit | 75742242000e782719bc1656f0a7da72b059e88e (patch) | |
| tree | 6bba82481931f2cabfa36c273126dfc2af7bf410 /test | |
| parent | 8a4d94fe70982690c5fe4580f906b8ca2a95c468 (diff) | |
2003-10-20  Havoc Pennington  <hp@redhat.com>
        hmm, make check is currently not passing.
	* doc/dbus-specification.xml: add requirement that custom type
	names follow the same rules as interface names.
	* dbus/dbus-protocol.h: change some of the byte codes, to avoid
	duplication and allow 'c' to be 'custom'; dict is now 'm' for
	'map'
	* doc/dbus-specification.xml: update type codes to match
	dbus-protocol.h, using the ASCII byte values. Rename type NAMED to
	CUSTOM. Add type OBJECT_PATH to the spec.
2003-10-17  Havoc Pennington  <hp@redhat.com>
	* bus/driver.c (create_unique_client_name): use "." as separator
	in base service names instead of '-'
	* dbus/dbus-string.c (_dbus_string_get_byte): allow getting nul
	byte at the end of the string
	* dbus/dbus-internals.h (_DBUS_LIKELY, _DBUS_UNLIKELY): add
	optimization macros since string validation seems to be a slow
	point.
	* doc/dbus-specification.xml: restrict valid
	service/interface/member/error names. Add test suite code for the
	name validation.
	* dbus/dbus-string.c: limit service/interface/member/error names
	to [0-9][A-Z][a-z]_
	* dbus/dbus-connection.c (dbus_connection_dispatch): add missing
	format arg to verbose spew
	* glib/dbus-gproxy.c (dbus_gproxy_call_no_reply): if not out of
	memory, return instead of g_error
	* test/test-service.c (path_message_func): support emitting a
	signal on request
	* dbus/dbus-bus.c (init_connections_unlocked): only fill in
	activation bus type if DBUS_BUS_ACTIVATION was set; default to
	assuming the activation bus was the session bus so that services
	started manually will still register.
	(init_connections_unlocked): fix so that in OOM situation we get
	the same semantics when retrying the function
	* test/test-service.c (main): change to use path registration, to
	test those codepaths; register with DBUS_BUS_ACTIVATION rather
	than DBUS_BUS_SESSION
Diffstat (limited to 'test')
| -rw-r--r-- | test/break-loader.c | 2 | ||||
| -rw-r--r-- | test/data/valid-messages/lots-of-arguments.message | 2 | ||||
| -rw-r--r-- | test/data/valid-service-files/debug-glib.service.in | 3 | ||||
| -rw-r--r-- | test/glib/Makefile.am | 7 | ||||
| -rwxr-xr-x | test/glib/run-test.sh | 3 | ||||
| -rw-r--r-- | test/glib/test-dbus-glib.c | 56 | ||||
| -rw-r--r-- | test/test-service.c | 88 | 
7 files changed, 143 insertions, 18 deletions
| diff --git a/test/break-loader.c b/test/break-loader.c index 5a0c61f2..e514d793 100644 --- a/test/break-loader.c +++ b/test/break-loader.c @@ -406,7 +406,7 @@ random_type (void)      DBUS_TYPE_UINT64,      DBUS_TYPE_DOUBLE,      DBUS_TYPE_STRING, -    DBUS_TYPE_NAMED, +    DBUS_TYPE_CUSTOM,      DBUS_TYPE_ARRAY,      DBUS_TYPE_DICT,      DBUS_TYPE_OBJECT_PATH diff --git a/test/data/valid-messages/lots-of-arguments.message b/test/data/valid-messages/lots-of-arguments.message index d3f6a4ee..bdaae0f8 100644 --- a/test/data/valid-messages/lots-of-arguments.message +++ b/test/data/valid-messages/lots-of-arguments.message @@ -31,7 +31,7 @@ DOUBLE_ARRAY { 0.1, 0.2, 3.1415926, 2.7183, 10.0, 9.99 }  TYPE ARRAY  TYPE STRING  STRING_ARRAY { 'Hello', 'This', 'Is', 'A', 'String', 'Array!' } -TYPE NAMED +TYPE CUSTOM  STRING 'named type'  BYTE_ARRAY { 'b', 'i', 'n', 'a', 'r', 'y', 'd', 'a', 't', 'a' } diff --git a/test/data/valid-service-files/debug-glib.service.in b/test/data/valid-service-files/debug-glib.service.in new file mode 100644 index 00000000..199fd808 --- /dev/null +++ b/test/data/valid-service-files/debug-glib.service.in @@ -0,0 +1,3 @@ +[D-BUS Service] +Name=org.freedesktop.DBus.TestSuiteGLibService +Exec=@TEST_GLIB_SERVICE_BINARY@ diff --git a/test/glib/Makefile.am b/test/glib/Makefile.am index 608e7d01..ba1f181d 100644 --- a/test/glib/Makefile.am +++ b/test/glib/Makefile.am @@ -32,13 +32,18 @@ endif  ## we use noinst_PROGRAMS not check_PROGRAMS for TESTS so that we  ## build even when not doing "make check" -noinst_PROGRAMS= test-dbus-glib $(THREAD_APPS) +noinst_PROGRAMS= test-dbus-glib test-service-glib $(THREAD_APPS)  test_dbus_glib_SOURCES=				\  	test-dbus-glib.c  test_dbus_glib_LDADD= $(top_builddir)/glib/libdbus-glib-1.la +test_service_glib_SOURCES=				\ +	test-service-glib.c + +test_service_glib_LDADD= $(top_builddir)/glib/libdbus-glib-1.la +  else  ### not building tests diff --git a/test/glib/run-test.sh b/test/glib/run-test.sh index a51396bb..ce2f469b 100755 --- a/test/glib/run-test.sh +++ b/test/glib/run-test.sh @@ -5,6 +5,7 @@ SCRIPTNAME=$0  function die()   {      if ! test -z "$DBUS_SESSION_BUS_PID" ; then +        echo "killing message bus"          kill -9 $DBUS_SESSION_BUS_PID      fi      echo $SCRIPTNAME: $* >&2 @@ -45,7 +46,7 @@ fi  echo "Started test bus pid $DBUS_SESSION_BUS_PID at $DBUS_SESSION_BUS_ADDRESS" -$DBUS_TOP_BUILDDIR/test/glib/test-dbus-glib || die "test-dbus-glib failed" +$DEBUG $DBUS_TOP_BUILDDIR/test/glib/test-dbus-glib || die "test-dbus-glib failed"  ## we kill -TERM so gcov data can be written out diff --git a/test/glib/test-dbus-glib.c b/test/glib/test-dbus-glib.c index fb8be4cc..5cb31235 100644 --- a/test/glib/test-dbus-glib.c +++ b/test/glib/test-dbus-glib.c @@ -4,11 +4,43 @@  #include <stdlib.h>  #include <string.h> +static GMainLoop *loop = NULL; +static int n_times_foo_received = 0; + +static void +foo_signal_handler (DBusGProxy  *proxy, +                    DBusMessage *signal, +                    void        *user_data) +{ +  double d; +  DBusError derror; +   +  if (!dbus_message_is_signal (signal, +                               "org.freedesktop.TestSuite", +                               "Foo")) +    { +      g_printerr ("Signal handler received the wrong message\n"); +      exit (1); +    } + +  dbus_error_init (&derror); +  if (!dbus_message_get_args (signal, &derror, DBUS_TYPE_DOUBLE, +                              &d, DBUS_TYPE_INVALID)) +    { +      g_printerr ("failed to get signal args: %s\n", derror.message); +      dbus_error_free (&derror); +      exit (1); +    } + +  n_times_foo_received += 1; + +  g_main_loop_quit (loop); +} +  int  main (int argc, char **argv)  {    DBusConnection *connection; -  GMainLoop *loop;    GError *error;    DBusGProxy *driver;    DBusGProxy *proxy; @@ -135,7 +167,7 @@ main (int argc, char **argv)    proxy = dbus_gproxy_new_for_service (connection,                                         "org.freedesktop.DBus.TestSuiteEchoService", -                                       "/fixme/the/test/service/ignores/this", /* FIXME */ +                                       "/org/freedesktop/TestSuite",                                         "org.freedesktop.TestSuite");    call = dbus_gproxy_begin_call (proxy, "Echo", @@ -156,6 +188,26 @@ main (int argc, char **argv)    g_print ("String echoed = \"%s\"\n", str);    dbus_free (str); + +  /* Test oneway call and signal handling */ + +  dbus_gproxy_connect_signal (proxy, "Foo", +                              foo_signal_handler, +                              NULL, NULL); +   +  dbus_gproxy_call_no_reply (proxy, "EmitFoo", +                             DBUS_TYPE_INVALID); + +  dbus_connection_flush (connection); +   +  g_main_loop_run (loop); + +  if (n_times_foo_received != 1) +    { +      g_printerr ("Foo signal received %d times, should have been 1\n", +                  n_times_foo_received); +      exit (1); +    }    g_object_unref (G_OBJECT (driver));    g_object_unref (G_OBJECT (proxy)); diff --git a/test/test-service.c b/test/test-service.c index c72a43af..6f77c3da 100644 --- a/test/test-service.c +++ b/test/test-service.c @@ -28,6 +28,8 @@ handle_echo (DBusConnection     *connection,    DBusError error;    DBusMessage *reply;    char *s; + +  _dbus_verbose ("sending reply to Echo method\n");    dbus_error_init (&error); @@ -72,21 +74,77 @@ handle_echo (DBusConnection     *connection,    return DBUS_HANDLER_RESULT_HANDLED;  } +static void +path_unregistered_func (DBusConnection  *connection, +                        void            *user_data) +{ +  /* connection was finalized */ +} +  static DBusHandlerResult -filter_func (DBusConnection     *connection, -             DBusMessage        *message, -             void               *user_data) -{   +path_message_func (DBusConnection  *connection, +                   DBusMessage     *message, +                   void            *user_data) +{    if (dbus_message_is_method_call (message,                                     "org.freedesktop.TestSuite",                                     "Echo"))      return handle_echo (connection, message);    else if (dbus_message_is_method_call (message,                                          "org.freedesktop.TestSuite", -                                        "Exit") || -           dbus_message_is_signal (message, -                                   DBUS_INTERFACE_ORG_FREEDESKTOP_LOCAL, -                                   "Disconnected")) +                                        "Exit")) +    { +      dbus_connection_disconnect (connection); +      quit (); +      return DBUS_HANDLER_RESULT_HANDLED; +    } +  else if (dbus_message_is_method_call (message, +                                        "org.freedesktop.TestSuite", +                                        "EmitFoo")) +    { +      /* Emit the Foo signal */ +      DBusMessage *signal; + +      _dbus_verbose ("emitting signal Foo\n"); +       +      signal = dbus_message_new_signal ("/org/freedesktop/TestSuite", +                                        "org.freedesktop.TestSuite", +                                        "Foo"); +      if (signal == NULL) +        die ("No memory\n"); +       +      if (!dbus_message_append_args (signal, +                                     DBUS_TYPE_DOUBLE, 42.6, +                                     DBUS_TYPE_INVALID)) +        die ("No memory"); +   +      if (!dbus_connection_send (connection, signal, NULL)) +        die ("No memory\n"); +       +      return DBUS_HANDLER_RESULT_HANDLED; +    } +  else +    return DBUS_HANDLER_RESULT_NOT_YET_HANDLED; +} + +static DBusObjectPathVTable +echo_vtable = { +  path_unregistered_func, +  path_message_func, +  NULL, +}; + +/* Pre-exploded path, "/org/freedesktop/TestSuite" */ +static const char* echo_path[] = { "org", "freedesktop", "TestSuite", NULL }; + +static DBusHandlerResult +filter_func (DBusConnection     *connection, +             DBusMessage        *message, +             void               *user_data) +{ +  if (dbus_message_is_signal (message, +                              DBUS_INTERFACE_ORG_FREEDESKTOP_LOCAL, +                              "Disconnected"))      {        dbus_connection_disconnect (connection);        quit (); @@ -107,11 +165,11 @@ main (int    argc,    int result;    dbus_error_init (&error); -  connection = dbus_bus_get (DBUS_BUS_SESSION, &error); +  connection = dbus_bus_get (DBUS_BUS_ACTIVATION, &error);    if (connection == NULL)      { -      _dbus_verbose ("*** Failed to open connection to activating message bus: %s\n", -                     error.message); +      fprintf (stderr, "*** Failed to open connection to activating message bus: %s\n", +               error.message);        dbus_error_free (&error);        return 1;      } @@ -127,13 +185,19 @@ main (int    argc,                                     filter_func, NULL, NULL))      die ("No memory"); +  if (!dbus_connection_register_object_path (connection, +                                             echo_path, +                                             &echo_vtable, +                                             NULL)) +    die ("No memory"); +      printf ("Acquiring service\n");    result = dbus_bus_acquire_service (connection, "org.freedesktop.DBus.TestSuiteEchoService",                                       0, &error);    if (dbus_error_is_set (&error))      { -      printf ("Error %s", error.message); +      fprintf (stderr, "Error %s", error.message);        _dbus_verbose ("*** Failed to acquire service: %s\n",                       error.message);        dbus_error_free (&error); | 
