[tracker/libtracker-sparql-porting: 35/36] libtracker-bus: Fix cancellation
- From: Jürg Billeter <juergbi src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [tracker/libtracker-sparql-porting: 35/36] libtracker-bus: Fix cancellation
- Date: Fri, 13 Aug 2010 14:34:26 +0000 (UTC)
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]