Chromium Code Reviews| Index: cc/trees/layer_tree_host_unittest.cc |
| diff --git a/cc/trees/layer_tree_host_unittest.cc b/cc/trees/layer_tree_host_unittest.cc |
| index aedd0d937a43a69ffce015ea7507f522556a406a..de3aa03a65e832676e5d1712e3854a5fc7f41eab 100644 |
| --- a/cc/trees/layer_tree_host_unittest.cc |
| +++ b/cc/trees/layer_tree_host_unittest.cc |
| @@ -69,6 +69,118 @@ namespace { |
| class LayerTreeHostTest : public LayerTreeTest {}; |
| +// Test if the LTHI receives ReadyToActivate notifications from the TileManager |
| +// when no raster tasks get scheduled. |
| +class LayerTreeHostTestReadyToActivate : public LayerTreeHostTest { |
| + public: |
| + LayerTreeHostTestReadyToActivate() |
| + : did_notify_ready_to_activate_(false), |
| + all_tiles_required_for_activation_are_ready_to_draw_(false) {} |
| + |
| + void BeginTest() override { PostSetNeedsCommitToMainThread(); } |
| + |
| + void NotifyReadyToActivateOnThread(LayerTreeHostImpl* impl) override { |
| + did_notify_ready_to_activate_ = true; |
| + const std::vector<PictureLayerImpl*>& layers = impl->GetPictureLayers(); |
| + all_tiles_required_for_activation_are_ready_to_draw_ = true; |
| + for (const auto& layer : layers) { |
| + if (!layer->AllTilesRequiredForActivationAreReadyToDraw()) |
| + all_tiles_required_for_activation_are_ready_to_draw_ = false; |
| + } |
| + EndTest(); |
| + } |
| + |
| + void AfterTest() override { |
| + EXPECT_TRUE(did_notify_ready_to_activate_); |
| + EXPECT_TRUE(all_tiles_required_for_activation_are_ready_to_draw_); |
| + } |
| + |
| + private: |
| + bool did_notify_ready_to_activate_; |
| + bool all_tiles_required_for_activation_are_ready_to_draw_; |
| +}; |
| + |
| +SINGLE_AND_MULTI_THREAD_IMPL_TEST_F(LayerTreeHostTestReadyToActivate); |
| + |
| +// Test if the LTHI receives ReadyToActivate notifications from the TileManager |
| +// when some raster tasks flagged as REQUIRED_FOR_ACTIVATION got scheduled. |
| +class LayerTreeHostTestReadyToActivateNonEmpty |
| + : public LayerTreeHostTestReadyToActivate { |
| + public: |
| + void SetupTree() override { |
| + client_.set_fill_with_nonsolid_color(true); |
| + scoped_refptr<FakePictureLayer> root_layer = |
| + FakePictureLayer::Create(&client_); |
| + root_layer->SetBounds(gfx::Size(1024, 1024)); |
| + root_layer->SetIsDrawable(true); |
| + |
| + layer_tree_host()->SetRootLayer(root_layer); |
| + LayerTreeHostTest::SetupTree(); |
| + } |
| + |
| + private: |
| + FakeContentLayerClient client_; |
| +}; |
| + |
| +SINGLE_AND_MULTI_THREAD_IMPL_TEST_F(LayerTreeHostTestReadyToActivateNonEmpty); |
| + |
| +// Test if the LTHI receives ReadyToDraw notifications from the TileManager when |
| +// no raster tasks get scheduled. |
| +class LayerTreeHostTestReadyToDraw : public LayerTreeHostTest { |
|
enne (OOO)
2014/11/10 20:02:12
Can you add some DCHECK that verifies that this is
ernstm
2014/11/11 01:36:39
Done.
|
| + public: |
| + LayerTreeHostTestReadyToDraw() |
| + : did_notify_ready_to_draw_(false), |
| + all_tiles_required_for_draw_are_ready_to_draw_(false) {} |
| + |
| + void BeginTest() override { PostSetNeedsCommitToMainThread(); } |
| + |
| + void NotifyReadyToDrawOnThread(LayerTreeHostImpl* impl) override { |
| + did_notify_ready_to_draw_ = true; |
| + const std::vector<PictureLayerImpl*>& layers = impl->GetPictureLayers(); |
| + all_tiles_required_for_draw_are_ready_to_draw_ = true; |
| + for (const auto& layer : layers) { |
| + if (!layer->AllTilesRequiredForDrawAreReadyToDraw()) |
| + all_tiles_required_for_draw_are_ready_to_draw_ = false; |
| + } |
| + EndTest(); |
| + } |
| + |
| + void AfterTest() override { |
| + EXPECT_TRUE(did_notify_ready_to_draw_); |
| + EXPECT_TRUE(all_tiles_required_for_draw_are_ready_to_draw_); |
| + } |
| + |
| + private: |
| + bool did_notify_ready_to_draw_; |
| + bool all_tiles_required_for_draw_are_ready_to_draw_; |
| +}; |
| + |
| +SINGLE_AND_MULTI_THREAD_IMPL_TEST_F(LayerTreeHostTestReadyToDraw); |
| + |
| +// Test if the LTHI receives ReadyToDraw notifications from the TileManager when |
| +// some raster tasks flagged as REQUIRED_FOR_DRAW got scheduled. |
| +class LayerTreeHostTestReadyToDrawNonEmpty |
|
enne (OOO)
2014/11/10 20:02:12
Can you add some DCHECK that verifies that this is
ernstm
2014/11/11 01:36:39
Done.
|
| + : public LayerTreeHostTestReadyToDraw { |
| + public: |
| + void SetupTree() override { |
| + client_.set_fill_with_nonsolid_color(true); |
| + scoped_refptr<FakePictureLayer> root_layer = |
| + FakePictureLayer::Create(&client_); |
| + root_layer->SetBounds(gfx::Size(1024, 1024)); |
| + root_layer->SetIsDrawable(true); |
| + |
| + layer_tree_host()->SetRootLayer(root_layer); |
| + LayerTreeHostTest::SetupTree(); |
| + } |
| + |
| + private: |
| + FakeContentLayerClient client_; |
| +}; |
| + |
| +// Note: With this test setup, we only get tiles flagged as REQUIRED_FOR_DRAW in |
| +// single threaded mode. |
| +SINGLE_THREAD_IMPL_TEST_F(LayerTreeHostTestReadyToDrawNonEmpty); |
| + |
| // Two setNeedsCommits in a row should lead to at least 1 commit and at least 1 |
| // draw with frame 0. |
| class LayerTreeHostTestSetNeedsCommit1 : public LayerTreeHostTest { |