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

Unified Diff: cc/trees/layer_tree_host_unittest.cc

Issue 315393002: Record SkPicture with correct LCD text setting. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: better unittest Created 6 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: 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 870f2df5f89f1a459c9433eb894d1cb52a8eb2d0..7c7a26b9fb979f3c026d76e84df01147f975688d 100644
--- a/cc/trees/layer_tree_host_unittest.cc
+++ b/cc/trees/layer_tree_host_unittest.cc
@@ -971,13 +971,14 @@ class TestOpacityChangeLayerDelegate : public ContentLayerClient {
virtual void PaintContents(
SkCanvas* canvas,
const gfx::Rect& clip,
+ bool can_paint_lcd_text,
gfx::RectF* opaque,
ContentLayerClient::GraphicsContextStatus gc_status) OVERRIDE {
// Set layer opacity to 0.
if (test_layer_)
test_layer_->SetOpacity(0.f);
}
- virtual void DidChangeLayerCanUseLCDText() OVERRIDE {}
+ virtual bool PaintsLCDText() const OVERRIDE { return false; }
virtual bool FillsBoundsCompletely() const OVERRIDE { return false; }
private:
@@ -2182,50 +2183,60 @@ class LayerTreeHostTestShutdownWithOnlySomeResourcesEvicted
SINGLE_AND_MULTI_THREAD_NOIMPL_TEST_F(
LayerTreeHostTestShutdownWithOnlySomeResourcesEvicted);
-class LayerTreeHostTestLCDNotification : public LayerTreeHostTest {
+class LayerTreeHostTestLCDText : public LayerTreeHostTest {
public:
- class NotificationClient : public ContentLayerClient {
+ class LCDTextClient : public ContentLayerClient {
public:
- NotificationClient()
- : layer_(0), paint_count_(0), lcd_notification_count_(0) {}
+ LCDTextClient(bool paints_lcd_text)
+ : paints_lcd_text_(paints_lcd_text),
+ paint_count_(0),
+ could_paint_lcd_text_last_frame_(false) {}
- void set_layer(Layer* layer) { layer_ = layer; }
int paint_count() const { return paint_count_; }
- int lcd_notification_count() const { return lcd_notification_count_; }
+ int could_paint_lcd_text_last_frame() const {
+ return could_paint_lcd_text_last_frame_;
+ }
virtual void PaintContents(
SkCanvas* canvas,
const gfx::Rect& clip,
+ bool can_paint_lcd_text,
gfx::RectF* opaque,
ContentLayerClient::GraphicsContextStatus gc_status) OVERRIDE {
++paint_count_;
+ could_paint_lcd_text_last_frame_ = can_paint_lcd_text;
}
- virtual void DidChangeLayerCanUseLCDText() OVERRIDE {
- ++lcd_notification_count_;
- layer_->SetNeedsDisplay();
- }
+ virtual bool PaintsLCDText() const OVERRIDE { return paints_lcd_text_; }
virtual bool FillsBoundsCompletely() const OVERRIDE { return false; }
private:
- Layer* layer_;
+ bool paints_lcd_text_;
int paint_count_;
- int lcd_notification_count_;
+ bool could_paint_lcd_text_last_frame_;
};
virtual void SetupTree() OVERRIDE {
- scoped_refptr<ContentLayer> root_layer = ContentLayer::Create(&client_);
- root_layer->SetIsDrawable(true);
- root_layer->SetBounds(gfx::Size(1, 1));
+ LayerTreeHostTest::SetupTree();
- layer_tree_host()->SetRootLayer(root_layer);
- client_.set_layer(root_layer.get());
+ lcd_text_client_.reset(new LCDTextClient(true));
+ regular_text_client_.reset(new LCDTextClient(false));
- // The expecations are based on the assumption that the default
- // LCD settings are:
+ if (layer_tree_host()->settings().impl_side_painting) {
+ lcd_text_layer_ = PictureLayer::Create(lcd_text_client_.get());
+ regular_text_layer_ = PictureLayer::Create(regular_text_client_.get());
+ } else {
+ lcd_text_layer_ = ContentLayer::Create(lcd_text_client_.get());
+ regular_text_layer_ = ContentLayer::Create(regular_text_client_.get());
+ }
+ lcd_text_layer_->SetIsDrawable(true);
+ lcd_text_layer_->SetBounds(gfx::Size(1, 1));
+ layer_tree_host()->root_layer()->AddChild(lcd_text_layer_);
+ regular_text_layer_->SetIsDrawable(true);
+ regular_text_layer_->SetBounds(gfx::Size(1, 1));
+ layer_tree_host()->root_layer()->AddChild(regular_text_layer_);
+
+ // The expecations are based on the assumption that LCD text is enabled.
EXPECT_TRUE(layer_tree_host()->settings().can_use_lcd_text);
- EXPECT_FALSE(root_layer->can_use_lcd_text());
-
- LayerTreeHostTest::SetupTree();
}
virtual void BeginTest() OVERRIDE { PostSetNeedsCommitToMainThread(); }
@@ -2234,44 +2245,67 @@ class LayerTreeHostTestLCDNotification : public LayerTreeHostTest {
virtual void DidCommit() OVERRIDE {
switch (layer_tree_host()->source_frame_number()) {
case 1:
- // The first update consists one LCD notification and one paint.
- EXPECT_EQ(1, client_.lcd_notification_count());
- 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());
+ // LCD text must be enabled on both layers.
+ EXPECT_TRUE(lcd_text_layer_->can_use_lcd_text());
+ EXPECT_TRUE(regular_text_layer_->can_use_lcd_text());
+ // Both layers must be painted.
+ EXPECT_EQ(1, lcd_text_client_->paint_count());
+ EXPECT_EQ(1, regular_text_client_->paint_count());
+ // LCD text must have been allowed on both layers.
+ EXPECT_TRUE(lcd_text_client_->could_paint_lcd_text_last_frame());
+ EXPECT_TRUE(regular_text_client_->could_paint_lcd_text_last_frame());
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());
- 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.
- layer_tree_host()->root_layer()->SetOpacity(.5f);
+ // Since nothing changed on any of the layers,
+ // everything should remain the same and they should not be repainted.
+ EXPECT_TRUE(lcd_text_layer_->can_use_lcd_text());
+ EXPECT_TRUE(regular_text_layer_->can_use_lcd_text());
+ EXPECT_EQ(1, lcd_text_client_->paint_count());
+ EXPECT_EQ(1, regular_text_client_->paint_count());
+ // Change layer opacity that should trigger lcd change.
+ lcd_text_layer_->SetOpacity(.5f);
+ regular_text_layer_->SetOpacity(.5f);
// No need to request a commit - setting opacity will do it.
break;
+ case 3:
+ // LCD text must have been disabled on layers due to opacity.
+ EXPECT_FALSE(lcd_text_layer_->can_use_lcd_text());
+ EXPECT_FALSE(regular_text_layer_->can_use_lcd_text());
+ // Layer with lcd text should have been repainted with LCD AA.
+ EXPECT_EQ(2, lcd_text_client_->paint_count());
+ EXPECT_FALSE(lcd_text_client_->could_paint_lcd_text_last_frame());
+ // Layer with regular text should not have been repainted.
+ EXPECT_EQ(1, regular_text_client_->paint_count());
+ // Reset layer opacity - making it possible to use LCD text again.
+ lcd_text_layer_->SetOpacity(1.f);
+ regular_text_layer_->SetOpacity(1.f);
+ break;
default:
- // Verify that there is not 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());
- // LCD text must have been disabled on the layer due to opacity.
- EXPECT_FALSE(layer_tree_host()->root_layer()->can_use_lcd_text());
+ // Verify that there is no extra commit due to layer invalidation.
+ EXPECT_EQ(4, layer_tree_host()->source_frame_number());
+ // LCD text is now allowed.
+ EXPECT_TRUE(lcd_text_layer_->can_use_lcd_text());
+ EXPECT_TRUE(regular_text_layer_->can_use_lcd_text());
+ // Although LCD text is allowed, it is not used.
+ // Once LCD is disabled, it cannot be switched back ON.
+ // So there should not be any invalidation or painting.
+ EXPECT_EQ(2, lcd_text_client_->paint_count());
+ EXPECT_EQ(1, regular_text_client_->paint_count());
EndTest();
break;
}
}
private:
- NotificationClient client_;
+ scoped_ptr<LCDTextClient> lcd_text_client_;
+ scoped_ptr<LCDTextClient> regular_text_client_;
+
+ scoped_refptr<Layer> lcd_text_layer_;
+ scoped_refptr<Layer> regular_text_layer_;
};
-SINGLE_THREAD_TEST_F(LayerTreeHostTestLCDNotification);
+SINGLE_AND_MULTI_THREAD_TEST_F(LayerTreeHostTestLCDText);
// Verify that the BeginFrame notification is used to initiate rendering.
class LayerTreeHostTestBeginFrameNotification : public LayerTreeHostTest {
@@ -2439,12 +2473,13 @@ class LayerTreeHostTestChangeLayerPropertiesInPaintContents
virtual void PaintContents(
SkCanvas* canvas,
const gfx::Rect& clip,
+ bool can_paint_lcd_text,
gfx::RectF* opaque,
ContentLayerClient::GraphicsContextStatus gc_status) OVERRIDE {
layer_->SetBounds(gfx::Size(2, 2));
}
- virtual void DidChangeLayerCanUseLCDText() OVERRIDE {}
+ virtual bool PaintsLCDText() const OVERRIDE { return false; }
virtual bool FillsBoundsCompletely() const OVERRIDE { return false; }

Powered by Google App Engine
This is Rietveld 408576698