feat: add shared fixtures for testing

This commit is contained in:
张翔
2026-03-06 12:13:01 +08:00
parent b6084ec01a
commit e47171bf01
3 changed files with 109 additions and 0 deletions
@@ -0,0 +1,15 @@
import { test as base } from '@playwright/test';
import { AccessibilityTester } from '../utils/accessibility/AccessibilityTester';
type MyFixtures = {
accessibilityTester: AccessibilityTester;
};
export const test = base.extend<MyFixtures>({
accessibilityTester: async ({ page }, use) => {
const tester = new AccessibilityTester(page);
await use(tester);
}
});
export { expect } from '@playwright/test';
@@ -0,0 +1,65 @@
import { test as base } from '@playwright/test';
import { BasePage, HomePage, AboutPage, ContactPage, ProductsPage, ServicesPage, CasesPage, NewsPage } from '../pages';
import { getEnvironmentConfig } from '../config/environments';
type MyFixtures = {
basePage: BasePage;
homePage: HomePage;
aboutPage: AboutPage;
contactPage: ContactPage;
productsPage: ProductsPage;
servicesPage: ServicesPage;
casesPage: CasesPage;
newsPage: NewsPage;
config: any;
};
export const test = base.extend<MyFixtures>({
config: async ({}, use) => {
const env = process.env.TEST_ENV || 'development';
const config = getEnvironmentConfig(env);
await use(config);
},
basePage: async ({ page }, use) => {
const basePage = new BasePage(page, '/');
await use(basePage);
},
homePage: async ({ page, config }, use) => {
const homePage = new HomePage(page, config);
await use(homePage);
},
aboutPage: async ({ page, config }, use) => {
const aboutPage = new AboutPage(page, config);
await use(aboutPage);
},
contactPage: async ({ page, config }, use) => {
const contactPage = new ContactPage(page, config);
await use(contactPage);
},
productsPage: async ({ page, config }, use) => {
const productsPage = new ProductsPage(page, config);
await use(productsPage);
},
servicesPage: async ({ page, config }, use) => {
const servicesPage = new ServicesPage(page, config);
await use(servicesPage);
},
casesPage: async ({ page, config }, use) => {
const casesPage = new CasesPage(page, config);
await use(casesPage);
},
newsPage: async ({ page, config }, use) => {
const newsPage = new NewsPage(page, config);
await use(newsPage);
}
});
export { expect } from '@playwright/test';
@@ -0,0 +1,29 @@
import { test as base } from '@playwright/test';
import { PerformanceMonitor } from '../utils/performance/PerformanceMonitor';
import { LighthouseRunner } from '../utils/performance/LighthouseRunner';
import { CoreWebVitals } from '../utils/performance/CoreWebVitals';
type MyFixtures = {
performanceMonitor: PerformanceMonitor;
lighthouseRunner: LighthouseRunner;
coreWebVitals: CoreWebVitals;
};
export const test = base.extend<MyFixtures>({
performanceMonitor: async ({ page }, use) => {
const monitor = new PerformanceMonitor(page);
await use(monitor);
},
lighthouseRunner: async ({ page }, use) => {
const runner = new LighthouseRunner(page);
await use(runner);
},
coreWebVitals: async ({ page }, use) => {
const vitals = new CoreWebVitals(page);
await use(vitals);
}
});
export { expect } from '@playwright/test';