mirror of
				https://github.com/strapi/strapi.git
				synced 2025-11-03 19:36:20 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			84 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			84 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
// @ts-check
 | 
						|
const { devices } = require('@playwright/test');
 | 
						|
 | 
						|
/**
 | 
						|
 * @typedef ConfigOptions
 | 
						|
 * @type {{ port: number; testDir: string; appDir: string }}
 | 
						|
 */
 | 
						|
 | 
						|
/**
 | 
						|
 * @see https://playwright.dev/docs/test-configuration
 | 
						|
 * @type {(options: ConfigOptions) => import('@playwright/test').PlaywrightTestConfig}
 | 
						|
 */
 | 
						|
const createConfig = ({ port, testDir, appDir }) => ({
 | 
						|
  testDir,
 | 
						|
  expect: {
 | 
						|
    /**
 | 
						|
     * Maximum time expect() should wait for the condition to be met.
 | 
						|
     * For example in `await expect(locator).toHaveText();`
 | 
						|
     */
 | 
						|
    timeout: 5000,
 | 
						|
  },
 | 
						|
  /* Run tests in files in parallel */
 | 
						|
  fullyParallel: false,
 | 
						|
  /* 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: 1,
 | 
						|
  /* Reporter to use. See https://playwright.dev/docs/test-reporters */
 | 
						|
  reporter: 'html',
 | 
						|
  /* 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://127.0.0.1:${port}`,
 | 
						|
    /* Maximum time each action such as `click()` can take. Defaults to 0 (no limit). */
 | 
						|
    actionTimeout: 0,
 | 
						|
 | 
						|
    /* Collect trace when a test failed on the CI. See https://playwright.dev/docs/trace-viewer
 | 
						|
       Until https://github.com/strapi/strapi/issues/18196 is fixed we can't enable this locally,
 | 
						|
       because the Strapi server restarts every time a new file (trace) is created.
 | 
						|
    */
 | 
						|
    trace: process.env.CI ? 'retain-on-failure' : 'off',
 | 
						|
  },
 | 
						|
 | 
						|
  /* Configure projects for major browsers */
 | 
						|
  projects: [
 | 
						|
    {
 | 
						|
      name: 'chromium',
 | 
						|
      use: {
 | 
						|
        ...devices['Desktop Chrome'],
 | 
						|
      },
 | 
						|
    },
 | 
						|
 | 
						|
    {
 | 
						|
      name: 'firefox',
 | 
						|
      use: {
 | 
						|
        ...devices['Desktop Firefox'],
 | 
						|
      },
 | 
						|
    },
 | 
						|
 | 
						|
    {
 | 
						|
      name: 'webkit',
 | 
						|
      use: {
 | 
						|
        ...devices['Desktop Safari'],
 | 
						|
      },
 | 
						|
    },
 | 
						|
  ],
 | 
						|
 | 
						|
  /* Folder for test artifacts such as screenshots, videos, traces, etc. */
 | 
						|
  outputDir: 'test-results/',
 | 
						|
 | 
						|
  /* Run your local dev server before starting the tests */
 | 
						|
  webServer: {
 | 
						|
    command: `cd ${appDir} && npm run develop`,
 | 
						|
    url: `http://127.0.0.1:${port}`,
 | 
						|
    timeout: 60 * 1000,
 | 
						|
    reuseExistingServer: true,
 | 
						|
    stdout: 'pipe',
 | 
						|
  },
 | 
						|
});
 | 
						|
 | 
						|
module.exports = { createConfig };
 |