2022-04-22 03:30:17 +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.
|
|
|
|
*/
|
|
|
|
|
2022-05-06 00:26:56 +03:00
|
|
|
import type { InlineConfig, Plugin } from 'vite';
|
2022-05-04 00:25:56 +03:00
|
|
|
import type { Suite } from '../../types/testReporter';
|
2022-05-06 00:26:56 +03:00
|
|
|
import type { Fixtures, FullConfig, Locator, Page, PlaywrightTestArgs, PlaywrightTestOptions, PlaywrightWorkerArgs, TestPlugin } from '../types';
|
2022-04-22 03:30:17 +03:00
|
|
|
|
2022-05-06 00:26:56 +03:00
|
|
|
import { mount } from '../mount';
|
2022-04-22 03:30:17 +03:00
|
|
|
|
2022-05-06 00:26:56 +03:00
|
|
|
export function vitePlugin(
|
|
|
|
name: string,
|
2022-05-04 07:25:50 +03:00
|
|
|
registerSourceFile: string,
|
2022-05-06 00:26:56 +03:00
|
|
|
frameworkPluginFactory: () => Plugin,
|
|
|
|
viteConfig: InlineConfig = {},
|
|
|
|
vitePort: number = 3100): TestPlugin {
|
|
|
|
|
|
|
|
let teardownVite: () => Promise<void>;
|
2022-04-25 20:40:58 +03:00
|
|
|
return {
|
2022-05-06 00:26:56 +03:00
|
|
|
name,
|
2022-04-28 21:43:39 +03:00
|
|
|
|
2022-05-04 00:25:56 +03:00
|
|
|
setup: async (config: FullConfig, configDirectory: string, suite: Suite) => {
|
2022-05-06 00:26:56 +03:00
|
|
|
teardownVite = await require('./vitePluginSetup').setup(registerSourceFile, frameworkPluginFactory, configDirectory, suite, viteConfig, vitePort);
|
2022-04-25 20:40:58 +03:00
|
|
|
},
|
|
|
|
|
|
|
|
teardown: async () => {
|
2022-05-06 00:26:56 +03:00
|
|
|
await teardownVite();
|
2022-04-25 20:40:58 +03:00
|
|
|
},
|
2022-04-22 03:30:17 +03:00
|
|
|
|
2022-05-06 00:26:56 +03:00
|
|
|
fixtures
|
2022-04-22 03:30:17 +03:00
|
|
|
};
|
|
|
|
}
|
2022-05-06 00:26:56 +03:00
|
|
|
|
|
|
|
const fixtures: Fixtures<PlaywrightTestArgs & PlaywrightTestOptions & { mount: (component: any, options: any) => Promise<Locator> }, PlaywrightWorkerArgs & { _workerPage: Page }> = {
|
|
|
|
_workerPage: [async ({ browser }, use) => {
|
|
|
|
const page = await (browser as any)._wrapApiCall(async () => {
|
|
|
|
const page = await browser.newPage();
|
|
|
|
await page.addInitScript('navigator.serviceWorker.register = () => {}');
|
|
|
|
return page;
|
|
|
|
});
|
|
|
|
await use(page);
|
|
|
|
}, { scope: 'worker' }],
|
|
|
|
|
|
|
|
context: async ({ page }, use) => {
|
|
|
|
await use(page.context());
|
|
|
|
},
|
|
|
|
|
|
|
|
page: async ({ _workerPage }, use) => {
|
|
|
|
await use(_workerPage);
|
|
|
|
},
|
|
|
|
|
|
|
|
mount: async ({ page, viewport }, use) => {
|
|
|
|
await use(async (component, options) => {
|
|
|
|
const selector = await mount(page, component, options, process.env.PLAYWRIGHT_VITE_PLUGIN_GALLERY!, viewport || { width: 1280, height: 720 });
|
|
|
|
return page.locator(selector);
|
|
|
|
});
|
|
|
|
},
|
|
|
|
};
|