跳至主要内容

测试使用选项

简介

除了配置测试运行器之外,您还可以配置 模拟网络录制 以用于 浏览器浏览器上下文。这些选项传递到 Playwright 配置中的 use: {} 对象。

基本选项

为所有测试设置基本 URL 和存储状态

playwright.config.ts
import { defineConfig } from '@playwright/test';

export default defineConfig({
use: {
// Base URL to use in actions like `await page.goto('/')`.
baseURL: 'http://127.0.0.1:3000',

// Populates context with given storage state.
storageState: 'state.json',
},
});
选项描述
testOptions.baseURL上下文中的所有页面使用的基本 URL。允许仅使用路径进行导航,例如 page.goto('/settings')
testOptions.storageState使用给定的存储状态填充上下文。对于轻松进行身份验证很有用,了解更多

模拟选项

使用 Playwright,您可以模拟真实的设备,例如手机和平板电脑。有关模拟设备的更多信息,请参阅我们的 项目指南。您还可以模拟所有测试或特定测试的 "geolocation""locale""timezone",以及设置 "permissions" 以显示通知或更改 "colorScheme"。请参阅我们的 模拟 指南以了解更多信息。

playwright.config.ts
import { defineConfig } from '@playwright/test';

export default defineConfig({
use: {
// Emulates `'prefers-colors-scheme'` media feature.
colorScheme: 'dark',

// Context geolocation.
geolocation: { longitude: 12.492507, latitude: 41.889938 },

// Emulates the user locale.
locale: 'en-GB',

// Grants specified permissions to the browser context.
permissions: ['geolocation'],

// Emulates the user timezone.
timezoneId: 'Europe/Paris',

// Viewport used for all pages in the context.
viewport: { width: 1280, height: 720 },
},
});
选项描述
testOptions.colorScheme模拟 'prefers-colors-scheme' 媒体功能,支持的值为 'light''dark''no-preference'
testOptions.geolocation上下文 地理位置
testOptions.locale模拟 用户区域设置,例如 en-GBde-DE 等。
testOptions.permissions要授予上下文中的所有页面的 权限 列表。
testOptions.timezoneId更改上下文的 时区
testOptions.viewport上下文中的所有页面使用的 视口

网络选项

可用于配置网络的选项

playwright.config.ts
import { defineConfig } from '@playwright/test';

export default defineConfig({
use: {
// Whether to automatically download all the attachments.
acceptDownloads: false,

// An object containing additional HTTP headers to be sent with every request.
extraHTTPHeaders: {
'X-My-Header': 'value',
},

// Credentials for HTTP authentication.
httpCredentials: {
username: 'user',
password: 'pass',
},

// Whether to ignore HTTPS errors during navigation.
ignoreHTTPSErrors: true,

// Whether to emulate network being offline.
offline: true,

// Proxy settings used for all pages in the test.
proxy: {
server: 'http://myproxy.com:3128',
bypass: 'localhost',
},
},
});
选项描述
testOptions.acceptDownloads是否自动下载所有附件,默认为 true了解有关 处理下载的更多信息。
testOptions.extraHTTPHeaders包含要与每个请求一起发送的其他 HTTP 标头的对象。所有标头值必须为字符串。
testOptions.httpCredentials用于 HTTP 身份验证 的凭据。
testOptions.ignoreHTTPSErrors在导航期间是否忽略 HTTPS 错误。
testOptions.offline是否模拟网络脱机。
testOptions.proxy测试中所有页面使用的 代理设置
注意

您无需配置任何内容即可模拟网络请求。只需定义一个自定义 路由,即可模拟浏览器上下文的网络。请参阅我们的 网络模拟指南以了解更多信息。

录制选项

使用 Playwright,您可以捕获屏幕截图、录制视频以及测试跟踪。默认情况下,这些功能处于关闭状态,但您可以通过在 playwright.config.js 文件中设置 screenshotvideotrace 选项来启用它们。

跟踪文件、屏幕截图和视频将显示在测试输出目录中,通常为 test-results

playwright.config.ts
import { defineConfig } from '@playwright/test';

export default defineConfig({
use: {
// Capture screenshot after each test failure.
screenshot: 'only-on-failure',

// Record trace only when retrying a test for the first time.
trace: 'on-first-retry',

// Record video only when retrying a test for the first time.
video: 'on-first-retry'
},
});
选项描述
testOptions.screenshot捕获测试的 屏幕截图。选项包括 'off''on''only-on-failure'
testOptions.tracePlaywright 可以在运行测试时生成测试跟踪。稍后,您可以查看跟踪并通过打开 跟踪查看器 获取有关 Playwright 执行的详细信息。选项包括:'off''on''retain-on-failure''on-first-retry'
testOptions.videoPlaywright 可以为您的测试录制 视频。选项包括:'off''on''retain-on-failure''on-first-retry'

其他选项

playwright.config.ts
import { defineConfig } from '@playwright/test';

export default defineConfig({
use: {
// Maximum time each action such as `click()` can take. Defaults to 0 (no limit).
actionTimeout: 0,

// Name of the browser that runs tests. For example `chromium`, `firefox`, `webkit`.
browserName: 'chromium',

// Toggles bypassing Content-Security-Policy.
bypassCSP: true,

// Channel to use, for example "chrome", "chrome-beta", "msedge", "msedge-beta".
channel: 'chrome',

// Run browser in headless mode.
headless: false,

// Change the default data-testid attribute.
testIdAttribute: 'pw-test-id',
},
});
选项描述
testOptions.actionTimeout每个 Playwright 操作的超时时间(毫秒)。默认为 0(无超时)。详细了解 超时 以及如何为单个测试设置超时。
testOptions.browserName运行测试的浏览器的名称。默认为 'chromium'。选项包括 chromiumfirefoxwebkit
testOptions.bypassCSP切换绕过内容安全策略。在 CSP 包含生产来源时很有用。默认为 false
testOptions.channel要使用的浏览器通道。详细了解 不同的浏览器和通道。
testOptions.headless是否以无头模式运行浏览器,这意味着在运行测试时不显示浏览器。默认为 true
testOptions.testIdAttribute更改 Playwright 定位器使用的默认 data-testid 属性

更多浏览器和上下文选项

任何被 browserType.launch()browser.newContext() 接受的选项都可以分别放入 use 部分中的 launchOptionscontextOptions 中。

playwright.config.ts
import { defineConfig } from '@playwright/test';

export default defineConfig({
use: {
launchOptions: {
slowMo: 50,
},
},
});

但是,大多数常用的选项(如 headlessviewport)都直接在 use 部分中可用 - 请参阅 基本选项模拟网络

显式上下文创建和选项继承

如果使用内置的 browser 夹具,则调用 browser.newContext() 将创建一个从配置继承选项的上下文

playwright.config.ts
import { defineConfig } from '@playwright/test';

export default defineConfig({
use: {
userAgent: 'some custom ua',
viewport: { width: 100, height: 100 },
},
});

一个示例测试说明了初始上下文选项是如何设置的

test('should inherit use options on context when using built-in browser fixture', async ({
browser,
}) => {
const context = await browser.newContext();
const page = await context.newPage();
expect(await page.evaluate(() => navigator.userAgent)).toBe('some custom ua');
expect(await page.evaluate(() => window.innerWidth)).toBe(100);
await context.close();
});

配置范围

您可以全局、按项目或按测试配置 Playwright。例如,您可以通过将 locale 添加到 Playwright 配置的 use 选项中来设置要全局使用的区域设置,然后使用配置中的 project 选项为特定项目覆盖它。您还可以通过在测试文件中添加 test.use({}) 并传入选项来为特定测试覆盖它。

playwright.config.ts
import { defineConfig } from '@playwright/test';

export default defineConfig({
use: {
locale: 'en-GB'
},
});

您可以使用 Playwright 配置中的 project 选项覆盖特定项目的选项。

import { defineConfig, devices } from '@playwright/test';

export default defineConfig({
projects: [
{
name: 'chromium',
use: {
...devices['Desktop Chrome'],
locale: 'de-DE',
},
},
],
});

您可以使用 test.use() 方法并传入选项来覆盖特定测试文件的选项。例如,要使用特定测试的法语区域设置运行测试

import { test, expect } from '@playwright/test';

test.use({ locale: 'fr-FR' });

test('example', async ({ page }) => {
// ...
});

这在 describe 块内也适用。例如,要在 describe 块中使用法语区域设置运行测试

import { test, expect } from '@playwright/test';

test.describe('french language block', () => {

test.use({ locale: 'fr-FR' });

test('example', async ({ page }) => {
// ...
});
});