summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/selection/anonymous
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 19:33:14 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 19:33:14 +0000
commit36d22d82aa202bb199967e9512281e9a53db42c9 (patch)
tree105e8c98ddea1c1e4784a60a5a6410fa416be2de /testing/web-platform/tests/selection/anonymous
parentInitial commit. (diff)
downloadfirefox-esr-36d22d82aa202bb199967e9512281e9a53db42c9.tar.xz
firefox-esr-36d22d82aa202bb199967e9512281e9a53db42c9.zip
Adding upstream version 115.7.0esr.upstream/115.7.0esr
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'testing/web-platform/tests/selection/anonymous')
-rw-r--r--testing/web-platform/tests/selection/anonymous/details-ancestor.html40
-rw-r--r--testing/web-platform/tests/selection/anonymous/details-mutate.html38
2 files changed, 78 insertions, 0 deletions
diff --git a/testing/web-platform/tests/selection/anonymous/details-ancestor.html b/testing/web-platform/tests/selection/anonymous/details-ancestor.html
new file mode 100644
index 0000000000..b0adfa6890
--- /dev/null
+++ b/testing/web-platform/tests/selection/anonymous/details-ancestor.html
@@ -0,0 +1,40 @@
+<!DOCTYPE html>
+<meta charset="utf-8">
+<title>Selecting internal node</title>
+<script src=/resources/testharness.js></script>
+<script src=/resources/testharnessreport.js></script>
+<script src="/resources/testdriver.js"></script>
+<script src="/resources/testdriver-vendor.js"></script>
+<script src="/resources/testdriver-actions.js"></script>
+<link rel="stylesheet" href="/fonts/ahem.css">
+<style>
+ details {
+ font: 16px/1 Ahem;
+ }
+</style>
+<details id="details"></details>
+<script>
+promise_test(async () => {
+ await new test_driver.Actions()
+ .pointerMove(5, 5, {origin: details})
+ .pointerDown()
+ .pointerMove(50, 50)
+ .pointerUp()
+ .send();
+ const selection = getSelection();
+
+ if (selection.anchorNode === null) {
+ // <details> is not selectable, which is acceptable
+ return;
+ }
+
+ // Gecko throws when accessing any property from DOM-invisible node
+ // so check we can access something
+ assert_equals(selection.anchorNode.constructor.name, "HTMLDetailsElement");
+ assert_equals(selection.anchorOffset, 0);
+ // Gecko limits the selection inside <details> while Blink does not
+ // so check something general
+ assert_equals(selection.focusNode.nodeType, Node.ELEMENT_NODE);
+ assert_equals(selection.focusOffset, 0);
+}, "Selecting the default summary of <details> should report a DOM-visible ancestor");
+</script>
diff --git a/testing/web-platform/tests/selection/anonymous/details-mutate.html b/testing/web-platform/tests/selection/anonymous/details-mutate.html
new file mode 100644
index 0000000000..3cd5475112
--- /dev/null
+++ b/testing/web-platform/tests/selection/anonymous/details-mutate.html
@@ -0,0 +1,38 @@
+<!DOCTYPE html>
+<meta charset="utf-8">
+<title>Test selecting anonymous summary element inside details</title>
+<script src="/resources/testharness.js"></script>
+<script src="/resources/testharnessreport.js"></script>
+<script src="/resources/testdriver.js"></script>
+<script src="/resources/testdriver-actions.js"></script>
+<script src="/resources/testdriver-vendor.js"></script>
+<link rel="stylesheet" href="/fonts/ahem.css">
+<style>
+ details {
+ font: 16px/1 Ahem;
+ }
+</style>
+<details id="d"></details>
+<script>
+ const selection = getSelection();
+ d.addEventListener("DOMSubtreeModified", ev => {
+ window.find("cthulu", true, false);
+ selection.extend(document.body, document.body.childNodes.length);
+ });
+
+ window.onload = () => {
+ promise_test(async () => {
+ // This enables `.extend()`
+ selection.collapse(document.body);
+ // Clicking implicitly selects an anonymous summary element inside <details>
+ await new test_driver.Actions()
+ .pointerMove(0, 0, { origin: d })
+ .pointerDown()
+ .pointerUp()
+ .send();
+ // FIXME: Convert this to a crash test. Currently test_driver actions
+ // do not work within crash tests.
+ assert_true(true, "No crash");
+ }, "Manipulating selection after clicking <details> shouldn't cause a crash");
+ };
+</script>