diff options
author | michaeln@chromium.org <michaeln@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2013-12-16 18:36:52 +0000 |
---|---|---|
committer | michaeln@chromium.org <michaeln@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2013-12-16 18:36:52 +0000 |
commit | 579446c1f83325c74e26e61b47a11c149e491a66 (patch) | |
tree | a297376e9fd53b8c24acb9b240ee880494c5567c /sql/connection_unittest.cc | |
parent | 3e0d61e2bb88eb80058b63ac6a8b9ebff64cc4eb (diff) | |
download | chromium_src-579446c1f83325c74e26e61b47a11c149e491a66.zip chromium_src-579446c1f83325c74e26e61b47a11c149e491a66.tar.gz chromium_src-579446c1f83325c74e26e61b47a11c149e491a66.tar.bz2 |
AppCache: Run a quick integrity check on the sqlite database when opening. If the test fails, delete the appcache directory and start afresh.
NOTRY=true
TBR=sky
BUG=318544
Review URL: https://codereview.chromium.org/104593010
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@240937 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'sql/connection_unittest.cc')
-rw-r--r-- | sql/connection_unittest.cc | 44 |
1 files changed, 44 insertions, 0 deletions
diff --git a/sql/connection_unittest.cc b/sql/connection_unittest.cc index 5aa7a9b..304ddcd 100644 --- a/sql/connection_unittest.cc +++ b/sql/connection_unittest.cc @@ -822,4 +822,48 @@ TEST_F(SQLConnectionTest, Attach) { EXPECT_FALSE(db().IsSQLValid("SELECT count(*) from other.bar")); } +TEST_F(SQLConnectionTest, Basic_QuickIntegrityCheck) { + 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); + ASSERT_TRUE(db().Open(db_path())); + EXPECT_FALSE(db().QuickIntegrityCheck()); + ASSERT_TRUE(ignore_errors.CheckIgnoredErrors()); + } +} + +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); + ASSERT_TRUE(db().Open(db_path())); + EXPECT_TRUE(db().FullIntegrityCheck(&messages)); + EXPECT_LT(1u, messages.size()); + EXPECT_NE(kOk, messages[0]); + ASSERT_TRUE(ignore_errors.CheckIgnoredErrors()); + } + + // TODO(shess): CorruptTableOrIndex could be used to produce a + // file that would pass the quick check and fail the full check. +} + } // namespace |