From dd8bd6dcb1e016b387dd53139e12de5130468cfe Mon Sep 17 00:00:00 2001 From: Andrey Lushnikov Date: Tue, 5 Feb 2019 13:17:02 -0800 Subject: [PATCH] test(firefox): support Puppeteer-Firefox specific env variables (#3907) This patch: - adds support to `FFOX` env variable for Puppeteer testsuite - install Firefox preferences when running tests with custom firefox executable References #3889 --- test/puppeteer.spec.js | 15 ++++++++++++++- test/test.js | 13 ++++--------- 2 files changed, 18 insertions(+), 10 deletions(-) diff --git a/test/puppeteer.spec.js b/test/puppeteer.spec.js index 3198a5aeb677f..daff3f0de6707 100644 --- a/test/puppeteer.spec.js +++ b/test/puppeteer.spec.js @@ -22,7 +22,7 @@ const {Matchers} = require('../utils/testrunner/'); const YELLOW_COLOR = '\x1b[33m'; const RESET_COLOR = '\x1b[0m'; -module.exports.addTests = ({testRunner, product, puppeteer, Errors, DeviceDescriptors, defaultBrowserOptions}) => { +module.exports.addTests = ({testRunner, product, puppeteer, Errors, DeviceDescriptors, slowMo, headless}) => { const {describe, xdescribe, fdescribe} = testRunner; const {it, fit, xit} = testRunner; const {beforeAll, beforeEach, afterAll, afterEach} = testRunner; @@ -30,6 +30,14 @@ module.exports.addTests = ({testRunner, product, puppeteer, Errors, DeviceDescri const CHROME = product === 'Chromium'; const FFOX = product === 'Firefox'; + const defaultBrowserOptions = { + handleSIGINT: false, + executablePath: CHROME ? process.env.CHROME : process.env.FFOX, + slowMo, + headless, + dumpio: (process.env.DUMPIO || 'false').trim().toLowerCase() === 'true', + }; + if (defaultBrowserOptions.executablePath) { console.warn(`${YELLOW_COLOR}WARN: running ${product} tests with ${defaultBrowserOptions.executablePath}${RESET_COLOR}`); } else { @@ -59,6 +67,11 @@ module.exports.addTests = ({testRunner, product, puppeteer, Errors, DeviceDescri headless: !!defaultBrowserOptions.headless, }; + beforeAll(async() => { + if (FFOX && defaultBrowserOptions.executablePath) + await require('../experimental/puppeteer-firefox/misc/install-preferences')(defaultBrowserOptions.executablePath); + }); + describe('Browser', function() { beforeAll(async state => { state.browser = await puppeteer.launch(defaultBrowserOptions); diff --git a/test/test.js b/test/test.js index 1b2ede24fd44d..91f87f7357ffa 100644 --- a/test/test.js +++ b/test/test.js @@ -20,13 +20,6 @@ const utils = require('./utils'); const headless = (process.env.HEADLESS || 'true').trim().toLowerCase() === 'true'; const slowMo = parseInt((process.env.SLOW_MO || '0').trim(), 10); -const defaultBrowserOptions = { - handleSIGINT: false, - executablePath: process.env.CHROME, - slowMo, - headless, - dumpio: (process.env.DUMPIO || 'false').trim().toLowerCase() === 'true', -}; let parallel = 1; if (process.env.PPTR_PARALLEL_TESTS) @@ -93,8 +86,9 @@ if (process.env.BROWSER !== 'firefox') { puppeteer: utils.requireRoot('index'), Errors: utils.requireRoot('Errors'), DeviceDescriptors: utils.requireRoot('DeviceDescriptors'), - defaultBrowserOptions, testRunner, + slowMo, + headless, }); if (process.env.COVERAGE) utils.recordAPICoverage(testRunner, require('../lib/api'), CHROMIUM_NO_COVERAGE); @@ -106,8 +100,9 @@ if (process.env.BROWSER !== 'firefox') { puppeteer: require('../experimental/puppeteer-firefox'), Errors: require('../experimental/puppeteer-firefox/Errors'), DeviceDescriptors: utils.requireRoot('DeviceDescriptors'), - defaultBrowserOptions, testRunner, + slowMo, + headless, }); }); }