summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/css/selectors/is-where-basic.html
diff options
context:
space:
mode:
Diffstat (limited to 'testing/web-platform/tests/css/selectors/is-where-basic.html')
-rw-r--r--testing/web-platform/tests/css/selectors/is-where-basic.html41
1 files changed, 41 insertions, 0 deletions
diff --git a/testing/web-platform/tests/css/selectors/is-where-basic.html b/testing/web-platform/tests/css/selectors/is-where-basic.html
new file mode 100644
index 0000000000..8623c8b7d6
--- /dev/null
+++ b/testing/web-platform/tests/css/selectors/is-where-basic.html
@@ -0,0 +1,41 @@
+<!DOCTYPE html>
+<title>Basic :is/:where matching behavior</title>
+<script src="/resources/testharness.js"></script>
+<script src="/resources/testharnessreport.js"></script>
+<link rel="help" href="https://drafts.csswg.org/selectors-4/#matches">
+
+<main id=main>
+ <div id=a><div id=d></div></div>
+ <div id=b><div id=e></div></div>
+ <div id=c><div id=f></div></div>
+</main>
+
+<script>
+ function formatElements(elements) {
+ return elements.map(e => e.id).sort().join();
+ }
+
+ // Test that |selector| returns the given elements in #main.
+ function test_selector(selector, expected) {
+ test(function() {
+ let actual = Array.from(main.querySelectorAll(selector));
+ assert_equals(formatElements(actual), formatElements(expected));
+ }, `${selector} matches expected elements`);
+ }
+
+ test_selector(':is()', []);
+ test_selector(':is(#a)', [a]);
+ test_selector(':is(#a, #f)', [a, f]);
+ test_selector(':is(#a, #c) :where(#a #d, #c #f)', [d, f]);
+ test_selector('#c > :is(#c > #f)', [f]);
+ test_selector('#c > :is(#b > #f)', []);
+ test_selector('#a div:is(#d)', [d]);
+ test_selector(':is(div) > div', [d, e, f]);
+ test_selector(':is(*) > div', [a, b, c, d, e, f]);
+ test_selector(':is(*) div', [a, b, c, d, e, f]);
+ test_selector('div > :where(#e, #f)', [e, f]);
+ test_selector('div > :where(*)', [d, e, f]);
+ test_selector(':is(*) > :where(*)', [a, b, c, d, e, f]);
+ test_selector(':is(#a + #b) + :is(#c)', [c]);
+ test_selector(':is(#a, #b) + div', [b, c]);
+</script>