| OLD | NEW |
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 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 "components/ntp_snippets/content_suggestions_service.h" | 5 #include "components/ntp_snippets/content_suggestions_service.h" |
| 6 | 6 |
| 7 #include <memory> | 7 #include <memory> |
| 8 #include <vector> | 8 #include <vector> |
| 9 | 9 |
| 10 #include "base/bind.h" | 10 #include "base/bind.h" |
| (...skipping 85 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 96 void(const std::string& suggestion_id, | 96 void(const std::string& suggestion_id, |
| 97 const ImageFetchedCallback& callback)); | 97 const ImageFetchedCallback& callback)); |
| 98 | 98 |
| 99 private: | 99 private: |
| 100 std::vector<Category> provided_categories_; | 100 std::vector<Category> provided_categories_; |
| 101 std::map<int, CategoryStatus> statuses_; | 101 std::map<int, CategoryStatus> statuses_; |
| 102 }; | 102 }; |
| 103 | 103 |
| 104 class MockServiceObserver : public ContentSuggestionsService::Observer { | 104 class MockServiceObserver : public ContentSuggestionsService::Observer { |
| 105 public: | 105 public: |
| 106 MOCK_METHOD0(OnNewSuggestions, void()); | 106 MOCK_METHOD1(OnNewSuggestions, void(Category category)); |
| 107 MOCK_METHOD2(OnCategoryStatusChanged, | 107 MOCK_METHOD2(OnCategoryStatusChanged, |
| 108 void(Category changed_category, CategoryStatus new_status)); | 108 void(Category changed_category, CategoryStatus new_status)); |
| 109 MOCK_METHOD0(ContentSuggestionsServiceShutdown, void()); | 109 MOCK_METHOD0(ContentSuggestionsServiceShutdown, void()); |
| 110 ~MockServiceObserver() override {} | 110 ~MockServiceObserver() override {} |
| 111 }; | 111 }; |
| 112 | 112 |
| 113 } // namespace | 113 } // namespace |
| 114 | 114 |
| 115 class ContentSuggestionsServiceTest : public testing::Test { | 115 class ContentSuggestionsServiceTest : public testing::Test { |
| 116 public: | 116 public: |
| (...skipping 193 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 310 MockProvider* provider1 = MakeProvider(articles_category); | 310 MockProvider* provider1 = MakeProvider(articles_category); |
| 311 MockProvider* provider2 = MakeProvider(offline_pages_category); | 311 MockProvider* provider2 = MakeProvider(offline_pages_category); |
| 312 EXPECT_THAT(providers().at(articles_category), Eq(provider1)); | 312 EXPECT_THAT(providers().at(articles_category), Eq(provider1)); |
| 313 EXPECT_THAT(providers().at(offline_pages_category), Eq(provider2)); | 313 EXPECT_THAT(providers().at(offline_pages_category), Eq(provider2)); |
| 314 | 314 |
| 315 // Create and register observer | 315 // Create and register observer |
| 316 MockServiceObserver observer; | 316 MockServiceObserver observer; |
| 317 service()->AddObserver(&observer); | 317 service()->AddObserver(&observer); |
| 318 | 318 |
| 319 // Send suggestions 1 and 2 | 319 // Send suggestions 1 and 2 |
| 320 EXPECT_CALL(observer, OnNewSuggestions()).Times(1); | 320 EXPECT_CALL(observer, OnNewSuggestions(articles_category)).Times(1); |
| 321 provider1->FireSuggestionsChanged(articles_category, {1, 2}); | 321 provider1->FireSuggestionsChanged(articles_category, {1, 2}); |
| 322 ExpectThatSuggestionsAre(articles_category, {1, 2}); | 322 ExpectThatSuggestionsAre(articles_category, {1, 2}); |
| 323 Mock::VerifyAndClearExpectations(&observer); | 323 Mock::VerifyAndClearExpectations(&observer); |
| 324 | 324 |
| 325 // Send them again, make sure they're not reported twice | 325 // Send them again, make sure they're not reported twice |
| 326 EXPECT_CALL(observer, OnNewSuggestions()).Times(1); | 326 EXPECT_CALL(observer, OnNewSuggestions(articles_category)).Times(1); |
| 327 provider1->FireSuggestionsChanged(articles_category, {1, 2}); | 327 provider1->FireSuggestionsChanged(articles_category, {1, 2}); |
| 328 ExpectThatSuggestionsAre(articles_category, {1, 2}); | 328 ExpectThatSuggestionsAre(articles_category, {1, 2}); |
| 329 ExpectThatSuggestionsAre(offline_pages_category, std::vector<int>()); | 329 ExpectThatSuggestionsAre(offline_pages_category, std::vector<int>()); |
| 330 Mock::VerifyAndClearExpectations(&observer); | 330 Mock::VerifyAndClearExpectations(&observer); |
| 331 | 331 |
| 332 // Send suggestions 13 and 14 | 332 // Send suggestions 13 and 14 |
| 333 EXPECT_CALL(observer, OnNewSuggestions()).Times(1); | 333 EXPECT_CALL(observer, OnNewSuggestions(offline_pages_category)).Times(1); |
| 334 provider2->FireSuggestionsChanged(offline_pages_category, {13, 14}); | 334 provider2->FireSuggestionsChanged(offline_pages_category, {13, 14}); |
| 335 ExpectThatSuggestionsAre(articles_category, {1, 2}); | 335 ExpectThatSuggestionsAre(articles_category, {1, 2}); |
| 336 ExpectThatSuggestionsAre(offline_pages_category, {13, 14}); | 336 ExpectThatSuggestionsAre(offline_pages_category, {13, 14}); |
| 337 Mock::VerifyAndClearExpectations(&observer); | 337 Mock::VerifyAndClearExpectations(&observer); |
| 338 | 338 |
| 339 // Send suggestion 1 only | 339 // Send suggestion 1 only |
| 340 EXPECT_CALL(observer, OnNewSuggestions()).Times(1); | 340 EXPECT_CALL(observer, OnNewSuggestions(articles_category)).Times(1); |
| 341 provider1->FireSuggestionsChanged(articles_category, {1}); | 341 provider1->FireSuggestionsChanged(articles_category, {1}); |
| 342 ExpectThatSuggestionsAre(articles_category, {1}); | 342 ExpectThatSuggestionsAre(articles_category, {1}); |
| 343 ExpectThatSuggestionsAre(offline_pages_category, {13, 14}); | 343 ExpectThatSuggestionsAre(offline_pages_category, {13, 14}); |
| 344 Mock::VerifyAndClearExpectations(&observer); | 344 Mock::VerifyAndClearExpectations(&observer); |
| 345 | 345 |
| 346 // provider2 reports OFFLINE_PAGES as unavailable | 346 // provider2 reports OFFLINE_PAGES as unavailable |
| 347 EXPECT_CALL(observer, OnCategoryStatusChanged( | 347 EXPECT_CALL(observer, OnCategoryStatusChanged( |
| 348 offline_pages_category, | 348 offline_pages_category, |
| 349 CategoryStatus::CATEGORY_EXPLICITLY_DISABLED)) | 349 CategoryStatus::CATEGORY_EXPLICITLY_DISABLED)) |
| 350 .Times(1); | 350 .Times(1); |
| 351 provider2->FireCategoryStatusChanged( | 351 provider2->FireCategoryStatusChanged( |
| 352 offline_pages_category, CategoryStatus::CATEGORY_EXPLICITLY_DISABLED); | 352 offline_pages_category, CategoryStatus::CATEGORY_EXPLICITLY_DISABLED); |
| 353 EXPECT_THAT(service()->GetCategoryStatus(articles_category), | 353 EXPECT_THAT(service()->GetCategoryStatus(articles_category), |
| 354 Eq(CategoryStatus::AVAILABLE)); | 354 Eq(CategoryStatus::AVAILABLE)); |
| 355 EXPECT_THAT(service()->GetCategoryStatus(offline_pages_category), | 355 EXPECT_THAT(service()->GetCategoryStatus(offline_pages_category), |
| 356 Eq(CategoryStatus::CATEGORY_EXPLICITLY_DISABLED)); | 356 Eq(CategoryStatus::CATEGORY_EXPLICITLY_DISABLED)); |
| 357 ExpectThatSuggestionsAre(articles_category, {1}); | 357 ExpectThatSuggestionsAre(articles_category, {1}); |
| 358 ExpectThatSuggestionsAre(offline_pages_category, std::vector<int>()); | 358 ExpectThatSuggestionsAre(offline_pages_category, std::vector<int>()); |
| 359 Mock::VerifyAndClearExpectations(&observer); | 359 Mock::VerifyAndClearExpectations(&observer); |
| 360 | 360 |
| 361 // Shutdown the service | 361 // Shutdown the service |
| 362 EXPECT_CALL(observer, ContentSuggestionsServiceShutdown()); | 362 EXPECT_CALL(observer, ContentSuggestionsServiceShutdown()); |
| 363 service()->Shutdown(); | 363 service()->Shutdown(); |
| 364 service()->RemoveObserver(&observer); | 364 service()->RemoveObserver(&observer); |
| 365 // The service will receive two Shutdown() calls. | 365 // The service will receive two Shutdown() calls. |
| 366 } | 366 } |
| 367 | 367 |
| 368 } // namespace ntp_snippets | 368 } // namespace ntp_snippets |
| OLD | NEW |