fix(Connection): do not assert that methods always have callbacks. (#2330)
In certain cases, all callbacks could be rejected before we get a response from transport. This is easily reproducible with `slowMo` option. Fixes #563.
This commit is contained in:
parent
294f33b75c
commit
57fa690724
@ -102,15 +102,17 @@ class Connection extends EventEmitter {
|
|||||||
await new Promise(f => setTimeout(f, this._delay));
|
await new Promise(f => setTimeout(f, this._delay));
|
||||||
debugProtocol('◀ RECV ' + message);
|
debugProtocol('◀ RECV ' + message);
|
||||||
const object = JSON.parse(message);
|
const object = JSON.parse(message);
|
||||||
if (object.id && this._callbacks.has(object.id)) {
|
if (object.id) {
|
||||||
const callback = this._callbacks.get(object.id);
|
const callback = this._callbacks.get(object.id);
|
||||||
|
// Callbacks could be all rejected if someone has called `.dispose()`.
|
||||||
|
if (callback) {
|
||||||
this._callbacks.delete(object.id);
|
this._callbacks.delete(object.id);
|
||||||
if (object.error)
|
if (object.error)
|
||||||
callback.reject(rewriteError(callback.error, `Protocol error (${callback.method}): ${object.error.message} ${object.error.data}`));
|
callback.reject(rewriteError(callback.error, `Protocol error (${callback.method}): ${object.error.message} ${object.error.data}`));
|
||||||
else
|
else
|
||||||
callback.resolve(object.result);
|
callback.resolve(object.result);
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
console.assert(!object.id);
|
|
||||||
if (object.method === 'Target.receivedMessageFromTarget') {
|
if (object.method === 'Target.receivedMessageFromTarget') {
|
||||||
const session = this._sessions.get(object.params.sessionId);
|
const session = this._sessions.get(object.params.sessionId);
|
||||||
if (session)
|
if (session)
|
||||||
|
Loading…
Reference in New Issue
Block a user