1*6b3a42afSjmmv // Copyright 2011 Google Inc.
2*6b3a42afSjmmv // All rights reserved.
3*6b3a42afSjmmv //
4*6b3a42afSjmmv // Redistribution and use in source and binary forms, with or without
5*6b3a42afSjmmv // modification, are permitted provided that the following conditions are
6*6b3a42afSjmmv // met:
7*6b3a42afSjmmv //
8*6b3a42afSjmmv // * Redistributions of source code must retain the above copyright
9*6b3a42afSjmmv // notice, this list of conditions and the following disclaimer.
10*6b3a42afSjmmv // * Redistributions in binary form must reproduce the above copyright
11*6b3a42afSjmmv // notice, this list of conditions and the following disclaimer in the
12*6b3a42afSjmmv // documentation and/or other materials provided with the distribution.
13*6b3a42afSjmmv // * Neither the name of Google Inc. nor the names of its contributors
14*6b3a42afSjmmv // may be used to endorse or promote products derived from this software
15*6b3a42afSjmmv // without specific prior written permission.
16*6b3a42afSjmmv //
17*6b3a42afSjmmv // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
18*6b3a42afSjmmv // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
19*6b3a42afSjmmv // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
20*6b3a42afSjmmv // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
21*6b3a42afSjmmv // OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
22*6b3a42afSjmmv // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
23*6b3a42afSjmmv // LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
24*6b3a42afSjmmv // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
25*6b3a42afSjmmv // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
26*6b3a42afSjmmv // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
27*6b3a42afSjmmv // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28*6b3a42afSjmmv
29*6b3a42afSjmmv #include "utils/sqlite/database.hpp"
30*6b3a42afSjmmv
31*6b3a42afSjmmv #include <atf-c++.hpp>
32*6b3a42afSjmmv
33*6b3a42afSjmmv #include "utils/fs/operations.hpp"
34*6b3a42afSjmmv #include "utils/fs/path.hpp"
35*6b3a42afSjmmv #include "utils/sqlite/statement.ipp"
36*6b3a42afSjmmv #include "utils/sqlite/test_utils.hpp"
37*6b3a42afSjmmv #include "utils/sqlite/transaction.hpp"
38*6b3a42afSjmmv
39*6b3a42afSjmmv namespace fs = utils::fs;
40*6b3a42afSjmmv namespace sqlite = utils::sqlite;
41*6b3a42afSjmmv
42*6b3a42afSjmmv
43*6b3a42afSjmmv ATF_TEST_CASE_WITHOUT_HEAD(in_memory);
ATF_TEST_CASE_BODY(in_memory)44*6b3a42afSjmmv ATF_TEST_CASE_BODY(in_memory)
45*6b3a42afSjmmv {
46*6b3a42afSjmmv sqlite::database db = sqlite::database::in_memory();
47*6b3a42afSjmmv create_test_table(raw(db));
48*6b3a42afSjmmv verify_test_table(raw(db));
49*6b3a42afSjmmv
50*6b3a42afSjmmv ATF_REQUIRE(!fs::exists(fs::path(":memory:")));
51*6b3a42afSjmmv }
52*6b3a42afSjmmv
53*6b3a42afSjmmv
54*6b3a42afSjmmv ATF_TEST_CASE_WITHOUT_HEAD(open__readonly__ok);
ATF_TEST_CASE_BODY(open__readonly__ok)55*6b3a42afSjmmv ATF_TEST_CASE_BODY(open__readonly__ok)
56*6b3a42afSjmmv {
57*6b3a42afSjmmv {
58*6b3a42afSjmmv ::sqlite3* db;
59*6b3a42afSjmmv ATF_REQUIRE_EQ(SQLITE_OK, ::sqlite3_open_v2("test.db", &db,
60*6b3a42afSjmmv SQLITE_OPEN_READWRITE | SQLITE_OPEN_CREATE, NULL));
61*6b3a42afSjmmv create_test_table(db);
62*6b3a42afSjmmv ::sqlite3_close(db);
63*6b3a42afSjmmv }
64*6b3a42afSjmmv {
65*6b3a42afSjmmv sqlite::database db = sqlite::database::open(fs::path("test.db"),
66*6b3a42afSjmmv sqlite::open_readonly);
67*6b3a42afSjmmv verify_test_table(raw(db));
68*6b3a42afSjmmv }
69*6b3a42afSjmmv }
70*6b3a42afSjmmv
71*6b3a42afSjmmv
72*6b3a42afSjmmv ATF_TEST_CASE_WITHOUT_HEAD(open__readonly__fail);
ATF_TEST_CASE_BODY(open__readonly__fail)73*6b3a42afSjmmv ATF_TEST_CASE_BODY(open__readonly__fail)
74*6b3a42afSjmmv {
75*6b3a42afSjmmv REQUIRE_API_ERROR("sqlite3_open_v2",
76*6b3a42afSjmmv sqlite::database::open(fs::path("missing.db"), sqlite::open_readonly));
77*6b3a42afSjmmv ATF_REQUIRE(!fs::exists(fs::path("missing.db")));
78*6b3a42afSjmmv }
79*6b3a42afSjmmv
80*6b3a42afSjmmv
81*6b3a42afSjmmv ATF_TEST_CASE_WITHOUT_HEAD(open__create__ok);
ATF_TEST_CASE_BODY(open__create__ok)82*6b3a42afSjmmv ATF_TEST_CASE_BODY(open__create__ok)
83*6b3a42afSjmmv {
84*6b3a42afSjmmv {
85*6b3a42afSjmmv sqlite::database db = sqlite::database::open(fs::path("test.db"),
86*6b3a42afSjmmv sqlite::open_readwrite | sqlite::open_create);
87*6b3a42afSjmmv ATF_REQUIRE(fs::exists(fs::path("test.db")));
88*6b3a42afSjmmv create_test_table(raw(db));
89*6b3a42afSjmmv }
90*6b3a42afSjmmv {
91*6b3a42afSjmmv ::sqlite3* db;
92*6b3a42afSjmmv ATF_REQUIRE_EQ(SQLITE_OK, ::sqlite3_open_v2("test.db", &db,
93*6b3a42afSjmmv SQLITE_OPEN_READONLY, NULL));
94*6b3a42afSjmmv verify_test_table(db);
95*6b3a42afSjmmv ::sqlite3_close(db);
96*6b3a42afSjmmv }
97*6b3a42afSjmmv }
98*6b3a42afSjmmv
99*6b3a42afSjmmv
100*6b3a42afSjmmv ATF_TEST_CASE(open__create__fail);
ATF_TEST_CASE_HEAD(open__create__fail)101*6b3a42afSjmmv ATF_TEST_CASE_HEAD(open__create__fail)
102*6b3a42afSjmmv {
103*6b3a42afSjmmv set_md_var("require.user", "unprivileged");
104*6b3a42afSjmmv }
ATF_TEST_CASE_BODY(open__create__fail)105*6b3a42afSjmmv ATF_TEST_CASE_BODY(open__create__fail)
106*6b3a42afSjmmv {
107*6b3a42afSjmmv fs::mkdir(fs::path("protected"), 0555);
108*6b3a42afSjmmv REQUIRE_API_ERROR("sqlite3_open_v2",
109*6b3a42afSjmmv sqlite::database::open(fs::path("protected/test.db"),
110*6b3a42afSjmmv sqlite::open_readwrite | sqlite::open_create));
111*6b3a42afSjmmv }
112*6b3a42afSjmmv
113*6b3a42afSjmmv
114*6b3a42afSjmmv ATF_TEST_CASE_WITHOUT_HEAD(temporary);
ATF_TEST_CASE_BODY(temporary)115*6b3a42afSjmmv ATF_TEST_CASE_BODY(temporary)
116*6b3a42afSjmmv {
117*6b3a42afSjmmv // We could validate if files go to disk by setting the temp_store_directory
118*6b3a42afSjmmv // PRAGMA to a subdirectory of pwd, and then ensuring the subdirectory is
119*6b3a42afSjmmv // not empty. However, there does not seem to be a way to force SQLite to
120*6b3a42afSjmmv // unconditionally write the temporary database to disk (even with
121*6b3a42afSjmmv // temp_store = FILE), so this scenary is hard to reproduce.
122*6b3a42afSjmmv sqlite::database db = sqlite::database::temporary();
123*6b3a42afSjmmv create_test_table(raw(db));
124*6b3a42afSjmmv verify_test_table(raw(db));
125*6b3a42afSjmmv }
126*6b3a42afSjmmv
127*6b3a42afSjmmv
128*6b3a42afSjmmv ATF_TEST_CASE_WITHOUT_HEAD(close);
ATF_TEST_CASE_BODY(close)129*6b3a42afSjmmv ATF_TEST_CASE_BODY(close)
130*6b3a42afSjmmv {
131*6b3a42afSjmmv sqlite::database db = sqlite::database::in_memory();
132*6b3a42afSjmmv db.close();
133*6b3a42afSjmmv // The destructor for the database will run now. If it does a second close,
134*6b3a42afSjmmv // we may crash, so let's see if we don't.
135*6b3a42afSjmmv }
136*6b3a42afSjmmv
137*6b3a42afSjmmv
138*6b3a42afSjmmv ATF_TEST_CASE_WITHOUT_HEAD(copy);
ATF_TEST_CASE_BODY(copy)139*6b3a42afSjmmv ATF_TEST_CASE_BODY(copy)
140*6b3a42afSjmmv {
141*6b3a42afSjmmv sqlite::database db1 = sqlite::database::in_memory();
142*6b3a42afSjmmv {
143*6b3a42afSjmmv sqlite::database db2 = sqlite::database::in_memory();
144*6b3a42afSjmmv create_test_table(raw(db2));
145*6b3a42afSjmmv db1 = db2;
146*6b3a42afSjmmv verify_test_table(raw(db1));
147*6b3a42afSjmmv }
148*6b3a42afSjmmv // db2 went out of scope. If the destruction is not properly managed, the
149*6b3a42afSjmmv // memory of db1 may have been invalidated and this would not work.
150*6b3a42afSjmmv verify_test_table(raw(db1));
151*6b3a42afSjmmv }
152*6b3a42afSjmmv
153*6b3a42afSjmmv
154*6b3a42afSjmmv ATF_TEST_CASE_WITHOUT_HEAD(exec__ok);
ATF_TEST_CASE_BODY(exec__ok)155*6b3a42afSjmmv ATF_TEST_CASE_BODY(exec__ok)
156*6b3a42afSjmmv {
157*6b3a42afSjmmv sqlite::database db = sqlite::database::in_memory();
158*6b3a42afSjmmv db.exec(create_test_table_sql);
159*6b3a42afSjmmv verify_test_table(raw(db));
160*6b3a42afSjmmv }
161*6b3a42afSjmmv
162*6b3a42afSjmmv
163*6b3a42afSjmmv ATF_TEST_CASE_WITHOUT_HEAD(exec__fail);
ATF_TEST_CASE_BODY(exec__fail)164*6b3a42afSjmmv ATF_TEST_CASE_BODY(exec__fail)
165*6b3a42afSjmmv {
166*6b3a42afSjmmv sqlite::database db = sqlite::database::in_memory();
167*6b3a42afSjmmv REQUIRE_API_ERROR("sqlite3_exec",
168*6b3a42afSjmmv db.exec("SELECT * FROM test"));
169*6b3a42afSjmmv REQUIRE_API_ERROR("sqlite3_exec",
170*6b3a42afSjmmv db.exec("CREATE TABLE test (col INTEGER PRIMARY KEY);"
171*6b3a42afSjmmv "FOO BAR"));
172*6b3a42afSjmmv db.exec("SELECT * FROM test");
173*6b3a42afSjmmv }
174*6b3a42afSjmmv
175*6b3a42afSjmmv
176*6b3a42afSjmmv ATF_TEST_CASE_WITHOUT_HEAD(create_statement__ok);
ATF_TEST_CASE_BODY(create_statement__ok)177*6b3a42afSjmmv ATF_TEST_CASE_BODY(create_statement__ok)
178*6b3a42afSjmmv {
179*6b3a42afSjmmv sqlite::database db = sqlite::database::in_memory();
180*6b3a42afSjmmv sqlite::statement stmt = db.create_statement("SELECT 3");
181*6b3a42afSjmmv // Statement testing happens in statement_test. We are only interested here
182*6b3a42afSjmmv // in ensuring that the API call exists and runs.
183*6b3a42afSjmmv }
184*6b3a42afSjmmv
185*6b3a42afSjmmv
186*6b3a42afSjmmv ATF_TEST_CASE_WITHOUT_HEAD(begin_transaction);
ATF_TEST_CASE_BODY(begin_transaction)187*6b3a42afSjmmv ATF_TEST_CASE_BODY(begin_transaction)
188*6b3a42afSjmmv {
189*6b3a42afSjmmv sqlite::database db = sqlite::database::in_memory();
190*6b3a42afSjmmv sqlite::transaction stmt = db.begin_transaction();
191*6b3a42afSjmmv // Transaction testing happens in transaction_test. We are only interested
192*6b3a42afSjmmv // here in ensuring that the API call exists and runs.
193*6b3a42afSjmmv }
194*6b3a42afSjmmv
195*6b3a42afSjmmv
196*6b3a42afSjmmv ATF_TEST_CASE_WITHOUT_HEAD(create_statement__fail);
ATF_TEST_CASE_BODY(create_statement__fail)197*6b3a42afSjmmv ATF_TEST_CASE_BODY(create_statement__fail)
198*6b3a42afSjmmv {
199*6b3a42afSjmmv sqlite::database db = sqlite::database::in_memory();
200*6b3a42afSjmmv REQUIRE_API_ERROR("sqlite3_prepare_v2",
201*6b3a42afSjmmv db.create_statement("SELECT * FROM missing"));
202*6b3a42afSjmmv }
203*6b3a42afSjmmv
204*6b3a42afSjmmv
205*6b3a42afSjmmv ATF_TEST_CASE_WITHOUT_HEAD(last_insert_rowid);
ATF_TEST_CASE_BODY(last_insert_rowid)206*6b3a42afSjmmv ATF_TEST_CASE_BODY(last_insert_rowid)
207*6b3a42afSjmmv {
208*6b3a42afSjmmv sqlite::database db = sqlite::database::in_memory();
209*6b3a42afSjmmv db.exec("CREATE TABLE test (a INTEGER PRIMARY KEY, b INTEGER)");
210*6b3a42afSjmmv db.exec("INSERT INTO test VALUES (723, 5)");
211*6b3a42afSjmmv ATF_REQUIRE_EQ(723, db.last_insert_rowid());
212*6b3a42afSjmmv db.exec("INSERT INTO test VALUES (145, 20)");
213*6b3a42afSjmmv ATF_REQUIRE_EQ(145, db.last_insert_rowid());
214*6b3a42afSjmmv }
215*6b3a42afSjmmv
216*6b3a42afSjmmv
ATF_INIT_TEST_CASES(tcs)217*6b3a42afSjmmv ATF_INIT_TEST_CASES(tcs)
218*6b3a42afSjmmv {
219*6b3a42afSjmmv ATF_ADD_TEST_CASE(tcs, in_memory);
220*6b3a42afSjmmv
221*6b3a42afSjmmv ATF_ADD_TEST_CASE(tcs, open__readonly__ok);
222*6b3a42afSjmmv ATF_ADD_TEST_CASE(tcs, open__readonly__fail);
223*6b3a42afSjmmv ATF_ADD_TEST_CASE(tcs, open__create__ok);
224*6b3a42afSjmmv ATF_ADD_TEST_CASE(tcs, open__create__fail);
225*6b3a42afSjmmv
226*6b3a42afSjmmv ATF_ADD_TEST_CASE(tcs, temporary);
227*6b3a42afSjmmv
228*6b3a42afSjmmv ATF_ADD_TEST_CASE(tcs, close);
229*6b3a42afSjmmv
230*6b3a42afSjmmv ATF_ADD_TEST_CASE(tcs, copy);
231*6b3a42afSjmmv
232*6b3a42afSjmmv ATF_ADD_TEST_CASE(tcs, exec__ok);
233*6b3a42afSjmmv ATF_ADD_TEST_CASE(tcs, exec__fail);
234*6b3a42afSjmmv
235*6b3a42afSjmmv ATF_ADD_TEST_CASE(tcs, begin_transaction);
236*6b3a42afSjmmv
237*6b3a42afSjmmv ATF_ADD_TEST_CASE(tcs, create_statement__ok);
238*6b3a42afSjmmv ATF_ADD_TEST_CASE(tcs, create_statement__fail);
239*6b3a42afSjmmv
240*6b3a42afSjmmv ATF_ADD_TEST_CASE(tcs, last_insert_rowid);
241*6b3a42afSjmmv }
242