-
Notifications
You must be signed in to change notification settings - Fork 3.2k
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
Enable ShadowRealm testing for ErrorEvent and queueMicrotask #49325
base: master
Are you sure you want to change the base?
Conversation
...ipting/events/event-handler-processing-algorithm-error/otherglobalscope-runtime-error.any.js
Show resolved
Hide resolved
96ee05b
to
383a3ce
Compare
...ipting/events/event-handler-processing-algorithm-error/otherglobalscope-runtime-error.any.js
Show resolved
Hide resolved
...ipting/events/event-handler-processing-algorithm-error/otherglobalscope-runtime-error.any.js
Outdated
Show resolved
Hide resolved
...events/event-handler-processing-algorithm-error/otherglobalscope-synthetic-errorevent.any.js
Outdated
Show resolved
Hide resolved
...cs/scripting-1/the-script-element/microtasks/evaluation-order-1-nothrow-static-import.any.js
Outdated
Show resolved
Hide resolved
// META: title=Microtask checkpoint after ShadowRealm onerror events | ||
// META: global=shadowrealm | ||
|
||
// Adapted from first part of ./resources/checkpoint-after-error-event.js. |
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 have not verified that the expected behavior is correct, but I assume it is if it matches the existing test
...webappapis/microtask-queuing/queue-microtask-shadowrealm-callback-report-exception.window.js
Outdated
Show resolved
Hide resolved
...webappapis/microtask-queuing/queue-microtask-shadowrealm-callback-report-exception.window.js
Outdated
Show resolved
Hide resolved
Adapt the tests for the onerror event on Worker global scopes to cover ShadowRealm global scopes as well. One of the tests uses setTimeout() directly to fire the global onerror event. Use queueMicrotask() instead, since that is [Exposed=*]. We cannot use t.step_timeout() because that wraps the callback in a t.step_func() which catches the error and fails the test.
This test is similar to window-onerror-runtime-error-throw.html and window-onerror-runtime-error.html, but ensuring that the ShadowRealm global's onerror is triggered and not the Window's onerror. By my reading of the spec, we cannot have a test equivalent to window-onerror-parse-error.html in ShadowRealm because ShadowRealm.prototype.evaluate() will exit early if the given code fails to parse.
reportError seems to be minimally tested. ShadowRealm doesn't have the location exposed, so just assume it will be blank. This may need to be changed depending on what browsers do. It is not specified what the value should be in https://html.spec.whatwg.org/#extract-error: "Set _attributes_[message], _attributes_[filename], _attributes_[lineno], and _attributes_[colno] to implementation-defined values derived from _exception_. NOTE: Browsers implement behavior not specified here or in the JavaScript specification to gather values which are helpful, including in unusual cases (e.g., `eval`). In the future, this might be specified in greater detail. This seems like exactly such an unusual case.
383a3ce
to
50fd176
Compare
@@ -1,4 +1,4 @@ | |||
// META: global=dedicatedworker-module,sharedworker-module | |||
// META: global=dedicatedworker-module,sharedworker-module,shadowrealm-in-window,shadowrealm-in-shadowrealm,shadowrealm-in-dedicatedworker,shadowrealm-in-sharedworker |
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.
With the improved error reporting in #49387 I realized these didn't run in shadowrealm-in-serviceworker
and shadowrealm-in-audioworklet
because the fake dynamic import isn't actually module code 😖 I'm not sure how important that is though.
Adapt the tests for the onerror event on Worker global scopes to cover ShadowRealm global scopes as well.
One of the tests uses setTimeout() directly to fire the global onerror event. Use queueMicrotask() instead, since that is [Exposed=*]. We cannot use t.step_timeout() because that wraps the callback in a t.step_func() which catches the error and fails the test.
Run the microtask evaluation order tests in ShadowRealm scopes.
Add a new test ensuring that the behaviour of wrapping exceptions thrown from outer realm functions in a fresh TypeError extends to the onerror event as well.
(This PR was originally for just ErrorEvent and onerror. I added my queueMicrotask coverage as well, because most of the tests are quite related. EDIT: added reportError coverage as well, pending whatwg/html#9893 (comment))