Bug 226808

Summary: Relax "parent must be an HTMLElement" restriction in outerHTML setter
Product: WebKit Reporter: zyscoder <zyscoder>
Component: WebKit Misc.Assignee: Chris Dumez <cdumez>
Status: RESOLVED FIXED    
Severity: Normal CC: cdumez, cmarcelo, darin, dbarton, esprehn+autocc, ews-watchlist, fred.wang, ggaren, kangil.han, rniwa, sam, webkit-bug-importer, wenson_hsieh
Priority: P2 Keywords: InRadar
Version: WebKit Local Build   
Hardware: Unspecified   
OS: Linux   
URL: https://github.com/w3c/DOM-Parsing/issues/70
See Also: https://bugs.webkit.org/show_bug.cgi?id=52686
http://www.w3.org/Bugs/Public/show_bug.cgi?id=12584
https://bugs.webkit.org/show_bug.cgi?id=249737
Attachments:
Description Flags
WIP Patch
none
Patch
none
Patch
none
Patch
none
Patch
none
Patch none

zyscoder@gmail.com
Reported 2021-06-09 02:15:21 PDT
Steps to reproduce: (1) Open a tab and navigate to https://www.cdc.gov/; (2) Run the following code in the Console of Devtools: ``` document.getElementById('sas').outerHTML = "any_str"; ``` (3) Then this code would throw a NoModificationAllowedError exception. Actual results: this code would throw a NoModificationAllowedError exception: `NoModificationAllowedError: The object can not be modified.` Expected results: In my test, both Chrome and Firefox would not throw any exceptions. https://w3c.github.io/DOM-Parsing/#outerhtml says `If parent is a Document, throw a "NoModificationAllowedError" DOMException.` Since the parent node is not a Document, maybe something wrong with the outerHTML setter.
Attachments
WIP Patch (2.09 KB, patch)
2021-06-12 17:58 PDT, Chris Dumez
no flags
Patch (6.54 KB, patch)
2021-06-12 19:37 PDT, Chris Dumez
no flags
Patch (15.65 KB, patch)
2021-06-12 21:47 PDT, Chris Dumez
no flags
Patch (16.06 KB, patch)
2021-06-13 10:32 PDT, Chris Dumez
no flags
Patch (16.25 KB, patch)
2021-06-13 10:49 PDT, Chris Dumez
no flags
Patch (16.25 KB, patch)
2021-06-13 11:49 PDT, Chris Dumez
no flags
Chris Dumez
Comment 1 2021-06-12 17:42:54 PDT
Parent of document.getElementById('sas') is an <svg> element. We have code throwing a NoModificationAllowedError if the parent is NOT an HTML element.
Chris Dumez
Comment 2 2021-06-12 17:58:33 PDT
Created attachment 431266 [details] WIP Patch
Chris Dumez
Comment 3 2021-06-12 18:32:45 PDT
Looks like WPT testing is a bit lacking in this area. No test result changes in the domparsing/ folder.
Chris Dumez
Comment 4 2021-06-12 19:31:44 PDT
There is also quite a bit of disagreement between the different browsers here. Gecko mostly matches the specification but our behavior is mostly aligned with Blink. I'll make the change to allow non-HTMLElement parents though since Firefox & Blink agree on that at least.
Chris Dumez
Comment 5 2021-06-12 19:37:21 PDT
Chris Dumez
Comment 6 2021-06-12 21:47:06 PDT
Ryosuke Niwa
Comment 7 2021-06-13 02:13:28 PDT
Comment on attachment 431269 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=431269&action=review > Source/WebCore/ChangeLog:20 > + - WebKit & Blink have some Text node merging logic that is not present in the specification > + and which Gecko doesn't implement. Could you file a spec issue for this? It seems like Gecko should implement this behavior as well.
Chris Dumez
Comment 8 2021-06-13 10:32:28 PDT
Chris Dumez
Comment 9 2021-06-13 10:40:14 PDT
(In reply to Ryosuke Niwa from comment #7) > Comment on attachment 431269 [details] > Patch > > View in context: > https://bugs.webkit.org/attachment.cgi?id=431269&action=review > > > Source/WebCore/ChangeLog:20 > > + - WebKit & Blink have some Text node merging logic that is not present in the specification > > + and which Gecko doesn't implement. > > Could you file a spec issue for this? It seems like Gecko should implement > this behavior as well. Sure thing: https://github.com/w3c/DOM-Parsing/issues/70
Darin Adler
Comment 10 2021-06-13 10:41:32 PDT
Comment on attachment 431269 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=431269&action=review > Source/WebCore/dom/Element.cpp:3252 > + // The specification allows setting outerHTML on an Element whose parent is a DocumentFragment and Gecko supports this. > + // However, as of June 2021, Blink matches our behavior and throws a NoModificationAllowedError for non-Element parents. Can we apply gentle pressure to resolve this so the browsers, specification, and WPT all agree? > Source/WebCore/dom/Element.cpp:3255 > + return Exception { NoModificationAllowedError, "Cannot set outerHTML on element because its parent is not an Element" }; Peculiar wording when called on something with no parent. > Source/WebCore/dom/Element.cpp:3268 > + // The following is not part of the specification but matches Blink's behavior as of June 2021. Pretty sure this is just because of our "shared heritage" since Blink is a fork of WebKit.
Darin Adler
Comment 11 2021-06-13 10:42:42 PDT
I would have titled this bug something more like this: Relax "parent must be HTMLElement" restriction on outerHTML I know the goal is to align with other browsers and the specification, but that part of the story is complicated since the two other major browsers don’t match each other and this doesn’t seem to be covered in WPT.
Chris Dumez
Comment 12 2021-06-13 10:44:58 PDT
(In reply to Darin Adler from comment #10) > Comment on attachment 431269 [details] > Patch > > View in context: > https://bugs.webkit.org/attachment.cgi?id=431269&action=review > > > Source/WebCore/dom/Element.cpp:3252 > > + // The specification allows setting outerHTML on an Element whose parent is a DocumentFragment and Gecko supports this. > > + // However, as of June 2021, Blink matches our behavior and throws a NoModificationAllowedError for non-Element parents. > > Can we apply gentle pressure to resolve this so the browsers, specification, > and WPT all agree? As mentioned earlier, WPT testing seems to be lacking here and I did file an issue against the spec to start a discussion. > > > Source/WebCore/dom/Element.cpp:3255 > > + return Exception { NoModificationAllowedError, "Cannot set outerHTML on element because its parent is not an Element" }; > > Peculiar wording when called on something with no parent. I personally felt that the "parent is not an Element" statement was true if the parent was null :) I didn't think it was worth it to add an extra if check just to provide better logging. But given your comment, I'll add it. > > > Source/WebCore/dom/Element.cpp:3268 > > + // The following is not part of the specification but matches Blink's behavior as of June 2021. > > Pretty sure this is just because of our "shared heritage" since Blink is a > fork of WebKit. That may well be but then again we were not totally matching Blink either and we do count as separate major engines nowadays when it comes to spec'ing.
Chris Dumez
Comment 13 2021-06-13 10:45:33 PDT
(In reply to Darin Adler from comment #11) > I would have titled this bug something more like this: > > Relax "parent must be HTMLElement" restriction on outerHTML > > I know the goal is to align with other browsers and the specification, but > that part of the story is complicated since the two other major browsers > don’t match each other and this doesn’t seem to be covered in WPT. Right, I did not file that bug and I should have re-titled it when I found out what the actual issue was. It's not too late though so I'll fix.
Chris Dumez
Comment 14 2021-06-13 10:49:36 PDT
Darin Adler
Comment 15 2021-06-13 10:52:34 PDT
(In reply to Chris Dumez from comment #12) > (In reply to Darin Adler from comment #10) > > Pretty sure this is just because of our "shared heritage" since Blink is a > > fork of WebKit. > > That may well be but then again we were not totally matching Blink either > and we do count as separate major engines nowadays when it comes to spec'ing. Actually looks like this merging was added by an engineer working on Chrome: https://bugs.webkit.org/show_bug.cgi?id=52686
Chris Dumez
Comment 16 2021-06-13 10:56:03 PDT
(In reply to Darin Adler from comment #15) > (In reply to Chris Dumez from comment #12) > > (In reply to Darin Adler from comment #10) > > > Pretty sure this is just because of our "shared heritage" since Blink is a > > > fork of WebKit. > > > > That may well be but then again we were not totally matching Blink either > > and we do count as separate major engines nowadays when it comes to spec'ing. > > Actually looks like this merging was added by an engineer working on Chrome: > > https://bugs.webkit.org/show_bug.cgi?id=52686 Thanks, this is useful information indeed and I have added it to my spec bug report.
Darin Adler
Comment 17 2021-06-13 10:58:33 PDT
(In reply to Chris Dumez from comment #12) > I personally felt that the "parent is not an Element" statement was true if > the parent was null :) I didn't think it was worth it to add an extra if > check just to provide better logging. But given your comment, I'll add it. I think we could also word something so it doesn’t seem strange, without adding a second message. To me saying "parent is not an Element" implied that there is a parent and it’s not an Element. Could have said "because it doesn't have a parent that is an Element".
Chris Dumez
Comment 18 2021-06-13 11:00:59 PDT
(In reply to Darin Adler from comment #17) > (In reply to Chris Dumez from comment #12) > > I personally felt that the "parent is not an Element" statement was true if > > the parent was null :) I didn't think it was worth it to add an extra if > > check just to provide better logging. But given your comment, I'll add it. > > I think we could also word something so it doesn’t seem strange, without > adding a second message. To me saying "parent is not an Element" implied > that there is a parent and it’s not an Element. Could have said "because it > doesn't have a parent that is an Element". The extra branch is not in the hot code path so I figure we might as well provide a more accurate error message. This is what I did in the latest iteration.
Chris Dumez
Comment 19 2021-06-13 11:49:38 PDT
EWS
Comment 20 2021-06-13 12:16:54 PDT
Committed r278821 (238774@main): <https://commits.webkit.org/238774@main> All reviewed patches have been landed. Closing bug and clearing flags on attachment 431284 [details].
Radar WebKit Bug Importer
Comment 21 2021-06-13 12:17:16 PDT
Note You need to log in before you can comment on or make changes to this bug.