Index: sql/connection_unittest.cc |
diff --git a/sql/connection_unittest.cc b/sql/connection_unittest.cc |
index 5aa7a9b588561e4c83c76a800360242d5de3a34b..ea0c8771362cc12d6afba170f95562a3f72dbaff 100644 |
--- a/sql/connection_unittest.cc |
+++ b/sql/connection_unittest.cc |
@@ -822,4 +822,45 @@ TEST_F(SQLConnectionTest, Attach) { |
EXPECT_FALSE(db().IsSQLValid("SELECT count(*) from other.bar")); |
} |
+TEST_F(SQLConnectionTest, Basic_QuickIntegrityCheck) { |
michaeln
2013/12/13 22:47:05
Also, added some basic tests for the integrity che
|
+ const char* kCreateSql = "CREATE TABLE foo (id INTEGER PRIMARY KEY, value)"; |
+ ASSERT_TRUE(db().Execute(kCreateSql)); |
+ EXPECT_TRUE(db().QuickIntegrityCheck()); |
+ db().Close(); |
+ |
+ ASSERT_TRUE(sql::test::CorruptSizeInHeader(db_path())); |
+ |
+ { |
+ sql::ScopedErrorIgnorer ignore_errors; |
+ ignore_errors.IgnoreError(SQLITE_CORRUPT); |
+ db().Open(db_path()); |
+ EXPECT_FALSE(db().QuickIntegrityCheck()); |
+ ASSERT_TRUE(ignore_errors.CheckIgnoredErrors()); |
+ } |
+} |
Scott Hess - ex-Googler
2013/12/13 23:15:46
Per offline discussion, given a table with an inde
|
+ |
+TEST_F(SQLConnectionTest, Basic_FullIntegrityCheck) { |
+ const std::string kOk("ok"); |
+ std::vector<std::string> messages; |
+ |
+ const char* kCreateSql = "CREATE TABLE foo (id INTEGER PRIMARY KEY, value)"; |
+ ASSERT_TRUE(db().Execute(kCreateSql)); |
+ EXPECT_TRUE(db().FullIntegrityCheck(&messages)); |
+ EXPECT_EQ(1u, messages.size()); |
+ EXPECT_EQ(kOk, messages[0]); |
+ db().Close(); |
+ |
+ ASSERT_TRUE(sql::test::CorruptSizeInHeader(db_path())); |
+ |
+ { |
+ sql::ScopedErrorIgnorer ignore_errors; |
+ ignore_errors.IgnoreError(SQLITE_CORRUPT); |
+ db().Open(db_path()); |
+ EXPECT_TRUE(db().FullIntegrityCheck(&messages)); |
+ EXPECT_LT(1u, messages.size()); |
+ EXPECT_NE(kOk, messages[0]); |
+ ASSERT_TRUE(ignore_errors.CheckIgnoredErrors()); |
+ } |
+} |
+ |
} // namespace |