Bug 71669

Summary: Fix wrong test results of fast/js/custom-constructors.html
Product: WebKit Reporter: Kentaro Hara <haraken>
Component: DOMAssignee: Kentaro Hara <haraken>
Status: RESOLVED FIXED    
Severity: Normal CC: abarth, dglazkov, dominicc, japhet, ojan, tkent, webkit.review.bot
Priority: P2    
Version: 528+ (Nightly build)   
Hardware: Unspecified   
OS: Unspecified   
Bug Depends on:    
Bug Blocks: 71093    
Attachments:
Description Flags
Patch
none
Patch
none
test case HTML
none
Patch none

Kentaro Hara
Reported 2011-11-07 05:03:03 PST
Some test results in custom-constructors.html are wrong: wrong: shouldBeEqualToString("new Option(undefined).innerText", ""); correct: shouldBeEqualToString("new Option(undefined).innerText", "undefined"); wrong: shouldBeEqualToString("new Option('somedata', undefined).value", "somedata"); correct: shouldBeEqualToString("new Option('somedata', undefined).value", "undefined"); According to the HTMLOptionElement spec (http://dev.w3.org/html5/spec/the-button-element.html#the-option-element), 'label' and 'value' do not have [TreatUndefinedAs=EmptyString]. Thus, a value undefined should be converted to a string "undefined", following the step 3 of the IDL conversion spec (http://dev.w3.org/2006/webapi/WebIDL/#es-DOMString).
Attachments
Patch (7.67 KB, patch)
2011-11-07 05:15 PST, Kentaro Hara
no flags
Patch (9.48 KB, patch)
2011-11-07 09:02 PST, Kentaro Hara
no flags
test case HTML (462 bytes, text/html)
2011-11-07 13:00 PST, Kentaro Hara
no flags
Patch (10.06 KB, patch)
2011-11-07 13:04 PST, Kentaro Hara
no flags
Kentaro Hara
Comment 1 2011-11-07 05:15:35 PST
WebKit Review Bot
Comment 2 2011-11-07 05:44:37 PST
Comment on attachment 113848 [details] Patch Attachment 113848 [details] did not pass chromium-ews (chromium-xvfb): Output: http://queues.webkit.org/results/10337757 New failing tests: fast/dom/element-attribute-js-null.html
Kentaro Hara
Comment 3 2011-11-07 09:02:44 PST
Ojan Vafai
Comment 4 2011-11-07 09:21:12 PST
What do IE, Gecko and Opera do? If we all match, then it might make sense for the spec to change. If WebKit's the only one with this behavior, then this patch seems right to me.
Adam Barth
Comment 5 2011-11-07 09:22:55 PST
I agree with Ojan that we should see what other browsers do to determine whether the bug is in WebKit or the spec.
Kentaro Hara
Comment 6 2011-11-07 12:55:04 PST
(In reply to comment #5) > I agree with Ojan that we should see what other browsers do to determine whether the bug is in WebKit or the spec. Thank you, Ojan and Adam! Firefox 7.0.1: new Option(undefined).text => "undefined" new Option(null).text => "null" new Option('aaa', undefined).value => "undefined" new Option('aaa', null).value => "null" o = new Option(); o.label = undefined; o.label => "undefined" o = new Option(); o.label = null; o.label => "" Opera 11.52: new Option(undefined).text => "undefined" new Option(null).text => "" new Option('aaa', undefined).value => "undefined" new Option('aaa', null).value => "" o = new Option(); o.label = undefined; o.label => "undefined" o = new Option(); o.label = null; o.label => "" Chrome 16.0.912.21 beta: new Option(undefined).text => "" new Option(null).text => "null" new Option('aaa', undefined).value => "aaa" new Option('aaa', null).value => "null" o = new Option(); o.label = undefined; o.label => "undefined" o = new Option(); o.label = null; o.label => "" The spec: new Option(undefined).text => "undefined" new Option(null).text => "null" new Option('aaa', undefined).value => "undefined" new Option('aaa', null).value => "null" o = new Option(); o.label = undefined; o.label => "undefined" o = new Option(); o.label = null; o.label => "null" I do not have an IE environment now. Could anyone try it? All are different:-) Should we follow the spec in this case?
Kentaro Hara
Comment 7 2011-11-07 13:00:18 PST
Created attachment 113916 [details] test case HTML Attached a test case. Could anyone open this HTML in IE and paste the result here?
Kentaro Hara
Comment 8 2011-11-07 13:04:37 PST
Darin Adler
Comment 9 2011-11-07 14:27:09 PST
Comment on attachment 113917 [details] Patch Looks fine. Did we double check that the other major browsers match the spec?
Kentaro Hara
Comment 10 2011-11-07 17:23:15 PST
Darin, thanks! IE: new Option(undefined).text => "" new Option(null).text => "null" new Option('aaa', undefined).value => "" new Option('aaa', null).value => "null" o = new Option(); o.label = undefined; o.label => "undefined" o = new Option(); o.label = null; o.label => "null" IE's behavior is also different from any other browsers'. With these observations, I think that following the spec makes sense.
WebKit Review Bot
Comment 11 2011-11-07 18:08:23 PST
Comment on attachment 113917 [details] Patch Clearing flags on attachment: 113917 Committed r99510: <http://trac.webkit.org/changeset/99510>
WebKit Review Bot
Comment 12 2011-11-07 18:08:28 PST
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.