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

Unified Diff: third_party/WebKit/Source/core/loader/resource/ImageResourceTest.cpp

Issue 2930323003: Show client placeholders for Server LoFi images. (Closed)
Patch Set: Created 3 years, 6 months 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: 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 3d99402b794544421ef05dfd7f9795b205fcf83e..a3864818a1d36ac624e406e21bd15ccdc3452c31 100644
--- a/third_party/WebKit/Source/core/loader/resource/ImageResourceTest.cpp
+++ b/third_party/WebKit/Source/core/loader/resource/ImageResourceTest.cpp
@@ -551,7 +551,8 @@ TEST(ImageResourceTest, ReloadIfLoFiOrPlaceholderAfterFinished) {
// The observer should have been notified that the image load completed.
EXPECT_TRUE(observer->ImageNotifyFinishedCalled());
EXPECT_EQ(kJpegImageWidth, observer->ImageWidthOnImageNotifyFinished());
- EXPECT_TRUE(image_resource->GetContent()->GetImage()->IsBitmapImage());
+ EXPECT_FALSE(image_resource->GetContent()->GetImage()->IsBitmapImage());
+ EXPECT_TRUE(image_resource->ShouldShowPlaceholder());
EXPECT_EQ(kJpegImageWidth, image_resource->GetContent()->GetImage()->width());
EXPECT_EQ(kJpegImageHeight,
image_resource->GetContent()->GetImage()->height());
@@ -595,7 +596,8 @@ TEST(ImageResourceTest, ReloadIfLoFiOrPlaceholderAfterFinishedWithOldHeaders) {
// The observer should have been notified that the image load completed.
EXPECT_TRUE(observer->ImageNotifyFinishedCalled());
EXPECT_EQ(kJpegImageWidth, observer->ImageWidthOnImageNotifyFinished());
- EXPECT_TRUE(image_resource->GetContent()->GetImage()->IsBitmapImage());
+ EXPECT_FALSE(image_resource->GetContent()->GetImage()->IsBitmapImage());
+ EXPECT_TRUE(image_resource->ShouldShowPlaceholder());
EXPECT_EQ(kJpegImageWidth, image_resource->GetContent()->GetImage()->width());
EXPECT_EQ(kJpegImageHeight,
image_resource->GetContent()->GetImage()->height());
@@ -696,7 +698,38 @@ TEST(ImageResourceTest, ReloadIfLoFiOrPlaceholderViaResourceFetcher) {
GetMemoryCache()->Remove(image_resource);
}
-TEST(ImageResourceTest, ReloadIfLoFiOrPlaceholderDuringFetch) {
+TEST(ImageResourceTest, ReloadIfLoFiOrPlaceholderBeforeResponse) {
+ KURL test_url(kParsedURLString, kTestURL);
+ ScopedMockedURLLoad scoped_mocked_url_load(test_url, GetTestFilePath());
+
+ ResourceRequest request(test_url);
+ request.SetPreviewsState(WebURLRequest::kServerLoFiOn);
+ FetchParameters fetch_params(request);
+ ResourceFetcher* fetcher = CreateFetcher();
+
+ ImageResource* image_resource = ImageResource::Fetch(fetch_params, fetcher);
+ std::unique_ptr<MockImageResourceObserver> observer =
+ MockImageResourceObserver::Create(image_resource->GetContent());
+
+ EXPECT_FALSE(image_resource->ErrorOccurred());
+ EXPECT_TRUE(image_resource->ShouldShowPlaceholder());
+
+ // Call reloadIfLoFiOrPlaceholderImage() while the image is still loading.
+ image_resource->ReloadIfLoFiOrPlaceholderImage(fetcher,
+ Resource::kReloadAlways);
+
+ EXPECT_EQ(1, observer->ImageChangedCount());
+ EXPECT_EQ(0, observer->ImageWidthOnLastImageChanged());
+ // The observer should not have been notified of completion yet, since the
+ // image is still loading.
+ EXPECT_FALSE(observer->ImageNotifyFinishedCalled());
+
+ TestThatReloadIsStartedThenServeReload(
+ test_url, image_resource, image_resource->GetContent(), observer.get(),
+ WebCachePolicy::kBypassingCache);
+}
+
+TEST(ImageResourceTest, ReloadIfLoFiOrPlaceholderDuringResponse) {
KURL test_url(kParsedURLString, kTestURL);
ScopedMockedURLLoad scoped_mocked_url_load(test_url, GetTestFilePath());
@@ -710,9 +743,13 @@ TEST(ImageResourceTest, ReloadIfLoFiOrPlaceholderDuringFetch) {
MockImageResourceObserver::Create(image_resource->GetContent());
// Send the image response.
+ ResourceResponse resource_response(test_url, "image/jpeg", sizeof(kJpegImage),
+ g_null_atom);
+ resource_response.AddHTTPHeaderField("chrome-proxy-content-transform",
+ "empty-image");
+
image_resource->Loader()->DidReceiveResponse(
- WrappedResourceResponse(ResourceResponse(
- test_url, "image/jpeg", sizeof(kJpegImage), g_null_atom)));
+ WrappedResourceResponse(resource_response));
image_resource->Loader()->DidReceiveData(
reinterpret_cast<const char*>(kJpegImage), sizeof(kJpegImage));
@@ -722,7 +759,7 @@ TEST(ImageResourceTest, ReloadIfLoFiOrPlaceholderDuringFetch) {
EXPECT_EQ(1, observer->ImageChangedCount());
EXPECT_EQ(kJpegImageWidth, observer->ImageWidthOnLastImageChanged());
EXPECT_FALSE(observer->ImageNotifyFinishedCalled());
- EXPECT_TRUE(image_resource->GetContent()->GetImage()->IsBitmapImage());
+ EXPECT_TRUE(image_resource->ShouldShowPlaceholder());
EXPECT_EQ(kJpegImageWidth, image_resource->GetContent()->GetImage()->width());
EXPECT_EQ(kJpegImageHeight,
image_resource->GetContent()->GetImage()->height());
@@ -1608,7 +1645,6 @@ TEST(ImageResourceTest, PeriodicFlushTest) {
// Send the image response.
ResourceResponse resource_response(KURL(), "image/jpeg", sizeof(kJpegImage2),
g_null_atom);
- resource_response.AddHTTPHeaderField("chrome-proxy", "q=low");
image_resource->ResponseReceived(resource_response, nullptr);
@@ -1679,5 +1715,151 @@ TEST(ImageResourceTest, PeriodicFlushTest) {
WTF::SetTimeFunctionsForTesting(nullptr);
}
+TEST(ImageResourceTest, ShowPlaceholderForServerLoFiWithBitAndHeaders) {
+ KURL test_url(kParsedURLString, kTestURL);
+ ScopedMockedURLLoad scoped_mocked_url_load(test_url, GetTestFilePath());
+
+ ResourceRequest request(test_url);
+ request.SetPreviewsState(WebURLRequest::kServerLoFiOn);
+ FetchParameters params{request};
+ ImageResource* image_resource = ImageResource::Fetch(params, CreateFetcher());
+ EXPECT_EQ(FetchParameters::kDisallowPlaceholder,
+ params.GetPlaceholderImageRequestType());
+ EXPECT_EQ(g_null_atom,
+ image_resource->GetResourceRequest().HttpHeaderField("range"));
+
+ EXPECT_TRUE(image_resource->ShouldShowPlaceholder());
+ std::unique_ptr<MockImageResourceObserver> observer =
+ MockImageResourceObserver::Create(image_resource->GetContent());
+
+ // Send the Server Lo-Fi image response, complete with Server Lo-Fi response
+ // headers.
+ ResourceResponse response(test_url, "image/jpeg", sizeof(kJpegImage),
+ g_null_atom);
+ response.AddHTTPHeaderField("chrome-proxy-content-transform", "empty-image");
+
+ image_resource->Loader()->DidReceiveResponse(
+ WrappedResourceResponse(response));
+ image_resource->Loader()->DidReceiveData(
+ reinterpret_cast<const char*>(kJpegImage), sizeof(kJpegImage));
+ image_resource->Loader()->DidFinishLoading(
+ 0.0, sizeof(kJpegImage), sizeof(kJpegImage), sizeof(kJpegImage));
+
+ EXPECT_EQ(ResourceStatus::kCached, image_resource->GetStatus());
+ EXPECT_TRUE(image_resource->ShouldShowPlaceholder());
+ EXPECT_LT(0, observer->ImageChangedCount());
+ EXPECT_EQ(kJpegImageWidth, observer->ImageWidthOnLastImageChanged());
+ EXPECT_TRUE(observer->ImageNotifyFinishedCalled());
+ EXPECT_EQ(kJpegImageWidth, observer->ImageWidthOnImageNotifyFinished());
+
+ ASSERT_TRUE(image_resource->GetContent()->HasImage());
+ EXPECT_EQ(kJpegImageWidth, image_resource->GetContent()->GetImage()->width());
+ EXPECT_EQ(kJpegImageHeight,
+ image_resource->GetContent()->GetImage()->height());
+ EXPECT_FALSE(image_resource->GetContent()->GetImage()->IsBitmapImage());
+}
+
+TEST(ImageResourceTest, DoNotShowPlaceholderForServerLoFiWithoutHeaders) {
+ KURL test_url(kParsedURLString, kTestURL);
+ ScopedMockedURLLoad scoped_mocked_url_load(test_url, GetTestFilePath());
+
+ ResourceRequest request(test_url);
+ request.SetPreviewsState(WebURLRequest::kServerLoFiOn);
+ FetchParameters params{request};
+ ImageResource* image_resource = ImageResource::Fetch(params, CreateFetcher());
+ EXPECT_EQ(FetchParameters::kDisallowPlaceholder,
+ params.GetPlaceholderImageRequestType());
+ EXPECT_EQ(g_null_atom,
+ image_resource->GetResourceRequest().HttpHeaderField("range"));
+
+ EXPECT_TRUE(image_resource->ShouldShowPlaceholder());
+ std::unique_ptr<MockImageResourceObserver> observer =
+ MockImageResourceObserver::Create(image_resource->GetContent());
+
+ // Send the image response without any Server Lo-Fi response headers.
+ image_resource->Loader()->DidReceiveResponse(
+ WrappedResourceResponse(ResourceResponse(
+ test_url, "image/jpeg", sizeof(kJpegImage), g_null_atom)));
+ image_resource->Loader()->DidReceiveData(
+ reinterpret_cast<const char*>(kJpegImage), sizeof(kJpegImage));
+ image_resource->Loader()->DidFinishLoading(
+ 0.0, sizeof(kJpegImage), sizeof(kJpegImage), sizeof(kJpegImage));
+
+ EXPECT_EQ(WebURLRequest::kPreviewsOff,
+ image_resource->GetResourceRequest().GetPreviewsState());
+ EXPECT_FALSE(image_resource->ShouldShowPlaceholder());
+
+ EXPECT_EQ(ResourceStatus::kCached, image_resource->GetStatus());
+ EXPECT_LT(0, observer->ImageChangedCount());
+ EXPECT_EQ(kJpegImageWidth, observer->ImageWidthOnLastImageChanged());
+ EXPECT_TRUE(observer->ImageNotifyFinishedCalled());
+ EXPECT_EQ(kJpegImageWidth, observer->ImageWidthOnImageNotifyFinished());
+
+ ASSERT_TRUE(image_resource->GetContent()->HasImage());
+ EXPECT_EQ(kJpegImageWidth, image_resource->GetContent()->GetImage()->width());
+ EXPECT_EQ(kJpegImageHeight,
+ image_resource->GetContent()->GetImage()->height());
+ EXPECT_TRUE(image_resource->GetContent()->GetImage()->IsBitmapImage());
+}
+
+TEST(ImageResourceTest, ShowPlaceholderForServerLoFiWithHeadersButWithoutBit) {
+ const struct {
+ const char* header_name;
+ const char* header_value;
+ } tests[] = {
+ // New-style Server Lo-Fi response header.
+ {"chrome-proxy-content-transform", "empty-image"},
+ // Legacy Server Lo-Fi response header.
+ {"chrome-proxy", "q=low"},
+ };
+
+ for (const auto& test : tests) {
+ KURL test_url(kParsedURLString, kTestURL);
+ ScopedMockedURLLoad scoped_mocked_url_load(test_url, GetTestFilePath());
+
+ FetchParameters params{ResourceRequest(test_url)};
+ ImageResource* image_resource =
+ ImageResource::Fetch(params, CreateFetcher());
+ EXPECT_EQ(FetchParameters::kDisallowPlaceholder,
+ params.GetPlaceholderImageRequestType());
+ EXPECT_EQ(g_null_atom,
+ image_resource->GetResourceRequest().HttpHeaderField("range"));
+
+ EXPECT_FALSE(image_resource->ShouldShowPlaceholder());
+ std::unique_ptr<MockImageResourceObserver> observer =
+ MockImageResourceObserver::Create(image_resource->GetContent());
+
+ // Send a Server Lo-Fi image response, complete with Server Lo-Fi response
+ // headers.
+ ResourceResponse response(test_url, "image/jpeg", sizeof(kJpegImage),
+ g_null_atom);
+ response.AddHTTPHeaderField(test.header_name, test.header_value);
+
+ image_resource->Loader()->DidReceiveResponse(
+ WrappedResourceResponse(response));
+ image_resource->Loader()->DidReceiveData(
+ reinterpret_cast<const char*>(kJpegImage), sizeof(kJpegImage));
+ image_resource->Loader()->DidFinishLoading(
+ 0.0, sizeof(kJpegImage), sizeof(kJpegImage), sizeof(kJpegImage));
+
+ EXPECT_TRUE(image_resource->GetResourceRequest().GetPreviewsState() &
+ WebURLRequest::kServerLoFiOn);
+ EXPECT_TRUE(image_resource->ShouldShowPlaceholder());
+
+ EXPECT_EQ(ResourceStatus::kCached, image_resource->GetStatus());
+ EXPECT_LT(0, observer->ImageChangedCount());
+ EXPECT_EQ(kJpegImageWidth, observer->ImageWidthOnLastImageChanged());
+ EXPECT_TRUE(observer->ImageNotifyFinishedCalled());
+ EXPECT_EQ(kJpegImageWidth, observer->ImageWidthOnImageNotifyFinished());
+
+ ASSERT_TRUE(image_resource->GetContent()->HasImage());
+ EXPECT_EQ(kJpegImageWidth,
+ image_resource->GetContent()->GetImage()->width());
+ EXPECT_EQ(kJpegImageHeight,
+ image_resource->GetContent()->GetImage()->height());
+ EXPECT_FALSE(image_resource->GetContent()->GetImage()->IsBitmapImage());
+ }
+}
+
} // namespace
} // namespace blink

Powered by Google App Engine
This is Rietveld 408576698