[glib/wip/gmenu] Add a test for multithreaded action group exporter use
- From: Matthias Clasen <matthiasc src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [glib/wip/gmenu] Add a test for multithreaded action group exporter use
- Date: Wed, 7 Dec 2011 05:44:19 +0000 (UTC)
commit ea60b734be911e3a1235bbf00087f03d2d660c6d
Author: Matthias Clasen <mclasen redhat com>
Date: Wed Dec 7 00:43:49 2011 -0500
Add a test for multithreaded action group exporter use
gio/tests/actions.c | 74 +++++++++++++++++++++++++++++++++++++++++++++++++++
1 files changed, 74 insertions(+), 0 deletions(-)
---
diff --git a/gio/tests/actions.c b/gio/tests/actions.c
index c263842..c924438 100644
--- a/gio/tests/actions.c
+++ b/gio/tests/actions.c
@@ -624,6 +624,79 @@ test_dbus_export (void)
g_object_unref (bus);
}
+static gpointer
+do_activate (gpointer data)
+{
+ GSimpleActionGroup *group = data;
+ gint i;
+ GAction *action;
+
+ for (i = 0; i < 1000000; i++)
+ {
+ action = g_simple_action_group_lookup (group, "a");
+ g_simple_action_set_enabled (G_SIMPLE_ACTION (action),
+ !g_action_get_enabled (action));
+ }
+
+ return NULL;
+}
+
+static gpointer
+do_export (gpointer data)
+{
+ GActionGroup *group = data;
+ gint i;
+ GError *error = NULL;
+ guint id;
+ GDBusConnection *bus;
+ gchar *path;
+
+ bus = g_bus_get_sync (G_BUS_TYPE_SESSION, NULL, NULL);
+ path = g_strdup_printf("/%p", data);
+
+ for (i = 0; i < 100000; i++)
+ {
+ id = g_dbus_connection_export_action_group (bus, path, G_ACTION_GROUP (group), &error);
+ g_assert_no_error (error);
+ g_dbus_connection_unexport_action_group (bus, id);
+ }
+
+ g_free (path);
+ g_object_unref (bus);
+
+ return NULL;
+}
+
+static void
+test_dbus_threaded (void)
+{
+ GSimpleActionGroup *group[10];
+ GThread *call[10];
+ GThread *export[10];
+ static GActionEntry entries[] = {
+ { "a", activate_action, NULL, NULL, NULL },
+ { "b", activate_action, NULL, NULL, NULL },
+ };
+ gint i;
+
+ for (i = 0; i < 10; i++)
+ {
+ group[i] = g_simple_action_group_new ();
+ g_simple_action_group_add_entries (group[i], entries, G_N_ELEMENTS (entries), NULL);
+ call[i] = g_thread_new ("call", do_activate, group[i]);
+ export[i] = g_thread_new ("export", do_export, group[i]);
+ }
+
+ for (i = 0; i < 10; i++)
+ {
+ g_thread_join (call[i]);
+ g_thread_join (export[i]);
+ }
+
+ for (i = 0; i < 10; i++)
+ g_object_unref (group[i]);
+}
+
int
main (int argc, char **argv)
{
@@ -635,6 +708,7 @@ main (int argc, char **argv)
g_test_add_func ("/actions/stateful", test_stateful);
g_test_add_func ("/actions/entries", test_entries);
g_test_add_func ("/actions/dbus/export", test_dbus_export);
+ g_test_add_func ("/actions/dbus/threaded", test_dbus_threaded);
return g_test_run ();
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]