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

Unified Diff: chrome/browser/history/browsing_history_service_unittest.cc

Issue 2450453002: Refactor BrowsingHistoryHandler, create BrowsingHistoryService (Closed)
Patch Set: Add missing import Created 4 years, 1 month 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: chrome/browser/history/browsing_history_service_unittest.cc
diff --git a/chrome/browser/history/browsing_history_service_unittest.cc b/chrome/browser/history/browsing_history_service_unittest.cc
new file mode 100644
index 0000000000000000000000000000000000000000..8473fd40b2ec42dc8deeccd4b15264f1c253c295
--- /dev/null
+++ b/chrome/browser/history/browsing_history_service_unittest.cc
@@ -0,0 +1,147 @@
+// Copyright 2016 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "chrome/browser/history/browsing_history_service.h"
+
+#include <stdint.h>
+#include <memory>
+
+#include "base/macros.h"
+#include "base/values.h"
+#include "testing/gtest/include/gtest/gtest.h"
+#include "url/gurl.h"
+
+namespace {
+
+struct TestResult {
+ std::string url;
+ int64_t hour_offset; // Visit time in hours past the baseline time.
+};
+
+// Duplicates on the same day in the local timezone are removed, so set a
+// baseline time in local time.
+const base::Time baseline_time = base::Time::UnixEpoch().LocalMidnight();
+
+// For each item in |results|, create a new Value representing the visit, and
+// insert it into |list_value|.
+void AddQueryResults(
+ TestResult* test_results,
+ int test_results_size,
+ std::vector<BrowsingHistoryService::HistoryEntry>* results) {
+ for (int i = 0; i < test_results_size; ++i) {
+ BrowsingHistoryService::HistoryEntry entry;
+ entry.time = baseline_time +
+ base::TimeDelta::FromHours(test_results[i].hour_offset);
+ entry.url = GURL(test_results[i].url);
+ entry.all_timestamps.insert(entry.time.ToInternalValue());
+ results->push_back(entry);
+ }
+}
+
+// Returns true if |result| matches the test data given by |correct_result|,
+// otherwise returns false.
+bool ResultEquals(
+ const BrowsingHistoryService::HistoryEntry& result,
+ const TestResult& correct_result) {
+ base::Time correct_time =
+ baseline_time + base::TimeDelta::FromHours(correct_result.hour_offset);
+
+ return result.time == correct_time && result.url == GURL(correct_result.url);
+}
+
+} // namespace
+
+class BrowsingHistoryServiceTest : public ::testing::Test {
+ public:
+ BrowsingHistoryServiceTest() {}
+ ~BrowsingHistoryServiceTest() override {}
+};
+
+// Tests that the MergeDuplicateResults method correctly removes duplicate
+// visits to the same URL on the same day.
+// Fails on Android. http://crbug.com/2345
+#if defined(OS_ANDROID)
+#define MAYBE_MergeDuplicateResults DISABLED_MergeDuplicateResults
+#else
+#define MAYBE_MergeDuplicateResults MergeDuplicateResults
+#endif
+TEST_F(BrowsingHistoryServiceTest, MAYBE_MergeDuplicateResults) {
+ {
+ // Basic test that duplicates on the same day are removed.
+ TestResult test_data[] = {
+ { "http://google.com", 0 },
+ { "http://google.de", 1 },
+ { "http://google.com", 2 },
+ { "http://google.com", 3 } // Most recent.
+ };
+ std::vector<BrowsingHistoryService::HistoryEntry> results;
+ AddQueryResults(test_data, arraysize(test_data), &results);
+ BrowsingHistoryService::MergeDuplicateResults(&results);
+
+ ASSERT_EQ(2U, results.size());
+ EXPECT_TRUE(ResultEquals(results[0], test_data[3]));
+ EXPECT_TRUE(ResultEquals(results[1], test_data[1]));
+ }
+
+ {
+ // Test that a duplicate URL on the next day is not removed.
+ TestResult test_data[] = {
+ { "http://google.com", 0 },
+ { "http://google.com", 23 },
+ { "http://google.com", 24 }, // Most recent.
+ };
+ std::vector<BrowsingHistoryService::HistoryEntry> results;
+ AddQueryResults(test_data, arraysize(test_data), &results);
+ BrowsingHistoryService::MergeDuplicateResults(&results);
+
+ ASSERT_EQ(2U, results.size());
+ EXPECT_TRUE(ResultEquals(results[0], test_data[2]));
+ EXPECT_TRUE(ResultEquals(results[1], test_data[1]));
+ }
+
+ {
+ // Test multiple duplicates across multiple days.
+ TestResult test_data[] = {
+ // First day.
+ { "http://google.de", 0 },
+ { "http://google.com", 1 },
+ { "http://google.de", 2 },
+ { "http://google.com", 3 },
+
+ // Second day.
+ { "http://google.de", 24 },
+ { "http://google.com", 25 },
+ { "http://google.de", 26 },
+ { "http://google.com", 27 }, // Most recent.
+ };
+ std::vector<BrowsingHistoryService::HistoryEntry> results;
+ AddQueryResults(test_data, arraysize(test_data), &results);
+ BrowsingHistoryService::MergeDuplicateResults(&results);
+
+ ASSERT_EQ(4U, results.size());
+ EXPECT_TRUE(ResultEquals(results[0], test_data[7]));
+ EXPECT_TRUE(ResultEquals(results[1], test_data[6]));
+ EXPECT_TRUE(ResultEquals(results[2], test_data[3]));
+ EXPECT_TRUE(ResultEquals(results[3], test_data[2]));
+ }
+
+ {
+ // Test that timestamps for duplicates are properly saved.
+ TestResult test_data[] = {
+ { "http://google.com", 0 },
+ { "http://google.de", 1 },
+ { "http://google.com", 2 },
+ { "http://google.com", 3 } // Most recent.
+ };
+ std::vector<BrowsingHistoryService::HistoryEntry> results;
+ AddQueryResults(test_data, arraysize(test_data), &results);
+ BrowsingHistoryService::MergeDuplicateResults(&results);
+
+ ASSERT_EQ(2U, results.size());
+ EXPECT_TRUE(ResultEquals(results[0], test_data[3]));
+ EXPECT_TRUE(ResultEquals(results[1], test_data[1]));
+ EXPECT_EQ(3u, results[0].all_timestamps.size());
+ EXPECT_EQ(1u, results[1].all_timestamps.size());
+ }
+}
« no previous file with comments | « chrome/browser/history/browsing_history_service_handler.h ('k') | chrome/browser/ui/webui/browsing_history_handler.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698