2019-11-19 05:18:28 +03:00
|
|
|
/**
|
|
|
|
* Copyright 2019 Google Inc. All rights reserved.
|
2019-12-11 00:21:51 +03:00
|
|
|
* Modifications copyright (c) Microsoft Corporation.
|
2019-11-19 05:18:28 +03:00
|
|
|
*
|
|
|
|
* 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 fs = require('fs');
|
|
|
|
const path = require('path');
|
2019-12-11 00:22:01 +03:00
|
|
|
const os = require('os');
|
2019-11-19 05:18:28 +03:00
|
|
|
const rm = require('rimraf').sync;
|
|
|
|
const GoldenUtils = require('./golden-utils');
|
|
|
|
const {Matchers} = require('../utils/testrunner/');
|
|
|
|
|
|
|
|
const YELLOW_COLOR = '\x1b[33m';
|
|
|
|
const RESET_COLOR = '\x1b[0m';
|
|
|
|
|
2019-12-19 04:11:45 +03:00
|
|
|
module.exports.describe = ({testRunner, product, playwrightPath}) => {
|
2019-11-19 05:18:28 +03:00
|
|
|
const {describe, xdescribe, fdescribe} = testRunner;
|
2019-12-20 02:47:35 +03:00
|
|
|
const {it, fit, xit, dit} = testRunner;
|
2019-11-19 05:18:28 +03:00
|
|
|
const {beforeAll, beforeEach, afterAll, afterEach} = testRunner;
|
|
|
|
|
2020-01-13 21:13:28 +03:00
|
|
|
const CHROMIUM = product === 'Chromium';
|
2019-11-19 05:18:28 +03:00
|
|
|
const FFOX = product === 'Firefox';
|
|
|
|
const WEBKIT = product === 'WebKit';
|
2019-12-11 00:22:01 +03:00
|
|
|
const MAC = os.platform() === 'darwin';
|
|
|
|
const LINUX = os.platform() === 'linux';
|
|
|
|
const WIN = os.platform() === 'win32';
|
2019-11-19 05:18:28 +03:00
|
|
|
|
2020-01-28 22:20:34 +03:00
|
|
|
const playwrightModule = require(playwrightPath);
|
|
|
|
const playwright = playwrightModule[product.toLowerCase()];
|
2019-11-19 05:18:28 +03:00
|
|
|
|
|
|
|
const headless = (process.env.HEADLESS || 'true').trim().toLowerCase() === 'true';
|
|
|
|
const slowMo = parseInt((process.env.SLOW_MO || '0').trim(), 10);
|
|
|
|
|
|
|
|
const executablePath = {
|
2019-12-18 05:07:01 +03:00
|
|
|
'Chromium': process.env.CRPATH,
|
|
|
|
'Firefox': process.env.FFPATH,
|
|
|
|
'WebKit': process.env.WKPATH,
|
2019-11-19 05:18:28 +03:00
|
|
|
}[product];
|
|
|
|
const defaultBrowserOptions = {
|
|
|
|
handleSIGINT: false,
|
|
|
|
executablePath,
|
|
|
|
slowMo,
|
|
|
|
headless,
|
|
|
|
dumpio: !!process.env.DUMPIO,
|
|
|
|
};
|
|
|
|
|
|
|
|
if (defaultBrowserOptions.executablePath) {
|
|
|
|
console.warn(`${YELLOW_COLOR}WARN: running ${product} tests with ${defaultBrowserOptions.executablePath}${RESET_COLOR}`);
|
|
|
|
} else {
|
|
|
|
// Make sure the `npm install` was run after the chromium roll.
|
|
|
|
if (!fs.existsSync(playwright.executablePath()))
|
|
|
|
throw new Error(`Browser is not downloaded. Run 'npm install' and try to re-run tests`);
|
|
|
|
}
|
|
|
|
|
|
|
|
const GOLDEN_DIR = path.join(__dirname, 'golden-' + product.toLowerCase());
|
|
|
|
const OUTPUT_DIR = path.join(__dirname, 'output-' + product.toLowerCase());
|
2019-11-20 03:29:28 +03:00
|
|
|
const ASSETS_DIR = path.join(__dirname, 'assets');
|
2019-11-19 05:18:28 +03:00
|
|
|
if (fs.existsSync(OUTPUT_DIR))
|
|
|
|
rm(OUTPUT_DIR);
|
|
|
|
const {expect} = new Matchers({
|
|
|
|
toBeGolden: GoldenUtils.compare.bind(null, GOLDEN_DIR, OUTPUT_DIR)
|
|
|
|
});
|
|
|
|
|
|
|
|
const testOptions = {
|
|
|
|
testRunner,
|
|
|
|
product,
|
|
|
|
FFOX,
|
|
|
|
WEBKIT,
|
2020-01-13 21:13:28 +03:00
|
|
|
CHROMIUM,
|
2019-12-11 00:22:01 +03:00
|
|
|
MAC,
|
|
|
|
LINUX,
|
|
|
|
WIN,
|
2019-11-19 05:18:28 +03:00
|
|
|
playwright,
|
2020-01-28 22:20:34 +03:00
|
|
|
selectors: playwrightModule.selectors,
|
2019-11-19 05:18:28 +03:00
|
|
|
expect,
|
|
|
|
defaultBrowserOptions,
|
|
|
|
playwrightPath,
|
|
|
|
headless: !!defaultBrowserOptions.headless,
|
2019-11-20 03:29:28 +03:00
|
|
|
ASSETS_DIR,
|
2019-11-19 05:18:28 +03:00
|
|
|
};
|
|
|
|
|
|
|
|
describe('Browser', function() {
|
|
|
|
beforeAll(async state => {
|
2020-02-05 23:41:55 +03:00
|
|
|
state.browser = await playwright.launch(defaultBrowserOptions);
|
|
|
|
state.browserServer = state.browser.__server__;
|
2019-11-19 05:18:28 +03:00
|
|
|
});
|
|
|
|
|
|
|
|
afterAll(async state => {
|
2020-02-05 23:41:55 +03:00
|
|
|
await state.browserServer.close();
|
2019-11-19 05:18:28 +03:00
|
|
|
state.browser = null;
|
2020-02-05 23:41:55 +03:00
|
|
|
state.browserServer = null;
|
2019-11-19 05:18:28 +03:00
|
|
|
});
|
|
|
|
|
2019-12-18 23:23:33 +03:00
|
|
|
beforeEach(async(state, test) => {
|
|
|
|
const contexts = [];
|
|
|
|
const onLine = (line) => test.output += line + '\n';
|
|
|
|
|
|
|
|
let rl;
|
2020-02-05 23:41:55 +03:00
|
|
|
if (state.browserServer.process().stderr) {
|
|
|
|
rl = require('readline').createInterface({ input: state.browserServer.process().stderr });
|
2019-11-19 05:18:28 +03:00
|
|
|
test.output = '';
|
|
|
|
rl.on('line', onLine);
|
2019-12-18 23:23:33 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
state.tearDown = async () => {
|
|
|
|
await Promise.all(contexts.map(c => c.close()));
|
2020-01-24 04:45:31 +03:00
|
|
|
if (rl) {
|
2019-11-19 05:18:28 +03:00
|
|
|
rl.removeListener('line', onLine);
|
|
|
|
rl.close();
|
|
|
|
}
|
2019-12-18 23:23:33 +03:00
|
|
|
};
|
|
|
|
|
|
|
|
state.newContext = async (options) => {
|
|
|
|
const context = await state.browser.newContext(options);
|
|
|
|
contexts.push(context);
|
|
|
|
return context;
|
|
|
|
};
|
|
|
|
|
|
|
|
state.newPage = async (options) => {
|
2019-12-19 05:07:11 +03:00
|
|
|
const context = await state.newContext(options);
|
2020-01-03 22:17:14 +03:00
|
|
|
return await context.newPage();
|
2019-12-18 23:23:33 +03:00
|
|
|
};
|
|
|
|
});
|
2019-11-19 05:18:28 +03:00
|
|
|
|
2019-12-18 23:23:33 +03:00
|
|
|
afterEach(async state => {
|
|
|
|
await state.tearDown();
|
|
|
|
});
|
2019-11-19 05:18:28 +03:00
|
|
|
|
|
|
|
describe('Page', function() {
|
|
|
|
beforeEach(async state => {
|
2019-12-18 23:23:33 +03:00
|
|
|
state.context = await state.newContext();
|
2019-11-19 05:18:28 +03:00
|
|
|
state.page = await state.context.newPage();
|
|
|
|
});
|
|
|
|
|
|
|
|
afterEach(async state => {
|
|
|
|
state.context = null;
|
|
|
|
state.page = null;
|
|
|
|
});
|
|
|
|
|
|
|
|
// Page-level tests that are given a browser, a context and a page.
|
|
|
|
// Each test is launched in a new browser context.
|
2020-01-03 22:15:43 +03:00
|
|
|
testRunner.loadTests(require('./accessibility.spec.js'), testOptions);
|
2019-12-19 04:11:45 +03:00
|
|
|
testRunner.loadTests(require('./click.spec.js'), testOptions);
|
|
|
|
testRunner.loadTests(require('./cookies.spec.js'), testOptions);
|
|
|
|
testRunner.loadTests(require('./dialog.spec.js'), testOptions);
|
|
|
|
testRunner.loadTests(require('./elementhandle.spec.js'), testOptions);
|
|
|
|
testRunner.loadTests(require('./emulation.spec.js'), testOptions);
|
|
|
|
testRunner.loadTests(require('./evaluation.spec.js'), testOptions);
|
|
|
|
testRunner.loadTests(require('./frame.spec.js'), testOptions);
|
|
|
|
testRunner.loadTests(require('./input.spec.js'), testOptions);
|
|
|
|
testRunner.loadTests(require('./jshandle.spec.js'), testOptions);
|
|
|
|
testRunner.loadTests(require('./keyboard.spec.js'), testOptions);
|
|
|
|
testRunner.loadTests(require('./mouse.spec.js'), testOptions);
|
|
|
|
testRunner.loadTests(require('./navigation.spec.js'), testOptions);
|
|
|
|
testRunner.loadTests(require('./network.spec.js'), testOptions);
|
|
|
|
testRunner.loadTests(require('./page.spec.js'), testOptions);
|
|
|
|
testRunner.loadTests(require('./queryselector.spec.js'), testOptions);
|
|
|
|
testRunner.loadTests(require('./screenshot.spec.js'), testOptions);
|
|
|
|
testRunner.loadTests(require('./waittask.spec.js'), testOptions);
|
2019-12-31 01:05:28 +03:00
|
|
|
testRunner.loadTests(require('./interception.spec.js'), testOptions);
|
2020-01-03 21:14:50 +03:00
|
|
|
testRunner.loadTests(require('./geolocation.spec.js'), testOptions);
|
2020-01-07 23:59:01 +03:00
|
|
|
testRunner.loadTests(require('./workers.spec.js'), testOptions);
|
2020-01-31 19:57:47 +03:00
|
|
|
testRunner.loadTests(require('./capabilities.spec.js'), testOptions);
|
2019-12-07 03:15:27 +03:00
|
|
|
|
2020-01-13 21:13:28 +03:00
|
|
|
if (CHROMIUM) {
|
2019-12-19 04:11:45 +03:00
|
|
|
testRunner.loadTests(require('./chromium/chromium.spec.js'), testOptions);
|
|
|
|
testRunner.loadTests(require('./chromium/coverage.spec.js'), testOptions);
|
|
|
|
testRunner.loadTests(require('./chromium/pdf.spec.js'), testOptions);
|
|
|
|
testRunner.loadTests(require('./chromium/session.spec.js'), testOptions);
|
2019-11-19 05:18:28 +03:00
|
|
|
}
|
2019-12-07 04:37:45 +03:00
|
|
|
|
2020-01-13 21:13:28 +03:00
|
|
|
if (CHROMIUM || FFOX) {
|
2019-12-19 04:11:45 +03:00
|
|
|
testRunner.loadTests(require('./features/permissions.spec.js'), testOptions);
|
2019-12-07 04:37:45 +03:00
|
|
|
}
|
|
|
|
|
2020-01-24 02:32:56 +03:00
|
|
|
if (WEBKIT) {
|
|
|
|
testRunner.loadTests(require('./webkit/provisional.spec.js'), testOptions);
|
|
|
|
}
|
2019-11-19 05:18:28 +03:00
|
|
|
});
|
|
|
|
|
|
|
|
// Browser-level tests that are given a browser.
|
2020-02-05 23:41:55 +03:00
|
|
|
testRunner.loadTests(require('./browser.spec.js'), testOptions);
|
2019-12-19 04:11:45 +03:00
|
|
|
testRunner.loadTests(require('./browsercontext.spec.js'), testOptions);
|
|
|
|
testRunner.loadTests(require('./ignorehttpserrors.spec.js'), testOptions);
|
2019-11-19 05:18:28 +03:00
|
|
|
});
|
|
|
|
|
|
|
|
// Top-level tests that launch Browser themselves.
|
2019-12-19 04:11:45 +03:00
|
|
|
testRunner.loadTests(require('./defaultbrowsercontext.spec.js'), testOptions);
|
|
|
|
testRunner.loadTests(require('./fixtures.spec.js'), testOptions);
|
|
|
|
testRunner.loadTests(require('./launcher.spec.js'), testOptions);
|
2020-01-31 19:54:11 +03:00
|
|
|
testRunner.loadTests(require('./headful.spec.js'), testOptions);
|
2020-02-06 23:41:43 +03:00
|
|
|
testRunner.loadTests(require('./multiclient.spec.js'), testOptions);
|
2019-12-11 01:02:48 +03:00
|
|
|
|
2020-01-13 21:13:28 +03:00
|
|
|
if (CHROMIUM) {
|
2019-12-19 04:11:45 +03:00
|
|
|
testRunner.loadTests(require('./chromium/launcher.spec.js'), testOptions);
|
|
|
|
testRunner.loadTests(require('./chromium/headful.spec.js'), testOptions);
|
|
|
|
testRunner.loadTests(require('./chromium/oopif.spec.js'), testOptions);
|
|
|
|
testRunner.loadTests(require('./chromium/tracing.spec.js'), testOptions);
|
2019-11-19 05:18:28 +03:00
|
|
|
}
|
2019-12-11 01:02:48 +03:00
|
|
|
|
2020-01-11 03:03:10 +03:00
|
|
|
testRunner.loadTests(require('./web.spec.js'), testOptions);
|
2019-11-19 05:18:28 +03:00
|
|
|
};
|