1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
|
/* -*- Mode: C; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8 -*- */
#include <stdlib.h>
#include <locale.h>
#include <libebook/libebook.h>
#include "data-test-utils.h"
static EbSqlClosure closure = { FALSE, NULL };
static void
test_create_cursor_empty_query (EbSqlFixture *fixture,
gconstpointer user_data)
{
EbSqlCursor *cursor;
EContactField sort_fields[] = { E_CONTACT_FAMILY_NAME, E_CONTACT_GIVEN_NAME };
EBookCursorSortType sort_types[] = { E_BOOK_CURSOR_SORT_ASCENDING, E_BOOK_CURSOR_SORT_ASCENDING };
GError *error = NULL;
cursor = e_book_sqlite_cursor_new (fixture->ebsql, NULL,
sort_fields, sort_types, 2, &error);
g_assert (cursor != NULL);
e_book_sqlite_cursor_free (fixture->ebsql, cursor);
}
static void
test_create_cursor_valid_query (EbSqlFixture *fixture,
gconstpointer user_data)
{
EbSqlCursor *cursor;
EContactField sort_fields[] = { E_CONTACT_FAMILY_NAME, E_CONTACT_GIVEN_NAME };
EBookCursorSortType sort_types[] = { E_BOOK_CURSOR_SORT_ASCENDING, E_BOOK_CURSOR_SORT_ASCENDING };
EBookQuery *query;
gchar *sexp;
GError *error = NULL;
query = e_book_query_field_test (E_CONTACT_FULL_NAME, E_BOOK_QUERY_IS, "James Brown");
sexp = e_book_query_to_string (query);
cursor = e_book_sqlite_cursor_new (fixture->ebsql, sexp,
sort_fields, sort_types, 2, &error);
g_assert (cursor != NULL);
e_book_sqlite_cursor_free (fixture->ebsql, cursor);
g_free (sexp);
e_book_query_unref (query);
}
static void
test_create_cursor_invalid_sort (EbSqlFixture *fixture,
gconstpointer user_data)
{
EbSqlCursor *cursor;
EContactField sort_fields[] = { E_CONTACT_TEL };
EBookCursorSortType sort_types[] = { E_BOOK_CURSOR_SORT_ASCENDING };
GError *error = NULL;
cursor = e_book_sqlite_cursor_new (fixture->ebsql, NULL,
sort_fields, sort_types, 1, &error);
g_assert (cursor == NULL);
g_assert (error);
g_assert (g_error_matches (error, E_BOOK_SQLITE_ERROR, E_BOOK_SQLITE_ERROR_INVALID_QUERY));
}
static void
test_create_cursor_missing_sort (EbSqlFixture *fixture,
gconstpointer user_data)
{
EbSqlCursor *cursor;
GError *error = NULL;
cursor = e_book_sqlite_cursor_new (fixture->ebsql, NULL, NULL, NULL, 0, &error);
g_assert (cursor == NULL);
g_assert (error);
g_assert (g_error_matches (error, E_BOOK_SQLITE_ERROR, E_BOOK_SQLITE_ERROR_INVALID_QUERY));
}
gint
main (gint argc,
gchar **argv)
{
#if !GLIB_CHECK_VERSION (2, 35, 1)
g_type_init ();
#endif
g_test_init (&argc, &argv, NULL);
/* Ensure that the client and server get the same locale */
g_assert (g_setenv ("LC_ALL", "en_US.UTF-8", TRUE));
setlocale (LC_ALL, "");
g_test_add ("/EbSqlCursor/Create/EmptyQuery", EbSqlFixture, &closure,
e_sqlite_fixture_setup, test_create_cursor_empty_query, e_sqlite_fixture_teardown);
g_test_add ("/EbSqlCursor/Create/ValidQuery", EbSqlFixture, &closure,
e_sqlite_fixture_setup, test_create_cursor_valid_query, e_sqlite_fixture_teardown);
g_test_add ("/EbSqlCursor/Create/InvalidSort", EbSqlFixture, &closure,
e_sqlite_fixture_setup, test_create_cursor_invalid_sort, e_sqlite_fixture_teardown);
g_test_add ("/EbSqlCursor/Create/MissingSort", EbSqlFixture, &closure,
e_sqlite_fixture_setup, test_create_cursor_missing_sort, e_sqlite_fixture_teardown);
return g_test_run ();
}
|