diff --git a/docs/api.md b/docs/api.md index 39341225c31..5e1c40ed2e0 100644 --- a/docs/api.md +++ b/docs/api.md @@ -2255,6 +2255,7 @@ return firstRequest.url(); ```js const firstResponse = await page.waitForResponse('https://example.com/resource'); const finalResponse = await page.waitForResponse(response => response.url() === 'https://example.com' && response.status() === 200); +const finalResponse = await page.waitForResponse(async response => { return (await response.text()).includes('') }) return finalResponse.ok(); ``` diff --git a/src/common/Page.ts b/src/common/Page.ts index 7194649bef2..4403998b889 100644 --- a/src/common/Page.ts +++ b/src/common/Page.ts @@ -1298,11 +1298,11 @@ export class Page extends EventEmitter { return helper.waitForEvent( this._frameManager.networkManager(), NetworkManagerEmittedEvents.Response, - (response) => { + async (response) => { if (helper.isString(urlOrPredicate)) return urlOrPredicate === response.url(); if (typeof urlOrPredicate === 'function') - return !!urlOrPredicate(response); + return !!(await urlOrPredicate(response)); return false; }, timeout, diff --git a/src/common/helper.ts b/src/common/helper.ts index d8ca9b4ef48..ba2af396a87 100644 --- a/src/common/helper.ts +++ b/src/common/helper.ts @@ -124,7 +124,7 @@ function isNumber(obj: unknown): obj is number { async function waitForEvent( emitter: CommonEventEmitter, eventName: string | symbol, - predicate: (event: T) => boolean, + predicate: (event: T) => Promise | boolean, timeout: number, abortPromise: Promise ): Promise { @@ -133,8 +133,8 @@ async function waitForEvent( resolveCallback = resolve; rejectCallback = reject; }); - const listener = addEventListener(emitter, eventName, (event) => { - if (!predicate(event)) return; + const listener = addEventListener(emitter, eventName, async (event) => { + if (!(await predicate(event))) return; resolveCallback(event); }); if (timeout) { diff --git a/test/page.spec.ts b/test/page.spec.ts index 7991a9c75b6..ccac65ea660 100644 --- a/test/page.spec.ts +++ b/test/page.spec.ts @@ -712,6 +712,22 @@ describe('Page', function () { .catch((error_) => (error = error_)); expect(error).toBeInstanceOf(puppeteer.errors.TimeoutError); }); + it('should work with async predicate', async () => { + const { page, server } = getTestState(); + await page.goto(server.EMPTY_PAGE); + const [response] = await Promise.all([ + page.waitForResponse(async (response) => { + console.log(response.url()); + return response.url() === server.PREFIX + '/digits/2.png'; + }), + page.evaluate(() => { + fetch('/digits/1.png'); + fetch('/digits/2.png'); + fetch('/digits/3.png'); + }), + ]); + expect(response.url()).toBe(server.PREFIX + '/digits/2.png'); + }); it('should work with no timeout', async () => { const { page, server } = getTestState();