Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

DOM: Added a few batch-insertion scenarios that are incompatible across engines #44658

Merged
merged 31 commits into from
Feb 29, 2024

Conversation

noamr
Copy link
Contributor

@noamr noamr commented Feb 19, 2024

Repurposing #15264 to clean up the mess around deferred insertion steps.
Made the tests tentative, and cleaned up a few of the results.

Currently the expected results match Firefox.
They're marked tentative, and we can reason about the differences and fix the tests when we come to a conclusion.

Together with @annevk and @nox

@wpt-pr-bot wpt-pr-bot added the dom label Feb 19, 2024
@wpt-pr-bot wpt-pr-bot requested review from annevk and jdm February 19, 2024 20:53
@noamr noamr changed the title Weird insertion DOM: Added a few batch-insertion scenarios that are incompatible across engines Feb 19, 2024
@noamr noamr requested a review from domfarolino February 19, 2024 21:02
Copy link
Member

@domfarolino domfarolino left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Mostly small stuff so far about test grouping and making the expectations more clear by using string/state variables instead of booleans that are equal to foo === null. Separately, I think it would be good to add test descriptions to each of the test(() => {}, "<description here>")s, just to make it more clear what each is asserting, and maybe add a little information about why.

const iframe = document.createElement("iframe");

test(() => {
iframe.src = "data:text/html,";
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We don't need this right?

test(() => {
window.state = "script not run yet";
window.iframe = document.createElement("iframe");
iframe.src = "data:text/html,"
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Same, is this important, or will the about:blank Document suffice?


assert_array_equals(happened, []);
document.body.appendChild(df);
assert_array_equals(happened, [true]);
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It depends on what we mean by "insertion effects". I don't think the goal is to eradicate all insertion side effects from taking place during DOM mutations. I think the goal is to eradicate all synchronous script-execution from the DOM mutation flow, to be queued until after all DOM mutations are done. The mutations themselves may have script-observable side effects by definition, which can be observed by the time earlier-inserted scripts run. (Although I'm not sure what we want to do about that in this case specifically).

@domfarolino
Copy link
Member

(I've added a few changes, test description updates, and test coalescing in response to this and my prior review; feel free to check them out).

nox and others added 17 commits February 29, 2024 17:29
The test follows the spec, but the spec is followed only by Safari.
This test too follows the spec, but only Safari defines the custom element
before inserting one in the document, other browsers upgrade the custom-element
at the time of the customElements.define call because it is already in tree.
This test once again follows the spec, but only Safari executes it correctly,
with no form owner set on the button at the time of the execution of the
script.
Safari and Chrome pass that test, Firefox fails it.
@domfarolino
Copy link
Member

I've rebased this on top of master and moved the tests to the insertion-removing-steps folder where other tests related to this have been landing. I think this is good to merge now.

@domfarolino domfarolino merged commit 870bb35 into master Feb 29, 2024
19 checks passed
@domfarolino domfarolino deleted the weird-insertion branch February 29, 2024 23:16
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

Successfully merging this pull request may close these issues.

6 participants