-
Notifications
You must be signed in to change notification settings - Fork 2.8k
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
Weird interactions between JS and EnqueueJob make await p
different from p.then
#5319
Comments
I'm personally prepared to accept this as a weird consequence of a set of otherwise-reasonable rules. It's not a great end result, but it's acceptable for something that's somewhat of an edge case. (It's hard to imagine this coming up in a disruptive way outside of tests. Outside of tests, I don't think developers have strong expectations about promise callbacks firing after removing iframes.) If I were to start picking out rules to change in order to align these, I'd probably start by trying to knock down promise subclassing support; adding all the complexity to support that is one my personal great regrets. E.g. I might suggest just changing step 2 in PromiseResolve to "If IsPromise(x), return x". |
- Use DOMException constructor from the proper realm (regression after b7f2dd3). - Make sure that promise microtasks are run, due to whatwg/html#5319.
Another work around seems to be |
Closing as working as intended, I guess, since nobody seems to have strong opinions to the contrary. Let's just add it to the pile of evidence that promise subclassing was a bad idea. |
Consider this test case:
One would ordinarily expect that either both Yays are printed, or neither of them, based on the intuition that
await
and.then
are essentially equivalent.However, this turns out not to be the case after #5212 (and also in Firefox currently). This is because
await p
would call PromiseResolve(p), which actually treats p as if it's a non-standard-Promise thenable (step 2b fails), so a PromiseResolveThenableJob microtask would be queued up. The HTML EnqueueJob then looks at thep.then
method, and decide that the microtask should not be run sinceiframe
's document is already inactive.On the other hand, the job settings of PromiseReactionJobs is decided based on the
then
handler, so the callback inp.then(() => {})
would get executed alright.This behavior is tremendously weird but interesting, since it is at the intersection between JS's desire to keep Promise subclassing work, the recent PR to reduce number of ticks in
await
(tc39/ecma262#1250), the newly specified job settings in EnqueueJob, and possibly the upcoming Jobs infrastructure refactoring too. However the question is, is this behavior desirable? If not, is fixing it viable?If we don't get to change how
p
was created, a workaround I found that'll letawait
keep working is:(I'm implementing #5212 in Chrome, and this showed up in one of the strange corners in WPT.)
The text was updated successfully, but these errors were encountered: