diff options
Diffstat (limited to 'test/glib')
-rw-r--r-- | test/glib/Makefile.am | 15 | ||||
-rw-r--r-- | test/glib/test-dbus-glib.c | 203 | ||||
-rw-r--r-- | test/glib/test-service-glib.c | 76 | ||||
-rw-r--r-- | test/glib/test-service-glib.xml | 33 |
4 files changed, 323 insertions, 4 deletions
diff --git a/test/glib/Makefile.am b/test/glib/Makefile.am index a679bcc1..0a246252 100644 --- a/test/glib/Makefile.am +++ b/test/glib/Makefile.am @@ -40,7 +40,20 @@ test_dbus_glib_SOURCES= \ test_dbus_glib_LDADD= $(top_builddir)/glib/libdbus-glib-1.la test_service_glib_SOURCES= \ - test-service-glib.c + test-service-glib.c \ + test-service-glib-glue.h + +BUILT_SOURCES = test-service-glib-glue.h test-service-glib-bindings.h + +test-service-glib-glue.h: $(top_builddir)/glib/dbus-binding-tool test-service-glib.xml + $(top_builddir)/glib/dbus-binding-tool --mode=glib-server $(srcdir)/test-service-glib.xml > test-service-glib-glue.h.tmp + mv test-service-glib-glue.h.tmp test-service-glib-glue.h + +test-service-glib-bindings.h: $(top_builddir)/glib/dbus-binding-tool test-service-glib.xml + $(top_builddir)/glib/dbus-binding-tool --mode=glib-client $(srcdir)/test-service-glib.xml > test-service-glib-bindings.h.tmp + mv test-service-glib-bindings.h.tmp test-service-glib-bindings.h + +CLEANFILES = test-service-glib-glue.h test-service-glib-glue.h.tmp test-service-glib-bindings.h test-service-glib-bindings.h.tmp test_service_glib_LDADD= $(top_builddir)/glib/libdbus-glib-1.la diff --git a/test/glib/test-dbus-glib.c b/test/glib/test-dbus-glib.c index cee9316b..ca36af1f 100644 --- a/test/glib/test-dbus-glib.c +++ b/test/glib/test-dbus-glib.c @@ -3,6 +3,7 @@ #include <stdio.h> #include <stdlib.h> #include <string.h> +#include "test-service-glib-bindings.h" static GMainLoop *loop = NULL; static int n_times_foo_received = 0; @@ -37,7 +38,11 @@ main (int argc, char **argv) int i; guint32 result; const char *v_STRING; + char *v_STRING_2; guint32 v_UINT32; + guint32 v_UINT32_2; + double v_DOUBLE; + double v_DOUBLE_2; g_type_init (); @@ -220,10 +225,204 @@ main (int argc, char **argv) n_times_foo_received); exit (1); } - - g_object_unref (G_OBJECT (driver)); + + /* Activate test servie */ + g_print ("Activating TestSuiteGLibService\n"); + v_STRING = "org.freedesktop.DBus.TestSuiteGLibService"; + v_UINT32 = 0; + call = dbus_g_proxy_begin_call (driver, "StartServiceByName", + DBUS_TYPE_STRING, + &v_STRING, + DBUS_TYPE_UINT32, + &v_UINT32, + DBUS_TYPE_INVALID); + + error = NULL; + if (!dbus_g_proxy_end_call (driver, call, &error, + DBUS_TYPE_UINT32, &result, + DBUS_TYPE_INVALID)) + { + g_printerr ("Failed to complete Activate call: %s\n", + error->message); + g_error_free (error); + exit (1); + } + g_object_unref (G_OBJECT (proxy)); + + proxy = dbus_g_proxy_new_for_name_owner (connection, + "org.freedesktop.DBus.TestSuiteGLibService", + "/org/freedesktop/DBus/Tests/MyTestObject", + "org.freedesktop.DBus.Tests.MyObject", + &error); + if (proxy == NULL) + { + g_printerr ("Failed to create proxy for name owner: %s\n", + error->message); + g_error_free (error); + exit (1); + } + + call = dbus_g_proxy_begin_call (proxy, "DoNothing", + DBUS_TYPE_INVALID); + error = NULL; + if (!dbus_g_proxy_end_call (proxy, call, &error, DBUS_TYPE_INVALID)) + { + g_printerr ("Failed to complete DoNothing call: %s\n", + error->message); + g_error_free (error); + exit (1); + } + + v_UINT32 = 42; + call = dbus_g_proxy_begin_call (proxy, "Increment", + DBUS_TYPE_UINT32, &v_UINT32, + DBUS_TYPE_INVALID); + error = NULL; + if (!dbus_g_proxy_end_call (proxy, call, &error, + DBUS_TYPE_UINT32, &v_UINT32_2, + DBUS_TYPE_INVALID)) + { + g_printerr ("Failed to complete Increment call: %s\n", + error->message); + g_error_free (error); + exit (1); + } + + if (v_UINT32_2 != v_UINT32 + 1) + { + g_printerr ("Increment call returned %d, should be 43\n", v_UINT32_2); + exit (1); + } + + call = dbus_g_proxy_begin_call (proxy, "ThrowError", DBUS_TYPE_INVALID); + error = NULL; + if (dbus_g_proxy_end_call (proxy, call, &error, DBUS_TYPE_INVALID) != FALSE) + { + g_printerr ("ThrowError call unexpectedly succeeded!\n"); + exit (1); + } + + g_print ("ThrowError failed (as expected) returned error: %s\n", error->message); + g_error_free (error); + + v_STRING = "foobar"; + call = dbus_g_proxy_begin_call (proxy, "Uppercase", + DBUS_TYPE_STRING, &v_STRING, + DBUS_TYPE_INVALID); + error = NULL; + if (!dbus_g_proxy_end_call (proxy, call, &error, + DBUS_TYPE_STRING, &v_STRING_2, + DBUS_TYPE_INVALID)) + { + g_printerr ("Failed to complete Uppercase call: %s\n", + error->message); + g_error_free (error); + exit (1); + } + if (strcmp ("FOOBAR", v_STRING_2) != 0) + { + g_printerr ("Uppercase call returned unexpected string %s\n", v_STRING_2); + exit (1); + } + + v_STRING = "bazwhee"; + v_UINT32 = 26; + v_DOUBLE = G_PI; + call = dbus_g_proxy_begin_call (proxy, "ManyArgs", + DBUS_TYPE_UINT32, &v_UINT32, + DBUS_TYPE_STRING, &v_STRING, + DBUS_TYPE_DOUBLE, &v_DOUBLE, + DBUS_TYPE_INVALID); + error = NULL; + if (!dbus_g_proxy_end_call (proxy, call, &error, + DBUS_TYPE_DOUBLE, &v_DOUBLE_2, + DBUS_TYPE_STRING, &v_STRING_2, + DBUS_TYPE_INVALID)) + { + g_printerr ("Failed to complete ManyArgs call: %s\n", + error->message); + g_error_free (error); + exit (1); + } + if (v_DOUBLE_2 < 55 || v_DOUBLE_2 > 56) + { + g_printerr ("ManyArgs call returned unexpected double value %f\n", v_DOUBLE_2); + exit (1); + } + if (strcmp ("BAZWHEE", v_STRING_2) != 0) + { + g_printerr ("ManyArgs call returned unexpected string %s\n", v_STRING_2); + exit (1); + } + + if (!org_freedesktop_DBus_Tests_MyObject_do_nothing (proxy, &error)) + { + g_printerr ("Failed to complete (wrapped) DoNothing call: %s\n", + error->message); + g_error_free (error); + exit (1); + } + + if (!org_freedesktop_DBus_Tests_MyObject_increment (proxy, 42, &v_UINT32_2, &error)) + { + g_printerr ("Failed to complete (wrapped) Increment call: %s\n", + error->message); + g_error_free (error); + exit (1); + } + + if (v_UINT32_2 != 43) + { + g_printerr ("(wrapped) increment call returned %d, should be 43\n", v_UINT32_2); + exit (1); + } + + if (org_freedesktop_DBus_Tests_MyObject_throw_error (proxy, &error) != FALSE) + { + g_printerr ("(wrapped) ThrowError call unexpectedly succeeded!\n"); + exit (1); + } + + g_print ("(wrapped) ThrowError failed (as expected) returned error: %s\n", error->message); + g_error_free (error); + + if (!org_freedesktop_DBus_Tests_MyObject_uppercase (proxy, "foobar", &v_STRING_2, &error)) + { + g_printerr ("Failed to complete (wrapped) Uppercase call: %s\n", + error->message); + g_error_free (error); + exit (1); + } + if (strcmp ("FOOBAR", v_STRING_2) != 0) + { + g_printerr ("(wrapped) Uppercase call returned unexpected string %s\n", v_STRING_2); + exit (1); + } + + if (!org_freedesktop_DBus_Tests_MyObject_many_args (proxy, 26, "bazwhee", G_PI, + &v_DOUBLE_2, &v_STRING_2, &error)) + { + g_printerr ("Failed to complete (wrapped) ManyArgs call: %s\n", + error->message); + g_error_free (error); + exit (1); + } + if (v_DOUBLE_2 < 55 || v_DOUBLE_2 > 56) + { + g_printerr ("(wrapped) ManyArgs call returned unexpected double value %f\n", v_DOUBLE_2); + exit (1); + } + if (strcmp ("BAZWHEE", v_STRING_2) != 0) + { + g_printerr ("(wrapped) ManyArgs call returned unexpected string %s\n", v_STRING_2); + exit (1); + } + + g_object_unref (G_OBJECT (proxy)); + g_object_unref (G_OBJECT (driver)); + g_print ("Successfully completed %s\n", argv[0]); return 0; diff --git a/test/glib/test-service-glib.c b/test/glib/test-service-glib.c index 2fa3095c..81cb556f 100644 --- a/test/glib/test-service-glib.c +++ b/test/glib/test-service-glib.c @@ -4,6 +4,8 @@ #include <stdlib.h> #include <string.h> #include <glib/gi18n.h> +#include <glib-object.h> +#include <glib/gquark.h> typedef struct MyObject MyObject; typedef struct MyObjectClass MyObjectClass; @@ -30,6 +32,28 @@ struct MyObjectClass G_DEFINE_TYPE(MyObject, my_object, G_TYPE_OBJECT) +typedef enum +{ + MY_OBJECT_ERROR_FOO, + MY_OBJECT_ERROR_BAR +} MyObjectError; + +#define MY_OBJECT_ERROR my_object_error_quark () + +gboolean my_object_do_nothing (MyObject *obj, GError **error); + +gboolean my_object_increment (MyObject *obj, gint32 x, int *ret, GError **error); + +gboolean my_object_throw_error (MyObject *obj, GError **error); + +gboolean my_object_uppercase (MyObject *obj, const char *str, char **ret, GError **error); + +gboolean my_object_many_args (MyObject *obj, guint32 x, const char *str, double trouble, double *d_ret, char **str_ret, GError **error); + +#include "test-service-glib-glue.h" + +GQuark my_object_error_quark (void); + /* Properties */ enum { @@ -115,6 +139,54 @@ my_object_class_init (MyObjectClass *mobject_class) "default value", G_PARAM_READWRITE)); } + +GQuark +my_object_error_quark (void) +{ + static GQuark quark = 0; + if (!quark) + quark = g_quark_from_static_string ("my_object_error"); + + return quark; +} + +gboolean +my_object_do_nothing (MyObject *obj, GError **error) +{ + return TRUE; +} + +gboolean +my_object_increment (MyObject *obj, gint32 x, int *ret, GError **error) +{ + *ret = x +1; + return TRUE; +} + +gboolean +my_object_throw_error (MyObject *obj, GError **error) +{ + g_set_error (error, + MY_OBJECT_ERROR, + MY_OBJECT_ERROR_FOO, + "this method always loses"); + return FALSE; +} + +gboolean +my_object_uppercase (MyObject *obj, const char *str, char **ret, GError **error) +{ + *ret = g_ascii_strup (str, -1); + return TRUE; +} + +gboolean +my_object_many_args (MyObject *obj, guint32 x, const char *str, double trouble, double *d_ret, char **str_ret, GError **error) +{ + *d_ret = trouble + (x * 2); + *str_ret = g_ascii_strup (str, -1); + return TRUE; +} static GMainLoop *loop; @@ -148,8 +220,10 @@ main (int argc, char **argv) obj = g_object_new (MY_TYPE_OBJECT, NULL); + dbus_g_object_class_install_info (G_OBJECT_GET_CLASS (obj), + &dbus_glib_my_object_object_info); dbus_g_connection_register_g_object (connection, - "/org/freedesktop/my_test_object", + "/org/freedesktop/DBus/Tests/MyTestObject", obj); driver_proxy = dbus_g_proxy_new_for_name (connection, diff --git a/test/glib/test-service-glib.xml b/test/glib/test-service-glib.xml new file mode 100644 index 00000000..223bf67f --- /dev/null +++ b/test/glib/test-service-glib.xml @@ -0,0 +1,33 @@ +<?xml version="1.0" encoding="UTF-8" ?> + +<node name="/org/freedesktop/DBus/Tests/MyTestObject"> + + <interface name="org.freedesktop.DBus.Tests.MyObject" c_name="my_object"> + + <method name="DoNothing" c_name="my_object_do_nothing"> + </method> + + <method name="Increment" c_name="my_object_increment"> + <arg type="uint32" name="x" /> + <arg type="uint32" direction="out" /> + </method> + + <method name="ThrowError" c_name="my_object_throw_error"> + </method> + + <method name="Uppercase" c_name="my_object_uppercase"> + <arg type="string" direction="in" /> + <arg type="string" direction="out" /> + </method> + + <method name="ManyArgs" c_name="my_object_many_args"> + <arg type="uint32" name="x" direction="in" /> + <arg type="string" name="str" direction="in" /> + <arg type="double" name="trouble" direction="in" /> + <arg type="double" name="d_ret" direction="out" /> + <arg type="string" name="str_ret" direction="out" /> + </method> + + </interface> + +</node> |