From 8b2f9074073a64cbf9b14b8f8a37fa1022f03b4d Mon Sep 17 00:00:00 2001 From: Dominic Farolino Date: Wed, 16 Oct 2024 01:29:04 -0700 Subject: [PATCH] DOM: Make moveBefore() throw for all pre-move validity checks This CL makes moveBefore() match the spec PR [1], with regard to the agreed-upon error-throwing behavior for all pre-moving validity and hierarchy conditions. This means throwing an exception for: - Disconnected parent destination or move target - Cross-document Nodes - Destination parent that is not an Element node - Move target that is not an Element or character data [1]: /~https://github.com/whatwg/dom/pull/1307 R=nrosenthal@chromium.org Bug: 40150299 Change-Id: Iaf5243fb2762e21ede068a222600bd158859fe92 --- .../moveBefore/tentative/Node-moveBefore.html | 401 +++++++----------- .../css-transition-cross-document.html | 10 +- ...s-transition-to-disconnected-document.html | 10 +- .../tentative/relevant-mutations.html | 2 +- .../tentative/throws-exception.html | 20 + 5 files changed, 198 insertions(+), 245 deletions(-) create mode 100644 dom/nodes/moveBefore/tentative/throws-exception.html diff --git a/dom/nodes/moveBefore/tentative/Node-moveBefore.html b/dom/nodes/moveBefore/tentative/Node-moveBefore.html index 8a1db6f93bcf80..b85d312c9e9c52 100644 --- a/dom/nodes/moveBefore/tentative/Node-moveBefore.html +++ b/dom/nodes/moveBefore/tentative/Node-moveBefore.html @@ -8,7 +8,6 @@ - diff --git a/dom/nodes/moveBefore/tentative/css-transition-to-disconnected-document.html b/dom/nodes/moveBefore/tentative/css-transition-to-disconnected-document.html index 537edfe9b61702..f5f8e1ccc8d468 100644 --- a/dom/nodes/moveBefore/tentative/css-transition-to-disconnected-document.html +++ b/dom/nodes/moveBefore/tentative/css-transition-to-disconnected-document.html @@ -35,9 +35,15 @@ item.style.left = "400px"; await new Promise(resolve => item.addEventListener("transitionstart", resolve)); const doc = document.implementation.createHTMLDocument(); - doc.body.moveBefore(item, null); + + // Calling `moveBefore()` on a cross-document element undergoing a + // transition does not move the element, nor alter the transition. + assert_throws_dom("HIERARCHY_REQUEST_ERR", () => { + doc.body.moveBefore(item, null); + }); + await new Promise(resolve => requestAnimationFrame(() => resolve())); - assert_equals(item.getBoundingClientRect().x, 0); + assert_between_inclusive(item.getBoundingClientRect().x, 0, 20); }, "Moving an element with a transition to a disconnected document should reset the transitionm state"); diff --git a/dom/nodes/moveBefore/tentative/relevant-mutations.html b/dom/nodes/moveBefore/tentative/relevant-mutations.html index 95b770dbef8afe..8cf4ba668c7760 100644 --- a/dom/nodes/moveBefore/tentative/relevant-mutations.html +++ b/dom/nodes/moveBefore/tentative/relevant-mutations.html @@ -42,7 +42,7 @@ const picture = document.querySelector('picture'); const source = document.querySelector('source'); - const img = document.createElement('img'); + const img = document.body.appendChild(document.createElement('img')); img.src = '/images/red.png'; t.add_cleanup(() => { diff --git a/dom/nodes/moveBefore/tentative/throws-exception.html b/dom/nodes/moveBefore/tentative/throws-exception.html new file mode 100644 index 00000000000000..34123c72dfd1bf --- /dev/null +++ b/dom/nodes/moveBefore/tentative/throws-exception.html @@ -0,0 +1,20 @@ + +moveBefore exception conditions + + + + +
+ +