Bug 14968

Summary: document.open() erroneously returns void instead of the new Document
Product: WebKit Reporter: Darin Fisher (:fishd, Google) <fishd>
Component: DOMAssignee: Alexey Proskuryakov <ap>
Status: RESOLVED FIXED    
Severity: Normal CC: ap
Priority: P2    
Version: 523.x (Safari 3)   
Hardware: All   
OS: All   
Attachments:
Description Flags
test case
none
test case (as originally reported)
none
proposed fix eric: review+

Darin Fisher (:fishd, Google)
Reported 2007-08-14 15:40:25 PDT
document.open() erroneously returns void instead of the new Document in other browsers (IE, FF, and Opera), document.open() returns the new Document, and you can write into it to generate content. example: var d = document.open("text/html", "replace"); d.write("foo"); d.close(); apparently, the html5 spec does not describe this behavior: http://www.whatwg.org/specs/web-apps/current-work/#htmldocument mozilla defines the form of document.open that returns a new document here (as a Netscape extension to the DOM): http://lxr.mozilla.org/seamonkey/source/dom/public/idl/html/nsIDOMNSHTMLDocument.idl
Attachments
test case (193 bytes, text/html)
2007-08-14 21:52 PDT, Alexey Proskuryakov
no flags
test case (as originally reported) (327 bytes, text/html)
2007-08-15 20:27 PDT, Darin Fisher (:fishd, Google)
no flags
proposed fix (3.67 KB, patch)
2008-11-29 01:13 PST, Alexey Proskuryakov
eric: review+
Alexey Proskuryakov
Comment 1 2007-08-14 21:52:32 PDT
Created attachment 15975 [details] test case This test works in Firefox 2, but not in Opera. Haven't tried with IE yet.
Alexey Proskuryakov
Comment 2 2007-08-15 03:12:44 PDT
This test fails in IE, too.
Darin Fisher (:fishd, Google)
Comment 3 2007-08-15 20:23:55 PDT
Alexey, your test case does not match the one in comment #0. If you try that you should see that FF2, IE6 and Opera9 all generate a page with the text "foo"
Darin Fisher (:fishd, Google)
Comment 4 2007-08-15 20:27:14 PDT
Created attachment 15992 [details] test case (as originally reported)
Alexey Proskuryakov
Comment 5 2007-08-15 21:54:59 PDT
(In reply to comment #3) > Alexey, your test case does not match the one in comment #0. Do you mean that the second parameter is true instead of "replace" in my test case? Indeed, I mistakenly used he linked Mozilla IDL to check the type - but it doesn't matter anyway, as the behavior WRT this issue is the same AFAICT. It seems that the main difference between our test cases is that the code runs during parsing in the first one, and after parsing has finished in the second one.
Darin Fisher (:fishd, Google)
Comment 6 2007-08-17 08:49:33 PDT
Ah, yes... It is interesting that the behavior varies depending on whether or not we are done parsing the main document.
Alexey Proskuryakov
Comment 7 2008-11-29 01:13:12 PST
Created attachment 25588 [details] proposed fix Note that parameters are currently ignored (except for checking their number, and forwarding to DOMWindow if necessary).
Eric Seidel (no email)
Comment 8 2008-11-29 01:21:20 PST
Comment on attachment 25588 [details] proposed fix This would ideally be one of the fancy new js-only tests... then again, ideally it would be easier (and more documented) to write a newer-fancy-js-only test. Sad that this has to be custom. But glad to see this fix!
Alexey Proskuryakov
Comment 9 2008-11-29 01:49:30 PST
(In reply to comment #8) > This would ideally be one of the fancy new js-only tests... Are you talking about js-test-pre.js and friends? I can think of many minor shortcomings, but not a single benefit - these tests are slower because of the need to load external subresources, they cannot be easily copied to another directory, they often need to be written in roundabout ways to convert a behavior check into a simple shouldBe(). Of course, fast/js is a special case, because the intention is to make those work from pure JS environment eventually. Thanks for review!
Alexey Proskuryakov
Comment 10 2008-11-29 10:29:32 PST
Committed revision 38842.
Note You need to log in before you can comment on or make changes to this bug.