Chromium Code Reviews| Index: Source/web/tests/WebFrameTest.cpp |
| diff --git a/Source/web/tests/WebFrameTest.cpp b/Source/web/tests/WebFrameTest.cpp |
| index c397b688dae0033f454a19d1f4d54b2ae9a38c74..1260219490c7f5db7f459215c90c6d3ec1a15f10 100644 |
| --- a/Source/web/tests/WebFrameTest.cpp |
| +++ b/Source/web/tests/WebFrameTest.cpp |
| @@ -57,6 +57,7 @@ |
| #include "core/rendering/RenderView.h" |
| #include "core/rendering/TextAutosizer.h" |
| #include "core/rendering/compositing/RenderLayerCompositor.h" |
| +#include "platform/DragImage.h" |
| #include "platform/UserGestureIndicator.h" |
| #include "platform/geometry/FloatRect.h" |
| #include "platform/network/ResourceError.h" |
| @@ -5433,4 +5434,40 @@ TEST_F(WebFrameTest, HasVisibleContentOnHiddenFrames) |
| } |
| } |
| +TEST_F(WebFrameTest, NodeImageTest) |
| +{ |
| + registerMockedHttpURLLoad("nodeimage.html"); |
| + |
| + FixedLayoutTestWebViewClient client; |
| + client.m_screenInfo.deviceScaleFactor = 1; |
| + int viewportWidth = 100; |
| + int viewportHeight = 100; |
| + |
| + FrameTestHelpers::WebViewHelper webViewHelper; |
| + webViewHelper.initializeAndLoad(m_baseURL + "nodeimage.html", true, 0, &client); |
| + webViewHelper.webView()->settings()->setViewportEnabled(true); |
| + webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
| + webViewHelper.webView()->layout(); |
| + |
| + SkBitmap bitmap; |
| + ASSERT_TRUE(bitmap.allocN32Pixels(40, 40)); |
| + SkCanvas canvas(bitmap); |
| + canvas.drawColor(SK_ColorGREEN); |
| + |
| + RefPtr<WebCore::LocalFrame> frame = webViewHelper.webViewImpl()->page()->mainFrame(); |
| + |
| + // Sub Test 1 |
| + { |
| + WebCore::Element* element = frame->document()->getElementById("case-css-transform"); |
| + OwnPtr<WebCore::DragImage> dragImage = frame->nodeImage(*element); |
| + EXPECT_TRUE(dragImage); |
| + EXPECT_EQ(40, dragImage->size().width()); |
| + EXPECT_EQ(40, dragImage->size().height()); |
| + const SkBitmap& dragBitmap = dragImage->bitmap(); |
| + SkAutoLockPixels lockPixel(dragBitmap); |
| + EXPECT_EQ(0, memcmp(bitmap.getPixels(), dragBitmap.getPixels(), bitmap.rowBytes() * 40)); |
|
dcheng
2014/05/28 21:02:59
You can replace bitmap.rowBytes() * 40 with bitmap
spartha
2014/05/29 05:55:00
Done.
|
| + } |
| + |
| +} |
| + |
| } // namespace |