@telefonica/acceptance-testing 2.19.0 → 2.21.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1 +1 @@
1
- {"version":3,"file":"acceptance-testing.cjs.production.min.js","sources":["../src/coverage.ts","../src/index.ts"],"sourcesContent":["import path from 'path';\nimport fs from 'fs';\n\nimport type {Page} from 'puppeteer';\n\nconst getGlobalPage = (): Page => (global as any).page;\n\nexport const getRootPath = () => {\n const rootPath = expect.getState().snapshotState._rootDir;\n if (!rootPath) {\n throw new Error('Root path not found');\n }\n return rootPath;\n};\n\n/**\n * We want to clear coverage files from previous runs, but at this point it is not easy because each\n * worker runs a different instance of this script, so we can't just clear the coverage folder at\n * the beginning of the test run.\n *\n * The solution is to remove the coverage folder when the stored ppid (parent process id) is\n * different from the current one\n */\nconst prepareCoverageReportPath = ({coveragePath}: {coveragePath: string}) => {\n const ppidFile = path.join(coveragePath, '.ppid');\n const ppid = process.ppid.toString();\n if (!fs.existsSync(ppidFile) || fs.readFileSync(ppidFile, 'utf-8') !== ppid) {\n // the condition is just to make sure we don't remove files outside the repo\n if (getRootPath() === process.cwd() && path.normalize(coveragePath).startsWith(process.cwd())) {\n fs.rmSync(coveragePath, {recursive: true, force: true});\n }\n fs.mkdirSync(coveragePath, {recursive: true});\n fs.writeFileSync(ppidFile, ppid);\n }\n};\n\n/**\n * Asumes the code was instrumented with istanbul and the coverage report stored in `window.__coverage__`.\n * If not, this function does nothing.\n */\nexport const collectCoverageIfAvailable = async ({coveragePath}: {coveragePath: string}): Promise<void> => {\n const coverage = await getGlobalPage().evaluate(() => {\n return (window as any).__coverage__;\n });\n if (!coverage) {\n return;\n }\n\n prepareCoverageReportPath({coveragePath});\n const nycOutputPath = path.join(coveragePath, '.nyc_output');\n fs.mkdirSync(nycOutputPath, {recursive: true});\n\n Object.values(coverage).forEach((cov: any) => {\n if (cov && cov.path && cov.hash) {\n fs.writeFileSync(path.join(nycOutputPath, cov.hash + '.json'), JSON.stringify({[cov.path]: cov}));\n }\n });\n};\n","import path from 'path';\nimport fs from 'fs';\nimport findRoot from 'find-root';\nimport {getDocument, queries} from 'pptr-testing-library';\nimport {configureToMatchImageSnapshot} from 'jest-image-snapshot';\nimport globToRegExp from 'glob-to-regexp';\nimport {execSync} from 'child_process';\nimport {collectCoverageIfAvailable} from './coverage';\n\nimport type {\n Page,\n ElementHandle,\n ScreenshotOptions,\n Browser,\n ClickOptions,\n Viewport,\n GeolocationOptions,\n HTTPRequest,\n ResponseForRequest,\n} from 'puppeteer';\nimport type {getQueriesForElement} from 'pptr-testing-library';\n\ntype CustomScreenshotOptions = ScreenshotOptions & {\n skipNetworkWait?: boolean;\n};\n\nexport const getGlobalBrowser = (): Browser => (global as any).browser;\nexport const getGlobalPage = (): Page => (global as any).page;\n\nconst isCi = process.argv.includes('--ci') || process.env.CI;\nconst isUsingDockerizedChromium = isCi || new URL(getGlobalBrowser().wsEndpoint()).port === '9223';\n\nexport const serverHostName = ((): string => {\n if (isCi) {\n return 'localhost';\n }\n\n if (isUsingDockerizedChromium) {\n return process.platform === 'linux' ? '172.17.0.1' : 'host.docker.internal';\n }\n\n return 'localhost';\n})();\n\nconst rootDir = findRoot(process.cwd());\nconst pkg = JSON.parse(fs.readFileSync(path.join(rootDir, 'package.json'), 'utf-8'));\nconst projectConfig = pkg.acceptanceTests ?? {};\nconst server = (isCi ? projectConfig.ciServer : projectConfig.devServer) ?? projectConfig.server;\nconst coveragePath = path.join(rootDir, projectConfig.coveragePath ?? 'reports/coverage-acceptance');\n\nexport const serverPort = server?.port;\n\nconst toMatchImageSnapshot = configureToMatchImageSnapshot({\n failureThreshold: 0,\n failureThresholdType: 'percent',\n customSnapshotIdentifier: ({defaultIdentifier}) => defaultIdentifier,\n});\n\nlet calledToMatchImageSnapshotOutsideDocker = false;\n\nconst localToMatchImageSnapshot = () => {\n calledToMatchImageSnapshotOutsideDocker = true;\n // let the expectation pass, then fail in afterEach. This way we allow developers to debug screenshot tests in local\n // but don't allow them to save screenshots taken outside the dockerized chromium\n return {\n message: () => '',\n pass: true,\n };\n};\n\nexpect.extend({\n toMatchImageSnapshot: isUsingDockerizedChromium ? toMatchImageSnapshot : localToMatchImageSnapshot,\n});\n\nafterEach(() => {\n if (calledToMatchImageSnapshotOutsideDocker) {\n const error = new Error(\n `Calling .toMatchImageSnapshot() is not allowed outside dockerized browser. Please, run your screenshot test in headless mode.`\n );\n error.stack = (error.stack || '').split('\\n')[0];\n throw error;\n }\n});\n\ntype WaitForPaintEndOptions = {\n fullPage?: boolean;\n captureBeyondViewport?: boolean;\n};\n\nconst waitForPaintEnd = async (\n element: ElementHandle | Page,\n {fullPage = true, captureBeyondViewport}: WaitForPaintEndOptions = {}\n) => {\n const MAX_WAIT = 15000;\n const STEP_TIME = 250;\n const t0 = Date.now();\n\n let buf1 = (await element.screenshot(\n normalizeSreenshotOptions({fullPage, captureBeyondViewport})\n )) as Buffer;\n await new Promise((r) => setTimeout(r, STEP_TIME));\n let buf2 = (await element.screenshot(\n normalizeSreenshotOptions({fullPage, captureBeyondViewport})\n )) as Buffer;\n\n // buffers are different if compare != 0\n while (buf1.compare(buf2)) {\n if (Date.now() - t0 > MAX_WAIT) {\n throw Error('Paint end timeout');\n }\n buf1 = buf2;\n await new Promise((r) => setTimeout(r, STEP_TIME));\n buf2 = (await element.screenshot(\n normalizeSreenshotOptions({fullPage, captureBeyondViewport})\n )) as Buffer;\n }\n};\n\nexport interface PageApi extends Omit<Page, 'click' | 'type' | 'select'> {\n clear: (selector: ElementHandle) => Promise<void>;\n // These are overridden:\n type: (selector: ElementHandle, text: string, options?: {delay: number}) => Promise<void>;\n click: (selector: ElementHandle, options?: ClickOptions) => Promise<void>;\n select: (selector: ElementHandle, ...values: string[]) => Promise<string[]>;\n screenshot: (options?: CustomScreenshotOptions) => Promise<Buffer | string | void>;\n}\n\nconst normalizeSreenshotOptions = ({captureBeyondViewport = false, ...options}: ScreenshotOptions = {}) => {\n // Puppeter default for captureBeyondViewport is true, but we think false is a better default.\n // When this is true, the fixed elements (like fixed footers) are relative to the original page\n // viewport, not to the full page, so those elements look weird in fullPage screenshots.\n return {...options, captureBeyondViewport};\n};\n\n// Puppeteer already calls scrollIntoViewIfNeeded before clicking an element. But it doesn't work in all situations\n// For example, when there is a fixed footer in the page and the element to click is under it, the browser won't scroll\n// because the element is already in the viewport (the ifNeeded part is important here). By forcing the scroll to the\n// center, we manage to fix these edge cases.\nconst scrollIntoView = (el: ElementHandle) => el.evaluate((e) => e.scrollIntoView({block: 'center'}));\n\nexport const getPageApi = (page: Page): PageApi => {\n const api: PageApi = Object.create(page);\n\n api.type = async (elementHandle, text, options) => {\n await scrollIntoView(elementHandle);\n return elementHandle.type(text, options);\n };\n api.click = async (elementHandle, options) => {\n await scrollIntoView(elementHandle);\n return elementHandle.click(options);\n };\n api.select = async (elementHandle, ...values) => {\n await scrollIntoView(elementHandle);\n return elementHandle.select(...values);\n };\n\n api.screenshot = async (options?: CustomScreenshotOptions) => {\n if (!options?.skipNetworkWait) {\n await page.waitForNetworkIdle();\n }\n await waitForPaintEnd(page, options);\n return page.screenshot(normalizeSreenshotOptions(options));\n };\n\n api.clear = async (elementHandle) => {\n await elementHandle.click({clickCount: 3});\n await elementHandle.press('Delete');\n };\n\n // For some reason, puppeteer browserContext.overridePermissions doesn't work with newer chrome versions.\n // This workaround polyfills the browser geolocation api to return the mocked position\n api.setGeolocation = (position: GeolocationOptions) =>\n page.evaluate((position) => {\n window.navigator.geolocation.getCurrentPosition = (callback) => {\n // @ts-ignore\n callback({\n coords: position,\n });\n };\n }, position as any);\n\n return api;\n};\n\nlet needsRequestInterception = false;\ntype RequestMatcherFn = (req: HTTPRequest) => boolean;\nlet requestHandlers: Array<{\n matcher: RequestMatcherFn;\n handler: jest.Mock<any, any>;\n}> = [];\n\nconst requestInterceptor = (req: HTTPRequest) => {\n const {handler} = requestHandlers.find(({matcher}) => matcher(req)) ?? {handler: null};\n if (!handler) {\n req.continue();\n return;\n }\n const response = handler(req);\n req.respond(response);\n};\n\nexport const interceptRequest = (\n matcher: RequestMatcherFn\n): jest.Mock<Partial<ResponseForRequest>, [HTTPRequest]> => {\n needsRequestInterception = true;\n const spy = jest.fn();\n requestHandlers.push({matcher, handler: spy});\n return spy;\n};\n\ntype ApiEndpointMock = {\n spyOn(path: string, method?: string): jest.Mock<unknown, [HTTPRequest]>;\n};\n\nexport const createApiEndpointMock = ({baseUrl}: {baseUrl: string}): ApiEndpointMock => {\n interceptRequest((req) => req.method() === 'OPTIONS' && req.url().startsWith(baseUrl)).mockImplementation(\n () => ({\n status: 204,\n headers: {\n 'Access-Control-Allow-Origin': '*',\n 'Access-Control-Allow-Methods': 'POST,PATCH,PUT,GET,OPTIONS',\n 'Access-Control-Allow-Headers': '*',\n },\n })\n );\n\n return {\n spyOn(path: string, method: string = 'GET') {\n const matcher = (req: HTTPRequest) => {\n const url = req.url();\n const urlPath = url.substring(baseUrl.length);\n return (\n req.method() === method && url.startsWith(baseUrl) && !!urlPath.match(globToRegExp(path))\n );\n };\n\n const spy = jest.fn();\n\n interceptRequest(matcher).mockImplementation((req) => {\n const spyResult = spy(req);\n const status = spyResult.status ?? 200;\n const resBody = spyResult.body || spyResult;\n return {\n status,\n headers: {\n 'Access-Control-Allow-Origin': '*',\n },\n contentType: 'application/json',\n body: JSON.stringify(resBody),\n };\n });\n\n return spy;\n },\n };\n};\n\ntype CookieConfig = {\n name: string;\n value: string;\n url?: string;\n domain?: string;\n path?: string;\n secure?: boolean;\n httpOnly?: boolean;\n sameSite?: 'Strict' | 'Lax' | 'None';\n expires?: number;\n priority?: 'Low' | 'Medium' | 'High';\n sameParty?: boolean;\n sourceScheme?: 'Unset' | 'NonSecure' | 'Secure';\n sourcePort?: number;\n};\n\ninterface OpenPageCommonConfig {\n userAgent?: string;\n viewport?: Viewport;\n isDarkMode?: boolean;\n cookies?: Array<CookieConfig>;\n}\n\ninterface OpenPageUrlConfig extends OpenPageCommonConfig {\n url: string;\n}\n\ninterface OpenPagePathConfig extends OpenPageCommonConfig {\n url?: undefined;\n\n path?: string;\n port?: number;\n protocol?: string;\n hostname?: string;\n}\n\ntype OpenPageConfig = OpenPageUrlConfig | OpenPagePathConfig;\n\nexport const openPage = async ({\n userAgent,\n isDarkMode,\n viewport,\n cookies,\n ...urlConfig\n}: OpenPageConfig): Promise<PageApi> => {\n const url = ((): string => {\n if (urlConfig.url !== undefined) {\n return urlConfig.url;\n }\n\n const {path = '/', port = serverPort, protocol = 'http', hostname = serverHostName} = urlConfig;\n\n if (!port) {\n const error = new Error(\n 'You must specify a port. You can specify it when calling openPage() or by configuring a dev and ci server in the acceptanceTests config in your package.json'\n );\n // Error.captureStackTrace(error, openPage);\n throw error;\n }\n\n return `${protocol}://${hostname}:${port}${path}`;\n })();\n\n const currentUserAgent = userAgent || (await getGlobalBrowser().userAgent());\n const page = getGlobalPage();\n\n await page.bringToFront();\n if (viewport) {\n await page.setViewport(viewport);\n }\n if (cookies) {\n await page.setCookie(...cookies);\n }\n await page.setUserAgent(`${currentUserAgent} acceptance-test`);\n await page.emulateMediaFeatures([{name: 'prefers-color-scheme', value: isDarkMode ? 'dark' : 'light'}]);\n\n // A set of styles to make screenshot tests more reliable.\n await page.evaluateOnNewDocument(() => {\n const style = document.createElement('style');\n style.innerHTML = `\n *, *:after, *:before {\n transition-delay: 0s !important;\n transition-duration: 0s !important;\n animation-delay: -0.0001s !important;\n animation-duration: 0s !important;\n animation-play-state: paused !important;\n caret-color: transparent !important;\n font-variant-ligatures: none !important;\n }\n *::-webkit-scrollbar {\n display: none !important;\n width: 0 !important;\n height: 0 !important;\n }\n `;\n window.addEventListener('DOMContentLoaded', () => {\n document.head.appendChild(style);\n });\n });\n\n if (needsRequestInterception) {\n await page.setRequestInterception(true);\n page.on('request', requestInterceptor);\n }\n\n try {\n await page.goto(url);\n } catch (e) {\n if ((e as Error).message.includes('net::ERR_CONNECTION_REFUSED')) {\n const connectionError = new Error(`Could not connect to ${url}. Is the server running?`);\n Error.captureStackTrace(connectionError, openPage);\n throw connectionError;\n } else {\n throw e;\n }\n }\n await page.waitForFunction('document.fonts.status === \"loaded\"');\n\n return getPageApi(page);\n};\n\nconst buildQueryMethods = ({page, element}: {page?: Page; element?: ElementHandle} = {}): ReturnType<\n typeof getQueriesForElement\n> => {\n const boundQueries: any = {};\n for (const [queryName, queryFn] of Object.entries(queries)) {\n boundQueries[queryName] = async (...args: any) => {\n const doc = await getDocument(page ?? getGlobalPage());\n const body = await doc.$('body');\n const queryArgs = [...args];\n if (queryName.startsWith('findBy')) {\n if (queryArgs.length === 1) {\n queryArgs.push(undefined);\n }\n queryArgs.push({timeout: 10000});\n }\n const elementHandle: ElementHandle = await queryFn(element ?? body, ...queryArgs);\n\n const newElementHandle = Object.create(elementHandle);\n\n newElementHandle.screenshot = async (options: CustomScreenshotOptions) => {\n if (!options?.skipNetworkWait) {\n await (page ?? getGlobalPage()).waitForNetworkIdle();\n }\n await waitForPaintEnd(elementHandle, {...options, fullPage: false});\n return elementHandle.screenshot(normalizeSreenshotOptions(options));\n };\n\n newElementHandle.click = async (options?: ClickOptions) => {\n await scrollIntoView(elementHandle);\n return elementHandle.click(options);\n };\n\n newElementHandle.type = async (text: string, options?: {delay: number}) => {\n await scrollIntoView(elementHandle);\n return elementHandle.type(text, options);\n };\n\n newElementHandle.select = async (...values: Array<string>) => {\n await scrollIntoView(elementHandle);\n return elementHandle.select(...values);\n };\n\n return newElementHandle;\n };\n }\n return boundQueries;\n};\n\nexport const getScreen = (page: Page) => buildQueryMethods({page});\n\nexport const screen = buildQueryMethods();\n\nexport const within = (element: ElementHandle) => buildQueryMethods({element});\n\nexport type {ElementHandle, Viewport} from 'puppeteer';\n\nbeforeEach(async () => {\n await getGlobalPage().setRequestInterception(false);\n\n // by resetting the page we clean up all the evaluateOnNewDocument calls, which are persistent between documents\n await (global as any).jestPuppeteer.resetPage();\n});\n\nafterEach(async () => {\n await collectCoverageIfAvailable({coveragePath});\n\n try {\n const page = getGlobalPage();\n requestHandlers = [];\n needsRequestInterception = false;\n page.off('request', requestInterceptor);\n\n // clear tab, this way we clear the DOM and stop js execution or pending requests\n await page.goto('about:blank');\n } catch (e) {\n // ignore, at this point page might be destroyed\n }\n});\n\n/**\n * Returns a new path to the file that can be used by chromium in acceptance tests\n *\n * To be able to use `element.uploadFile()` in a dockerized chromium, the file must exist in the\n * host and the docker, and both sides must use the same path.\n *\n * To workaround this bug or limitation, this function prepares the file by copying it to /tmp in\n * the host and the container.\n */\nexport const prepareFile = (filepath: string): string => {\n const isLocal = !isCi;\n const isHeadless = !!process.env.HEADLESS;\n const usesDocker = isLocal && isHeadless;\n\n const dockerComposeFile = path.join(__dirname, '..', 'docker-compose.yaml');\n\n if (usesDocker) {\n const containerId = execSync(`docker-compose -f ${dockerComposeFile} ps -q`).toString().trim();\n\n if (!containerId) {\n throw Error('acceptance-testing container not found');\n }\n\n execSync(`docker cp ${filepath} ${containerId}:/tmp`);\n\n const newPath = path.join('/tmp', path.basename(filepath));\n\n fs.copyFileSync(filepath, newPath);\n\n return newPath;\n } else {\n return filepath;\n }\n};\n\n/**\n * A convenience method to defer an expectation\n */\nexport const wait = <T>(expectation: () => Promise<T> | T, timeout = 10000, interval = 50): Promise<T> => {\n const startTime = Date.now();\n const startStack = new Error().stack;\n\n return new Promise((resolve, reject) => {\n const rejectOrRerun = (error: unknown) => {\n if (Date.now() - startTime >= timeout) {\n if (error instanceof Error) {\n if (error.message === 'Element not removed') {\n error.stack = startStack;\n }\n }\n reject(error);\n return;\n }\n // eslint-disable-next-line @typescript-eslint/no-use-before-define\n setTimeout(runExpectation, interval);\n };\n const runExpectation = () => {\n try {\n Promise.resolve(expectation())\n .then((r) => resolve(r))\n .catch(rejectOrRerun);\n } catch (error) {\n rejectOrRerun(error);\n }\n };\n setTimeout(runExpectation, 0);\n });\n};\n\nexport const waitForElementToBeRemoved = (\n element: ElementHandle<Element>,\n timeout = 10000,\n interval = 100\n): Promise<void> => {\n const startStack = new Error().stack;\n\n const wait = async () => {\n const t0 = Date.now();\n while (Date.now() - t0 < timeout) {\n // boundingBox returns null when the element is not in the DOM\n const box = await element.boundingBox();\n if (!box) {\n return;\n }\n await new Promise((resolve) => setTimeout(resolve, interval));\n }\n throw new Error('Element not removed');\n };\n\n return wait().catch((error) => {\n if (error.message === 'Element not removed') {\n error.stack = startStack;\n }\n throw error;\n });\n};\n"],"names":["prepareCoverageReportPath","_ref","coveragePath","ppidFile","path","join","ppid","process","toString","fs","existsSync","readFileSync","rootPath","expect","getState","snapshotState","_rootDir","Error","getRootPath","cwd","normalize","startsWith","rmSync","recursive","force","mkdirSync","writeFileSync","collectCoverageIfAvailable","_ref3","_asyncToGenerator","_regeneratorRuntime","mark","_callee","_ref2","coverage","nycOutputPath","wrap","_context","prev","next","global","page","evaluate","window","__coverage__","sent","abrupt","Object","values","forEach","cov","_JSON$stringify","hash","JSON","stringify","stop","_x","apply","arguments","getGlobalBrowser","browser","getGlobalPage","isCi","argv","includes","env","CI","isUsingDockerizedChromium","URL","wsEndpoint","port","serverHostName","platform","rootDir","findRoot","projectConfig","_pkg$acceptanceTests","parse","acceptanceTests","server","ciServer","devServer","_projectConfig$covera","serverPort","calledToMatchImageSnapshotOutsideDocker","extend","toMatchImageSnapshot","configureToMatchImageSnapshot","failureThreshold","failureThresholdType","customSnapshotIdentifier","defaultIdentifier","message","pass","afterEach","error","stack","split","waitForPaintEnd","element","_temp","_ref4","_ref4$fullPage","fullPage","captureBeyondViewport","MAX_WAIT","STEP_TIME","t0","buf1","buf2","Date","now","screenshot","normalizeSreenshotOptions","Promise","r","setTimeout","compare","_x2","_temp2","_ref5$captureBeyondVi","_ref5","_extends","_objectWithoutPropertiesLoose","_excluded","scrollIntoView","el","e","block","getPageApi","api","create","type","_ref6","_callee2","elementHandle","text","options","_context2","_x3","_x4","_x5","click","_ref7","_callee3","_context3","_x6","_x7","select","_ref8","_callee4","_len","_key","_args4","_context4","length","Array","_x8","_ref9","_callee5","_context5","skipNetworkWait","waitForNetworkIdle","_x9","clear","_ref10","_callee6","_context6","clickCount","press","_x10","setGeolocation","position","navigator","geolocation","getCurrentPosition","callback","coords","needsRequestInterception","requestHandlers","requestInterceptor","req","handler","_requestHandlers$find","find","_ref12","matcher","response","respond","interceptRequest","spy","jest","fn","push","openPage","_ref15","_callee7","_ref14","userAgent","isDarkMode","viewport","cookies","urlConfig","url","currentUserAgent","connectionError","_context7","_excluded2","undefined","_urlConfig$path","_urlConfig$port","_urlConfig$protocol","protocol","_urlConfig$hostname","hostname","bringToFront","setViewport","setCookie","setUserAgent","emulateMediaFeatures","name","value","evaluateOnNewDocument","style","document","createElement","innerHTML","addEventListener","head","appendChild","setRequestInterception","on","t1","captureStackTrace","waitForFunction","_x11","buildQueryMethods","_temp3","_ref16","boundQueries","_loop","_Object$entries$_i","_Object$entries","_i","queryName","queryFn","_callee12","doc","body","_len2","args","_key2","queryArgs","newElementHandle","_args12","_context12","getDocument","$","concat","timeout","_ref18","_callee8","_context8","_x12","_ref19","_callee9","_context9","_x13","_ref20","_callee10","_context10","_x14","_x15","_callee11","_args11","_context11","entries","queries","screen","beforeEach","_callee13","_context13","jestPuppeteer","resetPage","_callee14","_context14","off","_ref13","baseUrl","method","mockImplementation","status","headers","Access-Control-Allow-Origin","Access-Control-Allow-Methods","Access-Control-Allow-Headers","spyOn","urlPath","substring","match","globToRegExp","spyResult","_spyResult$status","contentType","filepath","isHeadless","HEADLESS","usesDocker","dockerComposeFile","__dirname","containerId","execSync","trim","newPath","basename","copyFileSync","expectation","interval","startTime","startStack","resolve","reject","rejectOrRerun","runExpectation","then","_ref24","_callee15","_context15","boundingBox","wait"],"mappings":"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"}
1
+ {"version":3,"file":"acceptance-testing.cjs.production.min.js","sources":["../src/index.ts"],"sourcesContent":["import path from 'path';\nimport fs from 'fs';\nimport findRoot from 'find-root';\nimport type {getQueriesForElement} from 'pptr-testing-library';\nimport {getDocument, queries} from 'pptr-testing-library';\nimport {configureToMatchImageSnapshot} from 'jest-image-snapshot';\nimport globToRegExp from 'glob-to-regexp';\nimport {execSync} from 'child_process';\nimport {collectCoverageIfAvailable} from 'coverage';\n\nimport type {\n Browser,\n ClickOptions,\n ElementHandle,\n GeolocationOptions,\n HTTPRequest,\n Page,\n ResponseForRequest,\n ScreenshotOptions,\n Viewport,\n} from 'puppeteer';\n\ntype CustomScreenshotOptions = ScreenshotOptions & {\n skipNetworkWait?: boolean;\n};\n\nexport const getGlobalBrowser = (): Browser => (global as any).browser;\nexport const getGlobalPage = (): Page => (global as any).page;\n\nconst isCi = process.argv.includes('--ci') || process.env.CI;\nconst isUsingDockerizedChromium = isCi || new URL(getGlobalBrowser().wsEndpoint()).port === '9223';\n\nexport const serverHostName = ((): string => {\n if (isCi) {\n return 'localhost';\n }\n\n if (isUsingDockerizedChromium) {\n return process.platform === 'linux' ? '172.17.0.1' : 'host.docker.internal';\n }\n\n return 'localhost';\n})();\n\nconst rootDir = findRoot(process.cwd());\nconst pkg = JSON.parse(fs.readFileSync(path.join(rootDir, 'package.json'), 'utf-8'));\nconst projectConfig = pkg.acceptanceTests ?? {};\nconst server = (isCi ? projectConfig.ciServer : projectConfig.devServer) ?? projectConfig.server;\nconst coveragePath = path.join(rootDir, projectConfig.coveragePath ?? 'reports/coverage-acceptance');\n\nexport const serverPort = server?.port;\n\nconst toMatchImageSnapshot = configureToMatchImageSnapshot({\n failureThreshold: 0,\n failureThresholdType: 'percent',\n customSnapshotIdentifier: ({defaultIdentifier}) => defaultIdentifier,\n});\n\nlet calledToMatchImageSnapshotOutsideDocker = false;\n\nconst localToMatchImageSnapshot = () => {\n calledToMatchImageSnapshotOutsideDocker = true;\n // let the expectation pass, then fail in afterEach. This way we allow developers to debug screenshot tests in local\n // but don't allow them to save screenshots taken outside the dockerized chromium\n return {\n message: () => '',\n pass: true,\n };\n};\n\nexpect.extend({\n toMatchImageSnapshot: isUsingDockerizedChromium ? toMatchImageSnapshot : localToMatchImageSnapshot,\n});\n\nafterEach(() => {\n if (calledToMatchImageSnapshotOutsideDocker) {\n const error = new Error(\n `Calling .toMatchImageSnapshot() is not allowed outside dockerized browser. Please, run your screenshot test in headless mode.`\n );\n error.stack = (error.stack || '').split('\\n')[0];\n throw error;\n }\n});\n\ntype WaitForPaintEndOptions = {\n fullPage?: boolean;\n captureBeyondViewport?: boolean;\n};\n\nconst waitForPaintEnd = async (\n element: ElementHandle | Page,\n {fullPage = true, captureBeyondViewport}: WaitForPaintEndOptions = {}\n) => {\n const MAX_WAIT = 15000;\n const STEP_TIME = 250;\n const t0 = Date.now();\n\n let buf1 = (await element.screenshot(\n normalizeSreenshotOptions({fullPage, captureBeyondViewport})\n )) as Buffer;\n await new Promise((r) => setTimeout(r, STEP_TIME));\n let buf2 = (await element.screenshot(\n normalizeSreenshotOptions({fullPage, captureBeyondViewport})\n )) as Buffer;\n\n // buffers are different if compare != 0\n while (buf1.compare(buf2)) {\n if (Date.now() - t0 > MAX_WAIT) {\n throw Error('Paint end timeout');\n }\n buf1 = buf2;\n await new Promise((r) => setTimeout(r, STEP_TIME));\n buf2 = (await element.screenshot(\n normalizeSreenshotOptions({fullPage, captureBeyondViewport})\n )) as Buffer;\n }\n};\n\nexport interface PageApi extends Omit<Page, 'click' | 'type' | 'select'> {\n clear: (selector: ElementHandle) => Promise<void>;\n // These are overridden:\n type: (selector: ElementHandle, text: string, options?: {delay: number}) => Promise<void>;\n click: (selector: ElementHandle, options?: ClickOptions) => Promise<void>;\n select: (selector: ElementHandle, ...values: string[]) => Promise<string[]>;\n screenshot: (options?: CustomScreenshotOptions) => Promise<Buffer | string | void>;\n}\n\nconst normalizeSreenshotOptions = ({captureBeyondViewport = false, ...options}: ScreenshotOptions = {}) => {\n // Puppeter default for captureBeyondViewport is true, but we think false is a better default.\n // When this is true, the fixed elements (like fixed footers) are relative to the original page\n // viewport, not to the full page, so those elements look weird in fullPage screenshots.\n return {...options, captureBeyondViewport};\n};\n\n// Puppeteer already calls scrollIntoViewIfNeeded before clicking an element. But it doesn't work in all situations\n// For example, when there is a fixed footer in the page and the element to click is under it, the browser won't scroll\n// because the element is already in the viewport (the ifNeeded part is important here). By forcing the scroll to the\n// center, we manage to fix these edge cases.\nconst scrollIntoView = (el: ElementHandle) => el.evaluate((e) => e.scrollIntoView({block: 'center'}));\n\nexport const getPageApi = (page: Page): PageApi => {\n const api: PageApi = Object.create(page);\n\n api.type = async (elementHandle, text, options) => {\n await scrollIntoView(elementHandle);\n return elementHandle.type(text, options);\n };\n api.click = async (elementHandle, options) => {\n await scrollIntoView(elementHandle);\n return elementHandle.click(options);\n };\n api.select = async (elementHandle, ...values) => {\n await scrollIntoView(elementHandle);\n return elementHandle.select(...values);\n };\n\n api.screenshot = async (options?: CustomScreenshotOptions) => {\n if (!options?.skipNetworkWait) {\n await page.waitForNetworkIdle();\n }\n await waitForPaintEnd(page, options);\n return page.screenshot(normalizeSreenshotOptions(options));\n };\n\n api.clear = async (elementHandle) => {\n await elementHandle.click({clickCount: 3});\n await elementHandle.press('Delete');\n };\n\n // For some reason, puppeteer browserContext.overridePermissions doesn't work with newer chrome versions.\n // This workaround polyfills the browser geolocation api to return the mocked position\n api.setGeolocation = (position: GeolocationOptions) =>\n page.evaluate((position) => {\n window.navigator.geolocation.getCurrentPosition = (callback) => {\n // @ts-expect-error - puppeteer's setGeoLocation does not expect a timestamp to be passed\n callback({\n coords: position,\n });\n };\n }, position as any);\n\n return api;\n};\n\nlet needsRequestInterception = false;\ntype RequestMatcherFn = (req: HTTPRequest) => boolean;\nlet requestHandlers: Array<{\n matcher: RequestMatcherFn;\n handler: jest.Mock<any, any>;\n}> = [];\n\nconst requestInterceptor = (req: HTTPRequest) => {\n const {handler} = requestHandlers.find(({matcher}) => matcher(req)) ?? {handler: null};\n if (!handler) {\n req.continue();\n return;\n }\n const response = handler(req);\n req.respond(response);\n};\n\nexport const interceptRequest = (\n matcher: RequestMatcherFn\n): jest.Mock<Partial<ResponseForRequest>, [HTTPRequest]> => {\n needsRequestInterception = true;\n const spy = jest.fn();\n requestHandlers.push({matcher, handler: spy});\n return spy;\n};\n\ntype ApiEndpointMock = {\n spyOn(path: string, method?: string): jest.Mock<unknown, [HTTPRequest]>;\n};\n\nexport const createApiEndpointMock = ({baseUrl}: {baseUrl: string}): ApiEndpointMock => {\n interceptRequest((req) => req.method() === 'OPTIONS' && req.url().startsWith(baseUrl)).mockImplementation(\n () => ({\n status: 204,\n headers: {\n 'Access-Control-Allow-Origin': '*',\n 'Access-Control-Allow-Methods': 'POST,PATCH,PUT,GET,OPTIONS,DELETE',\n 'Access-Control-Allow-Headers': '*',\n },\n })\n );\n\n return {\n spyOn(path: string, method: string = 'GET') {\n const matcher = (req: HTTPRequest) => {\n const url = req.url();\n const urlPath = url.substring(baseUrl.length);\n return (\n req.method() === method && url.startsWith(baseUrl) && !!urlPath.match(globToRegExp(path))\n );\n };\n\n const spy = jest.fn();\n\n interceptRequest(matcher).mockImplementation((req) => {\n const spyResult = spy(req);\n const status = spyResult.status ?? 200;\n const resBody = spyResult.body || spyResult;\n return {\n status,\n headers: {\n 'Access-Control-Allow-Origin': '*',\n },\n contentType: 'application/json',\n body: JSON.stringify(resBody),\n };\n });\n\n return spy;\n },\n };\n};\n\ntype CookieConfig = {\n name: string;\n value: string;\n url?: string;\n domain?: string;\n path?: string;\n secure?: boolean;\n httpOnly?: boolean;\n sameSite?: 'Strict' | 'Lax' | 'None';\n expires?: number;\n priority?: 'Low' | 'Medium' | 'High';\n sameParty?: boolean;\n sourceScheme?: 'Unset' | 'NonSecure' | 'Secure';\n sourcePort?: number;\n};\n\nexport interface TestViewport extends Viewport {\n safeAreaInset?: {\n top?: number | string;\n right?: number | string;\n bottom?: number | string;\n left?: number | string;\n };\n}\n\ninterface OpenPageCommonConfig {\n userAgent?: string;\n viewport?: TestViewport;\n isDarkMode?: boolean;\n cookies?: Array<CookieConfig>;\n}\n\ninterface OpenPageUrlConfig extends OpenPageCommonConfig {\n url: string;\n}\n\ninterface OpenPagePathConfig extends OpenPageCommonConfig {\n url?: undefined;\n\n path?: string;\n port?: number;\n protocol?: string;\n hostname?: string;\n}\n\ntype OpenPageConfig = OpenPageUrlConfig | OpenPagePathConfig;\n\nexport const openPage = async ({\n userAgent,\n isDarkMode,\n viewport,\n cookies,\n ...urlConfig\n}: OpenPageConfig): Promise<PageApi> => {\n const url = ((): string => {\n if (urlConfig.url !== undefined) {\n return urlConfig.url;\n }\n\n const {path = '/', port = serverPort, protocol = 'http', hostname = serverHostName} = urlConfig;\n\n if (!port) {\n // Error.captureStackTrace(error, openPage);\n throw new Error(\n 'You must specify a port. You can specify it when calling openPage() or by configuring a dev and ci server in the acceptanceTests config in your package.json'\n );\n }\n\n return `${protocol}://${hostname}:${port}${path}`;\n })();\n\n const currentUserAgent = userAgent || (await getGlobalBrowser().userAgent());\n const page = getGlobalPage();\n\n await page.bringToFront();\n if (viewport) {\n await page.setViewport(viewport);\n }\n if (cookies) {\n await page.setCookie(...cookies);\n }\n await page.setUserAgent(`${currentUserAgent} acceptance-test`);\n await page.emulateMediaFeatures([{name: 'prefers-color-scheme', value: isDarkMode ? 'dark' : 'light'}]);\n\n // A set of styles to make screenshot tests more reliable.\n await page.evaluateOnNewDocument((viewport: TestViewport) => {\n const overriddenSafeAreaInsets = !viewport\n ? []\n : Object.keys(viewport?.safeAreaInset ?? {}).map((key) => {\n const position = key as 'top' | 'right' | 'bottom' | 'left';\n return `--acceptance-test-override-safe-area-inset-${key}: ${viewport?.safeAreaInset?.[position]};`;\n });\n\n const style = document.createElement('style');\n style.innerHTML = `\n *, *:after, *:before {\n transition-delay: 0s !important;\n transition-duration: 0s !important;\n animation-delay: -0.0001s !important;\n animation-duration: 0s !important;\n animation-play-state: paused !important;\n caret-color: transparent !important;\n font-variant-ligatures: none !important;\n }\n *::-webkit-scrollbar {\n display: none !important;\n width: 0 !important;\n height: 0 !important;\n }\n :root {\n ${overriddenSafeAreaInsets.join('\\n')}\n }\n `;\n window.addEventListener('DOMContentLoaded', () => {\n document.head.appendChild(style);\n });\n }, viewport);\n\n if (needsRequestInterception) {\n await page.setRequestInterception(true);\n page.on('request', requestInterceptor);\n }\n\n try {\n await page.goto(url);\n } catch (e) {\n if ((e as Error).message.includes('net::ERR_CONNECTION_REFUSED')) {\n const connectionError = new Error(`Could not connect to ${url}. Is the server running?`);\n Error.captureStackTrace(connectionError, openPage);\n throw connectionError;\n } else {\n throw e;\n }\n }\n await page.waitForFunction('document.fonts.status === \"loaded\"');\n\n return getPageApi(page);\n};\n\nconst buildQueryMethods = ({page, element}: {page?: Page; element?: ElementHandle} = {}): ReturnType<\n typeof getQueriesForElement\n> => {\n const boundQueries: any = {};\n for (const [queryName, queryFn] of Object.entries(queries)) {\n boundQueries[queryName] = async (...args: any) => {\n const doc = await getDocument(page ?? getGlobalPage());\n const body = await doc.$('body');\n const queryArgs = [...args];\n if (queryName.startsWith('findBy')) {\n if (queryArgs.length === 1) {\n queryArgs.push(undefined);\n }\n queryArgs.push({timeout: 10000});\n }\n const elementHandle: ElementHandle = await queryFn(element ?? body, ...queryArgs);\n\n const newElementHandle = Object.create(elementHandle);\n\n newElementHandle.screenshot = async (options: CustomScreenshotOptions) => {\n if (!options?.skipNetworkWait) {\n await (page ?? getGlobalPage()).waitForNetworkIdle();\n }\n await waitForPaintEnd(elementHandle, {...options, fullPage: false});\n return elementHandle.screenshot(normalizeSreenshotOptions(options));\n };\n\n newElementHandle.click = async (options?: ClickOptions) => {\n await scrollIntoView(elementHandle);\n return elementHandle.click(options);\n };\n\n newElementHandle.type = async (text: string, options?: {delay: number}) => {\n await scrollIntoView(elementHandle);\n return elementHandle.type(text, options);\n };\n\n newElementHandle.select = async (...values: Array<string>) => {\n await scrollIntoView(elementHandle);\n return elementHandle.select(...values);\n };\n\n return newElementHandle;\n };\n }\n return boundQueries;\n};\n\nexport const getScreen = (page: Page) => buildQueryMethods({page});\n\nexport const screen = buildQueryMethods();\n\nexport const within = (element: ElementHandle) => buildQueryMethods({element});\n\nexport type {ElementHandle, Viewport} from 'puppeteer';\n\nbeforeEach(async () => {\n await getGlobalPage().setRequestInterception(false);\n\n // by resetting the page we clean up all the evaluateOnNewDocument calls, which are persistent between documents\n await (global as any).jestPuppeteer.resetPage();\n});\n\nafterEach(async () => {\n await collectCoverageIfAvailable({coveragePath});\n\n try {\n const page = getGlobalPage();\n requestHandlers = [];\n needsRequestInterception = false;\n page.off('request', requestInterceptor);\n\n // clear tab, this way we clear the DOM and stop js execution or pending requests\n await page.goto('about:blank');\n } catch (e) {\n // ignore, at this point page might be destroyed\n }\n});\n\n/**\n * Returns a new path to the file that can be used by chromium in acceptance tests\n *\n * To be able to use `element.uploadFile()` in a dockerized chromium, the file must exist in the\n * host and the docker, and both sides must use the same path.\n *\n * To workaround this bug or limitation, this function prepares the file by copying it to /tmp in\n * the host and the container.\n */\nexport const prepareFile = (filepath: string): string => {\n const isLocal = !isCi;\n const isHeadless = !!process.env.HEADLESS;\n const usesDocker = isLocal && isHeadless;\n\n const dockerComposeFile = path.join(__dirname, '..', 'docker-compose.yaml');\n\n if (usesDocker) {\n const containerId = execSync(`docker-compose -f ${dockerComposeFile} ps -q`).toString().trim();\n\n if (!containerId) {\n throw Error('acceptance-testing container not found');\n }\n\n execSync(`docker cp ${filepath} ${containerId}:/tmp`);\n\n const newPath = path.join('/tmp', path.basename(filepath));\n\n fs.copyFileSync(filepath, newPath);\n\n return newPath;\n } else {\n return filepath;\n }\n};\n\n/**\n * A convenience method to defer an expectation\n */\nexport const wait = <T>(expectation: () => Promise<T> | T, timeout = 10000, interval = 50): Promise<T> => {\n const startTime = Date.now();\n const startStack = new Error().stack;\n\n return new Promise((resolve, reject) => {\n const rejectOrRerun = (error: unknown) => {\n if (Date.now() - startTime >= timeout) {\n if (error instanceof Error) {\n if (error.message === 'Element not removed') {\n error.stack = startStack;\n }\n }\n reject(error);\n return;\n }\n // eslint-disable-next-line @typescript-eslint/no-use-before-define\n setTimeout(runExpectation, interval);\n };\n const runExpectation = () => {\n try {\n Promise.resolve(expectation())\n .then((r) => resolve(r))\n .catch(rejectOrRerun);\n } catch (error) {\n rejectOrRerun(error);\n }\n };\n setTimeout(runExpectation, 0);\n });\n};\n\nexport const waitForElementToBeRemoved = (\n element: ElementHandle<Element>,\n timeout = 10000,\n interval = 100\n): Promise<void> => {\n const startStack = new Error().stack;\n\n const wait = async () => {\n const t0 = Date.now();\n while (Date.now() - t0 < timeout) {\n // boundingBox returns null when the element is not in the DOM\n const box = await element.boundingBox();\n if (!box) {\n return;\n }\n await new Promise((resolve) => setTimeout(resolve, interval));\n }\n throw new Error('Element not removed');\n };\n\n return wait().catch((error) => {\n if (error.message === 'Element not removed') {\n error.stack = startStack;\n }\n throw error;\n });\n};\n"],"names":["getGlobalBrowser","global","browser","getGlobalPage","page","isCi","process","argv","includes","env","CI","isUsingDockerizedChromium","URL","wsEndpoint","port","serverHostName","platform","rootDir","findRoot","cwd","projectConfig","_pkg$acceptanceTests","JSON","parse","fs","readFileSync","path","join","acceptanceTests","server","_ref","ciServer","devServer","coveragePath","_projectConfig$covera","serverPort","calledToMatchImageSnapshotOutsideDocker","expect","extend","toMatchImageSnapshot","configureToMatchImageSnapshot","failureThreshold","failureThresholdType","customSnapshotIdentifier","_ref2","defaultIdentifier","message","pass","afterEach","error","Error","stack","split","waitForPaintEnd","_ref3","_asyncToGenerator","_regeneratorRuntime","mark","_callee","element","_temp","_ref4","_ref4$fullPage","fullPage","captureBeyondViewport","MAX_WAIT","STEP_TIME","t0","buf1","buf2","wrap","_context","prev","next","Date","now","screenshot","normalizeSreenshotOptions","sent","Promise","r","setTimeout","compare","stop","_x","_x2","apply","arguments","_temp2","_ref5$captureBeyondVi","_ref5","_extends","_objectWithoutPropertiesLoose","_excluded","scrollIntoView","el","evaluate","e","block","getPageApi","api","Object","create","type","_ref6","_callee2","elementHandle","text","options","_context2","abrupt","_x3","_x4","_x5","click","_ref7","_callee3","_context3","_x6","_x7","select","_ref8","_callee4","_len","values","_key","_args4","_context4","length","Array","_x8","_ref9","_callee5","_context5","skipNetworkWait","waitForNetworkIdle","_x9","clear","_ref10","_callee6","_context6","clickCount","press","_x10","setGeolocation","position","window","navigator","geolocation","getCurrentPosition","callback","coords","needsRequestInterception","requestHandlers","requestInterceptor","req","handler","_requestHandlers$find","find","_ref12","matcher","response","respond","interceptRequest","spy","jest","fn","push","openPage","_ref15","_callee7","_ref14","userAgent","isDarkMode","viewport","cookies","urlConfig","url","currentUserAgent","connectionError","_context7","_excluded2","undefined","_urlConfig$path","_urlConfig$port","_urlConfig$protocol","protocol","_urlConfig$hostname","hostname","bringToFront","setViewport","setCookie","setUserAgent","emulateMediaFeatures","name","value","evaluateOnNewDocument","overriddenSafeAreaInsets","keys","_viewport$safeAreaIns","safeAreaInset","map","key","_viewport$safeAreaIns2","style","document","createElement","innerHTML","addEventListener","head","appendChild","setRequestInterception","on","t1","captureStackTrace","waitForFunction","_x11","buildQueryMethods","_temp3","_ref16","boundQueries","_loop","_Object$entries$_i","_Object$entries","_i","queryName","queryFn","_callee12","doc","body","_len2","args","_key2","queryArgs","newElementHandle","_args12","_context12","getDocument","$","concat","startsWith","timeout","_ref18","_callee8","_context8","_x12","_ref19","_callee9","_context9","_x13","_ref20","_callee10","_context10","_x14","_x15","_callee11","_args11","_context11","entries","queries","screen","beforeEach","_callee13","_context13","jestPuppeteer","resetPage","_callee14","_context14","collectCoverageIfAvailable","off","_ref13","baseUrl","method","mockImplementation","status","headers","Access-Control-Allow-Origin","Access-Control-Allow-Methods","Access-Control-Allow-Headers","spyOn","urlPath","substring","match","globToRegExp","spyResult","_spyResult$status","contentType","stringify","filepath","isHeadless","HEADLESS","usesDocker","dockerComposeFile","__dirname","containerId","execSync","toString","trim","newPath","basename","copyFileSync","expectation","interval","startTime","startStack","resolve","reject","rejectOrRerun","runExpectation","then","_ref24","_callee15","_context15","boundingBox","wait"],"mappings":"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"}
@@ -5,6 +5,7 @@ import { queries, getDocument } from 'pptr-testing-library';
5
5
  import { configureToMatchImageSnapshot } from 'jest-image-snapshot';
6
6
  import globToRegExp from 'glob-to-regexp';
7
7
  import { execSync } from 'child_process';
8
+ import { collectCoverageIfAvailable } from 'coverage';
8
9
 
9
10
  function _regeneratorRuntime() {
10
11
  _regeneratorRuntime = function () {
@@ -364,96 +365,13 @@ function _objectWithoutPropertiesLoose(source, excluded) {
364
365
  return target;
365
366
  }
366
367
 
367
- var getGlobalPage = function getGlobalPage() {
368
- return global.page;
369
- };
370
- var getRootPath = function getRootPath() {
371
- var rootPath = expect.getState().snapshotState._rootDir;
372
- if (!rootPath) {
373
- throw new Error('Root path not found');
374
- }
375
- return rootPath;
376
- };
377
- /**
378
- * We want to clear coverage files from previous runs, but at this point it is not easy because each
379
- * worker runs a different instance of this script, so we can't just clear the coverage folder at
380
- * the beginning of the test run.
381
- *
382
- * The solution is to remove the coverage folder when the stored ppid (parent process id) is
383
- * different from the current one
384
- */
385
- var prepareCoverageReportPath = function prepareCoverageReportPath(_ref) {
386
- var coveragePath = _ref.coveragePath;
387
- var ppidFile = path.join(coveragePath, '.ppid');
388
- var ppid = process.ppid.toString();
389
- if (!fs.existsSync(ppidFile) || fs.readFileSync(ppidFile, 'utf-8') !== ppid) {
390
- // the condition is just to make sure we don't remove files outside the repo
391
- if (getRootPath() === process.cwd() && path.normalize(coveragePath).startsWith(process.cwd())) {
392
- fs.rmSync(coveragePath, {
393
- recursive: true,
394
- force: true
395
- });
396
- }
397
- fs.mkdirSync(coveragePath, {
398
- recursive: true
399
- });
400
- fs.writeFileSync(ppidFile, ppid);
401
- }
402
- };
403
- /**
404
- * Asumes the code was instrumented with istanbul and the coverage report stored in `window.__coverage__`.
405
- * If not, this function does nothing.
406
- */
407
- var collectCoverageIfAvailable = /*#__PURE__*/function () {
408
- var _ref3 = /*#__PURE__*/_asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee(_ref2) {
409
- var coveragePath, coverage, nycOutputPath;
410
- return _regeneratorRuntime().wrap(function _callee$(_context) {
411
- while (1) switch (_context.prev = _context.next) {
412
- case 0:
413
- coveragePath = _ref2.coveragePath;
414
- _context.next = 3;
415
- return getGlobalPage().evaluate(function () {
416
- return window.__coverage__;
417
- });
418
- case 3:
419
- coverage = _context.sent;
420
- if (coverage) {
421
- _context.next = 6;
422
- break;
423
- }
424
- return _context.abrupt("return");
425
- case 6:
426
- prepareCoverageReportPath({
427
- coveragePath: coveragePath
428
- });
429
- nycOutputPath = path.join(coveragePath, '.nyc_output');
430
- fs.mkdirSync(nycOutputPath, {
431
- recursive: true
432
- });
433
- Object.values(coverage).forEach(function (cov) {
434
- if (cov && cov.path && cov.hash) {
435
- var _JSON$stringify;
436
- fs.writeFileSync(path.join(nycOutputPath, cov.hash + '.json'), JSON.stringify((_JSON$stringify = {}, _JSON$stringify[cov.path] = cov, _JSON$stringify)));
437
- }
438
- });
439
- case 10:
440
- case "end":
441
- return _context.stop();
442
- }
443
- }, _callee);
444
- }));
445
- return function collectCoverageIfAvailable(_x) {
446
- return _ref3.apply(this, arguments);
447
- };
448
- }();
449
-
450
368
  var _excluded = ["captureBeyondViewport"],
451
369
  _excluded2 = ["userAgent", "isDarkMode", "viewport", "cookies"];
452
370
  var _pkg$acceptanceTests, _ref, _projectConfig$covera;
453
371
  var getGlobalBrowser = function getGlobalBrowser() {
454
372
  return global.browser;
455
373
  };
456
- var getGlobalPage$1 = function getGlobalPage() {
374
+ var getGlobalPage = function getGlobalPage() {
457
375
  return global.page;
458
376
  };
459
377
  var isCi = /*#__PURE__*/process.argv.includes('--ci') || process.env.CI;
@@ -710,7 +628,7 @@ var getPageApi = function getPageApi(page) {
710
628
  api.setGeolocation = function (position) {
711
629
  return page.evaluate(function (position) {
712
630
  window.navigator.geolocation.getCurrentPosition = function (callback) {
713
- // @ts-ignore
631
+ // @ts-expect-error - puppeteer's setGeoLocation does not expect a timestamp to be passed
714
632
  callback({
715
633
  coords: position
716
634
  });
@@ -755,7 +673,7 @@ var createApiEndpointMock = function createApiEndpointMock(_ref13) {
755
673
  status: 204,
756
674
  headers: {
757
675
  'Access-Control-Allow-Origin': '*',
758
- 'Access-Control-Allow-Methods': 'POST,PATCH,PUT,GET,OPTIONS',
676
+ 'Access-Control-Allow-Methods': 'POST,PATCH,PUT,GET,OPTIONS,DELETE',
759
677
  'Access-Control-Allow-Headers': '*'
760
678
  }
761
679
  };
@@ -809,9 +727,8 @@ var openPage = /*#__PURE__*/function () {
809
727
  _urlConfig$hostname = urlConfig.hostname,
810
728
  hostname = _urlConfig$hostname === void 0 ? serverHostName : _urlConfig$hostname;
811
729
  if (!port) {
812
- var error = new Error('You must specify a port. You can specify it when calling openPage() or by configuring a dev and ci server in the acceptanceTests config in your package.json');
813
730
  // Error.captureStackTrace(error, openPage);
814
- throw error;
731
+ throw new Error('You must specify a port. You can specify it when calling openPage() or by configuring a dev and ci server in the acceptanceTests config in your package.json');
815
732
  }
816
733
  return protocol + "://" + hostname + ":" + port + path;
817
734
  }();
@@ -826,7 +743,7 @@ var openPage = /*#__PURE__*/function () {
826
743
  _context7.t0 = _context7.sent;
827
744
  case 7:
828
745
  currentUserAgent = _context7.t0;
829
- page = getGlobalPage$1();
746
+ page = getGlobalPage();
830
747
  _context7.next = 11;
831
748
  return page.bringToFront();
832
749
  case 11:
@@ -854,13 +771,19 @@ var openPage = /*#__PURE__*/function () {
854
771
  }]);
855
772
  case 21:
856
773
  _context7.next = 23;
857
- return page.evaluateOnNewDocument(function () {
774
+ return page.evaluateOnNewDocument(function (viewport) {
775
+ var _viewport$safeAreaIns;
776
+ var overriddenSafeAreaInsets = !viewport ? [] : Object.keys((_viewport$safeAreaIns = viewport == null ? void 0 : viewport.safeAreaInset) != null ? _viewport$safeAreaIns : {}).map(function (key) {
777
+ var _viewport$safeAreaIns2;
778
+ var position = key;
779
+ return "--acceptance-test-override-safe-area-inset-" + key + ": " + (viewport == null ? void 0 : (_viewport$safeAreaIns2 = viewport.safeAreaInset) == null ? void 0 : _viewport$safeAreaIns2[position]) + ";";
780
+ });
858
781
  var style = document.createElement('style');
859
- style.innerHTML = "\n *, *:after, *:before {\n transition-delay: 0s !important;\n transition-duration: 0s !important;\n animation-delay: -0.0001s !important;\n animation-duration: 0s !important;\n animation-play-state: paused !important;\n caret-color: transparent !important;\n font-variant-ligatures: none !important;\n }\n *::-webkit-scrollbar {\n display: none !important;\n width: 0 !important;\n height: 0 !important;\n }\n ";
782
+ style.innerHTML = "\n *, *:after, *:before {\n transition-delay: 0s !important;\n transition-duration: 0s !important;\n animation-delay: -0.0001s !important;\n animation-duration: 0s !important;\n animation-play-state: paused !important;\n caret-color: transparent !important;\n font-variant-ligatures: none !important;\n }\n *::-webkit-scrollbar {\n display: none !important;\n width: 0 !important;\n height: 0 !important;\n }\n :root {\n " + overriddenSafeAreaInsets.join('\n') + "\n }\n ";
860
783
  window.addEventListener('DOMContentLoaded', function () {
861
784
  document.head.appendChild(style);
862
785
  });
863
- });
786
+ }, viewport);
864
787
  case 23:
865
788
  if (!needsRequestInterception) {
866
789
  _context7.next = 27;
@@ -927,7 +850,7 @@ var buildQueryMethods = function buildQueryMethods(_temp3) {
927
850
  while (1) switch (_context12.prev = _context12.next) {
928
851
  case 0:
929
852
  _context12.next = 2;
930
- return getDocument(page != null ? page : getGlobalPage$1());
853
+ return getDocument(page != null ? page : getGlobalPage());
931
854
  case 2:
932
855
  doc = _context12.sent;
933
856
  _context12.next = 5;
@@ -961,7 +884,7 @@ var buildQueryMethods = function buildQueryMethods(_temp3) {
961
884
  break;
962
885
  }
963
886
  _context8.next = 3;
964
- return (page != null ? page : getGlobalPage$1()).waitForNetworkIdle();
887
+ return (page != null ? page : getGlobalPage()).waitForNetworkIdle();
965
888
  case 3:
966
889
  _context8.next = 5;
967
890
  return waitForPaintEnd(elementHandle, _extends({}, options, {
@@ -1061,7 +984,7 @@ beforeEach( /*#__PURE__*/_asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().m
1061
984
  while (1) switch (_context13.prev = _context13.next) {
1062
985
  case 0:
1063
986
  _context13.next = 2;
1064
- return getGlobalPage$1().setRequestInterception(false);
987
+ return getGlobalPage().setRequestInterception(false);
1065
988
  case 2:
1066
989
  _context13.next = 4;
1067
990
  return global.jestPuppeteer.resetPage();
@@ -1082,7 +1005,7 @@ afterEach( /*#__PURE__*/_asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().ma
1082
1005
  });
1083
1006
  case 2:
1084
1007
  _context14.prev = 2;
1085
- page = getGlobalPage$1();
1008
+ page = getGlobalPage();
1086
1009
  requestHandlers = [];
1087
1010
  needsRequestInterception = false;
1088
1011
  page.off('request', requestInterceptor);
@@ -1223,5 +1146,5 @@ var waitForElementToBeRemoved = function waitForElementToBeRemoved(element, time
1223
1146
  });
1224
1147
  };
1225
1148
 
1226
- export { createApiEndpointMock, getGlobalBrowser, getGlobalPage$1 as getGlobalPage, getPageApi, getScreen, interceptRequest, openPage, prepareFile, screen, serverHostName, serverPort, wait, waitForElementToBeRemoved, within };
1149
+ export { createApiEndpointMock, getGlobalBrowser, getGlobalPage, getPageApi, getScreen, interceptRequest, openPage, prepareFile, screen, serverHostName, serverPort, wait, waitForElementToBeRemoved, within };
1227
1150
  //# sourceMappingURL=acceptance-testing.esm.js.map