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
|
#include <mbgl/test/util.hpp>
#include <gtest/gtest.h>
#include <sqlite3.hpp>
TEST(SQLite, Statement) {
using namespace mbgl;
mapbox::sqlite::Database db(":memory:", mapbox::sqlite::Create | mapbox::sqlite::ReadWrite);
db.exec("CREATE TABLE test (id INTEGER);");
mapbox::sqlite::Statement stmt1{ db, "INSERT INTO test (id) VALUES (?1);" };
mapbox::sqlite::Query query1{ stmt1 };
ASSERT_EQ(query1.lastInsertRowId(), 0);
ASSERT_EQ(query1.changes(), 0u);
query1.bind(1, 10);
query1.run();
ASSERT_EQ(query1.lastInsertRowId(), 1);
ASSERT_EQ(query1.changes(), 1u);
mapbox::sqlite::Statement stmt2{ db, "INSERT INTO test (id) VALUES (?1);" };
mapbox::sqlite::Query query2{ stmt2 };
ASSERT_EQ(query2.lastInsertRowId(), 0);
ASSERT_EQ(query2.changes(), 0u);
query2.bind(1, 20);
query2.run();
ASSERT_EQ(query2.lastInsertRowId(), 2);
ASSERT_EQ(query2.changes(), 1u);
}
TEST(SQLite, TEST_REQUIRES_WRITE(CantOpenException)) {
try {
// Should throw a CANTOPEN when the database doesn't exist,
// make sure all the backends behave the same way.
mapbox::sqlite::Database("test/fixtures/offline_database/foobar123.db", mapbox::sqlite::ReadOnly);
FAIL();
} catch (mapbox::sqlite::Exception& ex) {
ASSERT_EQ(ex.code, mapbox::sqlite::ResultCode::CantOpen);
}
}
|