2022-10-28 09:35:21 +02:00
// @ts-check
const { devices } = require ( '@playwright/test' ) ;
2024-03-01 12:31:17 +01:00
const { parseType } = require ( '@strapi/utils' ) ;
2022-10-28 09:35:21 +02:00
2024-01-19 18:12:35 +01:00
const getEnvNum = ( envVar , defaultValue ) => {
if ( envVar !== undefined && envVar !== null ) {
return Number ( envVar ) ;
}
return defaultValue ;
} ;
2024-03-01 12:31:17 +01:00
const getEnvString = ( envVar , defaultValue ) => {
if ( envVar ? . trim ( ) . length ) {
return envVar ;
}
return defaultValue ;
} ;
const getEnvBool = ( envVar , defaultValue ) => {
if ( ! envVar || envVar === '' ) {
return defaultValue ;
}
return parseType ( { type : 'boolean' , value : envVar . toLowerCase ( ) } ) ;
} ;
2023-07-13 11:37:46 +01:00
/ * *
* @ typedef ConfigOptions
* @ type { { port : number ; testDir : string ; appDir : string } }
* /
2022-10-28 09:35:21 +02:00
/ * *
* @ see https : //playwright.dev/docs/test-configuration
2023-07-13 11:37:46 +01:00
* @ type { ( options : ConfigOptions ) => import ( '@playwright/test' ) . PlaywrightTestConfig }
2022-10-28 09:35:21 +02:00
* /
2023-07-13 11:37:46 +01:00
const createConfig = ( { port , testDir , appDir } ) => ( {
testDir ,
2024-01-19 18:12:35 +01:00
/* default timeout for a jest test to 30s */
timeout : getEnvNum ( process . env . PLAYWRIGHT _TIMEOUT , 30 * 1000 ) ,
2022-10-28 09:35:21 +02:00
expect : {
/ * *
* Maximum time expect ( ) should wait for the condition to be met .
* For example in ` await expect(locator).toHaveText(); `
* /
2024-03-07 12:37:57 +01:00
timeout : getEnvNum ( process . env . PLAYWRIGHT _EXPECT _TIMEOUT , 20 * 1000 ) ,
2022-10-28 09:35:21 +02:00
} ,
/* 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('/')`. */
2023-07-13 11:37:46 +01:00
baseURL : ` http://127.0.0.1: ${ port } ` ,
2024-01-19 18:12:35 +01:00
/* Default time each action such as `click()` can take to 20s */
2024-03-07 12:37:57 +01:00
actionTimeout : getEnvNum ( process . env . PLAYWRIGHT _ACTION _TIMEOUT , 20 * 1000 ) ,
2022-10-28 09:35:21 +02:00
2023-09-28 11:47:43 +02:00
/* 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 .
* /
2024-03-01 12:31:17 +01:00
trace : 'retain-on-failure' ,
video : getEnvBool ( process . env . PLAYWRIGHT _VIDEO , false )
? {
mode : 'retain-on-failure' , // 'retain-on-failure' to save videos only for failed tests
size : {
width : 1280 ,
height : 720 ,
} ,
}
: 'off' ,
2022-10-28 09:35:21 +02:00
} ,
/* 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. */
2024-03-01 12:31:17 +01:00
outputDir : getEnvString ( process . env . PLAYWRIGHT _OUTPUT _DIR , '../test-results/' ) , // in the test-apps/e2e dir, to avoid writing files to the running Strapi project dir
2022-10-28 09:35:21 +02:00
/* Run your local dev server before starting the tests */
webServer : {
2023-07-13 11:37:46 +01:00
command : ` cd ${ appDir } && yarn develop ` ,
url : ` http://127.0.0.1: ${ port } ` ,
2024-01-19 18:12:35 +01:00
/* default Strapi server startup timeout to 160s */
timeout : getEnvNum ( process . env . PLAYWRIGHT _WEBSERVER _TIMEOUT , 160 * 1000 ) ,
2023-07-19 16:34:58 +01:00
reuseExistingServer : true ,
stdout : 'pipe' ,
2022-10-28 09:35:21 +02:00
} ,
2023-07-13 11:37:46 +01:00
} ) ;
2022-10-28 09:35:21 +02:00
2023-07-13 11:37:46 +01:00
module . exports = { createConfig } ;