refactor: do not pass user options to browser constructor (#2562)
This patch starts explicitly passing allowed options to the `Browser` class. This, for example, makes it impossible to pass `appMode` as an option to the `pptr.connect`.
This commit is contained in:
parent
2d82e0891a
commit
51645932b7
@ -23,14 +23,15 @@ class Browser extends EventEmitter {
|
|||||||
/**
|
/**
|
||||||
* @param {!Puppeteer.Connection} connection
|
* @param {!Puppeteer.Connection} connection
|
||||||
* @param {!Array<string>} contextIds
|
* @param {!Array<string>} contextIds
|
||||||
* @param {!BrowserOptions=} options
|
* @param {boolean} ignoreHTTPSErrors
|
||||||
|
* @param {boolean} setDefaultViewport
|
||||||
* @param {?Puppeteer.ChildProcess} process
|
* @param {?Puppeteer.ChildProcess} process
|
||||||
* @param {(function():Promise)=} closeCallback
|
* @param {(function():Promise)=} closeCallback
|
||||||
*/
|
*/
|
||||||
constructor(connection, contextIds, options = {}, process, closeCallback) {
|
constructor(connection, contextIds, ignoreHTTPSErrors, setDefaultViewport, process, closeCallback) {
|
||||||
super();
|
super();
|
||||||
this._ignoreHTTPSErrors = !!options.ignoreHTTPSErrors;
|
this._ignoreHTTPSErrors = ignoreHTTPSErrors;
|
||||||
this._appMode = !!options.appMode;
|
this._setDefaultViewport = setDefaultViewport;
|
||||||
this._process = process;
|
this._process = process;
|
||||||
this._screenshotTaskQueue = new TaskQueue();
|
this._screenshotTaskQueue = new TaskQueue();
|
||||||
this._connection = connection;
|
this._connection = connection;
|
||||||
@ -87,12 +88,13 @@ class Browser extends EventEmitter {
|
|||||||
/**
|
/**
|
||||||
* @param {!Puppeteer.Connection} connection
|
* @param {!Puppeteer.Connection} connection
|
||||||
* @param {!Array<string>} contextIds
|
* @param {!Array<string>} contextIds
|
||||||
* @param {!BrowserOptions=} options
|
* @param {boolean} ignoreHTTPSErrors
|
||||||
|
* @param {boolean} appMode
|
||||||
* @param {?Puppeteer.ChildProcess} process
|
* @param {?Puppeteer.ChildProcess} process
|
||||||
* @param {function()=} closeCallback
|
* @param {function()=} closeCallback
|
||||||
*/
|
*/
|
||||||
static async create(connection, contextIds, options, process, closeCallback) {
|
static async create(connection, contextIds, ignoreHTTPSErrors, appMode, process, closeCallback) {
|
||||||
const browser = new Browser(connection, contextIds, options, process, closeCallback);
|
const browser = new Browser(connection, contextIds, ignoreHTTPSErrors, appMode, process, closeCallback);
|
||||||
await connection.send('Target.setDiscoverTargets', {discover: true});
|
await connection.send('Target.setDiscoverTargets', {discover: true});
|
||||||
return browser;
|
return browser;
|
||||||
}
|
}
|
||||||
@ -105,7 +107,7 @@ class Browser extends EventEmitter {
|
|||||||
const {browserContextId} = targetInfo;
|
const {browserContextId} = targetInfo;
|
||||||
const context = (browserContextId && this._contexts.has(browserContextId)) ? this._contexts.get(browserContextId) : this._defaultContext;
|
const context = (browserContextId && this._contexts.has(browserContextId)) ? this._contexts.get(browserContextId) : this._defaultContext;
|
||||||
|
|
||||||
const target = new Target(targetInfo, context, () => this._connection.createSession(targetInfo.targetId), this._ignoreHTTPSErrors, !this._appMode, this._screenshotTaskQueue);
|
const target = new Target(targetInfo, context, () => this._connection.createSession(targetInfo.targetId), this._ignoreHTTPSErrors, this._setDefaultViewport, this._screenshotTaskQueue);
|
||||||
console.assert(!this._targets.has(event.targetInfo.targetId), 'Target should not exist before targetCreated');
|
console.assert(!this._targets.has(event.targetInfo.targetId), 'Target should not exist before targetCreated');
|
||||||
this._targets.set(event.targetInfo.targetId, target);
|
this._targets.set(event.targetInfo.targetId, target);
|
||||||
|
|
||||||
|
@ -159,7 +159,9 @@ class Launcher {
|
|||||||
} else {
|
} else {
|
||||||
connection = Connection.createForPipe(/** @type {!NodeJS.WritableStream} */(chromeProcess.stdio[3]), /** @type {!NodeJS.ReadableStream} */ (chromeProcess.stdio[4]), connectionDelay);
|
connection = Connection.createForPipe(/** @type {!NodeJS.WritableStream} */(chromeProcess.stdio[3]), /** @type {!NodeJS.ReadableStream} */ (chromeProcess.stdio[4]), connectionDelay);
|
||||||
}
|
}
|
||||||
return Browser.create(connection, [], options, chromeProcess, gracefullyCloseChrome);
|
const ignoreHTTPSErrors = !!options.ignoreHTTPSErrors;
|
||||||
|
const setDefaultViewport = !options.appMode;
|
||||||
|
return Browser.create(connection, [], ignoreHTTPSErrors, setDefaultViewport, chromeProcess, gracefullyCloseChrome);
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
killChrome();
|
killChrome();
|
||||||
throw e;
|
throw e;
|
||||||
@ -227,7 +229,8 @@ class Launcher {
|
|||||||
const connectionDelay = options.slowMo || 0;
|
const connectionDelay = options.slowMo || 0;
|
||||||
const connection = await Connection.createForWebSocket(options.browserWSEndpoint, connectionDelay);
|
const connection = await Connection.createForWebSocket(options.browserWSEndpoint, connectionDelay);
|
||||||
const {browserContextIds} = await connection.send('Target.getBrowserContexts');
|
const {browserContextIds} = await connection.send('Target.getBrowserContexts');
|
||||||
return Browser.create(connection, browserContextIds, options, null, () => connection.send('Browser.close').catch(debugError));
|
const ignoreHTTPSErrors = !!options.ignoreHTTPSErrors;
|
||||||
|
return Browser.create(connection, browserContextIds, ignoreHTTPSErrors, true /* setDefaultViewport */, null, () => connection.send('Browser.close').catch(debugError));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user