@telefonica/acceptance-testing 2.23.1-beta0 → 2.23.2
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.
- package/README.md +13 -1
- package/dist/acceptance-testing.cjs.development.js +14 -13
- package/dist/acceptance-testing.cjs.development.js.map +1 -1
- package/dist/acceptance-testing.cjs.production.min.js +1 -1
- package/dist/acceptance-testing.cjs.production.min.js.map +1 -1
- package/dist/acceptance-testing.esm.js +14 -13
- package/dist/acceptance-testing.esm.js.map +1 -1
- package/dist/utils.d.ts +1 -1
- package/package.json +1 -1
package/README.md
CHANGED
|
@@ -144,7 +144,7 @@ If you can intercept and mock requests in your acceptance tests you can use the
|
|
|
144
144
|
import {openPage, screen, interceptRequest} from '@telefonica/acceptance-testing';
|
|
145
145
|
|
|
146
146
|
test('example screenshot test', async () => {
|
|
147
|
-
const imageSpy = interceptRequest(req => req.url().endsWith('.jpg'));
|
|
147
|
+
const imageSpy = interceptRequest((req) => req.url().endsWith('.jpg'));
|
|
148
148
|
|
|
149
149
|
imageSpy.mockReturnValue({
|
|
150
150
|
status: 200,
|
|
@@ -271,3 +271,15 @@ Example config:
|
|
|
271
271
|
```
|
|
272
272
|
|
|
273
273
|
After running the tests, you can use a tool like `nyc` to generate the coverage summaries.
|
|
274
|
+
|
|
275
|
+
## Troubleshooting
|
|
276
|
+
|
|
277
|
+
If you see an acceptance test failing without any apparent reason, it could be caused by an unhandled error in
|
|
278
|
+
the browser. You can inspect it by adding a listener to the `pageerror` event:
|
|
279
|
+
|
|
280
|
+
```ts
|
|
281
|
+
page.on('pageerror', (err) => {
|
|
282
|
+
console.log('Unhandled browser error:', err);
|
|
283
|
+
process.emit('uncaughtException', err);
|
|
284
|
+
});
|
|
285
|
+
```
|
|
@@ -454,7 +454,7 @@ var collectCoverageIfAvailable = /*#__PURE__*/function () {
|
|
|
454
454
|
}();
|
|
455
455
|
|
|
456
456
|
/**
|
|
457
|
-
* Returns true if the current path matches the spied path
|
|
457
|
+
* Returns true if the current path matches the spied path, including parameters
|
|
458
458
|
*/
|
|
459
459
|
var matchPath = function matchPath(spiedPath, currentPath) {
|
|
460
460
|
var normalizedCurrentPath = path.normalize(currentPath);
|
|
@@ -465,6 +465,7 @@ var matchPath = function matchPath(spiedPath, currentPath) {
|
|
|
465
465
|
var _excluded = ["captureBeyondViewport"],
|
|
466
466
|
_excluded2 = ["userAgent", "isDarkMode", "viewport", "cookies"];
|
|
467
467
|
var _pkg$acceptanceTests, _ref, _projectConfig$covera;
|
|
468
|
+
var LINUX_DOCKER_HOST_IP = '172.17.0.1';
|
|
468
469
|
var getGlobalBrowser = function getGlobalBrowser() {
|
|
469
470
|
return global.browser;
|
|
470
471
|
};
|
|
@@ -506,7 +507,13 @@ var isWsl2 = function isWsl2() {
|
|
|
506
507
|
};
|
|
507
508
|
/** Assumes running inside WSL */
|
|
508
509
|
var getWslHostIp = function getWslHostIp() {
|
|
509
|
-
|
|
510
|
+
var ips = child_process.execSync('wsl.exe hostname -I').toString().trim().split(/\s+/);
|
|
511
|
+
if (ips.includes(LINUX_DOCKER_HOST_IP)) {
|
|
512
|
+
// looks like a docker engine installed inside linux
|
|
513
|
+
return LINUX_DOCKER_HOST_IP;
|
|
514
|
+
}
|
|
515
|
+
// assuming docker-desktop installed in windows
|
|
516
|
+
return ips[0];
|
|
510
517
|
};
|
|
511
518
|
var serverHostName = /*#__PURE__*/function () {
|
|
512
519
|
if (isCi) {
|
|
@@ -522,7 +529,7 @@ var serverHostName = /*#__PURE__*/function () {
|
|
|
522
529
|
if (process.platform === 'win32') {
|
|
523
530
|
throw new Error('Windows is not supported. Please, use WSL 2.');
|
|
524
531
|
}
|
|
525
|
-
return process.platform === 'linux' ?
|
|
532
|
+
return process.platform === 'linux' ? LINUX_DOCKER_HOST_IP : 'host.docker.internal';
|
|
526
533
|
}
|
|
527
534
|
return 'localhost';
|
|
528
535
|
}();
|
|
@@ -776,14 +783,6 @@ var getPageApi = function getPageApi(page) {
|
|
|
776
783
|
};
|
|
777
784
|
}, position);
|
|
778
785
|
};
|
|
779
|
-
// Show information when the page crashes
|
|
780
|
-
// https://stackoverflow.com/questions/68364356/jest-puppeteer-test-randomly-fails-without-output/75621138
|
|
781
|
-
api.on('pageerror', function (err) {
|
|
782
|
-
// Print the error
|
|
783
|
-
console.log('Unhandled browser error:', err);
|
|
784
|
-
// Cause Jest to fail the test
|
|
785
|
-
process.emit('uncaughtException', err);
|
|
786
|
-
});
|
|
787
786
|
return api;
|
|
788
787
|
};
|
|
789
788
|
var needsRequestInterception = false;
|
|
@@ -840,9 +839,11 @@ var createApiEndpointMock = function createApiEndpointMock(_temp3) {
|
|
|
840
839
|
}
|
|
841
840
|
var matcher = function matcher(req) {
|
|
842
841
|
var _URL2 = new URL(req.url()),
|
|
842
|
+
origin = _URL2.origin,
|
|
843
843
|
pathname = _URL2.pathname,
|
|
844
|
-
|
|
845
|
-
|
|
844
|
+
search = _URL2.search;
|
|
845
|
+
var pathWithParams = pathname + search;
|
|
846
|
+
return req.method() === method && !!origin.match(originRegExp) && matchPath(spiedPath, pathWithParams);
|
|
846
847
|
};
|
|
847
848
|
var spy = jest.fn();
|
|
848
849
|
interceptRequest(matcher).mockImplementation(function (req) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"acceptance-testing.cjs.development.js","sources":["../src/coverage.ts","../src/utils.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 globToRegExp from 'glob-to-regexp';\n\n/**\n * Returns true if the current path matches the spied path\n */\nexport const matchPath = (spiedPath: string, currentPath: string): boolean => {\n const normalizedCurrentPath = path.normalize(currentPath);\n const pattern = globToRegExp(spiedPath);\n return pattern.test(normalizedCurrentPath);\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';\nimport {matchPath} from './utils';\n\nimport type {getQueriesForElement} from 'pptr-testing-library';\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\n/** Check if running inside WSL */\nconst isWsl = () => {\n if (process.platform !== 'linux') {\n return false;\n }\n try {\n return execSync('which wsl.exe').toString().startsWith('/mnt/');\n } catch (e) {\n // catched because it throws an error if wsl.exe is not found\n return false;\n }\n};\n\n/** Assumes running inside WSL */\nconst isWsl2 = () => {\n // `wsl.exe -l -v` returns something like:\n //\n // NAME STATE VERSION\n // * Ubuntu-22.04 Running 2\n // docker-desktop-data Running 2\n // docker-desktop Running 2\n // Ubuntu-20.04 Stopped 2\n return (\n execSync('wsl.exe -l -v')\n .toString()\n // null-bytes are inserted between chars in this command output (UTF-16 output?)\n .replace(/\\0/g, '')\n .split('\\n')\n .map((line) => line.trim())\n // matches a line like: \"* Ubuntu-22.04 Running 2\"\n .some((line) => !!line.match(/\\*\\s+\\S+\\s+Running\\s+2/))\n );\n};\n\n/** Assumes running inside WSL */\nconst getWslHostIp = () => execSync('wsl.exe hostname -I').toString().trim();\n\nexport const serverHostName = ((): string => {\n if (isCi) {\n return 'localhost';\n }\n\n if (isUsingDockerizedChromium) {\n if (isWsl()) {\n if (isWsl2()) {\n return getWslHostIp();\n }\n throw new Error('WSL 1 is not supported. Please, use WSL 2.');\n }\n\n if (process.platform === 'win32') {\n throw new Error('Windows is not supported. Please, use WSL 2.');\n }\n\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 // Show information when the page crashes\n // https://stackoverflow.com/questions/68364356/jest-puppeteer-test-randomly-fails-without-output/75621138\n api.on('pageerror', (err) => {\n // Print the error\n console.log('Unhandled browser error:', err);\n\n // Cause Jest to fail the test\n process.emit('uncaughtException', err);\n });\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 = ({\n /** defaults to any origin */\n origin,\n baseUrl,\n}: {\n origin?: string;\n /** @deprecated use origin */\n baseUrl?: string;\n} = {}): ApiEndpointMock => {\n const originRegExp = globToRegExp(origin ?? baseUrl ?? '*');\n\n interceptRequest((req) => {\n const {origin} = new URL(req.url());\n return req.method() === 'OPTIONS' && !!origin.match(originRegExp);\n }).mockImplementation(() => ({\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 return {\n spyOn(spiedPath: string, method: string = 'GET') {\n const matcher = (req: HTTPRequest) => {\n const {pathname, origin} = new URL(req.url());\n\n return (\n req.method() === method && !!origin.match(originRegExp) && matchPath(spiedPath, pathname)\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":["getGlobalPage","global","page","getRootPath","rootPath","expect","getState","snapshotState","_rootDir","Error","prepareCoverageReportPath","_ref","coveragePath","ppidFile","path","join","ppid","process","toString","fs","existsSync","readFileSync","cwd","normalize","startsWith","rmSync","recursive","force","mkdirSync","writeFileSync","collectCoverageIfAvailable","_ref3","_asyncToGenerator","_regeneratorRuntime","mark","_callee","_ref2","coverage","nycOutputPath","wrap","_callee$","_context","prev","next","evaluate","window","__coverage__","sent","abrupt","Object","values","forEach","cov","hash","_JSON$stringify","JSON","stringify","stop","_x","apply","arguments","matchPath","spiedPath","currentPath","normalizedCurrentPath","pattern","globToRegExp","test","getGlobalBrowser","browser","isCi","argv","includes","env","CI","isUsingDockerizedChromium","URL","wsEndpoint","port","isWsl","platform","execSync","e","isWsl2","replace","split","map","line","trim","some","match","getWslHostIp","serverHostName","rootDir","findRoot","pkg","parse","projectConfig","_pkg$acceptanceTests","acceptanceTests","server","ciServer","devServer","_projectConfig$covera","serverPort","toMatchImageSnapshot","configureToMatchImageSnapshot","failureThreshold","failureThresholdType","customSnapshotIdentifier","defaultIdentifier","calledToMatchImageSnapshotOutsideDocker","localToMatchImageSnapshot","message","pass","extend","afterEach","error","stack","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","options","_objectWithoutPropertiesLoose","_excluded","_extends","scrollIntoView","el","block","getPageApi","api","create","type","_ref6","_callee2","elementHandle","text","_callee2$","_context2","_x3","_x4","_x5","click","_ref7","_callee3","_callee3$","_context3","_x6","_x7","select","_ref8","_callee4","_len","_key","_args4","_callee4$","_context4","length","Array","_x8","_ref9","_callee5","_callee5$","_context5","skipNetworkWait","waitForNetworkIdle","_x9","clear","_ref10","_callee6","_callee6$","_context6","clickCount","press","_x10","setGeolocation","position","navigator","geolocation","getCurrentPosition","callback","coords","on","err","console","log","emit","needsRequestInterception","requestHandlers","requestInterceptor","req","_ref11","_requestHandlers$find","find","_ref12","matcher","handler","response","respond","interceptRequest","spy","jest","fn","push","createApiEndpointMock","_temp3","origin","_ref13","baseUrl","originRegExp","_ref14","_URL","url","method","mockImplementation","status","headers","spyOn","_URL2","pathname","spyResult","_spyResult$status","resBody","body","contentType","openPage","_ref16","_callee7","_ref15","userAgent","isDarkMode","viewport","cookies","urlConfig","currentUserAgent","connectionError","_callee7$","_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","key","_viewport$safeAreaIns2","style","document","createElement","innerHTML","addEventListener","head","appendChild","setRequestInterception","t1","captureStackTrace","waitForFunction","_x11","buildQueryMethods","_temp4","_ref17","boundQueries","_loop","_Object$entries$_i","_Object$entries","_i","queryName","queryFn","_callee12","doc","_len2","args","_key2","queryArgs","newElementHandle","_args12","_callee12$","_context12","getDocument","$","concat","timeout","_ref19","_callee8","_callee8$","_context8","_x12","_ref20","_callee9","_callee9$","_context9","_x13","_ref21","_callee10","_callee10$","_context10","_x14","_x15","_callee11","_args11","_callee11$","_context11","entries","queries","getScreen","screen","within","beforeEach","_callee13","_callee13$","_context13","jestPuppeteer","resetPage","_callee14","_callee14$","_context14","off","prepareFile","filepath","isLocal","isHeadless","HEADLESS","usesDocker","dockerComposeFile","__dirname","containerId","newPath","basename","copyFileSync","wait","expectation","interval","startTime","startStack","resolve","reject","rejectOrRerun","runExpectation","then","waitForElementToBeRemoved","_ref25","_callee15","box","_callee15$","_context15","boundingBox"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"acceptance-testing.cjs.development.js","sources":["../src/coverage.ts","../src/utils.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 globToRegExp from 'glob-to-regexp';\n\n/**\n * Returns true if the current path matches the spied path, including parameters\n */\nexport const matchPath = (spiedPath: string, currentPath: string): boolean => {\n const normalizedCurrentPath = path.normalize(currentPath);\n const pattern = globToRegExp(spiedPath);\n return pattern.test(normalizedCurrentPath);\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';\nimport {matchPath} from './utils';\n\nimport type {getQueriesForElement} from 'pptr-testing-library';\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\nconst LINUX_DOCKER_HOST_IP = '172.17.0.1';\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\n/** Check if running inside WSL */\nconst isWsl = () => {\n if (process.platform !== 'linux') {\n return false;\n }\n try {\n return execSync('which wsl.exe').toString().startsWith('/mnt/');\n } catch (e) {\n // catched because it throws an error if wsl.exe is not found\n return false;\n }\n};\n\n/** Assumes running inside WSL */\nconst isWsl2 = () => {\n // `wsl.exe -l -v` returns something like:\n //\n // NAME STATE VERSION\n // * Ubuntu-22.04 Running 2\n // docker-desktop-data Running 2\n // docker-desktop Running 2\n // Ubuntu-20.04 Stopped 2\n return (\n execSync('wsl.exe -l -v')\n .toString()\n // null-bytes are inserted between chars in this command output (UTF-16 output?)\n .replace(/\\0/g, '')\n .split('\\n')\n .map((line) => line.trim())\n // matches a line like: \"* Ubuntu-22.04 Running 2\"\n .some((line) => !!line.match(/\\*\\s+\\S+\\s+Running\\s+2/))\n );\n};\n\n/** Assumes running inside WSL */\nconst getWslHostIp = () => {\n const ips = execSync('wsl.exe hostname -I').toString().trim().split(/\\s+/);\n\n if (ips.includes(LINUX_DOCKER_HOST_IP)) {\n // looks like a docker engine installed inside linux\n return LINUX_DOCKER_HOST_IP;\n }\n // assuming docker-desktop installed in windows\n return ips[0];\n};\n\nexport const serverHostName = ((): string => {\n if (isCi) {\n return 'localhost';\n }\n\n if (isUsingDockerizedChromium) {\n if (isWsl()) {\n if (isWsl2()) {\n return getWslHostIp();\n }\n throw new Error('WSL 1 is not supported. Please, use WSL 2.');\n }\n\n if (process.platform === 'win32') {\n throw new Error('Windows is not supported. Please, use WSL 2.');\n }\n\n return process.platform === 'linux' ? LINUX_DOCKER_HOST_IP : '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 = ({\n /** defaults to any origin */\n origin,\n baseUrl,\n}: {\n origin?: string;\n /** @deprecated use origin */\n baseUrl?: string;\n} = {}): ApiEndpointMock => {\n const originRegExp = globToRegExp(origin ?? baseUrl ?? '*');\n\n interceptRequest((req) => {\n const {origin} = new URL(req.url());\n return req.method() === 'OPTIONS' && !!origin.match(originRegExp);\n }).mockImplementation(() => ({\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 return {\n spyOn(spiedPath: string, method: string = 'GET') {\n const matcher = (req: HTTPRequest) => {\n const {origin, pathname, search} = new URL(req.url());\n const pathWithParams = pathname + search;\n\n return (\n req.method() === method &&\n !!origin.match(originRegExp) &&\n matchPath(spiedPath, pathWithParams)\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":["getGlobalPage","global","page","getRootPath","rootPath","expect","getState","snapshotState","_rootDir","Error","prepareCoverageReportPath","_ref","coveragePath","ppidFile","path","join","ppid","process","toString","fs","existsSync","readFileSync","cwd","normalize","startsWith","rmSync","recursive","force","mkdirSync","writeFileSync","collectCoverageIfAvailable","_ref3","_asyncToGenerator","_regeneratorRuntime","mark","_callee","_ref2","coverage","nycOutputPath","wrap","_callee$","_context","prev","next","evaluate","window","__coverage__","sent","abrupt","Object","values","forEach","cov","hash","_JSON$stringify","JSON","stringify","stop","_x","apply","arguments","matchPath","spiedPath","currentPath","normalizedCurrentPath","pattern","globToRegExp","test","LINUX_DOCKER_HOST_IP","getGlobalBrowser","browser","isCi","argv","includes","env","CI","isUsingDockerizedChromium","URL","wsEndpoint","port","isWsl","platform","execSync","e","isWsl2","replace","split","map","line","trim","some","match","getWslHostIp","ips","serverHostName","rootDir","findRoot","pkg","parse","projectConfig","_pkg$acceptanceTests","acceptanceTests","server","ciServer","devServer","_projectConfig$covera","serverPort","toMatchImageSnapshot","configureToMatchImageSnapshot","failureThreshold","failureThresholdType","customSnapshotIdentifier","defaultIdentifier","calledToMatchImageSnapshotOutsideDocker","localToMatchImageSnapshot","message","pass","extend","afterEach","error","stack","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","options","_objectWithoutPropertiesLoose","_excluded","_extends","scrollIntoView","el","block","getPageApi","api","create","type","_ref6","_callee2","elementHandle","text","_callee2$","_context2","_x3","_x4","_x5","click","_ref7","_callee3","_callee3$","_context3","_x6","_x7","select","_ref8","_callee4","_len","_key","_args4","_callee4$","_context4","length","Array","_x8","_ref9","_callee5","_callee5$","_context5","skipNetworkWait","waitForNetworkIdle","_x9","clear","_ref10","_callee6","_callee6$","_context6","clickCount","press","_x10","setGeolocation","position","navigator","geolocation","getCurrentPosition","callback","coords","needsRequestInterception","requestHandlers","requestInterceptor","req","_ref11","_requestHandlers$find","find","_ref12","matcher","handler","response","respond","interceptRequest","spy","jest","fn","push","createApiEndpointMock","_temp3","origin","_ref13","baseUrl","originRegExp","_ref14","_URL","url","method","mockImplementation","status","headers","spyOn","_URL2","pathname","search","pathWithParams","spyResult","_spyResult$status","resBody","body","contentType","openPage","_ref16","_callee7","_ref15","userAgent","isDarkMode","viewport","cookies","urlConfig","currentUserAgent","connectionError","_callee7$","_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","key","_viewport$safeAreaIns2","style","document","createElement","innerHTML","addEventListener","head","appendChild","setRequestInterception","on","t1","captureStackTrace","waitForFunction","_x11","buildQueryMethods","_temp4","_ref17","boundQueries","_loop","_Object$entries$_i","_Object$entries","_i","queryName","queryFn","_callee12","doc","_len2","args","_key2","queryArgs","newElementHandle","_args12","_callee12$","_context12","getDocument","$","concat","timeout","_ref19","_callee8","_callee8$","_context8","_x12","_ref20","_callee9","_callee9$","_context9","_x13","_ref21","_callee10","_callee10$","_context10","_x14","_x15","_callee11","_args11","_callee11$","_context11","entries","queries","getScreen","screen","within","beforeEach","_callee13","_callee13$","_context13","jestPuppeteer","resetPage","_callee14","_callee14$","_context14","off","prepareFile","filepath","isLocal","isHeadless","HEADLESS","usesDocker","dockerComposeFile","__dirname","containerId","newPath","basename","copyFileSync","wait","expectation","interval","startTime","startStack","resolve","reject","rejectOrRerun","runExpectation","then","waitForElementToBeRemoved","_ref25","_callee15","box","_callee15$","_context15","boundingBox"],"mappings":"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"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";function e(e){return e&&"object"==typeof e&&"default"in e?e.default:e}Object.defineProperty(exports,"__esModule",{value:!0});var t=e(require("path")),r=e(require("fs")),n=e(require("find-root")),o=require("pptr-testing-library"),a=require("jest-image-snapshot"),i=e(require("glob-to-regexp")),c=require("child_process");function u(){u=function(){return e};var e={},t=Object.prototype,r=t.hasOwnProperty,n=Object.defineProperty||function(e,t,r){e[t]=r.value},o="function"==typeof Symbol?Symbol:{},a=o.iterator||"@@iterator",i=o.asyncIterator||"@@asyncIterator",c=o.toStringTag||"@@toStringTag";function s(e,t,r){return Object.defineProperty(e,t,{value:r,enumerable:!0,configurable:!0,writable:!0}),e[t]}try{s({},"")}catch(e){s=function(e,t,r){return e[t]=r}}function p(e,t,r,o){var a=Object.create((t&&t.prototype instanceof h?t:h).prototype),i=new O(o||[]);return n(a,"_invoke",{value:k(e,r,i)}),a}function l(e,t,r){try{return{type:"normal",arg:e.call(t,r)}}catch(e){return{type:"throw",arg:e}}}e.wrap=p;var f={};function h(){}function v(){}function d(){}var w={};s(w,a,(function(){return this}));var m=Object.getPrototypeOf,y=m&&m(m(j([])));y&&y!==t&&r.call(y,a)&&(w=y);var g=d.prototype=h.prototype=Object.create(w);function x(e){["next","throw","return"].forEach((function(t){s(e,t,(function(e){return this._invoke(t,e)}))}))}function b(e,t){var o;n(this,"_invoke",{value:function(n,a){function i(){return new t((function(o,i){!function n(o,a,i,c){var u=l(e[o],e,a);if("throw"!==u.type){var s=u.arg,p=s.value;return p&&"object"==typeof p&&r.call(p,"__await")?t.resolve(p.__await).then((function(e){n("next",e,i,c)}),(function(e){n("throw",e,i,c)})):t.resolve(p).then((function(e){s.value=e,i(s)}),(function(e){return n("throw",e,i,c)}))}c(u.arg)}(n,a,o,i)}))}return o=o?o.then(i,i):i()}})}function k(e,t,r){var n="suspendedStart";return function(o,a){if("executing"===n)throw new Error("Generator is already running");if("completed"===n){if("throw"===o)throw a;return{value:void 0,done:!0}}for(r.method=o,r.arg=a;;){var i=r.delegate;if(i){var c=E(i,r);if(c){if(c===f)continue;return c}}if("next"===r.method)r.sent=r._sent=r.arg;else if("throw"===r.method){if("suspendedStart"===n)throw n="completed",r.arg;r.dispatchException(r.arg)}else"return"===r.method&&r.abrupt("return",r.arg);n="executing";var u=l(e,t,r);if("normal"===u.type){if(n=r.done?"completed":"suspendedYield",u.arg===f)continue;return{value:u.arg,done:r.done}}"throw"===u.type&&(n="completed",r.method="throw",r.arg=u.arg)}}}function E(e,t){var r=t.method,n=e.iterator[r];if(void 0===n)return t.delegate=null,"throw"===r&&e.iterator.return&&(t.method="return",t.arg=void 0,E(e,t),"throw"===t.method)||"return"!==r&&(t.method="throw",t.arg=new TypeError("The iterator does not provide a '"+r+"' method")),f;var o=l(n,e.iterator,t.arg);if("throw"===o.type)return t.method="throw",t.arg=o.arg,t.delegate=null,f;var a=o.arg;return a?a.done?(t[e.resultName]=a.value,t.next=e.nextLoc,"return"!==t.method&&(t.method="next",t.arg=void 0),t.delegate=null,f):a:(t.method="throw",t.arg=new TypeError("iterator result is not an object"),t.delegate=null,f)}function S(e){var t={tryLoc:e[0]};1 in e&&(t.catchLoc=e[1]),2 in e&&(t.finallyLoc=e[2],t.afterLoc=e[3]),this.tryEntries.push(t)}function P(e){var t=e.completion||{};t.type="normal",delete t.arg,e.completion=t}function O(e){this.tryEntries=[{tryLoc:"root"}],e.forEach(S,this),this.reset(!0)}function j(e){if(e){var t=e[a];if(t)return t.call(e);if("function"==typeof e.next)return e;if(!isNaN(e.length)){var n=-1,o=function t(){for(;++n<e.length;)if(r.call(e,n))return t.value=e[n],t.done=!1,t;return t.value=void 0,t.done=!0,t};return o.next=o}}return{next:L}}function L(){return{value:void 0,done:!0}}return v.prototype=d,n(g,"constructor",{value:d,configurable:!0}),n(d,"constructor",{value:v,configurable:!0}),v.displayName=s(d,c,"GeneratorFunction"),e.isGeneratorFunction=function(e){var t="function"==typeof e&&e.constructor;return!!t&&(t===v||"GeneratorFunction"===(t.displayName||t.name))},e.mark=function(e){return Object.setPrototypeOf?Object.setPrototypeOf(e,d):(e.__proto__=d,s(e,c,"GeneratorFunction")),e.prototype=Object.create(g),e},e.awrap=function(e){return{__await:e}},x(b.prototype),s(b.prototype,i,(function(){return this})),e.AsyncIterator=b,e.async=function(t,r,n,o,a){void 0===a&&(a=Promise);var i=new b(p(t,r,n,o),a);return e.isGeneratorFunction(r)?i:i.next().then((function(e){return e.done?e.value:i.next()}))},x(g),s(g,c,"Generator"),s(g,a,(function(){return this})),s(g,"toString",(function(){return"[object Generator]"})),e.keys=function(e){var t=Object(e),r=[];for(var n in t)r.push(n);return r.reverse(),function e(){for(;r.length;){var n=r.pop();if(n in t)return e.value=n,e.done=!1,e}return e.done=!0,e}},e.values=j,O.prototype={constructor:O,reset:function(e){if(this.prev=0,this.next=0,this.sent=this._sent=void 0,this.done=!1,this.delegate=null,this.method="next",this.arg=void 0,this.tryEntries.forEach(P),!e)for(var t in this)"t"===t.charAt(0)&&r.call(this,t)&&!isNaN(+t.slice(1))&&(this[t]=void 0)},stop:function(){this.done=!0;var e=this.tryEntries[0].completion;if("throw"===e.type)throw e.arg;return this.rval},dispatchException:function(e){if(this.done)throw e;var t=this;function n(r,n){return i.type="throw",i.arg=e,t.next=r,n&&(t.method="next",t.arg=void 0),!!n}for(var o=this.tryEntries.length-1;o>=0;--o){var a=this.tryEntries[o],i=a.completion;if("root"===a.tryLoc)return n("end");if(a.tryLoc<=this.prev){var c=r.call(a,"catchLoc"),u=r.call(a,"finallyLoc");if(c&&u){if(this.prev<a.catchLoc)return n(a.catchLoc,!0);if(this.prev<a.finallyLoc)return n(a.finallyLoc)}else if(c){if(this.prev<a.catchLoc)return n(a.catchLoc,!0)}else{if(!u)throw new Error("try statement without catch or finally");if(this.prev<a.finallyLoc)return n(a.finallyLoc)}}}},abrupt:function(e,t){for(var n=this.tryEntries.length-1;n>=0;--n){var o=this.tryEntries[n];if(o.tryLoc<=this.prev&&r.call(o,"finallyLoc")&&this.prev<o.finallyLoc){var a=o;break}}a&&("break"===e||"continue"===e)&&a.tryLoc<=t&&t<=a.finallyLoc&&(a=null);var i=a?a.completion:{};return i.type=e,i.arg=t,a?(this.method="next",this.next=a.finallyLoc,f):this.complete(i)},complete:function(e,t){if("throw"===e.type)throw e.arg;return"break"===e.type||"continue"===e.type?this.next=e.arg:"return"===e.type?(this.rval=this.arg=e.arg,this.method="return",this.next="end"):"normal"===e.type&&t&&(this.next=t),f},finish:function(e){for(var t=this.tryEntries.length-1;t>=0;--t){var r=this.tryEntries[t];if(r.finallyLoc===e)return this.complete(r.completion,r.afterLoc),P(r),f}},catch:function(e){for(var t=this.tryEntries.length-1;t>=0;--t){var r=this.tryEntries[t];if(r.tryLoc===e){var n=r.completion;if("throw"===n.type){var o=n.arg;P(r)}return o}}throw new Error("illegal catch attempt")},delegateYield:function(e,t,r){return this.delegate={iterator:j(e),resultName:t,nextLoc:r},"next"===this.method&&(this.arg=void 0),f}},e}function s(e,t,r,n,o,a,i){try{var c=e[a](i),u=c.value}catch(e){return void r(e)}c.done?t(u):Promise.resolve(u).then(n,o)}function p(e){return function(){var t=this,r=arguments;return new Promise((function(n,o){var a=e.apply(t,r);function i(e){s(a,n,o,i,c,"next",e)}function c(e){s(a,n,o,i,c,"throw",e)}i(void 0)}))}}function l(){return(l=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var r=arguments[t];for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&(e[n]=r[n])}return e}).apply(this,arguments)}function f(e,t){if(null==e)return{};var r,n,o={},a=Object.keys(e);for(n=0;n<a.length;n++)t.indexOf(r=a[n])>=0||(o[r]=e[r]);return o}var h,v,d,w=function(e){var n=e.coveragePath,o=t.join(n,".ppid"),a=process.ppid.toString();r.existsSync(o)&&r.readFileSync(o,"utf-8")===a||(function(){var e=expect.getState().snapshotState._rootDir;if(!e)throw new Error("Root path not found");return e}()===process.cwd()&&t.normalize(n).startsWith(process.cwd())&&r.rmSync(n,{recursive:!0,force:!0}),r.mkdirSync(n,{recursive:!0}),r.writeFileSync(o,a))},m=function(){var e=p(u().mark((function e(n){var o,a,i;return u().wrap((function(e){for(;;)switch(e.prev=e.next){case 0:return o=n.coveragePath,e.next=3,global.page.evaluate((function(){return window.__coverage__}));case 3:if(a=e.sent){e.next=6;break}return e.abrupt("return");case 6:w({coveragePath:o}),i=t.join(o,".nyc_output"),r.mkdirSync(i,{recursive:!0}),Object.values(a).forEach((function(e){var n;e&&e.path&&e.hash&&r.writeFileSync(t.join(i,e.hash+".json"),JSON.stringify(((n={})[e.path]=e,n)))}));case 10:case"end":return e.stop()}}),e)})));return function(t){return e.apply(this,arguments)}}(),y=["captureBeyondViewport"],g=["userAgent","isDarkMode","viewport","cookies"],x=function(){return global.browser},b=function(){return global.page},k=process.argv.includes("--ci")||process.env.CI,E=k||"9223"===new URL(x().wsEndpoint()).port,S=function(){if(k)return"localhost";if(E){if(function(){if("linux"!==process.platform)return!1;try{return c.execSync("which wsl.exe").toString().startsWith("/mnt/")}catch(e){return!1}}()){if(c.execSync("wsl.exe -l -v").toString().replace(/\0/g,"").split("\n").map((function(e){return e.trim()})).some((function(e){return!!e.match(/\*\s+\S+\s+Running\s+2/)})))return c.execSync("wsl.exe hostname -I").toString().trim();throw new Error("WSL 1 is not supported. Please, use WSL 2.")}if("win32"===process.platform)throw new Error("Windows is not supported. Please, use WSL 2.");return"linux"===process.platform?"172.17.0.1":"host.docker.internal"}return"localhost"}(),P=n(process.cwd()),O=null!=(h=JSON.parse(r.readFileSync(t.join(P,"package.json"),"utf-8")).acceptanceTests)?h:{},j=null!=(v=k?O.ciServer:O.devServer)?v:O.server,L=t.join(P,null!=(d=O.coveragePath)?d:"reports/coverage-acceptance"),T=null==j?void 0:j.port,_=!1;expect.extend({toMatchImageSnapshot:E?a.configureToMatchImageSnapshot({failureThreshold:0,failureThresholdType:"percent",customSnapshotIdentifier:function(e){return e.defaultIdentifier}}):function(){return _=!0,{message:function(){return""},pass:!0}}}),afterEach((function(){if(_){var e=new Error("Calling .toMatchImageSnapshot() is not allowed outside dockerized browser. Please, run your screenshot test in headless mode.");throw e.stack=(e.stack||"").split("\n")[0],e}}));var I=function(){var e=p(u().mark((function e(t,r){var n,o,a,i,c,s,p,l,f;return u().wrap((function(e){for(;;)switch(e.prev=e.next){case 0:return a=void 0===(o=(n=void 0===r?{}:r).fullPage)||o,i=n.captureBeyondViewport,c=15e3,s=250,p=Date.now(),e.next=6,t.screenshot(A({fullPage:a,captureBeyondViewport:i}));case 6:return l=e.sent,e.next=9,new Promise((function(e){return setTimeout(e,s)}));case 9:return e.next=11,t.screenshot(A({fullPage:a,captureBeyondViewport:i}));case 11:f=e.sent;case 12:if(!l.compare(f)){e.next=23;break}if(!(Date.now()-p>c)){e.next=15;break}throw Error("Paint end timeout");case 15:return l=f,e.next=18,new Promise((function(e){return setTimeout(e,s)}));case 18:return e.next=20,t.screenshot(A({fullPage:a,captureBeyondViewport:i}));case 20:f=e.sent,e.next=12;break;case 23:case"end":return e.stop()}}),e)})));return function(t,r){return e.apply(this,arguments)}}(),A=function(e){var t=void 0===e?{}:e,r=t.captureBeyondViewport,n=void 0!==r&&r;return l({},f(t,y),{captureBeyondViewport:n})},N=function(e){return e.evaluate((function(e){return e.scrollIntoView({block:"center"})}))},F=function(e){var t=Object.create(e);return t.type=function(){var e=p(u().mark((function e(t,r,n){return u().wrap((function(e){for(;;)switch(e.prev=e.next){case 0:return e.next=2,N(t);case 2:return e.abrupt("return",t.type(r,n));case 3:case"end":return e.stop()}}),e)})));return function(t,r,n){return e.apply(this,arguments)}}(),t.click=function(){var e=p(u().mark((function e(t,r){return u().wrap((function(e){for(;;)switch(e.prev=e.next){case 0:return e.next=2,N(t);case 2:return e.abrupt("return",t.click(r));case 3:case"end":return e.stop()}}),e)})));return function(t,r){return e.apply(this,arguments)}}(),t.select=function(){var e=p(u().mark((function e(t){var r,n,o,a=arguments;return u().wrap((function(e){for(;;)switch(e.prev=e.next){case 0:return e.next=2,N(t);case 2:for(r=a.length,n=new Array(r>1?r-1:0),o=1;o<r;o++)n[o-1]=a[o];return e.abrupt("return",t.select.apply(t,n));case 4:case"end":return e.stop()}}),e)})));return function(t){return e.apply(this,arguments)}}(),t.screenshot=function(){var t=p(u().mark((function t(r){return u().wrap((function(t){for(;;)switch(t.prev=t.next){case 0:if(null!=r&&r.skipNetworkWait){t.next=3;break}return t.next=3,e.waitForNetworkIdle();case 3:return t.next=5,I(e,r);case 5:return t.abrupt("return",e.screenshot(A(r)));case 6:case"end":return t.stop()}}),t)})));return function(e){return t.apply(this,arguments)}}(),t.clear=function(){var e=p(u().mark((function e(t){return u().wrap((function(e){for(;;)switch(e.prev=e.next){case 0:return e.next=2,t.click({clickCount:3});case 2:return e.next=4,t.press("Delete");case 4:case"end":return e.stop()}}),e)})));return function(t){return e.apply(this,arguments)}}(),t.setGeolocation=function(t){return e.evaluate((function(e){window.navigator.geolocation.getCurrentPosition=function(t){t({coords:e})}}),t)},t.on("pageerror",(function(e){console.log("Unhandled browser error:",e),process.emit("uncaughtException",e)})),t},D=!1,C=[],q=function(e){var t,r=(null!=(t=C.find((function(t){return(0,t.matcher)(e)})))?t:{handler:null}).handler;if(r){var n=r(e);e.respond(n)}else e.continue()},G=function(e){D=!0;var t=jest.fn();return C.push({matcher:e,handler:t}),t},R=function(){var e=p(u().mark((function e(t){var r,n,o,a,i,c,s,p,l;return u().wrap((function(e){for(;;)switch(e.prev=e.next){case 0:if(r=t.userAgent,n=t.isDarkMode,o=t.viewport,a=t.cookies,i=f(t,g),c=function(){if(void 0!==i.url)return i.url;var e=i.path,t=void 0===e?"/":e,r=i.port,n=void 0===r?T:r,o=i.protocol,a=void 0===o?"http":o,c=i.hostname,u=void 0===c?S:c;if(!n)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");return a+"://"+u+":"+n+t}(),e.t0=r,e.t0){e.next=7;break}return e.next=6,x().userAgent();case 6:e.t0=e.sent;case 7:return s=e.t0,p=b(),e.next=11,p.bringToFront();case 11:if(!o){e.next=14;break}return e.next=14,p.setViewport(o);case 14:if(!a){e.next=17;break}return e.next=17,p.setCookie.apply(p,a);case 17:return e.next=19,p.setUserAgent(s+" acceptance-test");case 19:return e.next=21,p.emulateMediaFeatures([{name:"prefers-color-scheme",value:n?"dark":"light"}]);case 21:return e.next=23,p.evaluateOnNewDocument((function(e){var t,r=e?Object.keys(null!=(t=null==e?void 0:e.safeAreaInset)?t:{}).map((function(t){var r;return"--acceptance-test-override-safe-area-inset-"+t+": "+(null==e||null==(r=e.safeAreaInset)?void 0:r[t])+";"})):[],n=document.createElement("style");n.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 "+r.join("\n")+"\n }\n ",window.addEventListener("DOMContentLoaded",(function(){document.head.appendChild(n)}))}),o);case 23:if(!D){e.next=27;break}return e.next=26,p.setRequestInterception(!0);case 26:p.on("request",q);case 27:return e.prev=27,e.next=30,p.goto(c);case 30:e.next=41;break;case 32:if(e.prev=32,e.t1=e.catch(27),!e.t1.message.includes("net::ERR_CONNECTION_REFUSED")){e.next=40;break}throw l=new Error("Could not connect to "+c+". Is the server running?"),Error.captureStackTrace(l,R),l;case 40:throw e.t1;case 41:return e.next=43,p.waitForFunction('document.fonts.status === "loaded"');case 43:return e.abrupt("return",F(p));case 44:case"end":return e.stop()}}),e,null,[[27,32]])})));return function(t){return e.apply(this,arguments)}}(),B=function(e){for(var t=void 0===e?{}:e,r=t.page,n=t.element,a={},i=function(){var e=s[c],t=e[0],i=e[1];a[t]=p(u().mark((function e(){var a,c,s,f,h,v,d,w,m=arguments;return u().wrap((function(e){for(;;)switch(e.prev=e.next){case 0:return e.next=2,o.getDocument(null!=r?r:b());case 2:return a=e.sent,e.next=5,a.$("body");case 5:for(c=e.sent,s=m.length,f=new Array(s),h=0;h<s;h++)f[h]=m[h];return v=[].concat(f),t.startsWith("findBy")&&(1===v.length&&v.push(void 0),v.push({timeout:1e4})),e.next=11,i.apply(void 0,[null!=n?n:c].concat(v));case 11:return d=e.sent,(w=Object.create(d)).screenshot=function(){var e=p(u().mark((function e(t){return u().wrap((function(e){for(;;)switch(e.prev=e.next){case 0:if(null!=t&&t.skipNetworkWait){e.next=3;break}return e.next=3,(null!=r?r:b()).waitForNetworkIdle();case 3:return e.next=5,I(d,l({},t,{fullPage:!1}));case 5:return e.abrupt("return",d.screenshot(A(t)));case 6:case"end":return e.stop()}}),e)})));return function(t){return e.apply(this,arguments)}}(),w.click=function(){var e=p(u().mark((function e(t){return u().wrap((function(e){for(;;)switch(e.prev=e.next){case 0:return e.next=2,N(d);case 2:return e.abrupt("return",d.click(t));case 3:case"end":return e.stop()}}),e)})));return function(t){return e.apply(this,arguments)}}(),w.type=function(){var e=p(u().mark((function e(t,r){return u().wrap((function(e){for(;;)switch(e.prev=e.next){case 0:return e.next=2,N(d);case 2:return e.abrupt("return",d.type(t,r));case 3:case"end":return e.stop()}}),e)})));return function(t,r){return e.apply(this,arguments)}}(),w.select=p(u().mark((function e(){var t=arguments;return u().wrap((function(e){for(;;)switch(e.prev=e.next){case 0:return e.next=2,N(d);case 2:return e.abrupt("return",d.select.apply(d,t));case 3:case"end":return e.stop()}}),e)}))),e.abrupt("return",w);case 18:case"end":return e.stop()}}),e)})))},c=0,s=Object.entries(o.queries);c<s.length;c++)i();return a},M=B();beforeEach(p(u().mark((function e(){return u().wrap((function(e){for(;;)switch(e.prev=e.next){case 0:return e.next=2,b().setRequestInterception(!1);case 2:return e.next=4,global.jestPuppeteer.resetPage();case 4:case"end":return e.stop()}}),e)})))),afterEach(p(u().mark((function e(){var t;return u().wrap((function(e){for(;;)switch(e.prev=e.next){case 0:return e.next=2,m({coveragePath:L});case 2:return e.prev=2,t=b(),C=[],D=!1,t.off("request",q),e.next=9,t.goto("about:blank");case 9:e.next=13;break;case 11:e.prev=11,e.t0=e.catch(2);case 13:case"end":return e.stop()}}),e,null,[[2,11]])})))),exports.createApiEndpointMock=function(e){var r,n=void 0===e?{}:e,o=n.origin,a=i(null!=(r=null!=o?o:n.baseUrl)?r:"*");return G((function(e){var t=new URL(e.url()).origin;return"OPTIONS"===e.method()&&!!t.match(a)})).mockImplementation((function(){return{status:204,headers:{"Access-Control-Allow-Origin":"*","Access-Control-Allow-Methods":"POST,PATCH,PUT,GET,OPTIONS,DELETE","Access-Control-Allow-Headers":"*"}}})),{spyOn:function(e,r){void 0===r&&(r="GET");var n=jest.fn();return G((function(n){var o=new URL(n.url()),c=o.pathname,u=o.origin;return n.method()===r&&!!u.match(a)&&function(e,r){var n=t.normalize(r);return i(e).test(n)}(e,c)})).mockImplementation((function(e){var t,r=n(e);return{status:null!=(t=r.status)?t:200,headers:{"Access-Control-Allow-Origin":"*"},contentType:"application/json",body:JSON.stringify(r.body||r)}})),n}}},exports.getGlobalBrowser=x,exports.getGlobalPage=b,exports.getPageApi=F,exports.getScreen=function(e){return B({page:e})},exports.interceptRequest=G,exports.openPage=R,exports.prepareFile=function(e){var n=!!process.env.HEADLESS,o=!k&&n,a=t.join(__dirname,"..","docker-compose.yaml");if(o){var i=c.execSync("docker-compose -f "+a+" ps -q").toString().trim();if(!i)throw Error("acceptance-testing container not found");c.execSync("docker cp "+e+" "+i+":/tmp");var u=t.join("/tmp",t.basename(e));return r.copyFileSync(e,u),u}return e},exports.screen=M,exports.serverHostName=S,exports.serverPort=T,exports.wait=function(e,t,r){void 0===t&&(t=1e4),void 0===r&&(r=50);var n=Date.now(),o=(new Error).stack;return new Promise((function(a,i){var c=function(e){if(Date.now()-n>=t)return e instanceof Error&&"Element not removed"===e.message&&(e.stack=o),void i(e);setTimeout(u,r)},u=function(){try{Promise.resolve(e()).then((function(e){return a(e)})).catch(c)}catch(e){c(e)}};setTimeout(u,0)}))},exports.waitForElementToBeRemoved=function(e,t,r){void 0===t&&(t=1e4),void 0===r&&(r=100);var n=(new Error).stack;return function(){var n=p(u().mark((function n(){var o;return u().wrap((function(n){for(;;)switch(n.prev=n.next){case 0:o=Date.now();case 1:if(!(Date.now()-o<t)){n.next=11;break}return n.next=4,e.boundingBox();case 4:if(n.sent){n.next=7;break}return n.abrupt("return");case 7:return n.next=9,new Promise((function(e){return setTimeout(e,r)}));case 9:n.next=1;break;case 11:throw new Error("Element not removed");case 12:case"end":return n.stop()}}),n)})));return function(){return n.apply(this,arguments)}}()().catch((function(e){throw"Element not removed"===e.message&&(e.stack=n),e}))},exports.within=function(e){return B({element:e})};
|
|
1
|
+
"use strict";function e(e){return e&&"object"==typeof e&&"default"in e?e.default:e}Object.defineProperty(exports,"__esModule",{value:!0});var t=e(require("path")),r=e(require("fs")),n=e(require("find-root")),o=require("pptr-testing-library"),a=require("jest-image-snapshot"),i=e(require("glob-to-regexp")),c=require("child_process");function u(){u=function(){return e};var e={},t=Object.prototype,r=t.hasOwnProperty,n=Object.defineProperty||function(e,t,r){e[t]=r.value},o="function"==typeof Symbol?Symbol:{},a=o.iterator||"@@iterator",i=o.asyncIterator||"@@asyncIterator",c=o.toStringTag||"@@toStringTag";function s(e,t,r){return Object.defineProperty(e,t,{value:r,enumerable:!0,configurable:!0,writable:!0}),e[t]}try{s({},"")}catch(e){s=function(e,t,r){return e[t]=r}}function p(e,t,r,o){var a=Object.create((t&&t.prototype instanceof h?t:h).prototype),i=new O(o||[]);return n(a,"_invoke",{value:k(e,r,i)}),a}function l(e,t,r){try{return{type:"normal",arg:e.call(t,r)}}catch(e){return{type:"throw",arg:e}}}e.wrap=p;var f={};function h(){}function v(){}function d(){}var w={};s(w,a,(function(){return this}));var m=Object.getPrototypeOf,y=m&&m(m(j([])));y&&y!==t&&r.call(y,a)&&(w=y);var g=d.prototype=h.prototype=Object.create(w);function x(e){["next","throw","return"].forEach((function(t){s(e,t,(function(e){return this._invoke(t,e)}))}))}function b(e,t){var o;n(this,"_invoke",{value:function(n,a){function i(){return new t((function(o,i){!function n(o,a,i,c){var u=l(e[o],e,a);if("throw"!==u.type){var s=u.arg,p=s.value;return p&&"object"==typeof p&&r.call(p,"__await")?t.resolve(p.__await).then((function(e){n("next",e,i,c)}),(function(e){n("throw",e,i,c)})):t.resolve(p).then((function(e){s.value=e,i(s)}),(function(e){return n("throw",e,i,c)}))}c(u.arg)}(n,a,o,i)}))}return o=o?o.then(i,i):i()}})}function k(e,t,r){var n="suspendedStart";return function(o,a){if("executing"===n)throw new Error("Generator is already running");if("completed"===n){if("throw"===o)throw a;return{value:void 0,done:!0}}for(r.method=o,r.arg=a;;){var i=r.delegate;if(i){var c=E(i,r);if(c){if(c===f)continue;return c}}if("next"===r.method)r.sent=r._sent=r.arg;else if("throw"===r.method){if("suspendedStart"===n)throw n="completed",r.arg;r.dispatchException(r.arg)}else"return"===r.method&&r.abrupt("return",r.arg);n="executing";var u=l(e,t,r);if("normal"===u.type){if(n=r.done?"completed":"suspendedYield",u.arg===f)continue;return{value:u.arg,done:r.done}}"throw"===u.type&&(n="completed",r.method="throw",r.arg=u.arg)}}}function E(e,t){var r=t.method,n=e.iterator[r];if(void 0===n)return t.delegate=null,"throw"===r&&e.iterator.return&&(t.method="return",t.arg=void 0,E(e,t),"throw"===t.method)||"return"!==r&&(t.method="throw",t.arg=new TypeError("The iterator does not provide a '"+r+"' method")),f;var o=l(n,e.iterator,t.arg);if("throw"===o.type)return t.method="throw",t.arg=o.arg,t.delegate=null,f;var a=o.arg;return a?a.done?(t[e.resultName]=a.value,t.next=e.nextLoc,"return"!==t.method&&(t.method="next",t.arg=void 0),t.delegate=null,f):a:(t.method="throw",t.arg=new TypeError("iterator result is not an object"),t.delegate=null,f)}function S(e){var t={tryLoc:e[0]};1 in e&&(t.catchLoc=e[1]),2 in e&&(t.finallyLoc=e[2],t.afterLoc=e[3]),this.tryEntries.push(t)}function P(e){var t=e.completion||{};t.type="normal",delete t.arg,e.completion=t}function O(e){this.tryEntries=[{tryLoc:"root"}],e.forEach(S,this),this.reset(!0)}function j(e){if(e){var t=e[a];if(t)return t.call(e);if("function"==typeof e.next)return e;if(!isNaN(e.length)){var n=-1,o=function t(){for(;++n<e.length;)if(r.call(e,n))return t.value=e[n],t.done=!1,t;return t.value=void 0,t.done=!0,t};return o.next=o}}return{next:L}}function L(){return{value:void 0,done:!0}}return v.prototype=d,n(g,"constructor",{value:d,configurable:!0}),n(d,"constructor",{value:v,configurable:!0}),v.displayName=s(d,c,"GeneratorFunction"),e.isGeneratorFunction=function(e){var t="function"==typeof e&&e.constructor;return!!t&&(t===v||"GeneratorFunction"===(t.displayName||t.name))},e.mark=function(e){return Object.setPrototypeOf?Object.setPrototypeOf(e,d):(e.__proto__=d,s(e,c,"GeneratorFunction")),e.prototype=Object.create(g),e},e.awrap=function(e){return{__await:e}},x(b.prototype),s(b.prototype,i,(function(){return this})),e.AsyncIterator=b,e.async=function(t,r,n,o,a){void 0===a&&(a=Promise);var i=new b(p(t,r,n,o),a);return e.isGeneratorFunction(r)?i:i.next().then((function(e){return e.done?e.value:i.next()}))},x(g),s(g,c,"Generator"),s(g,a,(function(){return this})),s(g,"toString",(function(){return"[object Generator]"})),e.keys=function(e){var t=Object(e),r=[];for(var n in t)r.push(n);return r.reverse(),function e(){for(;r.length;){var n=r.pop();if(n in t)return e.value=n,e.done=!1,e}return e.done=!0,e}},e.values=j,O.prototype={constructor:O,reset:function(e){if(this.prev=0,this.next=0,this.sent=this._sent=void 0,this.done=!1,this.delegate=null,this.method="next",this.arg=void 0,this.tryEntries.forEach(P),!e)for(var t in this)"t"===t.charAt(0)&&r.call(this,t)&&!isNaN(+t.slice(1))&&(this[t]=void 0)},stop:function(){this.done=!0;var e=this.tryEntries[0].completion;if("throw"===e.type)throw e.arg;return this.rval},dispatchException:function(e){if(this.done)throw e;var t=this;function n(r,n){return i.type="throw",i.arg=e,t.next=r,n&&(t.method="next",t.arg=void 0),!!n}for(var o=this.tryEntries.length-1;o>=0;--o){var a=this.tryEntries[o],i=a.completion;if("root"===a.tryLoc)return n("end");if(a.tryLoc<=this.prev){var c=r.call(a,"catchLoc"),u=r.call(a,"finallyLoc");if(c&&u){if(this.prev<a.catchLoc)return n(a.catchLoc,!0);if(this.prev<a.finallyLoc)return n(a.finallyLoc)}else if(c){if(this.prev<a.catchLoc)return n(a.catchLoc,!0)}else{if(!u)throw new Error("try statement without catch or finally");if(this.prev<a.finallyLoc)return n(a.finallyLoc)}}}},abrupt:function(e,t){for(var n=this.tryEntries.length-1;n>=0;--n){var o=this.tryEntries[n];if(o.tryLoc<=this.prev&&r.call(o,"finallyLoc")&&this.prev<o.finallyLoc){var a=o;break}}a&&("break"===e||"continue"===e)&&a.tryLoc<=t&&t<=a.finallyLoc&&(a=null);var i=a?a.completion:{};return i.type=e,i.arg=t,a?(this.method="next",this.next=a.finallyLoc,f):this.complete(i)},complete:function(e,t){if("throw"===e.type)throw e.arg;return"break"===e.type||"continue"===e.type?this.next=e.arg:"return"===e.type?(this.rval=this.arg=e.arg,this.method="return",this.next="end"):"normal"===e.type&&t&&(this.next=t),f},finish:function(e){for(var t=this.tryEntries.length-1;t>=0;--t){var r=this.tryEntries[t];if(r.finallyLoc===e)return this.complete(r.completion,r.afterLoc),P(r),f}},catch:function(e){for(var t=this.tryEntries.length-1;t>=0;--t){var r=this.tryEntries[t];if(r.tryLoc===e){var n=r.completion;if("throw"===n.type){var o=n.arg;P(r)}return o}}throw new Error("illegal catch attempt")},delegateYield:function(e,t,r){return this.delegate={iterator:j(e),resultName:t,nextLoc:r},"next"===this.method&&(this.arg=void 0),f}},e}function s(e,t,r,n,o,a,i){try{var c=e[a](i),u=c.value}catch(e){return void r(e)}c.done?t(u):Promise.resolve(u).then(n,o)}function p(e){return function(){var t=this,r=arguments;return new Promise((function(n,o){var a=e.apply(t,r);function i(e){s(a,n,o,i,c,"next",e)}function c(e){s(a,n,o,i,c,"throw",e)}i(void 0)}))}}function l(){return(l=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var r=arguments[t];for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&(e[n]=r[n])}return e}).apply(this,arguments)}function f(e,t){if(null==e)return{};var r,n,o={},a=Object.keys(e);for(n=0;n<a.length;n++)t.indexOf(r=a[n])>=0||(o[r]=e[r]);return o}var h,v,d,w=function(e){var n=e.coveragePath,o=t.join(n,".ppid"),a=process.ppid.toString();r.existsSync(o)&&r.readFileSync(o,"utf-8")===a||(function(){var e=expect.getState().snapshotState._rootDir;if(!e)throw new Error("Root path not found");return e}()===process.cwd()&&t.normalize(n).startsWith(process.cwd())&&r.rmSync(n,{recursive:!0,force:!0}),r.mkdirSync(n,{recursive:!0}),r.writeFileSync(o,a))},m=function(){var e=p(u().mark((function e(n){var o,a,i;return u().wrap((function(e){for(;;)switch(e.prev=e.next){case 0:return o=n.coveragePath,e.next=3,global.page.evaluate((function(){return window.__coverage__}));case 3:if(a=e.sent){e.next=6;break}return e.abrupt("return");case 6:w({coveragePath:o}),i=t.join(o,".nyc_output"),r.mkdirSync(i,{recursive:!0}),Object.values(a).forEach((function(e){var n;e&&e.path&&e.hash&&r.writeFileSync(t.join(i,e.hash+".json"),JSON.stringify(((n={})[e.path]=e,n)))}));case 10:case"end":return e.stop()}}),e)})));return function(t){return e.apply(this,arguments)}}(),y=["captureBeyondViewport"],g=["userAgent","isDarkMode","viewport","cookies"],x=function(){return global.browser},b=function(){return global.page},k=process.argv.includes("--ci")||process.env.CI,E=k||"9223"===new URL(x().wsEndpoint()).port,S=function(){if(k)return"localhost";if(E){if(function(){if("linux"!==process.platform)return!1;try{return c.execSync("which wsl.exe").toString().startsWith("/mnt/")}catch(e){return!1}}()){if(c.execSync("wsl.exe -l -v").toString().replace(/\0/g,"").split("\n").map((function(e){return e.trim()})).some((function(e){return!!e.match(/\*\s+\S+\s+Running\s+2/)})))return(e=c.execSync("wsl.exe hostname -I").toString().trim().split(/\s+/)).includes("172.17.0.1")?"172.17.0.1":e[0];throw new Error("WSL 1 is not supported. Please, use WSL 2.")}if("win32"===process.platform)throw new Error("Windows is not supported. Please, use WSL 2.");return"linux"===process.platform?"172.17.0.1":"host.docker.internal"}var e;return"localhost"}(),P=n(process.cwd()),O=null!=(h=JSON.parse(r.readFileSync(t.join(P,"package.json"),"utf-8")).acceptanceTests)?h:{},j=null!=(v=k?O.ciServer:O.devServer)?v:O.server,L=t.join(P,null!=(d=O.coveragePath)?d:"reports/coverage-acceptance"),T=null==j?void 0:j.port,_=!1;expect.extend({toMatchImageSnapshot:E?a.configureToMatchImageSnapshot({failureThreshold:0,failureThresholdType:"percent",customSnapshotIdentifier:function(e){return e.defaultIdentifier}}):function(){return _=!0,{message:function(){return""},pass:!0}}}),afterEach((function(){if(_){var e=new Error("Calling .toMatchImageSnapshot() is not allowed outside dockerized browser. Please, run your screenshot test in headless mode.");throw e.stack=(e.stack||"").split("\n")[0],e}}));var I=function(){var e=p(u().mark((function e(t,r){var n,o,a,i,c,s,p,l,f;return u().wrap((function(e){for(;;)switch(e.prev=e.next){case 0:return a=void 0===(o=(n=void 0===r?{}:r).fullPage)||o,i=n.captureBeyondViewport,c=15e3,s=250,p=Date.now(),e.next=6,t.screenshot(A({fullPage:a,captureBeyondViewport:i}));case 6:return l=e.sent,e.next=9,new Promise((function(e){return setTimeout(e,s)}));case 9:return e.next=11,t.screenshot(A({fullPage:a,captureBeyondViewport:i}));case 11:f=e.sent;case 12:if(!l.compare(f)){e.next=23;break}if(!(Date.now()-p>c)){e.next=15;break}throw Error("Paint end timeout");case 15:return l=f,e.next=18,new Promise((function(e){return setTimeout(e,s)}));case 18:return e.next=20,t.screenshot(A({fullPage:a,captureBeyondViewport:i}));case 20:f=e.sent,e.next=12;break;case 23:case"end":return e.stop()}}),e)})));return function(t,r){return e.apply(this,arguments)}}(),A=function(e){var t=void 0===e?{}:e,r=t.captureBeyondViewport,n=void 0!==r&&r;return l({},f(t,y),{captureBeyondViewport:n})},N=function(e){return e.evaluate((function(e){return e.scrollIntoView({block:"center"})}))},F=function(e){var t=Object.create(e);return t.type=function(){var e=p(u().mark((function e(t,r,n){return u().wrap((function(e){for(;;)switch(e.prev=e.next){case 0:return e.next=2,N(t);case 2:return e.abrupt("return",t.type(r,n));case 3:case"end":return e.stop()}}),e)})));return function(t,r,n){return e.apply(this,arguments)}}(),t.click=function(){var e=p(u().mark((function e(t,r){return u().wrap((function(e){for(;;)switch(e.prev=e.next){case 0:return e.next=2,N(t);case 2:return e.abrupt("return",t.click(r));case 3:case"end":return e.stop()}}),e)})));return function(t,r){return e.apply(this,arguments)}}(),t.select=function(){var e=p(u().mark((function e(t){var r,n,o,a=arguments;return u().wrap((function(e){for(;;)switch(e.prev=e.next){case 0:return e.next=2,N(t);case 2:for(r=a.length,n=new Array(r>1?r-1:0),o=1;o<r;o++)n[o-1]=a[o];return e.abrupt("return",t.select.apply(t,n));case 4:case"end":return e.stop()}}),e)})));return function(t){return e.apply(this,arguments)}}(),t.screenshot=function(){var t=p(u().mark((function t(r){return u().wrap((function(t){for(;;)switch(t.prev=t.next){case 0:if(null!=r&&r.skipNetworkWait){t.next=3;break}return t.next=3,e.waitForNetworkIdle();case 3:return t.next=5,I(e,r);case 5:return t.abrupt("return",e.screenshot(A(r)));case 6:case"end":return t.stop()}}),t)})));return function(e){return t.apply(this,arguments)}}(),t.clear=function(){var e=p(u().mark((function e(t){return u().wrap((function(e){for(;;)switch(e.prev=e.next){case 0:return e.next=2,t.click({clickCount:3});case 2:return e.next=4,t.press("Delete");case 4:case"end":return e.stop()}}),e)})));return function(t){return e.apply(this,arguments)}}(),t.setGeolocation=function(t){return e.evaluate((function(e){window.navigator.geolocation.getCurrentPosition=function(t){t({coords:e})}}),t)},t},D=!1,C=[],q=function(e){var t,r=(null!=(t=C.find((function(t){return(0,t.matcher)(e)})))?t:{handler:null}).handler;if(r){var n=r(e);e.respond(n)}else e.continue()},G=function(e){D=!0;var t=jest.fn();return C.push({matcher:e,handler:t}),t},R=function(){var e=p(u().mark((function e(t){var r,n,o,a,i,c,s,p,l;return u().wrap((function(e){for(;;)switch(e.prev=e.next){case 0:if(r=t.userAgent,n=t.isDarkMode,o=t.viewport,a=t.cookies,i=f(t,g),c=function(){if(void 0!==i.url)return i.url;var e=i.path,t=void 0===e?"/":e,r=i.port,n=void 0===r?T:r,o=i.protocol,a=void 0===o?"http":o,c=i.hostname,u=void 0===c?S:c;if(!n)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");return a+"://"+u+":"+n+t}(),e.t0=r,e.t0){e.next=7;break}return e.next=6,x().userAgent();case 6:e.t0=e.sent;case 7:return s=e.t0,p=b(),e.next=11,p.bringToFront();case 11:if(!o){e.next=14;break}return e.next=14,p.setViewport(o);case 14:if(!a){e.next=17;break}return e.next=17,p.setCookie.apply(p,a);case 17:return e.next=19,p.setUserAgent(s+" acceptance-test");case 19:return e.next=21,p.emulateMediaFeatures([{name:"prefers-color-scheme",value:n?"dark":"light"}]);case 21:return e.next=23,p.evaluateOnNewDocument((function(e){var t,r=e?Object.keys(null!=(t=null==e?void 0:e.safeAreaInset)?t:{}).map((function(t){var r;return"--acceptance-test-override-safe-area-inset-"+t+": "+(null==e||null==(r=e.safeAreaInset)?void 0:r[t])+";"})):[],n=document.createElement("style");n.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 "+r.join("\n")+"\n }\n ",window.addEventListener("DOMContentLoaded",(function(){document.head.appendChild(n)}))}),o);case 23:if(!D){e.next=27;break}return e.next=26,p.setRequestInterception(!0);case 26:p.on("request",q);case 27:return e.prev=27,e.next=30,p.goto(c);case 30:e.next=41;break;case 32:if(e.prev=32,e.t1=e.catch(27),!e.t1.message.includes("net::ERR_CONNECTION_REFUSED")){e.next=40;break}throw l=new Error("Could not connect to "+c+". Is the server running?"),Error.captureStackTrace(l,R),l;case 40:throw e.t1;case 41:return e.next=43,p.waitForFunction('document.fonts.status === "loaded"');case 43:return e.abrupt("return",F(p));case 44:case"end":return e.stop()}}),e,null,[[27,32]])})));return function(t){return e.apply(this,arguments)}}(),B=function(e){for(var t=void 0===e?{}:e,r=t.page,n=t.element,a={},i=function(){var e=s[c],t=e[0],i=e[1];a[t]=p(u().mark((function e(){var a,c,s,f,h,v,d,w,m=arguments;return u().wrap((function(e){for(;;)switch(e.prev=e.next){case 0:return e.next=2,o.getDocument(null!=r?r:b());case 2:return a=e.sent,e.next=5,a.$("body");case 5:for(c=e.sent,s=m.length,f=new Array(s),h=0;h<s;h++)f[h]=m[h];return v=[].concat(f),t.startsWith("findBy")&&(1===v.length&&v.push(void 0),v.push({timeout:1e4})),e.next=11,i.apply(void 0,[null!=n?n:c].concat(v));case 11:return d=e.sent,(w=Object.create(d)).screenshot=function(){var e=p(u().mark((function e(t){return u().wrap((function(e){for(;;)switch(e.prev=e.next){case 0:if(null!=t&&t.skipNetworkWait){e.next=3;break}return e.next=3,(null!=r?r:b()).waitForNetworkIdle();case 3:return e.next=5,I(d,l({},t,{fullPage:!1}));case 5:return e.abrupt("return",d.screenshot(A(t)));case 6:case"end":return e.stop()}}),e)})));return function(t){return e.apply(this,arguments)}}(),w.click=function(){var e=p(u().mark((function e(t){return u().wrap((function(e){for(;;)switch(e.prev=e.next){case 0:return e.next=2,N(d);case 2:return e.abrupt("return",d.click(t));case 3:case"end":return e.stop()}}),e)})));return function(t){return e.apply(this,arguments)}}(),w.type=function(){var e=p(u().mark((function e(t,r){return u().wrap((function(e){for(;;)switch(e.prev=e.next){case 0:return e.next=2,N(d);case 2:return e.abrupt("return",d.type(t,r));case 3:case"end":return e.stop()}}),e)})));return function(t,r){return e.apply(this,arguments)}}(),w.select=p(u().mark((function e(){var t=arguments;return u().wrap((function(e){for(;;)switch(e.prev=e.next){case 0:return e.next=2,N(d);case 2:return e.abrupt("return",d.select.apply(d,t));case 3:case"end":return e.stop()}}),e)}))),e.abrupt("return",w);case 18:case"end":return e.stop()}}),e)})))},c=0,s=Object.entries(o.queries);c<s.length;c++)i();return a},M=B();beforeEach(p(u().mark((function e(){return u().wrap((function(e){for(;;)switch(e.prev=e.next){case 0:return e.next=2,b().setRequestInterception(!1);case 2:return e.next=4,global.jestPuppeteer.resetPage();case 4:case"end":return e.stop()}}),e)})))),afterEach(p(u().mark((function e(){var t;return u().wrap((function(e){for(;;)switch(e.prev=e.next){case 0:return e.next=2,m({coveragePath:L});case 2:return e.prev=2,t=b(),C=[],D=!1,t.off("request",q),e.next=9,t.goto("about:blank");case 9:e.next=13;break;case 11:e.prev=11,e.t0=e.catch(2);case 13:case"end":return e.stop()}}),e,null,[[2,11]])})))),exports.createApiEndpointMock=function(e){var r,n=void 0===e?{}:e,o=n.origin,a=i(null!=(r=null!=o?o:n.baseUrl)?r:"*");return G((function(e){var t=new URL(e.url()).origin;return"OPTIONS"===e.method()&&!!t.match(a)})).mockImplementation((function(){return{status:204,headers:{"Access-Control-Allow-Origin":"*","Access-Control-Allow-Methods":"POST,PATCH,PUT,GET,OPTIONS,DELETE","Access-Control-Allow-Headers":"*"}}})),{spyOn:function(e,r){void 0===r&&(r="GET");var n=jest.fn();return G((function(n){var o=new URL(n.url()),c=o.origin,u=o.pathname+o.search;return n.method()===r&&!!c.match(a)&&function(e,r){var n=t.normalize(r);return i(e).test(n)}(e,u)})).mockImplementation((function(e){var t,r=n(e);return{status:null!=(t=r.status)?t:200,headers:{"Access-Control-Allow-Origin":"*"},contentType:"application/json",body:JSON.stringify(r.body||r)}})),n}}},exports.getGlobalBrowser=x,exports.getGlobalPage=b,exports.getPageApi=F,exports.getScreen=function(e){return B({page:e})},exports.interceptRequest=G,exports.openPage=R,exports.prepareFile=function(e){var n=!!process.env.HEADLESS,o=!k&&n,a=t.join(__dirname,"..","docker-compose.yaml");if(o){var i=c.execSync("docker-compose -f "+a+" ps -q").toString().trim();if(!i)throw Error("acceptance-testing container not found");c.execSync("docker cp "+e+" "+i+":/tmp");var u=t.join("/tmp",t.basename(e));return r.copyFileSync(e,u),u}return e},exports.screen=M,exports.serverHostName=S,exports.serverPort=T,exports.wait=function(e,t,r){void 0===t&&(t=1e4),void 0===r&&(r=50);var n=Date.now(),o=(new Error).stack;return new Promise((function(a,i){var c=function(e){if(Date.now()-n>=t)return e instanceof Error&&"Element not removed"===e.message&&(e.stack=o),void i(e);setTimeout(u,r)},u=function(){try{Promise.resolve(e()).then((function(e){return a(e)})).catch(c)}catch(e){c(e)}};setTimeout(u,0)}))},exports.waitForElementToBeRemoved=function(e,t,r){void 0===t&&(t=1e4),void 0===r&&(r=100);var n=(new Error).stack;return function(){var n=p(u().mark((function n(){var o;return u().wrap((function(n){for(;;)switch(n.prev=n.next){case 0:o=Date.now();case 1:if(!(Date.now()-o<t)){n.next=11;break}return n.next=4,e.boundingBox();case 4:if(n.sent){n.next=7;break}return n.abrupt("return");case 7:return n.next=9,new Promise((function(e){return setTimeout(e,r)}));case 9:n.next=1;break;case 11:throw new Error("Element not removed");case 12:case"end":return n.stop()}}),n)})));return function(){return n.apply(this,arguments)}}()().catch((function(e){throw"Element not removed"===e.message&&(e.stack=n),e}))},exports.within=function(e){return B({element:e})};
|
|
2
2
|
//# sourceMappingURL=acceptance-testing.cjs.production.min.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"acceptance-testing.cjs.production.min.js","sources":["../src/coverage.ts","../src/index.ts","../src/utils.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';\nimport {matchPath} from './utils';\n\nimport type {getQueriesForElement} from 'pptr-testing-library';\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\n/** Check if running inside WSL */\nconst isWsl = () => {\n if (process.platform !== 'linux') {\n return false;\n }\n try {\n return execSync('which wsl.exe').toString().startsWith('/mnt/');\n } catch (e) {\n // catched because it throws an error if wsl.exe is not found\n return false;\n }\n};\n\n/** Assumes running inside WSL */\nconst isWsl2 = () => {\n // `wsl.exe -l -v` returns something like:\n //\n // NAME STATE VERSION\n // * Ubuntu-22.04 Running 2\n // docker-desktop-data Running 2\n // docker-desktop Running 2\n // Ubuntu-20.04 Stopped 2\n return (\n execSync('wsl.exe -l -v')\n .toString()\n // null-bytes are inserted between chars in this command output (UTF-16 output?)\n .replace(/\\0/g, '')\n .split('\\n')\n .map((line) => line.trim())\n // matches a line like: \"* Ubuntu-22.04 Running 2\"\n .some((line) => !!line.match(/\\*\\s+\\S+\\s+Running\\s+2/))\n );\n};\n\n/** Assumes running inside WSL */\nconst getWslHostIp = () => execSync('wsl.exe hostname -I').toString().trim();\n\nexport const serverHostName = ((): string => {\n if (isCi) {\n return 'localhost';\n }\n\n if (isUsingDockerizedChromium) {\n if (isWsl()) {\n if (isWsl2()) {\n return getWslHostIp();\n }\n throw new Error('WSL 1 is not supported. Please, use WSL 2.');\n }\n\n if (process.platform === 'win32') {\n throw new Error('Windows is not supported. Please, use WSL 2.');\n }\n\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 // Show information when the page crashes\n // https://stackoverflow.com/questions/68364356/jest-puppeteer-test-randomly-fails-without-output/75621138\n api.on('pageerror', (err) => {\n // Print the error\n console.log('Unhandled browser error:', err);\n\n // Cause Jest to fail the test\n process.emit('uncaughtException', err);\n });\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 = ({\n /** defaults to any origin */\n origin,\n baseUrl,\n}: {\n origin?: string;\n /** @deprecated use origin */\n baseUrl?: string;\n} = {}): ApiEndpointMock => {\n const originRegExp = globToRegExp(origin ?? baseUrl ?? '*');\n\n interceptRequest((req) => {\n const {origin} = new URL(req.url());\n return req.method() === 'OPTIONS' && !!origin.match(originRegExp);\n }).mockImplementation(() => ({\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 return {\n spyOn(spiedPath: string, method: string = 'GET') {\n const matcher = (req: HTTPRequest) => {\n const {pathname, origin} = new URL(req.url());\n\n return (\n req.method() === method && !!origin.match(originRegExp) && matchPath(spiedPath, pathname)\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","import path from 'path';\nimport globToRegExp from 'glob-to-regexp';\n\n/**\n * Returns true if the current path matches the spied path\n */\nexport const matchPath = (spiedPath: string, currentPath: string): boolean => {\n const normalizedCurrentPath = path.normalize(currentPath);\n const pattern = globToRegExp(spiedPath);\n return pattern.test(normalizedCurrentPath);\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","execSync","e","isWsl","replace","split","map","line","trim","some","match","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","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","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","on","err","console","log","emit","needsRequestInterception","requestHandlers","requestInterceptor","req","handler","_requestHandlers$find","find","_ref12","matcher","response","respond","interceptRequest","spy","jest","fn","push","openPage","_ref16","_callee7","_ref15","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","key","_viewport$safeAreaIns2","style","document","createElement","innerHTML","addEventListener","head","appendChild","setRequestInterception","t1","captureStackTrace","waitForFunction","_x11","buildQueryMethods","_temp4","_ref17","boundQueries","_loop","_Object$entries$_i","_Object$entries","_i","queryName","queryFn","_callee12","doc","body","_len2","args","_key2","queryArgs","newElementHandle","_args12","_context12","getDocument","$","concat","timeout","_ref19","_callee8","_context8","_x12","_ref20","_callee9","_context9","_x13","_ref21","_callee10","_context10","_x14","_x15","_callee11","_args11","_context11","entries","queries","screen","beforeEach","_callee13","_context13","jestPuppeteer","resetPage","_callee14","_context14","off","_temp3","origin","_ref13","originRegExp","globToRegExp","_ref14","baseUrl","method","mockImplementation","status","headers","Access-Control-Allow-Origin","Access-Control-Allow-Methods","Access-Control-Allow-Headers","spyOn","spiedPath","_URL2","pathname","currentPath","normalizedCurrentPath","test","matchPath","spyResult","_spyResult$status","contentType","filepath","isHeadless","HEADLESS","usesDocker","dockerComposeFile","__dirname","containerId","newPath","basename","copyFileSync","expectation","interval","startTime","startStack","resolve","reject","rejectOrRerun","runExpectation","then","_ref25","_callee15","_context15","boundingBox","wait"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"acceptance-testing.cjs.production.min.js","sources":["../src/coverage.ts","../src/index.ts","../src/utils.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';\nimport {matchPath} from './utils';\n\nimport type {getQueriesForElement} from 'pptr-testing-library';\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\nconst LINUX_DOCKER_HOST_IP = '172.17.0.1';\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\n/** Check if running inside WSL */\nconst isWsl = () => {\n if (process.platform !== 'linux') {\n return false;\n }\n try {\n return execSync('which wsl.exe').toString().startsWith('/mnt/');\n } catch (e) {\n // catched because it throws an error if wsl.exe is not found\n return false;\n }\n};\n\n/** Assumes running inside WSL */\nconst isWsl2 = () => {\n // `wsl.exe -l -v` returns something like:\n //\n // NAME STATE VERSION\n // * Ubuntu-22.04 Running 2\n // docker-desktop-data Running 2\n // docker-desktop Running 2\n // Ubuntu-20.04 Stopped 2\n return (\n execSync('wsl.exe -l -v')\n .toString()\n // null-bytes are inserted between chars in this command output (UTF-16 output?)\n .replace(/\\0/g, '')\n .split('\\n')\n .map((line) => line.trim())\n // matches a line like: \"* Ubuntu-22.04 Running 2\"\n .some((line) => !!line.match(/\\*\\s+\\S+\\s+Running\\s+2/))\n );\n};\n\n/** Assumes running inside WSL */\nconst getWslHostIp = () => {\n const ips = execSync('wsl.exe hostname -I').toString().trim().split(/\\s+/);\n\n if (ips.includes(LINUX_DOCKER_HOST_IP)) {\n // looks like a docker engine installed inside linux\n return LINUX_DOCKER_HOST_IP;\n }\n // assuming docker-desktop installed in windows\n return ips[0];\n};\n\nexport const serverHostName = ((): string => {\n if (isCi) {\n return 'localhost';\n }\n\n if (isUsingDockerizedChromium) {\n if (isWsl()) {\n if (isWsl2()) {\n return getWslHostIp();\n }\n throw new Error('WSL 1 is not supported. Please, use WSL 2.');\n }\n\n if (process.platform === 'win32') {\n throw new Error('Windows is not supported. Please, use WSL 2.');\n }\n\n return process.platform === 'linux' ? LINUX_DOCKER_HOST_IP : '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 = ({\n /** defaults to any origin */\n origin,\n baseUrl,\n}: {\n origin?: string;\n /** @deprecated use origin */\n baseUrl?: string;\n} = {}): ApiEndpointMock => {\n const originRegExp = globToRegExp(origin ?? baseUrl ?? '*');\n\n interceptRequest((req) => {\n const {origin} = new URL(req.url());\n return req.method() === 'OPTIONS' && !!origin.match(originRegExp);\n }).mockImplementation(() => ({\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 return {\n spyOn(spiedPath: string, method: string = 'GET') {\n const matcher = (req: HTTPRequest) => {\n const {origin, pathname, search} = new URL(req.url());\n const pathWithParams = pathname + search;\n\n return (\n req.method() === method &&\n !!origin.match(originRegExp) &&\n matchPath(spiedPath, pathWithParams)\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","import path from 'path';\nimport globToRegExp from 'glob-to-regexp';\n\n/**\n * Returns true if the current path matches the spied path, including parameters\n */\nexport const matchPath = (spiedPath: string, currentPath: string): boolean => {\n const normalizedCurrentPath = path.normalize(currentPath);\n const pattern = globToRegExp(spiedPath);\n return pattern.test(normalizedCurrentPath);\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","execSync","e","isWsl","replace","split","map","line","trim","some","match","ips","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","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","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","_ref16","_callee7","_ref15","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","key","_viewport$safeAreaIns2","style","document","createElement","innerHTML","addEventListener","head","appendChild","setRequestInterception","on","t1","captureStackTrace","waitForFunction","_x11","buildQueryMethods","_temp4","_ref17","boundQueries","_loop","_Object$entries$_i","_Object$entries","_i","queryName","queryFn","_callee12","doc","body","_len2","args","_key2","queryArgs","newElementHandle","_args12","_context12","getDocument","$","concat","timeout","_ref19","_callee8","_context8","_x12","_ref20","_callee9","_context9","_x13","_ref21","_callee10","_context10","_x14","_x15","_callee11","_args11","_context11","entries","queries","screen","beforeEach","_callee13","_context13","jestPuppeteer","resetPage","_callee14","_context14","off","_temp3","origin","_ref13","originRegExp","globToRegExp","_ref14","baseUrl","method","mockImplementation","status","headers","Access-Control-Allow-Origin","Access-Control-Allow-Methods","Access-Control-Allow-Headers","spyOn","spiedPath","_URL2","pathWithParams","pathname","search","currentPath","normalizedCurrentPath","test","matchPath","spyResult","_spyResult$status","contentType","filepath","isHeadless","HEADLESS","usesDocker","dockerComposeFile","__dirname","containerId","newPath","basename","copyFileSync","expectation","interval","startTime","startStack","resolve","reject","rejectOrRerun","runExpectation","then","_ref25","_callee15","_context15","boundingBox","wait"],"mappings":"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"}
|
|
@@ -448,7 +448,7 @@ var collectCoverageIfAvailable = /*#__PURE__*/function () {
|
|
|
448
448
|
}();
|
|
449
449
|
|
|
450
450
|
/**
|
|
451
|
-
* Returns true if the current path matches the spied path
|
|
451
|
+
* Returns true if the current path matches the spied path, including parameters
|
|
452
452
|
*/
|
|
453
453
|
var matchPath = function matchPath(spiedPath, currentPath) {
|
|
454
454
|
var normalizedCurrentPath = path.normalize(currentPath);
|
|
@@ -459,6 +459,7 @@ var matchPath = function matchPath(spiedPath, currentPath) {
|
|
|
459
459
|
var _excluded = ["captureBeyondViewport"],
|
|
460
460
|
_excluded2 = ["userAgent", "isDarkMode", "viewport", "cookies"];
|
|
461
461
|
var _pkg$acceptanceTests, _ref, _projectConfig$covera;
|
|
462
|
+
var LINUX_DOCKER_HOST_IP = '172.17.0.1';
|
|
462
463
|
var getGlobalBrowser = function getGlobalBrowser() {
|
|
463
464
|
return global.browser;
|
|
464
465
|
};
|
|
@@ -500,7 +501,13 @@ var isWsl2 = function isWsl2() {
|
|
|
500
501
|
};
|
|
501
502
|
/** Assumes running inside WSL */
|
|
502
503
|
var getWslHostIp = function getWslHostIp() {
|
|
503
|
-
|
|
504
|
+
var ips = execSync('wsl.exe hostname -I').toString().trim().split(/\s+/);
|
|
505
|
+
if (ips.includes(LINUX_DOCKER_HOST_IP)) {
|
|
506
|
+
// looks like a docker engine installed inside linux
|
|
507
|
+
return LINUX_DOCKER_HOST_IP;
|
|
508
|
+
}
|
|
509
|
+
// assuming docker-desktop installed in windows
|
|
510
|
+
return ips[0];
|
|
504
511
|
};
|
|
505
512
|
var serverHostName = /*#__PURE__*/function () {
|
|
506
513
|
if (isCi) {
|
|
@@ -516,7 +523,7 @@ var serverHostName = /*#__PURE__*/function () {
|
|
|
516
523
|
if (process.platform === 'win32') {
|
|
517
524
|
throw new Error('Windows is not supported. Please, use WSL 2.');
|
|
518
525
|
}
|
|
519
|
-
return process.platform === 'linux' ?
|
|
526
|
+
return process.platform === 'linux' ? LINUX_DOCKER_HOST_IP : 'host.docker.internal';
|
|
520
527
|
}
|
|
521
528
|
return 'localhost';
|
|
522
529
|
}();
|
|
@@ -770,14 +777,6 @@ var getPageApi = function getPageApi(page) {
|
|
|
770
777
|
};
|
|
771
778
|
}, position);
|
|
772
779
|
};
|
|
773
|
-
// Show information when the page crashes
|
|
774
|
-
// https://stackoverflow.com/questions/68364356/jest-puppeteer-test-randomly-fails-without-output/75621138
|
|
775
|
-
api.on('pageerror', function (err) {
|
|
776
|
-
// Print the error
|
|
777
|
-
console.log('Unhandled browser error:', err);
|
|
778
|
-
// Cause Jest to fail the test
|
|
779
|
-
process.emit('uncaughtException', err);
|
|
780
|
-
});
|
|
781
780
|
return api;
|
|
782
781
|
};
|
|
783
782
|
var needsRequestInterception = false;
|
|
@@ -834,9 +833,11 @@ var createApiEndpointMock = function createApiEndpointMock(_temp3) {
|
|
|
834
833
|
}
|
|
835
834
|
var matcher = function matcher(req) {
|
|
836
835
|
var _URL2 = new URL(req.url()),
|
|
836
|
+
origin = _URL2.origin,
|
|
837
837
|
pathname = _URL2.pathname,
|
|
838
|
-
|
|
839
|
-
|
|
838
|
+
search = _URL2.search;
|
|
839
|
+
var pathWithParams = pathname + search;
|
|
840
|
+
return req.method() === method && !!origin.match(originRegExp) && matchPath(spiedPath, pathWithParams);
|
|
840
841
|
};
|
|
841
842
|
var spy = jest.fn();
|
|
842
843
|
interceptRequest(matcher).mockImplementation(function (req) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"acceptance-testing.esm.js","sources":["../src/coverage.ts","../src/utils.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 globToRegExp from 'glob-to-regexp';\n\n/**\n * Returns true if the current path matches the spied path\n */\nexport const matchPath = (spiedPath: string, currentPath: string): boolean => {\n const normalizedCurrentPath = path.normalize(currentPath);\n const pattern = globToRegExp(spiedPath);\n return pattern.test(normalizedCurrentPath);\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';\nimport {matchPath} from './utils';\n\nimport type {getQueriesForElement} from 'pptr-testing-library';\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\n/** Check if running inside WSL */\nconst isWsl = () => {\n if (process.platform !== 'linux') {\n return false;\n }\n try {\n return execSync('which wsl.exe').toString().startsWith('/mnt/');\n } catch (e) {\n // catched because it throws an error if wsl.exe is not found\n return false;\n }\n};\n\n/** Assumes running inside WSL */\nconst isWsl2 = () => {\n // `wsl.exe -l -v` returns something like:\n //\n // NAME STATE VERSION\n // * Ubuntu-22.04 Running 2\n // docker-desktop-data Running 2\n // docker-desktop Running 2\n // Ubuntu-20.04 Stopped 2\n return (\n execSync('wsl.exe -l -v')\n .toString()\n // null-bytes are inserted between chars in this command output (UTF-16 output?)\n .replace(/\\0/g, '')\n .split('\\n')\n .map((line) => line.trim())\n // matches a line like: \"* Ubuntu-22.04 Running 2\"\n .some((line) => !!line.match(/\\*\\s+\\S+\\s+Running\\s+2/))\n );\n};\n\n/** Assumes running inside WSL */\nconst getWslHostIp = () => execSync('wsl.exe hostname -I').toString().trim();\n\nexport const serverHostName = ((): string => {\n if (isCi) {\n return 'localhost';\n }\n\n if (isUsingDockerizedChromium) {\n if (isWsl()) {\n if (isWsl2()) {\n return getWslHostIp();\n }\n throw new Error('WSL 1 is not supported. Please, use WSL 2.');\n }\n\n if (process.platform === 'win32') {\n throw new Error('Windows is not supported. Please, use WSL 2.');\n }\n\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 // Show information when the page crashes\n // https://stackoverflow.com/questions/68364356/jest-puppeteer-test-randomly-fails-without-output/75621138\n api.on('pageerror', (err) => {\n // Print the error\n console.log('Unhandled browser error:', err);\n\n // Cause Jest to fail the test\n process.emit('uncaughtException', err);\n });\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 = ({\n /** defaults to any origin */\n origin,\n baseUrl,\n}: {\n origin?: string;\n /** @deprecated use origin */\n baseUrl?: string;\n} = {}): ApiEndpointMock => {\n const originRegExp = globToRegExp(origin ?? baseUrl ?? '*');\n\n interceptRequest((req) => {\n const {origin} = new URL(req.url());\n return req.method() === 'OPTIONS' && !!origin.match(originRegExp);\n }).mockImplementation(() => ({\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 return {\n spyOn(spiedPath: string, method: string = 'GET') {\n const matcher = (req: HTTPRequest) => {\n const {pathname, origin} = new URL(req.url());\n\n return (\n req.method() === method && !!origin.match(originRegExp) && matchPath(spiedPath, pathname)\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":["getGlobalPage","global","page","getRootPath","rootPath","expect","getState","snapshotState","_rootDir","Error","prepareCoverageReportPath","_ref","coveragePath","ppidFile","path","join","ppid","process","toString","fs","existsSync","readFileSync","cwd","normalize","startsWith","rmSync","recursive","force","mkdirSync","writeFileSync","collectCoverageIfAvailable","_ref3","_asyncToGenerator","_regeneratorRuntime","mark","_callee","_ref2","coverage","nycOutputPath","wrap","_callee$","_context","prev","next","evaluate","window","__coverage__","sent","abrupt","Object","values","forEach","cov","hash","_JSON$stringify","JSON","stringify","stop","_x","apply","arguments","matchPath","spiedPath","currentPath","normalizedCurrentPath","pattern","globToRegExp","test","getGlobalBrowser","browser","isCi","argv","includes","env","CI","isUsingDockerizedChromium","URL","wsEndpoint","port","isWsl","platform","execSync","e","isWsl2","replace","split","map","line","trim","some","match","getWslHostIp","serverHostName","rootDir","findRoot","pkg","parse","projectConfig","_pkg$acceptanceTests","acceptanceTests","server","ciServer","devServer","_projectConfig$covera","serverPort","toMatchImageSnapshot","configureToMatchImageSnapshot","failureThreshold","failureThresholdType","customSnapshotIdentifier","defaultIdentifier","calledToMatchImageSnapshotOutsideDocker","localToMatchImageSnapshot","message","pass","extend","afterEach","error","stack","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","options","_objectWithoutPropertiesLoose","_excluded","_extends","scrollIntoView","el","block","getPageApi","api","create","type","_ref6","_callee2","elementHandle","text","_callee2$","_context2","_x3","_x4","_x5","click","_ref7","_callee3","_callee3$","_context3","_x6","_x7","select","_ref8","_callee4","_len","_key","_args4","_callee4$","_context4","length","Array","_x8","_ref9","_callee5","_callee5$","_context5","skipNetworkWait","waitForNetworkIdle","_x9","clear","_ref10","_callee6","_callee6$","_context6","clickCount","press","_x10","setGeolocation","position","navigator","geolocation","getCurrentPosition","callback","coords","on","err","console","log","emit","needsRequestInterception","requestHandlers","requestInterceptor","req","_ref11","_requestHandlers$find","find","_ref12","matcher","handler","response","respond","interceptRequest","spy","jest","fn","push","createApiEndpointMock","_temp3","origin","_ref13","baseUrl","originRegExp","_ref14","_URL","url","method","mockImplementation","status","headers","spyOn","_URL2","pathname","spyResult","_spyResult$status","resBody","body","contentType","openPage","_ref16","_callee7","_ref15","userAgent","isDarkMode","viewport","cookies","urlConfig","currentUserAgent","connectionError","_callee7$","_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","key","_viewport$safeAreaIns2","style","document","createElement","innerHTML","addEventListener","head","appendChild","setRequestInterception","t1","captureStackTrace","waitForFunction","_x11","buildQueryMethods","_temp4","_ref17","boundQueries","_loop","_Object$entries$_i","_Object$entries","_i","queryName","queryFn","_callee12","doc","_len2","args","_key2","queryArgs","newElementHandle","_args12","_callee12$","_context12","getDocument","$","concat","timeout","_ref19","_callee8","_callee8$","_context8","_x12","_ref20","_callee9","_callee9$","_context9","_x13","_ref21","_callee10","_callee10$","_context10","_x14","_x15","_callee11","_args11","_callee11$","_context11","entries","queries","getScreen","screen","within","beforeEach","_callee13","_callee13$","_context13","jestPuppeteer","resetPage","_callee14","_callee14$","_context14","off","prepareFile","filepath","isLocal","isHeadless","HEADLESS","usesDocker","dockerComposeFile","__dirname","containerId","newPath","basename","copyFileSync","wait","expectation","interval","startTime","startStack","resolve","reject","rejectOrRerun","runExpectation","then","waitForElementToBeRemoved","_ref25","_callee15","box","_callee15$","_context15","boundingBox"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"acceptance-testing.esm.js","sources":["../src/coverage.ts","../src/utils.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 globToRegExp from 'glob-to-regexp';\n\n/**\n * Returns true if the current path matches the spied path, including parameters\n */\nexport const matchPath = (spiedPath: string, currentPath: string): boolean => {\n const normalizedCurrentPath = path.normalize(currentPath);\n const pattern = globToRegExp(spiedPath);\n return pattern.test(normalizedCurrentPath);\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';\nimport {matchPath} from './utils';\n\nimport type {getQueriesForElement} from 'pptr-testing-library';\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\nconst LINUX_DOCKER_HOST_IP = '172.17.0.1';\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\n/** Check if running inside WSL */\nconst isWsl = () => {\n if (process.platform !== 'linux') {\n return false;\n }\n try {\n return execSync('which wsl.exe').toString().startsWith('/mnt/');\n } catch (e) {\n // catched because it throws an error if wsl.exe is not found\n return false;\n }\n};\n\n/** Assumes running inside WSL */\nconst isWsl2 = () => {\n // `wsl.exe -l -v` returns something like:\n //\n // NAME STATE VERSION\n // * Ubuntu-22.04 Running 2\n // docker-desktop-data Running 2\n // docker-desktop Running 2\n // Ubuntu-20.04 Stopped 2\n return (\n execSync('wsl.exe -l -v')\n .toString()\n // null-bytes are inserted between chars in this command output (UTF-16 output?)\n .replace(/\\0/g, '')\n .split('\\n')\n .map((line) => line.trim())\n // matches a line like: \"* Ubuntu-22.04 Running 2\"\n .some((line) => !!line.match(/\\*\\s+\\S+\\s+Running\\s+2/))\n );\n};\n\n/** Assumes running inside WSL */\nconst getWslHostIp = () => {\n const ips = execSync('wsl.exe hostname -I').toString().trim().split(/\\s+/);\n\n if (ips.includes(LINUX_DOCKER_HOST_IP)) {\n // looks like a docker engine installed inside linux\n return LINUX_DOCKER_HOST_IP;\n }\n // assuming docker-desktop installed in windows\n return ips[0];\n};\n\nexport const serverHostName = ((): string => {\n if (isCi) {\n return 'localhost';\n }\n\n if (isUsingDockerizedChromium) {\n if (isWsl()) {\n if (isWsl2()) {\n return getWslHostIp();\n }\n throw new Error('WSL 1 is not supported. Please, use WSL 2.');\n }\n\n if (process.platform === 'win32') {\n throw new Error('Windows is not supported. Please, use WSL 2.');\n }\n\n return process.platform === 'linux' ? LINUX_DOCKER_HOST_IP : '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 = ({\n /** defaults to any origin */\n origin,\n baseUrl,\n}: {\n origin?: string;\n /** @deprecated use origin */\n baseUrl?: string;\n} = {}): ApiEndpointMock => {\n const originRegExp = globToRegExp(origin ?? baseUrl ?? '*');\n\n interceptRequest((req) => {\n const {origin} = new URL(req.url());\n return req.method() === 'OPTIONS' && !!origin.match(originRegExp);\n }).mockImplementation(() => ({\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 return {\n spyOn(spiedPath: string, method: string = 'GET') {\n const matcher = (req: HTTPRequest) => {\n const {origin, pathname, search} = new URL(req.url());\n const pathWithParams = pathname + search;\n\n return (\n req.method() === method &&\n !!origin.match(originRegExp) &&\n matchPath(spiedPath, pathWithParams)\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":["getGlobalPage","global","page","getRootPath","rootPath","expect","getState","snapshotState","_rootDir","Error","prepareCoverageReportPath","_ref","coveragePath","ppidFile","path","join","ppid","process","toString","fs","existsSync","readFileSync","cwd","normalize","startsWith","rmSync","recursive","force","mkdirSync","writeFileSync","collectCoverageIfAvailable","_ref3","_asyncToGenerator","_regeneratorRuntime","mark","_callee","_ref2","coverage","nycOutputPath","wrap","_callee$","_context","prev","next","evaluate","window","__coverage__","sent","abrupt","Object","values","forEach","cov","hash","_JSON$stringify","JSON","stringify","stop","_x","apply","arguments","matchPath","spiedPath","currentPath","normalizedCurrentPath","pattern","globToRegExp","test","LINUX_DOCKER_HOST_IP","getGlobalBrowser","browser","isCi","argv","includes","env","CI","isUsingDockerizedChromium","URL","wsEndpoint","port","isWsl","platform","execSync","e","isWsl2","replace","split","map","line","trim","some","match","getWslHostIp","ips","serverHostName","rootDir","findRoot","pkg","parse","projectConfig","_pkg$acceptanceTests","acceptanceTests","server","ciServer","devServer","_projectConfig$covera","serverPort","toMatchImageSnapshot","configureToMatchImageSnapshot","failureThreshold","failureThresholdType","customSnapshotIdentifier","defaultIdentifier","calledToMatchImageSnapshotOutsideDocker","localToMatchImageSnapshot","message","pass","extend","afterEach","error","stack","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","options","_objectWithoutPropertiesLoose","_excluded","_extends","scrollIntoView","el","block","getPageApi","api","create","type","_ref6","_callee2","elementHandle","text","_callee2$","_context2","_x3","_x4","_x5","click","_ref7","_callee3","_callee3$","_context3","_x6","_x7","select","_ref8","_callee4","_len","_key","_args4","_callee4$","_context4","length","Array","_x8","_ref9","_callee5","_callee5$","_context5","skipNetworkWait","waitForNetworkIdle","_x9","clear","_ref10","_callee6","_callee6$","_context6","clickCount","press","_x10","setGeolocation","position","navigator","geolocation","getCurrentPosition","callback","coords","needsRequestInterception","requestHandlers","requestInterceptor","req","_ref11","_requestHandlers$find","find","_ref12","matcher","handler","response","respond","interceptRequest","spy","jest","fn","push","createApiEndpointMock","_temp3","origin","_ref13","baseUrl","originRegExp","_ref14","_URL","url","method","mockImplementation","status","headers","spyOn","_URL2","pathname","search","pathWithParams","spyResult","_spyResult$status","resBody","body","contentType","openPage","_ref16","_callee7","_ref15","userAgent","isDarkMode","viewport","cookies","urlConfig","currentUserAgent","connectionError","_callee7$","_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","key","_viewport$safeAreaIns2","style","document","createElement","innerHTML","addEventListener","head","appendChild","setRequestInterception","on","t1","captureStackTrace","waitForFunction","_x11","buildQueryMethods","_temp4","_ref17","boundQueries","_loop","_Object$entries$_i","_Object$entries","_i","queryName","queryFn","_callee12","doc","_len2","args","_key2","queryArgs","newElementHandle","_args12","_callee12$","_context12","getDocument","$","concat","timeout","_ref19","_callee8","_callee8$","_context8","_x12","_ref20","_callee9","_callee9$","_context9","_x13","_ref21","_callee10","_callee10$","_context10","_x14","_x15","_callee11","_args11","_callee11$","_context11","entries","queries","getScreen","screen","within","beforeEach","_callee13","_callee13$","_context13","jestPuppeteer","resetPage","_callee14","_callee14$","_context14","off","prepareFile","filepath","isLocal","isHeadless","HEADLESS","usesDocker","dockerComposeFile","__dirname","containerId","newPath","basename","copyFileSync","wait","expectation","interval","startTime","startStack","resolve","reject","rejectOrRerun","runExpectation","then","waitForElementToBeRemoved","_ref25","_callee15","box","_callee15$","_context15","boundingBox"],"mappings":"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"}
|
package/dist/utils.d.ts
CHANGED