diff options
author | Ted Gould <ted@canonical.com> | 2009-04-20 12:36:07 -0500 |
---|---|---|
committer | Ted Gould <ted@canonical.com> | 2009-04-20 12:36:07 -0500 |
commit | 38c6ce2a36d6416016f64e5963deee29bc02f8b3 (patch) | |
tree | a0a91d4bc623b5d23713efcad65518ee2bf4beb1 /tests/test-interests-client.c | |
parent | 443c83ab353b818227270aa63f655fb2cbdbeba7 (diff) | |
download | libayatana-indicator-38c6ce2a36d6416016f64e5963deee29bc02f8b3.tar.gz libayatana-indicator-38c6ce2a36d6416016f64e5963deee29bc02f8b3.tar.bz2 libayatana-indicator-38c6ce2a36d6416016f64e5963deee29bc02f8b3.zip |
Adding an interests test
Diffstat (limited to 'tests/test-interests-client.c')
-rw-r--r-- | tests/test-interests-client.c | 63 |
1 files changed, 63 insertions, 0 deletions
diff --git a/tests/test-interests-client.c b/tests/test-interests-client.c new file mode 100644 index 0000000..0fe8587 --- /dev/null +++ b/tests/test-interests-client.c @@ -0,0 +1,63 @@ + +#include <glib.h> +#include "libindicate/indicator.h" +#include "libindicate/server.h" +#include "libindicate/interests.h" + +static gboolean passed = TRUE; +static GMainLoop * mainloop = NULL; +static gboolean interests[INDICATE_INTEREST_LAST] = {0}; + +static gboolean +check_interests (void) +{ + guint i; + for (i = INDICATE_INTEREST_NONE; i < INDICATE_INTEREST_LAST; i++) { + if (!interests[i]) { + return FALSE; + } + } + + return TRUE; +} + +static void +interest_added (IndicateServer * server, IndicateInterests interest) +{ + g_debug("Oh, someone is interested in my for: %d", interest); + interests[interest] = TRUE; + + if (check_interests()) { + g_main_loop_quit(mainloop); + } + + return; +} + +static gboolean +done_timeout_cb (gpointer data) +{ + g_debug("All interests not set"); + passed = FALSE; + g_main_loop_quit(mainloop); + return FALSE; +} + +int +main (int argc, char * argv) +{ + g_type_init(); + + IndicateIndicator * indicator = indicate_indicator_new(); + indicate_indicator_show(indicator); + + IndicateServer * server = indicate_server_ref_default(); + g_signal_connect(G_OBJECT(server), INDICATE_SERVER_SIGNAL_INTEREST_ADDED, G_CALLBACK(interest_added), NULL); + + g_timeout_add_seconds(10, done_timeout_cb, indicator); + + mainloop = g_main_loop_new(NULL, FALSE); + g_main_loop_run(mainloop); + + return !passed; +} |