diff options
| author | Ted Gould <ted@gould.cx> | 2010-01-13 12:30:30 -0600 | 
|---|---|---|
| committer | Ted Gould <ted@gould.cx> | 2010-01-13 12:30:30 -0600 | 
| commit | 21c5cc4a70c060c12c3fa7082874724c6ac96706 (patch) | |
| tree | 8eb50c8cc6f2ca9f3c2bdd8b75c6961b3b5e8858 /tests | |
| parent | 5ca2ed3d2bb3672888620f17d91f215797d47dd8 (diff) | |
| parent | b1b9134542bd3bcfa6b5492f0a7f1b83cf0ec32f (diff) | |
| download | ayatana-indicator-application-21c5cc4a70c060c12c3fa7082874724c6ac96706.tar.gz ayatana-indicator-application-21c5cc4a70c060c12c3fa7082874724c6ac96706.tar.bz2 ayatana-indicator-application-21c5cc4a70c060c12c3fa7082874724c6ac96706.zip | |
* Upstream update
  * Fallback support
Diffstat (limited to 'tests')
| -rw-r--r-- | tests/Makefile.am | 37 | ||||
| -rw-r--r-- | tests/test-libappindicator-fallback-item.c | 130 | ||||
| -rw-r--r-- | tests/test-libappindicator-fallback-watcher.c | 97 | 
3 files changed, 264 insertions, 0 deletions
| diff --git a/tests/Makefile.am b/tests/Makefile.am index 845b41c..c94ebdd 100644 --- a/tests/Makefile.am +++ b/tests/Makefile.am @@ -3,6 +3,8 @@ check_PROGRAMS = \  	test-libappindicator \  	test-libappindicator-dbus-client \  	test-libappindicator-dbus-server \ +	test-libappindicator-fallback-watcher \ +	test-libappindicator-fallback-item \  	test-simple-app  TESTS = @@ -59,6 +61,41 @@ test_libappindicator_dbus_server_LDADD = \  	$(top_builddir)/src/libappindicator.la  ######################################### +##  test-libappindicator-fallback +######################################### + +test_libappindicator_fallback_watcher_SOURCES = \ +	test-libappindicator-fallback-watcher.c + +test_libappindicator_fallback_watcher_CFLAGS = \ +	$(INDICATOR_CFLAGS) \ +	-Wall -Werror \ +	-I$(top_srcdir)/src + +test_libappindicator_fallback_watcher_LDADD = \ +	$(INDICATOR_LIBS) \ +	$(top_builddir)/src/libappindicator.la + +test_libappindicator_fallback_item_SOURCES = \ +	test-libappindicator-fallback-item.c + +test_libappindicator_fallback_item_CFLAGS = \ +	$(INDICATOR_CFLAGS) \ +	-Wall -Werror \ +	-I$(top_srcdir)/src + +test_libappindicator_fallback_item_LDADD = \ +	$(INDICATOR_LIBS) \ +	$(top_builddir)/src/libappindicator.la + +test-libappindicator-fallback: test-libappindicator-fallback-watcher test-libappindicator-fallback-item Makefile.am +	@echo "#!/bin/sh" > $@ +	@echo $(DBUS_RUNNER) --task ./test-libappindicator-fallback-watcher --task-name Watcher --ignore-return --task ./test-libappindicator-fallback-item --task-name Item >> $@ +	@chmod +x $@ + +TESTS += test-libappindicator-fallback + +#########################################  ##  Actual tests  ######################################### diff --git a/tests/test-libappindicator-fallback-item.c b/tests/test-libappindicator-fallback-item.c new file mode 100644 index 0000000..291bc7c --- /dev/null +++ b/tests/test-libappindicator-fallback-item.c @@ -0,0 +1,130 @@ +#include <glib.h> +#include <glib-object.h> +#include <libappindicator/app-indicator.h> + +#define TEST_LIBAPPINDICATOR_FALLBACK_ITEM_TYPE            (test_libappindicator_fallback_item_get_type ()) +#define TEST_LIBAPPINDICATOR_FALLBACK_ITEM(obj)            (G_TYPE_CHECK_INSTANCE_CAST ((obj), TEST_LIBAPPINDICATOR_FALLBACK_ITEM_TYPE, TestLibappindicatorFallbackItem)) +#define TEST_LIBAPPINDICATOR_FALLBACK_ITEM_CLASS(klass)    (G_TYPE_CHECK_CLASS_CAST ((klass), TEST_LIBAPPINDICATOR_FALLBACK_ITEM_TYPE, TestLibappindicatorFallbackItemClass)) +#define IS_TEST_LIBAPPINDICATOR_FALLBACK_ITEM(obj)         (G_TYPE_CHECK_INSTANCE_TYPE ((obj), TEST_LIBAPPINDICATOR_FALLBACK_ITEM_TYPE)) +#define IS_TEST_LIBAPPINDICATOR_FALLBACK_ITEM_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), TEST_LIBAPPINDICATOR_FALLBACK_ITEM_TYPE)) +#define TEST_LIBAPPINDICATOR_FALLBACK_ITEM_GET_CLASS(obj)  (G_TYPE_INSTANCE_GET_CLASS ((obj), TEST_LIBAPPINDICATOR_FALLBACK_ITEM_TYPE, TestLibappindicatorFallbackItemClass)) + +typedef struct _TestLibappindicatorFallbackItem      TestLibappindicatorFallbackItem; +typedef struct _TestLibappindicatorFallbackItemClass TestLibappindicatorFallbackItemClass; + +struct _TestLibappindicatorFallbackItemClass { +	AppIndicatorClass parent_class; + +}; + +struct _TestLibappindicatorFallbackItem { +	AppIndicator parent; + +}; + +GType test_libappindicator_fallback_item_get_type (void); + +#define TEST_LIBAPPINDICATOR_FALLBACK_ITEM_GET_PRIVATE(o) \ +(G_TYPE_INSTANCE_GET_PRIVATE ((o), TEST_LIBAPPINDICATOR_FALLBACK_ITEM_TYPE, TestLibappindicatorFallbackItemPrivate)) + +static void test_libappindicator_fallback_item_class_init (TestLibappindicatorFallbackItemClass *klass); +static void test_libappindicator_fallback_item_init       (TestLibappindicatorFallbackItem *self); +static GtkStatusIcon * fallback (AppIndicator * indicator); +static void unfallback (AppIndicator * indicator, GtkStatusIcon * status_icon); + +G_DEFINE_TYPE (TestLibappindicatorFallbackItem, test_libappindicator_fallback_item, APP_INDICATOR_TYPE); + +static void +test_libappindicator_fallback_item_class_init (TestLibappindicatorFallbackItemClass *klass) +{ +	AppIndicatorClass * aiclass = APP_INDICATOR_CLASS(klass); + +	aiclass->fallback = fallback; +	aiclass->unfallback = unfallback; +} + +static void +test_libappindicator_fallback_item_init (TestLibappindicatorFallbackItem *self) +{ +} + +GMainLoop * mainloop = NULL; +gboolean passed = FALSE; + +enum { +	STATE_INIT, +	STATE_FALLBACK, +	STATE_UNFALLBACK, +	STATE_REFALLBACK, +	STATE_REUNFALLBACK +}; + +gint state = STATE_INIT; + +static GtkStatusIcon * +fallback (AppIndicator * indicator) +{ +	g_debug("Fallback"); +	if (state == STATE_INIT) { +		state = STATE_FALLBACK; +	} else if (state == STATE_UNFALLBACK) { +		state = STATE_REFALLBACK; +	} else { +		g_debug("Error, fallback in state: %d", state); +		passed = FALSE; +	} +	return (GtkStatusIcon *)5; +} + +static void +unfallback (AppIndicator * indicator, GtkStatusIcon * status_icon) +{ +	g_debug("Unfallback"); +	if (state == STATE_FALLBACK) { +		state = STATE_UNFALLBACK; +	} else if (state == STATE_REFALLBACK) { +		state = STATE_REUNFALLBACK; +		passed = TRUE; +		g_main_loop_quit(mainloop); +	} else { +		g_debug("Error, unfallback in state: %d", state); +		passed = FALSE; +	} +	return; +} + +gboolean +kill_func (gpointer data) +{ +	g_debug("Kill Function"); +	g_main_loop_quit(mainloop); +	return FALSE; +} + +int +main (int argc, char ** argv) +{ +	gtk_init(&argc, &argv); + +	TestLibappindicatorFallbackItem * item = g_object_new(TEST_LIBAPPINDICATOR_FALLBACK_ITEM_TYPE, +		"id", "test-id", +		"category", "other", +		"icon-name", "bob", +		NULL); +	 +	GtkWidget * menu = gtk_menu_new(); +	app_indicator_set_menu(APP_INDICATOR(item), GTK_MENU(menu)); + +	g_timeout_add_seconds(1, kill_func, NULL); + +	mainloop = g_main_loop_new(NULL, FALSE); +	g_main_loop_run(mainloop); + +	g_object_unref(G_OBJECT(item)); + +	if (passed) { +		return 0; +	} else { +		return 1; +	} +} diff --git a/tests/test-libappindicator-fallback-watcher.c b/tests/test-libappindicator-fallback-watcher.c new file mode 100644 index 0000000..90c7db8 --- /dev/null +++ b/tests/test-libappindicator-fallback-watcher.c @@ -0,0 +1,97 @@ +/* +This puts the NotificationWatcher on the bus, kinda.  Enough to +trick the Item into unfalling back. + +Copyright 2010 Canonical Ltd. + +Authors: +    Ted Gould <ted@canonical.com> + +This program is free software: you can redistribute it and/or modify it +under the terms of the GNU General Public License version 3, as published +by the Free Software Foundation. + +This program is distributed in the hope that it will be useful, but +WITHOUT ANY WARRANTY; without even the implied warranties of +MERCHANTABILITY, SATISFACTORY QUALITY, or FITNESS FOR A PARTICULAR +PURPOSE.  See the GNU General Public License for more details. + +You should have received a copy of the GNU General Public License along +with this program.  If not, see <http://www.gnu.org/licenses/>. +*/ + +#include <glib.h> +#include <dbus/dbus-glib.h> +#include <dbus/dbus-glib-bindings.h> +#include <dbus/dbus-glib-lowlevel.h> + +#include "../src/dbus-shared.h" + +static GMainLoop * mainloop = NULL; + +static DBusHandlerResult +dbus_filter (DBusConnection * connection, DBusMessage * message, void * user_data) +{ +	if (dbus_message_is_method_call(message, NOTIFICATION_WATCHER_DBUS_ADDR, "RegisterStatusNotifierItem")) { +		DBusMessage * reply = dbus_message_new_method_return(message); +		dbus_connection_send(connection, reply, NULL); +		dbus_message_unref(reply); +		return DBUS_HANDLER_RESULT_HANDLED; +	} + +	return DBUS_HANDLER_RESULT_NOT_YET_HANDLED; +} + +gboolean +kill_func (gpointer userdata) +{ +	g_main_loop_quit(mainloop); +	return FALSE; +} + +int +main (int argv, char ** argc) +{ +	g_type_init(); + +	g_debug("Waiting to init."); + +	/* Wait 1/4 a second, which should trigger the fallback */ +	g_usleep(250000); + +	g_debug("Initing"); + +	GError * error = NULL; +	DBusGConnection * session_bus = dbus_g_bus_get(DBUS_BUS_SESSION, &error); +	if (error != NULL) { +		g_error("Unable to get session bus: %s", error->message); +		return 1; +	} + +    DBusGProxy * bus_proxy = dbus_g_proxy_new_for_name(session_bus, DBUS_SERVICE_DBUS, DBUS_PATH_DBUS, DBUS_INTERFACE_DBUS); +	guint nameret = 0; + +	if (!org_freedesktop_DBus_request_name(bus_proxy, NOTIFICATION_WATCHER_DBUS_ADDR, 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; +	} + +	dbus_connection_add_filter(dbus_g_connection_get_connection(session_bus), dbus_filter, NULL, NULL); + +	/* After we've got the name, let it unfallback, and then we'll drop again */ +	g_timeout_add(250, kill_func, NULL); + +	g_debug("Entering Mainloop"); + +	mainloop = g_main_loop_new(NULL, FALSE); +	g_main_loop_run(mainloop); + +	g_debug("Exiting"); + +	return 0; +} | 
