| Index: third_party/WebKit/Source/core/loader/resource/ImageResourceTest.cpp
|
| diff --git a/third_party/WebKit/Source/core/loader/resource/ImageResourceTest.cpp b/third_party/WebKit/Source/core/loader/resource/ImageResourceTest.cpp
|
| index 962a51741d3c46f07a10a764fc513fce9bb5ec95..7107dcad2f4269c3e0619d93e0870eae2f42b11e 100644
|
| --- a/third_party/WebKit/Source/core/loader/resource/ImageResourceTest.cpp
|
| +++ b/third_party/WebKit/Source/core/loader/resource/ImageResourceTest.cpp
|
| @@ -507,7 +507,6 @@ TEST(ImageResourceTest, ReloadIfLoFiOrPlaceholderAfterFinished) {
|
| KURL testURL(ParsedURLString, kTestURL);
|
| ScopedMockedURLLoad scopedMockedURLLoad(testURL, GetTestFilePath());
|
| ResourceRequest request = ResourceRequest(testURL);
|
| - request.setPreviewsState(WebURLRequest::ServerLoFiOn);
|
| ImageResource* imageResource = ImageResource::create(request);
|
| imageResource->setStatus(ResourceStatus::Pending);
|
|
|
| @@ -548,6 +547,49 @@ TEST(ImageResourceTest, ReloadIfLoFiOrPlaceholderAfterFinished) {
|
| WebCachePolicy::BypassingCache);
|
| }
|
|
|
| +TEST(ImageResourceTest,
|
| + ReloadIfLoFiOrPlaceholderAfterFinishedWithoutLoFiHeaders) {
|
| + KURL testURL(ParsedURLString, kTestURL);
|
| + ScopedMockedURLLoad scopedMockedURLLoad(testURL, GetTestFilePath());
|
| + ResourceRequest request = ResourceRequest(testURL);
|
| + request.setPreviewsState(WebURLRequest::ServerLoFiOn);
|
| + ImageResource* imageResource = ImageResource::create(request);
|
| + imageResource->setStatus(ResourceStatus::Pending);
|
| +
|
| + std::unique_ptr<MockImageResourceObserver> observer =
|
| + MockImageResourceObserver::create(imageResource->getContent());
|
| + ResourceFetcher* fetcher = createFetcher();
|
| +
|
| + // Send the image response, without any LoFi image response headers.
|
| + imageResource->responseReceived(
|
| + ResourceResponse(KURL(), "image/jpeg", sizeof(kJpegImage), nullAtom),
|
| + nullptr);
|
| + imageResource->appendData(reinterpret_cast<const char*>(kJpegImage),
|
| + sizeof(kJpegImage));
|
| + imageResource->finish();
|
| + EXPECT_FALSE(imageResource->errorOccurred());
|
| + ASSERT_TRUE(imageResource->getContent()->hasImage());
|
| + EXPECT_FALSE(imageResource->getContent()->getImage()->isNull());
|
| + EXPECT_EQ(2, observer->imageChangedCount());
|
| + EXPECT_EQ(kJpegImageWidth, observer->imageWidthOnLastImageChanged());
|
| + // The observer should have been notified that the image load completed.
|
| + EXPECT_TRUE(observer->imageNotifyFinishedCalled());
|
| + EXPECT_EQ(kJpegImageWidth, observer->imageWidthOnImageNotifyFinished());
|
| + EXPECT_TRUE(imageResource->getContent()->getImage()->isBitmapImage());
|
| + EXPECT_EQ(kJpegImageWidth, imageResource->getContent()->getImage()->width());
|
| + EXPECT_EQ(kJpegImageHeight,
|
| + imageResource->getContent()->getImage()->height());
|
| +
|
| + // Call reloadIfLoFiOrPlaceholderImage() after the image has finished loading.
|
| + imageResource->reloadIfLoFiOrPlaceholderImage(fetcher,
|
| + Resource::kReloadAlways);
|
| +
|
| + // The image should not have been reloaded, since it didn't have the LoFi
|
| + // image response headers.
|
| + EXPECT_EQ(2, observer->imageChangedCount());
|
| + EXPECT_TRUE(imageResource->isLoaded());
|
| +}
|
| +
|
| TEST(ImageResourceTest, ReloadIfLoFiOrPlaceholderViaResourceFetcher) {
|
| ResourceFetcher* fetcher = createFetcher();
|
|
|
| @@ -604,12 +646,8 @@ TEST(ImageResourceTest, ReloadIfLoFiOrPlaceholderDuringFetch) {
|
| MockImageResourceObserver::create(imageResource->getContent());
|
|
|
| // Send the image response.
|
| - ResourceResponse initialResourceResponse(testURL, "image/jpeg",
|
| - sizeof(kJpegImage), nullAtom);
|
| - initialResourceResponse.addHTTPHeaderField("chrome-proxy", "q=low");
|
| -
|
| - imageResource->loader()->didReceiveResponse(
|
| - WrappedResourceResponse(initialResourceResponse));
|
| + imageResource->loader()->didReceiveResponse(WrappedResourceResponse(
|
| + ResourceResponse(testURL, "image/jpeg", sizeof(kJpegImage), nullAtom)));
|
| imageResource->loader()->didReceiveData(
|
| reinterpret_cast<const char*>(kJpegImage), sizeof(kJpegImage));
|
|
|
|
|