[glib] gdbus tests: remove buggy use of GMainLoop
- From: Ryan Lortie <ryanl src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [glib] gdbus tests: remove buggy use of GMainLoop
- Date: Wed, 14 Dec 2011 14:56:59 +0000 (UTC)
commit 0a7930d04879018b5ea451ee9708f40fe93a131e
Author: Ryan Lortie <desrt desrt ca>
Date: Tue Dec 13 20:54:24 2011 -0500
gdbus tests: remove buggy use of GMainLoop
g_main_loop_quit() only quits mainloops that are currently running --
not ones that may run in the future. The way the gdbus-threading tests
are written can possibly result in a call to g_main_loop_quit() before
g_main_loop_run() has started.
The mainloops aren't actually used for anything other than signalling
the completion of the threads, so just use g_thread_join() for that.
https://bugzilla.gnome.org/show_bug.cgi?id=666129
gio/tests/gdbus-threading.c | 25 -------------------------
1 files changed, 0 insertions(+), 25 deletions(-)
---
diff --git a/gio/tests/gdbus-threading.c b/gio/tests/gdbus-threading.c
index be85513..1736e60 100644
--- a/gio/tests/gdbus-threading.c
+++ b/gio/tests/gdbus-threading.c
@@ -29,9 +29,6 @@
/* all tests rely on a global connection */
static GDBusConnection *c = NULL;
-/* all tests rely on a shared mainloop */
-static GMainLoop *loop = NULL;
-
/* ---------------------------------------------------------------------------------------------------- */
/* Ensure that signal and method replies are delivered in the right thread */
/* ---------------------------------------------------------------------------------------------------- */
@@ -221,8 +218,6 @@ test_delivery_in_thread_func (gpointer _data)
g_main_loop_unref (thread_loop);
g_main_context_unref (thread_context);
- g_main_loop_quit (loop);
-
return NULL;
}
@@ -235,9 +230,6 @@ test_delivery_in_thread (void)
test_delivery_in_thread_func,
NULL);
- /* run the event loop - it is needed to dispatch D-Bus messages */
- g_main_loop_run (loop);
-
g_thread_join (thread);
}
@@ -251,8 +243,6 @@ typedef struct {
GMainLoop *thread_loop;
GThread *thread;
-
- gboolean done;
} SyncThreadData;
static void
@@ -337,9 +327,6 @@ test_sleep_in_thread_func (gpointer _data)
g_main_loop_unref (data->thread_loop);
g_main_context_unref (thread_context);
- data->done = TRUE;
- g_main_loop_quit (loop);
-
return NULL;
}
@@ -386,7 +373,6 @@ test_method_calls_on_proxy (GDBusProxy *proxy)
data1.msec = 40;
data1.num = 100;
data1.async = do_async;
- data1.done = FALSE;
thread1 = g_thread_new ("sleep",
test_sleep_in_thread_func,
&data1);
@@ -395,7 +381,6 @@ test_method_calls_on_proxy (GDBusProxy *proxy)
data2.msec = 20;
data2.num = 200;
data2.async = do_async;
- data2.done = FALSE;
thread2 = g_thread_new ("sleep2",
test_sleep_in_thread_func,
&data2);
@@ -404,15 +389,10 @@ test_method_calls_on_proxy (GDBusProxy *proxy)
data3.msec = 100;
data3.num = 40;
data3.async = do_async;
- data3.done = FALSE;
thread3 = g_thread_new ("sleep3",
test_sleep_in_thread_func,
&data3);
- /* we handle messages in the main loop - threads will quit it when they are done */
- while (!(data1.done && data2.done && data3.done))
- g_main_loop_run (loop);
-
g_thread_join (thread1);
g_thread_join (thread2);
g_thread_join (thread3);
@@ -430,8 +410,6 @@ test_method_calls_on_proxy (GDBusProxy *proxy)
g_print (" ");
}
-
- g_main_loop_quit (loop);
}
static void
@@ -480,9 +458,6 @@ main (int argc,
g_type_init ();
g_test_init (&argc, &argv, NULL);
- /* all the tests rely on a shared main loop */
- loop = g_main_loop_new (NULL, FALSE);
-
/* all the tests use a session bus with a well-known address that we can bring up and down
* using session_bus_up() and session_bus_down().
*/
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]