| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394 |
- import { defineConfig, devices } from '@playwright/test';
- /**
- * Read environment variables from file.
- * https://github.com/motdotla/dotenv
- */
- // require('dotenv').config();
- /**
- * See https://playwright.dev/docs/test-configuration.
- */
- export default defineConfig({
- timeout: 7 * 1000,
- testDir: './playwright',
- outputDir: './playwright/output',
- /* Run tests in files in parallel */
- fullyParallel: true,
- /* Fail the build on CI if you accidentally left test.only in the source code. */
- forbidOnly: !!process.env.CI,
- /* Retry on CI only */
- retries: process.env.CI ? 2 : 0,
- /* Opt out of parallel tests on CI. */
- workers: process.env.CI ? 1 : undefined,
- /* Reporter to use. See https://playwright.dev/docs/test-reporters */
- reporter: process.env.CI ? 'github' : 'list',
- webServer: {
- command: 'yarn server',
- url: 'http://localhost:3000',
- reuseExistingServer: !process.env.CI,
- stdout: 'ignore',
- stderr: 'pipe',
- },
- /* Shared settings for all the projects below. See https://playwright.dev/docs/api/class-testoptions. */
- use: {
- /* Base URL to use in actions like `await page.goto('/')`. */
- baseURL: 'http://localhost:3000',
- /* Collect trace when retrying the failed test. See https://playwright.dev/docs/trace-viewer */
- trace: 'on-first-retry',
- viewport: { width: 1400, height: 1024 },
- // Use prepared auth state.
- storageState: 'playwright/.auth/user.json',
- },
- /* Configure projects for major browsers */
- projects: [
- // Setup project
- { name: 'setup', testMatch: /.*\.setup\.ts/ },
- {
- name: 'chromium',
- use: { ...devices['Desktop Chrome'] },
- dependencies: ['setup'],
- },
- {
- name: 'firefox',
- use: { ...devices['Desktop Firefox'] },
- dependencies: ['setup'],
- },
- {
- name: 'webkit',
- use: { ...devices['Desktop Safari'] },
- dependencies: ['setup'],
- },
- /* Test against mobile viewports. */
- // {
- // name: 'Mobile Chrome',
- // use: { ...devices['Pixel 5'] },
- // },
- // {
- // name: 'Mobile Safari',
- // use: { ...devices['iPhone 12'] },
- // },
- /* Test against branded browsers. */
- // {
- // name: 'Microsoft Edge',
- // use: { ...devices['Desktop Edge'], channel: 'msedge' },
- // },
- // {
- // name: 'Google Chrome',
- // use: { ...devices['Desktop Chrome'], channel: 'chrome' },
- // },
- ],
- });
|