Chromium Code Reviews| Index: cc/layer_tree_host_unittest.cc |
| diff --git a/cc/layer_tree_host_unittest.cc b/cc/layer_tree_host_unittest.cc |
| index 7e43aed6296592fe1f20e024c30f328f3f8d601e..3f4ce6b1fc4add1b87eca6a65e00223d192850a8 100644 |
| --- a/cc/layer_tree_host_unittest.cc |
| +++ b/cc/layer_tree_host_unittest.cc |
| @@ -11,6 +11,8 @@ |
| #include "cc/layer_tree_host_impl.h" |
| #include "cc/layer_tree_impl.h" |
| #include "cc/output_surface.h" |
| +#include "cc/picture_layer.h" |
| +#include "cc/picture_pile_impl.h" |
| #include "cc/single_thread_proxy.h" |
| #include "cc/test/fake_content_layer.h" |
| #include "cc/test/fake_content_layer_client.h" |
| @@ -2250,5 +2252,73 @@ TEST(LayerTreeHostTest, PartialUpdatesWithDelegatingRendererAndSoftwareContent) |
| EXPECT_EQ(0u, host->settings().maxPartialTextureUpdates); |
| } |
| +class LayerTreeHostTestCapturePicturePile : public LayerTreeHostTest { |
|
enne (OOO)
2013/01/03 23:55:30
Great! Thanks for the test. :)
Leandro Graciá Gil
2013/01/04 00:41:23
Np, thanks for your help to create and fix it.
|
| +public: |
| + LayerTreeHostTestCapturePicturePile() |
| + : m_bounds(gfx::Size(100, 100)) |
| + , m_layer(PictureLayer::create(&m_contentClient)) |
| + { |
| + m_settings.implSidePainting = true; |
| + } |
| + |
| + class FillRectContentLayerClient : public ContentLayerClient { |
| + public: |
| + virtual void paintContents(SkCanvas* canvas, const gfx::Rect& clip, gfx::RectF& opaque) OVERRIDE |
| + { |
| + SkPaint paint; |
| + paint.setColor(SK_ColorGREEN); |
| + |
| + SkRect rect = SkRect::MakeWH(canvas->getDeviceSize().width(), canvas->getDeviceSize().height()); |
| + opaque = gfx::RectF(rect.width(), rect.height()); |
| + canvas->drawRect(rect, paint); |
| + } |
| + }; |
| + |
| + virtual void beginTest() OVERRIDE |
| + { |
| + m_layer->setIsDrawable(true); |
| + m_layer->setBounds(m_bounds); |
| + m_layerTreeHost->setViewportSize(m_bounds, m_bounds); |
| + m_layerTreeHost->setRootLayer(m_layer); |
| + |
| + EXPECT_TRUE(m_layerTreeHost->initializeRendererIfNeeded()); |
| + postSetNeedsCommitToMainThread(); |
| + } |
| + |
| + virtual void didCommitAndDrawFrame() OVERRIDE |
| + { |
| + m_picturePile = m_layerTreeHost->capturePicturePile(); |
| + endTest(); |
| + } |
| + |
| + virtual void afterTest() OVERRIDE |
| + { |
| + SkBitmap bitmap; |
| + bitmap.setConfig(SkBitmap::kARGB_8888_Config, m_bounds.width(), m_bounds.height()); |
| + bitmap.allocPixels(); |
| + bitmap.eraseARGB(0, 0, 0, 0); |
| + SkCanvas canvas(bitmap); |
| + |
| + RenderingStats stats; |
| + m_picturePile->Raster(&canvas, gfx::Rect(m_bounds), 1.0, &stats); |
| + |
| + bitmap.lockPixels(); |
| + SkColor* pixels = reinterpret_cast<SkColor*>(bitmap.getPixels()); |
| + EXPECT_EQ(SK_ColorGREEN, pixels[0]); |
| + bitmap.unlockPixels(); |
| + } |
| + |
| +private: |
| + gfx::Size m_bounds; |
| + FillRectContentLayerClient m_contentClient; |
| + scoped_refptr<PictureLayer> m_layer; |
| + scoped_refptr<PicturePileImpl> m_picturePile; |
| +}; |
| + |
| +TEST_F(LayerTreeHostTestCapturePicturePile, runMultiThread) |
|
enne (OOO)
2013/01/03 23:55:30
This whole block can just be
MULTI_THREAD_TEST_F(
Leandro Graciá Gil
2013/01/04 00:41:23
Done.
|
| +{ |
| + runTest(true); |
| +} |
| + |
| } // namespace |
| } // namespace cc |