diff options
| author | Ted Gould <ted@gould.cx> | 2010-02-06 09:22:00 -0800 | 
|---|---|---|
| committer | Ted Gould <ted@gould.cx> | 2010-02-06 09:22:00 -0800 | 
| commit | 119bd7acf9f3246df348bcce10b99b6ae40c80ae (patch) | |
| tree | 2a4d6495d73b189bbbcd07f4d460181b9ec00de8 /tests/test-libappindicator-status-client.c | |
| parent | d27570eae3152102ab10633c6127243439b21580 (diff) | |
| download | ayatana-indicator-application-119bd7acf9f3246df348bcce10b99b6ae40c80ae.tar.gz ayatana-indicator-application-119bd7acf9f3246df348bcce10b99b6ae40c80ae.tar.bz2 ayatana-indicator-application-119bd7acf9f3246df348bcce10b99b6ae40c80ae.zip | |
Adjusting the status test to watch for toggles
Diffstat (limited to 'tests/test-libappindicator-status-client.c')
| -rw-r--r-- | tests/test-libappindicator-status-client.c | 228 | 
1 files changed, 46 insertions, 182 deletions
| diff --git a/tests/test-libappindicator-status-client.c b/tests/test-libappindicator-status-client.c index 5a7107f..40f44df 100644 --- a/tests/test-libappindicator-status-client.c +++ b/tests/test-libappindicator-status-client.c @@ -23,165 +23,71 @@ with this program.  If not, see <http://www.gnu.org/licenses/>.  #include <glib.h>  #include <dbus/dbus-glib.h> -#include <libappindicator/app-indicator.h> -#include "test-defines.h" +#include <dbus/dbus-glib-lowlevel.h> +#include "../src/dbus-shared.h"  static GMainLoop * mainloop = NULL;  static gboolean passed = TRUE; -static int propcount = 0; +static gboolean watchdog_hit = TRUE; +static gboolean active = FALSE; +static guint toggle_count = 0; -static void -check_propcount (void) -{ -	if (propcount >= 5) { -		g_main_loop_quit(mainloop); -	} -	return; -} +#define PASSIVE_STR  "Passive" +#define ACTIVE_STR   "Active" +#define ATTN_STR     "NeedsAttention" - -static void -prop_id_cb (DBusGProxy * proxy, DBusGProxyCall * call, void * data) +static DBusHandlerResult +dbus_filter (DBusConnection * connection, DBusMessage * message, void * user_data)  { -	propcount++; - -	GError * error = NULL; -	GValue value = {0}; - -	if (!dbus_g_proxy_end_call(proxy, call, &error, G_TYPE_VALUE, &value, G_TYPE_INVALID)) { -		g_warning("Getting ID failed: %s", error->message); -		g_error_free(error); -		passed = FALSE; -		check_propcount(); -		return; -	} - -	if (g_strcmp0(TEST_ID, g_value_get_string(&value))) { -		g_debug("Property ID Returned: FAILED"); -		passed = FALSE; -	} else { -		g_debug("Property ID Returned: PASSED"); +	if (!dbus_message_is_signal(message, NOTIFICATION_ITEM_DBUS_IFACE, "NewStatus")) { +		return DBUS_HANDLER_RESULT_NOT_YET_HANDLED;  	} -	check_propcount(); -	return; -} - -static void -prop_category_cb (DBusGProxy * proxy, DBusGProxyCall * call, void * data) -{ -	propcount++; - -	GError * error = NULL; -	GValue value = {0}; - -	if (!dbus_g_proxy_end_call(proxy, call, &error, G_TYPE_VALUE, &value, G_TYPE_INVALID)) { -		g_warning("Getting category failed: %s", error->message); -		g_error_free(error); -		passed = FALSE; -		check_propcount(); -		return; -	} +	gchar * string; -	if (g_strcmp0(TEST_CATEGORY_S, g_value_get_string(&value))) { -		g_debug("Property category Returned: FAILED"); -		passed = FALSE; -	} else { -		g_debug("Property category Returned: PASSED"); +	DBusError derror; +	dbus_error_init(&derror); +	if (!dbus_message_get_args(message, &derror, +				DBUS_TYPE_STRING, &string, +				DBUS_TYPE_INVALID)) { +		g_warning("Couldn't get parameters"); +		dbus_error_free(&derror); +		return DBUS_HANDLER_RESULT_NOT_YET_HANDLED;  	} -	check_propcount(); -	return; -} - -static void -prop_status_cb (DBusGProxy * proxy, DBusGProxyCall * call, void * data) -{ -	propcount++; - -	GError * error = NULL; -	GValue value = {0}; - -	if (!dbus_g_proxy_end_call(proxy, call, &error, G_TYPE_VALUE, &value, G_TYPE_INVALID)) { -		g_warning("Getting status failed: %s", error->message); -		g_error_free(error); -		passed = FALSE; -		check_propcount(); -		return; -	} +	watchdog_hit = TRUE; -	if (g_strcmp0(TEST_STATE_S, g_value_get_string(&value))) { -		g_debug("Property status Returned: FAILED"); -		passed = FALSE; +	if (g_strcmp0(string, ACTIVE_STR) == 0) { +		if (active) { +			g_warning("Got active when already active"); +			passed = FALSE; +			return DBUS_HANDLER_RESULT_NOT_YET_HANDLED; +		} +		active = TRUE;  	} else { -		g_debug("Property status Returned: PASSED"); +		active = FALSE;  	} -	check_propcount(); -	return; -} - -static void -prop_icon_name_cb (DBusGProxy * proxy, DBusGProxyCall * call, void * data) -{ -	propcount++; - -	GError * error = NULL; -	GValue value = {0}; - -	if (!dbus_g_proxy_end_call(proxy, call, &error, G_TYPE_VALUE, &value, G_TYPE_INVALID)) { -		g_warning("Getting icon name failed: %s", error->message); -		g_error_free(error); -		passed = FALSE; -		check_propcount(); -		return; -	} - -	if (g_strcmp0(TEST_ICON_NAME, g_value_get_string(&value))) { -		g_debug("Property icon name Returned: FAILED"); -		passed = FALSE; -	} else { -		g_debug("Property icon name Returned: PASSED"); -	} - -	check_propcount(); -	return; -} - -static void -prop_attention_icon_name_cb (DBusGProxy * proxy, DBusGProxyCall * call, void * data) -{ -	propcount++; +	toggle_count++; -	GError * error = NULL; -	GValue value = {0}; - -	if (!dbus_g_proxy_end_call(proxy, call, &error, G_TYPE_VALUE, &value, G_TYPE_INVALID)) { -		g_warning("Getting attention icon name failed: %s", error->message); -		g_error_free(error); -		passed = FALSE; -		check_propcount(); -		return; -	} - -	if (g_strcmp0(TEST_ATTENTION_ICON_NAME, g_value_get_string(&value))) { -		g_debug("Property attention icon name Returned: FAILED"); -		passed = FALSE; -	} else { -		g_debug("Property attention icon name Returned: PASSED"); +	if (toggle_count == 1000) { +		g_main_loop_quit(mainloop);  	} -	check_propcount(); -	return; +	return DBUS_HANDLER_RESULT_NOT_YET_HANDLED;  }  gboolean  kill_func (gpointer userdata)  { -	g_main_loop_quit(mainloop); -	g_warning("Forced to Kill"); -	passed = FALSE; -	return FALSE; +	if (watchdog_hit == FALSE) { +		g_main_loop_quit(mainloop); +		g_warning("Forced to Kill"); +		passed = FALSE; +		return FALSE; +	} +	watchdog_hit = FALSE; +	return TRUE;  }  gint @@ -198,53 +104,11 @@ main (gint argc, gchar * argv[])  		return 1;  	} -	DBusGProxy * props = dbus_g_proxy_new_for_name_owner(session_bus, -	                                                     ":1.0", -	                                                     "/org/ayatana/NotificationItem", -	                                                     DBUS_INTERFACE_PROPERTIES, -	                                                     &error); -	if (error != NULL) { -		g_error("Unable to get property proxy: %s", error->message); -		return 1; -	} - -	dbus_g_proxy_begin_call (props, -	                         "Get", -	                         prop_id_cb, -	                         NULL, NULL, -	                         G_TYPE_STRING, "org.ayatana.indicator.application.NotificationItem", -	                         G_TYPE_STRING, "Id", -	                         G_TYPE_INVALID); -	dbus_g_proxy_begin_call (props, -	                         "Get", -	                         prop_category_cb, -	                         NULL, NULL, -	                         G_TYPE_STRING, "org.ayatana.indicator.application.NotificationItem", -	                         G_TYPE_STRING, "Category", -	                         G_TYPE_INVALID); -	dbus_g_proxy_begin_call (props, -	                         "Get", -	                         prop_status_cb, -	                         NULL, NULL, -	                         G_TYPE_STRING, "org.ayatana.indicator.application.NotificationItem", -	                         G_TYPE_STRING, "Status", -	                         G_TYPE_INVALID); -	dbus_g_proxy_begin_call (props, -	                         "Get", -	                         prop_icon_name_cb, -	                         NULL, NULL, -	                         G_TYPE_STRING, "org.ayatana.indicator.application.NotificationItem", -	                         G_TYPE_STRING, "IconName", -	                         G_TYPE_INVALID); -	dbus_g_proxy_begin_call (props, -	                         "Get", -	                         prop_attention_icon_name_cb, -	                         NULL, NULL, -	                         G_TYPE_STRING, "org.ayatana.indicator.application.NotificationItem", -	                         G_TYPE_STRING, "AttentionIconName", -	                         G_TYPE_INVALID); +	dbus_connection_add_filter(dbus_g_connection_get_connection(session_bus), dbus_filter, NULL, NULL); +	dbus_bus_add_match(dbus_g_connection_get_connection(session_bus), "type='signal',interface='" NOTIFICATION_ITEM_DBUS_IFACE "',member='NewStatus'", NULL); -	g_timeout_add_seconds(2, kill_func, NULL); +	watchdog_hit = TRUE; +	g_timeout_add(100, kill_func, NULL);  	mainloop = g_main_loop_new(NULL, FALSE);  	g_main_loop_run(mainloop); | 
