| OLD | NEW |
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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/bitmap_fetcher/bitmap_fetcher_service.h" | 5 #include "chrome/browser/bitmap_fetcher/bitmap_fetcher_service.h" |
| 6 | 6 |
| 7 #include "chrome/browser/bitmap_fetcher/bitmap_fetcher.h" | 7 #include "chrome/browser/bitmap_fetcher/bitmap_fetcher.h" |
| 8 #include "chrome/test/base/testing_profile.h" | 8 #include "chrome/test/base/testing_profile.h" |
| 9 #include "content/public/test/test_browser_thread_bundle.h" |
| 9 #include "testing/gtest/include/gtest/gtest.h" | 10 #include "testing/gtest/include/gtest/gtest.h" |
| 10 | 11 |
| 11 namespace { | 12 namespace { |
| 12 | 13 |
| 13 class TestNotificationInterface { | 14 class TestNotificationInterface { |
| 14 public: | 15 public: |
| 15 virtual ~TestNotificationInterface() {} | 16 virtual ~TestNotificationInterface() {} |
| 16 virtual void OnImageChanged() = 0; | 17 virtual void OnImageChanged() = 0; |
| 17 virtual void OnRequestFinished() = 0; | 18 virtual void OnRequestFinished() = 0; |
| 18 }; | 19 }; |
| 19 | 20 |
| 20 class TestObserver : public BitmapFetcherService::Observer { | 21 class TestObserver : public BitmapFetcherService::Observer { |
| 21 public: | 22 public: |
| 22 explicit TestObserver(TestNotificationInterface* target) : target_(target) {} | 23 explicit TestObserver(TestNotificationInterface* target) : target_(target) {} |
| 23 ~TestObserver() override { target_->OnRequestFinished(); } | 24 ~TestObserver() override { target_->OnRequestFinished(); } |
| 24 | 25 |
| 25 void OnImageChanged(BitmapFetcherService::RequestId request_id, | 26 void OnImageChanged(BitmapFetcherService::RequestId request_id, |
| 26 const SkBitmap& answers_image) override { | 27 const SkBitmap& answers_image) override { |
| 27 target_->OnImageChanged(); | 28 target_->OnImageChanged(); |
| 28 } | 29 } |
| 29 | 30 |
| 31 private: |
| 30 TestNotificationInterface* target_; | 32 TestNotificationInterface* target_; |
| 33 |
| 34 DISALLOW_COPY_AND_ASSIGN(TestObserver); |
| 31 }; | 35 }; |
| 32 | 36 |
| 33 class TestService : public BitmapFetcherService { | 37 class TestService : public BitmapFetcherService { |
| 34 public: | 38 public: |
| 35 explicit TestService(content::BrowserContext* context) | 39 explicit TestService(content::BrowserContext* context) |
| 36 : BitmapFetcherService(context) {} | 40 : BitmapFetcherService(context) {} |
| 37 ~TestService() override {} | 41 ~TestService() override {} |
| 38 | 42 |
| 39 // Create a fetcher, but don't start downloading. That allows side-stepping | 43 // Create a fetcher, but don't start downloading. That allows side-stepping |
| 40 // the decode step, which requires a utility process. | 44 // the decode step, which requires a utility process. |
| 41 chrome::BitmapFetcher* CreateFetcher(const GURL& url) override { | 45 chrome::BitmapFetcher* CreateFetcher(const GURL& url) override { |
| 42 return new chrome::BitmapFetcher(url, this); | 46 return new chrome::BitmapFetcher(url, this); |
| 43 } | 47 } |
| 44 }; | 48 }; |
| 45 | 49 |
| 46 } // namespace | 50 } // namespace |
| 47 | 51 |
| 48 class BitmapFetcherServiceTest : public testing::Test, | 52 class BitmapFetcherServiceTest : public testing::Test, |
| 49 public TestNotificationInterface { | 53 public TestNotificationInterface { |
| 50 public: | 54 public: |
| 55 BitmapFetcherServiceTest() |
| 56 : url1_(GURL("http://example.org/sample-image-1.png")), |
| 57 url2_(GURL("http://example.org/sample-image-2.png")) { |
| 58 } |
| 59 |
| 51 void SetUp() override { | 60 void SetUp() override { |
| 52 service_.reset(new TestService(&profile_)); | 61 service_.reset(new TestService(&profile_)); |
| 53 requestsFinished_ = 0; | 62 requests_finished_ = 0; |
| 54 imagesChanged_ = 0; | 63 images_changed_ = 0; |
| 55 url1_ = GURL("http://example.org/sample-image-1.png"); | |
| 56 url2_ = GURL("http://example.org/sample-image-2.png"); | |
| 57 } | 64 } |
| 58 | 65 |
| 59 const ScopedVector<BitmapFetcherRequest>& requests() { | 66 const ScopedVector<BitmapFetcherRequest>& requests() const { |
| 60 return service_->requests_; | 67 return service_->requests_; |
| 61 } | 68 } |
| 62 const ScopedVector<chrome::BitmapFetcher>& active_fetchers() { | 69 const ScopedVector<chrome::BitmapFetcher>& active_fetchers() const { |
| 63 return service_->active_fetchers_; | 70 return service_->active_fetchers_; |
| 64 } | 71 } |
| 65 size_t cache_size() { return service_->cache_.size(); } | 72 size_t cache_size() const { return service_->cache_.size(); } |
| 66 | 73 |
| 67 void OnImageChanged() override { imagesChanged_++; } | 74 void OnImageChanged() override { images_changed_++; } |
| 68 | 75 |
| 69 void OnRequestFinished() override { requestsFinished_++; } | 76 void OnRequestFinished() override { requests_finished_++; } |
| 70 | 77 |
| 71 // Simulate finishing a URL fetch and decode for the given fetcher. | 78 // Simulate finishing a URL fetch and decode for the given fetcher. |
| 72 void CompleteFetch(const GURL& url) { | 79 void CompleteFetch(const GURL& url) { |
| 73 const chrome::BitmapFetcher* fetcher = service_->FindFetcherForUrl(url); | 80 const chrome::BitmapFetcher* fetcher = service_->FindFetcherForUrl(url); |
| 74 ASSERT_TRUE(NULL != fetcher); | 81 ASSERT_TRUE(fetcher); |
| 75 | 82 |
| 76 // Create a non-empty bitmap. | 83 // Create a non-empty bitmap. |
| 77 SkBitmap image; | 84 SkBitmap image; |
| 78 image.allocN32Pixels(2, 2); | 85 image.allocN32Pixels(2, 2); |
| 79 image.eraseColor(SK_ColorGREEN); | 86 image.eraseColor(SK_ColorGREEN); |
| 80 | 87 |
| 81 const_cast<chrome::BitmapFetcher*>(fetcher)->OnImageDecoded(image); | 88 const_cast<chrome::BitmapFetcher*>(fetcher)->OnImageDecoded(image); |
| 82 } | 89 } |
| 83 | 90 |
| 84 void FailFetch(const GURL& url) { | 91 void FailFetch(const GURL& url) { |
| 85 const chrome::BitmapFetcher* fetcher = service_->FindFetcherForUrl(url); | 92 const chrome::BitmapFetcher* fetcher = service_->FindFetcherForUrl(url); |
| 86 ASSERT_TRUE(NULL != fetcher); | 93 ASSERT_TRUE(fetcher); |
| 87 const_cast<chrome::BitmapFetcher*>(fetcher)->OnImageDecoded(SkBitmap()); | 94 const_cast<chrome::BitmapFetcher*>(fetcher)->OnImageDecoded(SkBitmap()); |
| 88 } | 95 } |
| 89 | 96 |
| 90 protected: | 97 protected: |
| 91 scoped_ptr<BitmapFetcherService> service_; | 98 scoped_ptr<BitmapFetcherService> service_; |
| 92 | 99 |
| 93 int imagesChanged_; | 100 int images_changed_; |
| 94 int requestsFinished_; | 101 int requests_finished_; |
| 95 | 102 |
| 96 GURL url1_; | 103 const GURL url1_; |
| 97 GURL url2_; | 104 const GURL url2_; |
| 98 | 105 |
| 99 private: | 106 private: |
| 107 content::TestBrowserThreadBundle thread_bundle_; |
| 100 TestingProfile profile_; | 108 TestingProfile profile_; |
| 101 }; | 109 }; |
| 102 | 110 |
| 103 TEST_F(BitmapFetcherServiceTest, RequestInvalidUrl) { | 111 TEST_F(BitmapFetcherServiceTest, RequestInvalidUrl) { |
| 104 const BitmapFetcherService::RequestId invalid_request_id = | 112 const BitmapFetcherService::RequestId invalid_request_id = |
| 105 BitmapFetcherService::REQUEST_ID_INVALID; | 113 BitmapFetcherService::REQUEST_ID_INVALID; |
| 106 GURL invalid_url; | 114 GURL invalid_url; |
| 107 ASSERT_FALSE(invalid_url.is_valid()); | 115 ASSERT_FALSE(invalid_url.is_valid()); |
| 108 | 116 |
| 109 BitmapFetcherService::RequestId request_id = | 117 BitmapFetcherService::RequestId request_id = |
| (...skipping 18 matching lines...) Expand all Loading... |
| 128 | 136 |
| 129 TEST_F(BitmapFetcherServiceTest, CompletedFetchNotifiesAllObservers) { | 137 TEST_F(BitmapFetcherServiceTest, CompletedFetchNotifiesAllObservers) { |
| 130 service_->RequestImage(url1_, new TestObserver(this)); | 138 service_->RequestImage(url1_, new TestObserver(this)); |
| 131 service_->RequestImage(url1_, new TestObserver(this)); | 139 service_->RequestImage(url1_, new TestObserver(this)); |
| 132 service_->RequestImage(url1_, new TestObserver(this)); | 140 service_->RequestImage(url1_, new TestObserver(this)); |
| 133 service_->RequestImage(url1_, new TestObserver(this)); | 141 service_->RequestImage(url1_, new TestObserver(this)); |
| 134 EXPECT_EQ(1U, active_fetchers().size()); | 142 EXPECT_EQ(1U, active_fetchers().size()); |
| 135 EXPECT_EQ(4U, requests().size()); | 143 EXPECT_EQ(4U, requests().size()); |
| 136 | 144 |
| 137 CompleteFetch(url1_); | 145 CompleteFetch(url1_); |
| 138 EXPECT_EQ(4, imagesChanged_); | 146 EXPECT_EQ(4, images_changed_); |
| 139 EXPECT_EQ(4, requestsFinished_); | 147 EXPECT_EQ(4, requests_finished_); |
| 140 } | 148 } |
| 141 | 149 |
| 142 TEST_F(BitmapFetcherServiceTest, CancelRequest) { | 150 TEST_F(BitmapFetcherServiceTest, CancelRequest) { |
| 143 service_->RequestImage(url1_, new TestObserver(this)); | 151 service_->RequestImage(url1_, new TestObserver(this)); |
| 144 service_->RequestImage(url1_, new TestObserver(this)); | 152 service_->RequestImage(url1_, new TestObserver(this)); |
| 145 BitmapFetcherService::RequestId requestId = | 153 BitmapFetcherService::RequestId requestId = |
| 146 service_->RequestImage(url2_, new TestObserver(this)); | 154 service_->RequestImage(url2_, new TestObserver(this)); |
| 147 service_->RequestImage(url1_, new TestObserver(this)); | 155 service_->RequestImage(url1_, new TestObserver(this)); |
| 148 service_->RequestImage(url1_, new TestObserver(this)); | 156 service_->RequestImage(url1_, new TestObserver(this)); |
| 149 EXPECT_EQ(5U, requests().size()); | 157 EXPECT_EQ(5U, requests().size()); |
| 150 | 158 |
| 151 service_->CancelRequest(requestId); | 159 service_->CancelRequest(requestId); |
| 152 EXPECT_EQ(4U, requests().size()); | 160 EXPECT_EQ(4U, requests().size()); |
| 153 | 161 |
| 154 CompleteFetch(url2_); | 162 CompleteFetch(url2_); |
| 155 EXPECT_EQ(0, imagesChanged_); | 163 EXPECT_EQ(0, images_changed_); |
| 156 | 164 |
| 157 CompleteFetch(url1_); | 165 CompleteFetch(url1_); |
| 158 EXPECT_EQ(4, imagesChanged_); | 166 EXPECT_EQ(4, images_changed_); |
| 159 } | 167 } |
| 160 | 168 |
| 161 TEST_F(BitmapFetcherServiceTest, FailedRequestsDontEnterCache) { | 169 TEST_F(BitmapFetcherServiceTest, FailedRequestsDontEnterCache) { |
| 162 service_->RequestImage(url1_, new TestObserver(this)); | 170 service_->RequestImage(url1_, new TestObserver(this)); |
| 163 service_->RequestImage(url2_, new TestObserver(this)); | 171 service_->RequestImage(url2_, new TestObserver(this)); |
| 164 EXPECT_EQ(0U, cache_size()); | 172 EXPECT_EQ(0U, cache_size()); |
| 165 | 173 |
| 166 CompleteFetch(url1_); | 174 CompleteFetch(url1_); |
| 167 EXPECT_EQ(1U, cache_size()); | 175 EXPECT_EQ(1U, cache_size()); |
| 168 | 176 |
| 169 FailFetch(url2_); | 177 FailFetch(url2_); |
| 170 EXPECT_EQ(1U, cache_size()); | 178 EXPECT_EQ(1U, cache_size()); |
| 171 } | 179 } |
| OLD | NEW |