import { defineConfig, devices } from '@playwright/test'; // Use process.env.PORT by default and fallback to port 3000 const PORT = process.env.PORT || 3000; // Set webServer.url and use.baseURL with the location of the WebServer respecting the correct set port const baseURL = `http://localhost:${PORT}`; /** * See https://playwright.dev/docs/test-configuration. */ export default defineConfig({ testDir: './tests', // Look for files with the .spec.js or .e2e.js extension testMatch: '*.@(spec|e2e).?(c|m)[jt]s?(x)', // Timeout per test timeout: 30 * 1000, // Fail the build on CI if you accidentally left test.only in the source code. forbidOnly: !!process.env.CI, // Reporter to use. See https://playwright.dev/docs/test-reporters reporter: process.env.CI ? 'github' : 'list', expect: { // Set timeout for async expect matchers timeout: 10 * 1000, }, // Run your local dev server before starting the tests: // https://playwright.dev/docs/test-advanced#launching-a-development-web-server-during-the-tests webServer: { command: process.env.CI ? 'npm run start' : 'npm run dev:next', url: baseURL, timeout: 2 * 60 * 1000, reuseExistingServer: !process.env.CI, }, // Shared settings for all the projects below. See https://playwright.dev/docs/api/class-testoptions. use: { // Use baseURL so to make navigations relative. // More information: https://playwright.dev/docs/api/class-testoptions#test-options-base-url baseURL, // Collect trace when retrying the failed test. See https://playwright.dev/docs/trace-viewer trace: process.env.CI ? 'retain-on-failure' : undefined, // Record videos when retrying the failed test. video: process.env.CI ? 'retain-on-failure' : undefined, }, projects: [ { name: 'chromium', use: { ...devices['Desktop Chrome'] }, }, ...(process.env.CI ? [ { name: 'firefox', use: { ...devices['Desktop Firefox'] }, }, ] : []), ], });