Mon, 10 Oct 2022 00:38:48 -0500
Add some api for handling SQLite3 migrations
Also port the SqliteHistoryAdapter to the new api.
Testing Done:
Ran the unit tests under valgrind and checked out code coverage which is really just missing error handling I can't test.
Bugs closed: PIDGIN-17695
Reviewed at https://reviews.imfreedom.org/r/1906/
|
41804
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
1 | /* |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
2 | * Purple - Internet Messaging Library |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
3 | * Copyright (C) Pidgin Developers <devel@pidgin.im> |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
4 | * |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
5 | * This library is free software; you can redistribute it and/or |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
6 | * modify it under the terms of the GNU Lesser General Public |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
7 | * License as published by the Free Software Foundation; either |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
8 | * version 2 of the License, or (at your option) any later version. |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
9 | * |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
10 | * This library is distributed in the hope that it will be useful, |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
11 | * but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
12 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
13 | * Lesser General Public License for more details. |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
14 | * |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
15 | * You should have received a copy of the GNU Lesser General Public |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
16 | * License along with this library; if not, see <https://www.gnu.org/licenses/>. |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
17 | */ |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
18 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
19 | #include <glib.h> |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
20 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
21 | #include <sqlite3.h> |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
22 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
23 | #include <purple.h> |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
24 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
25 | /****************************************************************************** |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
26 | * get schema version tests |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
27 | *****************************************************************************/ |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
28 | static void |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
29 | test_sqlite3_get_schema_version_null(void) { |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
30 | if(g_test_subprocess()) { |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
31 | GError *error = NULL; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
32 | int version = 0; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
33 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
34 | version = purple_sqlite3_get_schema_version(NULL, &error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
35 | g_assert_error(error, PURPLE_SQLITE3_DOMAIN, 0); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
36 | g_assert_cmpint(version, ==, -1); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
37 | } |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
38 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
39 | g_test_trap_subprocess(NULL, 0, 0); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
40 | g_test_trap_assert_failed(); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
41 | g_test_trap_assert_stderr("*assertion*!= NULL*"); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
42 | } |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
43 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
44 | static void |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
45 | test_sqlite3_get_schema_version_new(void) { |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
46 | GError *error = NULL; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
47 | sqlite3 *db = NULL; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
48 | int rc = 0; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
49 | int version = 0; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
50 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
51 | rc = sqlite3_open(":memory:", &db); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
52 | g_assert_nonnull(db); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
53 | g_assert_cmpint(rc, ==, SQLITE_OK); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
54 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
55 | version = purple_sqlite3_get_schema_version(db, &error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
56 | g_assert_no_error(error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
57 | g_assert_cmpint(version, ==, 0); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
58 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
59 | rc = sqlite3_close(db); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
60 | g_assert_cmpint(rc, ==, SQLITE_OK); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
61 | } |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
62 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
63 | /****************************************************************************** |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
64 | * string migration tests |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
65 | *****************************************************************************/ |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
66 | static void |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
67 | test_sqlite3_string_migrations_null(void) { |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
68 | if(g_test_subprocess()) { |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
69 | GError *error = NULL; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
70 | sqlite3 *db = NULL; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
71 | gboolean res = FALSE; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
72 | int rc = 0; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
73 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
74 | rc = sqlite3_open(":memory:", &db); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
75 | g_assert_nonnull(db); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
76 | g_assert_cmpint(rc, ==, SQLITE_OK); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
77 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
78 | res = purple_sqlite3_run_migrations_from_strings(db, NULL, &error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
79 | g_assert_no_error(error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
80 | g_assert_false(res); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
81 | } |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
82 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
83 | g_test_trap_subprocess(NULL, 0, 0); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
84 | g_test_trap_assert_failed(); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
85 | g_test_trap_assert_stderr("*migrations != NULL*"); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
86 | } |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
87 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
88 | static void |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
89 | test_sqlite3_string_migrations_null_terminator(void) { |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
90 | GError *error = NULL; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
91 | sqlite3 *db = NULL; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
92 | gboolean res = FALSE; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
93 | int rc = 0; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
94 | int version = -1; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
95 | const char *migrations[] = {NULL}; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
96 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
97 | rc = sqlite3_open(":memory:", &db); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
98 | g_assert_nonnull(db); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
99 | g_assert_cmpint(rc, ==, SQLITE_OK); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
100 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
101 | res = purple_sqlite3_run_migrations_from_strings(db, migrations, &error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
102 | g_assert_no_error(error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
103 | g_assert_true(res); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
104 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
105 | version = purple_sqlite3_get_schema_version(db, &error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
106 | g_assert_no_error(error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
107 | g_assert_cmpint(version, ==, 0); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
108 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
109 | rc = sqlite3_close(db); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
110 | g_assert_cmpint(rc, ==, SQLITE_OK); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
111 | } |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
112 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
113 | static void |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
114 | test_sqlite3_string_migrations_multiple(void) { |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
115 | GError *error = NULL; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
116 | sqlite3 *db = NULL; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
117 | gboolean res = FALSE; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
118 | int rc = 0; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
119 | int version = -1; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
120 | const char *migrations[] = { |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
121 | "CREATE TABLE foo(a TEXT); CREATE TABLE bar(b TEXT);", |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
122 | "CREATE TABLE baz(c TEXT);", |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
123 | NULL |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
124 | }; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
125 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
126 | rc = sqlite3_open(":memory:", &db); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
127 | g_assert_nonnull(db); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
128 | g_assert_cmpint(rc, ==, SQLITE_OK); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
129 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
130 | res = purple_sqlite3_run_migrations_from_strings(db, migrations, &error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
131 | g_assert_no_error(error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
132 | g_assert_true(res); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
133 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
134 | version = purple_sqlite3_get_schema_version(db, &error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
135 | g_assert_no_error(error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
136 | g_assert_cmpint(version, ==, 2); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
137 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
138 | /* Run the migrations again and make sure we remain at schema version 2. */ |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
139 | res = purple_sqlite3_run_migrations_from_strings(db, migrations, &error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
140 | g_assert_no_error(error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
141 | g_assert_true(res); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
142 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
143 | version = purple_sqlite3_get_schema_version(db, &error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
144 | g_assert_no_error(error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
145 | g_assert_cmpint(version, ==, 2); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
146 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
147 | rc = sqlite3_close(db); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
148 | g_assert_cmpint(rc, ==, SQLITE_OK); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
149 | } |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
150 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
151 | static void |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
152 | test_sqlite3_string_migrations_syntax_error(void) { |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
153 | GError *error = NULL; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
154 | sqlite3 *db = NULL; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
155 | gboolean res = FALSE; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
156 | int rc = 0; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
157 | int version = -1; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
158 | const char *migrations[] = { |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
159 | "CREATE TABLE broke(a TEXT", |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
160 | NULL |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
161 | }; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
162 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
163 | rc = sqlite3_open(":memory:", &db); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
164 | g_assert_nonnull(db); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
165 | g_assert_cmpint(rc, ==, SQLITE_OK); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
166 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
167 | res = purple_sqlite3_run_migrations_from_strings(db, migrations, &error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
168 | g_assert_error(error, PURPLE_SQLITE3_DOMAIN, 0); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
169 | g_clear_error(&error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
170 | g_assert_false(res); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
171 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
172 | version = purple_sqlite3_get_schema_version(db, &error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
173 | g_assert_no_error(error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
174 | g_assert_cmpint(version, ==, 0); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
175 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
176 | rc = sqlite3_close(db); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
177 | g_assert_cmpint(rc, ==, SQLITE_OK); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
178 | } |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
179 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
180 | static void |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
181 | test_sqlite3_string_migrations_older(void) { |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
182 | GError *error = NULL; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
183 | sqlite3 *db = NULL; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
184 | gboolean res = FALSE; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
185 | int rc = 0; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
186 | int version = -1; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
187 | const char *migrations1[] = { |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
188 | "CREATE TABLE foo(a TEXT); CREATE TABLE bar(b TEXT);", |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
189 | "CREATE TABLE baz(c TEXT);", |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
190 | NULL |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
191 | }; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
192 | const char *migrations2[] = { |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
193 | "CREATE TABLE foo(a TEXT); CREATE TABLE bar(b TEXT);", |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
194 | NULL |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
195 | }; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
196 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
197 | rc = sqlite3_open(":memory:", &db); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
198 | g_assert_nonnull(db); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
199 | g_assert_cmpint(rc, ==, SQLITE_OK); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
200 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
201 | res = purple_sqlite3_run_migrations_from_strings(db, migrations1, &error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
202 | g_assert_no_error(error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
203 | g_assert_true(res); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
204 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
205 | version = purple_sqlite3_get_schema_version(db, &error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
206 | g_assert_no_error(error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
207 | g_assert_cmpint(version, ==, 2); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
208 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
209 | /* Run the older migrations now and verify we get a failure. */ |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
210 | res = purple_sqlite3_run_migrations_from_strings(db, migrations2, &error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
211 | g_assert_error(error, PURPLE_SQLITE3_DOMAIN, 0); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
212 | g_clear_error(&error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
213 | g_assert_false(res); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
214 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
215 | version = purple_sqlite3_get_schema_version(db, &error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
216 | g_assert_no_error(error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
217 | g_assert_cmpint(version, ==, 2); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
218 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
219 | rc = sqlite3_close(db); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
220 | g_assert_cmpint(rc, ==, SQLITE_OK); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
221 | } |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
222 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
223 | /****************************************************************************** |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
224 | * resource migration tests |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
225 | *****************************************************************************/ |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
226 | static void |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
227 | test_sqlite3_resource_migrations_null_path(void) { |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
228 | if(g_test_subprocess()) { |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
229 | GError *error = NULL; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
230 | sqlite3 *db = NULL; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
231 | gboolean res = FALSE; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
232 | int rc = 0; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
233 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
234 | rc = sqlite3_open(":memory:", &db); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
235 | g_assert_nonnull(db); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
236 | g_assert_cmpint(rc, ==, SQLITE_OK); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
237 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
238 | res = purple_sqlite3_run_migrations_from_resources(db, NULL, NULL, |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
239 | &error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
240 | g_assert_no_error(error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
241 | g_assert_false(res); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
242 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
243 | rc = sqlite3_close(db); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
244 | g_assert_cmpint(rc, ==, SQLITE_OK); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
245 | } |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
246 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
247 | g_test_trap_subprocess(NULL, 0, 0); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
248 | g_test_trap_assert_failed(); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
249 | g_test_trap_assert_stderr("*path != NULL*"); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
250 | } |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
251 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
252 | static void |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
253 | test_sqlite3_resource_migrations_null_migrations(void) { |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
254 | if(g_test_subprocess()) { |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
255 | GError *error = NULL; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
256 | sqlite3 *db = NULL; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
257 | gboolean res = FALSE; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
258 | const char *path = "/im/libpidgin/purple/tests/sqlite3/"; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
259 | int rc = 0; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
260 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
261 | rc = sqlite3_open(":memory:", &db); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
262 | g_assert_nonnull(db); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
263 | g_assert_cmpint(rc, ==, SQLITE_OK); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
264 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
265 | res = purple_sqlite3_run_migrations_from_resources(db, path, NULL, |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
266 | &error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
267 | g_assert_no_error(error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
268 | g_assert_false(res); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
269 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
270 | rc = sqlite3_close(db); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
271 | g_assert_cmpint(rc, ==, SQLITE_OK); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
272 | } |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
273 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
274 | g_test_trap_subprocess(NULL, 0, 0); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
275 | g_test_trap_assert_failed(); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
276 | g_test_trap_assert_stderr("*migrations != NULL*"); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
277 | } |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
278 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
279 | static void |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
280 | test_sqlite3_resource_migrations_null_terminator(void) { |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
281 | GError *error = NULL; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
282 | sqlite3 *db = NULL; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
283 | gboolean res = FALSE; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
284 | int rc = 0; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
285 | int version = -1; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
286 | const char *migrations[] = {NULL}; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
287 | const char *path = "/im/pidgin/libpurple/tests/sqlite3/"; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
288 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
289 | rc = sqlite3_open(":memory:", &db); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
290 | g_assert_nonnull(db); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
291 | g_assert_cmpint(rc, ==, SQLITE_OK); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
292 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
293 | res = purple_sqlite3_run_migrations_from_resources(db, path, migrations, |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
294 | &error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
295 | g_assert_no_error(error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
296 | g_assert_true(res); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
297 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
298 | version = purple_sqlite3_get_schema_version(db, &error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
299 | g_assert_no_error(error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
300 | g_assert_cmpint(version, ==, 0); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
301 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
302 | rc = sqlite3_close(db); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
303 | g_assert_cmpint(rc, ==, SQLITE_OK); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
304 | } |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
305 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
306 | static void |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
307 | test_sqlite3_resource_migrations_multiple(void) { |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
308 | GError *error = NULL; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
309 | sqlite3 *db = NULL; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
310 | gboolean res = FALSE; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
311 | int rc = 0; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
312 | int version = -1; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
313 | const char *migrations[] = {"initial.sql", "secondary.sql", NULL}; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
314 | const char *path = "/im/pidgin/libpurple/tests/sqlite3/"; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
315 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
316 | rc = sqlite3_open(":memory:", &db); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
317 | g_assert_nonnull(db); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
318 | g_assert_cmpint(rc, ==, SQLITE_OK); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
319 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
320 | res = purple_sqlite3_run_migrations_from_resources(db, path, migrations, |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
321 | &error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
322 | g_assert_no_error(error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
323 | g_assert_true(res); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
324 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
325 | version = purple_sqlite3_get_schema_version(db, &error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
326 | g_assert_no_error(error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
327 | g_assert_cmpint(version, ==, 2); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
328 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
329 | /* Run the migrations again and make sure we remain at schema version 2. */ |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
330 | res = purple_sqlite3_run_migrations_from_strings(db, migrations, &error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
331 | g_assert_no_error(error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
332 | g_assert_true(res); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
333 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
334 | version = purple_sqlite3_get_schema_version(db, &error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
335 | g_assert_no_error(error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
336 | g_assert_cmpint(version, ==, 2); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
337 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
338 | rc = sqlite3_close(db); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
339 | g_assert_cmpint(rc, ==, SQLITE_OK); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
340 | } |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
341 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
342 | static void |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
343 | test_sqlite3_resource_migrations_missing(void) { |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
344 | GError *error = NULL; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
345 | sqlite3 *db = NULL; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
346 | gboolean res = FALSE; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
347 | int rc = 0; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
348 | int version = -1; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
349 | const char *migrations[] = {"initial.sql", "imaginary.sql", NULL}; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
350 | const char *path = "/im/pidgin/libpurple/tests/sqlite3/"; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
351 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
352 | rc = sqlite3_open(":memory:", &db); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
353 | g_assert_nonnull(db); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
354 | g_assert_cmpint(rc, ==, SQLITE_OK); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
355 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
356 | res = purple_sqlite3_run_migrations_from_resources(db, path, migrations, |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
357 | &error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
358 | g_assert_error(error, G_RESOURCE_ERROR, 0); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
359 | g_clear_error(&error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
360 | g_assert_false(res); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
361 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
362 | version = purple_sqlite3_get_schema_version(db, &error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
363 | g_assert_no_error(error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
364 | g_assert_cmpint(version, ==, 1); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
365 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
366 | rc = sqlite3_close(db); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
367 | g_assert_cmpint(rc, ==, SQLITE_OK); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
368 | } |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
369 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
370 | static void |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
371 | test_sqlite3_resource_migrations_syntax_error(void) { |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
372 | GError *error = NULL; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
373 | sqlite3 *db = NULL; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
374 | gboolean res = FALSE; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
375 | int rc = 0; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
376 | int version = -1; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
377 | const char *migrations[] = {"malformed.sql", NULL}; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
378 | const char *path = "/im/pidgin/libpurple/tests/sqlite3/"; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
379 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
380 | rc = sqlite3_open(":memory:", &db); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
381 | g_assert_nonnull(db); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
382 | g_assert_cmpint(rc, ==, SQLITE_OK); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
383 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
384 | res = purple_sqlite3_run_migrations_from_resources(db, path, migrations, |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
385 | &error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
386 | g_assert_error(error, PURPLE_SQLITE3_DOMAIN, 0); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
387 | g_clear_error(&error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
388 | g_assert_false(res); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
389 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
390 | version = purple_sqlite3_get_schema_version(db, &error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
391 | g_assert_no_error(error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
392 | g_assert_cmpint(version, ==, 0); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
393 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
394 | rc = sqlite3_close(db); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
395 | g_assert_cmpint(rc, ==, SQLITE_OK); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
396 | } |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
397 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
398 | static void |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
399 | test_sqlite3_resource_migrations_older(void) { |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
400 | GError *error = NULL; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
401 | sqlite3 *db = NULL; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
402 | gboolean res = FALSE; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
403 | int rc = 0; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
404 | int version = -1; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
405 | const char *migrations1[] = {"initial.sql", "secondary.sql", NULL}; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
406 | const char *migrations2[] = {"initial.sql", NULL}; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
407 | const char *path = "/im/pidgin/libpurple/tests/sqlite3/"; |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
408 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
409 | rc = sqlite3_open(":memory:", &db); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
410 | g_assert_nonnull(db); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
411 | g_assert_cmpint(rc, ==, SQLITE_OK); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
412 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
413 | res = purple_sqlite3_run_migrations_from_resources(db, path, migrations1, |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
414 | &error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
415 | g_assert_no_error(error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
416 | g_assert_true(res); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
417 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
418 | version = purple_sqlite3_get_schema_version(db, &error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
419 | g_assert_no_error(error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
420 | g_assert_cmpint(version, ==, 2); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
421 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
422 | /* Run the older migrations now and verify we get a failure. */ |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
423 | res = purple_sqlite3_run_migrations_from_resources(db, path, migrations2, |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
424 | &error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
425 | g_assert_error(error, PURPLE_SQLITE3_DOMAIN, 0); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
426 | g_clear_error(&error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
427 | g_assert_false(res); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
428 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
429 | version = purple_sqlite3_get_schema_version(db, &error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
430 | g_assert_no_error(error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
431 | g_assert_cmpint(version, ==, 2); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
432 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
433 | rc = sqlite3_close(db); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
434 | g_assert_cmpint(rc, ==, SQLITE_OK); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
435 | } |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
436 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
437 | /****************************************************************************** |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
438 | * Main |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
439 | *****************************************************************************/ |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
440 | int |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
441 | main(int argc, char *argv[]) { |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
442 | g_test_init(&argc, &argv, G_TEST_OPTION_ISOLATE_DIRS, NULL); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
443 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
444 | g_test_add_func("/sqlite3/schema_version/null", |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
445 | test_sqlite3_get_schema_version_null); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
446 | g_test_add_func("/sqlite3/schema_version/new", |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
447 | test_sqlite3_get_schema_version_new); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
448 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
449 | g_test_add_func("/sqlite3/string_migrations/null", |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
450 | test_sqlite3_string_migrations_null); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
451 | g_test_add_func("/sqlite3/string_migrations/null-terminator", |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
452 | test_sqlite3_string_migrations_null_terminator); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
453 | g_test_add_func("/sqlite3/string_migrations/multiple", |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
454 | test_sqlite3_string_migrations_multiple); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
455 | g_test_add_func("/sqlite3/string_migrations/syntax-error", |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
456 | test_sqlite3_string_migrations_syntax_error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
457 | g_test_add_func("/sqlite3/string_migrations/older", |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
458 | test_sqlite3_string_migrations_older); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
459 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
460 | g_test_add_func("/sqlite3/resource_migrations/null-path", |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
461 | test_sqlite3_resource_migrations_null_path); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
462 | g_test_add_func("/sqlite3/resource_migrations/null-migrations", |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
463 | test_sqlite3_resource_migrations_null_migrations); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
464 | g_test_add_func("/sqlite3/resource_migrations/null-terminator", |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
465 | test_sqlite3_resource_migrations_null_terminator); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
466 | g_test_add_func("/sqlite3/resource_migrations/multiple", |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
467 | test_sqlite3_resource_migrations_multiple); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
468 | g_test_add_func("/sqlite3/resource_migrations/missing", |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
469 | test_sqlite3_resource_migrations_missing); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
470 | g_test_add_func("/sqlite3/resource_migrations/syntax-error", |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
471 | test_sqlite3_resource_migrations_syntax_error); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
472 | g_test_add_func("/sqlite3/resource_migrations/older", |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
473 | test_sqlite3_resource_migrations_older); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
474 | |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
475 | return g_test_run(); |
|
36c3c3cd2402
Add some api for handling SQLite3 migrations
Gary Kramlich <grim@reaperworld.com>
parents:
diff
changeset
|
476 | } |