Bug 160728

Summary: Optimization in Node::appendChild() is not spec-compliant
Product: WebKit Reporter: Chris Dumez <cdumez>
Component: DOMAssignee: Chris Dumez <cdumez>
Status: RESOLVED FIXED    
Severity: Normal CC: cdumez, commit-queue, esprehn+autocc, kangil.han, rniwa
Priority: P2 Keywords: WebExposed
Version: WebKit Nightly Build   
Hardware: Unspecified   
OS: Unspecified   
Attachments:
Description Flags
Patch
none
Patch none

Chris Dumez
Reported 2016-08-09 19:54:36 PDT
We have an optimization in Node::appendChild() that avoid doing any work if the node to be appended is already the last child. This optimization is not spec-compliant: - https://dom.spec.whatwg.org/#dom-node-appendchild The issue is that this is observable via DOM Mutation observers / listeners or DOM ranges.
Attachments
Patch (15.96 KB, patch)
2016-08-09 20:16 PDT, Chris Dumez
no flags
Patch (15.97 KB, patch)
2016-08-09 20:20 PDT, Chris Dumez
no flags
Chris Dumez
Comment 1 2016-08-09 20:16:47 PDT
Ryosuke Niwa
Comment 2 2016-08-09 20:18:55 PDT
Comment on attachment 285709 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=285709&action=review > Source/WebCore/ChangeLog:20 > + common to call parent.appendChild(parent.lastChild). It turns out to > + regress the performance of things we care about though, we could fall > + back to do the optimization only when it is not observable. You mean if it turns out to regress? If we know for sure that this regresses the perf, we need to change the spec instead.
Chris Dumez
Comment 3 2016-08-09 20:20:05 PDT
Chris Dumez
Comment 4 2016-08-09 20:20:36 PDT
(In reply to comment #2) > Comment on attachment 285709 [details] > Patch > > View in context: > https://bugs.webkit.org/attachment.cgi?id=285709&action=review > > > Source/WebCore/ChangeLog:20 > > + common to call parent.appendChild(parent.lastChild). It turns out to > > + regress the performance of things we care about though, we could fall > > + back to do the optimization only when it is not observable. > > You mean if it turns out to regress? If we know for sure that this > regresses the perf, we need to change the spec instead. *If* it turns out. I indeed forgot a word :) This is fixed in the latest iteration.
Ryosuke Niwa
Comment 5 2016-08-09 20:27:11 PDT
Comment on attachment 285710 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=285710&action=review > LayoutTests/fast/dom/Node/appendChild-no-op-mutationobserver-expected.txt:1 > +Tests that calls of appendChild() lead to mutation events even if they are no-ops. In the future, we should probably write these tests using testharness.js so that we can upstream to W3C test suite.
WebKit Commit Bot
Comment 6 2016-08-09 20:49:27 PDT
Comment on attachment 285710 [details] Patch Clearing flags on attachment: 285710 Committed r204322: <http://trac.webkit.org/changeset/204322>
WebKit Commit Bot
Comment 7 2016-08-09 20:49:31 PDT
All reviewed patches have been landed. Closing bug.
Note You need to log in before you can comment on or make changes to this bug.