From 1847704789e2888c755de8c739d567364b8ad645 Mon Sep 17 00:00:00 2001 From: jrandolf <101637635+jrandolf@users.noreply.github.com> Date: Mon, 10 Oct 2022 16:01:09 +0200 Subject: [PATCH] fix!: refactor custom query handler API (#9078) This PR removes the deprecated query selector API from the `puppeteer` instance. Direct imports of the query selector API have also been deprecated and users are now expected to use the static methods defined on `Puppeteer`. --- docs/api/index.md | 12 +-- .../api/puppeteer.clearcustomqueryhandlers.md | 4 +- docs/api/puppeteer.connect.md | 5 +- docs/api/puppeteer.customqueryhandlernames.md | 6 +- ...teer.puppeteer.clearcustomqueryhandlers.md | 12 +-- ...eteer.puppeteer.customqueryhandlernames.md | 12 +-- docs/api/puppeteer.puppeteer.md | 14 +-- ...er.puppeteer.registercustomqueryhandler.md | 23 ++-- ....puppeteer.unregistercustomqueryhandler.md | 12 +-- .../puppeteer.registercustomqueryhandler.md | 23 ++-- .../puppeteer.unregistercustomqueryhandler.md | 10 +- .../puppeteer-core/src/common/Puppeteer.ts | 101 +++++++++--------- .../puppeteer-core/src/common/QueryHandler.ts | 29 ++--- packages/puppeteer-core/src/puppeteer-core.ts | 5 + packages/puppeteer/src/puppeteer.ts | 4 + test/src/elementhandle.spec.ts | 49 +++++---- test/src/queryselector.spec.ts | 7 +- 17 files changed, 150 insertions(+), 178 deletions(-) diff --git a/docs/api/index.md b/docs/api/index.md index b4af89c9dc6..2fa726570b2 100644 --- a/docs/api/index.md +++ b/docs/api/index.md @@ -51,12 +51,12 @@ sidebar_label: API ## Functions -| Function | Description | -| -------------------------------------------------------------------------------------- | ---------------------------------------------------------------------- | -| [clearCustomQueryHandlers()](./puppeteer.clearcustomqueryhandlers.md) | Clears all registered handlers. | -| [customQueryHandlerNames()](./puppeteer.customqueryhandlernames.md) | | -| [registerCustomQueryHandler(name, handler)](./puppeteer.registercustomqueryhandler.md) | Registers a [custom query handler](./puppeteer.customqueryhandler.md). | -| [unregisterCustomQueryHandler(name)](./puppeteer.unregistercustomqueryhandler.md) | | +| Function | Description | +| -------------------------------------------------------------------------------------- | ----------- | +| [clearCustomQueryHandlers()](./puppeteer.clearcustomqueryhandlers.md) | | +| [customQueryHandlerNames()](./puppeteer.customqueryhandlernames.md) | | +| [registerCustomQueryHandler(name, handler)](./puppeteer.registercustomqueryhandler.md) | | +| [unregisterCustomQueryHandler(name)](./puppeteer.unregistercustomqueryhandler.md) | | ## Interfaces diff --git a/docs/api/puppeteer.clearcustomqueryhandlers.md b/docs/api/puppeteer.clearcustomqueryhandlers.md index 8dcf2c26067..9c4d6c9cfb4 100644 --- a/docs/api/puppeteer.clearcustomqueryhandlers.md +++ b/docs/api/puppeteer.clearcustomqueryhandlers.md @@ -4,7 +4,9 @@ sidebar_label: clearCustomQueryHandlers # clearCustomQueryHandlers() function -Clears all registered handlers. +> Warning: This API is now obsolete. +> +> Import [Puppeteer](./puppeteer.puppeteer.md) and use the static method [Puppeteer.clearCustomQueryHandlers()](./puppeteer.puppeteer.clearcustomqueryhandlers.md) **Signature:** diff --git a/docs/api/puppeteer.connect.md b/docs/api/puppeteer.connect.md index 29453b9ca02..8cda9ef142d 100644 --- a/docs/api/puppeteer.connect.md +++ b/docs/api/puppeteer.connect.md @@ -7,6 +7,7 @@ sidebar_label: connect **Signature:** ```typescript -connect: (options: import('./types').ConnectOptions) => - Promise; +connect: ( + options: import('puppeteer-core/internal/common/Puppeteer.js').ConnectOptions +) => Promise; ``` diff --git a/docs/api/puppeteer.customqueryhandlernames.md b/docs/api/puppeteer.customqueryhandlernames.md index 9774e6a2b7b..bdf4bf26eaa 100644 --- a/docs/api/puppeteer.customqueryhandlernames.md +++ b/docs/api/puppeteer.customqueryhandlernames.md @@ -4,6 +4,10 @@ sidebar_label: customQueryHandlerNames # customQueryHandlerNames() function +> Warning: This API is now obsolete. +> +> Import [Puppeteer](./puppeteer.puppeteer.md) and use the static method [Puppeteer.customQueryHandlerNames()](./puppeteer.puppeteer.customqueryhandlernames.md) + **Signature:** ```typescript @@ -13,5 +17,3 @@ export declare function customQueryHandlerNames(): string[]; **Returns:** string\[\] - -a list with the names of all registered custom query handlers. diff --git a/docs/api/puppeteer.puppeteer.clearcustomqueryhandlers.md b/docs/api/puppeteer.puppeteer.clearcustomqueryhandlers.md index 650614c88b2..d0bebcfd1b0 100644 --- a/docs/api/puppeteer.puppeteer.clearcustomqueryhandlers.md +++ b/docs/api/puppeteer.puppeteer.clearcustomqueryhandlers.md @@ -4,24 +4,16 @@ sidebar_label: Puppeteer.clearCustomQueryHandlers # Puppeteer.clearCustomQueryHandlers() method -> Warning: This API is now obsolete. -> -> Import directly puppeteer. +Unregisters all custom query handlers. **Signature:** ```typescript class Puppeteer { - clearCustomQueryHandlers(): void; + static clearCustomQueryHandlers(): void; } ``` **Returns:** void - -## Example - -```ts -import {clearCustomQueryHandlers} from 'puppeteer'; -``` diff --git a/docs/api/puppeteer.puppeteer.customqueryhandlernames.md b/docs/api/puppeteer.puppeteer.customqueryhandlernames.md index 5fe78a4f166..09e3352d8ab 100644 --- a/docs/api/puppeteer.puppeteer.customqueryhandlernames.md +++ b/docs/api/puppeteer.puppeteer.customqueryhandlernames.md @@ -4,24 +4,16 @@ sidebar_label: Puppeteer.customQueryHandlerNames # Puppeteer.customQueryHandlerNames() method -> Warning: This API is now obsolete. -> -> Import directly puppeteer. +Gets the names of all custom query handlers. **Signature:** ```typescript class Puppeteer { - customQueryHandlerNames(): string[]; + static customQueryHandlerNames(): string[]; } ``` **Returns:** string\[\] - -## Example - -```ts -import {customQueryHandlerNames} from 'puppeteer'; -``` diff --git a/docs/api/puppeteer.puppeteer.md b/docs/api/puppeteer.puppeteer.md index 3ede0dcafd8..cd2375757b7 100644 --- a/docs/api/puppeteer.puppeteer.md +++ b/docs/api/puppeteer.puppeteer.md @@ -20,10 +20,10 @@ The constructor for this class is marked as internal. Third-party code should no ## Methods -| Method | Modifiers | Description | -| ----------------------------------------------------------------------------------------------------- | --------- | --------------------------------------------------------------- | -| [clearCustomQueryHandlers()](./puppeteer.puppeteer.clearcustomqueryhandlers.md) | | | -| [connect(options)](./puppeteer.puppeteer.connect.md) | | This method attaches Puppeteer to an existing browser instance. | -| [customQueryHandlerNames()](./puppeteer.puppeteer.customqueryhandlernames.md) | | | -| [registerCustomQueryHandler(name, queryHandler)](./puppeteer.puppeteer.registercustomqueryhandler.md) | | | -| [unregisterCustomQueryHandler(name)](./puppeteer.puppeteer.unregistercustomqueryhandler.md) | | | +| Method | Modifiers | Description | +| ----------------------------------------------------------------------------------------------------- | ------------------- | ---------------------------------------------------------------------- | +| [clearCustomQueryHandlers()](./puppeteer.puppeteer.clearcustomqueryhandlers.md) | static | Unregisters all custom query handlers. | +| [connect(options)](./puppeteer.puppeteer.connect.md) | | This method attaches Puppeteer to an existing browser instance. | +| [customQueryHandlerNames()](./puppeteer.puppeteer.customqueryhandlernames.md) | static | Gets the names of all custom query handlers. | +| [registerCustomQueryHandler(name, queryHandler)](./puppeteer.puppeteer.registercustomqueryhandler.md) | static | Registers a [custom query handler](./puppeteer.customqueryhandler.md). | +| [unregisterCustomQueryHandler(name)](./puppeteer.puppeteer.unregistercustomqueryhandler.md) | static | Unregisters a custom query handler for a given name. | diff --git a/docs/api/puppeteer.puppeteer.registercustomqueryhandler.md b/docs/api/puppeteer.puppeteer.registercustomqueryhandler.md index 03d0ae7a9b0..03afea7506e 100644 --- a/docs/api/puppeteer.puppeteer.registercustomqueryhandler.md +++ b/docs/api/puppeteer.puppeteer.registercustomqueryhandler.md @@ -4,15 +4,13 @@ sidebar_label: Puppeteer.registerCustomQueryHandler # Puppeteer.registerCustomQueryHandler() method -> Warning: This API is now obsolete. -> -> Import directly puppeteer. +Registers a [custom query handler](./puppeteer.customqueryhandler.md). **Signature:** ```typescript class Puppeteer { - registerCustomQueryHandler( + static registerCustomQueryHandler( name: string, queryHandler: CustomQueryHandler ): void; @@ -21,17 +19,22 @@ class Puppeteer { ## Parameters -| Parameter | Type | Description | -| ------------ | ------------------------------------------------------- | ----------- | -| name | string | | -| queryHandler | [CustomQueryHandler](./puppeteer.customqueryhandler.md) | | +| Parameter | Type | Description | +| ------------ | ------------------------------------------------------- | -------------------------------------------------------------------------- | +| name | string | The name that the custom query handler will be registered under. | +| queryHandler | [CustomQueryHandler](./puppeteer.customqueryhandler.md) | The [custom query handler](./puppeteer.customqueryhandler.md) to register. | **Returns:** void +## Remarks + +After registration, the handler can be used everywhere where a selector is expected by prepending the selection string with `/`. The name is only allowed to consist of lower- and upper case latin letters. + ## Example -```ts -import {registerCustomQueryHandler} from 'puppeteer'; +``` +puppeteer.registerCustomQueryHandler('text', { … }); +const aHandle = await page.$('text/…'); ``` diff --git a/docs/api/puppeteer.puppeteer.unregistercustomqueryhandler.md b/docs/api/puppeteer.puppeteer.unregistercustomqueryhandler.md index e15682fc6bd..85333198719 100644 --- a/docs/api/puppeteer.puppeteer.unregistercustomqueryhandler.md +++ b/docs/api/puppeteer.puppeteer.unregistercustomqueryhandler.md @@ -4,15 +4,13 @@ sidebar_label: Puppeteer.unregisterCustomQueryHandler # Puppeteer.unregisterCustomQueryHandler() method -> Warning: This API is now obsolete. -> -> Import directly puppeteer. +Unregisters a custom query handler for a given name. **Signature:** ```typescript class Puppeteer { - unregisterCustomQueryHandler(name: string): void; + static unregisterCustomQueryHandler(name: string): void; } ``` @@ -25,9 +23,3 @@ class Puppeteer { **Returns:** void - -## Example - -```ts -import {unregisterCustomQueryHandler} from 'puppeteer'; -``` diff --git a/docs/api/puppeteer.registercustomqueryhandler.md b/docs/api/puppeteer.registercustomqueryhandler.md index 50f8292ef02..f0591dad448 100644 --- a/docs/api/puppeteer.registercustomqueryhandler.md +++ b/docs/api/puppeteer.registercustomqueryhandler.md @@ -4,7 +4,9 @@ sidebar_label: registerCustomQueryHandler # registerCustomQueryHandler() function -Registers a [custom query handler](./puppeteer.customqueryhandler.md). +> Warning: This API is now obsolete. +> +> Import [Puppeteer](./puppeteer.puppeteer.md) and use the static method [Puppeteer.registerCustomQueryHandler()](./puppeteer.puppeteer.registercustomqueryhandler.md) **Signature:** @@ -17,22 +19,11 @@ export declare function registerCustomQueryHandler( ## Parameters -| Parameter | Type | Description | -| --------- | ------------------------------------------------------- | ---------------------------------------------------------------- | -| name | string | The name that the custom query handler will be registered under. | -| handler | [CustomQueryHandler](./puppeteer.customqueryhandler.md) | | +| Parameter | Type | Description | +| --------- | ------------------------------------------------------- | ----------- | +| name | string | | +| handler | [CustomQueryHandler](./puppeteer.customqueryhandler.md) | | **Returns:** void - -## Remarks - -After registration, the handler can be used everywhere where a selector is expected by prepending the selection string with `/`. The name is only allowed to consist of lower- and upper case latin letters. - -## Example - -``` -puppeteer.registerCustomQueryHandler('text', { … }); -const aHandle = await page.$('text/…'); -``` diff --git a/docs/api/puppeteer.unregistercustomqueryhandler.md b/docs/api/puppeteer.unregistercustomqueryhandler.md index 908e261158a..ff22008802b 100644 --- a/docs/api/puppeteer.unregistercustomqueryhandler.md +++ b/docs/api/puppeteer.unregistercustomqueryhandler.md @@ -4,6 +4,10 @@ sidebar_label: unregisterCustomQueryHandler # unregisterCustomQueryHandler() function +> Warning: This API is now obsolete. +> +> Import [Puppeteer](./puppeteer.puppeteer.md) and use the static method [Puppeteer.unregisterCustomQueryHandler()](./puppeteer.puppeteer.unregistercustomqueryhandler.md) + **Signature:** ```typescript @@ -12,9 +16,9 @@ export declare function unregisterCustomQueryHandler(name: string): void; ## Parameters -| Parameter | Type | Description | -| --------- | ------ | ---------------------------------------------- | -| name | string | The name of the query handler to unregistered. | +| Parameter | Type | Description | +| --------- | ------ | ----------- | +| name | string | | **Returns:** diff --git a/packages/puppeteer-core/src/common/Puppeteer.ts b/packages/puppeteer-core/src/common/Puppeteer.ts index ca2eb0299c4..dc0e8ee5061 100644 --- a/packages/puppeteer-core/src/common/Puppeteer.ts +++ b/packages/puppeteer-core/src/common/Puppeteer.ts @@ -54,6 +54,56 @@ export interface ConnectOptions extends BrowserConnectOptions { * @public */ export class Puppeteer { + /** + * Registers a {@link CustomQueryHandler | custom query handler}. + * + * @remarks + * After registration, the handler can be used everywhere where a selector is + * expected by prepending the selection string with `/`. The name is only + * allowed to consist of lower- and upper case latin letters. + * + * @example + * + * ``` + * puppeteer.registerCustomQueryHandler('text', { … }); + * const aHandle = await page.$('text/…'); + * ``` + * + * @param name - The name that the custom query handler will be registered + * under. + * @param queryHandler - The {@link CustomQueryHandler | custom query handler} + * to register. + * + * @public + */ + static registerCustomQueryHandler( + name: string, + queryHandler: CustomQueryHandler + ): void { + return registerCustomQueryHandler(name, queryHandler); + } + + /** + * Unregisters a custom query handler for a given name. + */ + static unregisterCustomQueryHandler(name: string): void { + return unregisterCustomQueryHandler(name); + } + + /** + * Gets the names of all custom query handlers. + */ + static customQueryHandlerNames(): string[] { + return customQueryHandlerNames(); + } + + /** + * Unregisters all custom query handlers. + */ + static clearCustomQueryHandlers(): void { + return clearCustomQueryHandlers(); + } + /** * @internal */ @@ -83,55 +133,4 @@ export class Puppeteer { connect(options: ConnectOptions): Promise { return _connectToCDPBrowser(options); } - - /** - * @deprecated Import directly puppeteer. - * @example - * - * ```ts - * import {registerCustomQueryHandler} from 'puppeteer'; - * ``` - */ - registerCustomQueryHandler( - name: string, - queryHandler: CustomQueryHandler - ): void { - return registerCustomQueryHandler(name, queryHandler); - } - - /** - * @deprecated Import directly puppeteer. - * @example - * - * ```ts - * import {unregisterCustomQueryHandler} from 'puppeteer'; - * ``` - */ - unregisterCustomQueryHandler(name: string): void { - return unregisterCustomQueryHandler(name); - } - - /** - * @deprecated Import directly puppeteer. - * @example - * - * ```ts - * import {customQueryHandlerNames} from 'puppeteer'; - * ``` - */ - customQueryHandlerNames(): string[] { - return customQueryHandlerNames(); - } - - /** - * @deprecated Import directly puppeteer. - * @example - * - * ```ts - * import {clearCustomQueryHandlers} from 'puppeteer'; - * ``` - */ - clearCustomQueryHandlers(): void { - return clearCustomQueryHandlers(); - } } diff --git a/packages/puppeteer-core/src/common/QueryHandler.ts b/packages/puppeteer-core/src/common/QueryHandler.ts index 1aa48ff6ac4..f856afe1477 100644 --- a/packages/puppeteer-core/src/common/QueryHandler.ts +++ b/packages/puppeteer-core/src/common/QueryHandler.ts @@ -237,24 +237,8 @@ const INTERNAL_QUERY_HANDLERS = new Map([ const QUERY_HANDLERS = new Map(); /** - * Registers a {@link CustomQueryHandler | custom query handler}. - * - * @remarks - * After registration, the handler can be used everywhere where a selector is - * expected by prepending the selection string with `/`. The name is only - * allowed to consist of lower- and upper case latin letters. - * - * @example - * - * ``` - * puppeteer.registerCustomQueryHandler('text', { … }); - * const aHandle = await page.$('text/…'); - * ``` - * - * @param name - The name that the custom query handler will be registered - * under. - * @param queryHandler - The {@link CustomQueryHandler | custom query handler} - * to register. + * @deprecated Import {@link Puppeteer} and use the static method + * {@link Puppeteer.registerCustomQueryHandler} * * @public */ @@ -278,7 +262,8 @@ export function registerCustomQueryHandler( } /** - * @param name - The name of the query handler to unregistered. + * @deprecated Import {@link Puppeteer} and use the static method + * {@link Puppeteer.unregisterCustomQueryHandler} * * @public */ @@ -287,7 +272,8 @@ export function unregisterCustomQueryHandler(name: string): void { } /** - * @returns a list with the names of all registered custom query handlers. + * @deprecated Import {@link Puppeteer} and use the static method + * {@link Puppeteer.customQueryHandlerNames} * * @public */ @@ -296,7 +282,8 @@ export function customQueryHandlerNames(): string[] { } /** - * Clears all registered handlers. + * @deprecated Import {@link Puppeteer} and use the static method + * {@link Puppeteer.clearCustomQueryHandlers} * * @public */ diff --git a/packages/puppeteer-core/src/puppeteer-core.ts b/packages/puppeteer-core/src/puppeteer-core.ts index e9cbb3b17c4..fadee46ee32 100644 --- a/packages/puppeteer-core/src/puppeteer-core.ts +++ b/packages/puppeteer-core/src/puppeteer-core.ts @@ -18,6 +18,11 @@ export {Protocol} from 'devtools-protocol'; export * from './common/Device.js'; export * from './common/Errors.js'; export * from './common/PredefinedNetworkConditions.js'; +export * from './common/Puppeteer.js'; + +/** + * @deprecated Use the query handler API defined on {@link Puppeteer} + */ export * from './common/QueryHandler.js'; import {rootDirname} from './constants.js'; diff --git a/packages/puppeteer/src/puppeteer.ts b/packages/puppeteer/src/puppeteer.ts index a0c89a29634..7b0a7fc4275 100644 --- a/packages/puppeteer/src/puppeteer.ts +++ b/packages/puppeteer/src/puppeteer.ts @@ -18,6 +18,10 @@ export {Protocol} from 'devtools-protocol'; export * from 'puppeteer-core/internal/common/Device.js'; export * from 'puppeteer-core/internal/common/Errors.js'; export * from 'puppeteer-core/internal/common/PredefinedNetworkConditions.js'; +export * from 'puppeteer-core/internal/common/Puppeteer.js'; +/** + * @deprecated Use the query handler API defined on {@link Puppeteer} + */ export * from 'puppeteer-core/internal/common/QueryHandler.js'; export {BrowserFetcher} from 'puppeteer-core/internal/node/BrowserFetcher.js'; export {LaunchOptions} from 'puppeteer-core/internal/node/LaunchOptions.js'; diff --git a/test/src/elementhandle.spec.ts b/test/src/elementhandle.spec.ts index b029f71de96..5b2b7e5e2fc 100644 --- a/test/src/elementhandle.spec.ts +++ b/test/src/elementhandle.spec.ts @@ -15,14 +15,15 @@ */ import expect from 'expect'; -import sinon from 'sinon'; import {ElementHandle} from 'puppeteer-core/internal/common/ElementHandle.js'; +import sinon from 'sinon'; import { getTestState, setupTestBrowserHooks, setupTestPageAndContextHooks, } from './mocha-utils.js'; +import {Puppeteer} from 'puppeteer'; import utils from './utils.js'; describe('ElementHandle specs', function () { @@ -390,16 +391,15 @@ describe('ElementHandle specs', function () { }); describe('Custom queries', function () { - this.afterEach(() => { - const {puppeteer} = getTestState(); - puppeteer.clearCustomQueryHandlers(); + afterEach(() => { + Puppeteer.clearCustomQueryHandlers(); }); it('should register and unregister', async () => { - const {page, puppeteer} = getTestState(); + const {page} = getTestState(); await page.setContent('
'); // Register. - puppeteer.registerCustomQueryHandler('getById', { + Puppeteer.registerCustomQueryHandler('getById', { queryOne: (_element, selector) => { return document.querySelector(`[id="${selector}"]`); }, @@ -412,11 +412,11 @@ describe('ElementHandle specs', function () { return element.id; }, element) ).toBe('foo'); - const handlerNamesAfterRegistering = puppeteer.customQueryHandlerNames(); + const handlerNamesAfterRegistering = Puppeteer.customQueryHandlerNames(); expect(handlerNamesAfterRegistering.includes('getById')).toBeTruthy(); // Unregister. - puppeteer.unregisterCustomQueryHandler('getById'); + Puppeteer.unregisterCustomQueryHandler('getById'); try { await page.$('getById/foo'); throw new Error('Custom query handler name not set - throw expected'); @@ -426,13 +426,12 @@ describe('ElementHandle specs', function () { ); } const handlerNamesAfterUnregistering = - puppeteer.customQueryHandlerNames(); + Puppeteer.customQueryHandlerNames(); expect(handlerNamesAfterUnregistering.includes('getById')).toBeFalsy(); }); it('should throw with invalid query names', () => { try { - const {puppeteer} = getTestState(); - puppeteer.registerCustomQueryHandler('1/2/3', { + Puppeteer.registerCustomQueryHandler('1/2/3', { queryOne: () => { return document.querySelector('foo'); }, @@ -447,11 +446,11 @@ describe('ElementHandle specs', function () { } }); it('should work for multiple elements', async () => { - const {page, puppeteer} = getTestState(); + const {page} = getTestState(); await page.setContent( '
Foo1
Foo2
' ); - puppeteer.registerCustomQueryHandler('getByClass', { + Puppeteer.registerCustomQueryHandler('getByClass', { queryAll: (_element, selector) => { return [...document.querySelectorAll(`.${selector}`)]; }, @@ -470,11 +469,11 @@ describe('ElementHandle specs', function () { expect(classNames).toStrictEqual(['foo', 'foo baz']); }); it('should eval correctly', async () => { - const {page, puppeteer} = getTestState(); + const {page} = getTestState(); await page.setContent( '
Foo1
Foo2
' ); - puppeteer.registerCustomQueryHandler('getByClass', { + Puppeteer.registerCustomQueryHandler('getByClass', { queryAll: (_element, selector) => { return [...document.querySelectorAll(`.${selector}`)]; }, @@ -486,8 +485,8 @@ describe('ElementHandle specs', function () { expect(elements).toBe(2); }); it('should wait correctly with waitForSelector', async () => { - const {page, puppeteer} = getTestState(); - puppeteer.registerCustomQueryHandler('getByClass', { + const {page} = getTestState(); + Puppeteer.registerCustomQueryHandler('getByClass', { queryOne: (element, selector) => { return (element as Element).querySelector(`.${selector}`); }, @@ -504,8 +503,8 @@ describe('ElementHandle specs', function () { }); it('should wait correctly with waitForSelector on an element', async () => { - const {page, puppeteer} = getTestState(); - puppeteer.registerCustomQueryHandler('getByClass', { + const {page} = getTestState(); + Puppeteer.registerCustomQueryHandler('getByClass', { queryOne: (element, selector) => { return (element as Element).querySelector(`.${selector}`); }, @@ -541,8 +540,8 @@ describe('ElementHandle specs', function () { it('should wait correctly with waitFor', async () => { /* page.waitFor is deprecated so we silence the warning to avoid test noise */ sinon.stub(console, 'warn').callsFake(() => {}); - const {page, puppeteer} = getTestState(); - puppeteer.registerCustomQueryHandler('getByClass', { + const {page} = getTestState(); + Puppeteer.registerCustomQueryHandler('getByClass', { queryOne: (element, selector) => { return (element as Element).querySelector(`.${selector}`); }, @@ -558,11 +557,11 @@ describe('ElementHandle specs', function () { expect(element).toBeDefined(); }); it('should work when both queryOne and queryAll are registered', async () => { - const {page, puppeteer} = getTestState(); + const {page} = getTestState(); await page.setContent( '
Foo2
' ); - puppeteer.registerCustomQueryHandler('getByClass', { + Puppeteer.registerCustomQueryHandler('getByClass', { queryOne: (element, selector) => { return (element as Element).querySelector(`.${selector}`); }, @@ -578,11 +577,11 @@ describe('ElementHandle specs', function () { expect(elements.length).toBe(3); }); it('should eval when both queryOne and queryAll are registered', async () => { - const {page, puppeteer} = getTestState(); + const {page} = getTestState(); await page.setContent( '
text
content
' ); - puppeteer.registerCustomQueryHandler('getByClass', { + Puppeteer.registerCustomQueryHandler('getByClass', { queryOne: (element, selector) => { return (element as Element).querySelector(`.${selector}`); }, diff --git a/test/src/queryselector.spec.ts b/test/src/queryselector.spec.ts index 80b5856de07..a6a08d40f59 100644 --- a/test/src/queryselector.spec.ts +++ b/test/src/queryselector.spec.ts @@ -14,6 +14,7 @@ * limitations under the License. */ import expect from 'expect'; +import {Puppeteer} from 'puppeteer'; import {CustomQueryHandler} from 'puppeteer-core/internal/common/QueryHandler.js'; import { getTestState, @@ -397,14 +398,12 @@ describe('querySelector', function () { }, }; before(() => { - const {puppeteer} = getTestState(); - puppeteer.registerCustomQueryHandler('allArray', handler); + Puppeteer.registerCustomQueryHandler('allArray', handler); }); it('should have registered handler', async () => { - const {puppeteer} = getTestState(); expect( - puppeteer.customQueryHandlerNames().includes('allArray') + Puppeteer.customQueryHandlerNames().includes('allArray') ).toBeTruthy(); }); it('$$ should query existing elements', async () => {