[evolution-data-server/openismus-work] test-client-custom-summary.c: Optimize test.
- From: Tristan Van Berkom <tvb src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [evolution-data-server/openismus-work] test-client-custom-summary.c: Optimize test.
- Date: Thu, 25 Apr 2013 10:46:30 +0000 (UTC)
commit 14131ebf76ba480198d3437d10f2b2acba76ca69
Author: Tristan Van Berkom <tristanvb openismus com>
Date: Tue Apr 23 19:30:51 2013 +0900
test-client-custom-summary.c: Optimize test.
Reuse the same two addressbooks for every test, so that only the
first 2 tests populate the addressbooks with contacts and the remaining
tests only create a client and execute a query.
Also add all test contacts with a single batch command and dont fetch
the test contacts, also removed the #if 0'd case which is the only
case which required the local contact copies.
tests/libebook/client/test-client-custom-summary.c | 185 +++++++++-----------
1 files changed, 80 insertions(+), 105 deletions(-)
---
diff --git a/tests/libebook/client/test-client-custom-summary.c
b/tests/libebook/client/test-client-custom-summary.c
index 83ceef1..23c8f46 100644
--- a/tests/libebook/client/test-client-custom-summary.c
+++ b/tests/libebook/client/test-client-custom-summary.c
@@ -29,6 +29,36 @@
#include "client-test-utils.h"
#include "e-test-server-utils.h"
+static void
+setup_custom_book (ESource *scratch,
+ ETestServerClosure *closure)
+{
+ ESourceBackendSummarySetup *setup;
+
+ g_type_ensure (E_TYPE_SOURCE_BACKEND_SUMMARY_SETUP);
+ setup = e_source_get_extension (scratch, E_SOURCE_EXTENSION_BACKEND_SUMMARY_SETUP);
+ e_source_backend_summary_setup_set_summary_fields (
+ setup,
+ E_CONTACT_FULL_NAME,
+ E_CONTACT_FAMILY_NAME,
+ E_CONTACT_EMAIL_1,
+ E_CONTACT_TEL,
+ E_CONTACT_EMAIL,
+ 0);
+ e_source_backend_summary_setup_set_indexed_fields (
+ setup,
+ E_CONTACT_TEL, E_BOOK_INDEX_SUFFIX,
+ E_CONTACT_TEL, E_BOOK_INDEX_PHONE,
+ E_CONTACT_FULL_NAME, E_BOOK_INDEX_PREFIX,
+ E_CONTACT_FULL_NAME, E_BOOK_INDEX_SUFFIX,
+ E_CONTACT_FAMILY_NAME, E_BOOK_INDEX_PREFIX,
+ E_CONTACT_FAMILY_NAME, E_BOOK_INDEX_SUFFIX,
+ 0);
+}
+
+static ETestServerClosure setup_custom_closure = { E_TEST_SERVER_ADDRESS_BOOK, setup_custom_book, 0, TRUE,
NULL };
+static ETestServerClosure setup_default_closure = { E_TEST_SERVER_ADDRESS_BOOK, NULL, 0, TRUE, NULL };
+
/* Define this macro to expect E_CLIENT_ERROR_NOT_SUPPORTED
* only on phone number queries when EDS is built with no
* phone number support.
@@ -39,6 +69,8 @@
# define CHECK_UNSUPPORTED_ERROR(data) (((ClientTestData *)(data))->phone_number_query != FALSE)
#endif
+#define N_CONTACTS 9
+
typedef struct {
ETestServerClosure closure;
gchar *sexp;
@@ -48,7 +80,6 @@ typedef struct {
typedef struct {
ETestServerFixture parent;
- EContact *contacts[9];
} ClientTestFixture;
static void
@@ -61,34 +92,18 @@ client_test_data_free (gpointer p)
}
static void
-setup_custom_book (ESource *scratch,
- ETestServerClosure *closure)
+client_test_setup_custom (ClientTestFixture *fixture,
+ gconstpointer user_data)
{
- ESourceBackendSummarySetup *setup;
-
- g_type_class_unref (g_type_class_ref (E_TYPE_SOURCE_BACKEND_SUMMARY_SETUP));
- setup = e_source_get_extension (scratch, E_SOURCE_EXTENSION_BACKEND_SUMMARY_SETUP);
- e_source_backend_summary_setup_set_summary_fields (setup,
- E_CONTACT_FULL_NAME,
- E_CONTACT_FAMILY_NAME,
- E_CONTACT_EMAIL_1,
- E_CONTACT_TEL,
- E_CONTACT_EMAIL,
- 0);
- e_source_backend_summary_setup_set_indexed_fields (setup,
- E_CONTACT_TEL, E_BOOK_INDEX_SUFFIX,
- E_CONTACT_TEL, E_BOOK_INDEX_PHONE,
- E_CONTACT_FULL_NAME, E_BOOK_INDEX_PREFIX,
- E_CONTACT_FULL_NAME, E_BOOK_INDEX_SUFFIX,
- E_CONTACT_FAMILY_NAME, E_BOOK_INDEX_PREFIX,
- E_CONTACT_FAMILY_NAME, E_BOOK_INDEX_SUFFIX,
- 0);
+ fixture->parent.source_name = g_strdup ("custom-book");
+ e_test_server_utils_setup (&fixture->parent, user_data);
}
static void
-client_test_setup (ClientTestFixture *fixture,
- gconstpointer user_data)
+client_test_setup_default (ClientTestFixture *fixture,
+ gconstpointer user_data)
{
+ fixture->parent.source_name = g_strdup ("default-book");
e_test_server_utils_setup (&fixture->parent, user_data);
}
@@ -96,13 +111,6 @@ static void
client_test_teardown (ClientTestFixture *fixture,
gconstpointer user_data)
{
- gint i;
-
- for (i = 0; i < G_N_ELEMENTS (fixture->contacts); ++i) {
- if (fixture->contacts[i])
- g_object_unref (fixture->contacts[i]);
- }
-
e_test_server_utils_teardown (&fixture->parent, user_data);
}
@@ -121,16 +129,20 @@ add_client_test_sexp (const gchar *prefix,
data->closure.type = direct ? E_TEST_SERVER_DIRECT_ADDRESS_BOOK : E_TEST_SERVER_ADDRESS_BOOK;
- if (custom)
- data->closure.customize = setup_custom_book;
-
data->closure.destroy_closure_func = client_test_data_free;
+ data->closure.keep_work_directory = TRUE;
data->sexp = sexp;
data->num_contacts = num_contacts;
data->phone_number_query = phone_number_query;
- g_test_add (path, ClientTestFixture, data,
- client_test_setup, func, client_test_teardown);
+ if (custom)
+ g_test_add (path, ClientTestFixture, data,
+ client_test_setup_custom, func,
+ client_test_teardown);
+ else
+ g_test_add (path, ClientTestFixture, data,
+ client_test_setup_default, func,
+ client_test_teardown);
g_free (path);
}
@@ -154,25 +166,36 @@ add_client_test (const gchar *prefix,
static void
setup_book (ClientTestFixture *fixture)
{
- EContact **it = fixture->contacts;
EBookClient *book_client;
+ GSList *contacts = NULL;
+ GError *error = NULL;
+ gint i;
book_client = E_TEST_SERVER_UTILS_SERVICE (fixture, EBookClient);
- /* Add contacts */
- if (!add_contact_from_test_case_verify (book_client, "custom-1", it++) ||
- !add_contact_from_test_case_verify (book_client, "custom-2", it++) ||
- !add_contact_from_test_case_verify (book_client, "custom-3", it++) ||
- !add_contact_from_test_case_verify (book_client, "custom-4", it++) ||
- !add_contact_from_test_case_verify (book_client, "custom-5", it++) ||
- !add_contact_from_test_case_verify (book_client, "custom-6", it++) ||
- !add_contact_from_test_case_verify (book_client, "custom-7", it++) ||
- !add_contact_from_test_case_verify (book_client, "custom-8", it++) ||
- !add_contact_from_test_case_verify (book_client, "custom-9", it++)) {
- g_error ("Failed to add contacts");
+ for (i = 0; i < N_CONTACTS; i++) {
+ gchar *case_name = g_strdup_printf ("custom-%d", i + 1);
+ gchar *vcard;
+ EContact *contact;
+
+ vcard = new_vcard_from_test_case (case_name);
+ contact = e_contact_new_from_vcard (vcard);
+ contacts = g_slist_prepend (contacts, contact);
+ g_free (vcard);
+ g_free (case_name);
}
- g_assert_cmpint (it - fixture->contacts, <=, G_N_ELEMENTS (fixture->contacts));
+ if (!e_book_client_add_contacts_sync (book_client, contacts, NULL, NULL, &error))
+ g_error ("Failed to add test contacts");
+
+ g_slist_free_full (contacts, (GDestroyNotify)g_object_unref);
+}
+
+static void
+setup_test (ClientTestFixture *fixture,
+ gconstpointer user_data)
+{
+ setup_book (fixture);
}
static void
@@ -185,7 +208,6 @@ search_test (ETestServerFixture *fixture,
const ClientTestData *const data = user_data;
book_client = E_TEST_SERVER_UTILS_SERVICE (fixture, EBookClient);
- setup_book ((ClientTestFixture *)fixture);
if (CHECK_UNSUPPORTED_ERROR (data)) {
/* Expect unsupported query (no phone number support in a phone number query) */
@@ -228,7 +250,6 @@ uid_test (ETestServerFixture *fixture,
const ClientTestData *const data = user_data;
book_client = E_TEST_SERVER_UTILS_SERVICE (fixture, EBookClient);
- setup_book ((ClientTestFixture *)fixture);
if (CHECK_UNSUPPORTED_ERROR (data)) {
/* Expect unsupported query (no phone number support in a phone number query) */
@@ -261,47 +282,6 @@ uid_test (ETestServerFixture *fixture,
e_util_free_string_slist (results);
}
-#ifdef ENABLE_PHONENUMBER
-#if 0 /* FIXME: This test is broken */
-
-static void
-locale_change_test (ClientTestFixture *fixture,
- gconstpointer user_data)
-{
- EBookClient *book_client;
- GSList *results = NULL;
- GError *error = NULL;
-
- book_client = E_TEST_SERVER_UTILS_SERVICE (fixture, EBookClient);
- setup_book (fixture);
-
- if (!e_book_client_get_contacts_uids_sync (
- book_client, "(eqphone \"phone\" \"221-5423789\" \"en_US.UTF-8\")",
- &results, NULL, &error)) {
- g_error ("get contact uids: %s", error->message);
- }
-
- g_assert_cmpint (g_slist_length (results), ==, 1);
-
- g_assert_cmpstr (
- results->data, ==,
- e_contact_get_const (fixture->contacts[0], E_CONTACT_UID));
-
- e_util_free_string_slist (results);
-
- if (!e_book_client_get_contacts_uids_sync (
- book_client, "(eqphone \"phone\" \"221-5423789\" \"en_GB.UTF-8\")",
- &results, NULL, &error)) {
- g_error ("get contact uids: %s", error->message);
- }
-
- g_assert_cmpint (g_slist_length (results), ==, 0);
- e_util_free_string_slist (results);
-}
-
-#endif
-#endif /* ENABLE_PHONENUMBER */
-
typedef struct {
gpointer func;
gboolean direct;
@@ -336,6 +316,14 @@ main (gint argc,
g_assert_cmpstr (setlocale (LC_ADDRESS, NULL), ==, "en_US.UTF-8");
+ /* Before beginning, setup two books and populate them with contacts, one with
+ * a customized summary and another without a customized summary
+ */
+ g_test_add ("/EBookClient/SetupDefaultBook", ClientTestFixture, &setup_default_closure,
+ client_test_setup_default, setup_test, client_test_teardown);
+ g_test_add ("/EBookClient/SetupCustomBook", ClientTestFixture, &setup_custom_closure,
+ client_test_setup_custom, setup_test, client_test_teardown);
+
/* Test all queries in 8 different combinations specified by the 'suites'
*/
for (i = 0; i < G_N_ELEMENTS (suites); i++) {
@@ -474,19 +462,6 @@ main (gint argc,
}
-#ifdef ENABLE_PHONENUMBER
-#if 0 /* FIXME: This test is broken */
-
- add_client_test (
- "/EBookClient", "/EqPhone/LocaleChange", locale_change_test,
- NULL, 0, FALSE, TRUE);
-
- add_client_test (
- "/EBookClient/DirectAccess", "/EqPhone/LocaleChange", locale_change_test,
- NULL, 0, TRUE, TRUE);
-#endif
-#endif /* ENABLE_PHONENUMBER */
-
ret = e_test_server_utils_run ();
return ret;
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]