Index: components/precache/core/precache_url_table_unittest.cc |
diff --git a/components/precache/core/precache_url_table_unittest.cc b/components/precache/core/precache_url_table_unittest.cc |
index 9053e58a96d65245b500bf457e293e0f04809a94..e622609edd9ff6276193defeb2f0868bb054e0b1 100644 |
--- a/components/precache/core/precache_url_table_unittest.cc |
+++ b/components/precache/core/precache_url_table_unittest.cc |
@@ -6,10 +6,13 @@ |
#include <map> |
#include <memory> |
+#include <set> |
#include "base/compiler_specific.h" |
#include "base/time/time.h" |
#include "sql/connection.h" |
+#include "sql/statement.h" |
+#include "testing/gmock/include/gmock/gmock.h" |
#include "testing/gtest/include/gtest/gtest.h" |
namespace precache { |
@@ -26,7 +29,7 @@ class PrecacheURLTableTest : public testing::Test { |
precache_url_table_.reset(new PrecacheURLTable()); |
db_.reset(new sql::Connection()); |
ASSERT_TRUE(db_->OpenInMemory()); |
- precache_url_table_->Init(db_.get()); |
+ ASSERT_TRUE(precache_url_table_->Init(db_.get())); |
} |
std::unique_ptr<PrecacheURLTable> precache_url_table_; |
@@ -35,7 +38,7 @@ class PrecacheURLTableTest : public testing::Test { |
TEST_F(PrecacheURLTableTest, AddURLWithNoExistingRow) { |
const base::Time kTime = base::Time::FromInternalValue(100); |
- precache_url_table_->AddURL(GURL("http://url.com"), kTime); |
+ precache_url_table_->AddURL(GURL("http://url.com"), 1, true, kTime); |
std::map<GURL, base::Time> expected_map; |
expected_map[GURL("http://url.com")] = kTime; |
@@ -48,8 +51,8 @@ TEST_F(PrecacheURLTableTest, AddURLWithNoExistingRow) { |
TEST_F(PrecacheURLTableTest, AddURLWithExistingRow) { |
const base::Time kOldTime = base::Time::FromInternalValue(50); |
const base::Time kNewTime = base::Time::FromInternalValue(100); |
- precache_url_table_->AddURL(GURL("http://url.com"), kOldTime); |
- precache_url_table_->AddURL(GURL("http://url.com"), kNewTime); |
+ precache_url_table_->AddURL(GURL("http://url.com"), 1, true, kOldTime); |
+ precache_url_table_->AddURL(GURL("http://url.com"), 1, true, kNewTime); |
std::map<GURL, base::Time> expected_map; |
expected_map[GURL("http://url.com")] = kNewTime; |
@@ -59,14 +62,15 @@ TEST_F(PrecacheURLTableTest, AddURLWithExistingRow) { |
EXPECT_EQ(expected_map, actual_map); |
} |
-TEST_F(PrecacheURLTableTest, DeleteURL) { |
+TEST_F(PrecacheURLTableTest, SetURLAsNotPrecached) { |
const base::Time kStaysTime = base::Time::FromInternalValue(50); |
const base::Time kDeletedTime = base::Time::FromInternalValue(100); |
- precache_url_table_->AddURL(GURL("http://stays.com"), kStaysTime); |
- precache_url_table_->AddURL(GURL("http://deleted.com"), kDeletedTime); |
+ precache_url_table_->AddURL(GURL("http://stays.com"), 1, true, kStaysTime); |
+ precache_url_table_->AddURL(GURL("http://deleted.com"), 1, true, |
+ kDeletedTime); |
- precache_url_table_->DeleteURL(GURL("http://deleted.com")); |
+ precache_url_table_->SetURLAsNotPrecached(GURL("http://deleted.com")); |
std::map<GURL, base::Time> expected_map; |
expected_map[GURL("http://stays.com")] = kStaysTime; |
@@ -76,17 +80,17 @@ TEST_F(PrecacheURLTableTest, DeleteURL) { |
EXPECT_EQ(expected_map, actual_map); |
} |
-TEST_F(PrecacheURLTableTest, HasURL) { |
- EXPECT_FALSE(precache_url_table_->HasURL(GURL("http://url.com"))); |
+TEST_F(PrecacheURLTableTest, IsURLPrecached) { |
+ EXPECT_FALSE(precache_url_table_->IsURLPrecached(GURL("http://url.com"))); |
- precache_url_table_->AddURL(GURL("http://url.com"), |
+ precache_url_table_->AddURL(GURL("http://url.com"), 1, true, |
base::Time::FromInternalValue(100)); |
- EXPECT_TRUE(precache_url_table_->HasURL(GURL("http://url.com"))); |
+ EXPECT_TRUE(precache_url_table_->IsURLPrecached(GURL("http://url.com"))); |
- precache_url_table_->DeleteURL(GURL("http://url.com")); |
+ precache_url_table_->SetURLAsNotPrecached(GURL("http://url.com")); |
- EXPECT_FALSE(precache_url_table_->HasURL(GURL("http://url.com"))); |
+ EXPECT_FALSE(precache_url_table_->IsURLPrecached(GURL("http://url.com"))); |
} |
TEST_F(PrecacheURLTableTest, DeleteAllPrecachedBefore) { |
@@ -95,10 +99,10 @@ TEST_F(PrecacheURLTableTest, DeleteAllPrecachedBefore) { |
const base::Time kEndTime = base::Time::FromInternalValue(30); |
const base::Time kAfterTime = base::Time::FromInternalValue(40); |
- precache_url_table_->AddURL(GURL("http://old.com"), kOldTime); |
- precache_url_table_->AddURL(GURL("http://before.com"), kBeforeTime); |
- precache_url_table_->AddURL(GURL("http://end.com"), kEndTime); |
- precache_url_table_->AddURL(GURL("http://after.com"), kAfterTime); |
+ precache_url_table_->AddURL(GURL("http://old.com"), 1, true, kOldTime); |
+ precache_url_table_->AddURL(GURL("http://before.com"), 1, true, kBeforeTime); |
+ precache_url_table_->AddURL(GURL("http://end.com"), 1, true, kEndTime); |
+ precache_url_table_->AddURL(GURL("http://after.com"), 1, true, kAfterTime); |
precache_url_table_->DeleteAllPrecachedBefore(kEndTime); |
@@ -111,6 +115,46 @@ TEST_F(PrecacheURLTableTest, DeleteAllPrecachedBefore) { |
EXPECT_EQ(expected_map, actual_map); |
} |
+TEST_F(PrecacheURLTableTest, TableMigration) { |
+ // Create the previous version of the URL table. |
+ precache_url_table_.reset(new PrecacheURLTable()); |
+ db_.reset(new sql::Connection()); |
+ ASSERT_TRUE(db_->OpenInMemory()); |
+ ASSERT_TRUE(db_->Execute( |
+ "CREATE TABLE IF NOT EXISTS precache_urls (url TEXT PRIMARY KEY, time " |
+ "INTEGER)")); |
+ |
+ // Populate data for the previous version. |
+ const std::string old_urls[] = {"http://foo.com", "http://bar.com", |
+ "http://foobar.com"}; |
+ for (const auto& url : old_urls) { |
+ sql::Statement statement(db_->GetCachedStatement( |
+ SQL_FROM_HERE, "INSERT INTO precache_urls (url, time) VALUES(?,100)")); |
+ statement.BindString(0, url); |
+ statement.Run(); |
+ } |
+ |
+ // Verify the migration. |
+ ASSERT_TRUE(precache_url_table_->Init(db_.get())); |
+ EXPECT_TRUE(db_->DoesColumnExist("precache_urls", "was_used")); |
+ EXPECT_TRUE(db_->DoesColumnExist("precache_urls", "is_precached")); |
+ EXPECT_TRUE(db_->DoesColumnExist("precache_urls", "referrer_host_id")); |
+ |
+ std::set<std::string> actual_urls; |
+ sql::Statement statement( |
+ db_->GetCachedStatement(SQL_FROM_HERE, |
+ "select url, referrer_host_id, was_used, " |
+ "is_precached from precache_urls")); |
+ while (statement.Step()) { |
+ actual_urls.insert(statement.ColumnString(0)); |
+ EXPECT_EQ(0, statement.ColumnInt(1)); |
+ EXPECT_EQ(0, statement.ColumnInt(2)); |
+ EXPECT_EQ(0, statement.ColumnInt(3)); |
+ } |
+ EXPECT_THAT(std::set<std::string>(begin(old_urls), end(old_urls)), |
+ ::testing::ContainerEq(actual_urls)); |
+} |
+ |
} // namespace |
} // namespace precache |