c5a72e9887
* feat: Set which browser to launch via PUPPETEER_PRODUCT This change introduces a PUPPETEER_PRODUCT environment variable as a first step toward using Puppeteer with many different browsers. Setting PUPPETEER_PRODUCT=firefox, for example, enables Firefox-specific Launcher settings. The state is also exposed as `puppeteer.product` in the API to support adding other product-specific behaviour as needed. The bulk of the change is a refactoring in Launcher to decouple generic browser start-up from product-specific configuration. Respecting the puppeteer-core restriction for PUPPETEER_ environment variables, lazily instantiate the Launcher based on a `product` Puppeteer.launch option, if available. * test: Distinguish Juggler unit tests from Firefox The funit script is renamed to fjunit (j for Juggler, which is used only by the experimental puppeteer-firefox package. In contrast, the funit script now refers to running Puppeteer unit tests against the main puppeteer package with Firefox. To do so with Firefox Nightly, run: `BINARY=path/to/firefox npm run funit` A number of changes in this patch make it easier to run Puppeteer unit tests in Mozilla's CI.
39 lines
1.5 KiB
JavaScript
39 lines
1.5 KiB
JavaScript
/**
|
|
* 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.
|
|
*/
|
|
|
|
const {helper} = require('./lib/helper');
|
|
const api = require('./lib/api');
|
|
for (const className in api) {
|
|
// Puppeteer-web excludes certain classes from bundle, e.g. BrowserFetcher.
|
|
if (typeof api[className] === 'function')
|
|
helper.installAsyncStackHooks(api[className]);
|
|
}
|
|
|
|
// If node does not support async await, use the compiled version.
|
|
const Puppeteer = require('./lib/Puppeteer');
|
|
const packageJson = require('./package.json');
|
|
const preferredRevision = packageJson.puppeteer.chromium_revision;
|
|
const isPuppeteerCore = packageJson.name === 'puppeteer-core';
|
|
|
|
const puppeteer = new Puppeteer(__dirname, preferredRevision, isPuppeteerCore);
|
|
|
|
// The introspection in `Helper.installAsyncStackHooks` references `Puppeteer._launcher`
|
|
// before the Puppeteer ctor is called, such that an invalid Launcher is selected at import,
|
|
// so we reset it.
|
|
puppeteer._lazyLauncher = undefined;
|
|
|
|
module.exports = puppeteer;
|