diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-19 01:13:27 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-19 01:13:27 +0000 |
commit | 40a355a42d4a9444dc753c04c6608dade2f06a23 (patch) | |
tree | 871fc667d2de662f171103ce5ec067014ef85e61 /testing/web-platform/tests/selection/selection-range-after-editinghost-removed.html | |
parent | Adding upstream version 124.0.1. (diff) | |
download | firefox-upstream/125.0.1.tar.xz firefox-upstream/125.0.1.zip |
Adding upstream version 125.0.1.upstream/125.0.1
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'testing/web-platform/tests/selection/selection-range-after-editinghost-removed.html')
-rw-r--r-- | testing/web-platform/tests/selection/selection-range-after-editinghost-removed.html | 69 |
1 files changed, 69 insertions, 0 deletions
diff --git a/testing/web-platform/tests/selection/selection-range-after-editinghost-removed.html b/testing/web-platform/tests/selection/selection-range-after-editinghost-removed.html new file mode 100644 index 0000000000..921903062a --- /dev/null +++ b/testing/web-platform/tests/selection/selection-range-after-editinghost-removed.html @@ -0,0 +1,69 @@ +<!doctype html> +<html> +<head> +<meta charset="utf-8"> +<title>Selection range in an editing host after the host is removed</title> +<script src=/resources/testharness.js></script> +<script src=/resources/testharnessreport.js></script> +<script> +"use strict"; + +addEventListener("load", () => { + const container = document.querySelector("div"); + test(() => { + const editingHost = document.createElement("div"); + editingHost.contentEditable = true; + editingHost.innerHTML = "ABC<br>"; + container.appendChild(editingHost); + editingHost.focus(); + getSelection().collapse(editingHost, 0); + editingHost.remove(); + assert_equals(getSelection().focusNode, container, "focusNode should be the container"); + assert_equals(getSelection().focusOffset, 0, "focusOffset should be 0"); + }, "Selection range in an editing host should be collapsed where the host was after it's removed"); + + test(() => { + const wrapper = document.createElement("div"); + wrapper.id = "wrapper"; + const editingHost = document.createElement("div"); + editingHost.contentEditable = true; + editingHost.innerHTML = "ABC<br>"; + wrapper.appendChild(editingHost); + container.appendChild(wrapper); + editingHost.focus(); + getSelection().collapse(editingHost, 0); + wrapper.remove(); + assert_equals(getSelection().focusNode, container, "focusNode should be the container"); + assert_equals(getSelection().focusOffset, 0, "focusOffset should be 0"); + }, "Selection range in an editing host should be collapsed where the host was after its parent is removed"); + + test(() => { + const editingHost = document.createElement("div"); + editingHost.contentEditable = true; + editingHost.innerHTML = "ABC<br>"; + container.appendChild(editingHost); + editingHost.focus(); + getSelection().collapse(editingHost, 0); + editingHost.replaceWith(editingHost); + assert_equals(getSelection().focusNode, container, "focusNode should be the container"); + assert_equals(getSelection().focusOffset, 0, "focusOffset should be 0"); + editingHost.remove(); + }, "Selection range in an editing host should be collapsed where the host was after it's replaced with itself (.replaceWith)"); + + test(() => { + const editingHost = document.createElement("div"); + editingHost.contentEditable = true; + editingHost.innerHTML = "ABC<br>"; + container.appendChild(editingHost); + editingHost.focus(); + getSelection().collapse(editingHost, 0); + container.replaceChild(editingHost, editingHost); + assert_equals(getSelection().focusNode, container, "focusNode should be the container"); + assert_equals(getSelection().focusOffset, 0, "focusOffset should be 0"); + editingHost.remove(); + }, "Selection range in an editing host should be collapsed where the host was after it's replaced with itself (.replaceChild)"); +}, {once: true}); +</script> +</head> +<body><div id="container"></div></body> +</html> |