| OLD | NEW |
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "chrome/browser/autocomplete/network_action_predictor.h" | 5 #include "chrome/browser/predictors/autocomplete_action_predictor.h" |
| 6 | 6 |
| 7 #include "base/command_line.h" | 7 #include "base/command_line.h" |
| 8 #include "base/memory/ref_counted.h" | 8 #include "base/memory/ref_counted.h" |
| 9 #include "base/message_loop.h" | 9 #include "base/message_loop.h" |
| 10 #include "base/string_util.h" | 10 #include "base/string_util.h" |
| 11 #include "base/time.h" | 11 #include "base/time.h" |
| 12 #include "base/utf_string_conversions.h" | 12 #include "base/utf_string_conversions.h" |
| 13 #include "chrome/browser/autocomplete/autocomplete_match.h" | 13 #include "chrome/browser/autocomplete/autocomplete_match.h" |
| 14 #include "chrome/browser/history/history.h" | 14 #include "chrome/browser/history/history.h" |
| 15 #include "chrome/browser/history/in_memory_database.h" | 15 #include "chrome/browser/history/in_memory_database.h" |
| 16 #include "chrome/browser/history/url_database.h" | 16 #include "chrome/browser/history/url_database.h" |
| 17 #include "chrome/browser/prerender/prerender_field_trial.h" | 17 #include "chrome/browser/prerender/prerender_field_trial.h" |
| 18 #include "chrome/common/chrome_switches.h" | 18 #include "chrome/common/chrome_switches.h" |
| 19 #include "chrome/common/guid.h" | 19 #include "chrome/common/guid.h" |
| 20 #include "chrome/test/base/testing_profile.h" | 20 #include "chrome/test/base/testing_profile.h" |
| 21 #include "content/test/test_browser_thread.h" | 21 #include "content/test/test_browser_thread.h" |
| 22 #include "testing/gtest/include/gtest/gtest.h" | 22 #include "testing/gtest/include/gtest/gtest.h" |
| 23 | 23 |
| 24 using content::BrowserThread; | 24 using content::BrowserThread; |
| 25 using predictors::AutocompleteActionPredictor; |
| 25 | 26 |
| 26 namespace { | 27 namespace { |
| 27 | 28 |
| 28 struct TestUrlInfo { | 29 struct TestUrlInfo { |
| 29 GURL url; | 30 GURL url; |
| 30 string16 title; | 31 string16 title; |
| 31 int days_from_now; | 32 int days_from_now; |
| 32 string16 user_text; | 33 string16 user_text; |
| 33 int number_of_hits; | 34 int number_of_hits; |
| 34 int number_of_misses; | 35 int number_of_misses; |
| 35 NetworkActionPredictor::Action expected_action; | 36 AutocompleteActionPredictor::Action expected_action; |
| 36 } test_url_db[] = { | 37 } test_url_db[] = { |
| 37 { GURL("http://www.testsite.com/a.html"), | 38 { GURL("http://www.testsite.com/a.html"), |
| 38 ASCIIToUTF16("Test - site - just a test"), 1, | 39 ASCIIToUTF16("Test - site - just a test"), 1, |
| 39 ASCIIToUTF16("j"), 5, 0, | 40 ASCIIToUTF16("j"), 5, 0, |
| 40 NetworkActionPredictor::ACTION_PRERENDER }, | 41 AutocompleteActionPredictor::ACTION_PRERENDER }, |
| 41 { GURL("http://www.testsite.com/b.html"), | 42 { GURL("http://www.testsite.com/b.html"), |
| 42 ASCIIToUTF16("Test - site - just a test"), 1, | 43 ASCIIToUTF16("Test - site - just a test"), 1, |
| 43 ASCIIToUTF16("ju"), 3, 0, | 44 ASCIIToUTF16("ju"), 3, 0, |
| 44 NetworkActionPredictor::ACTION_PRERENDER }, | 45 AutocompleteActionPredictor::ACTION_PRERENDER }, |
| 45 { GURL("http://www.testsite.com/c.html"), | 46 { GURL("http://www.testsite.com/c.html"), |
| 46 ASCIIToUTF16("Test - site - just a test"), 5, | 47 ASCIIToUTF16("Test - site - just a test"), 5, |
| 47 ASCIIToUTF16("just"), 3, 1, | 48 ASCIIToUTF16("just"), 3, 1, |
| 48 NetworkActionPredictor::ACTION_PRECONNECT }, | 49 AutocompleteActionPredictor::ACTION_PRECONNECT }, |
| 49 { GURL("http://www.testsite.com/d.html"), | 50 { GURL("http://www.testsite.com/d.html"), |
| 50 ASCIIToUTF16("Test - site - just a test"), 5, | 51 ASCIIToUTF16("Test - site - just a test"), 5, |
| 51 ASCIIToUTF16("just"), 3, 0, | 52 ASCIIToUTF16("just"), 3, 0, |
| 52 NetworkActionPredictor::ACTION_PRERENDER }, | 53 AutocompleteActionPredictor::ACTION_PRERENDER }, |
| 53 { GURL("http://www.testsite.com/e.html"), | 54 { GURL("http://www.testsite.com/e.html"), |
| 54 ASCIIToUTF16("Test - site - just a test"), 8, | 55 ASCIIToUTF16("Test - site - just a test"), 8, |
| 55 ASCIIToUTF16("just"), 3, 1, | 56 ASCIIToUTF16("just"), 3, 1, |
| 56 NetworkActionPredictor::ACTION_PRECONNECT }, | 57 AutocompleteActionPredictor::ACTION_PRECONNECT }, |
| 57 { GURL("http://www.testsite.com/f.html"), | 58 { GURL("http://www.testsite.com/f.html"), |
| 58 ASCIIToUTF16("Test - site - just a test"), 8, | 59 ASCIIToUTF16("Test - site - just a test"), 8, |
| 59 ASCIIToUTF16("just"), 3, 0, | 60 ASCIIToUTF16("just"), 3, 0, |
| 60 NetworkActionPredictor::ACTION_PRERENDER }, | 61 AutocompleteActionPredictor::ACTION_PRERENDER }, |
| 61 { GURL("http://www.testsite.com/g.html"), | 62 { GURL("http://www.testsite.com/g.html"), |
| 62 ASCIIToUTF16("Test - site - just a test"), 12, | 63 ASCIIToUTF16("Test - site - just a test"), 12, |
| 63 ASCIIToUTF16(""), 5, 0, | 64 ASCIIToUTF16(""), 5, 0, |
| 64 NetworkActionPredictor::ACTION_NONE }, | 65 AutocompleteActionPredictor::ACTION_NONE }, |
| 65 { GURL("http://www.testsite.com/h.html"), | 66 { GURL("http://www.testsite.com/h.html"), |
| 66 ASCIIToUTF16("Test - site - just a test"), 21, | 67 ASCIIToUTF16("Test - site - just a test"), 21, |
| 67 ASCIIToUTF16("just a test"), 2, 0, | 68 ASCIIToUTF16("just a test"), 2, 0, |
| 68 NetworkActionPredictor::ACTION_NONE }, | 69 AutocompleteActionPredictor::ACTION_NONE }, |
| 69 { GURL("http://www.testsite.com/i.html"), | 70 { GURL("http://www.testsite.com/i.html"), |
| 70 ASCIIToUTF16("Test - site - just a test"), 28, | 71 ASCIIToUTF16("Test - site - just a test"), 28, |
| 71 ASCIIToUTF16("just a test"), 2, 0, | 72 ASCIIToUTF16("just a test"), 2, 0, |
| 72 NetworkActionPredictor::ACTION_NONE } | 73 AutocompleteActionPredictor::ACTION_NONE } |
| 73 }; | 74 }; |
| 74 | 75 |
| 75 } // end namespace | 76 } // end namespace |
| 76 | 77 |
| 77 class NetworkActionPredictorTest : public testing::Test { | 78 namespace predictors { |
| 79 |
| 80 class AutocompleteActionPredictorTest : public testing::Test { |
| 78 public: | 81 public: |
| 79 NetworkActionPredictorTest() | 82 AutocompleteActionPredictorTest() |
| 80 : loop_(MessageLoop::TYPE_DEFAULT), | 83 : loop_(MessageLoop::TYPE_DEFAULT), |
| 81 ui_thread_(BrowserThread::UI, &loop_), | 84 ui_thread_(BrowserThread::UI, &loop_), |
| 82 db_thread_(BrowserThread::DB, &loop_), | 85 db_thread_(BrowserThread::DB, &loop_), |
| 83 file_thread_(BrowserThread::FILE, &loop_), | 86 file_thread_(BrowserThread::FILE, &loop_), |
| 84 predictor_(new NetworkActionPredictor(&profile_)) { | 87 predictor_(new AutocompleteActionPredictor(&profile_)) { |
| 85 } | 88 } |
| 86 | 89 |
| 87 void SetUp() { | 90 void SetUp() { |
| 88 CommandLine::ForCurrentProcess()->AppendSwitchASCII( | 91 CommandLine::ForCurrentProcess()->AppendSwitchASCII( |
| 89 switches::kPrerenderFromOmnibox, | 92 switches::kPrerenderFromOmnibox, |
| 90 switches::kPrerenderFromOmniboxSwitchValueEnabled); | 93 switches::kPrerenderFromOmniboxSwitchValueEnabled); |
| 91 | 94 |
| 92 profile_.CreateHistoryService(true, false); | 95 profile_.CreateHistoryService(true, false); |
| 93 profile_.BlockUntilHistoryProcessesPendingRequests(); | 96 profile_.BlockUntilHistoryProcessesPendingRequests(); |
| 94 | 97 |
| 95 ASSERT_TRUE(predictor_->initialized_); | 98 ASSERT_TRUE(predictor_->initialized_); |
| 96 ASSERT_TRUE(db_cache()->empty()); | 99 ASSERT_TRUE(db_cache()->empty()); |
| 97 ASSERT_TRUE(db_id_cache()->empty()); | 100 ASSERT_TRUE(db_id_cache()->empty()); |
| 98 } | 101 } |
| 99 | 102 |
| 100 void TearDown() { | 103 void TearDown() { |
| 101 profile_.DestroyHistoryService(); | 104 profile_.DestroyHistoryService(); |
| 102 predictor_->Shutdown(); | 105 predictor_->Shutdown(); |
| 103 } | 106 } |
| 104 | 107 |
| 105 protected: | 108 protected: |
| 106 typedef NetworkActionPredictor::DBCacheKey DBCacheKey; | 109 typedef AutocompleteActionPredictor::DBCacheKey DBCacheKey; |
| 107 typedef NetworkActionPredictor::DBCacheValue DBCacheValue; | 110 typedef AutocompleteActionPredictor::DBCacheValue DBCacheValue; |
| 108 typedef NetworkActionPredictor::DBCacheMap DBCacheMap; | 111 typedef AutocompleteActionPredictor::DBCacheMap DBCacheMap; |
| 109 typedef NetworkActionPredictor::DBIdCacheMap DBIdCacheMap; | 112 typedef AutocompleteActionPredictor::DBIdCacheMap DBIdCacheMap; |
| 110 | 113 |
| 111 void AddAllRowsToHistory() { | 114 void AddAllRowsToHistory() { |
| 112 for (size_t i = 0; i < arraysize(test_url_db); ++i) | 115 for (size_t i = 0; i < arraysize(test_url_db); ++i) |
| 113 ASSERT_TRUE(AddRowToHistory(test_url_db[i])); | 116 ASSERT_TRUE(AddRowToHistory(test_url_db[i])); |
| 114 } | 117 } |
| 115 | 118 |
| 116 history::URLID AddRowToHistory(const TestUrlInfo& test_row) { | 119 history::URLID AddRowToHistory(const TestUrlInfo& test_row) { |
| 117 HistoryService* history = | 120 HistoryService* history = |
| 118 profile_.GetHistoryService(Profile::EXPLICIT_ACCESS); | 121 profile_.GetHistoryService(Profile::EXPLICIT_ACCESS); |
| 119 CHECK(history); | 122 CHECK(history); |
| 120 history::URLDatabase* url_db = history->InMemoryDatabase(); | 123 history::URLDatabase* url_db = history->InMemoryDatabase(); |
| 121 CHECK(url_db); | 124 CHECK(url_db); |
| 122 | 125 |
| 123 const base::Time visit_time = | 126 const base::Time visit_time = |
| 124 base::Time::Now() - base::TimeDelta::FromDays( | 127 base::Time::Now() - base::TimeDelta::FromDays( |
| 125 test_row.days_from_now); | 128 test_row.days_from_now); |
| 126 | 129 |
| 127 history::URLRow row(test_row.url); | 130 history::URLRow row(test_row.url); |
| 128 row.set_title(test_row.title); | 131 row.set_title(test_row.title); |
| 129 row.set_last_visit(visit_time); | 132 row.set_last_visit(visit_time); |
| 130 | 133 |
| 131 return url_db->AddURL(row); | 134 return url_db->AddURL(row); |
| 132 } | 135 } |
| 133 | 136 |
| 134 NetworkActionPredictorDatabase::Row CreateRowFromTestUrlInfo( | 137 AutocompleteActionPredictorTable::Row CreateRowFromTestUrlInfo( |
| 135 const TestUrlInfo& test_row) const { | 138 const TestUrlInfo& test_row) const { |
| 136 NetworkActionPredictorDatabase::Row row; | 139 AutocompleteActionPredictorTable::Row row; |
| 137 row.id = guid::GenerateGUID(); | 140 row.id = guid::GenerateGUID(); |
| 138 row.user_text = test_row.user_text; | 141 row.user_text = test_row.user_text; |
| 139 row.url = test_row.url; | 142 row.url = test_row.url; |
| 140 row.number_of_hits = test_row.number_of_hits; | 143 row.number_of_hits = test_row.number_of_hits; |
| 141 row.number_of_misses = test_row.number_of_misses; | 144 row.number_of_misses = test_row.number_of_misses; |
| 142 return row; | 145 return row; |
| 143 } | 146 } |
| 144 | 147 |
| 145 void AddAllRows() { | 148 void AddAllRows() { |
| 146 for (size_t i = 0; i < arraysize(test_url_db); ++i) | 149 for (size_t i = 0; i < arraysize(test_url_db); ++i) |
| 147 AddRow(test_url_db[i]); | 150 AddRow(test_url_db[i]); |
| 148 } | 151 } |
| 149 | 152 |
| 150 std::string AddRow(const TestUrlInfo& test_row) { | 153 std::string AddRow(const TestUrlInfo& test_row) { |
| 151 NetworkActionPredictor::DBCacheKey key = { test_row.user_text, | 154 AutocompleteActionPredictor::DBCacheKey key = { test_row.user_text, |
| 152 test_row.url }; | 155 test_row.url }; |
| 153 NetworkActionPredictorDatabase::Row row = | 156 AutocompleteActionPredictorTable::Row row = |
| 154 CreateRowFromTestUrlInfo(test_row); | 157 CreateRowFromTestUrlInfo(test_row); |
| 155 predictor_->AddRow(key, row); | 158 predictor_->AddAndUpdateRows( |
| 159 AutocompleteActionPredictorTable::Rows(1, row), |
| 160 AutocompleteActionPredictorTable::Rows()); |
| 156 | 161 |
| 157 return row.id; | 162 return row.id; |
| 158 } | 163 } |
| 159 | 164 |
| 160 void UpdateRow(NetworkActionPredictor::DBCacheKey key, | 165 void UpdateRow(const AutocompleteActionPredictorTable::Row& row) { |
| 161 const NetworkActionPredictorDatabase::Row& row) { | 166 AutocompleteActionPredictor::DBCacheKey key = { row.user_text, row.url }; |
| 162 NetworkActionPredictor::DBCacheMap::iterator it = | 167 ASSERT_TRUE(db_cache()->find(key) != db_cache()->end()); |
| 163 db_cache()->find(key); | 168 predictor_->AddAndUpdateRows( |
| 164 ASSERT_TRUE(it != db_cache()->end()); | 169 AutocompleteActionPredictorTable::Rows(), |
| 165 | 170 AutocompleteActionPredictorTable::Rows(1, row)); |
| 166 predictor_->UpdateRow(it, row); | |
| 167 } | 171 } |
| 168 | 172 |
| 169 void DeleteAllRows() { | 173 void DeleteAllRows() { |
| 170 predictor_->DeleteAllRows(); | 174 predictor_->DeleteAllRows(); |
| 171 } | 175 } |
| 172 | 176 |
| 173 void DeleteRowsWithURLs(const std::set<GURL>& urls) { | 177 void DeleteRowsWithURLs(const std::set<GURL>& urls) { |
| 174 predictor_->DeleteRowsWithURLs(urls); | 178 predictor_->DeleteRowsWithURLs(urls); |
| 175 } | 179 } |
| 176 | 180 |
| 177 void DeleteOldIdsFromCaches( | 181 void DeleteOldIdsFromCaches( |
| 178 std::vector<NetworkActionPredictorDatabase::Row::Id>* id_list) { | 182 std::vector<AutocompleteActionPredictorTable::Row::Id>* id_list) { |
| 179 HistoryService* history_service = | 183 HistoryService* history_service = |
| 180 profile_.GetHistoryService(Profile::EXPLICIT_ACCESS); | 184 profile_.GetHistoryService(Profile::EXPLICIT_ACCESS); |
| 181 ASSERT_TRUE(history_service); | 185 ASSERT_TRUE(history_service); |
| 182 | 186 |
| 183 history::URLDatabase* url_db = history_service->InMemoryDatabase(); | 187 history::URLDatabase* url_db = history_service->InMemoryDatabase(); |
| 184 ASSERT_TRUE(url_db); | 188 ASSERT_TRUE(url_db); |
| 185 | 189 |
| 186 predictor_->DeleteOldIdsFromCaches(url_db, id_list); | 190 predictor_->DeleteOldIdsFromCaches(url_db, id_list); |
| 187 } | 191 } |
| 188 | 192 |
| 189 NetworkActionPredictor* predictor() { return predictor_.get(); } | 193 AutocompleteActionPredictor* predictor() { return predictor_.get(); } |
| 190 | 194 |
| 191 DBCacheMap* db_cache() { return &predictor_->db_cache_; } | 195 DBCacheMap* db_cache() { return &predictor_->db_cache_; } |
| 192 DBIdCacheMap* db_id_cache() { return &predictor_->db_id_cache_; } | 196 DBIdCacheMap* db_id_cache() { return &predictor_->db_id_cache_; } |
| 193 | 197 |
| 194 static int maximum_days_to_keep_entry() { | 198 static int maximum_days_to_keep_entry() { |
| 195 return NetworkActionPredictor::kMaximumDaysToKeepEntry; | 199 return AutocompleteActionPredictor::kMaximumDaysToKeepEntry; |
| 196 } | 200 } |
| 197 | 201 |
| 198 private: | 202 private: |
| 199 MessageLoop loop_; | 203 MessageLoop loop_; |
| 200 content::TestBrowserThread ui_thread_; | 204 content::TestBrowserThread ui_thread_; |
| 201 content::TestBrowserThread db_thread_; | 205 content::TestBrowserThread db_thread_; |
| 202 content::TestBrowserThread file_thread_; | 206 content::TestBrowserThread file_thread_; |
| 203 TestingProfile profile_; | 207 TestingProfile profile_; |
| 204 scoped_ptr<NetworkActionPredictor> predictor_; | 208 scoped_ptr<AutocompleteActionPredictor> predictor_; |
| 205 }; | 209 }; |
| 206 | 210 |
| 207 | 211 |
| 208 TEST_F(NetworkActionPredictorTest, AddRow) { | 212 TEST_F(AutocompleteActionPredictorTest, AddRow) { |
| 209 // Add a test entry to the predictor. | 213 // Add a test entry to the predictor. |
| 210 std::string guid = AddRow(test_url_db[0]); | 214 std::string guid = AddRow(test_url_db[0]); |
| 211 | 215 |
| 212 // Get the data back out of the cache. | 216 // Get the data back out of the cache. |
| 213 const DBCacheKey key = { test_url_db[0].user_text, test_url_db[0].url }; | 217 const DBCacheKey key = { test_url_db[0].user_text, test_url_db[0].url }; |
| 214 DBCacheMap::const_iterator it = db_cache()->find(key); | 218 DBCacheMap::const_iterator it = db_cache()->find(key); |
| 215 EXPECT_TRUE(it != db_cache()->end()); | 219 EXPECT_TRUE(it != db_cache()->end()); |
| 216 | 220 |
| 217 const DBCacheValue value = { test_url_db[0].number_of_hits, | 221 const DBCacheValue value = { test_url_db[0].number_of_hits, |
| 218 test_url_db[0].number_of_misses }; | 222 test_url_db[0].number_of_misses }; |
| 219 EXPECT_EQ(value.number_of_hits, it->second.number_of_hits); | 223 EXPECT_EQ(value.number_of_hits, it->second.number_of_hits); |
| 220 EXPECT_EQ(value.number_of_misses, it->second.number_of_misses); | 224 EXPECT_EQ(value.number_of_misses, it->second.number_of_misses); |
| 221 | 225 |
| 222 DBIdCacheMap::const_iterator id_it = db_id_cache()->find(key); | 226 DBIdCacheMap::const_iterator id_it = db_id_cache()->find(key); |
| 223 EXPECT_TRUE(id_it != db_id_cache()->end()); | 227 EXPECT_TRUE(id_it != db_id_cache()->end()); |
| 224 EXPECT_EQ(guid, id_it->second); | 228 EXPECT_EQ(guid, id_it->second); |
| 225 } | 229 } |
| 226 | 230 |
| 227 TEST_F(NetworkActionPredictorTest, UpdateRow) { | 231 TEST_F(AutocompleteActionPredictorTest, UpdateRow) { |
| 228 ASSERT_NO_FATAL_FAILURE(AddAllRows()); | 232 ASSERT_NO_FATAL_FAILURE(AddAllRows()); |
| 229 | 233 |
| 230 EXPECT_EQ(arraysize(test_url_db), db_cache()->size()); | 234 EXPECT_EQ(arraysize(test_url_db), db_cache()->size()); |
| 231 EXPECT_EQ(arraysize(test_url_db), db_id_cache()->size()); | 235 EXPECT_EQ(arraysize(test_url_db), db_id_cache()->size()); |
| 232 | 236 |
| 233 // Get the data back out of the cache. | 237 // Get the data back out of the cache. |
| 234 const DBCacheKey key = { test_url_db[0].user_text, test_url_db[0].url }; | 238 const DBCacheKey key = { test_url_db[0].user_text, test_url_db[0].url }; |
| 235 DBCacheMap::const_iterator it = db_cache()->find(key); | 239 DBCacheMap::const_iterator it = db_cache()->find(key); |
| 236 EXPECT_TRUE(it != db_cache()->end()); | 240 EXPECT_TRUE(it != db_cache()->end()); |
| 237 | 241 |
| 238 DBIdCacheMap::const_iterator id_it = db_id_cache()->find(key); | 242 DBIdCacheMap::const_iterator id_it = db_id_cache()->find(key); |
| 239 EXPECT_TRUE(id_it != db_id_cache()->end()); | 243 EXPECT_TRUE(id_it != db_id_cache()->end()); |
| 240 | 244 |
| 241 NetworkActionPredictorDatabase::Row update_row; | 245 AutocompleteActionPredictorTable::Row update_row; |
| 242 update_row.id = id_it->second; | 246 update_row.id = id_it->second; |
| 243 update_row.user_text = key.user_text; | 247 update_row.user_text = key.user_text; |
| 244 update_row.url = key.url; | 248 update_row.url = key.url; |
| 245 update_row.number_of_hits = it->second.number_of_hits + 1; | 249 update_row.number_of_hits = it->second.number_of_hits + 1; |
| 246 update_row.number_of_misses = it->second.number_of_misses + 2; | 250 update_row.number_of_misses = it->second.number_of_misses + 2; |
| 247 | 251 |
| 248 UpdateRow(key, update_row); | 252 UpdateRow(update_row); |
| 249 | 253 |
| 250 // Get the updated version. | 254 // Get the updated version. |
| 251 DBCacheMap::const_iterator update_it = db_cache()->find(key); | 255 DBCacheMap::const_iterator update_it = db_cache()->find(key); |
| 252 EXPECT_TRUE(update_it != db_cache()->end()); | 256 EXPECT_TRUE(update_it != db_cache()->end()); |
| 253 | 257 |
| 254 EXPECT_EQ(update_row.number_of_hits, update_it->second.number_of_hits); | 258 EXPECT_EQ(update_row.number_of_hits, update_it->second.number_of_hits); |
| 255 EXPECT_EQ(update_row.number_of_misses, update_it->second.number_of_misses); | 259 EXPECT_EQ(update_row.number_of_misses, update_it->second.number_of_misses); |
| 256 | 260 |
| 257 DBIdCacheMap::const_iterator update_id_it = db_id_cache()->find(key); | 261 DBIdCacheMap::const_iterator update_id_it = db_id_cache()->find(key); |
| 258 EXPECT_TRUE(update_id_it != db_id_cache()->end()); | 262 EXPECT_TRUE(update_id_it != db_id_cache()->end()); |
| 259 | 263 |
| 260 EXPECT_EQ(id_it->second, update_id_it->second); | 264 EXPECT_EQ(id_it->second, update_id_it->second); |
| 261 } | 265 } |
| 262 | 266 |
| 263 TEST_F(NetworkActionPredictorTest, DeleteAllRows) { | 267 TEST_F(AutocompleteActionPredictorTest, DeleteAllRows) { |
| 264 ASSERT_NO_FATAL_FAILURE(AddAllRows()); | 268 ASSERT_NO_FATAL_FAILURE(AddAllRows()); |
| 265 | 269 |
| 266 EXPECT_EQ(arraysize(test_url_db), db_cache()->size()); | 270 EXPECT_EQ(arraysize(test_url_db), db_cache()->size()); |
| 267 EXPECT_EQ(arraysize(test_url_db), db_id_cache()->size()); | 271 EXPECT_EQ(arraysize(test_url_db), db_id_cache()->size()); |
| 268 | 272 |
| 269 DeleteAllRows(); | 273 DeleteAllRows(); |
| 270 | 274 |
| 271 EXPECT_TRUE(db_cache()->empty()); | 275 EXPECT_TRUE(db_cache()->empty()); |
| 272 EXPECT_TRUE(db_id_cache()->empty()); | 276 EXPECT_TRUE(db_id_cache()->empty()); |
| 273 } | 277 } |
| 274 | 278 |
| 275 TEST_F(NetworkActionPredictorTest, DeleteRowsWithURLs) { | 279 TEST_F(AutocompleteActionPredictorTest, DeleteRowsWithURLs) { |
| 276 ASSERT_NO_FATAL_FAILURE(AddAllRows()); | 280 ASSERT_NO_FATAL_FAILURE(AddAllRows()); |
| 277 | 281 |
| 278 EXPECT_EQ(arraysize(test_url_db), db_cache()->size()); | 282 EXPECT_EQ(arraysize(test_url_db), db_cache()->size()); |
| 279 EXPECT_EQ(arraysize(test_url_db), db_id_cache()->size()); | 283 EXPECT_EQ(arraysize(test_url_db), db_id_cache()->size()); |
| 280 | 284 |
| 281 std::set<GURL> urls; | 285 std::set<GURL> urls; |
| 282 for (size_t i = 0; i < 2; ++i) | 286 for (size_t i = 0; i < 2; ++i) |
| 283 urls.insert(test_url_db[i].url); | 287 urls.insert(test_url_db[i].url); |
| 284 | 288 |
| 285 DeleteRowsWithURLs(urls); | 289 DeleteRowsWithURLs(urls); |
| 286 | 290 |
| 287 EXPECT_EQ(arraysize(test_url_db) - 2, db_cache()->size()); | 291 EXPECT_EQ(arraysize(test_url_db) - 2, db_cache()->size()); |
| 288 EXPECT_EQ(arraysize(test_url_db) - 2, db_id_cache()->size()); | 292 EXPECT_EQ(arraysize(test_url_db) - 2, db_id_cache()->size()); |
| 289 | 293 |
| 290 for (size_t i = 0; i < arraysize(test_url_db); ++i) { | 294 for (size_t i = 0; i < arraysize(test_url_db); ++i) { |
| 291 DBCacheKey key = { test_url_db[i].user_text, test_url_db[i].url }; | 295 DBCacheKey key = { test_url_db[i].user_text, test_url_db[i].url }; |
| 292 | 296 |
| 293 bool deleted = (i < 2); | 297 bool deleted = (i < 2); |
| 294 EXPECT_EQ(deleted, db_cache()->find(key) == db_cache()->end()); | 298 EXPECT_EQ(deleted, db_cache()->find(key) == db_cache()->end()); |
| 295 EXPECT_EQ(deleted, db_id_cache()->find(key) == db_id_cache()->end()); | 299 EXPECT_EQ(deleted, db_id_cache()->find(key) == db_id_cache()->end()); |
| 296 } | 300 } |
| 297 } | 301 } |
| 298 | 302 |
| 299 TEST_F(NetworkActionPredictorTest, DeleteOldIdsFromCaches) { | 303 TEST_F(AutocompleteActionPredictorTest, DeleteOldIdsFromCaches) { |
| 300 std::vector<NetworkActionPredictorDatabase::Row::Id> expected; | 304 std::vector<AutocompleteActionPredictorTable::Row::Id> expected; |
| 301 std::vector<NetworkActionPredictorDatabase::Row::Id> all_ids; | 305 std::vector<AutocompleteActionPredictorTable::Row::Id> all_ids; |
| 302 | 306 |
| 303 for (size_t i = 0; i < arraysize(test_url_db); ++i) { | 307 for (size_t i = 0; i < arraysize(test_url_db); ++i) { |
| 304 std::string row_id = AddRow(test_url_db[i]); | 308 std::string row_id = AddRow(test_url_db[i]); |
| 305 all_ids.push_back(row_id); | 309 all_ids.push_back(row_id); |
| 306 | 310 |
| 307 bool exclude_url = StartsWithASCII(test_url_db[i].url.path(), "/d", true) || | 311 bool exclude_url = StartsWithASCII(test_url_db[i].url.path(), "/d", true) || |
| 308 (test_url_db[i].days_from_now > maximum_days_to_keep_entry()); | 312 (test_url_db[i].days_from_now > maximum_days_to_keep_entry()); |
| 309 | 313 |
| 310 if (exclude_url) | 314 if (exclude_url) |
| 311 expected.push_back(row_id); | 315 expected.push_back(row_id); |
| 312 else | 316 else |
| 313 ASSERT_TRUE(AddRowToHistory(test_url_db[i])); | 317 ASSERT_TRUE(AddRowToHistory(test_url_db[i])); |
| 314 } | 318 } |
| 315 | 319 |
| 316 std::vector<NetworkActionPredictorDatabase::Row::Id> id_list; | 320 std::vector<AutocompleteActionPredictorTable::Row::Id> id_list; |
| 317 DeleteOldIdsFromCaches(&id_list); | 321 DeleteOldIdsFromCaches(&id_list); |
| 318 EXPECT_EQ(expected.size(), id_list.size()); | 322 EXPECT_EQ(expected.size(), id_list.size()); |
| 319 EXPECT_EQ(all_ids.size() - expected.size(), db_cache()->size()); | 323 EXPECT_EQ(all_ids.size() - expected.size(), db_cache()->size()); |
| 320 EXPECT_EQ(all_ids.size() - expected.size(), db_id_cache()->size()); | 324 EXPECT_EQ(all_ids.size() - expected.size(), db_id_cache()->size()); |
| 321 | 325 |
| 322 for (std::vector<NetworkActionPredictorDatabase::Row::Id>::iterator it = | 326 for (std::vector<AutocompleteActionPredictorTable::Row::Id>::iterator it = |
| 323 all_ids.begin(); | 327 all_ids.begin(); |
| 324 it != all_ids.end(); ++it) { | 328 it != all_ids.end(); ++it) { |
| 325 bool in_expected = | 329 bool in_expected = |
| 326 (std::find(expected.begin(), expected.end(), *it) != expected.end()); | 330 (std::find(expected.begin(), expected.end(), *it) != expected.end()); |
| 327 bool in_list = | 331 bool in_list = |
| 328 (std::find(id_list.begin(), id_list.end(), *it) != id_list.end()); | 332 (std::find(id_list.begin(), id_list.end(), *it) != id_list.end()); |
| 329 EXPECT_EQ(in_expected, in_list); | 333 EXPECT_EQ(in_expected, in_list); |
| 330 } | 334 } |
| 331 } | 335 } |
| 332 | 336 |
| 333 TEST_F(NetworkActionPredictorTest, RecommendActionURL) { | 337 TEST_F(AutocompleteActionPredictorTest, RecommendActionURL) { |
| 334 ASSERT_NO_FATAL_FAILURE(AddAllRows()); | 338 ASSERT_NO_FATAL_FAILURE(AddAllRows()); |
| 335 | 339 |
| 336 AutocompleteMatch match; | 340 AutocompleteMatch match; |
| 337 match.type = AutocompleteMatch::HISTORY_URL; | 341 match.type = AutocompleteMatch::HISTORY_URL; |
| 338 | 342 |
| 339 for (size_t i = 0; i < ARRAYSIZE_UNSAFE(test_url_db); ++i) { | 343 for (size_t i = 0; i < ARRAYSIZE_UNSAFE(test_url_db); ++i) { |
| 340 match.destination_url = GURL(test_url_db[i].url); | 344 match.destination_url = GURL(test_url_db[i].url); |
| 341 EXPECT_EQ(test_url_db[i].expected_action, | 345 EXPECT_EQ(test_url_db[i].expected_action, |
| 342 predictor()->RecommendAction(test_url_db[i].user_text, match)) | 346 predictor()->RecommendAction(test_url_db[i].user_text, match)) |
| 343 << "Unexpected action for " << match.destination_url; | 347 << "Unexpected action for " << match.destination_url; |
| 344 } | 348 } |
| 345 } | 349 } |
| 346 | 350 |
| 347 TEST_F(NetworkActionPredictorTest, RecommendActionSearch) { | 351 TEST_F(AutocompleteActionPredictorTest, RecommendActionSearch) { |
| 348 ASSERT_NO_FATAL_FAILURE(AddAllRows()); | 352 ASSERT_NO_FATAL_FAILURE(AddAllRows()); |
| 349 | 353 |
| 350 AutocompleteMatch match; | 354 AutocompleteMatch match; |
| 351 match.type = AutocompleteMatch::SEARCH_WHAT_YOU_TYPED; | 355 match.type = AutocompleteMatch::SEARCH_WHAT_YOU_TYPED; |
| 352 | 356 |
| 353 for (size_t i = 0; i < arraysize(test_url_db); ++i) { | 357 for (size_t i = 0; i < arraysize(test_url_db); ++i) { |
| 354 match.destination_url = GURL(test_url_db[i].url); | 358 match.destination_url = GURL(test_url_db[i].url); |
| 355 NetworkActionPredictor::Action expected_action = | 359 AutocompleteActionPredictor::Action expected_action = |
| 356 (test_url_db[i].expected_action == | 360 (test_url_db[i].expected_action == |
| 357 NetworkActionPredictor::ACTION_PRERENDER) ? | 361 AutocompleteActionPredictor::ACTION_PRERENDER) ? |
| 358 NetworkActionPredictor::ACTION_PRECONNECT : | 362 AutocompleteActionPredictor::ACTION_PRECONNECT : |
| 359 test_url_db[i].expected_action; | 363 test_url_db[i].expected_action; |
| 360 EXPECT_EQ(expected_action, | 364 EXPECT_EQ(expected_action, |
| 361 predictor()->RecommendAction(test_url_db[i].user_text, match)) | 365 predictor()->RecommendAction(test_url_db[i].user_text, match)) |
| 362 << "Unexpected action for " << match.destination_url; | 366 << "Unexpected action for " << match.destination_url; |
| 363 } | 367 } |
| 364 } | 368 } |
| 369 |
| 370 } // namespace predictors |
| OLD | NEW |