-
Notifications
You must be signed in to change notification settings - Fork 2.7k
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
Change URL parsing sequence for window open steps #10683
Conversation
Previously, we would only check at the last minute. This would be buggy in the case where we create a new navigable, and then throw an exception. Instead we should be sure to throw before creating a new navigable. In addition to fixing this somewhat-obviously-wrong bug, this also causes validation to happen in cases where a named window is targeted, but no window with that name exists. Previously, the window open steps would do nothing in such cases; now, they throw an exception when given an invalid URL. Closes #10681.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I hope this works out testing-wise as this seems like a very good change.
The changes look good to me, and I also hope that testing on other implementations works out as the normative change is intuitive to me.
I will give it a shot when I get some time! Not fully familiar with the process, but will figure it out :^) |
I looked into this and I think this is actually not testable. The only case where we would previously avoid URL parsing and do nothing is when the "rules for choosing a navigable" return null. This would occur "If the user agent has been configured such that in this instance it will not find a navigable" or "If currentNavigable's active window does not have transient activation and the user agent has been configured to not show popups (i.e., the user agent has a "popup blocker" enabled)". However, neither of this configurations is possible in web platform tests. The former is basically nonexistant in modern browsers (maybe it's for like kiosk-mode browsers?) and the latter cannot be tested because the WPT infra hard-codes the popup blocker to off (web-platform-tests/wpt#3867). So, I will go ahead and merge this. |
Corresponds to whatwg/html#10683 As part of this, I noticed we incorrectly were setting the "is popup" flag on the Navigable instead of the BrowsingContext. I've fixed that and removed the erroneous flag from Navigable.
Corresponds to whatwg/html#10683 As part of this, I noticed we incorrectly were setting the "is popup" flag on the Navigable instead of the BrowsingContext. I've fixed that and removed the erroneous flag from Navigable.
Corresponds to whatwg/html#10683 As part of this, I noticed we incorrectly were setting the "is popup" flag on the Navigable instead of the BrowsingContext. I've fixed that and removed the erroneous flag from Navigable.
Previously, we would only check at the last minute. This would be buggy in the case where we create a new navigable, and then throw an exception. Instead we should be sure to throw before creating a new navigable.
In addition to fixing this somewhat-obviously-wrong bug, this also causes URL parsing to happen even in cases where a named window is targeted, but no window with that name exists. Previously, the window open steps would do nothing in such cases; now, they throw an exception when given an unparseable URL.
Closes #10681.
@shannonbooth, your review would be appreciated. Also, are you interested in helping to write web platform tests for the normative change described above, about adding validation? I checked by source inspection that it matches how Chromium behaves, but depending on the results we might need to do more work to match the browser majority here.
(See WHATWG Working Mode: Changes for more details.)
/nav-history-apis.html ( diff )