aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTed Gould <ted@gould.cx>2010-06-28 17:56:45 -0500
committerTed Gould <ted@gould.cx>2010-06-28 17:56:45 -0500
commitd2ee9c6261888a13b0f531ad119b008b130daee9 (patch)
treef12e7bc186767afcc67abca28befb77120fda831
parent3bbd2b821624a706b94a297e7e46442b9ae227f9 (diff)
downloadlibdbusmenu-d2ee9c6261888a13b0f531ad119b008b130daee9.tar.gz
libdbusmenu-d2ee9c6261888a13b0f531ad119b008b130daee9.tar.bz2
libdbusmenu-d2ee9c6261888a13b0f531ad119b008b130daee9.zip
Adding a JSON loader
-rw-r--r--.bzrignore1
-rw-r--r--tests/Makefile.am42
-rw-r--r--tests/test-json-server.c60
3 files changed, 101 insertions, 2 deletions
diff --git a/.bzrignore b/.bzrignore
index 1079d9f..d2d26a9 100644
--- a/.bzrignore
+++ b/.bzrignore
@@ -185,3 +185,4 @@ m4/gtk-doc.m4
tests/dbusmenu-jsonloader.pc
tests/libdbusmenu-jsonloader.la
tests/libdbusmenu_jsonloader_la-json-loader.lo
+tests/test-json-server
diff --git a/tests/Makefile.am b/tests/Makefile.am
index d9468bb..9b95db0 100644
--- a/tests/Makefile.am
+++ b/tests/Makefile.am
@@ -7,8 +7,9 @@ TESTS = \
test-glib-properties \
test-glib-proxy \
test-glib-simple-items \
- test-gtk-objects-test \
test-glib-submenu \
+ test-json \
+ test-gtk-objects-test \
test-gtk-label \
test-gtk-shortcut \
test-gtk-reorder
@@ -31,7 +32,8 @@ check_PROGRAMS = \
test-gtk-shortcut-client \
test-gtk-shortcut-server \
test-glib-simple-items \
- test-gtk-reorder-server
+ test-gtk-reorder-server \
+ test-json-server
XVFB_RUN=". $(srcdir)/run-xvfb.sh"
@@ -119,6 +121,42 @@ test_glib_layout_client_LDADD = \
$(DBUSMENUGLIB_LIBS)
######################
+# Test JSON
+######################
+
+test-json: test-json-client test-json-server Makefile.am
+ @echo "#!/bin/bash" > $@
+ @echo $(DBUS_RUNNER) --task ./test-json-client --task-name Client --task ./test-json-server --task-name Server --ignore-return >> $@
+ @chmod +x $@
+
+test_json_server_SOURCES = \
+ test-json-server.c
+
+test_json_server_CFLAGS = \
+ -I $(srcdir)/.. \
+ -I $(srcdir) \
+ $(DBUSMENUGLIB_CFLAGS) \
+ $(DBUSMENUTESTS_CFLAGS) \
+ -Wall -Werror
+
+test_json_server_LDADD = \
+ ../libdbusmenu-glib/libdbusmenu-glib.la \
+ libdbusmenu-jsonloader.la \
+ $(DBUSMENUTESTS_LIBS) \
+ $(DBUSMENUGLIB_LIBS)
+
+test_json_client_SOURCES = \
+ test-json-client.c
+
+test_json_client_CFLAGS = \
+ -I $(srcdir)/.. \
+ $(DBUSMENUGLIB_CFLAGS) -Wall -Werror
+
+test_json_client_LDADD = \
+ ../libdbusmenu-glib/libdbusmenu-glib.la \
+ $(DBUSMENUGLIB_LIBS)
+
+######################
# Test Glib Submenu
######################
diff --git a/tests/test-json-server.c b/tests/test-json-server.c
new file mode 100644
index 0000000..b2b8341
--- /dev/null
+++ b/tests/test-json-server.c
@@ -0,0 +1,60 @@
+#include <glib.h>
+
+#include <dbus/dbus.h>
+#include <dbus/dbus-glib.h>
+#include <dbus/dbus-glib-lowlevel.h>
+#include <dbus/dbus-glib-bindings.h>
+
+#include <libdbusmenu-glib/server.h>
+#include <libdbusmenu-glib/menuitem.h>
+
+#include "json-loader.h"
+
+static GMainLoop * mainloop = NULL;
+
+static gboolean
+timer_func (gpointer data)
+{
+ g_main_loop_quit(mainloop);
+ return FALSE;
+}
+
+int
+main (int argc, char ** argv)
+{
+ GError * error = NULL;
+
+ g_type_init();
+
+ DBusGConnection * connection = dbus_g_bus_get(DBUS_BUS_SESSION, NULL);
+ g_debug("DBus ID: %s", dbus_connection_get_server_id(dbus_g_connection_get_connection(dbus_g_bus_get(DBUS_BUS_SESSION, NULL))));
+
+ DBusGProxy * bus_proxy = dbus_g_proxy_new_for_name(connection, DBUS_SERVICE_DBUS, DBUS_PATH_DBUS, DBUS_INTERFACE_DBUS);
+ guint nameret = 0;
+
+ if (!org_freedesktop_DBus_request_name(bus_proxy, "org.dbusmenu.test", 0, &nameret, &error)) {
+ g_error("Unable to call to request name");
+ return 1;
+ }
+
+ if (nameret != DBUS_REQUEST_NAME_REPLY_PRIMARY_OWNER) {
+ g_error("Unable to get name");
+ return 1;
+ }
+
+ DbusmenuServer * server = dbusmenu_server_new("/org/test");
+
+ DbusmenuMenuitem * root = dbusmenu_json_build_from_file(argv[1]);
+ g_return_val_if_fail(root!=NULL, 1);
+
+ dbusmenu_server_set_root(server, root);
+
+ g_timeout_add(3000, timer_func, NULL);
+
+ mainloop = g_main_loop_new(NULL, FALSE);
+ g_main_loop_run(mainloop);
+
+ g_debug("Quiting");
+
+ return 0;
+}