diff --git a/src/common/Page.ts b/src/common/Page.ts index 0493a324..5cfd88bd 100644 --- a/src/common/Page.ts +++ b/src/common/Page.ts @@ -631,11 +631,13 @@ export class Page extends EventEmitter { handler: (event: PageEventObject[K]) => void ): EventEmitter { if (eventName === 'request') { - const wrap = (event: HTTPRequest) => { - event.enqueueInterceptAction(() => - handler(event as PageEventObject[K]) - ); - }; + const wrap = + this._handlerMap.get(handler) || + ((event: HTTPRequest) => { + event.enqueueInterceptAction(() => + handler(event as PageEventObject[K]) + ); + }); this._handlerMap.set(handler, wrap); diff --git a/test/page.spec.ts b/test/page.spec.ts index 4a1a5b2a..9c31f5b7 100644 --- a/test/page.spec.ts +++ b/test/page.spec.ts @@ -153,17 +153,21 @@ describe('Page', function () { } }; + page.on('request', onResponse); page.on('request', onResponse); await page.goto(server.EMPTY_PAGE); - expect(handler.callCount).toBe(1); + expect(handler.callCount).toBe(2); page.off('request', onResponse); await page.goto(server.EMPTY_PAGE); // Still one because we removed the handler. - expect(handler.callCount).toBe(1); + expect(handler.callCount).toBe(3); + page.off('request', onResponse); + await page.goto(server.EMPTY_PAGE); + expect(handler.callCount).toBe(3); page.on('request', onResponse); await page.goto(server.EMPTY_PAGE); // Two now because we added the handler back. - expect(handler.callCount).toBe(2); + expect(handler.callCount).toBe(4); }); });