aboutsummaryrefslogtreecommitdiff
path: root/tests/test-thousand-indicators-server.c
diff options
context:
space:
mode:
authorTed Gould <ted@canonical.com>2009-04-20 15:39:42 -0500
committerTed Gould <ted@canonical.com>2009-04-20 15:39:42 -0500
commit6f87e9c09f9894db7fd6f42f65c8eb147c42a6e8 (patch)
treeb03356ce09b5d5cb1ac5b21b9aadfa1de586fddf /tests/test-thousand-indicators-server.c
parentecad1e36dce18875461e76d2a47d8a0e11570ff6 (diff)
downloadlibayatana-indicator-6f87e9c09f9894db7fd6f42f65c8eb147c42a6e8.tar.gz
libayatana-indicator-6f87e9c09f9894db7fd6f42f65c8eb147c42a6e8.tar.bz2
libayatana-indicator-6f87e9c09f9894db7fd6f42f65c8eb147c42a6e8.zip
Adding a test to build a bunch of indicators
Diffstat (limited to 'tests/test-thousand-indicators-server.c')
-rw-r--r--tests/test-thousand-indicators-server.c43
1 files changed, 43 insertions, 0 deletions
diff --git a/tests/test-thousand-indicators-server.c b/tests/test-thousand-indicators-server.c
new file mode 100644
index 0000000..285e56b
--- /dev/null
+++ b/tests/test-thousand-indicators-server.c
@@ -0,0 +1,43 @@
+
+#include <glib.h>
+#include "libindicate/listener.h"
+
+static gboolean passed = TRUE;
+static GMainLoop * mainloop = NULL;
+static guint indicator_count = 0;
+
+static void
+indicator_added (IndicateListener * listener, IndicateListenerServer * server, IndicateListenerIndicator * indicator, gchar * type, gpointer data)
+{
+ g_debug("Indicator Added: %s %d %s", INDICATE_LISTENER_SERVER_DBUS_NAME(server), INDICATE_LISTENER_INDICATOR_ID(indicator), type);
+ indicator_count++;
+ if (indicator_count == 1000) {
+ g_main_loop_quit(mainloop);
+ }
+}
+
+static gboolean
+failed_cb (gpointer data)
+{
+ g_debug("Failed to get a server in 5 seconds.");
+ passed = FALSE;
+ g_main_loop_quit(mainloop);
+ return FALSE;
+}
+
+int
+main (int argc, char * argv)
+{
+ g_type_init();
+
+ IndicateListener * listener = indicate_listener_ref_default();
+
+ g_signal_connect(listener, INDICATE_LISTENER_SIGNAL_INDICATOR_ADDED, G_CALLBACK(indicator_added), NULL);
+
+ g_timeout_add_seconds(5, failed_cb, NULL);
+
+ mainloop = g_main_loop_new(NULL, FALSE);
+ g_main_loop_run(mainloop);
+
+ return !passed;
+}