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 2804411371a7bea97b22435a0941e5ff32cbf8b9..59bf555aa451ee7e7640e7b65f7675739f0f0021 100644 |
| --- a/cc/trees/layer_tree_host_unittest.cc |
| +++ b/cc/trees/layer_tree_host_unittest.cc |
| @@ -1095,7 +1095,6 @@ class TestOpacityChangeLayerDelegate : public ContentLayerClient { |
| if (test_layer_) |
| test_layer_->SetOpacity(0.f); |
| } |
| - void DidChangeLayerCanUseLCDText() override {} |
| bool FillsBoundsCompletely() const override { return false; } |
| private: |
| @@ -2280,46 +2279,41 @@ class LayerTreeHostTestShutdownWithOnlySomeResourcesEvicted |
| SINGLE_AND_MULTI_THREAD_NOIMPL_TEST_F( |
| LayerTreeHostTestShutdownWithOnlySomeResourcesEvicted); |
| -class LayerTreeHostTestLCDNotification : public LayerTreeHostTest { |
| +class LayerTreeHostTestLcdChange : public LayerTreeHostTest { |
| public: |
| - class NotificationClient : public ContentLayerClient { |
| + class PaintClient : public FakeContentLayerClient { |
| public: |
| - NotificationClient() |
| - : layer_(0), paint_count_(0), lcd_notification_count_(0) {} |
| + PaintClient() : paint_count_(0) {} |
| - void set_layer(Layer* layer) { layer_ = layer; } |
| int paint_count() const { return paint_count_; } |
| - int lcd_notification_count() const { return lcd_notification_count_; } |
| void PaintContents( |
| SkCanvas* canvas, |
| const gfx::Rect& clip, |
| ContentLayerClient::GraphicsContextStatus gc_status) override { |
| + FakeContentLayerClient::PaintContents(canvas, clip, gc_status); |
| ++paint_count_; |
| } |
| - void DidChangeLayerCanUseLCDText() override { |
| - ++lcd_notification_count_; |
| - layer_->SetNeedsDisplay(); |
| - } |
| + |
| bool FillsBoundsCompletely() const override { return false; } |
| private: |
| - Layer* layer_; |
| int paint_count_; |
| - int lcd_notification_count_; |
| }; |
| void SetupTree() override { |
| + num_tiles_rastered_ = 0; |
| + |
| scoped_refptr<Layer> root_layer; |
| if (layer_tree_host()->settings().impl_side_painting) |
| root_layer = PictureLayer::Create(&client_); |
| else |
| root_layer = ContentLayer::Create(&client_); |
| + client_.set_fill_with_nonsolid_color(true); |
| root_layer->SetIsDrawable(true); |
| - root_layer->SetBounds(gfx::Size(1, 1)); |
| + root_layer->SetBounds(gfx::Size(10, 10)); |
| layer_tree_host()->SetRootLayer(root_layer); |
| - client_.set_layer(root_layer.get()); |
| // The expecations are based on the assumption that the default |
| // LCD settings are: |
| @@ -2330,49 +2324,76 @@ class LayerTreeHostTestLCDNotification : public LayerTreeHostTest { |
| } |
| void BeginTest() override { PostSetNeedsCommitToMainThread(); } |
| - void AfterTest() override {} |
| - void DidCommit() override { |
| + void DidCommitAndDrawFrame() override { |
| switch (layer_tree_host()->source_frame_number()) { |
| case 1: |
| - // The first update consists of one LCD notification and one paint. |
| - EXPECT_EQ(1, client_.lcd_notification_count()); |
| + // The first update consists of a paint of the whole layer. |
| EXPECT_EQ(1, client_.paint_count()); |
| // LCD text must have been enabled on the layer. |
| EXPECT_TRUE(layer_tree_host()->root_layer()->can_use_lcd_text()); |
| PostSetNeedsCommitToMainThread(); |
| break; |
| case 2: |
| - // Since nothing changed on layer, there should be no notification |
| - // or paint on the second update. |
| - EXPECT_EQ(1, client_.lcd_notification_count()); |
| + // Since nothing changed on layer, there should be no paint. |
| EXPECT_EQ(1, client_.paint_count()); |
| // LCD text must not have changed. |
| EXPECT_TRUE(layer_tree_host()->root_layer()->can_use_lcd_text()); |
| - // Change layer opacity that should trigger lcd notification. |
| + // Change layer opacity that should trigger lcd change. |
| layer_tree_host()->root_layer()->SetOpacity(.5f); |
| - // No need to request a commit - setting opacity will do it. |
| break; |
| - default: |
| - // Verify that there is no extra commit due to layer invalidation. |
| - EXPECT_EQ(3, layer_tree_host()->source_frame_number()); |
| - // LCD notification count should have incremented due to |
| - // change in layer opacity. |
| - EXPECT_EQ(2, client_.lcd_notification_count()); |
| - // Paint count should be incremented due to invalidation. |
| - EXPECT_EQ(2, client_.paint_count()); |
| + case 3: |
| + // LCD text doesn't require re-recording, so no painting should occur. |
| + EXPECT_EQ(1, client_.paint_count()); |
| // LCD text must have been disabled on the layer due to opacity. |
| EXPECT_FALSE(layer_tree_host()->root_layer()->can_use_lcd_text()); |
| + // Change layer opacity that should not trigger lcd change. |
| + layer_tree_host()->root_layer()->SetOpacity(1.f); |
| + break; |
| + case 4: |
| + // LCD text doesn't require re-recording, so no painting should occur. |
| + EXPECT_EQ(1, client_.paint_count()); |
| + // Even though LCD text could be allowed. |
| + EXPECT_TRUE(layer_tree_host()->root_layer()->can_use_lcd_text()); |
| EndTest(); |
| break; |
| } |
| } |
| + void NotifyTileStateChangedOnThread(LayerTreeHostImpl* host_impl, |
| + const Tile* tile) override { |
| + ++num_tiles_rastered_; |
| + } |
| + |
| + void DrawLayersOnThread(LayerTreeHostImpl* host_impl) override { |
| + switch (host_impl->active_tree()->source_frame_number()) { |
| + case 0: |
| + // The first draw. |
| + EXPECT_EQ(1, num_tiles_rastered_); |
| + break; |
| + case 1: |
| + // Nothing changed on the layer. |
| + EXPECT_EQ(1, num_tiles_rastered_); |
| + break; |
| + case 2: |
| + // LCD text was disabled, it should be re-rastered with LCD text off. |
| + EXPECT_EQ(2, num_tiles_rastered_); |
| + break; |
| + case 3: |
| + // LCD text was enabled but it's sticky and stays off. |
| + EXPECT_EQ(2, num_tiles_rastered_); |
| + break; |
| + } |
| + } |
| + |
| + void AfterTest() override {} |
| + |
| private: |
| - NotificationClient client_; |
| + PaintClient client_; |
| + int num_tiles_rastered_; |
| }; |
| -SINGLE_AND_MULTI_THREAD_TEST_F(LayerTreeHostTestLCDNotification); |
| +SINGLE_AND_MULTI_THREAD_IMPL_TEST_F(LayerTreeHostTestLcdChange); |
|
enne (OOO)
2014/11/14 00:05:45
Nice try, but Lcd => LCD
$ git grep Lcd cc | wc -
|
| // Verify that the BeginFrame notification is used to initiate rendering. |
| class LayerTreeHostTestBeginFrameNotification : public LayerTreeHostTest { |
| @@ -2543,8 +2564,6 @@ class LayerTreeHostTestChangeLayerPropertiesInPaintContents |
| layer_->SetBounds(gfx::Size(2, 2)); |
| } |
| - void DidChangeLayerCanUseLCDText() override {} |
| - |
| bool FillsBoundsCompletely() const override { return false; } |
| private: |