2022-09-02 15:18:23 -04:00
import { expect } from '@playwright/test' ;
const ARTIFACTS _PATH = ` tests/e2e/test-artifacts ` ;
const LOGIN _PASSWORD = 'password' ;
// log in user and store session info. This should generally be
// run in test.beforeAll(), then the session can be loaded in tests.
export async function login _user ( browser , workerInfo , user ) {
// Set up a new context
const context = await browser . newContext ( ) ;
const page = await context . newPage ( ) ;
// Route to login page
// Note: this could probably be done more quickly with a POST
const response = await page . goto ( '/user/login' ) ;
await expect ( response ? . status ( ) ) . toBe ( 200 ) ; // Status OK
// Fill out form
await page . type ( 'input[name=user_name]' , user ) ;
await page . type ( 'input[name=password]' , LOGIN _PASSWORD ) ;
await page . click ( 'form button.ui.green.button:visible' ) ;
await page . waitForLoadState ( 'networkidle' ) ;
await expect ( page . url ( ) , { message : ` Failed to login user ${ user } ` } ) . toBe ( ` ${ workerInfo . project . use . baseURL } / ` ) ;
// Save state
await context . storageState ( { path : ` ${ ARTIFACTS _PATH } /state- ${ user } - ${ workerInfo . workerIndex } .json ` } ) ;
return context ;
}
export async function load _logged _in _context ( browser , workerInfo , user ) {
let context ;
try {
context = await browser . newContext ( { storageState : ` ${ ARTIFACTS _PATH } /state- ${ user } - ${ workerInfo . workerIndex } .json ` } ) ;
} catch ( err ) {
if ( err . code === 'ENOENT' ) {
throw new Error ( ` Could not find state for ' ${ user } '. Did you call login_user(browser, workerInfo, ' ${ user } ') in test.beforeAll()? ` ) ;
}
}
return context ;
}
export async function save _visual ( page ) {
// Optionally include visual testing
if ( process . env . VISUAL _TEST ) {
await page . waitForLoadState ( 'networkidle' ) ;
// Mock page/version string
await page . locator ( 'footer div.ui.left' ) . evaluate ( ( node ) => node . innerHTML = 'MOCK' ) ;
await expect ( page ) . toHaveScreenshot ( {
fullPage : true ,
timeout : 20000 ,
mask : [
2022-09-12 11:08:46 +02:00
page . locator ( '.dashboard-navbar span>img.ui.avatar' ) ,
2023-03-24 18:35:38 +08:00
page . locator ( '.ui.dropdown.jump.item span>img.ui.avatar' ) ,
2022-09-02 15:18:23 -04:00
] ,
} ) ;
}
}