Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(538)

Unified Diff: components/previews/core/previews_opt_out_store_sql_unittest.cc

Issue 2749693003: Reland of Moving previews code from components/ to chrome/ (Closed)
Patch Set: fixed vector copy Created 3 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: components/previews/core/previews_opt_out_store_sql_unittest.cc
diff --git a/components/previews/core/previews_opt_out_store_sql_unittest.cc b/components/previews/core/previews_opt_out_store_sql_unittest.cc
index 9974885b1d8a935459ed2d0cf6ab9237b842a886..2057eed61b7db61e43c47322065bc8c484e913ba 100644
--- a/components/previews/core/previews_opt_out_store_sql_unittest.cc
+++ b/components/previews/core/previews_opt_out_store_sql_unittest.cc
@@ -64,16 +64,17 @@ class PreviewsOptOutStoreSQLTest : public testing::Test {
}
// Creates a store that operates on one thread.
- void Create() {
+ void Create(std::unique_ptr<PreviewsTypeList> enabled_previews) {
store_ = base::MakeUnique<PreviewsOptOutStoreSQL>(
base::ThreadTaskRunnerHandle::Get(),
base::ThreadTaskRunnerHandle::Get(),
- temp_dir_.GetPath().Append(kOptOutFilename));
+ temp_dir_.GetPath().Append(kOptOutFilename),
+ std::move(enabled_previews));
}
// Sets up initialization of |store_|.
- void CreateAndLoad() {
- Create();
+ void CreateAndLoad(std::unique_ptr<PreviewsTypeList> enabled_previews) {
+ Create(std::move(enabled_previews));
Load();
}
@@ -114,7 +115,9 @@ class PreviewsOptOutStoreSQLTest : public testing::Test {
TEST_F(PreviewsOptOutStoreSQLTest, TestErrorRecovery) {
// Creates the database and corrupt to test the recovery method.
std::string test_host = "host.com";
- CreateAndLoad();
+ std::unique_ptr<PreviewsTypeList> enabled_previews(new PreviewsTypeList);
+ enabled_previews->push_back({PreviewsType::OFFLINE, 0});
+ CreateAndLoad(std::move(enabled_previews));
store_->AddPreviewNavigation(true, test_host, PreviewsType::OFFLINE,
base::Time::Now());
base::RunLoop().RunUntilIdle();
@@ -125,7 +128,9 @@ TEST_F(PreviewsOptOutStoreSQLTest, TestErrorRecovery) {
temp_dir_.GetPath().Append(kOptOutFilename)));
base::RunLoop().RunUntilIdle();
- CreateAndLoad();
+ enabled_previews.reset(new PreviewsTypeList);
+ enabled_previews->push_back({PreviewsType::OFFLINE, 0});
+ CreateAndLoad(std::move(enabled_previews));
// The data should be recovered.
EXPECT_EQ(1U, black_list_map_->size());
auto iter = black_list_map_->find(test_host);
@@ -137,7 +142,9 @@ TEST_F(PreviewsOptOutStoreSQLTest, TestErrorRecovery) {
TEST_F(PreviewsOptOutStoreSQLTest, TestPersistance) {
// Tests if data is stored as expected in the SQLite database.
std::string test_host = "host.com";
- CreateAndLoad();
+ std::unique_ptr<PreviewsTypeList> enabled_previews(new PreviewsTypeList);
+ enabled_previews->push_back({PreviewsType::OFFLINE, 0});
+ CreateAndLoad(std::move(enabled_previews));
histogram_tester_.ExpectUniqueSample("Previews.OptOut.DBRowCount", 0, 1);
base::Time now = base::Time::Now();
store_->AddPreviewNavigation(true, test_host, PreviewsType::OFFLINE, now);
@@ -148,7 +155,9 @@ TEST_F(PreviewsOptOutStoreSQLTest, TestPersistance) {
DestroyStore();
// Reload and test for persistence
- CreateAndLoad();
+ enabled_previews.reset(new PreviewsTypeList);
+ enabled_previews->push_back({PreviewsType::OFFLINE, 0});
+ CreateAndLoad(std::move(enabled_previews));
EXPECT_EQ(1U, black_list_map_->size());
auto iter = black_list_map_->find(test_host);
@@ -172,7 +181,9 @@ TEST_F(PreviewsOptOutStoreSQLTest, TestMaxRows) {
std::string row_limit_string = base::SizeTToString(row_limit);
command_line->AppendSwitchASCII("previews-max-opt-out-rows",
row_limit_string);
- CreateAndLoad();
+ std::unique_ptr<PreviewsTypeList> enabled_previews(new PreviewsTypeList);
+ enabled_previews->push_back({PreviewsType::OFFLINE, 0});
+ CreateAndLoad(std::move(enabled_previews));
histogram_tester_.ExpectUniqueSample("Previews.OptOut.DBRowCount", 0, 1);
base::SimpleTestClock clock;
@@ -194,7 +205,9 @@ TEST_F(PreviewsOptOutStoreSQLTest, TestMaxRows) {
DestroyStore();
// Reload and test for persistence
- CreateAndLoad();
+ enabled_previews.reset(new PreviewsTypeList);
+ enabled_previews->push_back({PreviewsType::OFFLINE, 0});
+ CreateAndLoad(std::move(enabled_previews));
histogram_tester_.ExpectBucketCount("Previews.OptOut.DBRowCount",
static_cast<int>(row_limit) + 1, 1);
// The delete happens after the load, so it is possible to load more than
@@ -204,7 +217,9 @@ TEST_F(PreviewsOptOutStoreSQLTest, TestMaxRows) {
host_indifferent_item_->OptOutRecordsSizeForTesting());
DestroyStore();
- CreateAndLoad();
+ enabled_previews.reset(new PreviewsTypeList);
+ enabled_previews->push_back({PreviewsType::OFFLINE, 0});
+ CreateAndLoad(std::move(enabled_previews));
histogram_tester_.ExpectBucketCount("Previews.OptOut.DBRowCount",
static_cast<int>(row_limit), 1);
@@ -232,7 +247,9 @@ TEST_F(PreviewsOptOutStoreSQLTest, TestMaxRowsPerHost) {
std::string row_limit_string = base::SizeTToString(row_limit);
command_line->AppendSwitchASCII("previews-max-opt-out-rows-per-host",
row_limit_string);
- CreateAndLoad();
+ std::unique_ptr<PreviewsTypeList> enabled_previews(new PreviewsTypeList);
+ enabled_previews->push_back({PreviewsType::OFFLINE, 0});
+ CreateAndLoad(std::move(enabled_previews));
histogram_tester_.ExpectUniqueSample("Previews.OptOut.DBRowCount", 0, 1);
base::SimpleTestClock clock;
@@ -254,7 +271,9 @@ TEST_F(PreviewsOptOutStoreSQLTest, TestMaxRowsPerHost) {
DestroyStore();
// Reload and test for persistence.
- CreateAndLoad();
+ enabled_previews.reset(new PreviewsTypeList);
+ enabled_previews->push_back({PreviewsType::OFFLINE, 0});
+ CreateAndLoad(std::move(enabled_previews));
histogram_tester_.ExpectBucketCount("Previews.OptOut.DBRowCount",
static_cast<int>(row_limit), 1);
@@ -277,13 +296,10 @@ TEST_F(PreviewsOptOutStoreSQLTest, TestPreviewsDisabledClearsBlacklistEntry) {
// Tests if data is cleared for previews type when it is disabled.
// Enable offline previews and add black list entry for it.
std::map<std::string, std::string> params;
- params["show_offline_pages"] = "true";
- EXPECT_TRUE(
- base::AssociateFieldTrialParams("ClientSidePreviews", "Enabled", params));
- EXPECT_TRUE(
- base::FieldTrialList::CreateFieldTrial("ClientSidePreviews", "Enabled"));
std::string test_host = "host.com";
- CreateAndLoad();
+ std::unique_ptr<PreviewsTypeList> enabled_previews(new PreviewsTypeList);
+ enabled_previews->push_back({PreviewsType::OFFLINE, 0});
+ CreateAndLoad(std::move(enabled_previews));
histogram_tester_.ExpectUniqueSample("Previews.OptOut.DBRowCount", 0, 1);
base::Time now = base::Time::Now();
store_->AddPreviewNavigation(true, test_host, PreviewsType::OFFLINE, now);
@@ -292,41 +308,29 @@ TEST_F(PreviewsOptOutStoreSQLTest, TestPreviewsDisabledClearsBlacklistEntry) {
// Force data write to database then reload it and verify black list entry
// is present.
DestroyStore();
- CreateAndLoad();
+ enabled_previews.reset(new PreviewsTypeList);
+ enabled_previews->push_back({PreviewsType::OFFLINE, 0});
+ CreateAndLoad(std::move(enabled_previews));
auto iter = black_list_map_->find(test_host);
EXPECT_NE(black_list_map_->end(), iter);
EXPECT_EQ(1U, iter->second->OptOutRecordsSizeForTesting());
- // Now reload with offline pages previews disabled and verify black list
- // entry dropped.
- ResetFieldTrials();
- params["show_offline_pages"] = "false";
- EXPECT_TRUE(
- base::AssociateFieldTrialParams("ClientSidePreviews", "Enabled", params));
- EXPECT_TRUE(
- base::FieldTrialList::CreateFieldTrial("ClientSidePreviews", "Enabled"));
DestroyStore();
- CreateAndLoad();
+ enabled_previews.reset(new PreviewsTypeList);
+ CreateAndLoad(std::move(enabled_previews));
iter = black_list_map_->find(test_host);
EXPECT_EQ(black_list_map_->end(), iter);
- // Clean up field trials set in this test.
- ResetFieldTrials();
}
TEST_F(PreviewsOptOutStoreSQLTest,
TestPreviewsVersionUpdateClearsBlacklistEntry) {
// Tests if data is cleared for new version of previews type.
// Enable offline previews and add black list entry for it.
- std::map<std::string, std::string> params;
- params["show_offline_pages"] = "true";
- params["version"] = "1";
- EXPECT_TRUE(
- base::AssociateFieldTrialParams("ClientSidePreviews", "Enabled", params));
- EXPECT_TRUE(
- base::FieldTrialList::CreateFieldTrial("ClientSidePreviews", "Enabled"));
std::string test_host = "host.com";
- CreateAndLoad();
+ std::unique_ptr<PreviewsTypeList> enabled_previews(new PreviewsTypeList);
+ enabled_previews->push_back({PreviewsType::OFFLINE, 1});
+ CreateAndLoad(std::move(enabled_previews));
histogram_tester_.ExpectUniqueSample("Previews.OptOut.DBRowCount", 0, 1);
base::Time now = base::Time::Now();
store_->AddPreviewNavigation(true, test_host, PreviewsType::OFFLINE, now);
@@ -335,26 +339,19 @@ TEST_F(PreviewsOptOutStoreSQLTest,
// Force data write to database then reload it and verify black list entry
// is present.
DestroyStore();
- CreateAndLoad();
+ enabled_previews.reset(new PreviewsTypeList);
+ enabled_previews->push_back({PreviewsType::OFFLINE, 1});
+ CreateAndLoad(std::move(enabled_previews));
auto iter = black_list_map_->find(test_host);
EXPECT_NE(black_list_map_->end(), iter);
EXPECT_EQ(1U, iter->second->OptOutRecordsSizeForTesting());
- // Now reload with incremented previews version and verify black list
- // entry dropped.
- ResetFieldTrials();
- params["version"] = "2";
- EXPECT_TRUE(
- base::AssociateFieldTrialParams("ClientSidePreviews", "Enabled", params));
- EXPECT_TRUE(
- base::FieldTrialList::CreateFieldTrial("ClientSidePreviews", "Enabled"));
DestroyStore();
- CreateAndLoad();
+ enabled_previews.reset(new PreviewsTypeList);
+ enabled_previews->push_back({PreviewsType::OFFLINE, 2});
+ CreateAndLoad(std::move(enabled_previews));
iter = black_list_map_->find(test_host);
EXPECT_EQ(black_list_map_->end(), iter);
-
- // Clean up field trials set in this test.
- ResetFieldTrials();
}
} // namespace net
« no previous file with comments | « components/previews/core/previews_opt_out_store_sql.cc ('k') | components/previews/core/previews_ui_service.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698