2020-05-05 08:36:44 +00:00
|
|
|
/**
|
|
|
|
* Copyright 2017 Google Inc. All rights reserved.
|
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
*/
|
2020-06-18 14:53:23 +00:00
|
|
|
import Launcher from '../node/Launcher';
|
2020-06-04 10:47:13 +00:00
|
|
|
import {
|
2020-05-07 10:54:55 +00:00
|
|
|
LaunchOptions,
|
|
|
|
ChromeArgOptions,
|
|
|
|
BrowserOptions,
|
2020-06-18 14:53:23 +00:00
|
|
|
} from '../node/LaunchOptions';
|
|
|
|
import { ProductLauncher } from '../node/Launcher';
|
|
|
|
import { BrowserFetcher, BrowserFetcherOptions } from '../node/BrowserFetcher';
|
2020-05-07 10:54:55 +00:00
|
|
|
import { puppeteerErrors, PuppeteerErrors } from './Errors';
|
2020-06-04 10:47:13 +00:00
|
|
|
import { ConnectionTransport } from './ConnectionTransport';
|
2020-05-07 10:54:55 +00:00
|
|
|
|
|
|
|
import { devicesMap } from './DeviceDescriptors';
|
2020-06-18 14:53:23 +00:00
|
|
|
import { DevicesMap } from './DeviceDescriptors';
|
2020-05-07 10:54:55 +00:00
|
|
|
import { Browser } from './Browser';
|
2020-06-04 10:47:13 +00:00
|
|
|
import {
|
|
|
|
registerCustomQueryHandler,
|
|
|
|
unregisterCustomQueryHandler,
|
|
|
|
customQueryHandlers,
|
|
|
|
clearQueryHandlers,
|
|
|
|
QueryHandler,
|
|
|
|
} from './QueryHandler';
|
2020-05-05 08:36:44 +00:00
|
|
|
|
2020-06-04 10:47:13 +00:00
|
|
|
/**
|
|
|
|
* The main Puppeteer class
|
|
|
|
* @public
|
|
|
|
*/
|
2020-05-05 08:36:44 +00:00
|
|
|
export class Puppeteer {
|
|
|
|
_projectRoot: string;
|
|
|
|
_preferredRevision: string;
|
|
|
|
_isPuppeteerCore: boolean;
|
|
|
|
_changedProduct = false;
|
|
|
|
__productName: string;
|
|
|
|
_lazyLauncher: ProductLauncher;
|
|
|
|
|
2020-05-07 10:54:55 +00:00
|
|
|
constructor(
|
|
|
|
projectRoot: string,
|
|
|
|
preferredRevision: string,
|
|
|
|
isPuppeteerCore: boolean,
|
|
|
|
productName: string
|
|
|
|
) {
|
2020-05-05 08:36:44 +00:00
|
|
|
this._projectRoot = projectRoot;
|
|
|
|
this._preferredRevision = preferredRevision;
|
|
|
|
this._isPuppeteerCore = isPuppeteerCore;
|
|
|
|
// track changes to Launcher configuration via options or environment variables
|
|
|
|
this.__productName = productName;
|
|
|
|
}
|
|
|
|
|
2020-05-07 10:54:55 +00:00
|
|
|
launch(
|
|
|
|
options: LaunchOptions &
|
|
|
|
ChromeArgOptions &
|
|
|
|
BrowserOptions & { product?: string; extraPrefsFirefox?: {} } = {}
|
|
|
|
): Promise<Browser> {
|
|
|
|
if (options.product) this._productName = options.product;
|
2020-05-05 08:36:44 +00:00
|
|
|
return this._launcher.launch(options);
|
|
|
|
}
|
|
|
|
|
2020-05-07 10:54:55 +00:00
|
|
|
connect(
|
|
|
|
options: BrowserOptions & {
|
|
|
|
browserWSEndpoint?: string;
|
|
|
|
browserURL?: string;
|
|
|
|
transport?: ConnectionTransport;
|
|
|
|
product?: string;
|
|
|
|
}
|
|
|
|
): Promise<Browser> {
|
|
|
|
if (options.product) this._productName = options.product;
|
2020-05-05 08:36:44 +00:00
|
|
|
return this._launcher.connect(options);
|
|
|
|
}
|
|
|
|
|
|
|
|
set _productName(name: string) {
|
2020-05-07 10:54:55 +00:00
|
|
|
if (this.__productName !== name) this._changedProduct = true;
|
2020-05-05 08:36:44 +00:00
|
|
|
this.__productName = name;
|
|
|
|
}
|
|
|
|
|
|
|
|
get _productName(): string {
|
|
|
|
return this.__productName;
|
|
|
|
}
|
|
|
|
|
|
|
|
executablePath(): string {
|
|
|
|
return this._launcher.executablePath();
|
|
|
|
}
|
|
|
|
|
|
|
|
get _launcher(): ProductLauncher {
|
2020-05-07 10:54:55 +00:00
|
|
|
if (
|
|
|
|
!this._lazyLauncher ||
|
|
|
|
this._lazyLauncher.product !== this._productName ||
|
|
|
|
this._changedProduct
|
|
|
|
) {
|
2020-05-05 08:36:44 +00:00
|
|
|
// @ts-ignore
|
|
|
|
// eslint-disable-next-line @typescript-eslint/no-var-requires
|
2020-06-18 14:53:23 +00:00
|
|
|
const packageJson = require('../../package.json');
|
2020-05-05 08:36:44 +00:00
|
|
|
switch (this._productName) {
|
|
|
|
case 'firefox':
|
|
|
|
this._preferredRevision = packageJson.puppeteer.firefox_revision;
|
|
|
|
break;
|
|
|
|
case 'chrome':
|
|
|
|
default:
|
|
|
|
this._preferredRevision = packageJson.puppeteer.chromium_revision;
|
|
|
|
}
|
|
|
|
this._changedProduct = false;
|
2020-05-07 10:54:55 +00:00
|
|
|
this._lazyLauncher = Launcher(
|
|
|
|
this._projectRoot,
|
|
|
|
this._preferredRevision,
|
|
|
|
this._isPuppeteerCore,
|
|
|
|
this._productName
|
|
|
|
);
|
2020-05-05 08:36:44 +00:00
|
|
|
}
|
|
|
|
return this._lazyLauncher;
|
|
|
|
}
|
|
|
|
|
|
|
|
get product(): string {
|
|
|
|
return this._launcher.product;
|
|
|
|
}
|
|
|
|
|
|
|
|
get devices(): DevicesMap {
|
|
|
|
return devicesMap;
|
|
|
|
}
|
|
|
|
|
|
|
|
get errors(): PuppeteerErrors {
|
|
|
|
return puppeteerErrors;
|
|
|
|
}
|
|
|
|
|
2020-06-23 05:18:46 +00:00
|
|
|
defaultArgs(options: ChromeArgOptions = {}): string[] {
|
2020-05-05 08:36:44 +00:00
|
|
|
return this._launcher.defaultArgs(options);
|
|
|
|
}
|
|
|
|
|
|
|
|
createBrowserFetcher(options: BrowserFetcherOptions): BrowserFetcher {
|
|
|
|
return new BrowserFetcher(this._projectRoot, options);
|
|
|
|
}
|
|
|
|
|
|
|
|
// eslint-disable-next-line @typescript-eslint/camelcase
|
2020-05-07 10:54:55 +00:00
|
|
|
__experimental_registerCustomQueryHandler(
|
|
|
|
name: string,
|
2020-06-04 10:47:13 +00:00
|
|
|
queryHandler: QueryHandler
|
2020-05-07 10:54:55 +00:00
|
|
|
): void {
|
2020-06-04 10:47:13 +00:00
|
|
|
registerCustomQueryHandler(name, queryHandler);
|
2020-05-05 08:36:44 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// eslint-disable-next-line @typescript-eslint/camelcase
|
|
|
|
__experimental_unregisterCustomQueryHandler(name: string): void {
|
2020-06-04 10:47:13 +00:00
|
|
|
unregisterCustomQueryHandler(name);
|
2020-05-05 08:36:44 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// eslint-disable-next-line @typescript-eslint/camelcase
|
2020-06-04 10:47:13 +00:00
|
|
|
__experimental_customQueryHandlers(): Map<string, QueryHandler> {
|
|
|
|
return customQueryHandlers();
|
2020-05-05 08:36:44 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// eslint-disable-next-line @typescript-eslint/camelcase
|
|
|
|
__experimental_clearQueryHandlers(): void {
|
2020-06-04 10:47:13 +00:00
|
|
|
clearQueryHandlers();
|
2020-05-05 08:36:44 +00:00
|
|
|
}
|
|
|
|
}
|