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/history/history_backend.h" | 5 #include "chrome/browser/history/history_backend.h" |
6 | 6 |
7 #include <algorithm> | 7 #include <algorithm> |
8 #include <set> | 8 #include <set> |
9 #include <vector> | 9 #include <vector> |
10 | 10 |
11 #include "base/basictypes.h" | 11 #include "base/basictypes.h" |
12 #include "base/bind.h" | 12 #include "base/bind.h" |
13 #include "base/callback.h" | 13 #include "base/callback.h" |
14 #include "base/command_line.h" | 14 #include "base/command_line.h" |
15 #include "base/files/file_path.h" | 15 #include "base/files/file_path.h" |
16 #include "base/files/file_util.h" | 16 #include "base/files/file_util.h" |
17 #include "base/memory/ref_counted.h" | 17 #include "base/memory/ref_counted.h" |
18 #include "base/memory/scoped_ptr.h" | 18 #include "base/memory/scoped_ptr.h" |
19 #include "base/path_service.h" | 19 #include "base/path_service.h" |
20 #include "base/run_loop.h" | 20 #include "base/run_loop.h" |
21 #include "base/strings/string16.h" | 21 #include "base/strings/string16.h" |
22 #include "base/strings/string_number_conversions.h" | 22 #include "base/strings/string_number_conversions.h" |
23 #include "base/strings/utf_string_conversions.h" | 23 #include "base/strings/utf_string_conversions.h" |
24 #include "chrome/browser/chrome_notification_types.h" | |
25 #include "chrome/browser/history/history_notifications.h" | |
26 #include "chrome/browser/history/history_service.h" | 24 #include "chrome/browser/history/history_service.h" |
27 #include "chrome/browser/history/history_service_factory.h" | 25 #include "chrome/browser/history/history_service_factory.h" |
28 #include "chrome/browser/history/in_memory_history_backend.h" | 26 #include "chrome/browser/history/in_memory_history_backend.h" |
29 #include "chrome/browser/history/visit_filter.h" | 27 #include "chrome/browser/history/visit_filter.h" |
30 #include "chrome/common/chrome_constants.h" | 28 #include "chrome/common/chrome_constants.h" |
31 #include "chrome/common/chrome_paths.h" | 29 #include "chrome/common/chrome_paths.h" |
32 #include "chrome/common/importer/imported_favicon_usage.h" | 30 #include "chrome/common/importer/imported_favicon_usage.h" |
33 #include "chrome/test/base/testing_profile.h" | 31 #include "chrome/test/base/testing_profile.h" |
34 #include "components/history/core/browser/history_constants.h" | 32 #include "components/history/core/browser/history_constants.h" |
| 33 #include "components/history/core/browser/history_service_observer.h" |
35 #include "components/history/core/browser/in_memory_database.h" | 34 #include "components/history/core/browser/in_memory_database.h" |
36 #include "components/history/core/browser/keyword_search_term.h" | 35 #include "components/history/core/browser/keyword_search_term.h" |
37 #include "components/history/core/test/history_client_fake_bookmarks.h" | 36 #include "components/history/core/test/history_client_fake_bookmarks.h" |
38 #include "content/public/browser/notification_details.h" | 37 #include "content/public/browser/notification_details.h" |
39 #include "content/public/browser/notification_source.h" | 38 #include "content/public/browser/notification_source.h" |
40 #include "content/public/test/test_browser_thread.h" | 39 #include "content/public/test/test_browser_thread.h" |
41 #include "testing/gmock/include/gmock/gmock.h" | 40 #include "testing/gmock/include/gmock/gmock.h" |
42 #include "testing/gtest/include/gtest/gtest.h" | 41 #include "testing/gtest/include/gtest/gtest.h" |
43 #include "third_party/skia/include/core/SkBitmap.h" | 42 #include "third_party/skia/include/core/SkBitmap.h" |
44 #include "ui/gfx/codec/png_codec.h" | 43 #include "ui/gfx/codec/png_codec.h" |
(...skipping 74 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
119 | 118 |
120 void NotifyProfileError(sql::InitStatus init_status) override {} | 119 void NotifyProfileError(sql::InitStatus init_status) override {} |
121 void SetInMemoryBackend(scoped_ptr<InMemoryHistoryBackend> backend) override; | 120 void SetInMemoryBackend(scoped_ptr<InMemoryHistoryBackend> backend) override; |
122 void NotifyAddVisit(const BriefVisitInfo& info) override {} | 121 void NotifyAddVisit(const BriefVisitInfo& info) override {} |
123 void NotifyFaviconChanged(const std::set<GURL>& urls) override; | 122 void NotifyFaviconChanged(const std::set<GURL>& urls) override; |
124 void NotifyURLVisited(ui::PageTransition transition, | 123 void NotifyURLVisited(ui::PageTransition transition, |
125 const URLRow& row, | 124 const URLRow& row, |
126 const RedirectList& redirects, | 125 const RedirectList& redirects, |
127 base::Time visit_time) override; | 126 base::Time visit_time) override; |
128 void NotifyURLsModified(const URLRows& changed_urls) override; | 127 void NotifyURLsModified(const URLRows& changed_urls) override; |
| 128 void NotifyURLsDeleted(bool all_history, |
| 129 bool expired, |
| 130 const URLRows& deleted_rows, |
| 131 const std::set<GURL>& favicon_urls) override; |
129 void BroadcastNotifications(int type, | 132 void BroadcastNotifications(int type, |
130 scoped_ptr<HistoryDetails> details) override; | 133 scoped_ptr<HistoryDetails> details) override; |
131 void DBLoaded() override; | 134 void DBLoaded() override; |
132 | 135 |
133 private: | 136 private: |
134 // Not owned by us. | 137 // Not owned by us. |
135 HistoryBackendTestBase* test_; | 138 HistoryBackendTestBase* test_; |
136 | 139 |
137 DISALLOW_COPY_AND_ASSIGN(HistoryBackendTestDelegate); | 140 DISALLOW_COPY_AND_ASSIGN(HistoryBackendTestDelegate); |
138 }; | 141 }; |
139 | 142 |
140 class HistoryBackendTestBase : public testing::Test { | 143 class HistoryBackendTestBase : public testing::Test { |
141 public: | 144 public: |
142 typedef std::vector<std::pair<int, HistoryDetails*> > NotificationList; | |
143 typedef std::vector<std::pair<ui::PageTransition, URLRow>> URLVisitedList; | 145 typedef std::vector<std::pair<ui::PageTransition, URLRow>> URLVisitedList; |
144 typedef std::vector<URLRows> URLsModifiedList; | 146 typedef std::vector<URLRows> URLsModifiedList; |
| 147 typedef std::vector<std::pair<bool, bool>> URLsDeletedList; |
145 | 148 |
146 HistoryBackendTestBase() | 149 HistoryBackendTestBase() |
147 : loaded_(false), | 150 : loaded_(false), |
148 favicon_changed_notifications_(0), | 151 favicon_changed_notifications_(0), |
149 ui_thread_(content::BrowserThread::UI, &message_loop_) {} | 152 ui_thread_(content::BrowserThread::UI, &message_loop_) {} |
150 | 153 |
151 ~HistoryBackendTestBase() override { | 154 ~HistoryBackendTestBase() override { |
152 STLDeleteValues(&broadcasted_notifications_); | |
153 } | 155 } |
154 | 156 |
155 protected: | 157 protected: |
156 int favicon_changed_notifications() const { | 158 int favicon_changed_notifications() const { |
157 return favicon_changed_notifications_; | 159 return favicon_changed_notifications_; |
158 } | 160 } |
159 | 161 |
160 void ClearFaviconChangedNotificationCounter() { | 162 void ClearFaviconChangedNotificationCounter() { |
161 favicon_changed_notifications_ = 0; | 163 favicon_changed_notifications_ = 0; |
162 } | 164 } |
163 | 165 |
164 int num_url_visited_notifications() const { | 166 int num_url_visited_notifications() const { |
165 return url_visited_notifications_.size(); | 167 return url_visited_notifications_.size(); |
166 } | 168 } |
167 | 169 |
168 const URLVisitedList& url_visited_notifications() const { | 170 const URLVisitedList& url_visited_notifications() const { |
169 return url_visited_notifications_; | 171 return url_visited_notifications_; |
170 } | 172 } |
171 | 173 |
172 int num_urls_modified_notifications() const { | 174 int num_urls_modified_notifications() const { |
173 return urls_modified_notifications_.size(); | 175 return urls_modified_notifications_.size(); |
174 } | 176 } |
175 | 177 |
176 const URLsModifiedList& urls_modified_notifications() const { | 178 const URLsModifiedList& urls_modified_notifications() const { |
177 return urls_modified_notifications_; | 179 return urls_modified_notifications_; |
178 } | 180 } |
179 | 181 |
180 int num_broadcasted_notifications() const { | 182 const URLsDeletedList& urls_deleted_notifications() const { |
181 return broadcasted_notifications_.size(); | 183 return urls_deleted_notifications_; |
182 } | |
183 | |
184 const NotificationList& broadcasted_notifications() const { | |
185 return broadcasted_notifications_; | |
186 } | 184 } |
187 | 185 |
188 void ClearBroadcastedNotifications() { | 186 void ClearBroadcastedNotifications() { |
189 url_visited_notifications_.clear(); | 187 url_visited_notifications_.clear(); |
190 urls_modified_notifications_.clear(); | 188 urls_modified_notifications_.clear(); |
191 STLDeleteValues(&broadcasted_notifications_); | 189 urls_deleted_notifications_.clear(); |
192 } | 190 } |
193 | 191 |
194 base::FilePath test_dir() { | 192 base::FilePath test_dir() { |
195 return test_dir_; | 193 return test_dir_; |
196 } | 194 } |
197 | 195 |
198 void NotifyFaviconChanged(const std::set<GURL>& changed_favicons) { | 196 void NotifyFaviconChanged(const std::set<GURL>& changed_favicons) { |
199 ++favicon_changed_notifications_; | 197 ++favicon_changed_notifications_; |
200 } | 198 } |
201 | 199 |
202 void NotifyURLVisited(ui::PageTransition transition, | 200 void NotifyURLVisited(ui::PageTransition transition, |
203 const URLRow& row, | 201 const URLRow& row, |
204 const RedirectList& redirects, | 202 const RedirectList& redirects, |
205 base::Time visit_time) { | 203 base::Time visit_time) { |
206 // Send the notifications directly to the in-memory database. | 204 // Send the notifications directly to the in-memory database. |
207 mem_backend_->OnURLVisited(nullptr, transition, row, redirects, visit_time); | 205 mem_backend_->OnURLVisited(nullptr, transition, row, redirects, visit_time); |
208 url_visited_notifications_.push_back(std::make_pair(transition, row)); | 206 url_visited_notifications_.push_back(std::make_pair(transition, row)); |
209 } | 207 } |
210 | 208 |
211 void NotifyURLsModified(const URLRows& changed_urls) { | 209 void NotifyURLsModified(const URLRows& changed_urls) { |
212 // Send the notifications directly to the in-memory database. | 210 // Send the notifications directly to the in-memory database. |
213 mem_backend_->OnURLsModified(nullptr, changed_urls); | 211 mem_backend_->OnURLsModified(nullptr, changed_urls); |
214 urls_modified_notifications_.push_back(changed_urls); | 212 urls_modified_notifications_.push_back(changed_urls); |
215 } | 213 } |
216 | 214 |
| 215 void NotifyURLsDeleted(bool all_history, |
| 216 bool expired, |
| 217 const URLRows& deleted_rows, |
| 218 const std::set<GURL>& favicon_urls) { |
| 219 mem_backend_->OnURLsDeleted(nullptr, all_history, expired, deleted_rows, |
| 220 favicon_urls); |
| 221 urls_deleted_notifications_.push_back(std::make_pair(all_history, expired)); |
| 222 } |
| 223 |
217 void BroadcastNotifications(int type, scoped_ptr<HistoryDetails> details) { | 224 void BroadcastNotifications(int type, scoped_ptr<HistoryDetails> details) { |
218 // Send the notifications directly to the in-memory database. | 225 // Send the notifications directly to the in-memory database. |
219 content::Details<HistoryDetails> det(details.get()); | 226 content::Details<HistoryDetails> det(details.get()); |
220 mem_backend_->Observe( | 227 mem_backend_->Observe( |
221 type, content::Source<HistoryBackendTestBase>(NULL), det); | 228 type, content::Source<HistoryBackendTestBase>(NULL), det); |
222 | |
223 // The backend passes ownership of the details pointer to us. | |
224 broadcasted_notifications_.push_back( | |
225 std::make_pair(type, details.release())); | |
226 } | 229 } |
227 | 230 |
228 history::HistoryClientFakeBookmarks history_client_; | 231 history::HistoryClientFakeBookmarks history_client_; |
229 scoped_refptr<HistoryBackend> backend_; // Will be NULL on init failure. | 232 scoped_refptr<HistoryBackend> backend_; // Will be NULL on init failure. |
230 scoped_ptr<InMemoryHistoryBackend> mem_backend_; | 233 scoped_ptr<InMemoryHistoryBackend> mem_backend_; |
231 bool loaded_; | 234 bool loaded_; |
232 | 235 |
233 private: | 236 private: |
234 friend class HistoryBackendTestDelegate; | 237 friend class HistoryBackendTestDelegate; |
235 | 238 |
(...skipping 16 matching lines...) Expand all Loading... |
252 base::DeleteFile(test_dir_, true); | 255 base::DeleteFile(test_dir_, true); |
253 base::RunLoop().RunUntilIdle(); | 256 base::RunLoop().RunUntilIdle(); |
254 history_client_.ClearAllBookmarks(); | 257 history_client_.ClearAllBookmarks(); |
255 } | 258 } |
256 | 259 |
257 void SetInMemoryBackend(scoped_ptr<InMemoryHistoryBackend> backend) { | 260 void SetInMemoryBackend(scoped_ptr<InMemoryHistoryBackend> backend) { |
258 mem_backend_.swap(backend); | 261 mem_backend_.swap(backend); |
259 } | 262 } |
260 | 263 |
261 // The types and details of notifications which were broadcasted. | 264 // The types and details of notifications which were broadcasted. |
262 NotificationList broadcasted_notifications_; | |
263 int favicon_changed_notifications_; | 265 int favicon_changed_notifications_; |
264 URLVisitedList url_visited_notifications_; | 266 URLVisitedList url_visited_notifications_; |
265 URLsModifiedList urls_modified_notifications_; | 267 URLsModifiedList urls_modified_notifications_; |
| 268 URLsDeletedList urls_deleted_notifications_; |
266 | 269 |
267 base::MessageLoop message_loop_; | 270 base::MessageLoop message_loop_; |
268 base::FilePath test_dir_; | 271 base::FilePath test_dir_; |
269 content::TestBrowserThread ui_thread_; | 272 content::TestBrowserThread ui_thread_; |
270 | 273 |
271 DISALLOW_COPY_AND_ASSIGN(HistoryBackendTestBase); | 274 DISALLOW_COPY_AND_ASSIGN(HistoryBackendTestBase); |
272 }; | 275 }; |
273 | 276 |
274 void HistoryBackendTestDelegate::SetInMemoryBackend( | 277 void HistoryBackendTestDelegate::SetInMemoryBackend( |
275 scoped_ptr<InMemoryHistoryBackend> backend) { | 278 scoped_ptr<InMemoryHistoryBackend> backend) { |
(...skipping 10 matching lines...) Expand all Loading... |
286 const RedirectList& redirects, | 289 const RedirectList& redirects, |
287 base::Time visit_time) { | 290 base::Time visit_time) { |
288 test_->NotifyURLVisited(transition, row, redirects, visit_time); | 291 test_->NotifyURLVisited(transition, row, redirects, visit_time); |
289 } | 292 } |
290 | 293 |
291 void HistoryBackendTestDelegate::NotifyURLsModified( | 294 void HistoryBackendTestDelegate::NotifyURLsModified( |
292 const URLRows& changed_urls) { | 295 const URLRows& changed_urls) { |
293 test_->NotifyURLsModified(changed_urls); | 296 test_->NotifyURLsModified(changed_urls); |
294 } | 297 } |
295 | 298 |
| 299 void HistoryBackendTestDelegate::NotifyURLsDeleted( |
| 300 bool all_history, |
| 301 bool expired, |
| 302 const URLRows& deleted_rows, |
| 303 const std::set<GURL>& favicon_urls) { |
| 304 test_->NotifyURLsDeleted(all_history, expired, deleted_rows, favicon_urls); |
| 305 } |
| 306 |
296 void HistoryBackendTestDelegate::BroadcastNotifications( | 307 void HistoryBackendTestDelegate::BroadcastNotifications( |
297 int type, | 308 int type, |
298 scoped_ptr<HistoryDetails> details) { | 309 scoped_ptr<HistoryDetails> details) { |
299 test_->BroadcastNotifications(type, details.Pass()); | 310 test_->BroadcastNotifications(type, details.Pass()); |
300 } | 311 } |
301 | 312 |
302 void HistoryBackendTestDelegate::DBLoaded() { | 313 void HistoryBackendTestDelegate::DBLoaded() { |
303 test_->loaded_ = true; | 314 test_->loaded_ = true; |
304 } | 315 } |
305 | 316 |
(...skipping 153 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
459 private: | 470 private: |
460 DISALLOW_COPY_AND_ASSIGN(HistoryBackendTest); | 471 DISALLOW_COPY_AND_ASSIGN(HistoryBackendTest); |
461 }; | 472 }; |
462 | 473 |
463 class InMemoryHistoryBackendTest : public HistoryBackendTestBase { | 474 class InMemoryHistoryBackendTest : public HistoryBackendTestBase { |
464 public: | 475 public: |
465 InMemoryHistoryBackendTest() {} | 476 InMemoryHistoryBackendTest() {} |
466 ~InMemoryHistoryBackendTest() override {} | 477 ~InMemoryHistoryBackendTest() override {} |
467 | 478 |
468 protected: | 479 protected: |
469 void SimulateNotification(int type, | 480 void SimulateNotificationURLsDeleted(const URLRow* row1, |
470 const URLRow* row1, | 481 const URLRow* row2 = NULL, |
471 const URLRow* row2 = NULL, | 482 const URLRow* row3 = NULL) { |
472 const URLRow* row3 = NULL) { | |
473 DCHECK(type == chrome::NOTIFICATION_HISTORY_URLS_DELETED); | |
474 | |
475 URLRows rows; | 483 URLRows rows; |
476 rows.push_back(*row1); | 484 rows.push_back(*row1); |
477 if (row2) rows.push_back(*row2); | 485 if (row2) rows.push_back(*row2); |
478 if (row3) rows.push_back(*row3); | 486 if (row3) rows.push_back(*row3); |
479 | 487 |
480 scoped_ptr<URLsDeletedDetails> details(new URLsDeletedDetails()); | 488 NotifyURLsDeleted(false, false, rows, std::set<GURL>()); |
481 details->rows = rows; | |
482 BroadcastNotifications(type, details.Pass()); | |
483 } | 489 } |
484 | 490 |
485 size_t GetNumberOfMatchingSearchTerms(const int keyword_id, | 491 size_t GetNumberOfMatchingSearchTerms(const int keyword_id, |
486 const base::string16& prefix) { | 492 const base::string16& prefix) { |
487 std::vector<KeywordSearchTermVisit> matching_terms; | 493 std::vector<KeywordSearchTermVisit> matching_terms; |
488 mem_backend_->db()->GetMostRecentKeywordSearchTerms( | 494 mem_backend_->db()->GetMostRecentKeywordSearchTerms( |
489 keyword_id, prefix, 1, &matching_terms); | 495 keyword_id, prefix, 1, &matching_terms); |
490 return matching_terms.size(); | 496 return matching_terms.size(); |
491 } | 497 } |
492 | 498 |
(...skipping 182 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
675 std::vector<IconMapping> mappings; | 681 std::vector<IconMapping> mappings; |
676 EXPECT_TRUE(backend_->thumbnail_db_->GetIconMappingsForPageURL( | 682 EXPECT_TRUE(backend_->thumbnail_db_->GetIconMappingsForPageURL( |
677 outrow1.url(), favicon_base::FAVICON, &mappings)); | 683 outrow1.url(), favicon_base::FAVICON, &mappings)); |
678 EXPECT_EQ(1u, mappings.size()); | 684 EXPECT_EQ(1u, mappings.size()); |
679 EXPECT_EQ(out_favicon1, mappings[0].icon_id); | 685 EXPECT_EQ(out_favicon1, mappings[0].icon_id); |
680 | 686 |
681 // The first URL should still be bookmarked. | 687 // The first URL should still be bookmarked. |
682 EXPECT_TRUE(history_client_.IsBookmarked(row1.url())); | 688 EXPECT_TRUE(history_client_.IsBookmarked(row1.url())); |
683 | 689 |
684 // Check that we fire the notification about all history having been deleted. | 690 // Check that we fire the notification about all history having been deleted. |
685 ASSERT_EQ(1u, broadcasted_notifications().size()); | 691 ASSERT_EQ(1u, urls_deleted_notifications().size()); |
686 ASSERT_EQ(chrome::NOTIFICATION_HISTORY_URLS_DELETED, | 692 EXPECT_TRUE(urls_deleted_notifications()[0].first); |
687 broadcasted_notifications()[0].first); | 693 EXPECT_FALSE(urls_deleted_notifications()[0].second); |
688 const URLsDeletedDetails* details = static_cast<const URLsDeletedDetails*>( | |
689 broadcasted_notifications()[0].second); | |
690 EXPECT_TRUE(details->all_history); | |
691 EXPECT_FALSE(details->expired); | |
692 } | 694 } |
693 | 695 |
694 // Checks that adding a visit, then calling DeleteAll, and then trying to add | 696 // Checks that adding a visit, then calling DeleteAll, and then trying to add |
695 // data for the visited page works. This can happen when clearing the history | 697 // data for the visited page works. This can happen when clearing the history |
696 // immediately after visiting a page. | 698 // immediately after visiting a page. |
697 TEST_F(HistoryBackendTest, DeleteAllThenAddData) { | 699 TEST_F(HistoryBackendTest, DeleteAllThenAddData) { |
698 ASSERT_TRUE(backend_.get()); | 700 ASSERT_TRUE(backend_.get()); |
699 | 701 |
700 Time visit_time = Time::Now(); | 702 Time visit_time = Time::Now(); |
701 GURL url("http://www.google.com/"); | 703 GURL url("http://www.google.com/"); |
(...skipping 2426 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
3128 | 3130 |
3129 TEST_F(InMemoryHistoryBackendTest, OnURLsDeletedPiecewise) { | 3131 TEST_F(InMemoryHistoryBackendTest, OnURLsDeletedPiecewise) { |
3130 // Add two typed and one non-typed URLRow to the in-memory database. | 3132 // Add two typed and one non-typed URLRow to the in-memory database. |
3131 URLRow row1(CreateTestTypedURL()); | 3133 URLRow row1(CreateTestTypedURL()); |
3132 URLRow row2(CreateAnotherTestTypedURL()); | 3134 URLRow row2(CreateAnotherTestTypedURL()); |
3133 URLRow row3(CreateTestNonTypedURL()); | 3135 URLRow row3(CreateTestNonTypedURL()); |
3134 SimulateNotificationURLsModified(mem_backend_.get(), &row1, &row2, &row3); | 3136 SimulateNotificationURLsModified(mem_backend_.get(), &row1, &row2, &row3); |
3135 | 3137 |
3136 // Notify the in-memory database that the second typed URL and the non-typed | 3138 // Notify the in-memory database that the second typed URL and the non-typed |
3137 // URL has been deleted. | 3139 // URL has been deleted. |
3138 SimulateNotification(chrome::NOTIFICATION_HISTORY_URLS_DELETED, | 3140 SimulateNotificationURLsDeleted(&row2, &row3); |
3139 &row2, &row3); | |
3140 | 3141 |
3141 // Expect that the first typed URL remains intact, the second typed URL is | 3142 // Expect that the first typed URL remains intact, the second typed URL is |
3142 // correctly removed, and the non-typed URL does not magically appear. | 3143 // correctly removed, and the non-typed URL does not magically appear. |
3143 URLRow cached_row1; | 3144 URLRow cached_row1; |
3144 EXPECT_NE(0, mem_backend_->db()->GetRowForURL(row1.url(), &cached_row1)); | 3145 EXPECT_NE(0, mem_backend_->db()->GetRowForURL(row1.url(), &cached_row1)); |
3145 EXPECT_EQ(0, mem_backend_->db()->GetRowForURL(row2.url(), NULL)); | 3146 EXPECT_EQ(0, mem_backend_->db()->GetRowForURL(row2.url(), NULL)); |
3146 EXPECT_EQ(0, mem_backend_->db()->GetRowForURL(row3.url(), NULL)); | 3147 EXPECT_EQ(0, mem_backend_->db()->GetRowForURL(row3.url(), NULL)); |
3147 EXPECT_EQ(row1.id(), cached_row1.id()); | 3148 EXPECT_EQ(row1.id(), cached_row1.id()); |
3148 } | 3149 } |
3149 | 3150 |
3150 TEST_F(InMemoryHistoryBackendTest, OnURLsDeletedEnMasse) { | 3151 TEST_F(InMemoryHistoryBackendTest, OnURLsDeletedEnMasse) { |
3151 // Add two typed and one non-typed URLRow to the in-memory database. | 3152 // Add two typed and one non-typed URLRow to the in-memory database. |
3152 URLRow row1(CreateTestTypedURL()); | 3153 URLRow row1(CreateTestTypedURL()); |
3153 URLRow row2(CreateAnotherTestTypedURL()); | 3154 URLRow row2(CreateAnotherTestTypedURL()); |
3154 URLRow row3(CreateTestNonTypedURL()); | 3155 URLRow row3(CreateTestNonTypedURL()); |
3155 SimulateNotificationURLsModified(mem_backend_.get(), &row1, &row2, &row3); | 3156 SimulateNotificationURLsModified(mem_backend_.get(), &row1, &row2, &row3); |
3156 | 3157 |
3157 // Now notify the in-memory database that all history has been deleted. | 3158 // Now notify the in-memory database that all history has been deleted. |
3158 scoped_ptr<URLsDeletedDetails> details(new URLsDeletedDetails()); | 3159 mem_backend_->OnURLsDeleted(nullptr, true, false, URLRows(), |
3159 details->all_history = true; | 3160 std::set<GURL>()); |
3160 BroadcastNotifications(chrome::NOTIFICATION_HISTORY_URLS_DELETED, | |
3161 details.Pass()); | |
3162 | 3161 |
3163 // Expect that everything goes away. | 3162 // Expect that everything goes away. |
3164 EXPECT_EQ(0, mem_backend_->db()->GetRowForURL(row1.url(), NULL)); | 3163 EXPECT_EQ(0, mem_backend_->db()->GetRowForURL(row1.url(), NULL)); |
3165 EXPECT_EQ(0, mem_backend_->db()->GetRowForURL(row2.url(), NULL)); | 3164 EXPECT_EQ(0, mem_backend_->db()->GetRowForURL(row2.url(), NULL)); |
3166 EXPECT_EQ(0, mem_backend_->db()->GetRowForURL(row3.url(), NULL)); | 3165 EXPECT_EQ(0, mem_backend_->db()->GetRowForURL(row3.url(), NULL)); |
3167 } | 3166 } |
3168 | 3167 |
3169 void InMemoryHistoryBackendTest::PopulateTestURLsAndSearchTerms( | 3168 void InMemoryHistoryBackendTest::PopulateTestURLsAndSearchTerms( |
3170 URLRow* row1, | 3169 URLRow* row1, |
3171 URLRow* row2, | 3170 URLRow* row2, |
(...skipping 89 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
3261 } | 3260 } |
3262 | 3261 |
3263 TEST_F(InMemoryHistoryBackendTest, OnURLsDeletedWithSearchTerms) { | 3262 TEST_F(InMemoryHistoryBackendTest, OnURLsDeletedWithSearchTerms) { |
3264 URLRow row1(CreateTestTypedURL()); | 3263 URLRow row1(CreateTestTypedURL()); |
3265 URLRow row2(CreateTestNonTypedURL()); | 3264 URLRow row2(CreateTestNonTypedURL()); |
3266 base::string16 term1(base::UTF8ToUTF16(kTestSearchTerm1)); | 3265 base::string16 term1(base::UTF8ToUTF16(kTestSearchTerm1)); |
3267 base::string16 term2(base::UTF8ToUTF16(kTestSearchTerm2)); | 3266 base::string16 term2(base::UTF8ToUTF16(kTestSearchTerm2)); |
3268 PopulateTestURLsAndSearchTerms(&row1, &row2, term1, term2); | 3267 PopulateTestURLsAndSearchTerms(&row1, &row2, term1, term2); |
3269 | 3268 |
3270 // Notify the in-memory database that the second typed URL has been deleted. | 3269 // Notify the in-memory database that the second typed URL has been deleted. |
3271 SimulateNotification(chrome::NOTIFICATION_HISTORY_URLS_DELETED, &row2); | 3270 SimulateNotificationURLsDeleted(&row2); |
3272 | 3271 |
3273 // Verify that the second term is no longer returned as result, and also check | 3272 // Verify that the second term is no longer returned as result, and also check |
3274 // at the low level that it is gone for good. The term corresponding to the | 3273 // at the low level that it is gone for good. The term corresponding to the |
3275 // first URLRow should not be affected. | 3274 // first URLRow should not be affected. |
3276 EXPECT_EQ(1u, GetNumberOfMatchingSearchTerms(kTestKeywordId, term1)); | 3275 EXPECT_EQ(1u, GetNumberOfMatchingSearchTerms(kTestKeywordId, term1)); |
3277 EXPECT_EQ(0u, GetNumberOfMatchingSearchTerms(kTestKeywordId, term2)); | 3276 EXPECT_EQ(0u, GetNumberOfMatchingSearchTerms(kTestKeywordId, term2)); |
3278 EXPECT_TRUE(mem_backend_->db()->GetKeywordSearchTermRow(row1.id(), NULL)); | 3277 EXPECT_TRUE(mem_backend_->db()->GetKeywordSearchTermRow(row1.id(), NULL)); |
3279 EXPECT_FALSE(mem_backend_->db()->GetKeywordSearchTermRow(row2.id(), NULL)); | 3278 EXPECT_FALSE(mem_backend_->db()->GetKeywordSearchTermRow(row2.id(), NULL)); |
3280 } | 3279 } |
3281 | 3280 |
3282 } // namespace history | 3281 } // namespace history |
OLD | NEW |