summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/css/css-contain/contain-layout-dynamic-001.html
diff options
context:
space:
mode:
Diffstat (limited to 'testing/web-platform/tests/css/css-contain/contain-layout-dynamic-001.html')
-rw-r--r--testing/web-platform/tests/css/css-contain/contain-layout-dynamic-001.html228
1 files changed, 228 insertions, 0 deletions
diff --git a/testing/web-platform/tests/css/css-contain/contain-layout-dynamic-001.html b/testing/web-platform/tests/css/css-contain/contain-layout-dynamic-001.html
new file mode 100644
index 0000000000..428d2b9d4d
--- /dev/null
+++ b/testing/web-platform/tests/css/css-contain/contain-layout-dynamic-001.html
@@ -0,0 +1,228 @@
+<!DOCTYPE html>
+<meta charset="utf-8">
+<title>Dynamic change to layout containment</title>
+<link rel="help" href="https://drafts.csswg.org/css-contain/#contain-property">
+<link rel="help" href="https://bugzilla.mozilla.org/show_bug.cgi?id=1765615">
+<link rel="stylesheet" type="text/css" href="/fonts/ahem.css" />
+<script src="/resources/testharness.js"></script>
+<script src="/resources/testharnessreport.js"></script>
+<meta name="assert" content="Verify layout containment is properly updated after dynamic change to the contain property.">
+<style>
+ /* Selectors for contain */
+ #none .wrapper {
+ contain: none;
+ }
+ #layout .wrapper {
+ contain: layout;
+ }
+ #none_to_layout .wrapper {
+ contain: none;
+ }
+ #layout_to_none .wrapper {
+ contain: layout;
+ }
+
+ /* Selectors for testing absolute/fixed positioned elements */
+ #top_spacer {
+ height: 100px;
+ background: lightgray;
+ }
+ .absolute_pos {
+ position: absolute;
+ top: 42px;
+ }
+ .fixed_pos {
+ position: fixed;
+ top: 42px;
+ }
+
+ /* Selectors for testing baseline */
+ .flex {
+ display: inline-flex;
+ align-items: baseline;
+ }
+
+ /* Selectors for testing IFC (floats) */
+ .floatleft {
+ float: left;
+ }
+ .clearleft {
+ clear: left;
+ }
+
+ /* Selectors for testing IFC (margin collapsing) */
+ .blockmargin {
+ margin: 25px 0;
+ }
+ .wrapper.blockmargin {
+ background: lightgray;
+ }
+
+ .rect {
+ background: black;
+ width: 50px;
+ height: 100px;
+ }
+</style>
+<body>
+ <div id="log"></div>
+
+ <div id="top_spacer"></div>
+
+ <div id="none">
+ <div class="wrapper">
+ <div class="absolute_pos"></div>
+ <div class="fixed_pos"></div>
+ </div>
+ <div class="flex">
+ <div class="rect"></div>
+ <div class="wrapper rect">X</div>
+ </div>
+ <div>
+ <div class="floatleft rect"></div>
+ <div class="wrapper">
+ <div class="clearleft rect"></div>
+ </div>
+ </div>
+ <div>
+ <div class="wrapper blockmargin">
+ <div class="rect blockmargin"></div>
+ </div>
+ </div>
+ </div>
+
+ <div id="layout">
+ <div class="wrapper">
+ <div class="absolute_pos"></div>
+ <div class="fixed_pos"></div>
+ </div>
+ <div class="flex">
+ <div class="rect"></div>
+ <div class="wrapper rect">X</div>
+ </div>
+ <div>
+ <div class="floatleft rect"></div>
+ <div class="wrapper">
+ <div class="clearleft rect"></div>
+ </div>
+ </div>
+ <div>
+ <div class="wrapper blockmargin">
+ <div class="rect blockmargin"></div>
+ </div>
+ </div>
+ </div>
+
+ <div id="none_to_layout">
+ <div class="wrapper">
+ <div class="absolute_pos"></div>
+ <div class="fixed_pos"></div>
+ </div>
+ <div class="flex">
+ <div class="rect"></div>
+ <div class="wrapper rect">X</div>
+ </div>
+ <div>
+ <div class="floatleft rect"></div>
+ <div class="wrapper">
+ <div class="clearleft rect"></div>
+ </div>
+ </div>
+ <div>
+ <div class="wrapper blockmargin">
+ <div class="rect blockmargin"></div>
+ </div>
+ </div>
+ </div>
+
+ <div id="layout_to_none">
+ <div class="wrapper">
+ <div class="absolute_pos"></div>
+ <div class="fixed_pos"></div>
+ </div>
+ <div class="flex">
+ <div class="rect"></div>
+ <div class="wrapper rect">X</div>
+ </div>
+ <div>
+ <div class="floatleft rect"></div>
+ <div class="wrapper">
+ <div class="clearleft rect"></div>
+ </div>
+ </div>
+ <div>
+ <div class="wrapper blockmargin">
+ <div class="rect blockmargin"></div>
+ </div>
+ </div>
+ </div>
+
+ <script>
+ function verifyLayoutContainment(id, applied) {
+ let container = document.getElementById(id);
+ let wrappers = container.getElementsByClassName("wrapper");
+
+ // To verify the containment box establishes an absolute positioning
+ // containing block and a fixed positioning containing block, we test
+ // positions of absolutely/fixed positioned children (a bit below the
+ // containment box rather than a bit below the top of the viewport).
+ let containingBlockTop = wrappers[0].getBoundingClientRect().top;
+ let absTop = container.getElementsByClassName("absolute_pos")[0]
+ .getBoundingClientRect().top;
+ assert_equals(absTop > containingBlockTop, applied, "absolute positioning containing block");
+ let fixedTop = container.getElementsByClassName("fixed_pos")[0]
+ .getBoundingClientRect().top;
+ assert_equals(fixedTop > containingBlockTop, applied, "fixed positioning containing block");
+
+ // To verify the containment box suppresses baseline, we verify that
+ // the two items in the flex container are properly aligned.
+ let item1 = wrappers[1];
+ let item2 = item1.previousElementSibling;
+ let aligned = Math.abs(item1.getBoundingClientRect().top - item2.getBoundingClientRect().top) <= 1;
+ assert_equals(aligned, applied, "vertical baseline suppressed");
+
+ // To verify the containment box establishes an independent formatting
+ // context, we test position the clear: left div with respect to the
+ // float: left div.
+ let floatLeft = wrappers[2].previousElementSibling;
+ let clearLeft = wrappers[2].firstElementChild;
+ let clearNextToFloat = Math.abs(floatLeft.getBoundingClientRect().top - clearLeft.getBoundingClientRect().top) <= 1;
+ assert_equals(clearNextToFloat, applied, "independent formatting context (floats)");
+
+ // In addition, we verify that the margin inside the containment box
+ // are not collapsed.
+ let IFCWithMargin = wrappers[3];
+ let childWithMargin = IFCWithMargin.firstElementChild;
+ let marginCollapsed = Math.abs(IFCWithMargin.getBoundingClientRect().height - childWithMargin.getBoundingClientRect().height) <= 1;
+ assert_equals(!marginCollapsed, applied, "independent formatting context (margins collapsing)");
+ }
+
+ function setContain(id, value) {
+ let container = document.getElementById(id);
+ Array.from(container.getElementsByClassName("wrapper"))
+ .forEach(element => element.style.contain = value);
+ }
+
+ promise_test(async () => {
+ await document.fonts.ready;
+ verifyLayoutContainment("none", /* applied=*/false);
+ }, "contain: none");
+
+ promise_test(async () => {
+ await document.fonts.ready;
+ verifyLayoutContainment("layout", /* applied=*/true);
+ }, "contain: layout");
+
+ promise_test(async () => {
+ await document.fonts.ready;
+ setContain("none_to_layout", "layout");
+ verifyLayoutContainment("none_to_layout", /* applied=*/true)
+ }, "switching contain from none to layout");
+
+ promise_test(async () => {
+ await document.fonts.ready;
+ setContain("layout_to_none", "none");
+ verifyLayoutContainment("layout_to_none", /* applied=*/false);
+ }, "switching contain from layout to none");
+ </script>
+</body>