[evolution-data-server/openismus-work-master] Added test to show that fields-of-interest is working in libecal
- From: Tristan Van Berkom <tvb src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [evolution-data-server/openismus-work-master] Added test to show that fields-of-interest is working in libecal
- Date: Thu, 18 Aug 2011 17:42:41 +0000 (UTC)
commit 9b5d54f933dcbc72b1b80c3c2cd9011ad5e49b5e
Author: Tristan Van Berkom <tristan van berkom gmail com>
Date: Thu Aug 18 19:41:43 2011 +0200
Added test to show that fields-of-interest is working in libecal
Test is based on test-client-get-view.c, this version of the test
sets fields-of-interest to UID, RECURRENCE-ID and LAST-MODIFIED
fields, tests that all those fields are returned and asserts that
the event summary (which is indeed set) is always NULL.
tests/libecal/client/Makefile.am | 3 +
tests/libecal/client/test-client-revision-view.c | 283 ++++++++++++++++++++++
2 files changed, 286 insertions(+), 0 deletions(-)
---
diff --git a/tests/libecal/client/Makefile.am b/tests/libecal/client/Makefile.am
index 93672d6..68037ca 100644
--- a/tests/libecal/client/Makefile.am
+++ b/tests/libecal/client/Makefile.am
@@ -33,6 +33,7 @@ TESTS = \
test-client-receive-objects \
test-client-get-attachment-uris \
test-client-get-view \
+ test-client-revision-view \
test-client-stress-views \
test-client-stress-factory--serial \
test-client-stress-factory--fifo \
@@ -66,6 +67,8 @@ test_client_get_object_list_LDADD=$(TEST_LIBS)
test_client_get_object_list_CPPFLAGS=$(TEST_CPPFLAGS)
test_client_get_view_LDADD=$(TEST_LIBS)
test_client_get_view_CPPFLAGS=$(TEST_CPPFLAGS)
+test_client_revision_view_LDADD=$(TEST_LIBS)
+test_client_revision_view_CPPFLAGS=$(TEST_CPPFLAGS)
test_client_modify_object_LDADD=$(TEST_LIBS)
test_client_modify_object_CPPFLAGS=$(TEST_CPPFLAGS)
test_client_get_revision_LDADD=$(TEST_LIBS)
diff --git a/tests/libecal/client/test-client-revision-view.c b/tests/libecal/client/test-client-revision-view.c
new file mode 100644
index 0000000..6ee9e75
--- /dev/null
+++ b/tests/libecal/client/test-client-revision-view.c
@@ -0,0 +1,283 @@
+/* -*- Mode: C; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8 -*- */
+
+#include <stdlib.h>
+#include <libecal/e-cal-client.h>
+#include <libical/ical.h>
+
+#include "client-test-utils.h"
+
+typedef enum {
+ SUBTEST_OBJECTS_ADDED,
+ SUBTEST_OBJECTS_MODIFIED,
+ SUBTEST_OBJECTS_REMOVED,
+ SUBTEST_VIEW_DONE,
+ NUM_SUBTESTS,
+ SUBTEST_RESET
+} SubTestId;
+
+static void
+subtest_passed (SubTestId id)
+{
+ static guint subtests_complete = 0;
+
+ if (id == SUBTEST_RESET) {
+ subtests_complete = 0;
+ return;
+ }
+
+ subtests_complete |= (1 << id);
+
+ if (subtests_complete == ((1 << NUM_SUBTESTS) - 1))
+ stop_main_loop (0);
+}
+
+
+static struct icaltimetype
+get_last_modified (icalcomponent *component)
+{
+ icalcomponent *inner = icalcomponent_get_inner(component);
+ icalproperty *prop;
+
+ prop = icalcomponent_get_first_property(inner, ICAL_LASTMODIFIED_PROPERTY);
+
+ if (prop == 0){
+ return icaltime_null_time();
+ }
+
+ return icalproperty_get_lastmodified (prop);
+}
+
+static void
+objects_added_cb (GObject *object, const GSList *objects, gpointer data)
+{
+ const GSList *l;
+
+ for (l = objects; l; l = l->next) {
+ icalcomponent *component = l->data;
+ struct icaltimetype recurrence = icalcomponent_get_recurrenceid (component);
+ struct icaltimetype last_modified = get_last_modified (component);
+
+ g_print ("Object added %s (recurrence id:%s, last-modified:%s)\n",
+ icalcomponent_get_uid (component),
+ icaltime_as_ical_string (recurrence),
+ icaltime_as_ical_string (last_modified));
+
+ g_assert (icalcomponent_get_summary (component) == NULL);
+ }
+
+ subtest_passed (SUBTEST_OBJECTS_ADDED);
+}
+
+static void
+objects_modified_cb (GObject *object, const GSList *objects, gpointer data)
+{
+ const GSList *l;
+
+ for (l = objects; l; l = l->next) {
+ icalcomponent *component = l->data;
+ struct icaltimetype recurrence = icalcomponent_get_recurrenceid (component);
+ struct icaltimetype last_modified = get_last_modified (component);
+
+ g_print ("Object modified %s (recurrence id:%s, last-modified:%s)\n",
+ icalcomponent_get_uid (component),
+ icaltime_as_ical_string (recurrence),
+ icaltime_as_ical_string (last_modified));
+
+ g_assert (icalcomponent_get_summary (component) == NULL);
+ }
+
+ subtest_passed (SUBTEST_OBJECTS_MODIFIED);
+}
+
+static void
+objects_removed_cb (GObject *object, const GSList *objects, gpointer data)
+{
+ const GSList *l;
+
+ for (l = objects; l; l = l->next) {
+ ECalComponentId *id = l->data;
+
+ g_print ("Object removed: uid: %s, rid: %s\n", id->uid, id->rid);
+ }
+
+ subtest_passed (SUBTEST_OBJECTS_REMOVED);
+}
+
+static void
+complete_cb (GObject *object, const GError *error, gpointer data)
+{
+ g_print ("View complete (status: %d, error_msg:%s)\n", error ? error->code : 0, error ? error->message : "NULL");
+
+ subtest_passed (SUBTEST_VIEW_DONE);
+}
+
+static gpointer
+alter_cal_client (gpointer user_data)
+{
+ ECalClient *cal_client = user_data;
+ GError *error = NULL;
+ icalcomponent *icalcomp;
+ struct icaltimetype now;
+ gchar *uid = NULL;
+
+ g_return_val_if_fail (cal_client != NULL, NULL);
+
+ now = icaltime_current_time_with_zone (icaltimezone_get_utc_timezone ());
+ icalcomp = icalcomponent_new (ICAL_VEVENT_COMPONENT);
+ icalcomponent_set_summary (icalcomp, "Initial event summary");
+ icalcomponent_set_dtstart (icalcomp, now);
+ icalcomponent_set_dtend (icalcomp, icaltime_from_timet (icaltime_as_timet (now) + 60 * 60 * 60, 0));
+
+ if (!e_cal_client_create_object_sync (cal_client, icalcomp, &uid, NULL, &error)) {
+ report_error ("create object sync", &error);
+ icalcomponent_free (icalcomp);
+ stop_main_loop (1);
+ return NULL;
+ }
+
+ icalcomponent_set_uid (icalcomp, uid);
+ icalcomponent_set_recurrenceid (icalcomp,
+ icaltime_from_timet (icaltime_as_timet (now) + 60 * 60 * 60, 0));
+ icalcomponent_set_summary (icalcomp, "Modified event summary");
+
+ if (!e_cal_client_modify_object_sync (cal_client, icalcomp, CALOBJ_MOD_ALL, NULL, &error)) {
+ report_error ("modify object sync", &error);
+ icalcomponent_free (icalcomp);
+ g_free (uid);
+ stop_main_loop (1);
+ return NULL;
+ }
+
+ if (!e_cal_client_remove_object_sync (cal_client, uid, NULL, CALOBJ_MOD_ALL, NULL, &error)) {
+ report_error ("remove object sync", &error);
+ icalcomponent_free (icalcomp);
+ g_free (uid);
+ stop_main_loop (1);
+ return NULL;
+ }
+
+ g_free (uid);
+ icalcomponent_free (icalcomp);
+
+ return NULL;
+}
+
+static void
+async_get_view_ready (GObject *source_object, GAsyncResult *result, gpointer user_data)
+{
+ ECalClient *cal_client = E_CAL_CLIENT (source_object);
+ ECalClientView *view = NULL;
+ GError *error = NULL;
+ GSList *field_list = NULL;
+
+ g_return_if_fail (cal_client != NULL);
+
+ if (!e_cal_client_get_view_finish (cal_client, result, &view, &error)) {
+ report_error ("get view finish", &error);
+ stop_main_loop (1);
+ return;
+ }
+
+ subtest_passed (SUBTEST_RESET);
+ g_signal_connect (view, "objects_added", G_CALLBACK (objects_added_cb), cal_client);
+ g_signal_connect (view, "objects_modified", G_CALLBACK (objects_modified_cb), cal_client);
+ g_signal_connect (view, "objects_removed", G_CALLBACK (objects_removed_cb), cal_client);
+ g_signal_connect (view, "complete", G_CALLBACK (complete_cb), cal_client);
+
+ g_object_set_data_full (G_OBJECT (cal_client), "cal-view", view, g_object_unref);
+
+ field_list = g_slist_prepend (NULL, (gpointer) "UID");
+ field_list = g_slist_prepend (field_list, (gpointer) "RECURRENCE-ID");
+ field_list = g_slist_prepend (field_list, (gpointer) "LAST-MODIFIED");
+
+ e_cal_client_view_set_fields_of_interest (view, field_list, &error);
+ if (error)
+ report_error ("set fields of interest", &error);
+ g_slist_free (field_list);
+
+ e_cal_client_view_start (view, NULL);
+
+ alter_cal_client (cal_client);
+}
+
+static gpointer
+get_view_async (gpointer user_data)
+{
+ ECalClient *cal_client = user_data;
+
+ g_return_val_if_fail (user_data != NULL, NULL);
+
+ e_cal_client_get_view (cal_client, "(contains? \"any\" \"event\")", NULL, async_get_view_ready, NULL);
+
+ return NULL;
+}
+
+gint
+main (gint argc, gchar **argv)
+{
+ ECalClientView *view = NULL;
+ ECalClient *cal_client;
+ GError *error = NULL;
+ GSList *field_list = NULL;
+
+ main_initialize ();
+
+ cal_client = new_temp_client (E_CAL_CLIENT_SOURCE_TYPE_EVENTS, NULL);
+ g_return_val_if_fail (cal_client != NULL, FALSE);
+
+
+ if (!e_client_open_sync (E_CLIENT (cal_client), FALSE, NULL, &error)) {
+ report_error ("client open sync", &error);
+ g_object_unref (cal_client);
+ return 1;
+ }
+
+ if (!e_cal_client_get_view_sync (cal_client, "(contains? \"any\" \"event\")", &view, NULL, &error)) {
+ report_error ("get view sync", &error);
+ g_object_unref (cal_client);
+ return 1;
+ }
+
+ subtest_passed (SUBTEST_RESET);
+ g_signal_connect (view, "objects_added", G_CALLBACK (objects_added_cb), cal_client);
+ g_signal_connect (view, "objects_modified", G_CALLBACK (objects_modified_cb), cal_client);
+ g_signal_connect (view, "objects_removed", G_CALLBACK (objects_removed_cb), cal_client);
+ g_signal_connect (view, "complete", G_CALLBACK (complete_cb), cal_client);
+
+ field_list = g_slist_prepend (NULL, (gpointer) "UID");
+ field_list = g_slist_prepend (field_list, (gpointer) "RECURRENCE-ID");
+ field_list = g_slist_prepend (field_list, (gpointer) "LAST-MODIFIED");
+
+ e_cal_client_view_set_fields_of_interest (view, field_list, &error);
+ if (error)
+ report_error ("set fields of interest", &error);
+ g_slist_free (field_list);
+
+ e_cal_client_view_start (view, NULL);
+
+ start_in_thread_with_main_loop (alter_cal_client, cal_client);
+
+ g_object_unref (view);
+
+ if (get_main_loop_stop_result () != 0) {
+ g_object_unref (cal_client);
+ return get_main_loop_stop_result ();
+ }
+
+ start_in_idle_with_main_loop (get_view_async, cal_client);
+
+ g_object_set_data (G_OBJECT (cal_client), "cal-view", NULL);
+
+ if (!e_client_remove_sync (E_CLIENT (cal_client), NULL, &error)) {
+ report_error ("client remove sync", &error);
+ g_object_unref (cal_client);
+ return 1;
+ }
+
+ g_object_unref (cal_client);
+
+ if (get_main_loop_stop_result () == 0)
+ g_print ("Test finished successfully.\n");
+
+ return get_main_loop_stop_result ();
+}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]