Make sure to log in the AddonDebugging toolbox errors related to rejected promise returned by async API event listeners
Categories
(WebExtensions :: Developer Tools, defect, P3)
Tracking
(Not tracked)
People
(Reporter: rpl, Unassigned)
References
(Blocks 1 open bug)
Details
(Whiteboard: [addons-jira])
In Bug 1792559 we have applied fixes to the WebExtensions internals (in particular to BaseContext's applySafeWithoutClone method) to make sure to log an error with the category "content javascript" and the same innerWindowID actually associated to the BaseContext
instance related to the extension API event listener.
Bug 1792559 was tracking the issue related to the exception being thrown by a non-async listener, but if the listener is defined as an async function then an exception raised from inside the async function will be automatically converted into a rejected promise being returned and so from a caller perspective the call was successful and our internals propagates the rejected promise to the parent process.
Besides API events related to the extension messaging APIs, where the rejected promise will be propagated on the other side of the communication channel (e.g. if runtime.onMessage async listener rejects, then the call to runtime.sendMessage will return a rejected promise, if the rejection is not handled by the extension itself then it would be logged for that extension context) a rejected promise will be received by the API internals running on the parent process and eventually an error logged in the BrowserConsole (but not directly visible in the AddonDebugging toolbox because the error being logged wouldn't be associated to the innerWindowID of the context that have originated it).
As an example for the case mentioned in comment 24 related to WebRequest API events, the rejected promise are going to be propagated to WebRequest.jsm, where HttpObserverManager.applyChanges
await on the promise and will be then logging the error on the BrowserConsole (from the catch block here in WebRequest.jsm).
Updated•2 years ago
|
Reporter | ||
Updated•2 years ago
|
Comment 1•8 months ago
|
||
When an event listener is triggered from the parent to the child, the event listener of extensions are invoked through applySafeWithoutClone
by recvRunListener
at https://searchfox.org/mozilla-central/rev/dbd654fa899a56a6a2e92f325c4608020e80afae/toolkit/components/extensions/ExtensionChild.sys.mjs#825 . Bug 1792559 added extra logging to applySafeWithoutClone
when an error is thrown synchronously. But when the function returns a Promise (e.g. via async function
), then the try-catch of applySafeWithoutClone
will not capture the error.
The error will then propagate up to recvRunListener
, and the error ends up getting lost - definitely not logged to the right console.
If we want to fix this in a generic way, then we could consider modifying applySafeWithoutClone
to not immediately return the return result, but to check whether it is a promise, and if so, chain the promise to a .catch
that logs the error in the context of the context (when called in the child!).
Updated•9 days ago
|
Description
•