diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 19:33:14 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 19:33:14 +0000 |
commit | 36d22d82aa202bb199967e9512281e9a53db42c9 (patch) | |
tree | 105e8c98ddea1c1e4784a60a5a6410fa416be2de /testing/web-platform/tests/css/selectors/focus-within-009.html | |
parent | Initial commit. (diff) | |
download | firefox-esr-36d22d82aa202bb199967e9512281e9a53db42c9.tar.xz firefox-esr-36d22d82aa202bb199967e9512281e9a53db42c9.zip |
Adding upstream version 115.7.0esr.upstream/115.7.0esrupstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'testing/web-platform/tests/css/selectors/focus-within-009.html')
-rw-r--r-- | testing/web-platform/tests/css/selectors/focus-within-009.html | 158 |
1 files changed, 158 insertions, 0 deletions
diff --git a/testing/web-platform/tests/css/selectors/focus-within-009.html b/testing/web-platform/tests/css/selectors/focus-within-009.html new file mode 100644 index 0000000000..c8d47d2df0 --- /dev/null +++ b/testing/web-platform/tests/css/selectors/focus-within-009.html @@ -0,0 +1,158 @@ +<!DOCTYPE html> +<html id="html"> +<head> + <meta charset="utf-8"> + <title>Selectors Level 4: focus-within</title> + <link rel="author" title="Benjamin Poulain" href="mailto:bpoulain@apple.com"> + <link rel="author" title="Manuel Rego Casasnovas" href="mailto:rego@igalia.com"> + <link rel="help" href="https://drafts.csswg.org/selectors-4/#focus-within-pseudo"> + <meta name="assert" content="Checks the basic features of the ':focus-within' pseudo class."> + <script src="/resources/testharness.js"></script> + <script src="/resources/testharnessreport.js"></script> + <style> + * { + background-color: white; + } + :focus-within { + background-color: rgb(1, 2, 3); + } + </style> +</head> +<body id="body"> + <div id="test"> + <div id="container1"> + <div id="sibling1"></div> + <div id="sibling2"> + <input id="target1"> + </div> + <div id="sibling3"></div> + </div> + <div id="container2"> + <div id="sibling4"></div> + <div id="sibling5"> + <textarea id="target2"></textarea> + </div> + <div id="sibling6"></div> + </div> + </div> + <div id=log></div> + + <script> + "use strict"; + + function elementsStyledWithFocusWithinSelector() { + let elements = []; + for (let element of document.querySelectorAll("*")) { + if (getComputedStyle(element).backgroundColor === 'rgb(1, 2, 3)') { + elements.push(element.id); + } + } + return elements; + } + + function elementsMatchingFocusWithinSelector() { + let elements = []; + for (let element of document.querySelectorAll(":focus-within")) { + elements.push(element.id); + } + return elements; + } + + test( + function() { + assert_array_equals(elementsStyledWithFocusWithinSelector(), []); + assert_array_equals(elementsMatchingFocusWithinSelector(), []); + }, "Initial State"); + + var container1 = document.getElementById("container1"); + var container2 = document.getElementById("container2"); + var target1 = document.getElementById("target1"); + var target2 = document.getElementById("target2"); + + test( + function() { + target1.focus(); + assert_array_equals(elementsStyledWithFocusWithinSelector(), ["html", "body", "test", "container1", "sibling2", "target1"]); + assert_array_equals(elementsMatchingFocusWithinSelector(), ["html", "body", "test", "container1", "sibling2", "target1"]); + }, "Focus 'target1'"); + + test( + function() { + target2.focus(); + assert_array_equals(elementsStyledWithFocusWithinSelector(), ["html", "body", "test", "container2", "sibling5", "target2"]); + assert_array_equals(elementsMatchingFocusWithinSelector(), ["html", "body", "test", "container2", "sibling5", "target2"]); + }, "Focus 'target2'"); + + test( + function() { + target1.focus(); + assert_array_equals(elementsStyledWithFocusWithinSelector(), ["html", "body", "test", "container1", "sibling2", "target1"]); + assert_array_equals(elementsMatchingFocusWithinSelector(), ["html", "body", "test", "container1", "sibling2", "target1"]); + }, "Focus 'target1' again"); + + test( + function() { + target2.focus(); + assert_array_equals(elementsStyledWithFocusWithinSelector(), ["html", "body", "test", "container2", "sibling5", "target2"]); + assert_array_equals(elementsMatchingFocusWithinSelector(), ["html", "body", "test", "container2", "sibling5", "target2"]); + }, "Focus 'target2' again"); + + test( + function() { + target1.focus(); + assert_array_equals(elementsStyledWithFocusWithinSelector(), ["html", "body", "test", "container1", "sibling2", "target1"]); + assert_array_equals(elementsMatchingFocusWithinSelector(), ["html", "body", "test", "container1", "sibling2", "target1"]); + }, "Focus 'target1' once again"); + + test( + function() { + container1.parentElement.removeChild(container1); + assert_array_equals(elementsStyledWithFocusWithinSelector(), []); + assert_array_equals(elementsMatchingFocusWithinSelector(), []); + assert_equals(container1.querySelectorAll(":focus-within").length, 0); + assert_false(target1.matches(":focus")); + assert_false(target2.matches(":focus")); + }, "Detach 'container1' from the document"); + + test( + function() { + target1.focus(); + assert_array_equals(elementsStyledWithFocusWithinSelector(), []); + assert_array_equals(elementsMatchingFocusWithinSelector(), []); + assert_equals(container1.querySelectorAll(":focus-within").length, 0); + assert_false(target1.matches(":focus")); + assert_false(target2.matches(":focus")); + }, "Try to focus 'target1'"); + + test( + function() { + target2.focus(); + assert_array_equals(elementsStyledWithFocusWithinSelector(), ["html", "body", "test", "container2", "sibling5", "target2"]); + assert_array_equals(elementsMatchingFocusWithinSelector(), ["html", "body", "test", "container2", "sibling5", "target2"]); + }, "Focus 'target2' once again"); + + test( + function() { + container2.appendChild(container1); + assert_array_equals(elementsStyledWithFocusWithinSelector(), ["html", "body", "test", "container2", "sibling5", "target2"]); + assert_array_equals(elementsMatchingFocusWithinSelector(), ["html", "body", "test", "container2", "sibling5", "target2"]); + }, "Attach 'container1' in 'container2'"); + + test( + function() { + target1.focus(); + assert_array_equals(elementsStyledWithFocusWithinSelector(), ["html", "body", "test", "container2", "container1", "sibling2", "target1"]); + assert_array_equals(elementsMatchingFocusWithinSelector(), ["html", "body", "test", "container2", "container1", "sibling2", "target1"]); + }, "Focus 'target1' for the last time"); + + test( + function() { + container2.appendChild(target1); + assert_array_equals(elementsStyledWithFocusWithinSelector(), []); + assert_array_equals(elementsMatchingFocusWithinSelector(), []); + assert_false(target1.matches(":focus")); + assert_false(target2.matches(":focus")); + }, "Move 'target1' in 'container2'"); + </script> +</body> +</html> |