From 744a6e028a2e07330feed97c85d6fd605cc9424b Mon Sep 17 00:00:00 2001 From: jrandolf <101637635+jrandolf@users.noreply.github.com> Date: Thu, 25 Aug 2022 17:00:35 +0200 Subject: [PATCH] chore: infer client from context in JSHandle (#8842) --- src/common/ElementHandle.ts | 6 ++---- src/common/JSHandle.ts | 9 +++------ src/common/WebWorker.ts | 2 +- src/common/util.ts | 3 +-- 4 files changed, 7 insertions(+), 13 deletions(-) diff --git a/src/common/ElementHandle.ts b/src/common/ElementHandle.ts index 3078ee20..67379607 100644 --- a/src/common/ElementHandle.ts +++ b/src/common/ElementHandle.ts @@ -1,9 +1,8 @@ import {Protocol} from 'devtools-protocol'; import {assert} from '../util/assert.js'; -import {CDPSession} from './Connection.js'; import {ExecutionContext} from './ExecutionContext.js'; -import {FrameManager} from './FrameManager.js'; import {Frame} from './Frame.js'; +import {FrameManager} from './FrameManager.js'; import { MAIN_WORLD, PUPPETEER_WORLD, @@ -80,13 +79,12 @@ export class ElementHandle< */ constructor( context: ExecutionContext, - client: CDPSession, remoteObject: Protocol.Runtime.RemoteObject, frame: Frame, page: Page, frameManager: FrameManager ) { - super(context, client, remoteObject); + super(context, remoteObject); this.#frame = frame; this.#page = page; this.#frameManager = frameManager; diff --git a/src/common/JSHandle.ts b/src/common/JSHandle.ts index 70536309..c2c070bb 100644 --- a/src/common/JSHandle.ts +++ b/src/common/JSHandle.ts @@ -78,7 +78,6 @@ export class JSHandle { */ [__JSHandleSymbol]?: T; - #client: CDPSession; #disposed = false; #context: ExecutionContext; #remoteObject: Protocol.Runtime.RemoteObject; @@ -87,7 +86,7 @@ export class JSHandle { * @internal */ get client(): CDPSession { - return this.#client; + return this.#context._client; } /** @@ -102,11 +101,9 @@ export class JSHandle { */ constructor( context: ExecutionContext, - client: CDPSession, remoteObject: Protocol.Runtime.RemoteObject ) { this.#context = context; - this.#client = client; this.#remoteObject = remoteObject; } @@ -196,7 +193,7 @@ export class JSHandle { assert(this.#remoteObject.objectId); // We use Runtime.getProperties rather than iterative building because the // iterative approach might create a distorted snapshot. - const response = await this.#client.send('Runtime.getProperties', { + const response = await this.client.send('Runtime.getProperties', { objectId: this.#remoteObject.objectId, ownProperties: true, }); @@ -247,7 +244,7 @@ export class JSHandle { return; } this.#disposed = true; - await releaseObject(this.#client, this.#remoteObject); + await releaseObject(this.client, this.#remoteObject); } /** diff --git a/src/common/WebWorker.ts b/src/common/WebWorker.ts index 83495267..1b428223 100644 --- a/src/common/WebWorker.ts +++ b/src/common/WebWorker.ts @@ -93,7 +93,7 @@ export class WebWorker extends EventEmitter { return consoleAPICalled( event.type, event.args.map((object: Protocol.Runtime.RemoteObject) => { - return new JSHandle(context, this.#client, object); + return new JSHandle(context, object); }), event.stackTrace ); diff --git a/src/common/util.ts b/src/common/util.ts index b242d2c3..025e3dab 100644 --- a/src/common/util.ts +++ b/src/common/util.ts @@ -222,14 +222,13 @@ export function createJSHandle( const frameManager = frame._frameManager; return new ElementHandle( context, - context._client, remoteObject, frame, frameManager.page(), frameManager ); } - return new JSHandle(context, context._client, remoteObject); + return new JSHandle(context, remoteObject); } /**