2021-09-17 17:13:47 -07:00
# class: TestOptions
2022-07-05 16:24:50 -08:00
* since: v1.10
2021-09-17 17:13:47 -07:00
* langs: js
Playwright Test provides many options to configure test environment, [Browser], [BrowserContext] and more.
2022-03-25 19:30:45 +01:00
These options are usually provided in the [configuration file ](../test-configuration.md ) through [`property: TestConfig.use` ] and [`property: TestProject.use` ].
2021-09-17 17:13:47 -07:00
2022-06-10 16:34:31 -08:00
```js tab=js-js
2021-09-17 17:13:47 -07:00
// @ts -check
/** @type {import('@playwright/test ').PlaywrightTestConfig} */
const config = {
use: {
headless: false,
viewport: { width: 1280, height: 720 },
ignoreHTTPSErrors: true,
video: 'on-first-retry',
},
};
module.exports = config;
```
2022-06-10 16:34:31 -08:00
```js tab=js-ts
2022-05-27 12:36:59 -07:00
import type { PlaywrightTestConfig } from '@playwright/test ';
2021-09-17 17:13:47 -07:00
const config: PlaywrightTestConfig = {
use: {
headless: false,
viewport: { width: 1280, height: 720 },
ignoreHTTPSErrors: true,
video: 'on-first-retry',
},
};
export default config;
```
Alternatively, with [`method: Test.use` ] you can override some options for a file.
2022-06-10 16:34:31 -08:00
```js tab=js-js
2021-09-17 17:13:47 -07:00
// example.spec.js
const { test, expect } = require('@playwright/test ');
// Run tests in this file with portrait-like viewport.
test.use({ viewport: { width: 600, height: 900 } });
test('my portrait test', async ({ page }) => {
// ...
});
```
2022-06-10 16:34:31 -08:00
```js tab=js-ts
2021-09-17 17:13:47 -07:00
// example.spec.ts
import { test, expect } from '@playwright/test ';
// Run tests in this file with portrait-like viewport.
test.use({ viewport: { width: 600, height: 900 } });
test('my portrait test', async ({ page }) => {
// ...
});
```
## property: TestOptions.acceptDownloads = %%-context-option-acceptdownloads-%%
2022-07-05 16:24:50 -08:00
* since: v1.10
2021-09-17 17:13:47 -07:00
## property: TestOptions.baseURL = %%-context-option-baseURL-%%
2022-07-05 16:24:50 -08:00
* since: v1.10
2021-09-17 17:13:47 -07:00
## property: TestOptions.browserName
2022-07-05 16:24:50 -08:00
* since: v1.10
2021-09-17 17:13:47 -07:00
- type: < [BrowserName]< "chromium"|"firefox"|"webkit">>
Name of the browser that runs tests. Defaults to `'chromium'` . Most of the time you should set `browserName` in your [TestConfig]:
2022-06-10 16:34:31 -08:00
```js tab=js-js
2021-09-17 17:13:47 -07:00
// playwright.config.js
// @ts -check
/** @type {import('@playwright/test ').PlaywrightTestConfig} */
const config = {
use: {
browserName: 'firefox',
},
};
module.exports = config;
```
2022-06-10 16:34:31 -08:00
```js tab=js-ts
2021-09-17 17:13:47 -07:00
// playwright.config.ts
2022-05-27 12:36:59 -07:00
import { type PlaywrightTestConfig, devices } from '@playwright/test ';
2021-09-17 17:13:47 -07:00
const config: PlaywrightTestConfig = {
use: {
browserName: 'firefox',
},
};
export default config;
```
## property: TestOptions.actionTimeout
2022-07-05 16:24:50 -08:00
* since: v1.10
2021-09-17 17:13:47 -07:00
- type: < [int]>
Default timeout for each Playwright action in milliseconds, defaults to 0 (no timeout).
This is a default timeout for all Playwright actions, same as configured via [`method: Page.setDefaultTimeout` ].
2022-03-25 19:30:45 +01:00
Learn more about [various timeouts ](../test-timeouts.md ).
2021-11-19 17:06:46 -08:00
2021-09-17 17:13:47 -07:00
## property: TestOptions.bypassCSP = %%-context-option-bypasscsp-%%
2022-07-05 16:24:50 -08:00
* since: v1.10
2021-09-17 17:13:47 -07:00
## property: TestOptions.channel = %%-browser-option-channel-%%
2022-07-05 16:24:50 -08:00
* since: v1.10
2021-09-17 17:13:47 -07:00
## property: TestOptions.colorScheme = %%-context-option-colorscheme-%%
2022-07-05 16:24:50 -08:00
* since: v1.10
2021-09-17 17:13:47 -07:00
2022-02-08 20:45:42 -08:00
## property: TestOptions.connectOptions
2022-07-05 16:24:50 -08:00
* since: v1.10
2022-02-08 20:45:42 -08:00
- type: < [void]|[Object]>
- `wsEndpoint` < [string]> A browser websocket endpoint to connect to.
2022-04-06 19:02:10 -07:00
- `headers` ?< [void]|[Object]< [string], [string]>> Additional HTTP headers to be sent with web socket connect request. Optional.
- `timeout` ?< [int]> Timeout in milliseconds for the connection to be established. Optional, defaults to no timeout.
2022-02-08 20:45:42 -08:00
When connect options are specified, default [`property: Fixtures.browser` ], [`property: Fixtures.context` ] and [`property: Fixtures.page` ] use the remote browser instead of launching a browser locally, and any launch options like [`property: TestOptions.headless` ] or [`property: TestOptions.channel` ] are ignored.
2021-09-17 17:13:47 -07:00
## property: TestOptions.contextOptions
2022-07-05 16:24:50 -08:00
* since: v1.10
2021-09-17 17:13:47 -07:00
- type: < [Object]>
Options used to create the context, as passed to [`method: Browser.newContext` ]. Specific options like [`property: TestOptions.viewport` ] take priority over this.
## property: TestOptions.deviceScaleFactor = %%-context-option-devicescalefactor-%%
2022-07-05 16:24:50 -08:00
* since: v1.10
2021-09-17 17:13:47 -07:00
## property: TestOptions.extraHTTPHeaders = %%-context-option-extrahttpheaders-%%
2022-07-05 16:24:50 -08:00
* since: v1.10
2021-09-17 17:13:47 -07:00
## property: TestOptions.geolocation = %%-context-option-geolocation-%%
2022-07-05 16:24:50 -08:00
* since: v1.10
2021-09-17 17:13:47 -07:00
## property: TestOptions.hasTouch = %%-context-option-hastouch-%%
2022-07-05 16:24:50 -08:00
* since: v1.10
2021-09-17 17:13:47 -07:00
## property: TestOptions.headless = %%-browser-option-headless-%%
2022-07-05 16:24:50 -08:00
* since: v1.10
2021-09-17 17:13:47 -07:00
## property: TestOptions.httpCredentials = %%-context-option-httpcredentials-%%
2022-07-05 16:24:50 -08:00
* since: v1.10
2021-09-17 17:13:47 -07:00
## property: TestOptions.ignoreHTTPSErrors = %%-context-option-ignorehttpserrors-%%
2022-07-05 16:24:50 -08:00
* since: v1.10
2021-09-17 17:13:47 -07:00
## property: TestOptions.isMobile = %%-context-option-ismobile-%%
2022-07-05 16:24:50 -08:00
* since: v1.10
2021-09-17 17:13:47 -07:00
## property: TestOptions.javaScriptEnabled = %%-context-option-javascriptenabled-%%
2022-07-05 16:24:50 -08:00
* since: v1.10
2021-09-17 17:13:47 -07:00
## property: TestOptions.launchOptions
2022-07-05 16:24:50 -08:00
* since: v1.10
2021-09-17 17:13:47 -07:00
- type: < [Object]>
Options used to launch the browser, as passed to [`method: BrowserType.launch` ]. Specific options [`property: TestOptions.headless` ] and [`property: TestOptions.channel` ] take priority over this.
## property: TestOptions.locale = %%-context-option-locale-%%
2022-07-05 16:24:50 -08:00
* since: v1.10
2021-09-17 17:13:47 -07:00
## property: TestOptions.navigationTimeout
2022-07-05 16:24:50 -08:00
* since: v1.10
2021-09-17 17:13:47 -07:00
- type: < [int]>
Timeout for each navigation action in milliseconds. Defaults to 0 (no timeout).
This is a default navigation timeout, same as configured via [`method: Page.setDefaultNavigationTimeout` ].
2022-03-25 19:30:45 +01:00
Learn more about [various timeouts ](../test-timeouts.md ).
2021-11-19 17:06:46 -08:00
2021-09-17 17:13:47 -07:00
## property: TestOptions.offline = %%-context-option-offline-%%
2022-07-05 16:24:50 -08:00
* since: v1.10
2021-09-17 17:13:47 -07:00
## property: TestOptions.permissions = %%-context-option-permissions-%%
2022-07-05 16:24:50 -08:00
* since: v1.10
2021-09-17 17:13:47 -07:00
## property: TestOptions.proxy = %%-browser-option-proxy-%%
2022-07-05 16:24:50 -08:00
* since: v1.10
2021-09-17 17:13:47 -07:00
## property: TestOptions.screenshot
2022-07-05 16:24:50 -08:00
* since: v1.10
2021-09-17 17:13:47 -07:00
- type: < [Screenshot]< "off"|"on"|"only-on-failure">>
Whether to automatically capture a screenshot after each test. Defaults to `'off'` .
* `'off'` : Do not capture screenshots.
* `'on'` : Capture screenshot after each test.
* `'only-on-failure'` : Capture screenshot after each test failure.
2022-03-25 19:30:45 +01:00
Learn more about [automatic screenshots ](../test-configuration.md#automatic-screenshots ).
2021-09-17 17:13:47 -07:00
## property: TestOptions.storageState = %%-js-python-context-option-storage-state-%%
2022-07-05 16:24:50 -08:00
* since: v1.10
2021-09-17 17:13:47 -07:00
## property: TestOptions.timezoneId = %%-context-option-timezoneid-%%
2022-07-05 16:24:50 -08:00
* since: v1.10
2021-09-17 17:13:47 -07:00
## property: TestOptions.trace
2022-07-05 16:24:50 -08:00
* since: v1.10
2021-11-08 15:39:58 -08:00
- type: < [Object]|[TraceMode]< "off"|"on"|"retain-on-failure"|"on-first-retry">>
- `mode` < [TraceMode]< "off"|"on"|"retain-on-failure"|"on-first-retry">> Trace recording mode.
2022-04-06 19:02:10 -07:00
- `screenshots` ?< [boolean]> Whether to capture screenshots during tracing. Screenshots are used to build a timeline preview. Defaults to true. Optional.
- `snapshots` ?< [boolean]> Whether to capture DOM snapshot on every action. Defaults to true. Optional.
- `sources` ?< [boolean]> Whether to include source files for trace actions. Defaults to true. Optional.
2021-11-08 15:39:58 -08:00
Whether to record trace for each test. Defaults to `'off'` .
* `'off'` : Do not record trace.
* `'on'` : Record trace for each test.
* `'retain-on-failure'` : Record trace for each test, but remove all traces from successful test runs.
* `'on-first-retry'` : Record trace only when retrying a test for the first time.
2021-09-17 17:13:47 -07:00
2021-12-10 11:15:01 -08:00
For more control, pass an object that specifies `mode` and trace features to enable.
2022-03-25 19:30:45 +01:00
Learn more about [recording trace ](../test-configuration.md#record-test-trace ).
2021-09-17 17:13:47 -07:00
## property: TestOptions.userAgent = %%-context-option-useragent-%%
2022-07-05 16:24:50 -08:00
* since: v1.10
2021-09-17 17:13:47 -07:00
## property: TestOptions.video
2022-07-05 16:24:50 -08:00
* since: v1.10
2021-09-17 17:13:47 -07:00
- type: < [Object]|[VideoMode]< "off"|"on"|"retain-on-failure"|"on-first-retry">>
- `mode` < [VideoMode]< "off"|"on"|"retain-on-failure"|"on-first-retry">> Video recording mode.
2022-04-06 19:02:10 -07:00
- `size` ?< [Object]> Size of the recorded video. Optional.
2021-09-17 17:13:47 -07:00
- `width` < [int]>
- `height` < [int]>
Whether to record video for each test. Defaults to `'off'` .
* `'off'` : Do not record video.
* `'on'` : Record video for each test.
* `'retain-on-failure'` : Record video for each test, but remove all videos from successful test runs.
* `'on-first-retry'` : Record video only when retrying a test for the first time.
2021-12-10 11:15:01 -08:00
To control video size, pass an object with `mode` and `size` properties. If video size is not specified, it will be equal to [`property: TestOptions.viewport` ] scaled down to fit into 800x800. If `viewport` is not configured explicitly the video size defaults to 800x450. Actual picture of each page will be scaled down if necessary to fit the specified size.
2021-12-09 07:38:58 -08:00
2022-03-25 19:30:45 +01:00
Learn more about [recording video ](../test-configuration.md#record-video ).
2021-09-17 17:13:47 -07:00
## property: TestOptions.viewport = %%-context-option-viewport-%%
2022-07-05 16:24:50 -08:00
* since: v1.10
2021-09-17 17:13:47 -07:00
2022-06-08 18:27:51 -04:00
## property: TestOptions.serviceWorkers = %%-context-option-service-worker-policy-%%
2022-07-05 16:24:50 -08:00
* since: v1.10