aboutsummaryrefslogtreecommitdiff
path: root/tests/test-interests-client.c
diff options
context:
space:
mode:
authorTed Gould <ted@canonical.com>2009-04-27 10:50:40 -0500
committerTed Gould <ted@canonical.com>2009-04-27 10:50:40 -0500
commit73e576b120f91aa42d8040af16a2310fb60d62c1 (patch)
tree20062dd5d0ff2f06f0b73e8540b57367ed439bbf /tests/test-interests-client.c
parent183d218f7c7d22da792b90c0014d44b088d91008 (diff)
parent0f174a8a4904e33f912fae70a6345a861306b474 (diff)
downloadlibayatana-indicator-73e576b120f91aa42d8040af16a2310fb60d62c1.tar.gz
libayatana-indicator-73e576b120f91aa42d8040af16a2310fb60d62c1.tar.bz2
libayatana-indicator-73e576b120f91aa42d8040af16a2310fb60d62c1.zip
Upstream Snapshot: Adding in a test suite.
Diffstat (limited to 'tests/test-interests-client.c')
-rw-r--r--tests/test-interests-client.c63
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..bde3b26
--- /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 + 1; 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(2, done_timeout_cb, indicator);
+
+ mainloop = g_main_loop_new(NULL, FALSE);
+ g_main_loop_run(mainloop);
+
+ return !passed;
+}