From c2826f0aeb7e1e4db39be7e11504450e11b5aaf5 Mon Sep 17 00:00:00 2001 From: Simon Knott Date: Mon, 3 Feb 2025 14:32:11 +0100 Subject: [PATCH] remove "as any" --- .../dispatchers/mockingProxyDispatcher.ts | 10 +++---- .../server/dispatchers/networkDispatchers.ts | 27 ++++++++++--------- 2 files changed, 20 insertions(+), 17 deletions(-) diff --git a/packages/playwright-core/src/server/dispatchers/mockingProxyDispatcher.ts b/packages/playwright-core/src/server/dispatchers/mockingProxyDispatcher.ts index f40d06c689..4338f95095 100644 --- a/packages/playwright-core/src/server/dispatchers/mockingProxyDispatcher.ts +++ b/packages/playwright-core/src/server/dispatchers/mockingProxyDispatcher.ts @@ -35,23 +35,23 @@ export class MockingProxyDispatcher extends Dispatcher { - const requestDispatcher = RequestDispatcher.from(this as any, route.request()); + const requestDispatcher = RequestDispatcher.from(this, route.request()); this._dispatchEvent('route', { route: RouteDispatcher.from(requestDispatcher, route) }); }); this.addObjectListener(MockingProxy.Events.Request, ({ request, correlation }: { request: Request, correlation: string }) => { - this._dispatchEvent('request', { request: RequestDispatcher.from(this as any, request), correlation }); + this._dispatchEvent('request', { request: RequestDispatcher.from(this, request), correlation }); }); this.addObjectListener(MockingProxy.Events.RequestFailed, (request: Request) => { this._dispatchEvent('requestFailed', { - request: RequestDispatcher.from(this as any, request), + request: RequestDispatcher.from(this, request), failureText: request._failureText ?? undefined, responseEndTiming: request._responseEndTiming, }); }); this.addObjectListener(MockingProxy.Events.RequestFinished, (request: Request) => { this._dispatchEvent('requestFinished', { - request: RequestDispatcher.from(this as any, request), - response: ResponseDispatcher.fromNullable(this as any, request._existingResponse()), + request: RequestDispatcher.from(this, request), + response: ResponseDispatcher.fromNullable(this, request._existingResponse()), responseEndTiming: request._responseEndTiming, }); }); diff --git a/packages/playwright-core/src/server/dispatchers/networkDispatchers.ts b/packages/playwright-core/src/server/dispatchers/networkDispatchers.ts index ba600f697e..f36f5939ef 100644 --- a/packages/playwright-core/src/server/dispatchers/networkDispatchers.ts +++ b/packages/playwright-core/src/server/dispatchers/networkDispatchers.ts @@ -26,30 +26,33 @@ import type { BrowserContextDispatcher } from './browserContextDispatcher'; import type { PageDispatcher } from './pageDispatcher'; import { FrameDispatcher } from './frameDispatcher'; import { WorkerDispatcher } from './pageDispatcher'; +import type { MockingProxyDispatcher } from './mockingProxyDispatcher'; -export class RequestDispatcher extends Dispatcher implements channels.RequestChannel { +type NetworkScope = BrowserContextDispatcher | MockingProxyDispatcher; + +export class RequestDispatcher extends Dispatcher implements channels.RequestChannel { _type_Request: boolean; - private _browserContextDispatcher: BrowserContextDispatcher; + private _networkScope: NetworkScope; - static from(scope: BrowserContextDispatcher, request: Request): RequestDispatcher { + static from(scope: NetworkScope, request: Request): RequestDispatcher { const result = existingDispatcher(request); return result || new RequestDispatcher(scope, request); } - static fromNullable(scope: BrowserContextDispatcher, request: Request | null): RequestDispatcher | undefined { + static fromNullable(scope: NetworkScope, request: Request | null): RequestDispatcher | undefined { return request ? RequestDispatcher.from(scope, request) : undefined; } - private constructor(scope: BrowserContextDispatcher, request: Request) { + private constructor(scope: NetworkScope, request: Request) { const postData = request.postDataBuffer(); // Always try to attach request to the page, if not, frame. const frame = request.frame(); const page = request.frame()?._page; const pageDispatcher = page ? existingDispatcher(page) : null; - const frameDispatcher = frame ? FrameDispatcher.from(scope, frame) : null; + const frameDispatcher = frame ? FrameDispatcher.from(scope as BrowserContextDispatcher, frame) : null; super(pageDispatcher || frameDispatcher || scope, request, 'Request', { - frame: FrameDispatcher.fromNullable(scope, request.frame()), - serviceWorker: WorkerDispatcher.fromNullable(scope, request.serviceWorker()), + frame: FrameDispatcher.fromNullable(scope as BrowserContextDispatcher, request.frame()), + serviceWorker: WorkerDispatcher.fromNullable(scope as BrowserContextDispatcher, request.serviceWorker()), url: request.url(), resourceType: request.resourceType(), method: request.method(), @@ -59,7 +62,7 @@ export class RequestDispatcher extends Dispatcher { @@ -67,20 +70,20 @@ export class RequestDispatcher extends Dispatcher { - return { response: ResponseDispatcher.fromNullable(this._browserContextDispatcher, await this._object.response()) }; + return { response: ResponseDispatcher.fromNullable(this._networkScope, await this._object.response()) }; } } export class ResponseDispatcher extends Dispatcher implements channels.ResponseChannel { _type_Response = true; - static from(scope: BrowserContextDispatcher, response: Response): ResponseDispatcher { + static from(scope: NetworkScope, response: Response): ResponseDispatcher { const result = existingDispatcher(response); const requestDispatcher = RequestDispatcher.from(scope, response.request()); return result || new ResponseDispatcher(requestDispatcher, response); } - static fromNullable(scope: BrowserContextDispatcher, response: Response | null): ResponseDispatcher | undefined { + static fromNullable(scope: NetworkScope, response: Response | null): ResponseDispatcher | undefined { return response ? ResponseDispatcher.from(scope, response) : undefined; }