feat: add shared fixtures for testing
This commit is contained in:
@@ -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';
|
||||
Reference in New Issue
Block a user