2021-10-27 18:28:53 +03:00
|
|
|
/**
|
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
feat(test runner): replace declare/define with "options" (#10293)
1. Fixtures defined in test.extend() can now have `{ option: true }` configuration that makes them overridable in the config. Options support all other properties of fixtures - value/function, scope, auto.
```
const test = base.extend<MyOptions>({
foo: ['default', { option: true }],
});
```
2. test.declare() and project.define are removed.
3. project.use applies overrides to default option values and nothing else. Any test.extend() and test.use() calls take priority over config options.
Required user changes: if someone used to define fixture options with test.extend(), overriding them in config will stop working. The solution is to add `{ option: true }`.
```
// Old code
export const test = base.extend<{ myOption: number, myFixture: number }>({
myOption: 123,
myFixture: ({ myOption }, use) => use(2 * myOption),
});
// New code
export const test = base.extend<{ myOption: number, myFixture: number }>({
myOption: [123, { option: true }],
myFixture: ({ myOption }, use) => use(2 * myOption),
});
```
2021-11-19 02:45:52 +03:00
|
|
|
import { test } from '@playwright/test';
|
2022-04-07 00:57:14 +03:00
|
|
|
import type { TestModeName } from './testMode';
|
2022-04-15 01:30:04 +03:00
|
|
|
import { DefaultTestMode, DriverTestMode } from './testMode';
|
2022-09-07 00:15:53 +03:00
|
|
|
import * as playwrightLibrary from 'playwright-core';
|
2021-10-27 18:28:53 +03:00
|
|
|
|
feat(test runner): replace declare/define with "options" (#10293)
1. Fixtures defined in test.extend() can now have `{ option: true }` configuration that makes them overridable in the config. Options support all other properties of fixtures - value/function, scope, auto.
```
const test = base.extend<MyOptions>({
foo: ['default', { option: true }],
});
```
2. test.declare() and project.define are removed.
3. project.use applies overrides to default option values and nothing else. Any test.extend() and test.use() calls take priority over config options.
Required user changes: if someone used to define fixture options with test.extend(), overriding them in config will stop working. The solution is to add `{ option: true }`.
```
// Old code
export const test = base.extend<{ myOption: number, myFixture: number }>({
myOption: 123,
myFixture: ({ myOption }, use) => use(2 * myOption),
});
// New code
export const test = base.extend<{ myOption: number, myFixture: number }>({
myOption: [123, { option: true }],
myFixture: ({ myOption }, use) => use(2 * myOption),
});
```
2021-11-19 02:45:52 +03:00
|
|
|
export type TestModeWorkerOptions = {
|
2021-10-27 18:28:53 +03:00
|
|
|
mode: TestModeName;
|
|
|
|
};
|
|
|
|
|
2022-08-01 00:31:17 +03:00
|
|
|
export type TestModeTestFixtures = {
|
|
|
|
toImpl: (rpcObject?: any) => any;
|
|
|
|
};
|
|
|
|
|
feat(test runner): replace declare/define with "options" (#10293)
1. Fixtures defined in test.extend() can now have `{ option: true }` configuration that makes them overridable in the config. Options support all other properties of fixtures - value/function, scope, auto.
```
const test = base.extend<MyOptions>({
foo: ['default', { option: true }],
});
```
2. test.declare() and project.define are removed.
3. project.use applies overrides to default option values and nothing else. Any test.extend() and test.use() calls take priority over config options.
Required user changes: if someone used to define fixture options with test.extend(), overriding them in config will stop working. The solution is to add `{ option: true }`.
```
// Old code
export const test = base.extend<{ myOption: number, myFixture: number }>({
myOption: 123,
myFixture: ({ myOption }, use) => use(2 * myOption),
});
// New code
export const test = base.extend<{ myOption: number, myFixture: number }>({
myOption: [123, { option: true }],
myFixture: ({ myOption }, use) => use(2 * myOption),
});
```
2021-11-19 02:45:52 +03:00
|
|
|
export type TestModeWorkerFixtures = {
|
2022-08-01 00:31:17 +03:00
|
|
|
toImplInWorkerScope: (rpcObject?: any) => any;
|
feat(test runner): replace declare/define with "options" (#10293)
1. Fixtures defined in test.extend() can now have `{ option: true }` configuration that makes them overridable in the config. Options support all other properties of fixtures - value/function, scope, auto.
```
const test = base.extend<MyOptions>({
foo: ['default', { option: true }],
});
```
2. test.declare() and project.define are removed.
3. project.use applies overrides to default option values and nothing else. Any test.extend() and test.use() calls take priority over config options.
Required user changes: if someone used to define fixture options with test.extend(), overriding them in config will stop working. The solution is to add `{ option: true }`.
```
// Old code
export const test = base.extend<{ myOption: number, myFixture: number }>({
myOption: 123,
myFixture: ({ myOption }, use) => use(2 * myOption),
});
// New code
export const test = base.extend<{ myOption: number, myFixture: number }>({
myOption: [123, { option: true }],
myFixture: ({ myOption }, use) => use(2 * myOption),
});
```
2021-11-19 02:45:52 +03:00
|
|
|
playwright: typeof import('@playwright/test');
|
2024-05-30 04:05:17 +03:00
|
|
|
_playwrightImpl: typeof import('@playwright/test');
|
feat(test runner): replace declare/define with "options" (#10293)
1. Fixtures defined in test.extend() can now have `{ option: true }` configuration that makes them overridable in the config. Options support all other properties of fixtures - value/function, scope, auto.
```
const test = base.extend<MyOptions>({
foo: ['default', { option: true }],
});
```
2. test.declare() and project.define are removed.
3. project.use applies overrides to default option values and nothing else. Any test.extend() and test.use() calls take priority over config options.
Required user changes: if someone used to define fixture options with test.extend(), overriding them in config will stop working. The solution is to add `{ option: true }`.
```
// Old code
export const test = base.extend<{ myOption: number, myFixture: number }>({
myOption: 123,
myFixture: ({ myOption }, use) => use(2 * myOption),
});
// New code
export const test = base.extend<{ myOption: number, myFixture: number }>({
myOption: [123, { option: true }],
myFixture: ({ myOption }, use) => use(2 * myOption),
});
```
2021-11-19 02:45:52 +03:00
|
|
|
};
|
2021-10-27 18:28:53 +03:00
|
|
|
|
2022-08-01 00:31:17 +03:00
|
|
|
export const testModeTest = test.extend<TestModeTestFixtures, TestModeWorkerOptions & TestModeWorkerFixtures>({
|
2022-08-18 21:12:33 +03:00
|
|
|
mode: ['default', { scope: 'worker', option: true }],
|
2024-05-30 04:05:17 +03:00
|
|
|
_playwrightImpl: [async ({ mode }, run) => {
|
2021-10-27 18:28:53 +03:00
|
|
|
const testMode = {
|
2023-08-04 18:38:07 +03:00
|
|
|
'default': new DefaultTestMode(),
|
|
|
|
'service': new DefaultTestMode(),
|
|
|
|
'service2': new DefaultTestMode(),
|
|
|
|
'service-grid': new DefaultTestMode(),
|
|
|
|
'driver': new DriverTestMode(),
|
2021-10-27 18:28:53 +03:00
|
|
|
}[mode];
|
2022-04-07 23:55:44 +03:00
|
|
|
require('playwright-core/lib/utils').setUnderTest();
|
2021-10-27 18:28:53 +03:00
|
|
|
const playwright = await testMode.setup();
|
2022-09-07 00:15:53 +03:00
|
|
|
playwright._setSelectors(playwrightLibrary.selectors);
|
2021-10-27 18:28:53 +03:00
|
|
|
await run(playwright);
|
|
|
|
await testMode.teardown();
|
2022-08-18 21:12:33 +03:00
|
|
|
}, { scope: 'worker' }],
|
2021-10-27 18:28:53 +03:00
|
|
|
|
2022-08-01 00:31:17 +03:00
|
|
|
toImplInWorkerScope: [async ({ playwright }, use) => {
|
|
|
|
await use((playwright as any)._toImpl);
|
|
|
|
}, { scope: 'worker' }],
|
|
|
|
|
|
|
|
toImpl: async ({ toImplInWorkerScope: toImplWorker, mode }, use, testInfo) => {
|
|
|
|
if (mode !== 'default' || process.env.PW_TEST_REUSE_CONTEXT)
|
|
|
|
testInfo.skip();
|
|
|
|
await use(toImplWorker);
|
|
|
|
},
|
feat(test runner): replace declare/define with "options" (#10293)
1. Fixtures defined in test.extend() can now have `{ option: true }` configuration that makes them overridable in the config. Options support all other properties of fixtures - value/function, scope, auto.
```
const test = base.extend<MyOptions>({
foo: ['default', { option: true }],
});
```
2. test.declare() and project.define are removed.
3. project.use applies overrides to default option values and nothing else. Any test.extend() and test.use() calls take priority over config options.
Required user changes: if someone used to define fixture options with test.extend(), overriding them in config will stop working. The solution is to add `{ option: true }`.
```
// Old code
export const test = base.extend<{ myOption: number, myFixture: number }>({
myOption: 123,
myFixture: ({ myOption }, use) => use(2 * myOption),
});
// New code
export const test = base.extend<{ myOption: number, myFixture: number }>({
myOption: [123, { option: true }],
myFixture: ({ myOption }, use) => use(2 * myOption),
});
```
2021-11-19 02:45:52 +03:00
|
|
|
});
|