feat(runner): TestOptions.storageStateName (#18587)

This commit is contained in:
Yury Semikhatsky 2022-11-07 16:27:38 -08:00 committed by GitHub
parent 28d3f48a65
commit d5494edf71
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
5 changed files with 59 additions and 14 deletions

View File

@ -202,6 +202,14 @@ Learn more about [automatic screenshots](../test-configuration.md#automatic-scre
## property: TestOptions.storageState = %%-js-python-context-option-storage-state-%%
* since: v1.10
## property: TestOptions.storageStateName
* since: v1.28
- type: <[string]>
Name of the [Storage] entry that should be used to initialize [`property: TestOptions.storageState`]. The value must be
written to the storage before creatiion of a browser context that uses it (usually in [`property: TestProject.setup`]). If both
this property and [`property: TestOptions.storageState`] are specified, this property will always take precedence.
## property: TestOptions.testIdAttribute
* since: v1.27

View File

@ -151,6 +151,7 @@ export const test = _baseTest.extend<TestFixtures, WorkerFixtures>({
permissions: [({ contextOptions }, use) => use(contextOptions.permissions), { option: true }],
proxy: [({ contextOptions }, use) => use(contextOptions.proxy), { option: true }],
storageState: [({ contextOptions }, use) => use(contextOptions.storageState), { option: true }],
storageStateName: [undefined, { option: true }],
timezoneId: [({ contextOptions }, use) => use(contextOptions.timezoneId), { option: true }],
userAgent: [({ contextOptions }, use) => use(contextOptions.userAgent), { option: true }],
viewport: [({ contextOptions }, use) => use(contextOptions.viewport === undefined ? { width: 1280, height: 720 } : contextOptions.viewport), { option: true }],
@ -180,6 +181,7 @@ export const test = _baseTest.extend<TestFixtures, WorkerFixtures>({
permissions,
proxy,
storageState,
storageStateName,
viewport,
timezoneId,
userAgent,
@ -218,13 +220,13 @@ export const test = _baseTest.extend<TestFixtures, WorkerFixtures>({
options.permissions = permissions;
if (proxy !== undefined)
options.proxy = proxy;
if (storageState !== undefined) {
if (storageStateName !== undefined) {
const value = await test.info().storage().get(storageStateName);
if (!value)
throw new Error(`Cannot find value in the storage for storageStateName: "${storageStateName}"`);
options.storageState = value as any;
} else if (storageState !== undefined) {
options.storageState = storageState;
if (typeof storageState === 'string') {
const value = await test.info().storage().get(storageState);
if (value)
options.storageState = value as any;
}
}
if (timezoneId !== undefined)
options.timezoneId = timezoneId;

View File

@ -2949,6 +2949,15 @@ export interface PlaywrightTestOptions {
* Either a path to the file with saved storage, or an object with the following fields:
*/
storageState: StorageState | undefined;
/**
* Name of the [Storage] entry that should be used to initialize
* [testOptions.storageState](https://playwright.dev/docs/api/class-testoptions#test-options-storage-state). The value must
* be written to the storage before creatiion of a browser context that uses it (usually in
* [testProject.setup](https://playwright.dev/docs/api/class-testproject#test-project-setup)). If both this property and
* [testOptions.storageState](https://playwright.dev/docs/api/class-testoptions#test-options-storage-state) are specified,
* this property will always take precedence.
*/
storageStateName: string | undefined;
/**
* Changes the timezone of the context. See
* [ICU's metaZones.txt](https://cs.chromium.org/chromium/src/third_party/icu/source/data/misc/metaZones.txt?rcl=faee8bc70570192d82d2978a71e2a615788597d1)

View File

@ -204,7 +204,7 @@ test('should load context storageState from storage', async ({ runInlineTest, se
'a.test.ts': `
const { test } = pwt;
test.use({
storageState: 'user'
storageStateName: 'user'
})
test('should get data from setup', async ({ page }) => {
await page.goto('${server.EMPTY_PAGE}');
@ -225,7 +225,7 @@ test('should load context storageState from storage', async ({ runInlineTest, se
expect(result.passed).toBe(3);
});
test('should load storageState specified in the project config from storage', async ({ runInlineTest, server }) => {
test('should load storageStateName specified in the project config from storage', async ({ runInlineTest, server }) => {
server.setRoute('/setcookie.html', (req, res) => {
res.setHeader('Set-Cookie', ['a=v1']);
res.end();
@ -238,7 +238,7 @@ test('should load storageState specified in the project config from storage', as
name: 'p1',
setup: /.*storage.setup.ts/,
use: {
storageState: 'stateInStorage',
storageStateName: 'stateInStorage',
},
}
]
@ -247,7 +247,7 @@ test('should load storageState specified in the project config from storage', as
'storage.setup.ts': `
const { test, expect } = pwt;
test.reset({
storageState: 'default'
storageStateName: 'default'
})
test('should save storageState', async ({ page, context }) => {
const storage = test.info().storage();
@ -270,7 +270,7 @@ test('should load storageState specified in the project config from storage', as
expect(result.passed).toBe(2);
});
test('should load storageState specified in the global config from storage', async ({ runInlineTest, server }) => {
test('should load storageStateName specified in the global config from storage', async ({ runInlineTest, server }) => {
server.setRoute('/setcookie.html', (req, res) => {
res.setHeader('Set-Cookie', ['a=v1']);
res.end();
@ -279,7 +279,7 @@ test('should load storageState specified in the global config from storage', asy
'playwright.config.js': `
module.exports = {
use: {
storageState: 'stateInStorage',
storageStateName: 'stateInStorage',
},
projects: [
{
@ -292,9 +292,9 @@ test('should load storageState specified in the global config from storage', asy
'storage.setup.ts': `
const { test, expect } = pwt;
test.reset({
storageState: 'default'
storageStateName: 'default'
})
test('should save storageState', async ({ page, context }) => {
test('should save storageStateName', async ({ page, context }) => {
const storage = test.info().storage();
expect(await storage.get('stateInStorage')).toBe(undefined);
await page.goto('${server.PREFIX}/setcookie.html');
@ -313,4 +313,29 @@ test('should load storageState specified in the global config from storage', asy
}, { workers: 1 });
expect(result.exitCode).toBe(0);
expect(result.passed).toBe(2);
});
test('should throw on unknown storageStateName value', async ({ runInlineTest, server }) => {
const result = await runInlineTest({
'playwright.config.js': `
module.exports = {
projects: [
{
name: 'p1',
use: {
storageStateName: 'stateInStorage',
},
}
]
};
`,
'a.test.ts': `
const { test } = pwt;
test('should fail to initialize page', async ({ page }) => {
});
`,
}, { workers: 1 });
expect(result.exitCode).toBe(1);
expect(result.passed).toBe(0);
expect(result.output).toContain('Error: Cannot find value in the storage for storageStateName: "stateInStorage"');
});

View File

@ -235,6 +235,7 @@ export interface PlaywrightTestOptions {
permissions: string[] | undefined;
proxy: Proxy | undefined;
storageState: StorageState | undefined;
storageStateName: string | undefined;
timezoneId: string | undefined;
userAgent: string | undefined;
viewport: ViewportSize | null | undefined;