[tracker/libtracker-sparql-porting: 35/36] libtracker-bus: Fix cancellation



commit 5558d99faab0ef5bcf37269c6413f0ad406394f4
Author: Jürg Billeter <j bitron ch>
Date:   Wed Aug 11 15:54:22 2010 +0200

    libtracker-bus: Fix cancellation

 tests/tracker-steroids/tracker-test.c |   59 +++++++++++++++++++++++++++++---
 1 files changed, 53 insertions(+), 6 deletions(-)
---
diff --git a/tests/tracker-steroids/tracker-test.c b/tests/tracker-steroids/tracker-test.c
index e2d3cac..2c060bb 100644
--- a/tests/tracker-steroids/tracker-test.c
+++ b/tests/tracker-steroids/tracker-test.c
@@ -459,18 +459,42 @@ test_tracker_sparql_query_iterate_async ()
 }
 
 static void
+cancel_query_cb (GObject      *source_object,
+                 GAsyncResult *result,
+                 gpointer      user_data)
+{
+	GMainLoop *main_loop = user_data;
+	GError *error = NULL;
+
+	g_main_loop_quit (main_loop);
+
+	tracker_sparql_connection_query_finish (connection, result, &error);
+
+	g_assert (error);
+
+	g_error_free (error);
+}
+
+static void
 test_tracker_sparql_query_iterate_async_cancel ()
 {
 	const gchar *query = "SELECT ?r nie:url(?r) WHERE {?r a nfo:FileDataObject}";
+	GMainLoop *main_loop;
 	GCancellable *cancellable = g_cancellable_new ();
 
+	main_loop = g_main_loop_new (NULL, FALSE);
+
 	tracker_sparql_connection_query_async (connection,
 	                                       query,
 	                                       cancellable,
-	                                       (GAsyncReadyCallback) 42, /* will segfault if ever callback is called */
-	                                       NULL);
+	                                       cancel_query_cb,
+	                                       main_loop);
+
 	g_cancellable_cancel (cancellable);
-	g_usleep (1000000); /* Sleep one second to see if callback is called */
+
+	g_main_loop_run (main_loop);
+
+	g_main_loop_unref (main_loop);
 }
 
 static void
@@ -514,19 +538,42 @@ test_tracker_sparql_update_async ()
 }
 
 static void
+cancel_update_cb (GObject      *source_object,
+                  GAsyncResult *result,
+                  gpointer      user_data)
+{
+	GMainLoop *main_loop = user_data;
+	GError *error = NULL;
+
+	g_main_loop_quit (main_loop);
+
+	tracker_sparql_connection_update_finish (connection, result, &error);
+
+	g_assert (error);
+
+	g_error_free (error);
+}
+
+static void
 test_tracker_sparql_update_async_cancel ()
 {
 	GCancellable *cancellable = g_cancellable_new ();
 	const gchar *query = "INSERT { _:x a nmo:Message }";
+	GMainLoop *main_loop;
+
+	main_loop = g_main_loop_new (NULL, FALSE);
 
 	tracker_sparql_connection_update_async (connection,
 	                                        query,
 	                                        0,
 	                                        cancellable,
-	                                        (GAsyncReadyCallback) 42, /* will segfault if ever callback is called */
-	                                        NULL);
+	                                        cancel_update_cb,
+	                                        main_loop);
 	g_cancellable_cancel (cancellable);
-	g_usleep (1000000); /* Sleep one second to see if callback is called */
+
+	g_main_loop_run (main_loop);
+
+	g_main_loop_unref (main_loop);
 }
 
 static void



[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]