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

Side by Side Diff: chrome/browser/predictors/autocomplete_action_predictor_unittest.cc

Issue 9610006: Refactoring, moving and renaming the NetworkActionPredictor. (Closed) Base URL: http://git.chromium.org/chromium/src.git@master
Patch Set: Addressing shess's comments. Created 8 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 unified diff | Download patch
OLDNEW
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
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698