| Index: third_party/WebKit/Source/core/paint/PaintLayerScrollableAreaTest.cpp
|
| diff --git a/third_party/WebKit/Source/core/paint/PaintLayerScrollableAreaTest.cpp b/third_party/WebKit/Source/core/paint/PaintLayerScrollableAreaTest.cpp
|
| index 4b393489fdef498eba1acc122bdfb02aa4ea55ed..7678aa3e6b99335d95182f37b897e04590220430 100644
|
| --- a/third_party/WebKit/Source/core/paint/PaintLayerScrollableAreaTest.cpp
|
| +++ b/third_party/WebKit/Source/core/paint/PaintLayerScrollableAreaTest.cpp
|
| @@ -156,13 +156,14 @@ TEST_F(PaintLayerScrollableAreaTest,
|
| EXPECT_FALSE(canPaintBackgroundOntoScrollingContentsLayer("scroller16"));
|
| }
|
|
|
| -TEST_F(PaintLayerScrollableAreaTest, OpaqueLayersPromoted) {
|
| +TEST_F(PaintLayerScrollableAreaTest, OpaqueContainedLayersPromoted) {
|
| RuntimeEnabledFeatures::setCompositeOpaqueScrollersEnabled(true);
|
|
|
| setBodyInnerHTML(
|
| "<style>"
|
| - "#scroller { overflow: scroll; height: 200px; width: 200px; background: "
|
| - "white local content-box; border: 10px solid rgba(0, 255, 0, 0.5); }"
|
| + "#scroller { overflow: scroll; height: 200px; width: 200px; "
|
| + "contain: paint; background: white local content-box; "
|
| + "border: 10px solid rgba(0, 255, 0, 0.5); }"
|
| "#scrolled { height: 300px; }"
|
| "</style>"
|
| "<div id=\"scroller\"><div id=\"scrolled\"></div></div>");
|
| @@ -179,6 +180,36 @@ TEST_F(PaintLayerScrollableAreaTest, OpaqueLayersPromoted) {
|
| EXPECT_TRUE(paintLayer->graphicsLayerBackingForScrolling()->contentsOpaque());
|
| }
|
|
|
| +// Tests that we don't promote scrolling content which would not be contained.
|
| +// Promoting the scroller would also require promoting the positioned div
|
| +// which would lose subpixel anti-aliasing due to its transparent background.
|
| +TEST_F(PaintLayerScrollableAreaTest, NonContainedLayersNotPromoted) {
|
| + RuntimeEnabledFeatures::setCompositeOpaqueScrollersEnabled(true);
|
| +
|
| + setBodyInnerHTML(
|
| + "<style>"
|
| + "#scroller { overflow: scroll; height: 200px; width: 200px; "
|
| + "background: white local content-box; "
|
| + "border: 10px solid rgba(0, 255, 0, 0.5); }"
|
| + "#scrolled { height: 300px; }"
|
| + "#positioned { position: relative; }"
|
| + "</style>"
|
| + "<div id=\"scroller\">"
|
| + " <div id=\"positioned\">Not contained by scroller.</div>"
|
| + " <div id=\"scrolled\"></div>"
|
| + "</div>");
|
| + document().view()->updateAllLifecyclePhases();
|
| +
|
| + EXPECT_TRUE(RuntimeEnabledFeatures::compositeOpaqueScrollersEnabled());
|
| + Element* scroller = document().getElementById("scroller");
|
| + PaintLayer* paintLayer =
|
| + toLayoutBoxModelObject(scroller->layoutObject())->layer();
|
| + ASSERT_TRUE(paintLayer);
|
| + EXPECT_FALSE(paintLayer->needsCompositedScrolling());
|
| + EXPECT_FALSE(paintLayer->graphicsLayerBacking());
|
| + EXPECT_FALSE(paintLayer->graphicsLayerBackingForScrolling());
|
| +}
|
| +
|
| TEST_F(PaintLayerScrollableAreaTest, TransparentLayersNotPromoted) {
|
| RuntimeEnabledFeatures::setCompositeOpaqueScrollersEnabled(true);
|
|
|
| @@ -186,7 +217,7 @@ TEST_F(PaintLayerScrollableAreaTest, TransparentLayersNotPromoted) {
|
| "<style>"
|
| "#scroller { overflow: scroll; height: 200px; width: 200px; background: "
|
| "rgba(0, 255, 0, 0.5) local content-box; border: 10px solid rgba(0, 255, "
|
| - "0, 0.5); }"
|
| + "0, 0.5); contain: paint; }"
|
| "#scrolled { height: 300px; }"
|
| "</style>"
|
| "<div id=\"scroller\"><div id=\"scrolled\"></div></div>");
|
| @@ -208,7 +239,7 @@ TEST_F(PaintLayerScrollableAreaTest, OpaqueLayersDepromotedOnStyleChange) {
|
| setBodyInnerHTML(
|
| "<style>"
|
| "#scroller { overflow: scroll; height: 200px; width: 200px; background: "
|
| - "white local content-box; }"
|
| + "white local content-box; contain: paint; }"
|
| "#scrolled { height: 300px; }"
|
| "</style>"
|
| "<div id=\"scroller\"><div id=\"scrolled\"></div></div>");
|
| @@ -239,7 +270,7 @@ TEST_F(PaintLayerScrollableAreaTest, OpaqueLayersPromotedOnStyleChange) {
|
| setBodyInnerHTML(
|
| "<style>"
|
| "#scroller { overflow: scroll; height: 200px; width: 200px; background: "
|
| - "rgba(255,255,255,0.5) local content-box; }"
|
| + "rgba(255,255,255,0.5) local content-box; contain: paint; }"
|
| "#scrolled { height: 300px; }"
|
| "</style>"
|
| "<div id=\"scroller\"><div id=\"scrolled\"></div></div>");
|
| @@ -273,7 +304,7 @@ TEST_F(PaintLayerScrollableAreaTest, OnlyNonTransformedOpaqueLayersPromoted) {
|
| setBodyInnerHTML(
|
| "<style>"
|
| "#scroller { overflow: scroll; height: 200px; width: 200px; background: "
|
| - "white local content-box; }"
|
| + "white local content-box; contain: paint; }"
|
| "#scrolled { height: 300px; }"
|
| "</style>"
|
| "<div id=\"parent\">"
|
| @@ -327,7 +358,7 @@ TEST_F(PaintLayerScrollableAreaTest, OnlyOpaqueLayersPromoted) {
|
| setBodyInnerHTML(
|
| "<style>"
|
| "#scroller { overflow: scroll; height: 200px; width: 200px; background: "
|
| - "white local content-box; }"
|
| + "white local content-box; contain: paint; }"
|
| "#scrolled { height: 300px; }"
|
| "</style>"
|
| "<div id=\"parent\">"
|
|
|