playwright/tests/library/playwright.config.ts

166 lines
5.3 KiB
TypeScript
Raw Normal View History

/**
* Copyright (c) Microsoft Corporation.
*
* 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.
*/
import { config as loadEnv } from 'dotenv';
loadEnv({ path: path.join(__dirname, '..', '..', '.env') });
import type { Config, PlaywrightTestOptions, PlaywrightWorkerOptions, ReporterDescription } from '@playwright/test';
import * as path from 'path';
2022-04-07 00:57:14 +03:00
import type { TestModeWorkerOptions } from '../config/testModeFixtures';
import type { TestModeName } from '../config/testMode';
2022-04-07 00:57:14 +03:00
import type { CoverageWorkerOptions } from '../config/coverageFixtures';
2021-10-27 18:28:53 +03:00
type BrowserName = 'chromium' | 'firefox' | 'webkit';
const getExecutablePath = (browserName: BrowserName) => {
if (browserName === 'chromium' && process.env.CRPATH)
return process.env.CRPATH;
if (browserName === 'firefox' && process.env.FFPATH)
return process.env.FFPATH;
if (browserName === 'webkit' && process.env.WKPATH)
return process.env.WKPATH;
};
const mode = (process.env.PWTEST_MODE ?? 'default') as TestModeName;
const headed = process.argv.includes('--headed');
const channel = process.env.PWTEST_CHANNEL as any;
const video = !!process.env.PWTEST_VIDEO;
const trace = !!process.env.PWTEST_TRACE;
const outputDir = path.join(__dirname, '..', '..', 'test-results');
const testDir = path.join(__dirname, '..');
const reporters = () => {
const result: ReporterDescription[] = process.env.CI ? [
['dot'],
['json', { outputFile: path.join(outputDir, 'report.json') }],
['blob'],
] : [
['html', { open: 'on-failure' }]
];
return result;
};
const os: 'linux' | 'windows' = (process.env.PLAYWRIGHT_SERVICE_OS as 'linux' | 'windows') || 'linux';
2023-07-27 04:36:33 +03:00
const runId = process.env.PLAYWRIGHT_SERVICE_RUN_ID || new Date().toISOString(); // name the test run
let connectOptions: any;
2023-08-04 18:38:07 +03:00
let webServer: any;
if (mode === 'service') {
connectOptions = { wsEndpoint: 'ws://localhost:3333/' };
2023-08-04 18:38:07 +03:00
webServer = {
command: 'npx playwright run-server --port=3333',
url: 'http://localhost:3333',
reuseExistingServer: !process.env.CI,
};
}
if (mode === 'service2') {
2023-07-31 21:24:04 +03:00
process.env.PW_VERSION_OVERRIDE = '1.37';
connectOptions = {
wsEndpoint: `${process.env.PLAYWRIGHT_SERVICE_URL}?accessKey=${process.env.PLAYWRIGHT_SERVICE_ACCESS_KEY}&cap=${JSON.stringify({ os, runId })}`,
timeout: 3 * 60 * 1000,
exposeNetwork: '<loopback>',
};
}
2023-08-04 18:38:07 +03:00
if (mode === 'service-grid') {
connectOptions = {
wsEndpoint: 'ws://localhost:3333',
2023-08-04 18:38:07 +03:00
timeout: 60 * 60 * 1000,
headers: {
'x-playwright-access-key': 'secret'
}
2023-08-04 18:38:07 +03:00
};
webServer = [
{
command: 'node ../../packages/playwright-grid/cli.js grid --port=3333 --access-key=secret',
stdout: 'pipe',
url: 'http://localhost:3333/secret',
2023-08-04 18:38:07 +03:00
reuseExistingServer: !process.env.CI,
}, {
command: 'node ../../packages/playwright-grid/cli.js node --grid=ws://localhost:3333 --access-key=secret --capacity=2',
2023-08-04 18:38:07 +03:00
},
{
command: 'node ../../packages/playwright-grid/cli.js node --grid=ws://localhost:3333 --access-key=secret --capacity=2',
2023-08-04 18:38:07 +03:00
}
];
}
const config: Config<CoverageWorkerOptions & PlaywrightWorkerOptions & PlaywrightTestOptions & TestModeWorkerOptions> = {
testDir,
outputDir,
expect: {
timeout: 10000,
toHaveScreenshot: { _comparator: 'ssim-cie94' } as any,
toMatchSnapshot: { _comparator: 'ssim-cie94' } as any,
},
maxFailures: 200,
timeout: video ? 60000 : 30000,
globalTimeout: 5400000,
2022-06-24 01:55:12 +03:00
workers: process.env.CI ? 2 : undefined,
fullyParallel: !process.env.CI,
forbidOnly: !!process.env.CI,
retries: process.env.CI ? 3 : 0,
reporter: reporters(),
projects: [],
use: {
connectOptions,
},
2023-08-04 18:38:07 +03:00
webServer,
};
const browserNames = ['chromium', 'webkit', 'firefox'] as BrowserName[];
for (const browserName of browserNames) {
const executablePath = getExecutablePath(browserName);
if (executablePath && !process.env.TEST_WORKER_INDEX)
console.error(`Using executable at ${executablePath}`);
const devtools = process.env.DEVTOOLS === '1';
const testIgnore: RegExp[] = browserNames.filter(b => b !== browserName).map(b => new RegExp(b));
for (const folder of ['library', 'page']) {
config.projects.push({
name: browserName,
testDir: path.join(testDir, folder),
testIgnore,
snapshotPathTemplate: '{testDir}/{testFileDir}/{testFileName}-snapshots/{arg}{-projectName}{ext}',
use: {
mode,
browserName,
headless: !headed,
channel,
video: video ? 'on' : undefined,
launchOptions: {
executablePath,
devtools
},
trace: trace ? 'on' : undefined,
coverageName: browserName,
},
metadata: {
platform: process.platform,
docker: !!process.env.INSIDE_DOCKER,
headful: !!headed,
browserName,
channel,
mode,
video: !!video,
trace: !!trace,
},
});
}
}
export default config;