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

Unified Diff: chrome/browser/ntp_snippets/download_suggestions_provider_unittest.cc

Issue 2469933002: Offline Pages: Replace Observer::OfflinePageModelChanged with OfflinePageAdded. (Closed)
Patch Set: Test fix 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/ntp_snippets/download_suggestions_provider_unittest.cc
diff --git a/chrome/browser/ntp_snippets/download_suggestions_provider_unittest.cc b/chrome/browser/ntp_snippets/download_suggestions_provider_unittest.cc
index e8028e000bcef925e445b24811e628c1c6309e40..eeded1dbbbd7c71c47b8e52ed3383b26f95c37d5 100644
--- a/chrome/browser/ntp_snippets/download_suggestions_provider_unittest.cc
+++ b/chrome/browser/ntp_snippets/download_suggestions_provider_unittest.cc
@@ -264,9 +264,10 @@ class DownloadSuggestionsProviderTest : public testing::Test {
ntp_snippets::KnownCategories::DOWNLOADS);
}
- void FireOfflinePageModelChanged() {
+ void AddOfflinePage(const offline_pages::OfflinePageItem& added_page) {
DCHECK(provider_);
- provider_->OfflinePageModelChanged(&offline_pages_model_);
+ offline_pages_model_.mutable_items()->push_back(added_page);
+ provider_->OfflinePageAdded(&offline_pages_model_, added_page);
}
void FireOfflinePageDeleted(const OfflinePageItem& item) {
@@ -512,8 +513,9 @@ TEST_F(DownloadSuggestionsProviderTest,
*observer(),
OnNewSuggestions(_, downloads_category(),
UnorderedElementsAre(HasUrl("http://dummy.com/2"),
+ HasUrl("http://dummy.com/3"),
HasUrl("http://download.com/2"))));
- FireOfflinePageModelChanged();
+ AddOfflinePage(CreateDummyOfflinePage(3));
}
TEST_F(DownloadSuggestionsProviderTest, ShouldReturnDismissedSuggestions) {
@@ -604,9 +606,10 @@ TEST_F(DownloadSuggestionsProviderTest,
*observer(),
OnNewSuggestions(_, downloads_category(),
UnorderedElementsAre(HasUrl("http://dummy.com/2"),
+ HasUrl("http://dummy.com/3"),
HasUrl("http://download.com/1"),
HasUrl("http://download.com/2"))));
- FireOfflinePageModelChanged();
+ AddOfflinePage(CreateDummyOfflinePage(3));
}
TEST_F(DownloadSuggestionsProviderTest, ShouldReplaceDismissedItemWithNewData) {
@@ -632,18 +635,20 @@ TEST_F(DownloadSuggestionsProviderTest, ShouldReplaceDismissedItemWithNewData) {
provider()->DismissSuggestion(
GetDummySuggestionId(1, /*is_offline_page=*/false));
+ provider()->DismissSuggestion(
+ GetDummySuggestionId(2, /*is_offline_page=*/false));
// The provider is not notified about the 6th item, however, it must report
// it now.
EXPECT_CALL(
*observer(),
OnNewSuggestions(_, downloads_category(),
- UnorderedElementsAre(HasUrl("http://download.com/2"),
+ UnorderedElementsAre(HasUrl("http://dummy.com/1"),
HasUrl("http://download.com/3"),
HasUrl("http://download.com/4"),
HasUrl("http://download.com/5"),
HasUrl("http://download.com/6"))));
- FireOfflinePageModelChanged();
+ AddOfflinePage(CreateDummyOfflinePage(1));
}
TEST_F(DownloadSuggestionsProviderTest,
@@ -729,20 +734,21 @@ TEST_F(DownloadSuggestionsProviderTest, ShouldReplaceRemovedItemWithNewData) {
EXPECT_CALL(
*observer(),
OnNewSuggestions(_, downloads_category(),
- UnorderedElementsAre(HasUrl("http://download.com/1"),
+ UnorderedElementsAre(HasUrl("http://dummy.com/6"),
+ HasUrl("http://download.com/1"),
HasUrl("http://download.com/2"),
HasUrl("http://download.com/3"),
- HasUrl("http://download.com/4"),
- HasUrl("http://download.com/5"))));
- FireOfflinePageModelChanged();
+ HasUrl("http://download.com/4"))));
+ AddOfflinePage(CreateDummyOfflinePage(6));
}
TEST_F(DownloadSuggestionsProviderTest, ShouldPruneOfflinePagesDismissedIDs) {
IgnoreOnCategoryStatusChangedToAvailable();
IgnoreOnSuggestionInvalidated();
- *(offline_pages_model()->mutable_items()) =
- CreateDummyOfflinePages({1, 2, 3});
+ auto offline_pages = CreateDummyOfflinePages({1, 2, 3});
+
+ *(offline_pages_model()->mutable_items()) = offline_pages;
EXPECT_CALL(*observer(), OnNewSuggestions(_, downloads_category(),
UnorderedElementsAre(
HasUrl("http://dummy.com/1"),
@@ -758,17 +764,9 @@ TEST_F(DownloadSuggestionsProviderTest, ShouldPruneOfflinePagesDismissedIDs) {
GetDummySuggestionId(3, /*is_offline_page=*/true));
EXPECT_THAT(GetDismissedSuggestions(), SizeIs(3));
- // Prune on getting all offline pages. Note that the first suggestion is not
- // removed from |offline_pages_model| storage, because otherwise
- // |GetDismissedSuggestions| cannot return it.
- EXPECT_CALL(*observer(),
- OnNewSuggestions(_, downloads_category(), IsEmpty()));
-
- // TODO(vitaliii): Add the first suggestion back, so that
- // GetDismissedSuggestions can return it.
- *(offline_pages_model()->mutable_items()) =
- CreateDummyOfflinePages({2, 3});
- FireOfflinePageModelChanged();
+ // Note that the first suggestion is not removed from |offline_pages_model|
+ // storage, because otherwise |GetDismissedSuggestions| cannot return it.
+ FireOfflinePageDeleted(offline_pages[0]);
EXPECT_THAT(GetDismissedSuggestions(), SizeIs(2));
// Prune when offline page is deleted.

Powered by Google App Engine
This is Rietveld 408576698