@telefonica/acceptance-testing 2.22.0-beta0 → 2.22.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -209,6 +209,9 @@ You can also use globs for API paths and origins if you need.
209
209
  Some examples:
210
210
 
211
211
  ```ts
212
+ // any origin (default)
213
+ createApiEndpointMock({origin: '*'});
214
+
212
215
  // any port
213
216
  createApiEndpointMock({origin: 'https://example.com:*'});
214
217
 
@@ -218,9 +221,6 @@ createApiEndpointMock({origin: 'https://*:3000'});
218
221
  // any subdomain
219
222
  createApiEndpointMock({origin: 'https://*.example.com:3000'});
220
223
 
221
- // any origin
222
- createApiEndpointMock({origin: '*'});
223
-
224
224
  // any second level path
225
225
  api.spyOn('/some/*/path');
226
226
  ```
@@ -752,12 +752,16 @@ var interceptRequest = function interceptRequest(matcher) {
752
752
  });
753
753
  return spy;
754
754
  };
755
- var createApiEndpointMock = function createApiEndpointMock(_ref13) {
756
- var origin = _ref13.origin,
755
+ var createApiEndpointMock = function createApiEndpointMock(_temp3) {
756
+ var _ref14;
757
+ var _ref13 = _temp3 === void 0 ? {} : _temp3,
758
+ origin = _ref13.origin,
757
759
  baseUrl = _ref13.baseUrl;
758
- var originParam = origin != null ? origin : baseUrl;
760
+ var originRegExp = globToRegExp((_ref14 = origin != null ? origin : baseUrl) != null ? _ref14 : '*');
759
761
  interceptRequest(function (req) {
760
- return req.method() === 'OPTIONS' && req.url().startsWith(originParam);
762
+ var _URL = new URL(req.url()),
763
+ origin = _URL.origin;
764
+ return req.method() === 'OPTIONS' && !!origin.match(originRegExp);
761
765
  }).mockImplementation(function () {
762
766
  return {
763
767
  status: 204,
@@ -774,11 +778,10 @@ var createApiEndpointMock = function createApiEndpointMock(_ref13) {
774
778
  method = 'GET';
775
779
  }
776
780
  var matcher = function matcher(req) {
777
- var url = req.url();
778
- var _URL = new URL(url),
779
- pathname = _URL.pathname,
780
- origin = _URL.origin;
781
- return req.method() === method && !!origin.match(globToRegExp(originParam)) && !!pathname.match(globToRegExp(path));
781
+ var _URL2 = new URL(req.url()),
782
+ pathname = _URL2.pathname,
783
+ origin = _URL2.origin;
784
+ return req.method() === method && !!origin.match(originRegExp) && !!pathname.match(globToRegExp(path));
782
785
  };
783
786
  var spy = jest.fn();
784
787
  interceptRequest(matcher).mockImplementation(function (req) {
@@ -800,12 +803,12 @@ var createApiEndpointMock = function createApiEndpointMock(_ref13) {
800
803
  };
801
804
  };
802
805
  var openPage = /*#__PURE__*/function () {
803
- var _ref15 = /*#__PURE__*/_asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee7(_ref14) {
806
+ var _ref16 = /*#__PURE__*/_asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee7(_ref15) {
804
807
  var userAgent, isDarkMode, viewport, cookies, urlConfig, url, currentUserAgent, page, connectionError;
805
808
  return _regeneratorRuntime().wrap(function _callee7$(_context7) {
806
809
  while (1) switch (_context7.prev = _context7.next) {
807
810
  case 0:
808
- userAgent = _ref14.userAgent, isDarkMode = _ref14.isDarkMode, viewport = _ref14.viewport, cookies = _ref14.cookies, urlConfig = /*#__PURE__*/_objectWithoutPropertiesLoose(_ref14, _excluded2);
811
+ userAgent = _ref15.userAgent, isDarkMode = _ref15.isDarkMode, viewport = _ref15.viewport, cookies = _ref15.cookies, urlConfig = /*#__PURE__*/_objectWithoutPropertiesLoose(_ref15, _excluded2);
809
812
  url = function () {
810
813
  if (urlConfig.url !== undefined) {
811
814
  return urlConfig.url;
@@ -916,13 +919,13 @@ var openPage = /*#__PURE__*/function () {
916
919
  }, _callee7, null, [[27, 32]]);
917
920
  }));
918
921
  return function openPage(_x11) {
919
- return _ref15.apply(this, arguments);
922
+ return _ref16.apply(this, arguments);
920
923
  };
921
924
  }();
922
- var buildQueryMethods = function buildQueryMethods(_temp3) {
923
- var _ref16 = _temp3 === void 0 ? {} : _temp3,
924
- page = _ref16.page,
925
- element = _ref16.element;
925
+ var buildQueryMethods = function buildQueryMethods(_temp4) {
926
+ var _ref17 = _temp4 === void 0 ? {} : _temp4,
927
+ page = _ref17.page,
928
+ element = _ref17.element;
926
929
  var boundQueries = {};
927
930
  var _loop = function _loop() {
928
931
  var _Object$entries$_i = _Object$entries[_i],
@@ -967,7 +970,7 @@ var buildQueryMethods = function buildQueryMethods(_temp3) {
967
970
  elementHandle = _context12.sent;
968
971
  newElementHandle = Object.create(elementHandle);
969
972
  newElementHandle.screenshot = /*#__PURE__*/function () {
970
- var _ref18 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee8(options) {
973
+ var _ref19 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee8(options) {
971
974
  return _regeneratorRuntime().wrap(function _callee8$(_context8) {
972
975
  while (1) switch (_context8.prev = _context8.next) {
973
976
  case 0:
@@ -991,11 +994,11 @@ var buildQueryMethods = function buildQueryMethods(_temp3) {
991
994
  }, _callee8);
992
995
  }));
993
996
  return function (_x12) {
994
- return _ref18.apply(this, arguments);
997
+ return _ref19.apply(this, arguments);
995
998
  };
996
999
  }();
997
1000
  newElementHandle.click = /*#__PURE__*/function () {
998
- var _ref19 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee9(options) {
1001
+ var _ref20 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee9(options) {
999
1002
  return _regeneratorRuntime().wrap(function _callee9$(_context9) {
1000
1003
  while (1) switch (_context9.prev = _context9.next) {
1001
1004
  case 0:
@@ -1010,11 +1013,11 @@ var buildQueryMethods = function buildQueryMethods(_temp3) {
1010
1013
  }, _callee9);
1011
1014
  }));
1012
1015
  return function (_x13) {
1013
- return _ref19.apply(this, arguments);
1016
+ return _ref20.apply(this, arguments);
1014
1017
  };
1015
1018
  }();
1016
1019
  newElementHandle.type = /*#__PURE__*/function () {
1017
- var _ref20 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee10(text, options) {
1020
+ var _ref21 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee10(text, options) {
1018
1021
  return _regeneratorRuntime().wrap(function _callee10$(_context10) {
1019
1022
  while (1) switch (_context10.prev = _context10.next) {
1020
1023
  case 0:
@@ -1029,7 +1032,7 @@ var buildQueryMethods = function buildQueryMethods(_temp3) {
1029
1032
  }, _callee10);
1030
1033
  }));
1031
1034
  return function (_x14, _x15) {
1032
- return _ref20.apply(this, arguments);
1035
+ return _ref21.apply(this, arguments);
1033
1036
  };
1034
1037
  }();
1035
1038
  newElementHandle.select = /*#__PURE__*/_asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee11() {
@@ -1190,7 +1193,7 @@ var waitForElementToBeRemoved = function waitForElementToBeRemoved(element, time
1190
1193
  }
1191
1194
  var startStack = new Error().stack;
1192
1195
  var wait = /*#__PURE__*/function () {
1193
- var _ref24 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee15() {
1196
+ var _ref25 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee15() {
1194
1197
  var t0, box;
1195
1198
  return _regeneratorRuntime().wrap(function _callee15$(_context15) {
1196
1199
  while (1) switch (_context15.prev = _context15.next) {
@@ -1227,7 +1230,7 @@ var waitForElementToBeRemoved = function waitForElementToBeRemoved(element, time
1227
1230
  }, _callee15);
1228
1231
  }));
1229
1232
  return function wait() {
1230
- return _ref24.apply(this, arguments);
1233
+ return _ref25.apply(this, arguments);
1231
1234
  };
1232
1235
  }();
1233
1236
  return wait()["catch"](function (error) {
@@ -1 +1 @@
1
- {"version":3,"file":"acceptance-testing.cjs.development.js","sources":["../src/coverage.ts","../src/index.ts"],"sourcesContent":["import path from 'path';\nimport fs from 'fs';\n\nimport type {Page} from 'puppeteer';\n\nconst getGlobalPage = (): Page => (global as any).page;\n\nexport const getRootPath = () => {\n const rootPath = expect.getState().snapshotState._rootDir;\n if (!rootPath) {\n throw new Error('Root path not found');\n }\n return rootPath;\n};\n\n/**\n * We want to clear coverage files from previous runs, but at this point it is not easy because each\n * worker runs a different instance of this script, so we can't just clear the coverage folder at\n * the beginning of the test run.\n *\n * The solution is to remove the coverage folder when the stored ppid (parent process id) is\n * different from the current one\n */\nconst prepareCoverageReportPath = ({coveragePath}: {coveragePath: string}) => {\n const ppidFile = path.join(coveragePath, '.ppid');\n const ppid = process.ppid.toString();\n if (!fs.existsSync(ppidFile) || fs.readFileSync(ppidFile, 'utf-8') !== ppid) {\n // the condition is just to make sure we don't remove files outside the repo\n if (getRootPath() === process.cwd() && path.normalize(coveragePath).startsWith(process.cwd())) {\n fs.rmSync(coveragePath, {recursive: true, force: true});\n }\n fs.mkdirSync(coveragePath, {recursive: true});\n fs.writeFileSync(ppidFile, ppid);\n }\n};\n\n/**\n * Asumes the code was instrumented with istanbul and the coverage report stored in `window.__coverage__`.\n * If not, this function does nothing.\n */\nexport const collectCoverageIfAvailable = async ({coveragePath}: {coveragePath: string}): Promise<void> => {\n const coverage = await getGlobalPage().evaluate(() => {\n return (window as any).__coverage__;\n });\n if (!coverage) {\n return;\n }\n\n prepareCoverageReportPath({coveragePath});\n const nycOutputPath = path.join(coveragePath, '.nyc_output');\n fs.mkdirSync(nycOutputPath, {recursive: true});\n\n Object.values(coverage).forEach((cov: any) => {\n if (cov && cov.path && cov.hash) {\n fs.writeFileSync(path.join(nycOutputPath, cov.hash + '.json'), JSON.stringify({[cov.path]: cov}));\n }\n });\n};\n","import path from 'path';\nimport fs from 'fs';\nimport findRoot from 'find-root';\nimport type {getQueriesForElement} from 'pptr-testing-library';\nimport {getDocument, queries} from 'pptr-testing-library';\nimport {configureToMatchImageSnapshot} from 'jest-image-snapshot';\nimport globToRegExp from 'glob-to-regexp';\nimport {execSync} from 'child_process';\nimport {collectCoverageIfAvailable} from './coverage';\n\nimport type {\n Browser,\n ClickOptions,\n ElementHandle,\n GeolocationOptions,\n HTTPRequest,\n Page,\n ResponseForRequest,\n ScreenshotOptions,\n Viewport,\n} from 'puppeteer';\n\ntype CustomScreenshotOptions = ScreenshotOptions & {\n skipNetworkWait?: boolean;\n};\n\nexport const getGlobalBrowser = (): Browser => (global as any).browser;\nexport const getGlobalPage = (): Page => (global as any).page;\n\nconst isCi = process.argv.includes('--ci') || process.env.CI;\nconst isUsingDockerizedChromium = isCi || new URL(getGlobalBrowser().wsEndpoint()).port === '9223';\n\nexport const serverHostName = ((): string => {\n if (isCi) {\n return 'localhost';\n }\n\n if (isUsingDockerizedChromium) {\n return process.platform === 'linux' ? '172.17.0.1' : 'host.docker.internal';\n }\n\n return 'localhost';\n})();\n\nconst rootDir = findRoot(process.cwd());\nconst pkg = JSON.parse(fs.readFileSync(path.join(rootDir, 'package.json'), 'utf-8'));\nconst projectConfig = pkg.acceptanceTests ?? {};\nconst server = (isCi ? projectConfig.ciServer : projectConfig.devServer) ?? projectConfig.server;\nconst coveragePath = path.join(rootDir, projectConfig.coveragePath ?? 'reports/coverage-acceptance');\n\nexport const serverPort = server?.port;\n\nconst toMatchImageSnapshot = configureToMatchImageSnapshot({\n failureThreshold: 0,\n failureThresholdType: 'percent',\n customSnapshotIdentifier: ({defaultIdentifier}) => defaultIdentifier,\n});\n\nlet calledToMatchImageSnapshotOutsideDocker = false;\n\nconst localToMatchImageSnapshot = () => {\n calledToMatchImageSnapshotOutsideDocker = true;\n // let the expectation pass, then fail in afterEach. This way we allow developers to debug screenshot tests in local\n // but don't allow them to save screenshots taken outside the dockerized chromium\n return {\n message: () => '',\n pass: true,\n };\n};\n\nexpect.extend({\n toMatchImageSnapshot: isUsingDockerizedChromium ? toMatchImageSnapshot : localToMatchImageSnapshot,\n});\n\nafterEach(() => {\n if (calledToMatchImageSnapshotOutsideDocker) {\n const error = new Error(\n `Calling .toMatchImageSnapshot() is not allowed outside dockerized browser. Please, run your screenshot test in headless mode.`\n );\n error.stack = (error.stack || '').split('\\n')[0];\n throw error;\n }\n});\n\ntype WaitForPaintEndOptions = {\n fullPage?: boolean;\n captureBeyondViewport?: boolean;\n};\n\nconst waitForPaintEnd = async (\n element: ElementHandle | Page,\n {fullPage = true, captureBeyondViewport}: WaitForPaintEndOptions = {}\n) => {\n const MAX_WAIT = 15000;\n const STEP_TIME = 250;\n const t0 = Date.now();\n\n let buf1 = (await element.screenshot(\n normalizeSreenshotOptions({fullPage, captureBeyondViewport})\n )) as Buffer;\n await new Promise((r) => setTimeout(r, STEP_TIME));\n let buf2 = (await element.screenshot(\n normalizeSreenshotOptions({fullPage, captureBeyondViewport})\n )) as Buffer;\n\n // buffers are different if compare != 0\n while (buf1.compare(buf2)) {\n if (Date.now() - t0 > MAX_WAIT) {\n throw Error('Paint end timeout');\n }\n buf1 = buf2;\n await new Promise((r) => setTimeout(r, STEP_TIME));\n buf2 = (await element.screenshot(\n normalizeSreenshotOptions({fullPage, captureBeyondViewport})\n )) as Buffer;\n }\n};\n\nexport interface PageApi extends Omit<Page, 'click' | 'type' | 'select'> {\n clear: (selector: ElementHandle) => Promise<void>;\n // These are overridden:\n type: (selector: ElementHandle, text: string, options?: {delay: number}) => Promise<void>;\n click: (selector: ElementHandle, options?: ClickOptions) => Promise<void>;\n select: (selector: ElementHandle, ...values: string[]) => Promise<string[]>;\n screenshot: (options?: CustomScreenshotOptions) => Promise<Buffer | string | void>;\n}\n\nconst normalizeSreenshotOptions = ({captureBeyondViewport = false, ...options}: ScreenshotOptions = {}) => {\n // Puppeter default for captureBeyondViewport is true, but we think false is a better default.\n // When this is true, the fixed elements (like fixed footers) are relative to the original page\n // viewport, not to the full page, so those elements look weird in fullPage screenshots.\n return {...options, captureBeyondViewport};\n};\n\n// Puppeteer already calls scrollIntoViewIfNeeded before clicking an element. But it doesn't work in all situations\n// For example, when there is a fixed footer in the page and the element to click is under it, the browser won't scroll\n// because the element is already in the viewport (the ifNeeded part is important here). By forcing the scroll to the\n// center, we manage to fix these edge cases.\nconst scrollIntoView = (el: ElementHandle) => el.evaluate((e) => e.scrollIntoView({block: 'center'}));\n\nexport const getPageApi = (page: Page): PageApi => {\n const api: PageApi = Object.create(page);\n\n api.type = async (elementHandle, text, options) => {\n await scrollIntoView(elementHandle);\n return elementHandle.type(text, options);\n };\n api.click = async (elementHandle, options) => {\n await scrollIntoView(elementHandle);\n return elementHandle.click(options);\n };\n api.select = async (elementHandle, ...values) => {\n await scrollIntoView(elementHandle);\n return elementHandle.select(...values);\n };\n\n api.screenshot = async (options?: CustomScreenshotOptions) => {\n if (!options?.skipNetworkWait) {\n await page.waitForNetworkIdle();\n }\n await waitForPaintEnd(page, options);\n return page.screenshot(normalizeSreenshotOptions(options));\n };\n\n api.clear = async (elementHandle) => {\n await elementHandle.click({clickCount: 3});\n await elementHandle.press('Delete');\n };\n\n // For some reason, puppeteer browserContext.overridePermissions doesn't work with newer chrome versions.\n // This workaround polyfills the browser geolocation api to return the mocked position\n api.setGeolocation = (position: GeolocationOptions) =>\n page.evaluate((position) => {\n window.navigator.geolocation.getCurrentPosition = (callback) => {\n // @ts-expect-error - puppeteer's setGeoLocation does not expect a timestamp to be passed\n callback({\n coords: position,\n });\n };\n }, position as any);\n\n return api;\n};\n\nlet needsRequestInterception = false;\ntype RequestMatcherFn = (req: HTTPRequest) => boolean;\nlet requestHandlers: Array<{\n matcher: RequestMatcherFn;\n handler: jest.Mock<any, any>;\n}> = [];\n\nconst requestInterceptor = (req: HTTPRequest) => {\n const {handler} = requestHandlers.find(({matcher}) => matcher(req)) ?? {handler: null};\n if (!handler) {\n req.continue();\n return;\n }\n const response = handler(req);\n req.respond(response);\n};\n\nexport const interceptRequest = (\n matcher: RequestMatcherFn\n): jest.Mock<Partial<ResponseForRequest>, [HTTPRequest]> => {\n needsRequestInterception = true;\n const spy = jest.fn();\n requestHandlers.push({matcher, handler: spy});\n return spy;\n};\n\ntype ApiEndpointMock = {\n spyOn(path: string, method?: string): jest.Mock<unknown, [HTTPRequest]>;\n};\n\nexport const createApiEndpointMock = ({\n origin,\n baseUrl,\n}: {\n origin: string;\n /** @deprecated use origin */\n baseUrl: string;\n}): ApiEndpointMock => {\n const originParam = origin ?? baseUrl;\n interceptRequest(\n (req) => req.method() === 'OPTIONS' && req.url().startsWith(originParam)\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(path: string, method: string = 'GET') {\n const matcher = (req: HTTPRequest) => {\n const url = req.url();\n const {pathname, origin} = new URL(url);\n return (\n req.method() === method &&\n !!origin.match(globToRegExp(originParam)) &&\n !!pathname.match(globToRegExp(path))\n );\n };\n\n const spy = jest.fn();\n\n interceptRequest(matcher).mockImplementation((req) => {\n const spyResult = spy(req);\n const status = spyResult.status ?? 200;\n const resBody = spyResult.body || spyResult;\n return {\n status,\n headers: {\n 'Access-Control-Allow-Origin': '*',\n },\n contentType: 'application/json',\n body: JSON.stringify(resBody),\n };\n });\n\n return spy;\n },\n };\n};\n\ntype CookieConfig = {\n name: string;\n value: string;\n url?: string;\n domain?: string;\n path?: string;\n secure?: boolean;\n httpOnly?: boolean;\n sameSite?: 'Strict' | 'Lax' | 'None';\n expires?: number;\n priority?: 'Low' | 'Medium' | 'High';\n sameParty?: boolean;\n sourceScheme?: 'Unset' | 'NonSecure' | 'Secure';\n sourcePort?: number;\n};\n\nexport interface TestViewport extends Viewport {\n safeAreaInset?: {\n top?: number | string;\n right?: number | string;\n bottom?: number | string;\n left?: number | string;\n };\n}\n\ninterface OpenPageCommonConfig {\n userAgent?: string;\n viewport?: TestViewport;\n isDarkMode?: boolean;\n cookies?: Array<CookieConfig>;\n}\n\ninterface OpenPageUrlConfig extends OpenPageCommonConfig {\n url: string;\n}\n\ninterface OpenPagePathConfig extends OpenPageCommonConfig {\n url?: undefined;\n\n path?: string;\n port?: number;\n protocol?: string;\n hostname?: string;\n}\n\ntype OpenPageConfig = OpenPageUrlConfig | OpenPagePathConfig;\n\nexport const openPage = async ({\n userAgent,\n isDarkMode,\n viewport,\n cookies,\n ...urlConfig\n}: OpenPageConfig): Promise<PageApi> => {\n const url = ((): string => {\n if (urlConfig.url !== undefined) {\n return urlConfig.url;\n }\n\n const {path = '/', port = serverPort, protocol = 'http', hostname = serverHostName} = urlConfig;\n\n if (!port) {\n // Error.captureStackTrace(error, openPage);\n throw new Error(\n 'You must specify a port. You can specify it when calling openPage() or by configuring a dev and ci server in the acceptanceTests config in your package.json'\n );\n }\n\n return `${protocol}://${hostname}:${port}${path}`;\n })();\n\n const currentUserAgent = userAgent || (await getGlobalBrowser().userAgent());\n const page = getGlobalPage();\n\n await page.bringToFront();\n if (viewport) {\n await page.setViewport(viewport);\n }\n if (cookies) {\n await page.setCookie(...cookies);\n }\n await page.setUserAgent(`${currentUserAgent} acceptance-test`);\n await page.emulateMediaFeatures([{name: 'prefers-color-scheme', value: isDarkMode ? 'dark' : 'light'}]);\n\n // A set of styles to make screenshot tests more reliable.\n await page.evaluateOnNewDocument((viewport: TestViewport) => {\n const overriddenSafeAreaInsets = !viewport\n ? []\n : Object.keys(viewport?.safeAreaInset ?? {}).map((key) => {\n const position = key as 'top' | 'right' | 'bottom' | 'left';\n return `--acceptance-test-override-safe-area-inset-${key}: ${viewport?.safeAreaInset?.[position]};`;\n });\n\n const style = document.createElement('style');\n style.innerHTML = `\n *, *:after, *:before {\n transition-delay: 0s !important;\n transition-duration: 0s !important;\n animation-delay: -0.0001s !important;\n animation-duration: 0s !important;\n animation-play-state: paused !important;\n caret-color: transparent !important;\n font-variant-ligatures: none !important;\n }\n *::-webkit-scrollbar {\n display: none !important;\n width: 0 !important;\n height: 0 !important;\n }\n :root {\n ${overriddenSafeAreaInsets.join('\\n')}\n }\n `;\n window.addEventListener('DOMContentLoaded', () => {\n document.head.appendChild(style);\n });\n }, viewport);\n\n if (needsRequestInterception) {\n await page.setRequestInterception(true);\n page.on('request', requestInterceptor);\n }\n\n try {\n await page.goto(url);\n } catch (e) {\n if ((e as Error).message.includes('net::ERR_CONNECTION_REFUSED')) {\n const connectionError = new Error(`Could not connect to ${url}. Is the server running?`);\n Error.captureStackTrace(connectionError, openPage);\n throw connectionError;\n } else {\n throw e;\n }\n }\n await page.waitForFunction('document.fonts.status === \"loaded\"');\n\n return getPageApi(page);\n};\n\nconst buildQueryMethods = ({page, element}: {page?: Page; element?: ElementHandle} = {}): ReturnType<\n typeof getQueriesForElement\n> => {\n const boundQueries: any = {};\n for (const [queryName, queryFn] of Object.entries(queries)) {\n boundQueries[queryName] = async (...args: any) => {\n const doc = await getDocument(page ?? getGlobalPage());\n const body = await doc.$('body');\n const queryArgs = [...args];\n if (queryName.startsWith('findBy')) {\n if (queryArgs.length === 1) {\n queryArgs.push(undefined);\n }\n queryArgs.push({timeout: 10000});\n }\n const elementHandle: ElementHandle = await queryFn(element ?? body, ...queryArgs);\n\n const newElementHandle = Object.create(elementHandle);\n\n newElementHandle.screenshot = async (options: CustomScreenshotOptions) => {\n if (!options?.skipNetworkWait) {\n await (page ?? getGlobalPage()).waitForNetworkIdle();\n }\n await waitForPaintEnd(elementHandle, {...options, fullPage: false});\n return elementHandle.screenshot(normalizeSreenshotOptions(options));\n };\n\n newElementHandle.click = async (options?: ClickOptions) => {\n await scrollIntoView(elementHandle);\n return elementHandle.click(options);\n };\n\n newElementHandle.type = async (text: string, options?: {delay: number}) => {\n await scrollIntoView(elementHandle);\n return elementHandle.type(text, options);\n };\n\n newElementHandle.select = async (...values: Array<string>) => {\n await scrollIntoView(elementHandle);\n return elementHandle.select(...values);\n };\n\n return newElementHandle;\n };\n }\n return boundQueries;\n};\n\nexport const getScreen = (page: Page) => buildQueryMethods({page});\n\nexport const screen = buildQueryMethods();\n\nexport const within = (element: ElementHandle) => buildQueryMethods({element});\n\nexport type {ElementHandle, Viewport} from 'puppeteer';\n\nbeforeEach(async () => {\n await getGlobalPage().setRequestInterception(false);\n\n // by resetting the page we clean up all the evaluateOnNewDocument calls, which are persistent between documents\n await (global as any).jestPuppeteer.resetPage();\n});\n\nafterEach(async () => {\n await collectCoverageIfAvailable({coveragePath});\n\n try {\n const page = getGlobalPage();\n requestHandlers = [];\n needsRequestInterception = false;\n page.off('request', requestInterceptor);\n\n // clear tab, this way we clear the DOM and stop js execution or pending requests\n await page.goto('about:blank');\n } catch (e) {\n // ignore, at this point page might be destroyed\n }\n});\n\n/**\n * Returns a new path to the file that can be used by chromium in acceptance tests\n *\n * To be able to use `element.uploadFile()` in a dockerized chromium, the file must exist in the\n * host and the docker, and both sides must use the same path.\n *\n * To workaround this bug or limitation, this function prepares the file by copying it to /tmp in\n * the host and the container.\n */\nexport const prepareFile = (filepath: string): string => {\n const isLocal = !isCi;\n const isHeadless = !!process.env.HEADLESS;\n const usesDocker = isLocal && isHeadless;\n\n const dockerComposeFile = path.join(__dirname, '..', 'docker-compose.yaml');\n\n if (usesDocker) {\n const containerId = execSync(`docker-compose -f ${dockerComposeFile} ps -q`).toString().trim();\n\n if (!containerId) {\n throw Error('acceptance-testing container not found');\n }\n\n execSync(`docker cp ${filepath} ${containerId}:/tmp`);\n\n const newPath = path.join('/tmp', path.basename(filepath));\n\n fs.copyFileSync(filepath, newPath);\n\n return newPath;\n } else {\n return filepath;\n }\n};\n\n/**\n * A convenience method to defer an expectation\n */\nexport const wait = <T>(expectation: () => Promise<T> | T, timeout = 10000, interval = 50): Promise<T> => {\n const startTime = Date.now();\n const startStack = new Error().stack;\n\n return new Promise((resolve, reject) => {\n const rejectOrRerun = (error: unknown) => {\n if (Date.now() - startTime >= timeout) {\n if (error instanceof Error) {\n if (error.message === 'Element not removed') {\n error.stack = startStack;\n }\n }\n reject(error);\n return;\n }\n // eslint-disable-next-line @typescript-eslint/no-use-before-define\n setTimeout(runExpectation, interval);\n };\n const runExpectation = () => {\n try {\n Promise.resolve(expectation())\n .then((r) => resolve(r))\n .catch(rejectOrRerun);\n } catch (error) {\n rejectOrRerun(error);\n }\n };\n setTimeout(runExpectation, 0);\n });\n};\n\nexport const waitForElementToBeRemoved = (\n element: ElementHandle<Element>,\n timeout = 10000,\n interval = 100\n): Promise<void> => {\n const startStack = new Error().stack;\n\n const wait = async () => {\n const t0 = Date.now();\n while (Date.now() - t0 < timeout) {\n // boundingBox returns null when the element is not in the DOM\n const box = await element.boundingBox();\n if (!box) {\n return;\n }\n await new Promise((resolve) => setTimeout(resolve, interval));\n }\n throw new Error('Element not removed');\n };\n\n return wait().catch((error) => {\n if (error.message === 'Element not removed') {\n error.stack = startStack;\n }\n throw error;\n });\n};\n"],"names":["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","getGlobalBrowser","browser","isCi","argv","includes","env","CI","isUsingDockerizedChromium","URL","wsEndpoint","port","serverHostName","platform","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","split","waitForPaintEnd","element","_temp","_ref4","_ref4$fullPage","fullPage","captureBeyondViewport","MAX_WAIT","STEP_TIME","t0","buf1","buf2","Date","now","screenshot","normalizeSreenshotOptions","Promise","r","setTimeout","compare","_x2","_temp2","_ref5$captureBeyondVi","_ref5","options","_objectWithoutPropertiesLoose","_excluded","_extends","scrollIntoView","el","e","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","_ref13","origin","baseUrl","originParam","method","url","mockImplementation","status","headers","spyOn","_URL","pathname","match","globToRegExp","spyResult","_spyResult$status","resBody","body","contentType","openPage","_ref15","_callee7","_ref14","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","map","key","_viewport$safeAreaIns2","style","document","createElement","innerHTML","addEventListener","head","appendChild","setRequestInterception","on","t1","captureStackTrace","waitForFunction","_x11","buildQueryMethods","_temp3","_ref16","boundQueries","_loop","_Object$entries$_i","_Object$entries","_i","queryName","queryFn","_callee12","doc","_len2","args","_key2","queryArgs","newElementHandle","_args12","_callee12$","_context12","getDocument","$","concat","timeout","_ref18","_callee8","_callee8$","_context8","_x12","_ref19","_callee9","_callee9$","_context9","_x13","_ref20","_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","execSync","trim","newPath","basename","copyFileSync","wait","expectation","interval","startTime","startStack","resolve","reject","rejectOrRerun","runExpectation","then","waitForElementToBeRemoved","_ref24","_callee15","box","_callee15$","_context15","boundingBox"],"mappings":"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"}
1
+ {"version":3,"file":"acceptance-testing.cjs.development.js","sources":["../src/coverage.ts","../src/index.ts"],"sourcesContent":["import path from 'path';\nimport fs from 'fs';\n\nimport type {Page} from 'puppeteer';\n\nconst getGlobalPage = (): Page => (global as any).page;\n\nexport const getRootPath = () => {\n const rootPath = expect.getState().snapshotState._rootDir;\n if (!rootPath) {\n throw new Error('Root path not found');\n }\n return rootPath;\n};\n\n/**\n * We want to clear coverage files from previous runs, but at this point it is not easy because each\n * worker runs a different instance of this script, so we can't just clear the coverage folder at\n * the beginning of the test run.\n *\n * The solution is to remove the coverage folder when the stored ppid (parent process id) is\n * different from the current one\n */\nconst prepareCoverageReportPath = ({coveragePath}: {coveragePath: string}) => {\n const ppidFile = path.join(coveragePath, '.ppid');\n const ppid = process.ppid.toString();\n if (!fs.existsSync(ppidFile) || fs.readFileSync(ppidFile, 'utf-8') !== ppid) {\n // the condition is just to make sure we don't remove files outside the repo\n if (getRootPath() === process.cwd() && path.normalize(coveragePath).startsWith(process.cwd())) {\n fs.rmSync(coveragePath, {recursive: true, force: true});\n }\n fs.mkdirSync(coveragePath, {recursive: true});\n fs.writeFileSync(ppidFile, ppid);\n }\n};\n\n/**\n * Asumes the code was instrumented with istanbul and the coverage report stored in `window.__coverage__`.\n * If not, this function does nothing.\n */\nexport const collectCoverageIfAvailable = async ({coveragePath}: {coveragePath: string}): Promise<void> => {\n const coverage = await getGlobalPage().evaluate(() => {\n return (window as any).__coverage__;\n });\n if (!coverage) {\n return;\n }\n\n prepareCoverageReportPath({coveragePath});\n const nycOutputPath = path.join(coveragePath, '.nyc_output');\n fs.mkdirSync(nycOutputPath, {recursive: true});\n\n Object.values(coverage).forEach((cov: any) => {\n if (cov && cov.path && cov.hash) {\n fs.writeFileSync(path.join(nycOutputPath, cov.hash + '.json'), JSON.stringify({[cov.path]: cov}));\n }\n });\n};\n","import path from 'path';\nimport fs from 'fs';\nimport findRoot from 'find-root';\nimport type {getQueriesForElement} from 'pptr-testing-library';\nimport {getDocument, queries} from 'pptr-testing-library';\nimport {configureToMatchImageSnapshot} from 'jest-image-snapshot';\nimport globToRegExp from 'glob-to-regexp';\nimport {execSync} from 'child_process';\nimport {collectCoverageIfAvailable} from './coverage';\n\nimport type {\n Browser,\n ClickOptions,\n ElementHandle,\n GeolocationOptions,\n HTTPRequest,\n Page,\n ResponseForRequest,\n ScreenshotOptions,\n Viewport,\n} from 'puppeteer';\n\ntype CustomScreenshotOptions = ScreenshotOptions & {\n skipNetworkWait?: boolean;\n};\n\nexport const getGlobalBrowser = (): Browser => (global as any).browser;\nexport const getGlobalPage = (): Page => (global as any).page;\n\nconst isCi = process.argv.includes('--ci') || process.env.CI;\nconst isUsingDockerizedChromium = isCi || new URL(getGlobalBrowser().wsEndpoint()).port === '9223';\n\nexport const serverHostName = ((): string => {\n if (isCi) {\n return 'localhost';\n }\n\n if (isUsingDockerizedChromium) {\n return process.platform === 'linux' ? '172.17.0.1' : 'host.docker.internal';\n }\n\n return 'localhost';\n})();\n\nconst rootDir = findRoot(process.cwd());\nconst pkg = JSON.parse(fs.readFileSync(path.join(rootDir, 'package.json'), 'utf-8'));\nconst projectConfig = pkg.acceptanceTests ?? {};\nconst server = (isCi ? projectConfig.ciServer : projectConfig.devServer) ?? projectConfig.server;\nconst coveragePath = path.join(rootDir, projectConfig.coveragePath ?? 'reports/coverage-acceptance');\n\nexport const serverPort = server?.port;\n\nconst toMatchImageSnapshot = configureToMatchImageSnapshot({\n failureThreshold: 0,\n failureThresholdType: 'percent',\n customSnapshotIdentifier: ({defaultIdentifier}) => defaultIdentifier,\n});\n\nlet calledToMatchImageSnapshotOutsideDocker = false;\n\nconst localToMatchImageSnapshot = () => {\n calledToMatchImageSnapshotOutsideDocker = true;\n // let the expectation pass, then fail in afterEach. This way we allow developers to debug screenshot tests in local\n // but don't allow them to save screenshots taken outside the dockerized chromium\n return {\n message: () => '',\n pass: true,\n };\n};\n\nexpect.extend({\n toMatchImageSnapshot: isUsingDockerizedChromium ? toMatchImageSnapshot : localToMatchImageSnapshot,\n});\n\nafterEach(() => {\n if (calledToMatchImageSnapshotOutsideDocker) {\n const error = new Error(\n `Calling .toMatchImageSnapshot() is not allowed outside dockerized browser. Please, run your screenshot test in headless mode.`\n );\n error.stack = (error.stack || '').split('\\n')[0];\n throw error;\n }\n});\n\ntype WaitForPaintEndOptions = {\n fullPage?: boolean;\n captureBeyondViewport?: boolean;\n};\n\nconst waitForPaintEnd = async (\n element: ElementHandle | Page,\n {fullPage = true, captureBeyondViewport}: WaitForPaintEndOptions = {}\n) => {\n const MAX_WAIT = 15000;\n const STEP_TIME = 250;\n const t0 = Date.now();\n\n let buf1 = (await element.screenshot(\n normalizeSreenshotOptions({fullPage, captureBeyondViewport})\n )) as Buffer;\n await new Promise((r) => setTimeout(r, STEP_TIME));\n let buf2 = (await element.screenshot(\n normalizeSreenshotOptions({fullPage, captureBeyondViewport})\n )) as Buffer;\n\n // buffers are different if compare != 0\n while (buf1.compare(buf2)) {\n if (Date.now() - t0 > MAX_WAIT) {\n throw Error('Paint end timeout');\n }\n buf1 = buf2;\n await new Promise((r) => setTimeout(r, STEP_TIME));\n buf2 = (await element.screenshot(\n normalizeSreenshotOptions({fullPage, captureBeyondViewport})\n )) as Buffer;\n }\n};\n\nexport interface PageApi extends Omit<Page, 'click' | 'type' | 'select'> {\n clear: (selector: ElementHandle) => Promise<void>;\n // These are overridden:\n type: (selector: ElementHandle, text: string, options?: {delay: number}) => Promise<void>;\n click: (selector: ElementHandle, options?: ClickOptions) => Promise<void>;\n select: (selector: ElementHandle, ...values: string[]) => Promise<string[]>;\n screenshot: (options?: CustomScreenshotOptions) => Promise<Buffer | string | void>;\n}\n\nconst normalizeSreenshotOptions = ({captureBeyondViewport = false, ...options}: ScreenshotOptions = {}) => {\n // Puppeter default for captureBeyondViewport is true, but we think false is a better default.\n // When this is true, the fixed elements (like fixed footers) are relative to the original page\n // viewport, not to the full page, so those elements look weird in fullPage screenshots.\n return {...options, captureBeyondViewport};\n};\n\n// Puppeteer already calls scrollIntoViewIfNeeded before clicking an element. But it doesn't work in all situations\n// For example, when there is a fixed footer in the page and the element to click is under it, the browser won't scroll\n// because the element is already in the viewport (the ifNeeded part is important here). By forcing the scroll to the\n// center, we manage to fix these edge cases.\nconst scrollIntoView = (el: ElementHandle) => el.evaluate((e) => e.scrollIntoView({block: 'center'}));\n\nexport const getPageApi = (page: Page): PageApi => {\n const api: PageApi = Object.create(page);\n\n api.type = async (elementHandle, text, options) => {\n await scrollIntoView(elementHandle);\n return elementHandle.type(text, options);\n };\n api.click = async (elementHandle, options) => {\n await scrollIntoView(elementHandle);\n return elementHandle.click(options);\n };\n api.select = async (elementHandle, ...values) => {\n await scrollIntoView(elementHandle);\n return elementHandle.select(...values);\n };\n\n api.screenshot = async (options?: CustomScreenshotOptions) => {\n if (!options?.skipNetworkWait) {\n await page.waitForNetworkIdle();\n }\n await waitForPaintEnd(page, options);\n return page.screenshot(normalizeSreenshotOptions(options));\n };\n\n api.clear = async (elementHandle) => {\n await elementHandle.click({clickCount: 3});\n await elementHandle.press('Delete');\n };\n\n // For some reason, puppeteer browserContext.overridePermissions doesn't work with newer chrome versions.\n // This workaround polyfills the browser geolocation api to return the mocked position\n api.setGeolocation = (position: GeolocationOptions) =>\n page.evaluate((position) => {\n window.navigator.geolocation.getCurrentPosition = (callback) => {\n // @ts-expect-error - puppeteer's setGeoLocation does not expect a timestamp to be passed\n callback({\n coords: position,\n });\n };\n }, position as any);\n\n return api;\n};\n\nlet needsRequestInterception = false;\ntype RequestMatcherFn = (req: HTTPRequest) => boolean;\nlet requestHandlers: Array<{\n matcher: RequestMatcherFn;\n handler: jest.Mock<any, any>;\n}> = [];\n\nconst requestInterceptor = (req: HTTPRequest) => {\n const {handler} = requestHandlers.find(({matcher}) => matcher(req)) ?? {handler: null};\n if (!handler) {\n req.continue();\n return;\n }\n const response = handler(req);\n req.respond(response);\n};\n\nexport const interceptRequest = (\n matcher: RequestMatcherFn\n): jest.Mock<Partial<ResponseForRequest>, [HTTPRequest]> => {\n needsRequestInterception = true;\n const spy = jest.fn();\n requestHandlers.push({matcher, handler: spy});\n return spy;\n};\n\ntype ApiEndpointMock = {\n spyOn(path: string, method?: string): jest.Mock<unknown, [HTTPRequest]>;\n};\n\nexport const createApiEndpointMock = ({\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(path: string, method: string = 'GET') {\n const matcher = (req: HTTPRequest) => {\n const {pathname, origin} = new URL(req.url());\n return (\n req.method() === method &&\n !!origin.match(originRegExp) &&\n !!pathname.match(globToRegExp(path))\n );\n };\n\n const spy = jest.fn();\n\n interceptRequest(matcher).mockImplementation((req) => {\n const spyResult = spy(req);\n const status = spyResult.status ?? 200;\n const resBody = spyResult.body || spyResult;\n return {\n status,\n headers: {\n 'Access-Control-Allow-Origin': '*',\n },\n contentType: 'application/json',\n body: JSON.stringify(resBody),\n };\n });\n\n return spy;\n },\n };\n};\n\ntype CookieConfig = {\n name: string;\n value: string;\n url?: string;\n domain?: string;\n path?: string;\n secure?: boolean;\n httpOnly?: boolean;\n sameSite?: 'Strict' | 'Lax' | 'None';\n expires?: number;\n priority?: 'Low' | 'Medium' | 'High';\n sameParty?: boolean;\n sourceScheme?: 'Unset' | 'NonSecure' | 'Secure';\n sourcePort?: number;\n};\n\nexport interface TestViewport extends Viewport {\n safeAreaInset?: {\n top?: number | string;\n right?: number | string;\n bottom?: number | string;\n left?: number | string;\n };\n}\n\ninterface OpenPageCommonConfig {\n userAgent?: string;\n viewport?: TestViewport;\n isDarkMode?: boolean;\n cookies?: Array<CookieConfig>;\n}\n\ninterface OpenPageUrlConfig extends OpenPageCommonConfig {\n url: string;\n}\n\ninterface OpenPagePathConfig extends OpenPageCommonConfig {\n url?: undefined;\n\n path?: string;\n port?: number;\n protocol?: string;\n hostname?: string;\n}\n\ntype OpenPageConfig = OpenPageUrlConfig | OpenPagePathConfig;\n\nexport const openPage = async ({\n userAgent,\n isDarkMode,\n viewport,\n cookies,\n ...urlConfig\n}: OpenPageConfig): Promise<PageApi> => {\n const url = ((): string => {\n if (urlConfig.url !== undefined) {\n return urlConfig.url;\n }\n\n const {path = '/', port = serverPort, protocol = 'http', hostname = serverHostName} = urlConfig;\n\n if (!port) {\n // Error.captureStackTrace(error, openPage);\n throw new Error(\n 'You must specify a port. You can specify it when calling openPage() or by configuring a dev and ci server in the acceptanceTests config in your package.json'\n );\n }\n\n return `${protocol}://${hostname}:${port}${path}`;\n })();\n\n const currentUserAgent = userAgent || (await getGlobalBrowser().userAgent());\n const page = getGlobalPage();\n\n await page.bringToFront();\n if (viewport) {\n await page.setViewport(viewport);\n }\n if (cookies) {\n await page.setCookie(...cookies);\n }\n await page.setUserAgent(`${currentUserAgent} acceptance-test`);\n await page.emulateMediaFeatures([{name: 'prefers-color-scheme', value: isDarkMode ? 'dark' : 'light'}]);\n\n // A set of styles to make screenshot tests more reliable.\n await page.evaluateOnNewDocument((viewport: TestViewport) => {\n const overriddenSafeAreaInsets = !viewport\n ? []\n : Object.keys(viewport?.safeAreaInset ?? {}).map((key) => {\n const position = key as 'top' | 'right' | 'bottom' | 'left';\n return `--acceptance-test-override-safe-area-inset-${key}: ${viewport?.safeAreaInset?.[position]};`;\n });\n\n const style = document.createElement('style');\n style.innerHTML = `\n *, *:after, *:before {\n transition-delay: 0s !important;\n transition-duration: 0s !important;\n animation-delay: -0.0001s !important;\n animation-duration: 0s !important;\n animation-play-state: paused !important;\n caret-color: transparent !important;\n font-variant-ligatures: none !important;\n }\n *::-webkit-scrollbar {\n display: none !important;\n width: 0 !important;\n height: 0 !important;\n }\n :root {\n ${overriddenSafeAreaInsets.join('\\n')}\n }\n `;\n window.addEventListener('DOMContentLoaded', () => {\n document.head.appendChild(style);\n });\n }, viewport);\n\n if (needsRequestInterception) {\n await page.setRequestInterception(true);\n page.on('request', requestInterceptor);\n }\n\n try {\n await page.goto(url);\n } catch (e) {\n if ((e as Error).message.includes('net::ERR_CONNECTION_REFUSED')) {\n const connectionError = new Error(`Could not connect to ${url}. Is the server running?`);\n Error.captureStackTrace(connectionError, openPage);\n throw connectionError;\n } else {\n throw e;\n }\n }\n await page.waitForFunction('document.fonts.status === \"loaded\"');\n\n return getPageApi(page);\n};\n\nconst buildQueryMethods = ({page, element}: {page?: Page; element?: ElementHandle} = {}): ReturnType<\n typeof getQueriesForElement\n> => {\n const boundQueries: any = {};\n for (const [queryName, queryFn] of Object.entries(queries)) {\n boundQueries[queryName] = async (...args: any) => {\n const doc = await getDocument(page ?? getGlobalPage());\n const body = await doc.$('body');\n const queryArgs = [...args];\n if (queryName.startsWith('findBy')) {\n if (queryArgs.length === 1) {\n queryArgs.push(undefined);\n }\n queryArgs.push({timeout: 10000});\n }\n const elementHandle: ElementHandle = await queryFn(element ?? body, ...queryArgs);\n\n const newElementHandle = Object.create(elementHandle);\n\n newElementHandle.screenshot = async (options: CustomScreenshotOptions) => {\n if (!options?.skipNetworkWait) {\n await (page ?? getGlobalPage()).waitForNetworkIdle();\n }\n await waitForPaintEnd(elementHandle, {...options, fullPage: false});\n return elementHandle.screenshot(normalizeSreenshotOptions(options));\n };\n\n newElementHandle.click = async (options?: ClickOptions) => {\n await scrollIntoView(elementHandle);\n return elementHandle.click(options);\n };\n\n newElementHandle.type = async (text: string, options?: {delay: number}) => {\n await scrollIntoView(elementHandle);\n return elementHandle.type(text, options);\n };\n\n newElementHandle.select = async (...values: Array<string>) => {\n await scrollIntoView(elementHandle);\n return elementHandle.select(...values);\n };\n\n return newElementHandle;\n };\n }\n return boundQueries;\n};\n\nexport const getScreen = (page: Page) => buildQueryMethods({page});\n\nexport const screen = buildQueryMethods();\n\nexport const within = (element: ElementHandle) => buildQueryMethods({element});\n\nexport type {ElementHandle, Viewport} from 'puppeteer';\n\nbeforeEach(async () => {\n await getGlobalPage().setRequestInterception(false);\n\n // by resetting the page we clean up all the evaluateOnNewDocument calls, which are persistent between documents\n await (global as any).jestPuppeteer.resetPage();\n});\n\nafterEach(async () => {\n await collectCoverageIfAvailable({coveragePath});\n\n try {\n const page = getGlobalPage();\n requestHandlers = [];\n needsRequestInterception = false;\n page.off('request', requestInterceptor);\n\n // clear tab, this way we clear the DOM and stop js execution or pending requests\n await page.goto('about:blank');\n } catch (e) {\n // ignore, at this point page might be destroyed\n }\n});\n\n/**\n * Returns a new path to the file that can be used by chromium in acceptance tests\n *\n * To be able to use `element.uploadFile()` in a dockerized chromium, the file must exist in the\n * host and the docker, and both sides must use the same path.\n *\n * To workaround this bug or limitation, this function prepares the file by copying it to /tmp in\n * the host and the container.\n */\nexport const prepareFile = (filepath: string): string => {\n const isLocal = !isCi;\n const isHeadless = !!process.env.HEADLESS;\n const usesDocker = isLocal && isHeadless;\n\n const dockerComposeFile = path.join(__dirname, '..', 'docker-compose.yaml');\n\n if (usesDocker) {\n const containerId = execSync(`docker-compose -f ${dockerComposeFile} ps -q`).toString().trim();\n\n if (!containerId) {\n throw Error('acceptance-testing container not found');\n }\n\n execSync(`docker cp ${filepath} ${containerId}:/tmp`);\n\n const newPath = path.join('/tmp', path.basename(filepath));\n\n fs.copyFileSync(filepath, newPath);\n\n return newPath;\n } else {\n return filepath;\n }\n};\n\n/**\n * A convenience method to defer an expectation\n */\nexport const wait = <T>(expectation: () => Promise<T> | T, timeout = 10000, interval = 50): Promise<T> => {\n const startTime = Date.now();\n const startStack = new Error().stack;\n\n return new Promise((resolve, reject) => {\n const rejectOrRerun = (error: unknown) => {\n if (Date.now() - startTime >= timeout) {\n if (error instanceof Error) {\n if (error.message === 'Element not removed') {\n error.stack = startStack;\n }\n }\n reject(error);\n return;\n }\n // eslint-disable-next-line @typescript-eslint/no-use-before-define\n setTimeout(runExpectation, interval);\n };\n const runExpectation = () => {\n try {\n Promise.resolve(expectation())\n .then((r) => resolve(r))\n .catch(rejectOrRerun);\n } catch (error) {\n rejectOrRerun(error);\n }\n };\n setTimeout(runExpectation, 0);\n });\n};\n\nexport const waitForElementToBeRemoved = (\n element: ElementHandle<Element>,\n timeout = 10000,\n interval = 100\n): Promise<void> => {\n const startStack = new Error().stack;\n\n const wait = async () => {\n const t0 = Date.now();\n while (Date.now() - t0 < timeout) {\n // boundingBox returns null when the element is not in the DOM\n const box = await element.boundingBox();\n if (!box) {\n return;\n }\n await new Promise((resolve) => setTimeout(resolve, interval));\n }\n throw new Error('Element not removed');\n };\n\n return wait().catch((error) => {\n if (error.message === 'Element not removed') {\n error.stack = startStack;\n }\n throw error;\n });\n};\n"],"names":["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","getGlobalBrowser","browser","isCi","argv","includes","env","CI","isUsingDockerizedChromium","URL","wsEndpoint","port","serverHostName","platform","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","split","waitForPaintEnd","element","_temp","_ref4","_ref4$fullPage","fullPage","captureBeyondViewport","MAX_WAIT","STEP_TIME","t0","buf1","buf2","Date","now","screenshot","normalizeSreenshotOptions","Promise","r","setTimeout","compare","_x2","_temp2","_ref5$captureBeyondVi","_ref5","options","_objectWithoutPropertiesLoose","_excluded","_extends","scrollIntoView","el","e","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","globToRegExp","_ref14","_URL","url","method","match","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","map","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","execSync","trim","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 j(o||[]);return n(a,"_invoke",{value:k(e,r,i)}),a}function f(e,t,r){try{return{type:"normal",arg:e.call(t,r)}}catch(e){return{type:"throw",arg:e}}}e.wrap=p;var l={};function h(){}function v(){}function d(){}var y={};s(y,a,(function(){return this}));var w=Object.getPrototypeOf,m=w&&w(w(S([])));m&&m!==t&&r.call(m,a)&&(y=m);var g=d.prototype=h.prototype=Object.create(y);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=f(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===l)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=f(e,t,r);if("normal"===u.type){if(n=r.done?"completed":"suspendedYield",u.arg===l)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")),l;var o=f(n,e.iterator,t.arg);if("throw"===o.type)return t.method="throw",t.arg=o.arg,t.delegate=null,l;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,l):a:(t.method="throw",t.arg=new TypeError("iterator result is not an object"),t.delegate=null,l)}function O(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 j(e){this.tryEntries=[{tryLoc:"root"}],e.forEach(O,this),this.reset(!0)}function S(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=S,j.prototype={constructor:j,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,l):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),l},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),l}},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:S(e),resultName:t,nextLoc:r},"next"===this.method&&(this.arg=void 0),l}},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 f(){return(f=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 l(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,y=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))},w=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:y({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)}}(),m=["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,O=function(){return k?"localhost":E?"linux"===process.platform?"172.17.0.1":"host.docker.internal":"localhost"}(),P=n(process.cwd()),j=null!=(h=JSON.parse(r.readFileSync(t.join(P,"package.json"),"utf-8")).acceptanceTests)?h:{},S=null!=(v=k?j.ciServer:j.devServer)?v:j.server,L=t.join(P,null!=(d=j.coveragePath)?d:"reports/coverage-acceptance"),T=null==S?void 0:S.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 A=function(){var e=p(u().mark((function e(t,r){var n,o,a,i,c,s,p,f,l;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(I({fullPage:a,captureBeyondViewport:i}));case 6:return f=e.sent,e.next=9,new Promise((function(e){return setTimeout(e,s)}));case 9:return e.next=11,t.screenshot(I({fullPage:a,captureBeyondViewport:i}));case 11:l=e.sent;case 12:if(!f.compare(l)){e.next=23;break}if(!(Date.now()-p>c)){e.next=15;break}throw Error("Paint end timeout");case 15:return f=l,e.next=18,new Promise((function(e){return setTimeout(e,s)}));case 18:return e.next=20,t.screenshot(I({fullPage:a,captureBeyondViewport:i}));case 20:l=e.sent,e.next=12;break;case 23:case"end":return e.stop()}}),e)})));return function(t,r){return e.apply(this,arguments)}}(),I=function(e){var t=void 0===e?{}:e,r=t.captureBeyondViewport,n=void 0!==r&&r;return f({},l(t,m),{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,A(e,r);case 5:return t.abrupt("return",e.screenshot(I(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},B=function(){var e=p(u().mark((function e(t){var r,n,o,a,i,c,s,p,f;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=l(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?O: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 f=new Error("Could not connect to "+c+". Is the server running?"),Error.captureStackTrace(f,B),f;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)}}(),M=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,l,h,v,d,y,w=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=w.length,l=new Array(s),h=0;h<s;h++)l[h]=w[h];return v=[].concat(l),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,(y=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,A(d,f({},t,{fullPage:!1}));case 5:return e.abrupt("return",d.screenshot(I(t)));case 6:case"end":return e.stop()}}),e)})));return function(t){return e.apply(this,arguments)}}(),y.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)}}(),y.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)}}(),y.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",y);case 18:case"end":return e.stop()}}),e)})))},c=0,s=Object.entries(o.queries);c<s.length;c++)i();return a},R=M();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,w({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 t=e.origin,r=null!=t?t:e.baseUrl;return G((function(e){return"OPTIONS"===e.method()&&e.url().startsWith(r)})).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,t){void 0===t&&(t="GET");var n=jest.fn();return G((function(n){var o=n.url(),a=new URL(o),c=a.pathname,u=a.origin;return n.method()===t&&!!u.match(i(r))&&!!c.match(i(e))})).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 M({page:e})},exports.interceptRequest=G,exports.openPage=B,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=R,exports.serverHostName=O,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 M({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 j(o||[]);return n(a,"_invoke",{value:k(e,r,i)}),a}function f(e,t,r){try{return{type:"normal",arg:e.call(t,r)}}catch(e){return{type:"throw",arg:e}}}e.wrap=p;var l={};function h(){}function v(){}function d(){}var y={};s(y,a,(function(){return this}));var w=Object.getPrototypeOf,m=w&&w(w(S([])));m&&m!==t&&r.call(m,a)&&(y=m);var g=d.prototype=h.prototype=Object.create(y);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=f(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===l)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=f(e,t,r);if("normal"===u.type){if(n=r.done?"completed":"suspendedYield",u.arg===l)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")),l;var o=f(n,e.iterator,t.arg);if("throw"===o.type)return t.method="throw",t.arg=o.arg,t.delegate=null,l;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,l):a:(t.method="throw",t.arg=new TypeError("iterator result is not an object"),t.delegate=null,l)}function O(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 j(e){this.tryEntries=[{tryLoc:"root"}],e.forEach(O,this),this.reset(!0)}function S(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=S,j.prototype={constructor:j,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,l):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),l},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),l}},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:S(e),resultName:t,nextLoc:r},"next"===this.method&&(this.arg=void 0),l}},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 f(){return(f=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 l(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,y=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))},w=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:y({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)}}(),m=["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,O=function(){return k?"localhost":E?"linux"===process.platform?"172.17.0.1":"host.docker.internal":"localhost"}(),P=n(process.cwd()),j=null!=(h=JSON.parse(r.readFileSync(t.join(P,"package.json"),"utf-8")).acceptanceTests)?h:{},S=null!=(v=k?j.ciServer:j.devServer)?v:j.server,L=t.join(P,null!=(d=j.coveragePath)?d:"reports/coverage-acceptance"),T=null==S?void 0:S.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 A=function(){var e=p(u().mark((function e(t,r){var n,o,a,i,c,s,p,f,l;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(I({fullPage:a,captureBeyondViewport:i}));case 6:return f=e.sent,e.next=9,new Promise((function(e){return setTimeout(e,s)}));case 9:return e.next=11,t.screenshot(I({fullPage:a,captureBeyondViewport:i}));case 11:l=e.sent;case 12:if(!f.compare(l)){e.next=23;break}if(!(Date.now()-p>c)){e.next=15;break}throw Error("Paint end timeout");case 15:return f=l,e.next=18,new Promise((function(e){return setTimeout(e,s)}));case 18:return e.next=20,t.screenshot(I({fullPage:a,captureBeyondViewport:i}));case 20:l=e.sent,e.next=12;break;case 23:case"end":return e.stop()}}),e)})));return function(t,r){return e.apply(this,arguments)}}(),I=function(e){var t=void 0===e?{}:e,r=t.captureBeyondViewport,n=void 0!==r&&r;return f({},l(t,m),{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,A(e,r);case 5:return t.abrupt("return",e.screenshot(I(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},B=function(){var e=p(u().mark((function e(t){var r,n,o,a,i,c,s,p,f;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=l(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?O: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 f=new Error("Could not connect to "+c+". Is the server running?"),Error.captureStackTrace(f,B),f;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)}}(),M=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,l,h,v,d,y,w=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=w.length,l=new Array(s),h=0;h<s;h++)l[h]=w[h];return v=[].concat(l),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,(y=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,A(d,f({},t,{fullPage:!1}));case 5:return e.abrupt("return",d.screenshot(I(t)));case 6:case"end":return e.stop()}}),e)})));return function(t){return e.apply(this,arguments)}}(),y.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)}}(),y.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)}}(),y.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",y);case 18:case"end":return e.stop()}}),e)})))},c=0,s=Object.entries(o.queries);c<s.length;c++)i();return a},R=M();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,w({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 t,r=void 0===e?{}:e,n=r.origin,o=i(null!=(t=null!=n?n:r.baseUrl)?t:"*");return G((function(e){var t=new URL(e.url()).origin;return"OPTIONS"===e.method()&&!!t.match(o)})).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,t){void 0===t&&(t="GET");var r=jest.fn();return G((function(r){var n=new URL(r.url()),a=n.pathname,c=n.origin;return r.method()===t&&!!c.match(o)&&!!a.match(i(e))})).mockImplementation((function(e){var t,n=r(e);return{status:null!=(t=n.status)?t:200,headers:{"Access-Control-Allow-Origin":"*"},contentType:"application/json",body:JSON.stringify(n.body||n)}})),r}}},exports.getGlobalBrowser=x,exports.getGlobalPage=b,exports.getPageApi=F,exports.getScreen=function(e){return M({page:e})},exports.interceptRequest=G,exports.openPage=B,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=R,exports.serverHostName=O,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 M({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"],"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 type {getQueriesForElement} from 'pptr-testing-library';\nimport {getDocument, queries} from 'pptr-testing-library';\nimport {configureToMatchImageSnapshot} from 'jest-image-snapshot';\nimport globToRegExp from 'glob-to-regexp';\nimport {execSync} from 'child_process';\nimport {collectCoverageIfAvailable} from './coverage';\n\nimport type {\n Browser,\n ClickOptions,\n ElementHandle,\n GeolocationOptions,\n HTTPRequest,\n Page,\n ResponseForRequest,\n ScreenshotOptions,\n Viewport,\n} from 'puppeteer';\n\ntype CustomScreenshotOptions = ScreenshotOptions & {\n skipNetworkWait?: boolean;\n};\n\nexport const getGlobalBrowser = (): Browser => (global as any).browser;\nexport const getGlobalPage = (): Page => (global as any).page;\n\nconst isCi = process.argv.includes('--ci') || process.env.CI;\nconst isUsingDockerizedChromium = isCi || new URL(getGlobalBrowser().wsEndpoint()).port === '9223';\n\nexport const serverHostName = ((): string => {\n if (isCi) {\n return 'localhost';\n }\n\n if (isUsingDockerizedChromium) {\n return process.platform === 'linux' ? '172.17.0.1' : 'host.docker.internal';\n }\n\n return 'localhost';\n})();\n\nconst rootDir = findRoot(process.cwd());\nconst pkg = JSON.parse(fs.readFileSync(path.join(rootDir, 'package.json'), 'utf-8'));\nconst projectConfig = pkg.acceptanceTests ?? {};\nconst server = (isCi ? projectConfig.ciServer : projectConfig.devServer) ?? projectConfig.server;\nconst coveragePath = path.join(rootDir, projectConfig.coveragePath ?? 'reports/coverage-acceptance');\n\nexport const serverPort = server?.port;\n\nconst toMatchImageSnapshot = configureToMatchImageSnapshot({\n failureThreshold: 0,\n failureThresholdType: 'percent',\n customSnapshotIdentifier: ({defaultIdentifier}) => defaultIdentifier,\n});\n\nlet calledToMatchImageSnapshotOutsideDocker = false;\n\nconst localToMatchImageSnapshot = () => {\n calledToMatchImageSnapshotOutsideDocker = true;\n // let the expectation pass, then fail in afterEach. This way we allow developers to debug screenshot tests in local\n // but don't allow them to save screenshots taken outside the dockerized chromium\n return {\n message: () => '',\n pass: true,\n };\n};\n\nexpect.extend({\n toMatchImageSnapshot: isUsingDockerizedChromium ? toMatchImageSnapshot : localToMatchImageSnapshot,\n});\n\nafterEach(() => {\n if (calledToMatchImageSnapshotOutsideDocker) {\n const error = new Error(\n `Calling .toMatchImageSnapshot() is not allowed outside dockerized browser. Please, run your screenshot test in headless mode.`\n );\n error.stack = (error.stack || '').split('\\n')[0];\n throw error;\n }\n});\n\ntype WaitForPaintEndOptions = {\n fullPage?: boolean;\n captureBeyondViewport?: boolean;\n};\n\nconst waitForPaintEnd = async (\n element: ElementHandle | Page,\n {fullPage = true, captureBeyondViewport}: WaitForPaintEndOptions = {}\n) => {\n const MAX_WAIT = 15000;\n const STEP_TIME = 250;\n const t0 = Date.now();\n\n let buf1 = (await element.screenshot(\n normalizeSreenshotOptions({fullPage, captureBeyondViewport})\n )) as Buffer;\n await new Promise((r) => setTimeout(r, STEP_TIME));\n let buf2 = (await element.screenshot(\n normalizeSreenshotOptions({fullPage, captureBeyondViewport})\n )) as Buffer;\n\n // buffers are different if compare != 0\n while (buf1.compare(buf2)) {\n if (Date.now() - t0 > MAX_WAIT) {\n throw Error('Paint end timeout');\n }\n buf1 = buf2;\n await new Promise((r) => setTimeout(r, STEP_TIME));\n buf2 = (await element.screenshot(\n normalizeSreenshotOptions({fullPage, captureBeyondViewport})\n )) as Buffer;\n }\n};\n\nexport interface PageApi extends Omit<Page, 'click' | 'type' | 'select'> {\n clear: (selector: ElementHandle) => Promise<void>;\n // These are overridden:\n type: (selector: ElementHandle, text: string, options?: {delay: number}) => Promise<void>;\n click: (selector: ElementHandle, options?: ClickOptions) => Promise<void>;\n select: (selector: ElementHandle, ...values: string[]) => Promise<string[]>;\n screenshot: (options?: CustomScreenshotOptions) => Promise<Buffer | string | void>;\n}\n\nconst normalizeSreenshotOptions = ({captureBeyondViewport = false, ...options}: ScreenshotOptions = {}) => {\n // Puppeter default for captureBeyondViewport is true, but we think false is a better default.\n // When this is true, the fixed elements (like fixed footers) are relative to the original page\n // viewport, not to the full page, so those elements look weird in fullPage screenshots.\n return {...options, captureBeyondViewport};\n};\n\n// Puppeteer already calls scrollIntoViewIfNeeded before clicking an element. But it doesn't work in all situations\n// For example, when there is a fixed footer in the page and the element to click is under it, the browser won't scroll\n// because the element is already in the viewport (the ifNeeded part is important here). By forcing the scroll to the\n// center, we manage to fix these edge cases.\nconst scrollIntoView = (el: ElementHandle) => el.evaluate((e) => e.scrollIntoView({block: 'center'}));\n\nexport const getPageApi = (page: Page): PageApi => {\n const api: PageApi = Object.create(page);\n\n api.type = async (elementHandle, text, options) => {\n await scrollIntoView(elementHandle);\n return elementHandle.type(text, options);\n };\n api.click = async (elementHandle, options) => {\n await scrollIntoView(elementHandle);\n return elementHandle.click(options);\n };\n api.select = async (elementHandle, ...values) => {\n await scrollIntoView(elementHandle);\n return elementHandle.select(...values);\n };\n\n api.screenshot = async (options?: CustomScreenshotOptions) => {\n if (!options?.skipNetworkWait) {\n await page.waitForNetworkIdle();\n }\n await waitForPaintEnd(page, options);\n return page.screenshot(normalizeSreenshotOptions(options));\n };\n\n api.clear = async (elementHandle) => {\n await elementHandle.click({clickCount: 3});\n await elementHandle.press('Delete');\n };\n\n // For some reason, puppeteer browserContext.overridePermissions doesn't work with newer chrome versions.\n // This workaround polyfills the browser geolocation api to return the mocked position\n api.setGeolocation = (position: GeolocationOptions) =>\n page.evaluate((position) => {\n window.navigator.geolocation.getCurrentPosition = (callback) => {\n // @ts-expect-error - puppeteer's setGeoLocation does not expect a timestamp to be passed\n callback({\n coords: position,\n });\n };\n }, position as any);\n\n return api;\n};\n\nlet needsRequestInterception = false;\ntype RequestMatcherFn = (req: HTTPRequest) => boolean;\nlet requestHandlers: Array<{\n matcher: RequestMatcherFn;\n handler: jest.Mock<any, any>;\n}> = [];\n\nconst requestInterceptor = (req: HTTPRequest) => {\n const {handler} = requestHandlers.find(({matcher}) => matcher(req)) ?? {handler: null};\n if (!handler) {\n req.continue();\n return;\n }\n const response = handler(req);\n req.respond(response);\n};\n\nexport const interceptRequest = (\n matcher: RequestMatcherFn\n): jest.Mock<Partial<ResponseForRequest>, [HTTPRequest]> => {\n needsRequestInterception = true;\n const spy = jest.fn();\n requestHandlers.push({matcher, handler: spy});\n return spy;\n};\n\ntype ApiEndpointMock = {\n spyOn(path: string, method?: string): jest.Mock<unknown, [HTTPRequest]>;\n};\n\nexport const createApiEndpointMock = ({\n origin,\n baseUrl,\n}: {\n origin: string;\n /** @deprecated use origin */\n baseUrl: string;\n}): ApiEndpointMock => {\n const originParam = origin ?? baseUrl;\n interceptRequest(\n (req) => req.method() === 'OPTIONS' && req.url().startsWith(originParam)\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(path: string, method: string = 'GET') {\n const matcher = (req: HTTPRequest) => {\n const url = req.url();\n const {pathname, origin} = new URL(url);\n return (\n req.method() === method &&\n !!origin.match(globToRegExp(originParam)) &&\n !!pathname.match(globToRegExp(path))\n );\n };\n\n const spy = jest.fn();\n\n interceptRequest(matcher).mockImplementation((req) => {\n const spyResult = spy(req);\n const status = spyResult.status ?? 200;\n const resBody = spyResult.body || spyResult;\n return {\n status,\n headers: {\n 'Access-Control-Allow-Origin': '*',\n },\n contentType: 'application/json',\n body: JSON.stringify(resBody),\n };\n });\n\n return spy;\n },\n };\n};\n\ntype CookieConfig = {\n name: string;\n value: string;\n url?: string;\n domain?: string;\n path?: string;\n secure?: boolean;\n httpOnly?: boolean;\n sameSite?: 'Strict' | 'Lax' | 'None';\n expires?: number;\n priority?: 'Low' | 'Medium' | 'High';\n sameParty?: boolean;\n sourceScheme?: 'Unset' | 'NonSecure' | 'Secure';\n sourcePort?: number;\n};\n\nexport interface TestViewport extends Viewport {\n safeAreaInset?: {\n top?: number | string;\n right?: number | string;\n bottom?: number | string;\n left?: number | string;\n };\n}\n\ninterface OpenPageCommonConfig {\n userAgent?: string;\n viewport?: TestViewport;\n isDarkMode?: boolean;\n cookies?: Array<CookieConfig>;\n}\n\ninterface OpenPageUrlConfig extends OpenPageCommonConfig {\n url: string;\n}\n\ninterface OpenPagePathConfig extends OpenPageCommonConfig {\n url?: undefined;\n\n path?: string;\n port?: number;\n protocol?: string;\n hostname?: string;\n}\n\ntype OpenPageConfig = OpenPageUrlConfig | OpenPagePathConfig;\n\nexport const openPage = async ({\n userAgent,\n isDarkMode,\n viewport,\n cookies,\n ...urlConfig\n}: OpenPageConfig): Promise<PageApi> => {\n const url = ((): string => {\n if (urlConfig.url !== undefined) {\n return urlConfig.url;\n }\n\n const {path = '/', port = serverPort, protocol = 'http', hostname = serverHostName} = urlConfig;\n\n if (!port) {\n // Error.captureStackTrace(error, openPage);\n throw new Error(\n 'You must specify a port. You can specify it when calling openPage() or by configuring a dev and ci server in the acceptanceTests config in your package.json'\n );\n }\n\n return `${protocol}://${hostname}:${port}${path}`;\n })();\n\n const currentUserAgent = userAgent || (await getGlobalBrowser().userAgent());\n const page = getGlobalPage();\n\n await page.bringToFront();\n if (viewport) {\n await page.setViewport(viewport);\n }\n if (cookies) {\n await page.setCookie(...cookies);\n }\n await page.setUserAgent(`${currentUserAgent} acceptance-test`);\n await page.emulateMediaFeatures([{name: 'prefers-color-scheme', value: isDarkMode ? 'dark' : 'light'}]);\n\n // A set of styles to make screenshot tests more reliable.\n await page.evaluateOnNewDocument((viewport: TestViewport) => {\n const overriddenSafeAreaInsets = !viewport\n ? []\n : Object.keys(viewport?.safeAreaInset ?? {}).map((key) => {\n const position = key as 'top' | 'right' | 'bottom' | 'left';\n return `--acceptance-test-override-safe-area-inset-${key}: ${viewport?.safeAreaInset?.[position]};`;\n });\n\n const style = document.createElement('style');\n style.innerHTML = `\n *, *:after, *:before {\n transition-delay: 0s !important;\n transition-duration: 0s !important;\n animation-delay: -0.0001s !important;\n animation-duration: 0s !important;\n animation-play-state: paused !important;\n caret-color: transparent !important;\n font-variant-ligatures: none !important;\n }\n *::-webkit-scrollbar {\n display: none !important;\n width: 0 !important;\n height: 0 !important;\n }\n :root {\n ${overriddenSafeAreaInsets.join('\\n')}\n }\n `;\n window.addEventListener('DOMContentLoaded', () => {\n document.head.appendChild(style);\n });\n }, viewport);\n\n if (needsRequestInterception) {\n await page.setRequestInterception(true);\n page.on('request', requestInterceptor);\n }\n\n try {\n await page.goto(url);\n } catch (e) {\n if ((e as Error).message.includes('net::ERR_CONNECTION_REFUSED')) {\n const connectionError = new Error(`Could not connect to ${url}. Is the server running?`);\n Error.captureStackTrace(connectionError, openPage);\n throw connectionError;\n } else {\n throw e;\n }\n }\n await page.waitForFunction('document.fonts.status === \"loaded\"');\n\n return getPageApi(page);\n};\n\nconst buildQueryMethods = ({page, element}: {page?: Page; element?: ElementHandle} = {}): ReturnType<\n typeof getQueriesForElement\n> => {\n const boundQueries: any = {};\n for (const [queryName, queryFn] of Object.entries(queries)) {\n boundQueries[queryName] = async (...args: any) => {\n const doc = await getDocument(page ?? getGlobalPage());\n const body = await doc.$('body');\n const queryArgs = [...args];\n if (queryName.startsWith('findBy')) {\n if (queryArgs.length === 1) {\n queryArgs.push(undefined);\n }\n queryArgs.push({timeout: 10000});\n }\n const elementHandle: ElementHandle = await queryFn(element ?? body, ...queryArgs);\n\n const newElementHandle = Object.create(elementHandle);\n\n newElementHandle.screenshot = async (options: CustomScreenshotOptions) => {\n if (!options?.skipNetworkWait) {\n await (page ?? getGlobalPage()).waitForNetworkIdle();\n }\n await waitForPaintEnd(elementHandle, {...options, fullPage: false});\n return elementHandle.screenshot(normalizeSreenshotOptions(options));\n };\n\n newElementHandle.click = async (options?: ClickOptions) => {\n await scrollIntoView(elementHandle);\n return elementHandle.click(options);\n };\n\n newElementHandle.type = async (text: string, options?: {delay: number}) => {\n await scrollIntoView(elementHandle);\n return elementHandle.type(text, options);\n };\n\n newElementHandle.select = async (...values: Array<string>) => {\n await scrollIntoView(elementHandle);\n return elementHandle.select(...values);\n };\n\n return newElementHandle;\n };\n }\n return boundQueries;\n};\n\nexport const getScreen = (page: Page) => buildQueryMethods({page});\n\nexport const screen = buildQueryMethods();\n\nexport const within = (element: ElementHandle) => buildQueryMethods({element});\n\nexport type {ElementHandle, Viewport} from 'puppeteer';\n\nbeforeEach(async () => {\n await getGlobalPage().setRequestInterception(false);\n\n // by resetting the page we clean up all the evaluateOnNewDocument calls, which are persistent between documents\n await (global as any).jestPuppeteer.resetPage();\n});\n\nafterEach(async () => {\n await collectCoverageIfAvailable({coveragePath});\n\n try {\n const page = getGlobalPage();\n requestHandlers = [];\n needsRequestInterception = false;\n page.off('request', requestInterceptor);\n\n // clear tab, this way we clear the DOM and stop js execution or pending requests\n await page.goto('about:blank');\n } catch (e) {\n // ignore, at this point page might be destroyed\n }\n});\n\n/**\n * Returns a new path to the file that can be used by chromium in acceptance tests\n *\n * To be able to use `element.uploadFile()` in a dockerized chromium, the file must exist in the\n * host and the docker, and both sides must use the same path.\n *\n * To workaround this bug or limitation, this function prepares the file by copying it to /tmp in\n * the host and the container.\n */\nexport const prepareFile = (filepath: string): string => {\n const isLocal = !isCi;\n const isHeadless = !!process.env.HEADLESS;\n const usesDocker = isLocal && isHeadless;\n\n const dockerComposeFile = path.join(__dirname, '..', 'docker-compose.yaml');\n\n if (usesDocker) {\n const containerId = execSync(`docker-compose -f ${dockerComposeFile} ps -q`).toString().trim();\n\n if (!containerId) {\n throw Error('acceptance-testing container not found');\n }\n\n execSync(`docker cp ${filepath} ${containerId}:/tmp`);\n\n const newPath = path.join('/tmp', path.basename(filepath));\n\n fs.copyFileSync(filepath, newPath);\n\n return newPath;\n } else {\n return filepath;\n }\n};\n\n/**\n * A convenience method to defer an expectation\n */\nexport const wait = <T>(expectation: () => Promise<T> | T, timeout = 10000, interval = 50): Promise<T> => {\n const startTime = Date.now();\n const startStack = new Error().stack;\n\n return new Promise((resolve, reject) => {\n const rejectOrRerun = (error: unknown) => {\n if (Date.now() - startTime >= timeout) {\n if (error instanceof Error) {\n if (error.message === 'Element not removed') {\n error.stack = startStack;\n }\n }\n reject(error);\n return;\n }\n // eslint-disable-next-line @typescript-eslint/no-use-before-define\n setTimeout(runExpectation, interval);\n };\n const runExpectation = () => {\n try {\n Promise.resolve(expectation())\n .then((r) => resolve(r))\n .catch(rejectOrRerun);\n } catch (error) {\n rejectOrRerun(error);\n }\n };\n setTimeout(runExpectation, 0);\n });\n};\n\nexport const waitForElementToBeRemoved = (\n element: ElementHandle<Element>,\n timeout = 10000,\n interval = 100\n): Promise<void> => {\n const startStack = new Error().stack;\n\n const wait = async () => {\n const t0 = Date.now();\n while (Date.now() - t0 < timeout) {\n // boundingBox returns null when the element is not in the DOM\n const box = await element.boundingBox();\n if (!box) {\n return;\n }\n await new Promise((resolve) => setTimeout(resolve, interval));\n }\n throw new Error('Element not removed');\n };\n\n return wait().catch((error) => {\n if (error.message === 'Element not removed') {\n error.stack = startStack;\n }\n throw error;\n });\n};\n"],"names":["prepareCoverageReportPath","_ref","coveragePath","ppidFile","path","join","ppid","process","toString","fs","existsSync","readFileSync","rootPath","expect","getState","snapshotState","_rootDir","Error","getRootPath","cwd","normalize","startsWith","rmSync","recursive","force","mkdirSync","writeFileSync","collectCoverageIfAvailable","_ref3","_asyncToGenerator","_regeneratorRuntime","mark","_callee","_ref2","coverage","nycOutputPath","wrap","_context","prev","next","global","page","evaluate","window","__coverage__","sent","abrupt","Object","values","forEach","cov","_JSON$stringify","hash","JSON","stringify","stop","_x","apply","arguments","getGlobalBrowser","browser","getGlobalPage","isCi","argv","includes","env","CI","isUsingDockerizedChromium","URL","wsEndpoint","port","serverHostName","platform","rootDir","findRoot","projectConfig","_pkg$acceptanceTests","parse","acceptanceTests","server","ciServer","devServer","_projectConfig$covera","serverPort","calledToMatchImageSnapshotOutsideDocker","extend","toMatchImageSnapshot","configureToMatchImageSnapshot","failureThreshold","failureThresholdType","customSnapshotIdentifier","defaultIdentifier","message","pass","afterEach","error","stack","split","waitForPaintEnd","element","_temp","_ref4","_ref4$fullPage","fullPage","captureBeyondViewport","MAX_WAIT","STEP_TIME","t0","buf1","buf2","Date","now","screenshot","normalizeSreenshotOptions","Promise","r","setTimeout","compare","_x2","_temp2","_ref5$captureBeyondVi","_ref5","_extends","_objectWithoutPropertiesLoose","_excluded","scrollIntoView","el","e","block","getPageApi","api","create","type","_ref6","_callee2","elementHandle","text","options","_context2","_x3","_x4","_x5","click","_ref7","_callee3","_context3","_x6","_x7","select","_ref8","_callee4","_len","_key","_args4","_context4","length","Array","_x8","_ref9","_callee5","_context5","skipNetworkWait","waitForNetworkIdle","_x9","clear","_ref10","_callee6","_context6","clickCount","press","_x10","setGeolocation","position","navigator","geolocation","getCurrentPosition","callback","coords","needsRequestInterception","requestHandlers","requestInterceptor","req","handler","_requestHandlers$find","find","_ref12","matcher","response","respond","interceptRequest","spy","jest","fn","push","openPage","_ref15","_callee7","_ref14","userAgent","isDarkMode","viewport","cookies","urlConfig","url","currentUserAgent","connectionError","_context7","_excluded2","undefined","_urlConfig$path","_urlConfig$port","_urlConfig$protocol","protocol","_urlConfig$hostname","hostname","bringToFront","setViewport","setCookie","setUserAgent","emulateMediaFeatures","name","value","evaluateOnNewDocument","overriddenSafeAreaInsets","keys","_viewport$safeAreaIns","safeAreaInset","map","key","_viewport$safeAreaIns2","style","document","createElement","innerHTML","addEventListener","head","appendChild","setRequestInterception","on","t1","captureStackTrace","waitForFunction","_x11","buildQueryMethods","_temp3","_ref16","boundQueries","_loop","_Object$entries$_i","_Object$entries","_i","queryName","queryFn","_callee12","doc","body","_len2","args","_key2","queryArgs","newElementHandle","_args12","_context12","getDocument","$","concat","timeout","_ref18","_callee8","_context8","_x12","_ref19","_callee9","_context9","_x13","_ref20","_callee10","_context10","_x14","_x15","_callee11","_args11","_context11","entries","queries","screen","beforeEach","_callee13","_context13","jestPuppeteer","resetPage","_callee14","_context14","off","_ref13","origin","originParam","baseUrl","method","mockImplementation","status","headers","Access-Control-Allow-Origin","Access-Control-Allow-Methods","Access-Control-Allow-Headers","spyOn","_URL","pathname","match","globToRegExp","spyResult","_spyResult$status","contentType","filepath","isHeadless","HEADLESS","usesDocker","dockerComposeFile","__dirname","containerId","execSync","trim","newPath","basename","copyFileSync","expectation","interval","startTime","startStack","resolve","reject","rejectOrRerun","runExpectation","then","_ref24","_callee15","_context15","boundingBox","wait"],"mappings":"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"}
1
+ {"version":3,"file":"acceptance-testing.cjs.production.min.js","sources":["../src/coverage.ts","../src/index.ts"],"sourcesContent":["import path from 'path';\nimport fs from 'fs';\n\nimport type {Page} from 'puppeteer';\n\nconst getGlobalPage = (): Page => (global as any).page;\n\nexport const getRootPath = () => {\n const rootPath = expect.getState().snapshotState._rootDir;\n if (!rootPath) {\n throw new Error('Root path not found');\n }\n return rootPath;\n};\n\n/**\n * We want to clear coverage files from previous runs, but at this point it is not easy because each\n * worker runs a different instance of this script, so we can't just clear the coverage folder at\n * the beginning of the test run.\n *\n * The solution is to remove the coverage folder when the stored ppid (parent process id) is\n * different from the current one\n */\nconst prepareCoverageReportPath = ({coveragePath}: {coveragePath: string}) => {\n const ppidFile = path.join(coveragePath, '.ppid');\n const ppid = process.ppid.toString();\n if (!fs.existsSync(ppidFile) || fs.readFileSync(ppidFile, 'utf-8') !== ppid) {\n // the condition is just to make sure we don't remove files outside the repo\n if (getRootPath() === process.cwd() && path.normalize(coveragePath).startsWith(process.cwd())) {\n fs.rmSync(coveragePath, {recursive: true, force: true});\n }\n fs.mkdirSync(coveragePath, {recursive: true});\n fs.writeFileSync(ppidFile, ppid);\n }\n};\n\n/**\n * Asumes the code was instrumented with istanbul and the coverage report stored in `window.__coverage__`.\n * If not, this function does nothing.\n */\nexport const collectCoverageIfAvailable = async ({coveragePath}: {coveragePath: string}): Promise<void> => {\n const coverage = await getGlobalPage().evaluate(() => {\n return (window as any).__coverage__;\n });\n if (!coverage) {\n return;\n }\n\n prepareCoverageReportPath({coveragePath});\n const nycOutputPath = path.join(coveragePath, '.nyc_output');\n fs.mkdirSync(nycOutputPath, {recursive: true});\n\n Object.values(coverage).forEach((cov: any) => {\n if (cov && cov.path && cov.hash) {\n fs.writeFileSync(path.join(nycOutputPath, cov.hash + '.json'), JSON.stringify({[cov.path]: cov}));\n }\n });\n};\n","import path from 'path';\nimport fs from 'fs';\nimport findRoot from 'find-root';\nimport type {getQueriesForElement} from 'pptr-testing-library';\nimport {getDocument, queries} from 'pptr-testing-library';\nimport {configureToMatchImageSnapshot} from 'jest-image-snapshot';\nimport globToRegExp from 'glob-to-regexp';\nimport {execSync} from 'child_process';\nimport {collectCoverageIfAvailable} from './coverage';\n\nimport type {\n Browser,\n ClickOptions,\n ElementHandle,\n GeolocationOptions,\n HTTPRequest,\n Page,\n ResponseForRequest,\n ScreenshotOptions,\n Viewport,\n} from 'puppeteer';\n\ntype CustomScreenshotOptions = ScreenshotOptions & {\n skipNetworkWait?: boolean;\n};\n\nexport const getGlobalBrowser = (): Browser => (global as any).browser;\nexport const getGlobalPage = (): Page => (global as any).page;\n\nconst isCi = process.argv.includes('--ci') || process.env.CI;\nconst isUsingDockerizedChromium = isCi || new URL(getGlobalBrowser().wsEndpoint()).port === '9223';\n\nexport const serverHostName = ((): string => {\n if (isCi) {\n return 'localhost';\n }\n\n if (isUsingDockerizedChromium) {\n return process.platform === 'linux' ? '172.17.0.1' : 'host.docker.internal';\n }\n\n return 'localhost';\n})();\n\nconst rootDir = findRoot(process.cwd());\nconst pkg = JSON.parse(fs.readFileSync(path.join(rootDir, 'package.json'), 'utf-8'));\nconst projectConfig = pkg.acceptanceTests ?? {};\nconst server = (isCi ? projectConfig.ciServer : projectConfig.devServer) ?? projectConfig.server;\nconst coveragePath = path.join(rootDir, projectConfig.coveragePath ?? 'reports/coverage-acceptance');\n\nexport const serverPort = server?.port;\n\nconst toMatchImageSnapshot = configureToMatchImageSnapshot({\n failureThreshold: 0,\n failureThresholdType: 'percent',\n customSnapshotIdentifier: ({defaultIdentifier}) => defaultIdentifier,\n});\n\nlet calledToMatchImageSnapshotOutsideDocker = false;\n\nconst localToMatchImageSnapshot = () => {\n calledToMatchImageSnapshotOutsideDocker = true;\n // let the expectation pass, then fail in afterEach. This way we allow developers to debug screenshot tests in local\n // but don't allow them to save screenshots taken outside the dockerized chromium\n return {\n message: () => '',\n pass: true,\n };\n};\n\nexpect.extend({\n toMatchImageSnapshot: isUsingDockerizedChromium ? toMatchImageSnapshot : localToMatchImageSnapshot,\n});\n\nafterEach(() => {\n if (calledToMatchImageSnapshotOutsideDocker) {\n const error = new Error(\n `Calling .toMatchImageSnapshot() is not allowed outside dockerized browser. Please, run your screenshot test in headless mode.`\n );\n error.stack = (error.stack || '').split('\\n')[0];\n throw error;\n }\n});\n\ntype WaitForPaintEndOptions = {\n fullPage?: boolean;\n captureBeyondViewport?: boolean;\n};\n\nconst waitForPaintEnd = async (\n element: ElementHandle | Page,\n {fullPage = true, captureBeyondViewport}: WaitForPaintEndOptions = {}\n) => {\n const MAX_WAIT = 15000;\n const STEP_TIME = 250;\n const t0 = Date.now();\n\n let buf1 = (await element.screenshot(\n normalizeSreenshotOptions({fullPage, captureBeyondViewport})\n )) as Buffer;\n await new Promise((r) => setTimeout(r, STEP_TIME));\n let buf2 = (await element.screenshot(\n normalizeSreenshotOptions({fullPage, captureBeyondViewport})\n )) as Buffer;\n\n // buffers are different if compare != 0\n while (buf1.compare(buf2)) {\n if (Date.now() - t0 > MAX_WAIT) {\n throw Error('Paint end timeout');\n }\n buf1 = buf2;\n await new Promise((r) => setTimeout(r, STEP_TIME));\n buf2 = (await element.screenshot(\n normalizeSreenshotOptions({fullPage, captureBeyondViewport})\n )) as Buffer;\n }\n};\n\nexport interface PageApi extends Omit<Page, 'click' | 'type' | 'select'> {\n clear: (selector: ElementHandle) => Promise<void>;\n // These are overridden:\n type: (selector: ElementHandle, text: string, options?: {delay: number}) => Promise<void>;\n click: (selector: ElementHandle, options?: ClickOptions) => Promise<void>;\n select: (selector: ElementHandle, ...values: string[]) => Promise<string[]>;\n screenshot: (options?: CustomScreenshotOptions) => Promise<Buffer | string | void>;\n}\n\nconst normalizeSreenshotOptions = ({captureBeyondViewport = false, ...options}: ScreenshotOptions = {}) => {\n // Puppeter default for captureBeyondViewport is true, but we think false is a better default.\n // When this is true, the fixed elements (like fixed footers) are relative to the original page\n // viewport, not to the full page, so those elements look weird in fullPage screenshots.\n return {...options, captureBeyondViewport};\n};\n\n// Puppeteer already calls scrollIntoViewIfNeeded before clicking an element. But it doesn't work in all situations\n// For example, when there is a fixed footer in the page and the element to click is under it, the browser won't scroll\n// because the element is already in the viewport (the ifNeeded part is important here). By forcing the scroll to the\n// center, we manage to fix these edge cases.\nconst scrollIntoView = (el: ElementHandle) => el.evaluate((e) => e.scrollIntoView({block: 'center'}));\n\nexport const getPageApi = (page: Page): PageApi => {\n const api: PageApi = Object.create(page);\n\n api.type = async (elementHandle, text, options) => {\n await scrollIntoView(elementHandle);\n return elementHandle.type(text, options);\n };\n api.click = async (elementHandle, options) => {\n await scrollIntoView(elementHandle);\n return elementHandle.click(options);\n };\n api.select = async (elementHandle, ...values) => {\n await scrollIntoView(elementHandle);\n return elementHandle.select(...values);\n };\n\n api.screenshot = async (options?: CustomScreenshotOptions) => {\n if (!options?.skipNetworkWait) {\n await page.waitForNetworkIdle();\n }\n await waitForPaintEnd(page, options);\n return page.screenshot(normalizeSreenshotOptions(options));\n };\n\n api.clear = async (elementHandle) => {\n await elementHandle.click({clickCount: 3});\n await elementHandle.press('Delete');\n };\n\n // For some reason, puppeteer browserContext.overridePermissions doesn't work with newer chrome versions.\n // This workaround polyfills the browser geolocation api to return the mocked position\n api.setGeolocation = (position: GeolocationOptions) =>\n page.evaluate((position) => {\n window.navigator.geolocation.getCurrentPosition = (callback) => {\n // @ts-expect-error - puppeteer's setGeoLocation does not expect a timestamp to be passed\n callback({\n coords: position,\n });\n };\n }, position as any);\n\n return api;\n};\n\nlet needsRequestInterception = false;\ntype RequestMatcherFn = (req: HTTPRequest) => boolean;\nlet requestHandlers: Array<{\n matcher: RequestMatcherFn;\n handler: jest.Mock<any, any>;\n}> = [];\n\nconst requestInterceptor = (req: HTTPRequest) => {\n const {handler} = requestHandlers.find(({matcher}) => matcher(req)) ?? {handler: null};\n if (!handler) {\n req.continue();\n return;\n }\n const response = handler(req);\n req.respond(response);\n};\n\nexport const interceptRequest = (\n matcher: RequestMatcherFn\n): jest.Mock<Partial<ResponseForRequest>, [HTTPRequest]> => {\n needsRequestInterception = true;\n const spy = jest.fn();\n requestHandlers.push({matcher, handler: spy});\n return spy;\n};\n\ntype ApiEndpointMock = {\n spyOn(path: string, method?: string): jest.Mock<unknown, [HTTPRequest]>;\n};\n\nexport const createApiEndpointMock = ({\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(path: string, method: string = 'GET') {\n const matcher = (req: HTTPRequest) => {\n const {pathname, origin} = new URL(req.url());\n return (\n req.method() === method &&\n !!origin.match(originRegExp) &&\n !!pathname.match(globToRegExp(path))\n );\n };\n\n const spy = jest.fn();\n\n interceptRequest(matcher).mockImplementation((req) => {\n const spyResult = spy(req);\n const status = spyResult.status ?? 200;\n const resBody = spyResult.body || spyResult;\n return {\n status,\n headers: {\n 'Access-Control-Allow-Origin': '*',\n },\n contentType: 'application/json',\n body: JSON.stringify(resBody),\n };\n });\n\n return spy;\n },\n };\n};\n\ntype CookieConfig = {\n name: string;\n value: string;\n url?: string;\n domain?: string;\n path?: string;\n secure?: boolean;\n httpOnly?: boolean;\n sameSite?: 'Strict' | 'Lax' | 'None';\n expires?: number;\n priority?: 'Low' | 'Medium' | 'High';\n sameParty?: boolean;\n sourceScheme?: 'Unset' | 'NonSecure' | 'Secure';\n sourcePort?: number;\n};\n\nexport interface TestViewport extends Viewport {\n safeAreaInset?: {\n top?: number | string;\n right?: number | string;\n bottom?: number | string;\n left?: number | string;\n };\n}\n\ninterface OpenPageCommonConfig {\n userAgent?: string;\n viewport?: TestViewport;\n isDarkMode?: boolean;\n cookies?: Array<CookieConfig>;\n}\n\ninterface OpenPageUrlConfig extends OpenPageCommonConfig {\n url: string;\n}\n\ninterface OpenPagePathConfig extends OpenPageCommonConfig {\n url?: undefined;\n\n path?: string;\n port?: number;\n protocol?: string;\n hostname?: string;\n}\n\ntype OpenPageConfig = OpenPageUrlConfig | OpenPagePathConfig;\n\nexport const openPage = async ({\n userAgent,\n isDarkMode,\n viewport,\n cookies,\n ...urlConfig\n}: OpenPageConfig): Promise<PageApi> => {\n const url = ((): string => {\n if (urlConfig.url !== undefined) {\n return urlConfig.url;\n }\n\n const {path = '/', port = serverPort, protocol = 'http', hostname = serverHostName} = urlConfig;\n\n if (!port) {\n // Error.captureStackTrace(error, openPage);\n throw new Error(\n 'You must specify a port. You can specify it when calling openPage() or by configuring a dev and ci server in the acceptanceTests config in your package.json'\n );\n }\n\n return `${protocol}://${hostname}:${port}${path}`;\n })();\n\n const currentUserAgent = userAgent || (await getGlobalBrowser().userAgent());\n const page = getGlobalPage();\n\n await page.bringToFront();\n if (viewport) {\n await page.setViewport(viewport);\n }\n if (cookies) {\n await page.setCookie(...cookies);\n }\n await page.setUserAgent(`${currentUserAgent} acceptance-test`);\n await page.emulateMediaFeatures([{name: 'prefers-color-scheme', value: isDarkMode ? 'dark' : 'light'}]);\n\n // A set of styles to make screenshot tests more reliable.\n await page.evaluateOnNewDocument((viewport: TestViewport) => {\n const overriddenSafeAreaInsets = !viewport\n ? []\n : Object.keys(viewport?.safeAreaInset ?? {}).map((key) => {\n const position = key as 'top' | 'right' | 'bottom' | 'left';\n return `--acceptance-test-override-safe-area-inset-${key}: ${viewport?.safeAreaInset?.[position]};`;\n });\n\n const style = document.createElement('style');\n style.innerHTML = `\n *, *:after, *:before {\n transition-delay: 0s !important;\n transition-duration: 0s !important;\n animation-delay: -0.0001s !important;\n animation-duration: 0s !important;\n animation-play-state: paused !important;\n caret-color: transparent !important;\n font-variant-ligatures: none !important;\n }\n *::-webkit-scrollbar {\n display: none !important;\n width: 0 !important;\n height: 0 !important;\n }\n :root {\n ${overriddenSafeAreaInsets.join('\\n')}\n }\n `;\n window.addEventListener('DOMContentLoaded', () => {\n document.head.appendChild(style);\n });\n }, viewport);\n\n if (needsRequestInterception) {\n await page.setRequestInterception(true);\n page.on('request', requestInterceptor);\n }\n\n try {\n await page.goto(url);\n } catch (e) {\n if ((e as Error).message.includes('net::ERR_CONNECTION_REFUSED')) {\n const connectionError = new Error(`Could not connect to ${url}. Is the server running?`);\n Error.captureStackTrace(connectionError, openPage);\n throw connectionError;\n } else {\n throw e;\n }\n }\n await page.waitForFunction('document.fonts.status === \"loaded\"');\n\n return getPageApi(page);\n};\n\nconst buildQueryMethods = ({page, element}: {page?: Page; element?: ElementHandle} = {}): ReturnType<\n typeof getQueriesForElement\n> => {\n const boundQueries: any = {};\n for (const [queryName, queryFn] of Object.entries(queries)) {\n boundQueries[queryName] = async (...args: any) => {\n const doc = await getDocument(page ?? getGlobalPage());\n const body = await doc.$('body');\n const queryArgs = [...args];\n if (queryName.startsWith('findBy')) {\n if (queryArgs.length === 1) {\n queryArgs.push(undefined);\n }\n queryArgs.push({timeout: 10000});\n }\n const elementHandle: ElementHandle = await queryFn(element ?? body, ...queryArgs);\n\n const newElementHandle = Object.create(elementHandle);\n\n newElementHandle.screenshot = async (options: CustomScreenshotOptions) => {\n if (!options?.skipNetworkWait) {\n await (page ?? getGlobalPage()).waitForNetworkIdle();\n }\n await waitForPaintEnd(elementHandle, {...options, fullPage: false});\n return elementHandle.screenshot(normalizeSreenshotOptions(options));\n };\n\n newElementHandle.click = async (options?: ClickOptions) => {\n await scrollIntoView(elementHandle);\n return elementHandle.click(options);\n };\n\n newElementHandle.type = async (text: string, options?: {delay: number}) => {\n await scrollIntoView(elementHandle);\n return elementHandle.type(text, options);\n };\n\n newElementHandle.select = async (...values: Array<string>) => {\n await scrollIntoView(elementHandle);\n return elementHandle.select(...values);\n };\n\n return newElementHandle;\n };\n }\n return boundQueries;\n};\n\nexport const getScreen = (page: Page) => buildQueryMethods({page});\n\nexport const screen = buildQueryMethods();\n\nexport const within = (element: ElementHandle) => buildQueryMethods({element});\n\nexport type {ElementHandle, Viewport} from 'puppeteer';\n\nbeforeEach(async () => {\n await getGlobalPage().setRequestInterception(false);\n\n // by resetting the page we clean up all the evaluateOnNewDocument calls, which are persistent between documents\n await (global as any).jestPuppeteer.resetPage();\n});\n\nafterEach(async () => {\n await collectCoverageIfAvailable({coveragePath});\n\n try {\n const page = getGlobalPage();\n requestHandlers = [];\n needsRequestInterception = false;\n page.off('request', requestInterceptor);\n\n // clear tab, this way we clear the DOM and stop js execution or pending requests\n await page.goto('about:blank');\n } catch (e) {\n // ignore, at this point page might be destroyed\n }\n});\n\n/**\n * Returns a new path to the file that can be used by chromium in acceptance tests\n *\n * To be able to use `element.uploadFile()` in a dockerized chromium, the file must exist in the\n * host and the docker, and both sides must use the same path.\n *\n * To workaround this bug or limitation, this function prepares the file by copying it to /tmp in\n * the host and the container.\n */\nexport const prepareFile = (filepath: string): string => {\n const isLocal = !isCi;\n const isHeadless = !!process.env.HEADLESS;\n const usesDocker = isLocal && isHeadless;\n\n const dockerComposeFile = path.join(__dirname, '..', 'docker-compose.yaml');\n\n if (usesDocker) {\n const containerId = execSync(`docker-compose -f ${dockerComposeFile} ps -q`).toString().trim();\n\n if (!containerId) {\n throw Error('acceptance-testing container not found');\n }\n\n execSync(`docker cp ${filepath} ${containerId}:/tmp`);\n\n const newPath = path.join('/tmp', path.basename(filepath));\n\n fs.copyFileSync(filepath, newPath);\n\n return newPath;\n } else {\n return filepath;\n }\n};\n\n/**\n * A convenience method to defer an expectation\n */\nexport const wait = <T>(expectation: () => Promise<T> | T, timeout = 10000, interval = 50): Promise<T> => {\n const startTime = Date.now();\n const startStack = new Error().stack;\n\n return new Promise((resolve, reject) => {\n const rejectOrRerun = (error: unknown) => {\n if (Date.now() - startTime >= timeout) {\n if (error instanceof Error) {\n if (error.message === 'Element not removed') {\n error.stack = startStack;\n }\n }\n reject(error);\n return;\n }\n // eslint-disable-next-line @typescript-eslint/no-use-before-define\n setTimeout(runExpectation, interval);\n };\n const runExpectation = () => {\n try {\n Promise.resolve(expectation())\n .then((r) => resolve(r))\n .catch(rejectOrRerun);\n } catch (error) {\n rejectOrRerun(error);\n }\n };\n setTimeout(runExpectation, 0);\n });\n};\n\nexport const waitForElementToBeRemoved = (\n element: ElementHandle<Element>,\n timeout = 10000,\n interval = 100\n): Promise<void> => {\n const startStack = new Error().stack;\n\n const wait = async () => {\n const t0 = Date.now();\n while (Date.now() - t0 < timeout) {\n // boundingBox returns null when the element is not in the DOM\n const box = await element.boundingBox();\n if (!box) {\n return;\n }\n await new Promise((resolve) => setTimeout(resolve, interval));\n }\n throw new Error('Element not removed');\n };\n\n return wait().catch((error) => {\n if (error.message === 'Element not removed') {\n error.stack = startStack;\n }\n throw error;\n });\n};\n"],"names":["prepareCoverageReportPath","_ref","coveragePath","ppidFile","path","join","ppid","process","toString","fs","existsSync","readFileSync","rootPath","expect","getState","snapshotState","_rootDir","Error","getRootPath","cwd","normalize","startsWith","rmSync","recursive","force","mkdirSync","writeFileSync","collectCoverageIfAvailable","_ref3","_asyncToGenerator","_regeneratorRuntime","mark","_callee","_ref2","coverage","nycOutputPath","wrap","_context","prev","next","global","page","evaluate","window","__coverage__","sent","abrupt","Object","values","forEach","cov","_JSON$stringify","hash","JSON","stringify","stop","_x","apply","arguments","getGlobalBrowser","browser","getGlobalPage","isCi","argv","includes","env","CI","isUsingDockerizedChromium","URL","wsEndpoint","port","serverHostName","platform","rootDir","findRoot","projectConfig","_pkg$acceptanceTests","parse","acceptanceTests","server","ciServer","devServer","_projectConfig$covera","serverPort","calledToMatchImageSnapshotOutsideDocker","extend","toMatchImageSnapshot","configureToMatchImageSnapshot","failureThreshold","failureThresholdType","customSnapshotIdentifier","defaultIdentifier","message","pass","afterEach","error","stack","split","waitForPaintEnd","element","_temp","_ref4","_ref4$fullPage","fullPage","captureBeyondViewport","MAX_WAIT","STEP_TIME","t0","buf1","buf2","Date","now","screenshot","normalizeSreenshotOptions","Promise","r","setTimeout","compare","_x2","_temp2","_ref5$captureBeyondVi","_ref5","_extends","_objectWithoutPropertiesLoose","_excluded","scrollIntoView","el","e","block","getPageApi","api","create","type","_ref6","_callee2","elementHandle","text","options","_context2","_x3","_x4","_x5","click","_ref7","_callee3","_context3","_x6","_x7","select","_ref8","_callee4","_len","_key","_args4","_context4","length","Array","_x8","_ref9","_callee5","_context5","skipNetworkWait","waitForNetworkIdle","_x9","clear","_ref10","_callee6","_context6","clickCount","press","_x10","setGeolocation","position","navigator","geolocation","getCurrentPosition","callback","coords","needsRequestInterception","requestHandlers","requestInterceptor","req","handler","_requestHandlers$find","find","_ref12","matcher","response","respond","interceptRequest","spy","jest","fn","push","openPage","_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","map","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","match","mockImplementation","status","headers","Access-Control-Allow-Origin","Access-Control-Allow-Methods","Access-Control-Allow-Headers","spyOn","_URL2","pathname","spyResult","_spyResult$status","contentType","filepath","isHeadless","HEADLESS","usesDocker","dockerComposeFile","__dirname","containerId","execSync","trim","newPath","basename","copyFileSync","expectation","interval","startTime","startStack","resolve","reject","rejectOrRerun","runExpectation","then","_ref25","_callee15","_context15","boundingBox","wait"],"mappings":"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"}
@@ -746,12 +746,16 @@ var interceptRequest = function interceptRequest(matcher) {
746
746
  });
747
747
  return spy;
748
748
  };
749
- var createApiEndpointMock = function createApiEndpointMock(_ref13) {
750
- var origin = _ref13.origin,
749
+ var createApiEndpointMock = function createApiEndpointMock(_temp3) {
750
+ var _ref14;
751
+ var _ref13 = _temp3 === void 0 ? {} : _temp3,
752
+ origin = _ref13.origin,
751
753
  baseUrl = _ref13.baseUrl;
752
- var originParam = origin != null ? origin : baseUrl;
754
+ var originRegExp = globToRegExp((_ref14 = origin != null ? origin : baseUrl) != null ? _ref14 : '*');
753
755
  interceptRequest(function (req) {
754
- return req.method() === 'OPTIONS' && req.url().startsWith(originParam);
756
+ var _URL = new URL(req.url()),
757
+ origin = _URL.origin;
758
+ return req.method() === 'OPTIONS' && !!origin.match(originRegExp);
755
759
  }).mockImplementation(function () {
756
760
  return {
757
761
  status: 204,
@@ -768,11 +772,10 @@ var createApiEndpointMock = function createApiEndpointMock(_ref13) {
768
772
  method = 'GET';
769
773
  }
770
774
  var matcher = function matcher(req) {
771
- var url = req.url();
772
- var _URL = new URL(url),
773
- pathname = _URL.pathname,
774
- origin = _URL.origin;
775
- return req.method() === method && !!origin.match(globToRegExp(originParam)) && !!pathname.match(globToRegExp(path));
775
+ var _URL2 = new URL(req.url()),
776
+ pathname = _URL2.pathname,
777
+ origin = _URL2.origin;
778
+ return req.method() === method && !!origin.match(originRegExp) && !!pathname.match(globToRegExp(path));
776
779
  };
777
780
  var spy = jest.fn();
778
781
  interceptRequest(matcher).mockImplementation(function (req) {
@@ -794,12 +797,12 @@ var createApiEndpointMock = function createApiEndpointMock(_ref13) {
794
797
  };
795
798
  };
796
799
  var openPage = /*#__PURE__*/function () {
797
- var _ref15 = /*#__PURE__*/_asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee7(_ref14) {
800
+ var _ref16 = /*#__PURE__*/_asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee7(_ref15) {
798
801
  var userAgent, isDarkMode, viewport, cookies, urlConfig, url, currentUserAgent, page, connectionError;
799
802
  return _regeneratorRuntime().wrap(function _callee7$(_context7) {
800
803
  while (1) switch (_context7.prev = _context7.next) {
801
804
  case 0:
802
- userAgent = _ref14.userAgent, isDarkMode = _ref14.isDarkMode, viewport = _ref14.viewport, cookies = _ref14.cookies, urlConfig = /*#__PURE__*/_objectWithoutPropertiesLoose(_ref14, _excluded2);
805
+ userAgent = _ref15.userAgent, isDarkMode = _ref15.isDarkMode, viewport = _ref15.viewport, cookies = _ref15.cookies, urlConfig = /*#__PURE__*/_objectWithoutPropertiesLoose(_ref15, _excluded2);
803
806
  url = function () {
804
807
  if (urlConfig.url !== undefined) {
805
808
  return urlConfig.url;
@@ -910,13 +913,13 @@ var openPage = /*#__PURE__*/function () {
910
913
  }, _callee7, null, [[27, 32]]);
911
914
  }));
912
915
  return function openPage(_x11) {
913
- return _ref15.apply(this, arguments);
916
+ return _ref16.apply(this, arguments);
914
917
  };
915
918
  }();
916
- var buildQueryMethods = function buildQueryMethods(_temp3) {
917
- var _ref16 = _temp3 === void 0 ? {} : _temp3,
918
- page = _ref16.page,
919
- element = _ref16.element;
919
+ var buildQueryMethods = function buildQueryMethods(_temp4) {
920
+ var _ref17 = _temp4 === void 0 ? {} : _temp4,
921
+ page = _ref17.page,
922
+ element = _ref17.element;
920
923
  var boundQueries = {};
921
924
  var _loop = function _loop() {
922
925
  var _Object$entries$_i = _Object$entries[_i],
@@ -961,7 +964,7 @@ var buildQueryMethods = function buildQueryMethods(_temp3) {
961
964
  elementHandle = _context12.sent;
962
965
  newElementHandle = Object.create(elementHandle);
963
966
  newElementHandle.screenshot = /*#__PURE__*/function () {
964
- var _ref18 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee8(options) {
967
+ var _ref19 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee8(options) {
965
968
  return _regeneratorRuntime().wrap(function _callee8$(_context8) {
966
969
  while (1) switch (_context8.prev = _context8.next) {
967
970
  case 0:
@@ -985,11 +988,11 @@ var buildQueryMethods = function buildQueryMethods(_temp3) {
985
988
  }, _callee8);
986
989
  }));
987
990
  return function (_x12) {
988
- return _ref18.apply(this, arguments);
991
+ return _ref19.apply(this, arguments);
989
992
  };
990
993
  }();
991
994
  newElementHandle.click = /*#__PURE__*/function () {
992
- var _ref19 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee9(options) {
995
+ var _ref20 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee9(options) {
993
996
  return _regeneratorRuntime().wrap(function _callee9$(_context9) {
994
997
  while (1) switch (_context9.prev = _context9.next) {
995
998
  case 0:
@@ -1004,11 +1007,11 @@ var buildQueryMethods = function buildQueryMethods(_temp3) {
1004
1007
  }, _callee9);
1005
1008
  }));
1006
1009
  return function (_x13) {
1007
- return _ref19.apply(this, arguments);
1010
+ return _ref20.apply(this, arguments);
1008
1011
  };
1009
1012
  }();
1010
1013
  newElementHandle.type = /*#__PURE__*/function () {
1011
- var _ref20 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee10(text, options) {
1014
+ var _ref21 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee10(text, options) {
1012
1015
  return _regeneratorRuntime().wrap(function _callee10$(_context10) {
1013
1016
  while (1) switch (_context10.prev = _context10.next) {
1014
1017
  case 0:
@@ -1023,7 +1026,7 @@ var buildQueryMethods = function buildQueryMethods(_temp3) {
1023
1026
  }, _callee10);
1024
1027
  }));
1025
1028
  return function (_x14, _x15) {
1026
- return _ref20.apply(this, arguments);
1029
+ return _ref21.apply(this, arguments);
1027
1030
  };
1028
1031
  }();
1029
1032
  newElementHandle.select = /*#__PURE__*/_asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee11() {
@@ -1184,7 +1187,7 @@ var waitForElementToBeRemoved = function waitForElementToBeRemoved(element, time
1184
1187
  }
1185
1188
  var startStack = new Error().stack;
1186
1189
  var wait = /*#__PURE__*/function () {
1187
- var _ref24 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee15() {
1190
+ var _ref25 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee15() {
1188
1191
  var t0, box;
1189
1192
  return _regeneratorRuntime().wrap(function _callee15$(_context15) {
1190
1193
  while (1) switch (_context15.prev = _context15.next) {
@@ -1221,7 +1224,7 @@ var waitForElementToBeRemoved = function waitForElementToBeRemoved(element, time
1221
1224
  }, _callee15);
1222
1225
  }));
1223
1226
  return function wait() {
1224
- return _ref24.apply(this, arguments);
1227
+ return _ref25.apply(this, arguments);
1225
1228
  };
1226
1229
  }();
1227
1230
  return wait()["catch"](function (error) {
@@ -1 +1 @@
1
- {"version":3,"file":"acceptance-testing.esm.js","sources":["../src/coverage.ts","../src/index.ts"],"sourcesContent":["import path from 'path';\nimport fs from 'fs';\n\nimport type {Page} from 'puppeteer';\n\nconst getGlobalPage = (): Page => (global as any).page;\n\nexport const getRootPath = () => {\n const rootPath = expect.getState().snapshotState._rootDir;\n if (!rootPath) {\n throw new Error('Root path not found');\n }\n return rootPath;\n};\n\n/**\n * We want to clear coverage files from previous runs, but at this point it is not easy because each\n * worker runs a different instance of this script, so we can't just clear the coverage folder at\n * the beginning of the test run.\n *\n * The solution is to remove the coverage folder when the stored ppid (parent process id) is\n * different from the current one\n */\nconst prepareCoverageReportPath = ({coveragePath}: {coveragePath: string}) => {\n const ppidFile = path.join(coveragePath, '.ppid');\n const ppid = process.ppid.toString();\n if (!fs.existsSync(ppidFile) || fs.readFileSync(ppidFile, 'utf-8') !== ppid) {\n // the condition is just to make sure we don't remove files outside the repo\n if (getRootPath() === process.cwd() && path.normalize(coveragePath).startsWith(process.cwd())) {\n fs.rmSync(coveragePath, {recursive: true, force: true});\n }\n fs.mkdirSync(coveragePath, {recursive: true});\n fs.writeFileSync(ppidFile, ppid);\n }\n};\n\n/**\n * Asumes the code was instrumented with istanbul and the coverage report stored in `window.__coverage__`.\n * If not, this function does nothing.\n */\nexport const collectCoverageIfAvailable = async ({coveragePath}: {coveragePath: string}): Promise<void> => {\n const coverage = await getGlobalPage().evaluate(() => {\n return (window as any).__coverage__;\n });\n if (!coverage) {\n return;\n }\n\n prepareCoverageReportPath({coveragePath});\n const nycOutputPath = path.join(coveragePath, '.nyc_output');\n fs.mkdirSync(nycOutputPath, {recursive: true});\n\n Object.values(coverage).forEach((cov: any) => {\n if (cov && cov.path && cov.hash) {\n fs.writeFileSync(path.join(nycOutputPath, cov.hash + '.json'), JSON.stringify({[cov.path]: cov}));\n }\n });\n};\n","import path from 'path';\nimport fs from 'fs';\nimport findRoot from 'find-root';\nimport type {getQueriesForElement} from 'pptr-testing-library';\nimport {getDocument, queries} from 'pptr-testing-library';\nimport {configureToMatchImageSnapshot} from 'jest-image-snapshot';\nimport globToRegExp from 'glob-to-regexp';\nimport {execSync} from 'child_process';\nimport {collectCoverageIfAvailable} from './coverage';\n\nimport type {\n Browser,\n ClickOptions,\n ElementHandle,\n GeolocationOptions,\n HTTPRequest,\n Page,\n ResponseForRequest,\n ScreenshotOptions,\n Viewport,\n} from 'puppeteer';\n\ntype CustomScreenshotOptions = ScreenshotOptions & {\n skipNetworkWait?: boolean;\n};\n\nexport const getGlobalBrowser = (): Browser => (global as any).browser;\nexport const getGlobalPage = (): Page => (global as any).page;\n\nconst isCi = process.argv.includes('--ci') || process.env.CI;\nconst isUsingDockerizedChromium = isCi || new URL(getGlobalBrowser().wsEndpoint()).port === '9223';\n\nexport const serverHostName = ((): string => {\n if (isCi) {\n return 'localhost';\n }\n\n if (isUsingDockerizedChromium) {\n return process.platform === 'linux' ? '172.17.0.1' : 'host.docker.internal';\n }\n\n return 'localhost';\n})();\n\nconst rootDir = findRoot(process.cwd());\nconst pkg = JSON.parse(fs.readFileSync(path.join(rootDir, 'package.json'), 'utf-8'));\nconst projectConfig = pkg.acceptanceTests ?? {};\nconst server = (isCi ? projectConfig.ciServer : projectConfig.devServer) ?? projectConfig.server;\nconst coveragePath = path.join(rootDir, projectConfig.coveragePath ?? 'reports/coverage-acceptance');\n\nexport const serverPort = server?.port;\n\nconst toMatchImageSnapshot = configureToMatchImageSnapshot({\n failureThreshold: 0,\n failureThresholdType: 'percent',\n customSnapshotIdentifier: ({defaultIdentifier}) => defaultIdentifier,\n});\n\nlet calledToMatchImageSnapshotOutsideDocker = false;\n\nconst localToMatchImageSnapshot = () => {\n calledToMatchImageSnapshotOutsideDocker = true;\n // let the expectation pass, then fail in afterEach. This way we allow developers to debug screenshot tests in local\n // but don't allow them to save screenshots taken outside the dockerized chromium\n return {\n message: () => '',\n pass: true,\n };\n};\n\nexpect.extend({\n toMatchImageSnapshot: isUsingDockerizedChromium ? toMatchImageSnapshot : localToMatchImageSnapshot,\n});\n\nafterEach(() => {\n if (calledToMatchImageSnapshotOutsideDocker) {\n const error = new Error(\n `Calling .toMatchImageSnapshot() is not allowed outside dockerized browser. Please, run your screenshot test in headless mode.`\n );\n error.stack = (error.stack || '').split('\\n')[0];\n throw error;\n }\n});\n\ntype WaitForPaintEndOptions = {\n fullPage?: boolean;\n captureBeyondViewport?: boolean;\n};\n\nconst waitForPaintEnd = async (\n element: ElementHandle | Page,\n {fullPage = true, captureBeyondViewport}: WaitForPaintEndOptions = {}\n) => {\n const MAX_WAIT = 15000;\n const STEP_TIME = 250;\n const t0 = Date.now();\n\n let buf1 = (await element.screenshot(\n normalizeSreenshotOptions({fullPage, captureBeyondViewport})\n )) as Buffer;\n await new Promise((r) => setTimeout(r, STEP_TIME));\n let buf2 = (await element.screenshot(\n normalizeSreenshotOptions({fullPage, captureBeyondViewport})\n )) as Buffer;\n\n // buffers are different if compare != 0\n while (buf1.compare(buf2)) {\n if (Date.now() - t0 > MAX_WAIT) {\n throw Error('Paint end timeout');\n }\n buf1 = buf2;\n await new Promise((r) => setTimeout(r, STEP_TIME));\n buf2 = (await element.screenshot(\n normalizeSreenshotOptions({fullPage, captureBeyondViewport})\n )) as Buffer;\n }\n};\n\nexport interface PageApi extends Omit<Page, 'click' | 'type' | 'select'> {\n clear: (selector: ElementHandle) => Promise<void>;\n // These are overridden:\n type: (selector: ElementHandle, text: string, options?: {delay: number}) => Promise<void>;\n click: (selector: ElementHandle, options?: ClickOptions) => Promise<void>;\n select: (selector: ElementHandle, ...values: string[]) => Promise<string[]>;\n screenshot: (options?: CustomScreenshotOptions) => Promise<Buffer | string | void>;\n}\n\nconst normalizeSreenshotOptions = ({captureBeyondViewport = false, ...options}: ScreenshotOptions = {}) => {\n // Puppeter default for captureBeyondViewport is true, but we think false is a better default.\n // When this is true, the fixed elements (like fixed footers) are relative to the original page\n // viewport, not to the full page, so those elements look weird in fullPage screenshots.\n return {...options, captureBeyondViewport};\n};\n\n// Puppeteer already calls scrollIntoViewIfNeeded before clicking an element. But it doesn't work in all situations\n// For example, when there is a fixed footer in the page and the element to click is under it, the browser won't scroll\n// because the element is already in the viewport (the ifNeeded part is important here). By forcing the scroll to the\n// center, we manage to fix these edge cases.\nconst scrollIntoView = (el: ElementHandle) => el.evaluate((e) => e.scrollIntoView({block: 'center'}));\n\nexport const getPageApi = (page: Page): PageApi => {\n const api: PageApi = Object.create(page);\n\n api.type = async (elementHandle, text, options) => {\n await scrollIntoView(elementHandle);\n return elementHandle.type(text, options);\n };\n api.click = async (elementHandle, options) => {\n await scrollIntoView(elementHandle);\n return elementHandle.click(options);\n };\n api.select = async (elementHandle, ...values) => {\n await scrollIntoView(elementHandle);\n return elementHandle.select(...values);\n };\n\n api.screenshot = async (options?: CustomScreenshotOptions) => {\n if (!options?.skipNetworkWait) {\n await page.waitForNetworkIdle();\n }\n await waitForPaintEnd(page, options);\n return page.screenshot(normalizeSreenshotOptions(options));\n };\n\n api.clear = async (elementHandle) => {\n await elementHandle.click({clickCount: 3});\n await elementHandle.press('Delete');\n };\n\n // For some reason, puppeteer browserContext.overridePermissions doesn't work with newer chrome versions.\n // This workaround polyfills the browser geolocation api to return the mocked position\n api.setGeolocation = (position: GeolocationOptions) =>\n page.evaluate((position) => {\n window.navigator.geolocation.getCurrentPosition = (callback) => {\n // @ts-expect-error - puppeteer's setGeoLocation does not expect a timestamp to be passed\n callback({\n coords: position,\n });\n };\n }, position as any);\n\n return api;\n};\n\nlet needsRequestInterception = false;\ntype RequestMatcherFn = (req: HTTPRequest) => boolean;\nlet requestHandlers: Array<{\n matcher: RequestMatcherFn;\n handler: jest.Mock<any, any>;\n}> = [];\n\nconst requestInterceptor = (req: HTTPRequest) => {\n const {handler} = requestHandlers.find(({matcher}) => matcher(req)) ?? {handler: null};\n if (!handler) {\n req.continue();\n return;\n }\n const response = handler(req);\n req.respond(response);\n};\n\nexport const interceptRequest = (\n matcher: RequestMatcherFn\n): jest.Mock<Partial<ResponseForRequest>, [HTTPRequest]> => {\n needsRequestInterception = true;\n const spy = jest.fn();\n requestHandlers.push({matcher, handler: spy});\n return spy;\n};\n\ntype ApiEndpointMock = {\n spyOn(path: string, method?: string): jest.Mock<unknown, [HTTPRequest]>;\n};\n\nexport const createApiEndpointMock = ({\n origin,\n baseUrl,\n}: {\n origin: string;\n /** @deprecated use origin */\n baseUrl: string;\n}): ApiEndpointMock => {\n const originParam = origin ?? baseUrl;\n interceptRequest(\n (req) => req.method() === 'OPTIONS' && req.url().startsWith(originParam)\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(path: string, method: string = 'GET') {\n const matcher = (req: HTTPRequest) => {\n const url = req.url();\n const {pathname, origin} = new URL(url);\n return (\n req.method() === method &&\n !!origin.match(globToRegExp(originParam)) &&\n !!pathname.match(globToRegExp(path))\n );\n };\n\n const spy = jest.fn();\n\n interceptRequest(matcher).mockImplementation((req) => {\n const spyResult = spy(req);\n const status = spyResult.status ?? 200;\n const resBody = spyResult.body || spyResult;\n return {\n status,\n headers: {\n 'Access-Control-Allow-Origin': '*',\n },\n contentType: 'application/json',\n body: JSON.stringify(resBody),\n };\n });\n\n return spy;\n },\n };\n};\n\ntype CookieConfig = {\n name: string;\n value: string;\n url?: string;\n domain?: string;\n path?: string;\n secure?: boolean;\n httpOnly?: boolean;\n sameSite?: 'Strict' | 'Lax' | 'None';\n expires?: number;\n priority?: 'Low' | 'Medium' | 'High';\n sameParty?: boolean;\n sourceScheme?: 'Unset' | 'NonSecure' | 'Secure';\n sourcePort?: number;\n};\n\nexport interface TestViewport extends Viewport {\n safeAreaInset?: {\n top?: number | string;\n right?: number | string;\n bottom?: number | string;\n left?: number | string;\n };\n}\n\ninterface OpenPageCommonConfig {\n userAgent?: string;\n viewport?: TestViewport;\n isDarkMode?: boolean;\n cookies?: Array<CookieConfig>;\n}\n\ninterface OpenPageUrlConfig extends OpenPageCommonConfig {\n url: string;\n}\n\ninterface OpenPagePathConfig extends OpenPageCommonConfig {\n url?: undefined;\n\n path?: string;\n port?: number;\n protocol?: string;\n hostname?: string;\n}\n\ntype OpenPageConfig = OpenPageUrlConfig | OpenPagePathConfig;\n\nexport const openPage = async ({\n userAgent,\n isDarkMode,\n viewport,\n cookies,\n ...urlConfig\n}: OpenPageConfig): Promise<PageApi> => {\n const url = ((): string => {\n if (urlConfig.url !== undefined) {\n return urlConfig.url;\n }\n\n const {path = '/', port = serverPort, protocol = 'http', hostname = serverHostName} = urlConfig;\n\n if (!port) {\n // Error.captureStackTrace(error, openPage);\n throw new Error(\n 'You must specify a port. You can specify it when calling openPage() or by configuring a dev and ci server in the acceptanceTests config in your package.json'\n );\n }\n\n return `${protocol}://${hostname}:${port}${path}`;\n })();\n\n const currentUserAgent = userAgent || (await getGlobalBrowser().userAgent());\n const page = getGlobalPage();\n\n await page.bringToFront();\n if (viewport) {\n await page.setViewport(viewport);\n }\n if (cookies) {\n await page.setCookie(...cookies);\n }\n await page.setUserAgent(`${currentUserAgent} acceptance-test`);\n await page.emulateMediaFeatures([{name: 'prefers-color-scheme', value: isDarkMode ? 'dark' : 'light'}]);\n\n // A set of styles to make screenshot tests more reliable.\n await page.evaluateOnNewDocument((viewport: TestViewport) => {\n const overriddenSafeAreaInsets = !viewport\n ? []\n : Object.keys(viewport?.safeAreaInset ?? {}).map((key) => {\n const position = key as 'top' | 'right' | 'bottom' | 'left';\n return `--acceptance-test-override-safe-area-inset-${key}: ${viewport?.safeAreaInset?.[position]};`;\n });\n\n const style = document.createElement('style');\n style.innerHTML = `\n *, *:after, *:before {\n transition-delay: 0s !important;\n transition-duration: 0s !important;\n animation-delay: -0.0001s !important;\n animation-duration: 0s !important;\n animation-play-state: paused !important;\n caret-color: transparent !important;\n font-variant-ligatures: none !important;\n }\n *::-webkit-scrollbar {\n display: none !important;\n width: 0 !important;\n height: 0 !important;\n }\n :root {\n ${overriddenSafeAreaInsets.join('\\n')}\n }\n `;\n window.addEventListener('DOMContentLoaded', () => {\n document.head.appendChild(style);\n });\n }, viewport);\n\n if (needsRequestInterception) {\n await page.setRequestInterception(true);\n page.on('request', requestInterceptor);\n }\n\n try {\n await page.goto(url);\n } catch (e) {\n if ((e as Error).message.includes('net::ERR_CONNECTION_REFUSED')) {\n const connectionError = new Error(`Could not connect to ${url}. Is the server running?`);\n Error.captureStackTrace(connectionError, openPage);\n throw connectionError;\n } else {\n throw e;\n }\n }\n await page.waitForFunction('document.fonts.status === \"loaded\"');\n\n return getPageApi(page);\n};\n\nconst buildQueryMethods = ({page, element}: {page?: Page; element?: ElementHandle} = {}): ReturnType<\n typeof getQueriesForElement\n> => {\n const boundQueries: any = {};\n for (const [queryName, queryFn] of Object.entries(queries)) {\n boundQueries[queryName] = async (...args: any) => {\n const doc = await getDocument(page ?? getGlobalPage());\n const body = await doc.$('body');\n const queryArgs = [...args];\n if (queryName.startsWith('findBy')) {\n if (queryArgs.length === 1) {\n queryArgs.push(undefined);\n }\n queryArgs.push({timeout: 10000});\n }\n const elementHandle: ElementHandle = await queryFn(element ?? body, ...queryArgs);\n\n const newElementHandle = Object.create(elementHandle);\n\n newElementHandle.screenshot = async (options: CustomScreenshotOptions) => {\n if (!options?.skipNetworkWait) {\n await (page ?? getGlobalPage()).waitForNetworkIdle();\n }\n await waitForPaintEnd(elementHandle, {...options, fullPage: false});\n return elementHandle.screenshot(normalizeSreenshotOptions(options));\n };\n\n newElementHandle.click = async (options?: ClickOptions) => {\n await scrollIntoView(elementHandle);\n return elementHandle.click(options);\n };\n\n newElementHandle.type = async (text: string, options?: {delay: number}) => {\n await scrollIntoView(elementHandle);\n return elementHandle.type(text, options);\n };\n\n newElementHandle.select = async (...values: Array<string>) => {\n await scrollIntoView(elementHandle);\n return elementHandle.select(...values);\n };\n\n return newElementHandle;\n };\n }\n return boundQueries;\n};\n\nexport const getScreen = (page: Page) => buildQueryMethods({page});\n\nexport const screen = buildQueryMethods();\n\nexport const within = (element: ElementHandle) => buildQueryMethods({element});\n\nexport type {ElementHandle, Viewport} from 'puppeteer';\n\nbeforeEach(async () => {\n await getGlobalPage().setRequestInterception(false);\n\n // by resetting the page we clean up all the evaluateOnNewDocument calls, which are persistent between documents\n await (global as any).jestPuppeteer.resetPage();\n});\n\nafterEach(async () => {\n await collectCoverageIfAvailable({coveragePath});\n\n try {\n const page = getGlobalPage();\n requestHandlers = [];\n needsRequestInterception = false;\n page.off('request', requestInterceptor);\n\n // clear tab, this way we clear the DOM and stop js execution or pending requests\n await page.goto('about:blank');\n } catch (e) {\n // ignore, at this point page might be destroyed\n }\n});\n\n/**\n * Returns a new path to the file that can be used by chromium in acceptance tests\n *\n * To be able to use `element.uploadFile()` in a dockerized chromium, the file must exist in the\n * host and the docker, and both sides must use the same path.\n *\n * To workaround this bug or limitation, this function prepares the file by copying it to /tmp in\n * the host and the container.\n */\nexport const prepareFile = (filepath: string): string => {\n const isLocal = !isCi;\n const isHeadless = !!process.env.HEADLESS;\n const usesDocker = isLocal && isHeadless;\n\n const dockerComposeFile = path.join(__dirname, '..', 'docker-compose.yaml');\n\n if (usesDocker) {\n const containerId = execSync(`docker-compose -f ${dockerComposeFile} ps -q`).toString().trim();\n\n if (!containerId) {\n throw Error('acceptance-testing container not found');\n }\n\n execSync(`docker cp ${filepath} ${containerId}:/tmp`);\n\n const newPath = path.join('/tmp', path.basename(filepath));\n\n fs.copyFileSync(filepath, newPath);\n\n return newPath;\n } else {\n return filepath;\n }\n};\n\n/**\n * A convenience method to defer an expectation\n */\nexport const wait = <T>(expectation: () => Promise<T> | T, timeout = 10000, interval = 50): Promise<T> => {\n const startTime = Date.now();\n const startStack = new Error().stack;\n\n return new Promise((resolve, reject) => {\n const rejectOrRerun = (error: unknown) => {\n if (Date.now() - startTime >= timeout) {\n if (error instanceof Error) {\n if (error.message === 'Element not removed') {\n error.stack = startStack;\n }\n }\n reject(error);\n return;\n }\n // eslint-disable-next-line @typescript-eslint/no-use-before-define\n setTimeout(runExpectation, interval);\n };\n const runExpectation = () => {\n try {\n Promise.resolve(expectation())\n .then((r) => resolve(r))\n .catch(rejectOrRerun);\n } catch (error) {\n rejectOrRerun(error);\n }\n };\n setTimeout(runExpectation, 0);\n });\n};\n\nexport const waitForElementToBeRemoved = (\n element: ElementHandle<Element>,\n timeout = 10000,\n interval = 100\n): Promise<void> => {\n const startStack = new Error().stack;\n\n const wait = async () => {\n const t0 = Date.now();\n while (Date.now() - t0 < timeout) {\n // boundingBox returns null when the element is not in the DOM\n const box = await element.boundingBox();\n if (!box) {\n return;\n }\n await new Promise((resolve) => setTimeout(resolve, interval));\n }\n throw new Error('Element not removed');\n };\n\n return wait().catch((error) => {\n if (error.message === 'Element not removed') {\n error.stack = startStack;\n }\n throw error;\n });\n};\n"],"names":["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","getGlobalBrowser","browser","isCi","argv","includes","env","CI","isUsingDockerizedChromium","URL","wsEndpoint","port","serverHostName","platform","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","split","waitForPaintEnd","element","_temp","_ref4","_ref4$fullPage","fullPage","captureBeyondViewport","MAX_WAIT","STEP_TIME","t0","buf1","buf2","Date","now","screenshot","normalizeSreenshotOptions","Promise","r","setTimeout","compare","_x2","_temp2","_ref5$captureBeyondVi","_ref5","options","_objectWithoutPropertiesLoose","_excluded","_extends","scrollIntoView","el","e","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","_ref13","origin","baseUrl","originParam","method","url","mockImplementation","status","headers","spyOn","_URL","pathname","match","globToRegExp","spyResult","_spyResult$status","resBody","body","contentType","openPage","_ref15","_callee7","_ref14","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","map","key","_viewport$safeAreaIns2","style","document","createElement","innerHTML","addEventListener","head","appendChild","setRequestInterception","on","t1","captureStackTrace","waitForFunction","_x11","buildQueryMethods","_temp3","_ref16","boundQueries","_loop","_Object$entries$_i","_Object$entries","_i","queryName","queryFn","_callee12","doc","_len2","args","_key2","queryArgs","newElementHandle","_args12","_callee12$","_context12","getDocument","$","concat","timeout","_ref18","_callee8","_callee8$","_context8","_x12","_ref19","_callee9","_callee9$","_context9","_x13","_ref20","_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","execSync","trim","newPath","basename","copyFileSync","wait","expectation","interval","startTime","startStack","resolve","reject","rejectOrRerun","runExpectation","then","waitForElementToBeRemoved","_ref24","_callee15","box","_callee15$","_context15","boundingBox"],"mappings":"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"}
1
+ {"version":3,"file":"acceptance-testing.esm.js","sources":["../src/coverage.ts","../src/index.ts"],"sourcesContent":["import path from 'path';\nimport fs from 'fs';\n\nimport type {Page} from 'puppeteer';\n\nconst getGlobalPage = (): Page => (global as any).page;\n\nexport const getRootPath = () => {\n const rootPath = expect.getState().snapshotState._rootDir;\n if (!rootPath) {\n throw new Error('Root path not found');\n }\n return rootPath;\n};\n\n/**\n * We want to clear coverage files from previous runs, but at this point it is not easy because each\n * worker runs a different instance of this script, so we can't just clear the coverage folder at\n * the beginning of the test run.\n *\n * The solution is to remove the coverage folder when the stored ppid (parent process id) is\n * different from the current one\n */\nconst prepareCoverageReportPath = ({coveragePath}: {coveragePath: string}) => {\n const ppidFile = path.join(coveragePath, '.ppid');\n const ppid = process.ppid.toString();\n if (!fs.existsSync(ppidFile) || fs.readFileSync(ppidFile, 'utf-8') !== ppid) {\n // the condition is just to make sure we don't remove files outside the repo\n if (getRootPath() === process.cwd() && path.normalize(coveragePath).startsWith(process.cwd())) {\n fs.rmSync(coveragePath, {recursive: true, force: true});\n }\n fs.mkdirSync(coveragePath, {recursive: true});\n fs.writeFileSync(ppidFile, ppid);\n }\n};\n\n/**\n * Asumes the code was instrumented with istanbul and the coverage report stored in `window.__coverage__`.\n * If not, this function does nothing.\n */\nexport const collectCoverageIfAvailable = async ({coveragePath}: {coveragePath: string}): Promise<void> => {\n const coverage = await getGlobalPage().evaluate(() => {\n return (window as any).__coverage__;\n });\n if (!coverage) {\n return;\n }\n\n prepareCoverageReportPath({coveragePath});\n const nycOutputPath = path.join(coveragePath, '.nyc_output');\n fs.mkdirSync(nycOutputPath, {recursive: true});\n\n Object.values(coverage).forEach((cov: any) => {\n if (cov && cov.path && cov.hash) {\n fs.writeFileSync(path.join(nycOutputPath, cov.hash + '.json'), JSON.stringify({[cov.path]: cov}));\n }\n });\n};\n","import path from 'path';\nimport fs from 'fs';\nimport findRoot from 'find-root';\nimport type {getQueriesForElement} from 'pptr-testing-library';\nimport {getDocument, queries} from 'pptr-testing-library';\nimport {configureToMatchImageSnapshot} from 'jest-image-snapshot';\nimport globToRegExp from 'glob-to-regexp';\nimport {execSync} from 'child_process';\nimport {collectCoverageIfAvailable} from './coverage';\n\nimport type {\n Browser,\n ClickOptions,\n ElementHandle,\n GeolocationOptions,\n HTTPRequest,\n Page,\n ResponseForRequest,\n ScreenshotOptions,\n Viewport,\n} from 'puppeteer';\n\ntype CustomScreenshotOptions = ScreenshotOptions & {\n skipNetworkWait?: boolean;\n};\n\nexport const getGlobalBrowser = (): Browser => (global as any).browser;\nexport const getGlobalPage = (): Page => (global as any).page;\n\nconst isCi = process.argv.includes('--ci') || process.env.CI;\nconst isUsingDockerizedChromium = isCi || new URL(getGlobalBrowser().wsEndpoint()).port === '9223';\n\nexport const serverHostName = ((): string => {\n if (isCi) {\n return 'localhost';\n }\n\n if (isUsingDockerizedChromium) {\n return process.platform === 'linux' ? '172.17.0.1' : 'host.docker.internal';\n }\n\n return 'localhost';\n})();\n\nconst rootDir = findRoot(process.cwd());\nconst pkg = JSON.parse(fs.readFileSync(path.join(rootDir, 'package.json'), 'utf-8'));\nconst projectConfig = pkg.acceptanceTests ?? {};\nconst server = (isCi ? projectConfig.ciServer : projectConfig.devServer) ?? projectConfig.server;\nconst coveragePath = path.join(rootDir, projectConfig.coveragePath ?? 'reports/coverage-acceptance');\n\nexport const serverPort = server?.port;\n\nconst toMatchImageSnapshot = configureToMatchImageSnapshot({\n failureThreshold: 0,\n failureThresholdType: 'percent',\n customSnapshotIdentifier: ({defaultIdentifier}) => defaultIdentifier,\n});\n\nlet calledToMatchImageSnapshotOutsideDocker = false;\n\nconst localToMatchImageSnapshot = () => {\n calledToMatchImageSnapshotOutsideDocker = true;\n // let the expectation pass, then fail in afterEach. This way we allow developers to debug screenshot tests in local\n // but don't allow them to save screenshots taken outside the dockerized chromium\n return {\n message: () => '',\n pass: true,\n };\n};\n\nexpect.extend({\n toMatchImageSnapshot: isUsingDockerizedChromium ? toMatchImageSnapshot : localToMatchImageSnapshot,\n});\n\nafterEach(() => {\n if (calledToMatchImageSnapshotOutsideDocker) {\n const error = new Error(\n `Calling .toMatchImageSnapshot() is not allowed outside dockerized browser. Please, run your screenshot test in headless mode.`\n );\n error.stack = (error.stack || '').split('\\n')[0];\n throw error;\n }\n});\n\ntype WaitForPaintEndOptions = {\n fullPage?: boolean;\n captureBeyondViewport?: boolean;\n};\n\nconst waitForPaintEnd = async (\n element: ElementHandle | Page,\n {fullPage = true, captureBeyondViewport}: WaitForPaintEndOptions = {}\n) => {\n const MAX_WAIT = 15000;\n const STEP_TIME = 250;\n const t0 = Date.now();\n\n let buf1 = (await element.screenshot(\n normalizeSreenshotOptions({fullPage, captureBeyondViewport})\n )) as Buffer;\n await new Promise((r) => setTimeout(r, STEP_TIME));\n let buf2 = (await element.screenshot(\n normalizeSreenshotOptions({fullPage, captureBeyondViewport})\n )) as Buffer;\n\n // buffers are different if compare != 0\n while (buf1.compare(buf2)) {\n if (Date.now() - t0 > MAX_WAIT) {\n throw Error('Paint end timeout');\n }\n buf1 = buf2;\n await new Promise((r) => setTimeout(r, STEP_TIME));\n buf2 = (await element.screenshot(\n normalizeSreenshotOptions({fullPage, captureBeyondViewport})\n )) as Buffer;\n }\n};\n\nexport interface PageApi extends Omit<Page, 'click' | 'type' | 'select'> {\n clear: (selector: ElementHandle) => Promise<void>;\n // These are overridden:\n type: (selector: ElementHandle, text: string, options?: {delay: number}) => Promise<void>;\n click: (selector: ElementHandle, options?: ClickOptions) => Promise<void>;\n select: (selector: ElementHandle, ...values: string[]) => Promise<string[]>;\n screenshot: (options?: CustomScreenshotOptions) => Promise<Buffer | string | void>;\n}\n\nconst normalizeSreenshotOptions = ({captureBeyondViewport = false, ...options}: ScreenshotOptions = {}) => {\n // Puppeter default for captureBeyondViewport is true, but we think false is a better default.\n // When this is true, the fixed elements (like fixed footers) are relative to the original page\n // viewport, not to the full page, so those elements look weird in fullPage screenshots.\n return {...options, captureBeyondViewport};\n};\n\n// Puppeteer already calls scrollIntoViewIfNeeded before clicking an element. But it doesn't work in all situations\n// For example, when there is a fixed footer in the page and the element to click is under it, the browser won't scroll\n// because the element is already in the viewport (the ifNeeded part is important here). By forcing the scroll to the\n// center, we manage to fix these edge cases.\nconst scrollIntoView = (el: ElementHandle) => el.evaluate((e) => e.scrollIntoView({block: 'center'}));\n\nexport const getPageApi = (page: Page): PageApi => {\n const api: PageApi = Object.create(page);\n\n api.type = async (elementHandle, text, options) => {\n await scrollIntoView(elementHandle);\n return elementHandle.type(text, options);\n };\n api.click = async (elementHandle, options) => {\n await scrollIntoView(elementHandle);\n return elementHandle.click(options);\n };\n api.select = async (elementHandle, ...values) => {\n await scrollIntoView(elementHandle);\n return elementHandle.select(...values);\n };\n\n api.screenshot = async (options?: CustomScreenshotOptions) => {\n if (!options?.skipNetworkWait) {\n await page.waitForNetworkIdle();\n }\n await waitForPaintEnd(page, options);\n return page.screenshot(normalizeSreenshotOptions(options));\n };\n\n api.clear = async (elementHandle) => {\n await elementHandle.click({clickCount: 3});\n await elementHandle.press('Delete');\n };\n\n // For some reason, puppeteer browserContext.overridePermissions doesn't work with newer chrome versions.\n // This workaround polyfills the browser geolocation api to return the mocked position\n api.setGeolocation = (position: GeolocationOptions) =>\n page.evaluate((position) => {\n window.navigator.geolocation.getCurrentPosition = (callback) => {\n // @ts-expect-error - puppeteer's setGeoLocation does not expect a timestamp to be passed\n callback({\n coords: position,\n });\n };\n }, position as any);\n\n return api;\n};\n\nlet needsRequestInterception = false;\ntype RequestMatcherFn = (req: HTTPRequest) => boolean;\nlet requestHandlers: Array<{\n matcher: RequestMatcherFn;\n handler: jest.Mock<any, any>;\n}> = [];\n\nconst requestInterceptor = (req: HTTPRequest) => {\n const {handler} = requestHandlers.find(({matcher}) => matcher(req)) ?? {handler: null};\n if (!handler) {\n req.continue();\n return;\n }\n const response = handler(req);\n req.respond(response);\n};\n\nexport const interceptRequest = (\n matcher: RequestMatcherFn\n): jest.Mock<Partial<ResponseForRequest>, [HTTPRequest]> => {\n needsRequestInterception = true;\n const spy = jest.fn();\n requestHandlers.push({matcher, handler: spy});\n return spy;\n};\n\ntype ApiEndpointMock = {\n spyOn(path: string, method?: string): jest.Mock<unknown, [HTTPRequest]>;\n};\n\nexport const createApiEndpointMock = ({\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(path: string, method: string = 'GET') {\n const matcher = (req: HTTPRequest) => {\n const {pathname, origin} = new URL(req.url());\n return (\n req.method() === method &&\n !!origin.match(originRegExp) &&\n !!pathname.match(globToRegExp(path))\n );\n };\n\n const spy = jest.fn();\n\n interceptRequest(matcher).mockImplementation((req) => {\n const spyResult = spy(req);\n const status = spyResult.status ?? 200;\n const resBody = spyResult.body || spyResult;\n return {\n status,\n headers: {\n 'Access-Control-Allow-Origin': '*',\n },\n contentType: 'application/json',\n body: JSON.stringify(resBody),\n };\n });\n\n return spy;\n },\n };\n};\n\ntype CookieConfig = {\n name: string;\n value: string;\n url?: string;\n domain?: string;\n path?: string;\n secure?: boolean;\n httpOnly?: boolean;\n sameSite?: 'Strict' | 'Lax' | 'None';\n expires?: number;\n priority?: 'Low' | 'Medium' | 'High';\n sameParty?: boolean;\n sourceScheme?: 'Unset' | 'NonSecure' | 'Secure';\n sourcePort?: number;\n};\n\nexport interface TestViewport extends Viewport {\n safeAreaInset?: {\n top?: number | string;\n right?: number | string;\n bottom?: number | string;\n left?: number | string;\n };\n}\n\ninterface OpenPageCommonConfig {\n userAgent?: string;\n viewport?: TestViewport;\n isDarkMode?: boolean;\n cookies?: Array<CookieConfig>;\n}\n\ninterface OpenPageUrlConfig extends OpenPageCommonConfig {\n url: string;\n}\n\ninterface OpenPagePathConfig extends OpenPageCommonConfig {\n url?: undefined;\n\n path?: string;\n port?: number;\n protocol?: string;\n hostname?: string;\n}\n\ntype OpenPageConfig = OpenPageUrlConfig | OpenPagePathConfig;\n\nexport const openPage = async ({\n userAgent,\n isDarkMode,\n viewport,\n cookies,\n ...urlConfig\n}: OpenPageConfig): Promise<PageApi> => {\n const url = ((): string => {\n if (urlConfig.url !== undefined) {\n return urlConfig.url;\n }\n\n const {path = '/', port = serverPort, protocol = 'http', hostname = serverHostName} = urlConfig;\n\n if (!port) {\n // Error.captureStackTrace(error, openPage);\n throw new Error(\n 'You must specify a port. You can specify it when calling openPage() or by configuring a dev and ci server in the acceptanceTests config in your package.json'\n );\n }\n\n return `${protocol}://${hostname}:${port}${path}`;\n })();\n\n const currentUserAgent = userAgent || (await getGlobalBrowser().userAgent());\n const page = getGlobalPage();\n\n await page.bringToFront();\n if (viewport) {\n await page.setViewport(viewport);\n }\n if (cookies) {\n await page.setCookie(...cookies);\n }\n await page.setUserAgent(`${currentUserAgent} acceptance-test`);\n await page.emulateMediaFeatures([{name: 'prefers-color-scheme', value: isDarkMode ? 'dark' : 'light'}]);\n\n // A set of styles to make screenshot tests more reliable.\n await page.evaluateOnNewDocument((viewport: TestViewport) => {\n const overriddenSafeAreaInsets = !viewport\n ? []\n : Object.keys(viewport?.safeAreaInset ?? {}).map((key) => {\n const position = key as 'top' | 'right' | 'bottom' | 'left';\n return `--acceptance-test-override-safe-area-inset-${key}: ${viewport?.safeAreaInset?.[position]};`;\n });\n\n const style = document.createElement('style');\n style.innerHTML = `\n *, *:after, *:before {\n transition-delay: 0s !important;\n transition-duration: 0s !important;\n animation-delay: -0.0001s !important;\n animation-duration: 0s !important;\n animation-play-state: paused !important;\n caret-color: transparent !important;\n font-variant-ligatures: none !important;\n }\n *::-webkit-scrollbar {\n display: none !important;\n width: 0 !important;\n height: 0 !important;\n }\n :root {\n ${overriddenSafeAreaInsets.join('\\n')}\n }\n `;\n window.addEventListener('DOMContentLoaded', () => {\n document.head.appendChild(style);\n });\n }, viewport);\n\n if (needsRequestInterception) {\n await page.setRequestInterception(true);\n page.on('request', requestInterceptor);\n }\n\n try {\n await page.goto(url);\n } catch (e) {\n if ((e as Error).message.includes('net::ERR_CONNECTION_REFUSED')) {\n const connectionError = new Error(`Could not connect to ${url}. Is the server running?`);\n Error.captureStackTrace(connectionError, openPage);\n throw connectionError;\n } else {\n throw e;\n }\n }\n await page.waitForFunction('document.fonts.status === \"loaded\"');\n\n return getPageApi(page);\n};\n\nconst buildQueryMethods = ({page, element}: {page?: Page; element?: ElementHandle} = {}): ReturnType<\n typeof getQueriesForElement\n> => {\n const boundQueries: any = {};\n for (const [queryName, queryFn] of Object.entries(queries)) {\n boundQueries[queryName] = async (...args: any) => {\n const doc = await getDocument(page ?? getGlobalPage());\n const body = await doc.$('body');\n const queryArgs = [...args];\n if (queryName.startsWith('findBy')) {\n if (queryArgs.length === 1) {\n queryArgs.push(undefined);\n }\n queryArgs.push({timeout: 10000});\n }\n const elementHandle: ElementHandle = await queryFn(element ?? body, ...queryArgs);\n\n const newElementHandle = Object.create(elementHandle);\n\n newElementHandle.screenshot = async (options: CustomScreenshotOptions) => {\n if (!options?.skipNetworkWait) {\n await (page ?? getGlobalPage()).waitForNetworkIdle();\n }\n await waitForPaintEnd(elementHandle, {...options, fullPage: false});\n return elementHandle.screenshot(normalizeSreenshotOptions(options));\n };\n\n newElementHandle.click = async (options?: ClickOptions) => {\n await scrollIntoView(elementHandle);\n return elementHandle.click(options);\n };\n\n newElementHandle.type = async (text: string, options?: {delay: number}) => {\n await scrollIntoView(elementHandle);\n return elementHandle.type(text, options);\n };\n\n newElementHandle.select = async (...values: Array<string>) => {\n await scrollIntoView(elementHandle);\n return elementHandle.select(...values);\n };\n\n return newElementHandle;\n };\n }\n return boundQueries;\n};\n\nexport const getScreen = (page: Page) => buildQueryMethods({page});\n\nexport const screen = buildQueryMethods();\n\nexport const within = (element: ElementHandle) => buildQueryMethods({element});\n\nexport type {ElementHandle, Viewport} from 'puppeteer';\n\nbeforeEach(async () => {\n await getGlobalPage().setRequestInterception(false);\n\n // by resetting the page we clean up all the evaluateOnNewDocument calls, which are persistent between documents\n await (global as any).jestPuppeteer.resetPage();\n});\n\nafterEach(async () => {\n await collectCoverageIfAvailable({coveragePath});\n\n try {\n const page = getGlobalPage();\n requestHandlers = [];\n needsRequestInterception = false;\n page.off('request', requestInterceptor);\n\n // clear tab, this way we clear the DOM and stop js execution or pending requests\n await page.goto('about:blank');\n } catch (e) {\n // ignore, at this point page might be destroyed\n }\n});\n\n/**\n * Returns a new path to the file that can be used by chromium in acceptance tests\n *\n * To be able to use `element.uploadFile()` in a dockerized chromium, the file must exist in the\n * host and the docker, and both sides must use the same path.\n *\n * To workaround this bug or limitation, this function prepares the file by copying it to /tmp in\n * the host and the container.\n */\nexport const prepareFile = (filepath: string): string => {\n const isLocal = !isCi;\n const isHeadless = !!process.env.HEADLESS;\n const usesDocker = isLocal && isHeadless;\n\n const dockerComposeFile = path.join(__dirname, '..', 'docker-compose.yaml');\n\n if (usesDocker) {\n const containerId = execSync(`docker-compose -f ${dockerComposeFile} ps -q`).toString().trim();\n\n if (!containerId) {\n throw Error('acceptance-testing container not found');\n }\n\n execSync(`docker cp ${filepath} ${containerId}:/tmp`);\n\n const newPath = path.join('/tmp', path.basename(filepath));\n\n fs.copyFileSync(filepath, newPath);\n\n return newPath;\n } else {\n return filepath;\n }\n};\n\n/**\n * A convenience method to defer an expectation\n */\nexport const wait = <T>(expectation: () => Promise<T> | T, timeout = 10000, interval = 50): Promise<T> => {\n const startTime = Date.now();\n const startStack = new Error().stack;\n\n return new Promise((resolve, reject) => {\n const rejectOrRerun = (error: unknown) => {\n if (Date.now() - startTime >= timeout) {\n if (error instanceof Error) {\n if (error.message === 'Element not removed') {\n error.stack = startStack;\n }\n }\n reject(error);\n return;\n }\n // eslint-disable-next-line @typescript-eslint/no-use-before-define\n setTimeout(runExpectation, interval);\n };\n const runExpectation = () => {\n try {\n Promise.resolve(expectation())\n .then((r) => resolve(r))\n .catch(rejectOrRerun);\n } catch (error) {\n rejectOrRerun(error);\n }\n };\n setTimeout(runExpectation, 0);\n });\n};\n\nexport const waitForElementToBeRemoved = (\n element: ElementHandle<Element>,\n timeout = 10000,\n interval = 100\n): Promise<void> => {\n const startStack = new Error().stack;\n\n const wait = async () => {\n const t0 = Date.now();\n while (Date.now() - t0 < timeout) {\n // boundingBox returns null when the element is not in the DOM\n const box = await element.boundingBox();\n if (!box) {\n return;\n }\n await new Promise((resolve) => setTimeout(resolve, interval));\n }\n throw new Error('Element not removed');\n };\n\n return wait().catch((error) => {\n if (error.message === 'Element not removed') {\n error.stack = startStack;\n }\n throw error;\n });\n};\n"],"names":["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","getGlobalBrowser","browser","isCi","argv","includes","env","CI","isUsingDockerizedChromium","URL","wsEndpoint","port","serverHostName","platform","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","split","waitForPaintEnd","element","_temp","_ref4","_ref4$fullPage","fullPage","captureBeyondViewport","MAX_WAIT","STEP_TIME","t0","buf1","buf2","Date","now","screenshot","normalizeSreenshotOptions","Promise","r","setTimeout","compare","_x2","_temp2","_ref5$captureBeyondVi","_ref5","options","_objectWithoutPropertiesLoose","_excluded","_extends","scrollIntoView","el","e","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","globToRegExp","_ref14","_URL","url","method","match","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","map","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","execSync","trim","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/index.d.ts CHANGED
@@ -24,10 +24,10 @@ export declare const interceptRequest: (matcher: RequestMatcherFn) => jest.Mock<
24
24
  declare type ApiEndpointMock = {
25
25
  spyOn(path: string, method?: string): jest.Mock<unknown, [HTTPRequest]>;
26
26
  };
27
- export declare const createApiEndpointMock: ({ origin, baseUrl, }: {
28
- origin: string;
27
+ export declare const createApiEndpointMock: ({ origin, baseUrl, }?: {
28
+ origin?: string | undefined;
29
29
  /** @deprecated use origin */
30
- baseUrl: string;
30
+ baseUrl?: string | undefined;
31
31
  }) => ApiEndpointMock;
32
32
  declare type CookieConfig = {
33
33
  name: string;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@telefonica/acceptance-testing",
3
- "version": "2.22.0-beta0",
3
+ "version": "2.22.0",
4
4
  "author": "Telefonica",
5
5
  "license": "UNLICENSED",
6
6
  "module": "dist/acceptance-testing.esm.js",