1 // Copyright 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #include "sql/meta_table.h"
7 #include "base/files/file_path.h"
8 #include "base/files/scoped_temp_dir.h"
9 #include "sql/connection.h"
10 #include "sql/statement.h"
11 #include "testing/gtest/include/gtest/gtest.h"
15 class SQLMetaTableTest
: public testing::Test
{
17 virtual void SetUp() {
18 ASSERT_TRUE(temp_dir_
.CreateUniqueTempDir());
19 ASSERT_TRUE(db_
.Open(temp_dir_
.path().AppendASCII("SQLMetaTableTest.db")));
22 virtual void TearDown() {
26 sql::Connection
& db() { return db_
; }
29 base::ScopedTempDir temp_dir_
;
33 TEST_F(SQLMetaTableTest
, DoesTableExist
) {
34 EXPECT_FALSE(sql::MetaTable::DoesTableExist(&db()));
37 sql::MetaTable meta_table
;
38 EXPECT_TRUE(meta_table
.Init(&db(), 1, 1));
41 EXPECT_TRUE(sql::MetaTable::DoesTableExist(&db()));
44 TEST_F(SQLMetaTableTest
, RazeIfDeprecated
) {
45 const int kDeprecatedVersion
= 1;
46 const int kVersion
= 2;
48 // Setup a current database.
50 sql::MetaTable meta_table
;
51 EXPECT_TRUE(meta_table
.Init(&db(), kVersion
, kVersion
));
52 EXPECT_TRUE(db().Execute("CREATE TABLE t(c)"));
53 EXPECT_TRUE(db().DoesTableExist("t"));
56 // Table should should still exist if the database version is new enough.
57 sql::MetaTable::RazeIfDeprecated(&db(), kDeprecatedVersion
);
58 EXPECT_TRUE(db().DoesTableExist("t"));
60 // TODO(shess): It may make sense to Raze() if meta isn't present or
61 // version isn't present. See meta_table.h TODO on RazeIfDeprecated().
63 // Table should still exist if the version is not available.
64 EXPECT_TRUE(db().Execute("DELETE FROM meta WHERE key = 'version'"));
66 sql::MetaTable meta_table
;
67 EXPECT_TRUE(meta_table
.Init(&db(), kVersion
, kVersion
));
68 EXPECT_EQ(0, meta_table
.GetVersionNumber());
70 sql::MetaTable::RazeIfDeprecated(&db(), kDeprecatedVersion
);
71 EXPECT_TRUE(db().DoesTableExist("t"));
73 // Table should still exist if meta table is missing.
74 EXPECT_TRUE(db().Execute("DROP TABLE meta"));
75 sql::MetaTable::RazeIfDeprecated(&db(), kDeprecatedVersion
);
76 EXPECT_TRUE(db().DoesTableExist("t"));
78 // Setup meta with deprecated version.
80 sql::MetaTable meta_table
;
81 EXPECT_TRUE(meta_table
.Init(&db(), kDeprecatedVersion
, kDeprecatedVersion
));
84 // Deprecation check should remove the table.
85 EXPECT_TRUE(db().DoesTableExist("t"));
86 sql::MetaTable::RazeIfDeprecated(&db(), kDeprecatedVersion
);
87 EXPECT_FALSE(sql::MetaTable::DoesTableExist(&db()));
88 EXPECT_FALSE(db().DoesTableExist("t"));
91 TEST_F(SQLMetaTableTest
, VersionNumber
) {
92 // Compatibility versions one less than the main versions to make
93 // sure the values aren't being crossed with each other.
94 const int kVersionFirst
= 2;
95 const int kCompatVersionFirst
= kVersionFirst
- 1;
96 const int kVersionSecond
= 4;
97 const int kCompatVersionSecond
= kVersionSecond
- 1;
98 const int kVersionThird
= 6;
99 const int kCompatVersionThird
= kVersionThird
- 1;
101 // First Init() sets the version info as expected.
103 sql::MetaTable meta_table
;
104 EXPECT_TRUE(meta_table
.Init(&db(), kVersionFirst
, kCompatVersionFirst
));
105 EXPECT_EQ(kVersionFirst
, meta_table
.GetVersionNumber());
106 EXPECT_EQ(kCompatVersionFirst
, meta_table
.GetCompatibleVersionNumber());
109 // Second Init() does not change the version info.
111 sql::MetaTable meta_table
;
112 EXPECT_TRUE(meta_table
.Init(&db(), kVersionSecond
, kCompatVersionSecond
));
113 EXPECT_EQ(kVersionFirst
, meta_table
.GetVersionNumber());
114 EXPECT_EQ(kCompatVersionFirst
, meta_table
.GetCompatibleVersionNumber());
116 meta_table
.SetVersionNumber(kVersionSecond
);
117 meta_table
.SetCompatibleVersionNumber(kCompatVersionSecond
);
120 // Version info from Set*() calls is seen.
122 sql::MetaTable meta_table
;
123 EXPECT_TRUE(meta_table
.Init(&db(), kVersionThird
, kCompatVersionThird
));
124 EXPECT_EQ(kVersionSecond
, meta_table
.GetVersionNumber());
125 EXPECT_EQ(kCompatVersionSecond
, meta_table
.GetCompatibleVersionNumber());
129 TEST_F(SQLMetaTableTest
, StringValue
) {
130 const char kKey
[] = "String Key";
131 const std::string
kFirstValue("First Value");
132 const std::string
kSecondValue("Second Value");
134 // Initially, the value isn't there until set.
136 sql::MetaTable meta_table
;
137 EXPECT_TRUE(meta_table
.Init(&db(), 1, 1));
140 EXPECT_FALSE(meta_table
.GetValue(kKey
, &value
));
142 EXPECT_TRUE(meta_table
.SetValue(kKey
, kFirstValue
));
143 EXPECT_TRUE(meta_table
.GetValue(kKey
, &value
));
144 EXPECT_EQ(kFirstValue
, value
);
147 // Value is persistent across different instances.
149 sql::MetaTable meta_table
;
150 EXPECT_TRUE(meta_table
.Init(&db(), 1, 1));
153 EXPECT_TRUE(meta_table
.GetValue(kKey
, &value
));
154 EXPECT_EQ(kFirstValue
, value
);
156 EXPECT_TRUE(meta_table
.SetValue(kKey
, kSecondValue
));
159 // Existing value was successfully changed.
161 sql::MetaTable meta_table
;
162 EXPECT_TRUE(meta_table
.Init(&db(), 1, 1));
165 EXPECT_TRUE(meta_table
.GetValue(kKey
, &value
));
166 EXPECT_EQ(kSecondValue
, value
);
170 TEST_F(SQLMetaTableTest
, IntValue
) {
171 const char kKey
[] = "Int Key";
172 const int kFirstValue
= 17;
173 const int kSecondValue
= 23;
175 // Initially, the value isn't there until set.
177 sql::MetaTable meta_table
;
178 EXPECT_TRUE(meta_table
.Init(&db(), 1, 1));
181 EXPECT_FALSE(meta_table
.GetValue(kKey
, &value
));
183 EXPECT_TRUE(meta_table
.SetValue(kKey
, kFirstValue
));
184 EXPECT_TRUE(meta_table
.GetValue(kKey
, &value
));
185 EXPECT_EQ(kFirstValue
, value
);
188 // Value is persistent across different instances.
190 sql::MetaTable meta_table
;
191 EXPECT_TRUE(meta_table
.Init(&db(), 1, 1));
194 EXPECT_TRUE(meta_table
.GetValue(kKey
, &value
));
195 EXPECT_EQ(kFirstValue
, value
);
197 EXPECT_TRUE(meta_table
.SetValue(kKey
, kSecondValue
));
200 // Existing value was successfully changed.
202 sql::MetaTable meta_table
;
203 EXPECT_TRUE(meta_table
.Init(&db(), 1, 1));
206 EXPECT_TRUE(meta_table
.GetValue(kKey
, &value
));
207 EXPECT_EQ(kSecondValue
, value
);
211 TEST_F(SQLMetaTableTest
, Int64Value
) {
212 const char kKey
[] = "Int Key";
213 const int64 kFirstValue
= GG_LONGLONG(5000000017);
214 const int64 kSecondValue
= GG_LONGLONG(5000000023);
216 // Initially, the value isn't there until set.
218 sql::MetaTable meta_table
;
219 EXPECT_TRUE(meta_table
.Init(&db(), 1, 1));
222 EXPECT_FALSE(meta_table
.GetValue(kKey
, &value
));
224 EXPECT_TRUE(meta_table
.SetValue(kKey
, kFirstValue
));
225 EXPECT_TRUE(meta_table
.GetValue(kKey
, &value
));
226 EXPECT_EQ(kFirstValue
, value
);
229 // Value is persistent across different instances.
231 sql::MetaTable meta_table
;
232 EXPECT_TRUE(meta_table
.Init(&db(), 1, 1));
235 EXPECT_TRUE(meta_table
.GetValue(kKey
, &value
));
236 EXPECT_EQ(kFirstValue
, value
);
238 EXPECT_TRUE(meta_table
.SetValue(kKey
, kSecondValue
));
241 // Existing value was successfully changed.
243 sql::MetaTable meta_table
;
244 EXPECT_TRUE(meta_table
.Init(&db(), 1, 1));
247 EXPECT_TRUE(meta_table
.GetValue(kKey
, &value
));
248 EXPECT_EQ(kSecondValue
, value
);
252 TEST_F(SQLMetaTableTest
, DeleteKey
) {
253 const char kKey
[] = "String Key";
254 const std::string
kValue("String Value");
256 sql::MetaTable meta_table
;
257 EXPECT_TRUE(meta_table
.Init(&db(), 1, 1));
259 // Value isn't present.
261 EXPECT_FALSE(meta_table
.GetValue(kKey
, &value
));
263 // Now value is present.
264 EXPECT_TRUE(meta_table
.SetValue(kKey
, kValue
));
265 EXPECT_TRUE(meta_table
.GetValue(kKey
, &value
));
266 EXPECT_EQ(kValue
, value
);
268 // After delete value isn't present.
269 EXPECT_TRUE(meta_table
.DeleteKey(kKey
));
270 EXPECT_FALSE(meta_table
.GetValue(kKey
, &value
));