testcafe 2.2.0 → 2.3.1

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.
Files changed (93) hide show
  1. package/CHANGELOG.md +82 -0
  2. package/bin/testcafe-with-v8-flag-filter.js +16 -3
  3. package/lib/api/exportable-lib/index.mjs +27 -0
  4. package/lib/api/structure/fixture.js +7 -3
  5. package/lib/api/structure/test.js +8 -3
  6. package/lib/api/structure/testing-unit.js +15 -1
  7. package/lib/api/test-controller/index.js +4 -4
  8. package/lib/browser/connection/gateway.js +13 -1
  9. package/lib/browser/connection/index.js +10 -1
  10. package/lib/browser/connection/service-routes.js +2 -1
  11. package/lib/browser/provider/built-in/dedicated/chrome/index.js +6 -1
  12. package/lib/browser/provider/index.js +4 -1
  13. package/lib/cli/argument-parser/index.js +58 -59
  14. package/lib/cli/cli.js +3 -2
  15. package/lib/client/automation/index.js +90 -4
  16. package/lib/client/automation/index.min.js +1 -1
  17. package/lib/client/browser/idle-page/index.js +7 -5
  18. package/lib/client/core/deps/hammerhead.js +24 -0
  19. package/lib/client/core/index.js +42 -7
  20. package/lib/client/core/index.min.js +1 -1
  21. package/lib/client/core/utils/values/axis-values.js +43 -0
  22. package/lib/client/driver/index.js +336 -211
  23. package/lib/client/driver/index.min.js +1 -1
  24. package/lib/client/test-run/iframe.js.mustache +2 -1
  25. package/lib/client/test-run/index.js.mustache +30 -28
  26. package/lib/client/ui/index.js +33 -23
  27. package/lib/client/ui/index.min.js +1 -1
  28. package/lib/compiler/babel/load-libs.js +10 -9
  29. package/lib/compiler/compilers.js +7 -7
  30. package/lib/compiler/esm-loader.js +38 -0
  31. package/lib/compiler/index.js +8 -7
  32. package/lib/compiler/interfaces.js +1 -1
  33. package/lib/compiler/prevent-module-caching-suffix.js +6 -0
  34. package/lib/compiler/test-file/add-export-api.js +3 -9
  35. package/lib/compiler/test-file/api-based.js +30 -14
  36. package/lib/compiler/test-file/base.js +4 -1
  37. package/lib/compiler/test-file/formats/coffeescript/compiler.js +5 -4
  38. package/lib/compiler/test-file/formats/es-next/compiler.js +21 -11
  39. package/lib/compiler/test-file/formats/extensions.js +15 -0
  40. package/lib/compiler/test-file/formats/typescript/compiler.js +27 -17
  41. package/lib/compiler/test-file/get-exportable-lib-path.js +17 -0
  42. package/lib/configuration/option-names.js +2 -1
  43. package/lib/custom-client-scripts/get-code.js +4 -3
  44. package/lib/custom-client-scripts/routing.js +3 -3
  45. package/lib/errors/is-internal-stack-frame.js +3 -2
  46. package/lib/errors/process-test-fn-error.js +3 -2
  47. package/lib/errors/runtime/index.js +18 -4
  48. package/lib/errors/runtime/templates.js +2 -1
  49. package/lib/errors/test-run/utils.js +8 -3
  50. package/lib/errors/types.js +2 -1
  51. package/lib/proxyless/api-base.js +25 -0
  52. package/lib/proxyless/client/event-simulator.js +40 -0
  53. package/lib/proxyless/client/types.js +11 -0
  54. package/lib/proxyless/client/utils.js +24 -0
  55. package/lib/proxyless/cookie-provider.js +3 -3
  56. package/lib/proxyless/index.js +20 -2
  57. package/lib/proxyless/request-hooks/event-factory/frame-navigated-event-based.js +40 -0
  58. package/lib/proxyless/request-hooks/event-factory/request-paused-event-based.js +95 -0
  59. package/lib/proxyless/request-hooks/event-provider.js +6 -54
  60. package/lib/proxyless/request-pipeline/context-info.js +55 -0
  61. package/lib/proxyless/request-pipeline/index.js +73 -31
  62. package/lib/proxyless/request-pipeline/resendAuthRequest.js +23 -0
  63. package/lib/proxyless/request-pipeline/special-handlers.js +2 -2
  64. package/lib/proxyless/request-pipeline/test-run-bridge.js +45 -0
  65. package/lib/proxyless/resource-injector.js +41 -29
  66. package/lib/proxyless/session-storage/index.js +39 -0
  67. package/lib/proxyless/storages-provider.js +17 -0
  68. package/lib/proxyless/types.js +8 -1
  69. package/lib/proxyless/utils/cdp.js +29 -2
  70. package/lib/proxyless/utils/get-active-client.js +8 -0
  71. package/lib/runner/bootstrapper.js +3 -2
  72. package/lib/runner/browser-job.js +1 -1
  73. package/lib/runner/task/index.js +2 -2
  74. package/lib/services/compiler/service.js +4 -4
  75. package/lib/services/utils/ipc/interfaces.js +1 -1
  76. package/lib/services/utils/ipc/proxy.js +1 -4
  77. package/lib/shared/utils/is-file-protocol.js +9 -0
  78. package/lib/test-run/commands/actions.js +2 -2
  79. package/lib/test-run/index.js +21 -6
  80. package/lib/test-run/request/send.js +20 -13
  81. package/lib/test-run/storages/base.js +16 -0
  82. package/lib/test-run/storages/factory.js +12 -0
  83. package/lib/testcafe.js +3 -3
  84. package/lib/utils/async-event-emitter.js +1 -1
  85. package/lib/utils/convert-to-best-fit-type.js +1 -1
  86. package/lib/utils/get-options/base.js +1 -1
  87. package/lib/utils/setup-sourcemap-support.js +10 -4
  88. package/package.json +13 -8
  89. package/ts-defs/index.d.ts +4 -4
  90. package/ts-defs/selectors.d.ts +2 -2
  91. package/ts-defs/testcafe-scripts.d.ts +2 -2
  92. package/lib/compiler/test-file/exportble-lib-path.js +0 -7
  93. package/lib/proxyless/request-hooks/event-factory.js +0 -95
@@ -0,0 +1,45 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const connection_1 = __importDefault(require("../../browser/connection"));
7
+ class TestRunBridge {
8
+ constructor(browserId) {
9
+ this._browserId = browserId;
10
+ }
11
+ getBrowserConnection() {
12
+ return connection_1.default.getById(this._browserId);
13
+ }
14
+ getCurrentTestRun() {
15
+ const browserConnection = this.getBrowserConnection();
16
+ return browserConnection.getCurrentTestRun();
17
+ }
18
+ getSessionId() {
19
+ var _a;
20
+ return ((_a = this.getCurrentTestRun()) === null || _a === void 0 ? void 0 : _a.id) || '';
21
+ }
22
+ getUserScripts() {
23
+ const currentTestRun = this.getCurrentTestRun();
24
+ if (!currentTestRun)
25
+ return [];
26
+ return currentTestRun.injectable.userScripts;
27
+ }
28
+ async getTaskScript({ isIframe }) {
29
+ const browserConnection = this.getBrowserConnection();
30
+ const proxy = browserConnection.browserConnectionGateway.proxy;
31
+ const windowId = browserConnection.activeWindowId;
32
+ // @ts-ignore
33
+ return await this.getCurrentTestRun().session.getTaskScript({
34
+ referer: '',
35
+ cookieUrl: '',
36
+ withPayload: true,
37
+ serverInfo: proxy.server1Info,
38
+ windowId,
39
+ isIframe,
40
+ });
41
+ }
42
+ }
43
+ exports.default = TestRunBridge;
44
+ module.exports = exports.default;
45
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVzdC1ydW4tYnJpZGdlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3Byb3h5bGVzcy9yZXF1ZXN0LXBpcGVsaW5lL3Rlc3QtcnVuLWJyaWRnZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUNBLDBFQUF5RDtBQUl6RCxNQUFxQixhQUFhO0lBRTlCLFlBQW9CLFNBQWlCO1FBQ2pDLElBQUksQ0FBQyxVQUFVLEdBQUcsU0FBUyxDQUFDO0lBQ2hDLENBQUM7SUFFTSxvQkFBb0I7UUFDdkIsT0FBTyxvQkFBaUIsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBc0IsQ0FBQztJQUMzRSxDQUFDO0lBRU0saUJBQWlCO1FBQ3BCLE1BQU0saUJBQWlCLEdBQUcsSUFBSSxDQUFDLG9CQUFvQixFQUFFLENBQUM7UUFFdEQsT0FBTyxpQkFBaUIsQ0FBQyxpQkFBaUIsRUFBRSxDQUFDO0lBQ2pELENBQUM7SUFFTSxZQUFZOztRQUNmLE9BQU8sQ0FBQSxNQUFBLElBQUksQ0FBQyxpQkFBaUIsRUFBRSwwQ0FBRSxFQUFFLEtBQUksRUFBRSxDQUFDO0lBQzlDLENBQUM7SUFFTSxjQUFjO1FBQ2pCLE1BQU0sY0FBYyxHQUFHLElBQUksQ0FBQyxpQkFBaUIsRUFBRSxDQUFDO1FBRWhELElBQUksQ0FBQyxjQUFjO1lBQ2YsT0FBTyxFQUFFLENBQUM7UUFFZCxPQUFPLGNBQWMsQ0FBQyxVQUFVLENBQUMsV0FBVyxDQUFDO0lBQ2pELENBQUM7SUFFTSxLQUFLLENBQUMsYUFBYSxDQUFFLEVBQUUsUUFBUSxFQUE4QjtRQUNoRSxNQUFNLGlCQUFpQixHQUFHLElBQUksQ0FBQyxvQkFBb0IsRUFBRSxDQUFDO1FBQ3RELE1BQU0sS0FBSyxHQUFlLGlCQUFpQixDQUFDLHdCQUF3QixDQUFDLEtBQUssQ0FBQztRQUMzRSxNQUFNLFFBQVEsR0FBWSxpQkFBaUIsQ0FBQyxjQUFjLENBQUM7UUFFM0QsYUFBYTtRQUNiLE9BQU8sTUFBTSxJQUFJLENBQUMsaUJBQWlCLEVBQUUsQ0FBQyxPQUFPLENBQUMsYUFBYSxDQUFDO1lBQ3hELE9BQU8sRUFBTSxFQUFFO1lBQ2YsU0FBUyxFQUFJLEVBQUU7WUFDZixXQUFXLEVBQUUsSUFBSTtZQUNqQixVQUFVLEVBQUcsS0FBSyxDQUFDLFdBQVc7WUFDOUIsUUFBUTtZQUNSLFFBQVE7U0FDWCxDQUFDLENBQUM7SUFDUCxDQUFDO0NBQ0o7QUE1Q0QsZ0NBNENDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFRlc3RSdW4gZnJvbSAnLi4vLi4vdGVzdC1ydW4nO1xuaW1wb3J0IEJyb3dzZXJDb25uZWN0aW9uIGZyb20gJy4uLy4uL2Jyb3dzZXIvY29ubmVjdGlvbic7XG5pbXBvcnQgeyBVc2VyU2NyaXB0IH0gZnJvbSAndGVzdGNhZmUtaGFtbWVyaGVhZCc7XG5pbXBvcnQgeyBJbmplY3RhYmxlUmVzb3VyY2VzT3B0aW9ucyB9IGZyb20gJy4uL3R5cGVzJztcblxuZXhwb3J0IGRlZmF1bHQgY2xhc3MgVGVzdFJ1bkJyaWRnZSB7XG4gICAgcHJpdmF0ZSByZWFkb25seSBfYnJvd3NlcklkOiBzdHJpbmc7XG4gICAgcHVibGljIGNvbnN0cnVjdG9yIChicm93c2VySWQ6IHN0cmluZykge1xuICAgICAgICB0aGlzLl9icm93c2VySWQgPSBicm93c2VySWQ7XG4gICAgfVxuXG4gICAgcHVibGljIGdldEJyb3dzZXJDb25uZWN0aW9uICgpOiBCcm93c2VyQ29ubmVjdGlvbiB7XG4gICAgICAgIHJldHVybiBCcm93c2VyQ29ubmVjdGlvbi5nZXRCeUlkKHRoaXMuX2Jyb3dzZXJJZCkgYXMgQnJvd3NlckNvbm5lY3Rpb247XG4gICAgfVxuXG4gICAgcHVibGljIGdldEN1cnJlbnRUZXN0UnVuICgpOiBUZXN0UnVuIHtcbiAgICAgICAgY29uc3QgYnJvd3NlckNvbm5lY3Rpb24gPSB0aGlzLmdldEJyb3dzZXJDb25uZWN0aW9uKCk7XG5cbiAgICAgICAgcmV0dXJuIGJyb3dzZXJDb25uZWN0aW9uLmdldEN1cnJlbnRUZXN0UnVuKCk7XG4gICAgfVxuXG4gICAgcHVibGljIGdldFNlc3Npb25JZCAoKTogc3RyaW5nIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuZ2V0Q3VycmVudFRlc3RSdW4oKT8uaWQgfHwgJyc7XG4gICAgfVxuXG4gICAgcHVibGljIGdldFVzZXJTY3JpcHRzICgpOiBVc2VyU2NyaXB0W10ge1xuICAgICAgICBjb25zdCBjdXJyZW50VGVzdFJ1biA9IHRoaXMuZ2V0Q3VycmVudFRlc3RSdW4oKTtcblxuICAgICAgICBpZiAoIWN1cnJlbnRUZXN0UnVuKVxuICAgICAgICAgICAgcmV0dXJuIFtdO1xuXG4gICAgICAgIHJldHVybiBjdXJyZW50VGVzdFJ1bi5pbmplY3RhYmxlLnVzZXJTY3JpcHRzO1xuICAgIH1cblxuICAgIHB1YmxpYyBhc3luYyBnZXRUYXNrU2NyaXB0ICh7IGlzSWZyYW1lIH06IEluamVjdGFibGVSZXNvdXJjZXNPcHRpb25zKTogUHJvbWlzZTxzdHJpbmc+IHtcbiAgICAgICAgY29uc3QgYnJvd3NlckNvbm5lY3Rpb24gPSB0aGlzLmdldEJyb3dzZXJDb25uZWN0aW9uKCk7XG4gICAgICAgIGNvbnN0IHByb3h5ICAgICAgICAgICAgID0gYnJvd3NlckNvbm5lY3Rpb24uYnJvd3NlckNvbm5lY3Rpb25HYXRld2F5LnByb3h5O1xuICAgICAgICBjb25zdCB3aW5kb3dJZCAgICAgICAgICA9IGJyb3dzZXJDb25uZWN0aW9uLmFjdGl2ZVdpbmRvd0lkO1xuXG4gICAgICAgIC8vIEB0cy1pZ25vcmVcbiAgICAgICAgcmV0dXJuIGF3YWl0IHRoaXMuZ2V0Q3VycmVudFRlc3RSdW4oKS5zZXNzaW9uLmdldFRhc2tTY3JpcHQoe1xuICAgICAgICAgICAgcmVmZXJlcjogICAgICcnLFxuICAgICAgICAgICAgY29va2llVXJsOiAgICcnLFxuICAgICAgICAgICAgd2l0aFBheWxvYWQ6IHRydWUsXG4gICAgICAgICAgICBzZXJ2ZXJJbmZvOiAgcHJveHkuc2VydmVyMUluZm8sXG4gICAgICAgICAgICB3aW5kb3dJZCxcbiAgICAgICAgICAgIGlzSWZyYW1lLFxuICAgICAgICB9KTtcbiAgICB9XG59XG4iXX0=
@@ -4,7 +4,6 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
4
4
  };
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
6
  const testcafe_hammerhead_1 = require("testcafe-hammerhead");
7
- const connection_1 = __importDefault(require("../browser/connection"));
8
7
  const injectables_1 = require("../assets/injectables");
9
8
  const empty_page_markup_1 = __importDefault(require("./empty-page-markup"));
10
9
  const http_status_codes_1 = require("http-status-codes");
@@ -19,31 +18,43 @@ const RESPONSE_REMOVED_HEADERS = [
19
18
  'cross-origin-resource-policy',
20
19
  ];
21
20
  class ResourceInjector {
22
- constructor(browserId, specialServiceRoutes) {
23
- this._browserId = browserId;
21
+ constructor(testRunBridge, specialServiceRoutes) {
24
22
  this._specialServiceRoutes = specialServiceRoutes;
23
+ this._testRunBridge = testRunBridge;
25
24
  }
26
- get _browserConnection() {
27
- return connection_1.default.getById(this._browserId);
25
+ _getRestoreContextStorageScript(contextStorage) {
26
+ const currentTestRun = this._testRunBridge.getCurrentTestRun();
27
+ const value = JSON.stringify((contextStorage === null || contextStorage === void 0 ? void 0 : contextStorage[currentTestRun.id]) || '');
28
+ return `Object.defineProperty(window, '%proxylessContextStorage%', { configurable: true, value: ${value} });`;
28
29
  }
29
- get _currentTestRun() {
30
- return this._browserConnection.getCurrentTestRun();
30
+ _getRestoreStoragesScript(restoringStorages) {
31
+ if (!restoringStorages)
32
+ return '(function() {})()';
33
+ return `(function() {
34
+ window.localStorage.clear();
35
+ window.sessionStorage.clear();
36
+
37
+ const snapshot = ${JSON.stringify(restoringStorages)};
38
+ const ls = JSON.parse(snapshot.localStorage);
39
+ const ss = JSON.parse(snapshot.sessionStorage);
40
+
41
+ for (let i = 0; i < ls[0].length; i++)
42
+ window.localStorage.setItem(ls[0][i], ls[1][i]);
43
+
44
+ for (let i = 0; i < ss[0].length; i++)
45
+ window.sessionStorage.setItem(ss[0][i], ss[1][i]);
46
+ })();
47
+ `;
31
48
  }
32
- async _prepareInjectableResources({ isIframe, restoringStorages }) {
33
- const proxy = this._browserConnection.browserConnectionGateway.proxy;
34
- const windowId = this._browserConnection.activeWindowId;
35
- if (!this._currentTestRun)
49
+ _resolveRelativeUrls(proxy, relativeUrls) {
50
+ return relativeUrls.map(url => proxy.resolveRelativeServiceUrl(url));
51
+ }
52
+ async _prepareInjectableResources({ isIframe, restoringStorages, contextStorage, userScripts }) {
53
+ if (!this._testRunBridge.getCurrentTestRun())
36
54
  return null;
37
- const taskScript = await this._currentTestRun.session.getTaskScript({
38
- referer: '',
39
- cookieUrl: '',
40
- withPayload: true,
41
- serverInfo: proxy.server1Info,
42
- windowId,
43
- isIframe,
44
- });
55
+ const taskScript = await this._testRunBridge.getTaskScript({ isIframe, restoringStorages, contextStorage, userScripts });
56
+ const proxy = this._testRunBridge.getBrowserConnection().browserConnectionGateway.proxy;
45
57
  const injectableResources = {
46
- storages: restoringStorages,
47
58
  stylesheets: [
48
59
  injectables_1.TESTCAFE_UI_STYLES,
49
60
  ],
@@ -51,10 +62,12 @@ class ResourceInjector {
51
62
  ...testcafe_hammerhead_1.INJECTABLE_SCRIPTS.map(hs => (0, testcafe_hammerhead_1.getAssetPath)(hs, proxy.options.developmentMode)),
52
63
  ...injectables_1.SCRIPTS.map(s => (0, testcafe_hammerhead_1.getAssetPath)(s, proxy.options.developmentMode)),
53
64
  ],
54
- embeddedScripts: [taskScript],
65
+ embeddedScripts: [this._getRestoreStoragesScript(restoringStorages), this._getRestoreContextStorageScript(contextStorage), taskScript],
66
+ userScripts: userScripts || [],
55
67
  };
56
- injectableResources.scripts = injectableResources.scripts.map(script => proxy.resolveRelativeServiceUrl(script));
57
- injectableResources.stylesheets = injectableResources.stylesheets.map(style => proxy.resolveRelativeServiceUrl(style));
68
+ injectableResources.scripts = this._resolveRelativeUrls(proxy, injectableResources.scripts);
69
+ injectableResources.userScripts = this._resolveRelativeUrls(proxy, injectableResources.userScripts);
70
+ injectableResources.stylesheets = this._resolveRelativeUrls(proxy, injectableResources.stylesheets);
58
71
  return injectableResources;
59
72
  }
60
73
  _processResponseHeaders(headers) {
@@ -73,8 +86,7 @@ class ResourceInjector {
73
86
  });
74
87
  }
75
88
  async redirectToErrorPage(client, err, url) {
76
- const browserConnection = connection_1.default.getById(this._browserId);
77
- const currentTestRun = browserConnection.getCurrentTestRun();
89
+ const currentTestRun = this._testRunBridge.getCurrentTestRun();
78
90
  if (!currentTestRun)
79
91
  return;
80
92
  currentTestRun.pendingPageError = new test_run_1.PageLoadError(err, url);
@@ -111,9 +123,9 @@ class ResourceInjector {
111
123
  };
112
124
  }
113
125
  }
114
- async processAboutBlankPage(event, client) {
126
+ async processAboutBlankPage(event, userScripts, client) {
115
127
  (0, debug_loggers_1.resourceInjectorLogger)('Handle page as about:blank. Origin url: %s', event.frame.url);
116
- const injectableResources = await this._prepareInjectableResources({ isIframe: false });
128
+ const injectableResources = await this._prepareInjectableResources({ isIframe: false, userScripts });
117
129
  const html = (0, testcafe_hammerhead_1.injectResources)(empty_page_markup_1.default, injectableResources);
118
130
  await client.Page.setDocumentContent({
119
131
  frameId: event.frame.id,
@@ -139,7 +151,7 @@ class ResourceInjector {
139
151
  if (url && restoringStorages) {
140
152
  return {
141
153
  host: new URL(url).host,
142
- sessionId: this._currentTestRun.session.id,
154
+ sessionId: this._testRunBridge.getSessionId(),
143
155
  };
144
156
  }
145
157
  return void 0;
@@ -147,4 +159,4 @@ class ResourceInjector {
147
159
  }
148
160
  exports.default = ResourceInjector;
149
161
  module.exports = exports.default;
150
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resource-injector.js","sourceRoot":"","sources":["../../src/proxyless/resource-injector.ts"],"names":[],"mappings":"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","sourcesContent":["import { ProtocolApi } from 'chrome-remote-interface';\n// @ts-ignore\nimport { TestRun as LegacyTestRun } from 'testcafe-legacy-api';\nimport Protocol from 'devtools-protocol';\nimport RequestPausedEvent = Protocol.Fetch.RequestPausedEvent;\nimport FrameNavigatedEvent = Protocol.Page.FrameNavigatedEvent;\nimport FulfillRequestRequest = Protocol.Fetch.FulfillRequestRequest;\nimport HeaderEntry = Protocol.Fetch.HeaderEntry;\nimport {\n    injectResources,\n    PageInjectableResources,\n    INJECTABLE_SCRIPTS as HAMMERHEAD_INJECTABLE_SCRIPTS,\n    getAssetPath,\n    PageRestoreStoragesOptions,\n} from 'testcafe-hammerhead';\nimport BrowserConnection from '../browser/connection';\nimport { SCRIPTS, TESTCAFE_UI_STYLES } from '../assets/injectables';\nimport EMPTY_PAGE_MARKUP from './empty-page-markup';\nimport { StatusCodes } from 'http-status-codes';\nimport { PageLoadError } from '../errors/test-run';\nimport { redirect, navigateTo } from './utils/cdp';\n\nimport {\n    DocumentResourceInfo,\n    InjectableResourcesOptions,\n    SpecialServiceRoutes,\n} from './types';\n\nimport { resourceInjectorLogger } from '../utils/debug-loggers';\nimport {\n    getResponseAsString,\n    stringifyHeaderValues,\n    toBase64String,\n} from './utils/string';\nimport { safeFulfillRequest } from './request-pipeline/safe-api';\nimport TestRun from '../test-run';\n\nconst RESPONSE_REMOVED_HEADERS = [\n    'cross-origin-embedder-policy',\n    'cross-origin-opener-policy',\n    'cross-origin-resource-policy',\n];\n\nexport default class ResourceInjector {\n    private readonly _browserId: string;\n    private readonly _specialServiceRoutes: SpecialServiceRoutes;\n\n    public constructor (browserId: string, specialServiceRoutes: SpecialServiceRoutes) {\n        this._browserId            = browserId;\n        this._specialServiceRoutes = specialServiceRoutes;\n    }\n\n    private get _browserConnection (): BrowserConnection {\n        return BrowserConnection.getById(this._browserId) as BrowserConnection;\n    }\n\n    private get _currentTestRun (): LegacyTestRun | TestRun | null {\n        return this._browserConnection.getCurrentTestRun();\n    }\n\n    private async _prepareInjectableResources ({ isIframe, restoringStorages }: InjectableResourcesOptions): Promise<PageInjectableResources | null> {\n        const proxy    = this._browserConnection.browserConnectionGateway.proxy;\n        const windowId = this._browserConnection.activeWindowId;\n\n        if (!this._currentTestRun)\n            return null;\n\n        const taskScript = await this._currentTestRun.session.getTaskScript({\n            referer:     '',\n            cookieUrl:   '',\n            withPayload: true,\n            serverInfo:  proxy.server1Info,\n            windowId,\n            isIframe,\n        });\n\n        const injectableResources = {\n            storages:    restoringStorages,\n            stylesheets: [\n                TESTCAFE_UI_STYLES,\n            ],\n            scripts: [\n                ...HAMMERHEAD_INJECTABLE_SCRIPTS.map(hs => getAssetPath(hs, proxy.options.developmentMode)),\n                ...SCRIPTS.map(s => getAssetPath(s, proxy.options.developmentMode)),\n            ],\n            embeddedScripts: [taskScript],\n        };\n\n        injectableResources.scripts     = injectableResources.scripts.map(script => proxy.resolveRelativeServiceUrl(script));\n        injectableResources.stylesheets = injectableResources.stylesheets.map(style => proxy.resolveRelativeServiceUrl(style));\n\n        return injectableResources;\n    }\n\n    private _processResponseHeaders (headers: HeaderEntry[] | undefined): HeaderEntry[] {\n        if (!headers)\n            return [];\n\n        headers = headers.filter(header => !RESPONSE_REMOVED_HEADERS.includes(header.name.toLowerCase()));\n\n        return stringifyHeaderValues(headers);\n    }\n\n    private async _fulfillRequest (client: ProtocolApi, fulfillRequestInfo: FulfillRequestRequest, body: string): Promise<void> {\n        await safeFulfillRequest(client, {\n            requestId:       fulfillRequestInfo.requestId,\n            responseCode:    fulfillRequestInfo.responseCode || StatusCodes.OK,\n            responsePhrase:  fulfillRequestInfo.responsePhrase,\n            responseHeaders: this._processResponseHeaders(fulfillRequestInfo.responseHeaders),\n            body:            toBase64String(body),\n        });\n    }\n\n    public async redirectToErrorPage (client: ProtocolApi, err: Error, url: string): Promise<void> {\n        const browserConnection = BrowserConnection.getById(this._browserId) as BrowserConnection;\n        const currentTestRun    = browserConnection.getCurrentTestRun();\n\n        if (!currentTestRun)\n            return;\n\n        currentTestRun.pendingPageError = new PageLoadError(err, url);\n\n        await navigateTo(client, this._specialServiceRoutes.errorPage1);\n    }\n\n    public async getDocumentResourceInfo (event: RequestPausedEvent, client: ProtocolApi): Promise<DocumentResourceInfo> {\n        const {\n            requestId,\n            request,\n            responseErrorReason,\n            resourceType,\n        } = event;\n\n        if (resourceType !== 'Document') {\n            return {\n                error: null,\n                body:  null,\n            };\n        }\n\n        try {\n            if (responseErrorReason === 'NameNotResolved') {\n                const err = new Error(`Failed to find a DNS-record for the resource at \"${event.request.url}\"`);\n\n                return {\n                    error: err,\n                    body:  null,\n                };\n            }\n\n            const responseObj = await client.Fetch.getResponseBody({ requestId });\n            const responseStr = getResponseAsString(responseObj);\n\n            return {\n                error: null,\n                body:  Buffer.from(responseStr),\n            };\n        }\n        catch (err) {\n            resourceInjectorLogger('Failed to process request: %s', request.url);\n\n            return {\n                error: err,\n                body:  null,\n            };\n        }\n    }\n\n    public async processAboutBlankPage (event: FrameNavigatedEvent, client: ProtocolApi): Promise<void> {\n        resourceInjectorLogger('Handle page as about:blank. Origin url: %s', event.frame.url);\n\n        const injectableResources = await this._prepareInjectableResources({ isIframe: false }) as PageInjectableResources;\n        const html                = injectResources(EMPTY_PAGE_MARKUP, injectableResources);\n\n        await client.Page.setDocumentContent({\n            frameId: event.frame.id,\n            html,\n        });\n    }\n\n    public async processHTMLPageContent (fulfillRequestInfo: FulfillRequestRequest, injectableResourcesOptions: InjectableResourcesOptions, client: ProtocolApi): Promise<void> {\n        const injectableResources = await this._prepareInjectableResources(injectableResourcesOptions);\n\n        // NOTE: an unhandled exception interrupts the test execution,\n        // and we are force to redirect manually to the idle page.\n        if (!injectableResources)\n            await redirect(client, fulfillRequestInfo.requestId, this._specialServiceRoutes.idlePage);\n        else {\n            const updatedResponseStr = injectResources(\n                fulfillRequestInfo.body as string,\n                injectableResources,\n                this._getPageInjectableResourcesOptions(injectableResourcesOptions),\n            );\n\n            await this._fulfillRequest(client, fulfillRequestInfo, updatedResponseStr);\n        }\n    }\n\n    public async processNonProxiedContent (fulfillRequestInfo: FulfillRequestRequest, client: ProtocolApi): Promise<void> {\n        await this._fulfillRequest(client, fulfillRequestInfo, fulfillRequestInfo.body as string);\n    }\n\n    private _getPageInjectableResourcesOptions (injectableResourcesOptions: InjectableResourcesOptions): PageRestoreStoragesOptions | undefined {\n        const { url, restoringStorages } = injectableResourcesOptions;\n\n        if (url && restoringStorages) {\n            return {\n                host:      new URL(url).host,\n                sessionId: this._currentTestRun.session.id,\n            };\n        }\n\n        return void 0;\n    }\n}\n"]}
162
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resource-injector.js","sourceRoot":"","sources":["../../src/proxyless/resource-injector.ts"],"names":[],"mappings":"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","sourcesContent":["import { ProtocolApi } from 'chrome-remote-interface';\nimport Protocol from 'devtools-protocol';\nimport RequestPausedEvent = Protocol.Fetch.RequestPausedEvent;\nimport FrameNavigatedEvent = Protocol.Page.FrameNavigatedEvent;\nimport FulfillRequestRequest = Protocol.Fetch.FulfillRequestRequest;\nimport HeaderEntry = Protocol.Fetch.HeaderEntry;\nimport {\n    injectResources,\n    PageInjectableResources,\n    INJECTABLE_SCRIPTS as HAMMERHEAD_INJECTABLE_SCRIPTS,\n    getAssetPath,\n    PageRestoreStoragesOptions,\n    StoragesSnapshot,\n    Proxy,\n} from 'testcafe-hammerhead';\nimport { SCRIPTS, TESTCAFE_UI_STYLES } from '../assets/injectables';\nimport EMPTY_PAGE_MARKUP from './empty-page-markup';\nimport { StatusCodes } from 'http-status-codes';\nimport { PageLoadError } from '../errors/test-run';\nimport { redirect, navigateTo } from './utils/cdp';\n\nimport {\n    DocumentResourceInfo,\n    InjectableResourcesOptions,\n    SessionStorageInfo,\n    SpecialServiceRoutes,\n} from './types';\n\nimport { resourceInjectorLogger } from '../utils/debug-loggers';\nimport {\n    getResponseAsString,\n    stringifyHeaderValues,\n    toBase64String,\n} from './utils/string';\nimport { safeFulfillRequest } from './request-pipeline/safe-api';\nimport TestRunBridge from './request-pipeline/test-run-bridge';\n\nconst RESPONSE_REMOVED_HEADERS = [\n    'cross-origin-embedder-policy',\n    'cross-origin-opener-policy',\n    'cross-origin-resource-policy',\n];\n\nexport default class ResourceInjector {\n    private readonly _specialServiceRoutes: SpecialServiceRoutes;\n    private readonly _testRunBridge: TestRunBridge;\n\n    public constructor (testRunBridge: TestRunBridge, specialServiceRoutes: SpecialServiceRoutes) {\n        this._specialServiceRoutes = specialServiceRoutes;\n        this._testRunBridge        = testRunBridge;\n    }\n\n    private _getRestoreContextStorageScript (contextStorage?: SessionStorageInfo | null): string {\n        const currentTestRun = this._testRunBridge.getCurrentTestRun();\n        const value = JSON.stringify(contextStorage?.[currentTestRun.id] || '');\n\n        return `Object.defineProperty(window, '%proxylessContextStorage%', { configurable: true, value: ${value} });`;\n    }\n\n    private _getRestoreStoragesScript (restoringStorages: StoragesSnapshot | null | undefined): string {\n        if (!restoringStorages)\n            return '(function() {})()';\n\n        return `(function() {\n            window.localStorage.clear();\n            window.sessionStorage.clear();\n\n            const snapshot = ${JSON.stringify(restoringStorages)};\n            const ls       = JSON.parse(snapshot.localStorage);\n            const ss       = JSON.parse(snapshot.sessionStorage);\n\n            for (let i = 0; i < ls[0].length; i++)\n                window.localStorage.setItem(ls[0][i], ls[1][i]);\n\n            for (let i = 0; i < ss[0].length; i++)\n                window.sessionStorage.setItem(ss[0][i], ss[1][i]);\n        })();\n        `;\n    }\n\n    private _resolveRelativeUrls (proxy: Proxy, relativeUrls: string[]): string[] {\n        return relativeUrls.map(url => proxy.resolveRelativeServiceUrl(url));\n    }\n\n    private async _prepareInjectableResources ({ isIframe, restoringStorages, contextStorage, userScripts }: InjectableResourcesOptions): Promise<PageInjectableResources | null> {\n        if (!this._testRunBridge.getCurrentTestRun())\n            return null;\n\n        const taskScript = await this._testRunBridge.getTaskScript({ isIframe, restoringStorages, contextStorage, userScripts });\n        const proxy      = this._testRunBridge.getBrowserConnection().browserConnectionGateway.proxy;\n\n        const injectableResources = {\n            stylesheets: [\n                TESTCAFE_UI_STYLES,\n            ],\n            scripts: [\n                ...HAMMERHEAD_INJECTABLE_SCRIPTS.map(hs => getAssetPath(hs, proxy.options.developmentMode)),\n                ...SCRIPTS.map(s => getAssetPath(s, proxy.options.developmentMode)),\n            ],\n            embeddedScripts: [ this._getRestoreStoragesScript(restoringStorages), this._getRestoreContextStorageScript(contextStorage), taskScript],\n            userScripts:     userScripts || [],\n        };\n\n        injectableResources.scripts     = this._resolveRelativeUrls(proxy, injectableResources.scripts);\n        injectableResources.userScripts = this._resolveRelativeUrls(proxy, injectableResources.userScripts);\n        injectableResources.stylesheets = this._resolveRelativeUrls(proxy, injectableResources.stylesheets);\n\n        return injectableResources;\n    }\n\n    private _processResponseHeaders (headers: HeaderEntry[] | undefined): HeaderEntry[] {\n        if (!headers)\n            return [];\n\n        headers = headers.filter(header => !RESPONSE_REMOVED_HEADERS.includes(header.name.toLowerCase()));\n\n        return stringifyHeaderValues(headers);\n    }\n\n    private async _fulfillRequest (client: ProtocolApi, fulfillRequestInfo: FulfillRequestRequest, body: string): Promise<void> {\n        await safeFulfillRequest(client, {\n            requestId:       fulfillRequestInfo.requestId,\n            responseCode:    fulfillRequestInfo.responseCode || StatusCodes.OK,\n            responsePhrase:  fulfillRequestInfo.responsePhrase,\n            responseHeaders: this._processResponseHeaders(fulfillRequestInfo.responseHeaders),\n            body:            toBase64String(body),\n        });\n    }\n\n    public async redirectToErrorPage (client: ProtocolApi, err: Error, url: string): Promise<void> {\n        const currentTestRun = this._testRunBridge.getCurrentTestRun();\n\n        if (!currentTestRun)\n            return;\n\n        currentTestRun.pendingPageError = new PageLoadError(err, url);\n\n        await navigateTo(client, this._specialServiceRoutes.errorPage1);\n    }\n\n    public async getDocumentResourceInfo (event: RequestPausedEvent, client: ProtocolApi): Promise<DocumentResourceInfo> {\n        const {\n            requestId,\n            request,\n            responseErrorReason,\n            resourceType,\n        } = event;\n\n        if (resourceType !== 'Document') {\n            return {\n                error: null,\n                body:  null,\n            };\n        }\n\n        try {\n            if (responseErrorReason === 'NameNotResolved') {\n                const err = new Error(`Failed to find a DNS-record for the resource at \"${event.request.url}\"`);\n\n                return {\n                    error: err,\n                    body:  null,\n                };\n            }\n\n            const responseObj = await client.Fetch.getResponseBody({ requestId });\n            const responseStr = getResponseAsString(responseObj);\n\n            return {\n                error: null,\n                body:  Buffer.from(responseStr),\n            };\n        }\n        catch (err) {\n            resourceInjectorLogger('Failed to process request: %s', request.url);\n\n            return {\n                error: err,\n                body:  null,\n            };\n        }\n    }\n\n    public async processAboutBlankPage (event: FrameNavigatedEvent, userScripts: string[], client: ProtocolApi): Promise<void> {\n        resourceInjectorLogger('Handle page as about:blank. Origin url: %s', event.frame.url);\n\n        const injectableResources = await this._prepareInjectableResources({ isIframe: false, userScripts }) as PageInjectableResources;\n        const html                = injectResources(EMPTY_PAGE_MARKUP, injectableResources);\n\n        await client.Page.setDocumentContent({\n            frameId: event.frame.id,\n            html,\n        });\n    }\n\n    public async processHTMLPageContent (fulfillRequestInfo: FulfillRequestRequest, injectableResourcesOptions: InjectableResourcesOptions, client: ProtocolApi): Promise<void> {\n        const injectableResources = await this._prepareInjectableResources(injectableResourcesOptions);\n\n        // NOTE: an unhandled exception interrupts the test execution,\n        // and we are force to redirect manually to the idle page.\n        if (!injectableResources)\n            await redirect(client, fulfillRequestInfo.requestId, this._specialServiceRoutes.idlePage);\n        else {\n            const updatedResponseStr = injectResources(\n                fulfillRequestInfo.body as string,\n                injectableResources,\n                this._getPageInjectableResourcesOptions(injectableResourcesOptions),\n            );\n\n            await this._fulfillRequest(client, fulfillRequestInfo, updatedResponseStr);\n        }\n    }\n\n    public async processNonProxiedContent (fulfillRequestInfo: FulfillRequestRequest, client: ProtocolApi): Promise<void> {\n        await this._fulfillRequest(client, fulfillRequestInfo, fulfillRequestInfo.body as string);\n    }\n\n    private _getPageInjectableResourcesOptions (injectableResourcesOptions: InjectableResourcesOptions): PageRestoreStoragesOptions | undefined {\n        const { url, restoringStorages } = injectableResourcesOptions;\n\n        if (url && restoringStorages) {\n            return {\n                host:      new URL(url).host,\n                sessionId: this._testRunBridge.getSessionId(),\n            };\n        }\n\n        return void 0;\n    }\n}\n"]}
@@ -0,0 +1,39 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const api_base_1 = __importDefault(require("../api-base"));
7
+ const async_event_emitter_1 = __importDefault(require("../../utils/async-event-emitter"));
8
+ const PROXYLESS_STORAGE_BINDING = 'PROXYLESS_STORAGE_BINDING';
9
+ class SessionStorage extends api_base_1.default {
10
+ constructor(browserId, client) {
11
+ super(browserId, client);
12
+ this._eventEmitter = new async_event_emitter_1.default();
13
+ if (this._browserConnection.messageBus)
14
+ this._addTestRunEventListeners(this._browserConnection.messageBus);
15
+ this._browserConnection.on('message-bus-initialized', messageBus => {
16
+ this._addTestRunEventListeners(messageBus);
17
+ });
18
+ }
19
+ _addTestRunEventListeners(messageBus) {
20
+ messageBus.on('test-run-done', testRun => {
21
+ this._eventEmitter.emit('contextStorageTestRunDone', { testRunId: testRun.id });
22
+ });
23
+ }
24
+ on(eventName, listener) {
25
+ return this._eventEmitter.on(eventName, listener);
26
+ }
27
+ async init() {
28
+ await this._client.Runtime.addBinding({ name: PROXYLESS_STORAGE_BINDING });
29
+ await this._client.Runtime.on('bindingCalled', (event) => {
30
+ if (event.name === PROXYLESS_STORAGE_BINDING) {
31
+ const { testRunId, frameDriverId, data } = JSON.parse(event.payload);
32
+ this._eventEmitter.emit('contextStorageSync', { sessionStorage: data, testRunId, frameDriverId });
33
+ }
34
+ });
35
+ }
36
+ }
37
+ exports.default = SessionStorage;
38
+ module.exports = exports.default;
39
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvcHJveHlsZXNzL3Nlc3Npb24tc3RvcmFnZS9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUVBLDJEQUEyQztBQUUzQywwRkFBZ0U7QUFJaEUsTUFBTSx5QkFBeUIsR0FBRywyQkFBMkIsQ0FBQztBQUU5RCxNQUFxQixjQUFlLFNBQVEsa0JBQWdCO0lBR3hELFlBQWEsU0FBaUIsRUFBRSxNQUFtQjtRQUMvQyxLQUFLLENBQUMsU0FBUyxFQUFFLE1BQU0sQ0FBQyxDQUFDO1FBRXpCLElBQUksQ0FBQyxhQUFhLEdBQUcsSUFBSSw2QkFBaUIsRUFBRSxDQUFDO1FBRTdDLElBQUksSUFBSSxDQUFDLGtCQUFrQixDQUFDLFVBQVU7WUFDbEMsSUFBSSxDQUFDLHlCQUF5QixDQUFDLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxVQUFVLENBQUMsQ0FBQztRQUV2RSxJQUFJLENBQUMsa0JBQWtCLENBQUMsRUFBRSxDQUFDLHlCQUF5QixFQUFFLFVBQVUsQ0FBQyxFQUFFO1lBQy9ELElBQUksQ0FBQyx5QkFBeUIsQ0FBQyxVQUFVLENBQUMsQ0FBQztRQUMvQyxDQUFDLENBQUMsQ0FBQztJQUNQLENBQUM7SUFFTyx5QkFBeUIsQ0FBRSxVQUFzQjtRQUNyRCxVQUFVLENBQUMsRUFBRSxDQUFDLGVBQWUsRUFBRSxPQUFPLENBQUMsRUFBRTtZQUNyQyxJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQywyQkFBMkIsRUFBRSxFQUFFLFNBQVMsRUFBRSxPQUFPLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQztRQUNwRixDQUFDLENBQUMsQ0FBQztJQUNQLENBQUM7SUFFTSxFQUFFLENBQUUsU0FBaUIsRUFBRSxRQUFrQztRQUM1RCxPQUFPLElBQUksQ0FBQyxhQUFhLENBQUMsRUFBRSxDQUFDLFNBQVMsRUFBRSxRQUFRLENBQUMsQ0FBQztJQUN0RCxDQUFDO0lBRU0sS0FBSyxDQUFDLElBQUk7UUFDYixNQUFNLElBQUksQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLFVBQVUsQ0FBQyxFQUFFLElBQUksRUFBRSx5QkFBeUIsRUFBRSxDQUFDLENBQUM7UUFFM0UsTUFBTSxJQUFJLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxFQUFFLENBQUMsZUFBZSxFQUFFLENBQUMsS0FBeUIsRUFBRSxFQUFFO1lBQ3pFLElBQUksS0FBSyxDQUFDLElBQUksS0FBSyx5QkFBeUIsRUFBRTtnQkFDMUMsTUFBTSxFQUFFLFNBQVMsRUFBRSxhQUFhLEVBQUUsSUFBSSxFQUFFLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLENBQUM7Z0JBRXJFLElBQUksQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLG9CQUFvQixFQUFFLEVBQUUsY0FBYyxFQUFFLElBQUksRUFBRSxTQUFTLEVBQUUsYUFBYSxFQUFFLENBQUMsQ0FBQzthQUNyRztRQUNMLENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztDQUNKO0FBckNELGlDQXFDQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFByb3RvY29sQXBpIH0gZnJvbSAnY2hyb21lLXJlbW90ZS1pbnRlcmZhY2UnO1xuaW1wb3J0IFByb3RvY29sIGZyb20gJ2RldnRvb2xzLXByb3RvY29sJztcbmltcG9ydCBQcm94eWxlc3NBcGlCYXNlIGZyb20gJy4uL2FwaS1iYXNlJztcbmltcG9ydCBCaW5kaW5nQ2FsbGVkRXZlbnQgPSBQcm90b2NvbC5SdW50aW1lLkJpbmRpbmdDYWxsZWRFdmVudDtcbmltcG9ydCBBc3luY0V2ZW50RW1pdHRlciBmcm9tICcuLi8uLi91dGlscy9hc3luYy1ldmVudC1lbWl0dGVyJztcbmltcG9ydCBFbWl0dGVyeSBmcm9tICdlbWl0dGVyeSc7XG5pbXBvcnQgTWVzc2FnZUJ1cyBmcm9tICcuLi8uLi91dGlscy9tZXNzYWdlLWJ1cyc7XG5cbmNvbnN0IFBST1hZTEVTU19TVE9SQUdFX0JJTkRJTkcgPSAnUFJPWFlMRVNTX1NUT1JBR0VfQklORElORyc7XG5cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIFNlc3Npb25TdG9yYWdlIGV4dGVuZHMgUHJveHlsZXNzQXBpQmFzZSB7XG4gICAgcHJpdmF0ZSBfZXZlbnRFbWl0dGVyOiBBc3luY0V2ZW50RW1pdHRlcjtcblxuICAgIGNvbnN0cnVjdG9yIChicm93c2VySWQ6IHN0cmluZywgY2xpZW50OiBQcm90b2NvbEFwaSkge1xuICAgICAgICBzdXBlcihicm93c2VySWQsIGNsaWVudCk7XG5cbiAgICAgICAgdGhpcy5fZXZlbnRFbWl0dGVyID0gbmV3IEFzeW5jRXZlbnRFbWl0dGVyKCk7XG5cbiAgICAgICAgaWYgKHRoaXMuX2Jyb3dzZXJDb25uZWN0aW9uLm1lc3NhZ2VCdXMpXG4gICAgICAgICAgICB0aGlzLl9hZGRUZXN0UnVuRXZlbnRMaXN0ZW5lcnModGhpcy5fYnJvd3NlckNvbm5lY3Rpb24ubWVzc2FnZUJ1cyk7XG5cbiAgICAgICAgdGhpcy5fYnJvd3NlckNvbm5lY3Rpb24ub24oJ21lc3NhZ2UtYnVzLWluaXRpYWxpemVkJywgbWVzc2FnZUJ1cyA9PiB7XG4gICAgICAgICAgICB0aGlzLl9hZGRUZXN0UnVuRXZlbnRMaXN0ZW5lcnMobWVzc2FnZUJ1cyk7XG4gICAgICAgIH0pO1xuICAgIH1cblxuICAgIHByaXZhdGUgX2FkZFRlc3RSdW5FdmVudExpc3RlbmVycyAobWVzc2FnZUJ1czogTWVzc2FnZUJ1cyk6IHZvaWQge1xuICAgICAgICBtZXNzYWdlQnVzLm9uKCd0ZXN0LXJ1bi1kb25lJywgdGVzdFJ1biA9PiB7XG4gICAgICAgICAgICB0aGlzLl9ldmVudEVtaXR0ZXIuZW1pdCgnY29udGV4dFN0b3JhZ2VUZXN0UnVuRG9uZScsIHsgdGVzdFJ1bklkOiB0ZXN0UnVuLmlkIH0pO1xuICAgICAgICB9KTtcbiAgICB9XG5cbiAgICBwdWJsaWMgb24gKGV2ZW50TmFtZTogc3RyaW5nLCBsaXN0ZW5lcjogKGV2ZW50RGF0YT86IGFueSkgPT4gYW55KTogRW1pdHRlcnkuVW5zdWJzY3JpYmVGbiB7XG4gICAgICAgIHJldHVybiB0aGlzLl9ldmVudEVtaXR0ZXIub24oZXZlbnROYW1lLCBsaXN0ZW5lcik7XG4gICAgfVxuXG4gICAgcHVibGljIGFzeW5jIGluaXQgKCk6IFByb21pc2U8dm9pZD4ge1xuICAgICAgICBhd2FpdCB0aGlzLl9jbGllbnQuUnVudGltZS5hZGRCaW5kaW5nKHsgbmFtZTogUFJPWFlMRVNTX1NUT1JBR0VfQklORElORyB9KTtcblxuICAgICAgICBhd2FpdCB0aGlzLl9jbGllbnQuUnVudGltZS5vbignYmluZGluZ0NhbGxlZCcsIChldmVudDogQmluZGluZ0NhbGxlZEV2ZW50KSA9PiB7XG4gICAgICAgICAgICBpZiAoZXZlbnQubmFtZSA9PT0gUFJPWFlMRVNTX1NUT1JBR0VfQklORElORykge1xuICAgICAgICAgICAgICAgIGNvbnN0IHsgdGVzdFJ1bklkLCBmcmFtZURyaXZlcklkLCBkYXRhIH0gPSBKU09OLnBhcnNlKGV2ZW50LnBheWxvYWQpO1xuXG4gICAgICAgICAgICAgICAgdGhpcy5fZXZlbnRFbWl0dGVyLmVtaXQoJ2NvbnRleHRTdG9yYWdlU3luYycsIHsgc2Vzc2lvblN0b3JhZ2U6IGRhdGEsIHRlc3RSdW5JZCwgZnJhbWVEcml2ZXJJZCB9KTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgfSk7XG4gICAgfVxufVxuIl19
@@ -0,0 +1,17 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.CdpStoragesProvider = void 0;
4
+ const get_active_client_1 = require("./utils/get-active-client");
5
+ const base_1 = require("../test-run/storages/base");
6
+ class CdpStoragesProvider extends base_1.StoragesProviderBase {
7
+ async _getCdpClient() {
8
+ const browserConnection = this.testRun.browserConnection;
9
+ return (0, get_active_client_1.getActiveClient)(browserConnection);
10
+ }
11
+ async clearStorages() {
12
+ const client = await this._getCdpClient();
13
+ await client.Storage.clearDataForOrigin({ origin: '*', storageTypes: 'all' });
14
+ }
15
+ }
16
+ exports.CdpStoragesProvider = CdpStoragesProvider;
17
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RvcmFnZXMtcHJvdmlkZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvcHJveHlsZXNzL3N0b3JhZ2VzLXByb3ZpZGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUNBLGlFQUE0RDtBQUM1RCxvREFBbUY7QUFFbkYsTUFBYSxtQkFBb0IsU0FBUSwyQkFBb0I7SUFDakQsS0FBSyxDQUFDLGFBQWE7UUFDdkIsTUFBTSxpQkFBaUIsR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLGlCQUFpQixDQUFDO1FBRXpELE9BQU8sSUFBQSxtQ0FBZSxFQUFDLGlCQUFpQixDQUFDLENBQUM7SUFDOUMsQ0FBQztJQUVELEtBQUssQ0FBQyxhQUFhO1FBQ2YsTUFBTSxNQUFNLEdBQUcsTUFBTSxJQUFJLENBQUMsYUFBYSxFQUFFLENBQUM7UUFFMUMsTUFBTSxNQUFNLENBQUMsT0FBTyxDQUFDLGtCQUFrQixDQUFDLEVBQUUsTUFBTSxFQUFFLEdBQUcsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLENBQUMsQ0FBQztJQUNsRixDQUFDO0NBQ0o7QUFaRCxrREFZQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCByZW1vdGVDaHJvbWUgZnJvbSAnY2hyb21lLXJlbW90ZS1pbnRlcmZhY2UnO1xuaW1wb3J0IHsgZ2V0QWN0aXZlQ2xpZW50IH0gZnJvbSAnLi91dGlscy9nZXQtYWN0aXZlLWNsaWVudCc7XG5pbXBvcnQgeyBTdG9yYWdlc1Byb3ZpZGVyLCBTdG9yYWdlc1Byb3ZpZGVyQmFzZSB9IGZyb20gJy4uL3Rlc3QtcnVuL3N0b3JhZ2VzL2Jhc2UnO1xuXG5leHBvcnQgY2xhc3MgQ2RwU3RvcmFnZXNQcm92aWRlciBleHRlbmRzIFN0b3JhZ2VzUHJvdmlkZXJCYXNlIGltcGxlbWVudHMgU3RvcmFnZXNQcm92aWRlciB7XG4gICAgcHJpdmF0ZSBhc3luYyBfZ2V0Q2RwQ2xpZW50ICgpOiBQcm9taXNlPHJlbW90ZUNocm9tZS5Qcm90b2NvbEFwaT4ge1xuICAgICAgICBjb25zdCBicm93c2VyQ29ubmVjdGlvbiA9IHRoaXMudGVzdFJ1bi5icm93c2VyQ29ubmVjdGlvbjtcblxuICAgICAgICByZXR1cm4gZ2V0QWN0aXZlQ2xpZW50KGJyb3dzZXJDb25uZWN0aW9uKTtcbiAgICB9XG5cbiAgICBhc3luYyBjbGVhclN0b3JhZ2VzICgpOiBQcm9taXNlPHZvaWQ+IHtcbiAgICAgICAgY29uc3QgY2xpZW50ID0gYXdhaXQgdGhpcy5fZ2V0Q2RwQ2xpZW50KCk7XG5cbiAgICAgICAgYXdhaXQgY2xpZW50LlN0b3JhZ2UuY2xlYXJEYXRhRm9yT3JpZ2luKHsgb3JpZ2luOiAnKicsIHN0b3JhZ2VUeXBlczogJ2FsbCcgfSk7XG4gICAgfVxufVxuIl19
@@ -1,3 +1,10 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvcHJveHlsZXNzL3R5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUHJvdG9jb2wgZnJvbSAnZGV2dG9vbHMtcHJvdG9jb2wnO1xuaW1wb3J0IFJlcXVlc3RQYXVzZWRFdmVudCA9IFByb3RvY29sLkZldGNoLlJlcXVlc3RQYXVzZWRFdmVudDtcbmltcG9ydCB7IFByb3RvY29sQXBpIH0gZnJvbSAnY2hyb21lLXJlbW90ZS1pbnRlcmZhY2UnO1xuaW1wb3J0IHsgUHJveHlsZXNzU2V0dXBPcHRpb25zIH0gZnJvbSAnLi4vc2hhcmVkL3R5cGVzJztcbmltcG9ydCB7IFN0b3JhZ2VzU25hcHNob3QgfSBmcm9tICd0ZXN0Y2FmZS1oYW1tZXJoZWFkJztcblxuZXhwb3J0IGludGVyZmFjZSBTcGVjaWFsU2VydmljZVJvdXRlcyB7XG4gICAgZXJyb3JQYWdlMTogc3RyaW5nO1xuICAgIGVycm9yUGFnZTI6IHN0cmluZztcbiAgICBvcGVuRmlsZVByb3RvY29sVXJsOiBzdHJpbmc7XG4gICAgaWRsZVBhZ2U6IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBEb2N1bWVudFJlc291cmNlSW5mbyB7XG4gICAgZXJyb3I6IGFueTtcbiAgICBib2R5OiBCdWZmZXIgfCBudWxsO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFJlcXVlc3RIYW5kbGVyIHtcbiAgICBjb25kaXRpb246IChldmVudDogUmVxdWVzdFBhdXNlZEV2ZW50LCBvcHRpb25zPzogUHJveHlsZXNzU2V0dXBPcHRpb25zLCBzZXJ2aWNlUm91dGVzPzogU3BlY2lhbFNlcnZpY2VSb3V0ZXMpID0+IGJvb2xlYW47XG4gICAgaGFuZGxlcjogKGV2ZW50OiBSZXF1ZXN0UGF1c2VkRXZlbnQsIGNsaWVudDogUHJvdG9jb2xBcGksIG9wdGlvbnM/OiBQcm94eWxlc3NTZXR1cE9wdGlvbnMpID0+IFByb21pc2U8dm9pZD47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgSW5qZWN0YWJsZVJlc291cmNlc09wdGlvbnMge1xuICAgIGlzSWZyYW1lOiBib29sZWFuO1xuICAgIHVybD86IHN0cmluZztcbiAgICByZXN0b3JpbmdTdG9yYWdlcz86IFN0b3JhZ2VzU25hcHNob3QgfCBudWxsO1xufVxuIl19
3
+ exports.EventType = void 0;
4
+ var EventType;
5
+ (function (EventType) {
6
+ EventType[EventType["Mouse"] = 0] = "Mouse";
7
+ EventType[EventType["Key"] = 1] = "Key";
8
+ EventType[EventType["Touch"] = 2] = "Touch";
9
+ })(EventType = exports.EventType || (exports.EventType = {}));
10
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvcHJveHlsZXNzL3R5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQWtDQSxJQUFZLFNBSVg7QUFKRCxXQUFZLFNBQVM7SUFDakIsMkNBQUssQ0FBQTtJQUNMLHVDQUFHLENBQUE7SUFDSCwyQ0FBSyxDQUFBO0FBQ1QsQ0FBQyxFQUpXLFNBQVMsR0FBVCxpQkFBUyxLQUFULGlCQUFTLFFBSXBCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFByb3RvY29sIGZyb20gJ2RldnRvb2xzLXByb3RvY29sJztcbmltcG9ydCBSZXF1ZXN0UGF1c2VkRXZlbnQgPSBQcm90b2NvbC5GZXRjaC5SZXF1ZXN0UGF1c2VkRXZlbnQ7XG5pbXBvcnQgeyBQcm90b2NvbEFwaSB9IGZyb20gJ2Nocm9tZS1yZW1vdGUtaW50ZXJmYWNlJztcbmltcG9ydCB7IFByb3h5bGVzc1NldHVwT3B0aW9ucyB9IGZyb20gJy4uL3NoYXJlZC90eXBlcyc7XG5pbXBvcnQgeyBTdG9yYWdlc1NuYXBzaG90IH0gZnJvbSAndGVzdGNhZmUtaGFtbWVyaGVhZCc7XG5pbXBvcnQgeyBEaWN0aW9uYXJ5IH0gZnJvbSAnLi4vY29uZmlndXJhdGlvbi9pbnRlcmZhY2VzJztcblxuZXhwb3J0IGludGVyZmFjZSBTcGVjaWFsU2VydmljZVJvdXRlcyB7XG4gICAgZXJyb3JQYWdlMTogc3RyaW5nO1xuICAgIGVycm9yUGFnZTI6IHN0cmluZztcbiAgICBvcGVuRmlsZVByb3RvY29sVXJsOiBzdHJpbmc7XG4gICAgaWRsZVBhZ2U6IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBEb2N1bWVudFJlc291cmNlSW5mbyB7XG4gICAgZXJyb3I6IGFueTtcbiAgICBib2R5OiBCdWZmZXIgfCBudWxsO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFJlcXVlc3RIYW5kbGVyIHtcbiAgICBjb25kaXRpb246IChldmVudDogUmVxdWVzdFBhdXNlZEV2ZW50LCBvcHRpb25zPzogUHJveHlsZXNzU2V0dXBPcHRpb25zLCBzZXJ2aWNlUm91dGVzPzogU3BlY2lhbFNlcnZpY2VSb3V0ZXMpID0+IGJvb2xlYW47XG4gICAgaGFuZGxlcjogKGV2ZW50OiBSZXF1ZXN0UGF1c2VkRXZlbnQsIGNsaWVudDogUHJvdG9jb2xBcGksIG9wdGlvbnM/OiBQcm94eWxlc3NTZXR1cE9wdGlvbnMpID0+IFByb21pc2U8dm9pZD47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgSW5qZWN0YWJsZVJlc291cmNlc09wdGlvbnMge1xuICAgIGlzSWZyYW1lOiBib29sZWFuO1xuICAgIHVybD86IHN0cmluZztcbiAgICByZXN0b3JpbmdTdG9yYWdlcz86IFN0b3JhZ2VzU25hcHNob3QgfCBudWxsO1xuICAgIGNvbnRleHRTdG9yYWdlPzogU2Vzc2lvblN0b3JhZ2VJbmZvO1xuICAgIHVzZXJTY3JpcHRzPzogc3RyaW5nW107XG59XG5cbmV4cG9ydCB0eXBlIFNlc3Npb25TdG9yYWdlSW5mbyA9IERpY3Rpb25hcnk8RGljdGlvbmFyeTxzdHJpbmc+PiB8IG51bGw7XG5cbmV4cG9ydCBlbnVtIEV2ZW50VHlwZSB7XG4gICAgTW91c2UsXG4gICAgS2V5LFxuICAgIFRvdWNoLFxufVxuIl19
@@ -1,8 +1,9 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.createRequestPausedEventForResponse = exports.isPreflightRequest = exports.isRequestPausedEvent = exports.isRequest = exports.navigateTo = exports.redirect = void 0;
3
+ exports.getRequestId = exports.createRequestPausedEventForResponse = exports.isPreflightRequest = exports.isRequestPausedEvent = exports.isUnauthorized = exports.isRequest = exports.dispatchEvent = exports.navigateTo = exports.redirect = void 0;
4
4
  const http_status_codes_1 = require("http-status-codes");
5
5
  const headers_1 = require("./headers");
6
+ const types_1 = require("../types");
6
7
  async function redirect(client, requestId, url) {
7
8
  await client.Fetch.fulfillRequest({
8
9
  requestId,
@@ -17,10 +18,30 @@ async function navigateTo(client, url) {
17
18
  await client.Page.navigate({ url });
18
19
  }
19
20
  exports.navigateTo = navigateTo;
21
+ async function dispatchEvent(client, type, options) {
22
+ switch (+type) {
23
+ case types_1.EventType.Mouse:
24
+ await client.Input.dispatchMouseEvent(options);
25
+ break;
26
+ case types_1.EventType.Key:
27
+ await client.Input.dispatchKeyEvent(options);
28
+ break;
29
+ case types_1.EventType.Touch:
30
+ await client.Input.dispatchTouchEvent(options);
31
+ break;
32
+ default:
33
+ throw new Error(`Unknown "${options.type}" event type`);
34
+ }
35
+ }
36
+ exports.dispatchEvent = dispatchEvent;
20
37
  function isRequest(event) {
21
38
  return event.responseStatusCode === void 0;
22
39
  }
23
40
  exports.isRequest = isRequest;
41
+ function isUnauthorized(statusCode) {
42
+ return statusCode === 401;
43
+ }
44
+ exports.isUnauthorized = isUnauthorized;
24
45
  function isRequestPausedEvent(val) {
25
46
  return val && val.frameId && typeof val.request === 'object';
26
47
  }
@@ -36,4 +57,10 @@ function createRequestPausedEventForResponse(mockedResponse, requestEvent) {
36
57
  });
37
58
  }
38
59
  exports.createRequestPausedEventForResponse = createRequestPausedEventForResponse;
39
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2RwLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3Byb3h5bGVzcy91dGlscy9jZHAudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQ0EseURBQWdEO0FBSWhELHVDQUFtRDtBQUc1QyxLQUFLLFVBQVUsUUFBUSxDQUFFLE1BQW1CLEVBQUUsU0FBaUIsRUFBRSxHQUFXO0lBQy9FLE1BQU0sTUFBTSxDQUFDLEtBQUssQ0FBQyxjQUFjLENBQUM7UUFDOUIsU0FBUztRQUNULFlBQVksRUFBSywrQkFBVyxDQUFDLGlCQUFpQjtRQUM5QyxlQUFlLEVBQUU7WUFDYixFQUFFLElBQUksRUFBRSxVQUFVLEVBQUUsS0FBSyxFQUFFLEdBQUcsRUFBRTtTQUNuQztLQUNKLENBQUMsQ0FBQztBQUNQLENBQUM7QUFSRCw0QkFRQztBQUVNLEtBQUssVUFBVSxVQUFVLENBQUUsTUFBbUIsRUFBRSxHQUFXO0lBQzlELE1BQU0sTUFBTSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsRUFBRSxHQUFHLEVBQUUsQ0FBQyxDQUFDO0FBQ3hDLENBQUM7QUFGRCxnQ0FFQztBQUVELFNBQWdCLFNBQVMsQ0FBRSxLQUF5QjtJQUNoRCxPQUFPLEtBQUssQ0FBQyxrQkFBa0IsS0FBSyxLQUFLLENBQUMsQ0FBQztBQUMvQyxDQUFDO0FBRkQsOEJBRUM7QUFFRCxTQUFnQixvQkFBb0IsQ0FBRSxHQUFRO0lBQzFDLE9BQU8sR0FBRyxJQUFJLEdBQUcsQ0FBQyxPQUFPLElBQUksT0FBTyxHQUFHLENBQUMsT0FBTyxLQUFLLFFBQVEsQ0FBQztBQUNqRSxDQUFDO0FBRkQsb0RBRUM7QUFFRCxTQUFnQixrQkFBa0IsQ0FBRSxLQUF5QjtJQUN6RCxPQUFPLEtBQUssQ0FBQyxPQUFPLENBQUMsTUFBTSxLQUFLLFNBQVMsQ0FBQztBQUM5QyxDQUFDO0FBRkQsZ0RBRUM7QUFFRCxTQUFnQixtQ0FBbUMsQ0FBRSxjQUFtQyxFQUFFLFlBQWdDO0lBQ3RILE9BQU8sTUFBTSxDQUFDLE1BQU0sQ0FBQyxFQUFFLEVBQUUsWUFBWSxFQUFFO1FBQ25DLGtCQUFrQixFQUFFLGNBQWMsQ0FBQyxVQUFVO1FBQzdDLGVBQWUsRUFBSyxJQUFBLGdDQUFzQixFQUFDLGNBQWMsQ0FBQyxPQUFPLENBQUM7S0FDckUsQ0FBQyxDQUFDO0FBQ1AsQ0FBQztBQUxELGtGQUtDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUHJvdG9jb2xBcGkgfSBmcm9tICdjaHJvbWUtcmVtb3RlLWludGVyZmFjZSc7XG5pbXBvcnQgeyBTdGF0dXNDb2RlcyB9IGZyb20gJ2h0dHAtc3RhdHVzLWNvZGVzJztcbmltcG9ydCBQcm90b2NvbCBmcm9tICdkZXZ0b29scy1wcm90b2NvbCc7XG5pbXBvcnQgUmVxdWVzdFBhdXNlZEV2ZW50ID0gUHJvdG9jb2wuRmV0Y2guUmVxdWVzdFBhdXNlZEV2ZW50O1xuaW1wb3J0IHsgSW5jb21pbmdNZXNzYWdlTGlrZSB9IGZyb20gJ3Rlc3RjYWZlLWhhbW1lcmhlYWQnO1xuaW1wb3J0IHsgY29udmVydFRvSGVhZGVyRW50cmllcyB9IGZyb20gJy4vaGVhZGVycyc7XG5cblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIHJlZGlyZWN0IChjbGllbnQ6IFByb3RvY29sQXBpLCByZXF1ZXN0SWQ6IHN0cmluZywgdXJsOiBzdHJpbmcpOiBQcm9taXNlPHZvaWQ+IHtcbiAgICBhd2FpdCBjbGllbnQuRmV0Y2guZnVsZmlsbFJlcXVlc3Qoe1xuICAgICAgICByZXF1ZXN0SWQsXG4gICAgICAgIHJlc3BvbnNlQ29kZTogICAgU3RhdHVzQ29kZXMuTU9WRURfUEVSTUFORU5UTFksXG4gICAgICAgIHJlc3BvbnNlSGVhZGVyczogW1xuICAgICAgICAgICAgeyBuYW1lOiAnbG9jYXRpb24nLCB2YWx1ZTogdXJsIH0sXG4gICAgICAgIF0sXG4gICAgfSk7XG59XG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBuYXZpZ2F0ZVRvIChjbGllbnQ6IFByb3RvY29sQXBpLCB1cmw6IHN0cmluZyk6IFByb21pc2U8dm9pZD4ge1xuICAgIGF3YWl0IGNsaWVudC5QYWdlLm5hdmlnYXRlKHsgdXJsIH0pO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gaXNSZXF1ZXN0IChldmVudDogUmVxdWVzdFBhdXNlZEV2ZW50KTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIGV2ZW50LnJlc3BvbnNlU3RhdHVzQ29kZSA9PT0gdm9pZCAwO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gaXNSZXF1ZXN0UGF1c2VkRXZlbnQgKHZhbDogYW55KTogdmFsIGlzIFJlcXVlc3RQYXVzZWRFdmVudCB7XG4gICAgcmV0dXJuIHZhbCAmJiB2YWwuZnJhbWVJZCAmJiB0eXBlb2YgdmFsLnJlcXVlc3QgPT09ICdvYmplY3QnO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gaXNQcmVmbGlnaHRSZXF1ZXN0IChldmVudDogUmVxdWVzdFBhdXNlZEV2ZW50KTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIGV2ZW50LnJlcXVlc3QubWV0aG9kID09PSAnT1BUSU9OUyc7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVSZXF1ZXN0UGF1c2VkRXZlbnRGb3JSZXNwb25zZSAobW9ja2VkUmVzcG9uc2U6IEluY29taW5nTWVzc2FnZUxpa2UsIHJlcXVlc3RFdmVudDogUmVxdWVzdFBhdXNlZEV2ZW50KTogUmVxdWVzdFBhdXNlZEV2ZW50IHtcbiAgICByZXR1cm4gT2JqZWN0LmFzc2lnbih7fSwgcmVxdWVzdEV2ZW50LCB7XG4gICAgICAgIHJlc3BvbnNlU3RhdHVzQ29kZTogbW9ja2VkUmVzcG9uc2Uuc3RhdHVzQ29kZSxcbiAgICAgICAgcmVzcG9uc2VIZWFkZXJzOiAgICBjb252ZXJ0VG9IZWFkZXJFbnRyaWVzKG1vY2tlZFJlc3BvbnNlLmhlYWRlcnMpLFxuICAgIH0pO1xufVxuIl19
60
+ function getRequestId(event) {
61
+ if (isRequestPausedEvent(event))
62
+ return event.networkId;
63
+ return event.frame.loaderId;
64
+ }
65
+ exports.getRequestId = getRequestId;
66
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2RwLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3Byb3h5bGVzcy91dGlscy9jZHAudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQ0EseURBQWdEO0FBS2hELHVDQUFtRDtBQUNuRCxvQ0FBcUM7QUFHOUIsS0FBSyxVQUFVLFFBQVEsQ0FBRSxNQUFtQixFQUFFLFNBQWlCLEVBQUUsR0FBVztJQUMvRSxNQUFNLE1BQU0sQ0FBQyxLQUFLLENBQUMsY0FBYyxDQUFDO1FBQzlCLFNBQVM7UUFDVCxZQUFZLEVBQUssK0JBQVcsQ0FBQyxpQkFBaUI7UUFDOUMsZUFBZSxFQUFFO1lBQ2IsRUFBRSxJQUFJLEVBQUUsVUFBVSxFQUFFLEtBQUssRUFBRSxHQUFHLEVBQUU7U0FDbkM7S0FDSixDQUFDLENBQUM7QUFDUCxDQUFDO0FBUkQsNEJBUUM7QUFFTSxLQUFLLFVBQVUsVUFBVSxDQUFFLE1BQW1CLEVBQUUsR0FBVztJQUM5RCxNQUFNLE1BQU0sQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLEVBQUUsR0FBRyxFQUFFLENBQUMsQ0FBQztBQUN4QyxDQUFDO0FBRkQsZ0NBRUM7QUFFTSxLQUFLLFVBQVUsYUFBYSxDQUFFLE1BQW1CLEVBQUUsSUFBZSxFQUFFLE9BQVk7SUFDbkYsUUFBUSxDQUFDLElBQUksRUFBRTtRQUNYLEtBQUssaUJBQVMsQ0FBQyxLQUFLO1lBQ2hCLE1BQU0sTUFBTSxDQUFDLEtBQUssQ0FBQyxrQkFBa0IsQ0FBQyxPQUFPLENBQUMsQ0FBQztZQUMvQyxNQUFNO1FBQ1YsS0FBSyxpQkFBUyxDQUFDLEdBQUc7WUFDZCxNQUFNLE1BQU0sQ0FBQyxLQUFLLENBQUMsZ0JBQWdCLENBQUMsT0FBTyxDQUFDLENBQUM7WUFDN0MsTUFBTTtRQUNWLEtBQUssaUJBQVMsQ0FBQyxLQUFLO1lBQ2hCLE1BQU0sTUFBTSxDQUFDLEtBQUssQ0FBQyxrQkFBa0IsQ0FBQyxPQUFPLENBQUMsQ0FBQztZQUMvQyxNQUFNO1FBQ1Y7WUFDSSxNQUFNLElBQUksS0FBSyxDQUFDLFlBQVksT0FBTyxDQUFDLElBQUksY0FBYyxDQUFDLENBQUM7S0FDL0Q7QUFDTCxDQUFDO0FBZEQsc0NBY0M7QUFFRCxTQUFnQixTQUFTLENBQUUsS0FBeUI7SUFDaEQsT0FBTyxLQUFLLENBQUMsa0JBQWtCLEtBQUssS0FBSyxDQUFDLENBQUM7QUFDL0MsQ0FBQztBQUZELDhCQUVDO0FBRUQsU0FBZ0IsY0FBYyxDQUFFLFVBQWtCO0lBQzlDLE9BQU8sVUFBVSxLQUFLLEdBQUcsQ0FBQztBQUM5QixDQUFDO0FBRkQsd0NBRUM7QUFFRCxTQUFnQixvQkFBb0IsQ0FBRSxHQUFRO0lBQzFDLE9BQU8sR0FBRyxJQUFJLEdBQUcsQ0FBQyxPQUFPLElBQUksT0FBTyxHQUFHLENBQUMsT0FBTyxLQUFLLFFBQVEsQ0FBQztBQUNqRSxDQUFDO0FBRkQsb0RBRUM7QUFFRCxTQUFnQixrQkFBa0IsQ0FBRSxLQUF5QjtJQUN6RCxPQUFPLEtBQUssQ0FBQyxPQUFPLENBQUMsTUFBTSxLQUFLLFNBQVMsQ0FBQztBQUM5QyxDQUFDO0FBRkQsZ0RBRUM7QUFFRCxTQUFnQixtQ0FBbUMsQ0FBRSxjQUFtQyxFQUFFLFlBQWdDO0lBQ3RILE9BQU8sTUFBTSxDQUFDLE1BQU0sQ0FBQyxFQUFFLEVBQUUsWUFBWSxFQUFFO1FBQ25DLGtCQUFrQixFQUFFLGNBQWMsQ0FBQyxVQUFVO1FBQzdDLGVBQWUsRUFBSyxJQUFBLGdDQUFzQixFQUFDLGNBQWMsQ0FBQyxPQUFPLENBQUM7S0FDckUsQ0FBQyxDQUFDO0FBQ1AsQ0FBQztBQUxELGtGQUtDO0FBRUQsU0FBZ0IsWUFBWSxDQUFFLEtBQStDO0lBQ3pFLElBQUksb0JBQW9CLENBQUMsS0FBSyxDQUFDO1FBQzNCLE9BQU8sS0FBSyxDQUFDLFNBQW1CLENBQUM7SUFFckMsT0FBTyxLQUFLLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQztBQUNoQyxDQUFDO0FBTEQsb0NBS0MiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQcm90b2NvbEFwaSB9IGZyb20gJ2Nocm9tZS1yZW1vdGUtaW50ZXJmYWNlJztcbmltcG9ydCB7IFN0YXR1c0NvZGVzIH0gZnJvbSAnaHR0cC1zdGF0dXMtY29kZXMnO1xuaW1wb3J0IFByb3RvY29sIGZyb20gJ2RldnRvb2xzLXByb3RvY29sJztcbmltcG9ydCBSZXF1ZXN0UGF1c2VkRXZlbnQgPSBQcm90b2NvbC5GZXRjaC5SZXF1ZXN0UGF1c2VkRXZlbnQ7XG5pbXBvcnQgRnJhbWVOYXZpZ2F0ZWRFdmVudCA9IFByb3RvY29sLlBhZ2UuRnJhbWVOYXZpZ2F0ZWRFdmVudDtcbmltcG9ydCB7IEluY29taW5nTWVzc2FnZUxpa2UgfSBmcm9tICd0ZXN0Y2FmZS1oYW1tZXJoZWFkJztcbmltcG9ydCB7IGNvbnZlcnRUb0hlYWRlckVudHJpZXMgfSBmcm9tICcuL2hlYWRlcnMnO1xuaW1wb3J0IHsgRXZlbnRUeXBlIH0gZnJvbSAnLi4vdHlwZXMnO1xuXG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiByZWRpcmVjdCAoY2xpZW50OiBQcm90b2NvbEFwaSwgcmVxdWVzdElkOiBzdHJpbmcsIHVybDogc3RyaW5nKTogUHJvbWlzZTx2b2lkPiB7XG4gICAgYXdhaXQgY2xpZW50LkZldGNoLmZ1bGZpbGxSZXF1ZXN0KHtcbiAgICAgICAgcmVxdWVzdElkLFxuICAgICAgICByZXNwb25zZUNvZGU6ICAgIFN0YXR1c0NvZGVzLk1PVkVEX1BFUk1BTkVOVExZLFxuICAgICAgICByZXNwb25zZUhlYWRlcnM6IFtcbiAgICAgICAgICAgIHsgbmFtZTogJ2xvY2F0aW9uJywgdmFsdWU6IHVybCB9LFxuICAgICAgICBdLFxuICAgIH0pO1xufVxuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gbmF2aWdhdGVUbyAoY2xpZW50OiBQcm90b2NvbEFwaSwgdXJsOiBzdHJpbmcpOiBQcm9taXNlPHZvaWQ+IHtcbiAgICBhd2FpdCBjbGllbnQuUGFnZS5uYXZpZ2F0ZSh7IHVybCB9KTtcbn1cblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGRpc3BhdGNoRXZlbnQgKGNsaWVudDogUHJvdG9jb2xBcGksIHR5cGU6IEV2ZW50VHlwZSwgb3B0aW9uczogYW55KTogUHJvbWlzZTx2b2lkPiB7XG4gICAgc3dpdGNoICgrdHlwZSkge1xuICAgICAgICBjYXNlIEV2ZW50VHlwZS5Nb3VzZTpcbiAgICAgICAgICAgIGF3YWl0IGNsaWVudC5JbnB1dC5kaXNwYXRjaE1vdXNlRXZlbnQob3B0aW9ucyk7XG4gICAgICAgICAgICBicmVhaztcbiAgICAgICAgY2FzZSBFdmVudFR5cGUuS2V5OlxuICAgICAgICAgICAgYXdhaXQgY2xpZW50LklucHV0LmRpc3BhdGNoS2V5RXZlbnQob3B0aW9ucyk7XG4gICAgICAgICAgICBicmVhaztcbiAgICAgICAgY2FzZSBFdmVudFR5cGUuVG91Y2g6XG4gICAgICAgICAgICBhd2FpdCBjbGllbnQuSW5wdXQuZGlzcGF0Y2hUb3VjaEV2ZW50KG9wdGlvbnMpO1xuICAgICAgICAgICAgYnJlYWs7XG4gICAgICAgIGRlZmF1bHQ6XG4gICAgICAgICAgICB0aHJvdyBuZXcgRXJyb3IoYFVua25vd24gXCIke29wdGlvbnMudHlwZX1cIiBldmVudCB0eXBlYCk7XG4gICAgfVxufVxuXG5leHBvcnQgZnVuY3Rpb24gaXNSZXF1ZXN0IChldmVudDogUmVxdWVzdFBhdXNlZEV2ZW50KTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIGV2ZW50LnJlc3BvbnNlU3RhdHVzQ29kZSA9PT0gdm9pZCAwO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gaXNVbmF1dGhvcml6ZWQgKHN0YXR1c0NvZGU6IG51bWJlcik6IGJvb2xlYW4ge1xuICAgIHJldHVybiBzdGF0dXNDb2RlID09PSA0MDE7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBpc1JlcXVlc3RQYXVzZWRFdmVudCAodmFsOiBhbnkpOiB2YWwgaXMgUmVxdWVzdFBhdXNlZEV2ZW50IHtcbiAgICByZXR1cm4gdmFsICYmIHZhbC5mcmFtZUlkICYmIHR5cGVvZiB2YWwucmVxdWVzdCA9PT0gJ29iamVjdCc7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBpc1ByZWZsaWdodFJlcXVlc3QgKGV2ZW50OiBSZXF1ZXN0UGF1c2VkRXZlbnQpOiBib29sZWFuIHtcbiAgICByZXR1cm4gZXZlbnQucmVxdWVzdC5tZXRob2QgPT09ICdPUFRJT05TJztcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZVJlcXVlc3RQYXVzZWRFdmVudEZvclJlc3BvbnNlIChtb2NrZWRSZXNwb25zZTogSW5jb21pbmdNZXNzYWdlTGlrZSwgcmVxdWVzdEV2ZW50OiBSZXF1ZXN0UGF1c2VkRXZlbnQpOiBSZXF1ZXN0UGF1c2VkRXZlbnQge1xuICAgIHJldHVybiBPYmplY3QuYXNzaWduKHt9LCByZXF1ZXN0RXZlbnQsIHtcbiAgICAgICAgcmVzcG9uc2VTdGF0dXNDb2RlOiBtb2NrZWRSZXNwb25zZS5zdGF0dXNDb2RlLFxuICAgICAgICByZXNwb25zZUhlYWRlcnM6ICAgIGNvbnZlcnRUb0hlYWRlckVudHJpZXMobW9ja2VkUmVzcG9uc2UuaGVhZGVycyksXG4gICAgfSk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXRSZXF1ZXN0SWQgKGV2ZW50OiBSZXF1ZXN0UGF1c2VkRXZlbnQgfCBGcmFtZU5hdmlnYXRlZEV2ZW50KTogc3RyaW5nIHtcbiAgICBpZiAoaXNSZXF1ZXN0UGF1c2VkRXZlbnQoZXZlbnQpKVxuICAgICAgICByZXR1cm4gZXZlbnQubmV0d29ya0lkIGFzIHN0cmluZztcblxuICAgIHJldHVybiBldmVudC5mcmFtZS5sb2FkZXJJZDtcbn1cbiJdfQ==
@@ -0,0 +1,8 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.getActiveClient = void 0;
4
+ async function getActiveClient(connection) {
5
+ return connection.provider.plugin.openedBrowsers[connection.id].browserClient.getActiveClient();
6
+ }
7
+ exports.getActiveClient = getActiveClient;
8
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2V0LWFjdGl2ZS1jbGllbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvcHJveHlsZXNzL3V0aWxzL2dldC1hY3RpdmUtY2xpZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUdPLEtBQUssVUFBVSxlQUFlLENBQUUsVUFBNkI7SUFDaEUsT0FBTyxVQUFVLENBQUMsUUFBUSxDQUFDLE1BQU0sQ0FBQyxjQUFjLENBQUMsVUFBVSxDQUFDLEVBQUUsQ0FBQyxDQUFDLGFBQWEsQ0FBQyxlQUFlLEVBQUUsQ0FBQztBQUNwRyxDQUFDO0FBRkQsMENBRUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgcmVtb3RlQ2hyb21lIGZyb20gJ2Nocm9tZS1yZW1vdGUtaW50ZXJmYWNlJztcbmltcG9ydCBCcm93c2VyQ29ubmVjdGlvbiBmcm9tICcuLi8uLi9icm93c2VyL2Nvbm5lY3Rpb24nO1xuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gZ2V0QWN0aXZlQ2xpZW50IChjb25uZWN0aW9uOiBCcm93c2VyQ29ubmVjdGlvbik6IFByb21pc2U8cmVtb3RlQ2hyb21lLlByb3RvY29sQXBpPiB7XG4gICAgcmV0dXJuIGNvbm5lY3Rpb24ucHJvdmlkZXIucGx1Z2luLm9wZW5lZEJyb3dzZXJzW2Nvbm5lY3Rpb24uaWRdLmJyb3dzZXJDbGllbnQuZ2V0QWN0aXZlQ2xpZW50KCk7XG59XG4iXX0=
@@ -99,12 +99,13 @@ class Bootstrapper {
99
99
  }
100
100
  async _compileTests({ sourceList, compilerOptions, runnableConfigurationId }) {
101
101
  const baseUrl = this.configuration.getOption(option_names_1.default.baseUrl);
102
+ const experimentalEsm = this.configuration.getOption(option_names_1.default.experimentalEsm);
102
103
  if (this.compilerService) {
103
104
  await this.compilerService.init();
104
105
  await this.compilerService.setUserVariables(user_variables_1.default.value);
105
106
  return this.compilerService.getTests({ sourceList, compilerOptions, runnableConfigurationId }, baseUrl);
106
107
  }
107
- const compiler = new compiler_1.default(sourceList, compilerOptions, { baseUrl, isCompilerServiceMode: false });
108
+ const compiler = new compiler_1.default(sourceList, compilerOptions, { baseUrl, isCompilerServiceMode: false, experimentalEsm });
108
109
  return compiler.getTests();
109
110
  }
110
111
  _assertGlobalHooks() {
@@ -239,4 +240,4 @@ class Bootstrapper {
239
240
  }
240
241
  exports.default = Bootstrapper;
241
242
  module.exports = exports.default;
242
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bootstrapper.js","sourceRoot":"","sources":["../../src/runner/bootstrapper.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    chunk,\n    times,\n    union,\n    castArray,\n    flattenDeep as flatten,\n} from 'lodash';\n\nimport debug from 'debug';\nimport prettyTime from 'pretty-hrtime';\nimport Compiler from '../compiler';\nimport BrowserConnection, { BrowserInfo } from '../browser/connection';\nimport BrowserSet from './browser-set';\nimport { GeneralError } from '../errors/runtime';\nimport { RUNTIME_ERRORS } from '../errors/types';\nimport TestedApp from './tested-app';\nimport parseFileList from '../utils/parse-file-list';\nimport loadClientScripts from '../custom-client-scripts/load';\nimport { getConcatenatedValuesString } from '../utils/string';\nimport { ReporterSource } from '../reporter/interfaces';\nimport ClientScript from '../custom-client-scripts/client-script';\nimport ClientScriptInit from '../custom-client-scripts/client-script-init';\nimport BrowserConnectionGateway from '../browser/connection/gateway';\nimport { CompilerArguments } from '../compiler/interfaces';\nimport CompilerService from '../services/compiler/host';\nimport Test from '../api/structure/test';\nimport { BootstrapperInit, BrowserSetOptions } from './interfaces';\nimport WarningLog from '../notifications/warning-log';\nimport WARNING_MESSAGES from '../notifications/warning-message';\nimport guardTimeExecution from '../utils/guard-time-execution';\nimport asyncFilter from '../utils/async-filter';\nimport Fixture from '../api/structure/fixture';\nimport MessageBus from '../utils/message-bus';\nimport wrapTestFunction from '../api/wrap-test-function';\nimport { assertType, is } from '../errors/runtime/type-assertions';\nimport { generateUniqueId } from 'testcafe-hammerhead';\nimport assertRequestHookType from '../api/request-hooks/assert-type';\nimport userVariables from '../api/user-variables';\nimport Configuration from '../configuration/configuration-base';\nimport OPTION_NAMES from '../configuration/option-names';\n\nconst DEBUG_SCOPE = 'testcafe:bootstrapper';\n\ntype TestSource = unknown;\n\ntype BrowserInfoSource = BrowserInfo | BrowserConnection;\n\ninterface PromiseSuccess<T> {\n    result: T;\n}\n\ninterface PromiseError<E extends Error = Error> {\n    error: E;\n}\n\ninterface BasicRuntimeResources {\n    browserSet: BrowserSet;\n    tests: Test[];\n    testedApp?: TestedApp;\n}\n\ninterface RunnableConfiguration extends BasicRuntimeResources {\n    commonClientScripts: ClientScript[];\n    id: string;\n}\n\ntype PromiseResult<T, E extends Error = Error> = PromiseSuccess<T> | PromiseError<E>;\n\nfunction isPromiseError<T, E extends Error = Error> (value: PromiseResult<T, E>): value is PromiseError<E> {\n    return (value as PromiseError<E>).error !== void 0;\n}\n\ninterface SeparatedBrowserInfo {\n    remotes: BrowserConnection[];\n    automated: BrowserInfo[];\n}\n\ntype PromiseCollection<T> = {\n    [K in keyof T]: Promise<T[K]>\n}\n\ntype ResultCollection<T> = { [P in keyof T]: PromiseResult<T[P]> };\n\nexport default class Bootstrapper {\n    private readonly browserConnectionGateway: BrowserConnectionGateway;\n    public concurrency: number;\n    public sources: TestSource[];\n    public browsers: BrowserInfoSource[];\n    public reporters: ReporterSource[];\n    public filter?: FilterFunction;\n    public appCommand?: string;\n    public appInitDelay?: number;\n    public tsConfigPath?: string;\n    public clientScripts: ClientScriptInit[];\n    public disableMultipleWindows: boolean;\n    public proxyless: boolean;\n    public compilerOptions?: CompilerOptions;\n    public browserInitTimeout?: number;\n    public hooks?: GlobalHooks;\n    public configuration: Configuration;\n\n    private readonly compilerService?: CompilerService;\n    private readonly debugLogger: debug.Debugger;\n    private readonly warningLog: WarningLog;\n    private readonly messageBus: MessageBus;\n\n    private readonly TESTS_COMPILATION_UPPERBOUND: number;\n\n    public constructor ({ browserConnectionGateway, compilerService, messageBus, configuration }: BootstrapperInit) {\n        this.browserConnectionGateway = browserConnectionGateway;\n        this.concurrency              = 1;\n        this.sources                  = [];\n        this.browsers                 = [];\n        this.reporters                = [];\n        this.filter                   = void 0;\n        this.appCommand               = void 0;\n        this.appInitDelay             = void 0;\n        this.tsConfigPath             = void 0;\n        this.clientScripts            = [];\n        this.disableMultipleWindows   = false;\n        this.proxyless                = false;\n        this.compilerOptions          = void 0;\n        this.debugLogger              = debug(DEBUG_SCOPE);\n        this.warningLog               = new WarningLog(null, WarningLog.createAddWarningCallback(messageBus));\n        this.compilerService          = compilerService;\n        this.messageBus               = messageBus;\n        this.configuration            = configuration;\n\n        this.TESTS_COMPILATION_UPPERBOUND = 60;\n    }\n\n    private static _getBrowserName (browser: BrowserInfoSource): string {\n        if (browser instanceof BrowserConnection)\n            return browser.browserInfo.browserName;\n\n        return browser.browserName;\n    }\n\n    private static _splitBrowserInfo (browserInfo: BrowserInfoSource[]): SeparatedBrowserInfo {\n        const remotes: BrowserConnection[]  = [];\n        const automated: BrowserInfo[]      = [];\n\n        browserInfo.forEach(browser => {\n            if (browser instanceof BrowserConnection)\n                remotes.push(browser);\n            else\n                automated.push(browser);\n        });\n\n        return { remotes, automated };\n    }\n\n    private _createAutomatedConnections (browserInfo: BrowserInfo[]): BrowserConnection[][] {\n        if (!browserInfo)\n            return [];\n\n        return browserInfo\n            .map(browser => times(this.concurrency, () => new BrowserConnection(\n                this.browserConnectionGateway, { ...browser }, false, this.disableMultipleWindows, this.proxyless, this.messageBus)));\n    }\n\n    private _getBrowserSetOptions (): BrowserSetOptions {\n        return {\n            concurrency:        this.concurrency,\n            browserInitTimeout: this.browserInitTimeout,\n            warningLog:         this.warningLog,\n        };\n    }\n\n    private async _getBrowserConnections (browserInfo: BrowserInfoSource[]): Promise<BrowserSet> {\n        const { automated, remotes } = Bootstrapper._splitBrowserInfo(browserInfo);\n\n        if (remotes && remotes.length % this.concurrency)\n            throw new GeneralError(RUNTIME_ERRORS.cannotDivideRemotesCountByConcurrency);\n\n        let browserConnections = this._createAutomatedConnections(automated);\n\n        remotes.forEach(remoteConnection => {\n            remoteConnection.messageBus = this.messageBus;\n        });\n\n        browserConnections = browserConnections.concat(chunk(remotes, this.concurrency));\n\n        return BrowserSet.from(browserConnections, this._getBrowserSetOptions());\n    }\n\n    private async _filterTests (tests: Test[], predicate: FilterFunction): Promise<Test[]> {\n        return asyncFilter(tests, test => {\n            const testFixture = test.fixture as Fixture;\n\n            return predicate(\n                test.name as string,\n                testFixture.name as string,\n                testFixture.path,\n                test.meta,\n                testFixture.meta);\n        });\n    }\n\n    private async _compileTests ({ sourceList, compilerOptions, runnableConfigurationId }: CompilerArguments): Promise<Test[]> {\n        const baseUrl  = this.configuration.getOption(OPTION_NAMES.baseUrl) as string;\n\n        if (this.compilerService) {\n            await this.compilerService.init();\n            await this.compilerService.setUserVariables(userVariables.value);\n\n            return this.compilerService.getTests({ sourceList, compilerOptions, runnableConfigurationId }, baseUrl);\n        }\n\n        const compiler = new Compiler(sourceList, compilerOptions, { baseUrl, isCompilerServiceMode: false });\n\n        return compiler.getTests();\n    }\n\n    private _assertGlobalHooks (): void {\n        if (!this.hooks)\n            return;\n\n        if (this.hooks.fixture?.before)\n            assertType(is.function, 'globalBefore', 'The fixture.globalBefore hook', this.hooks.fixture.before);\n\n        if (this.hooks.fixture?.after)\n            assertType(is.function, 'globalAfter', 'The fixture.globalAfter hook', this.hooks.fixture.after);\n\n        if (this.hooks.test?.before)\n            assertType(is.function, 'globalBefore', 'The test.globalBefore hook', this.hooks.test.before);\n\n        if (this.hooks.test?.after)\n            assertType(is.function, 'globalAfter', 'The test.globalAfter hook', this.hooks.test.after);\n\n        if (this.hooks.request)\n            assertRequestHookType(flatten(castArray(this.hooks.request)));\n    }\n\n    private _setGlobalHooksToTests (tests: Test[]): void {\n        if (!this.hooks)\n            return;\n\n        this._assertGlobalHooks();\n\n        const fixtureBefore = this.hooks.fixture?.before || null;\n        const fixtureAfter  = this.hooks.fixture?.after || null;\n        const testBefore    = this.hooks.test?.before ? wrapTestFunction(this.hooks.test.before) : null;\n        const testAfter     = this.hooks.test?.after ? wrapTestFunction(this.hooks.test.after) : null;\n        const request       = this.hooks.request || [];\n\n        tests.forEach(item => {\n            if (item.fixture) {\n                item.fixture.globalBeforeFn = item.fixture.globalBeforeFn || fixtureBefore;\n                item.fixture.globalAfterFn  = item.fixture.globalAfterFn || fixtureAfter;\n            }\n\n            item.globalBeforeFn = testBefore;\n            item.globalAfterFn  = testAfter;\n            item.requestHooks   = union(flatten(castArray(request)), item.requestHooks);\n        });\n    }\n\n    private async _getTests (id: string): Promise<Test[]> {\n        const cwd        = process.cwd();\n        const sourceList = await parseFileList(this.sources, cwd);\n\n        if (!sourceList.length)\n            throw new GeneralError(RUNTIME_ERRORS.testFilesNotFound, cwd, getConcatenatedValuesString(this.sources, '\\n', ''));\n\n        let tests = await guardTimeExecution(\n            async () => await this._compileTests({ sourceList, compilerOptions: this.compilerOptions, runnableConfigurationId: id }),\n            elapsedTime => {\n                this.debugLogger(`tests compilation took ${prettyTime(elapsedTime)}`);\n\n                const [ elapsedSeconds ] = elapsedTime;\n\n                if (elapsedSeconds > this.TESTS_COMPILATION_UPPERBOUND)\n                    this.warningLog.addWarning(WARNING_MESSAGES.testsCompilationTakesTooLong, prettyTime(elapsedTime));\n            }\n        );\n\n        const testsWithOnlyFlag = tests.filter(test => test.only);\n\n        if (testsWithOnlyFlag.length)\n            tests = testsWithOnlyFlag;\n\n        if (!tests.length)\n            throw new GeneralError(RUNTIME_ERRORS.noTestsToRun);\n\n        if (this.filter)\n            tests = await this._filterTests(tests, this.filter);\n\n        if (!tests.length)\n            throw new GeneralError(RUNTIME_ERRORS.noTestsToRunDueFiltering);\n\n        this._setGlobalHooksToTests(tests);\n\n        return tests;\n    }\n\n    private async _startTestedApp (): Promise<TestedApp|undefined> {\n        if (!this.appCommand)\n            return void 0;\n\n        const testedApp = new TestedApp();\n\n        await testedApp.start(this.appCommand, this.appInitDelay as number);\n\n        return testedApp;\n    }\n\n    private async _canUseParallelBootstrapping (browserInfo: BrowserInfoSource[]): Promise<boolean> {\n        const isLocalPromises = browserInfo.map(browser => browser.provider.isLocalBrowser(void 0, Bootstrapper._getBrowserName(browser)));\n        const isLocalBrowsers = await Promise.all(isLocalPromises);\n\n        return isLocalBrowsers.every(result => result);\n    }\n\n    private async _bootstrapSequence (browserInfo: BrowserInfoSource[], id: string): Promise<BasicRuntimeResources> {\n        const tests       = await this._getTests(id);\n        const testedApp   = await this._startTestedApp();\n        const browserSet  = await this._getBrowserConnections(browserInfo);\n\n        return { tests, testedApp, browserSet };\n    }\n\n    private _wrapBootstrappingPromise<T> (promise: Promise<T>): Promise<PromiseResult<T>> {\n        return promise\n            .then(result => ({ error: void 0, result }))\n            .catch(error => ({ result: void 0, error }));\n    }\n\n    private async _getBootstrappingError (browserSetStatus: PromiseResult<BrowserSet>, testsStatus: PromiseResult<Test[]>, testedAppStatus: PromiseResult<TestedApp|undefined>): Promise<Error> {\n        if (!isPromiseError(browserSetStatus))\n            await browserSetStatus.result.dispose();\n\n        if (!isPromiseError(browserSetStatus) && !isPromiseError(testedAppStatus) && testedAppStatus.result)\n            await testedAppStatus.result.kill();\n\n        if (isPromiseError(testsStatus))\n            return testsStatus.error;\n\n        if (isPromiseError(testedAppStatus))\n            return testedAppStatus.error;\n\n        if (isPromiseError(browserSetStatus))\n            return browserSetStatus.error;\n\n        return new Error('Unexpected call');\n    }\n\n    private _getBootstrappingPromises<T> (arg: PromiseCollection<T>): PromiseCollection<ResultCollection<T>> {\n        const result = {} as unknown as PromiseCollection<ResultCollection<T>>;\n\n        for (const k in arg)\n            result[k] = this._wrapBootstrappingPromise(arg[k]);\n\n        return result;\n    }\n\n    private async _bootstrapParallel (browserInfo: BrowserInfoSource[], id: string): Promise<BasicRuntimeResources> {\n        const bootstrappingPromises = {\n            browserSet: this._getBrowserConnections(browserInfo),\n            tests:      this._getTests(id),\n            app:        this._startTestedApp(),\n        };\n\n        const bootstrappingResultPromises = this._getBootstrappingPromises(bootstrappingPromises);\n\n        const bootstrappingResults = await Promise.all([\n            bootstrappingResultPromises.browserSet,\n            bootstrappingResultPromises.tests,\n            bootstrappingResultPromises.app,\n        ]);\n\n        const [browserSetResults, testResults, appResults] = bootstrappingResults;\n\n        if (isPromiseError(browserSetResults) || isPromiseError(testResults) || isPromiseError(appResults))\n            throw await this._getBootstrappingError(...bootstrappingResults);\n\n        return {\n            browserSet: browserSetResults.result,\n            tests:      testResults.result,\n            testedApp:  appResults.result,\n        };\n    }\n\n    // API\n    public async createRunnableConfiguration (): Promise<RunnableConfiguration> {\n        const id                  = generateUniqueId();\n        const commonClientScripts = await loadClientScripts(this.clientScripts);\n\n        if (await this._canUseParallelBootstrapping(this.browsers))\n            return { ...await this._bootstrapParallel(this.browsers, id), commonClientScripts, id };\n\n        return { ...await this._bootstrapSequence(this.browsers, id), commonClientScripts, id };\n    }\n}\n"]}
243
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bootstrapper.js","sourceRoot":"","sources":["../../src/runner/bootstrapper.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    chunk,\n    times,\n    union,\n    castArray,\n    flattenDeep as flatten,\n} from 'lodash';\n\nimport debug from 'debug';\nimport prettyTime from 'pretty-hrtime';\nimport Compiler from '../compiler';\nimport BrowserConnection, { BrowserInfo } from '../browser/connection';\nimport BrowserSet from './browser-set';\nimport { GeneralError } from '../errors/runtime';\nimport { RUNTIME_ERRORS } from '../errors/types';\nimport TestedApp from './tested-app';\nimport parseFileList from '../utils/parse-file-list';\nimport loadClientScripts from '../custom-client-scripts/load';\nimport { getConcatenatedValuesString } from '../utils/string';\nimport { ReporterSource } from '../reporter/interfaces';\nimport ClientScript from '../custom-client-scripts/client-script';\nimport ClientScriptInit from '../custom-client-scripts/client-script-init';\nimport BrowserConnectionGateway from '../browser/connection/gateway';\nimport { CompilerArguments } from '../compiler/interfaces';\nimport CompilerService from '../services/compiler/host';\nimport Test from '../api/structure/test';\nimport { BootstrapperInit, BrowserSetOptions } from './interfaces';\nimport WarningLog from '../notifications/warning-log';\nimport WARNING_MESSAGES from '../notifications/warning-message';\nimport guardTimeExecution from '../utils/guard-time-execution';\nimport asyncFilter from '../utils/async-filter';\nimport Fixture from '../api/structure/fixture';\nimport MessageBus from '../utils/message-bus';\nimport wrapTestFunction from '../api/wrap-test-function';\nimport { assertType, is } from '../errors/runtime/type-assertions';\nimport { generateUniqueId } from 'testcafe-hammerhead';\nimport assertRequestHookType from '../api/request-hooks/assert-type';\nimport userVariables from '../api/user-variables';\nimport Configuration from '../configuration/configuration-base';\nimport OPTION_NAMES from '../configuration/option-names';\n\nconst DEBUG_SCOPE = 'testcafe:bootstrapper';\n\ntype TestSource = unknown;\n\ntype BrowserInfoSource = BrowserInfo | BrowserConnection;\n\ninterface PromiseSuccess<T> {\n    result: T;\n}\n\ninterface PromiseError<E extends Error = Error> {\n    error: E;\n}\n\ninterface BasicRuntimeResources {\n    browserSet: BrowserSet;\n    tests: Test[];\n    testedApp?: TestedApp;\n}\n\ninterface RunnableConfiguration extends BasicRuntimeResources {\n    commonClientScripts: ClientScript[];\n    id: string;\n}\n\ntype PromiseResult<T, E extends Error = Error> = PromiseSuccess<T> | PromiseError<E>;\n\nfunction isPromiseError<T, E extends Error = Error> (value: PromiseResult<T, E>): value is PromiseError<E> {\n    return (value as PromiseError<E>).error !== void 0;\n}\n\ninterface SeparatedBrowserInfo {\n    remotes: BrowserConnection[];\n    automated: BrowserInfo[];\n}\n\ntype PromiseCollection<T> = {\n    [K in keyof T]: Promise<T[K]>\n}\n\ntype ResultCollection<T> = { [P in keyof T]: PromiseResult<T[P]> };\n\nexport default class Bootstrapper {\n    private readonly browserConnectionGateway: BrowserConnectionGateway;\n    public concurrency: number;\n    public sources: TestSource[];\n    public browsers: BrowserInfoSource[];\n    public reporters: ReporterSource[];\n    public filter?: FilterFunction;\n    public appCommand?: string;\n    public appInitDelay?: number;\n    public tsConfigPath?: string;\n    public clientScripts: ClientScriptInit[];\n    public disableMultipleWindows: boolean;\n    public proxyless: boolean;\n    public compilerOptions?: CompilerOptions;\n    public browserInitTimeout?: number;\n    public hooks?: GlobalHooks;\n    public configuration: Configuration;\n\n    private readonly compilerService?: CompilerService;\n    private readonly debugLogger: debug.Debugger;\n    private readonly warningLog: WarningLog;\n    private readonly messageBus: MessageBus;\n\n    private readonly TESTS_COMPILATION_UPPERBOUND: number;\n\n    public constructor ({ browserConnectionGateway, compilerService, messageBus, configuration }: BootstrapperInit) {\n        this.browserConnectionGateway = browserConnectionGateway;\n        this.concurrency              = 1;\n        this.sources                  = [];\n        this.browsers                 = [];\n        this.reporters                = [];\n        this.filter                   = void 0;\n        this.appCommand               = void 0;\n        this.appInitDelay             = void 0;\n        this.tsConfigPath             = void 0;\n        this.clientScripts            = [];\n        this.disableMultipleWindows   = false;\n        this.proxyless                = false;\n        this.compilerOptions          = void 0;\n        this.debugLogger              = debug(DEBUG_SCOPE);\n        this.warningLog               = new WarningLog(null, WarningLog.createAddWarningCallback(messageBus));\n        this.compilerService          = compilerService;\n        this.messageBus               = messageBus;\n        this.configuration            = configuration;\n\n        this.TESTS_COMPILATION_UPPERBOUND = 60;\n    }\n\n    private static _getBrowserName (browser: BrowserInfoSource): string {\n        if (browser instanceof BrowserConnection)\n            return browser.browserInfo.browserName;\n\n        return browser.browserName;\n    }\n\n    private static _splitBrowserInfo (browserInfo: BrowserInfoSource[]): SeparatedBrowserInfo {\n        const remotes: BrowserConnection[]  = [];\n        const automated: BrowserInfo[]      = [];\n\n        browserInfo.forEach(browser => {\n            if (browser instanceof BrowserConnection)\n                remotes.push(browser);\n            else\n                automated.push(browser);\n        });\n\n        return { remotes, automated };\n    }\n\n    private _createAutomatedConnections (browserInfo: BrowserInfo[]): BrowserConnection[][] {\n        if (!browserInfo)\n            return [];\n\n        return browserInfo\n            .map(browser => times(this.concurrency, () => new BrowserConnection(\n                this.browserConnectionGateway, { ...browser }, false, this.disableMultipleWindows, this.proxyless, this.messageBus)));\n    }\n\n    private _getBrowserSetOptions (): BrowserSetOptions {\n        return {\n            concurrency:        this.concurrency,\n            browserInitTimeout: this.browserInitTimeout,\n            warningLog:         this.warningLog,\n        };\n    }\n\n    private async _getBrowserConnections (browserInfo: BrowserInfoSource[]): Promise<BrowserSet> {\n        const { automated, remotes } = Bootstrapper._splitBrowserInfo(browserInfo);\n\n        if (remotes && remotes.length % this.concurrency)\n            throw new GeneralError(RUNTIME_ERRORS.cannotDivideRemotesCountByConcurrency);\n\n        let browserConnections = this._createAutomatedConnections(automated);\n\n        remotes.forEach(remoteConnection => {\n            remoteConnection.messageBus = this.messageBus;\n        });\n\n        browserConnections = browserConnections.concat(chunk(remotes, this.concurrency));\n\n        return BrowserSet.from(browserConnections, this._getBrowserSetOptions());\n    }\n\n    private async _filterTests (tests: Test[], predicate: FilterFunction): Promise<Test[]> {\n        return asyncFilter(tests, test => {\n            const testFixture = test.fixture as Fixture;\n\n            return predicate(\n                test.name as string,\n                testFixture.name as string,\n                testFixture.path,\n                test.meta,\n                testFixture.meta);\n        });\n    }\n\n    private async _compileTests ({ sourceList, compilerOptions, runnableConfigurationId }: CompilerArguments): Promise<Test[]> {\n        const baseUrl          = this.configuration.getOption(OPTION_NAMES.baseUrl) as string;\n        const experimentalEsm  = this.configuration.getOption(OPTION_NAMES.experimentalEsm) as boolean;\n\n        if (this.compilerService) {\n            await this.compilerService.init();\n            await this.compilerService.setUserVariables(userVariables.value);\n\n            return this.compilerService.getTests({ sourceList, compilerOptions, runnableConfigurationId }, baseUrl);\n        }\n\n        const compiler = new Compiler(sourceList, compilerOptions, { baseUrl, isCompilerServiceMode: false, experimentalEsm });\n\n        return compiler.getTests();\n    }\n\n    private _assertGlobalHooks (): void {\n        if (!this.hooks)\n            return;\n\n        if (this.hooks.fixture?.before)\n            assertType(is.function, 'globalBefore', 'The fixture.globalBefore hook', this.hooks.fixture.before);\n\n        if (this.hooks.fixture?.after)\n            assertType(is.function, 'globalAfter', 'The fixture.globalAfter hook', this.hooks.fixture.after);\n\n        if (this.hooks.test?.before)\n            assertType(is.function, 'globalBefore', 'The test.globalBefore hook', this.hooks.test.before);\n\n        if (this.hooks.test?.after)\n            assertType(is.function, 'globalAfter', 'The test.globalAfter hook', this.hooks.test.after);\n\n        if (this.hooks.request)\n            assertRequestHookType(flatten(castArray(this.hooks.request)));\n    }\n\n    private _setGlobalHooksToTests (tests: Test[]): void {\n        if (!this.hooks)\n            return;\n\n        this._assertGlobalHooks();\n\n        const fixtureBefore = this.hooks.fixture?.before || null;\n        const fixtureAfter  = this.hooks.fixture?.after || null;\n        const testBefore    = this.hooks.test?.before ? wrapTestFunction(this.hooks.test.before) : null;\n        const testAfter     = this.hooks.test?.after ? wrapTestFunction(this.hooks.test.after) : null;\n        const request       = this.hooks.request || [];\n\n        tests.forEach(item => {\n            if (item.fixture) {\n                item.fixture.globalBeforeFn = item.fixture.globalBeforeFn || fixtureBefore;\n                item.fixture.globalAfterFn  = item.fixture.globalAfterFn || fixtureAfter;\n            }\n\n            item.globalBeforeFn = testBefore;\n            item.globalAfterFn  = testAfter;\n            item.requestHooks   = union(flatten(castArray(request)), item.requestHooks);\n        });\n    }\n\n    private async _getTests (id: string): Promise<Test[]> {\n        const cwd        = process.cwd();\n        const sourceList = await parseFileList(this.sources, cwd);\n\n        if (!sourceList.length)\n            throw new GeneralError(RUNTIME_ERRORS.testFilesNotFound, cwd, getConcatenatedValuesString(this.sources, '\\n', ''));\n\n        let tests = await guardTimeExecution(\n            async () => await this._compileTests({ sourceList, compilerOptions: this.compilerOptions, runnableConfigurationId: id }),\n            elapsedTime => {\n                this.debugLogger(`tests compilation took ${prettyTime(elapsedTime)}`);\n\n                const [ elapsedSeconds ] = elapsedTime;\n\n                if (elapsedSeconds > this.TESTS_COMPILATION_UPPERBOUND)\n                    this.warningLog.addWarning(WARNING_MESSAGES.testsCompilationTakesTooLong, prettyTime(elapsedTime));\n            }\n        );\n\n        const testsWithOnlyFlag = tests.filter(test => test.only);\n\n        if (testsWithOnlyFlag.length)\n            tests = testsWithOnlyFlag;\n\n        if (!tests.length)\n            throw new GeneralError(RUNTIME_ERRORS.noTestsToRun);\n\n        if (this.filter)\n            tests = await this._filterTests(tests, this.filter);\n\n        if (!tests.length)\n            throw new GeneralError(RUNTIME_ERRORS.noTestsToRunDueFiltering);\n\n        this._setGlobalHooksToTests(tests);\n\n        return tests;\n    }\n\n    private async _startTestedApp (): Promise<TestedApp|undefined> {\n        if (!this.appCommand)\n            return void 0;\n\n        const testedApp = new TestedApp();\n\n        await testedApp.start(this.appCommand, this.appInitDelay as number);\n\n        return testedApp;\n    }\n\n    private async _canUseParallelBootstrapping (browserInfo: BrowserInfoSource[]): Promise<boolean> {\n        const isLocalPromises = browserInfo.map(browser => browser.provider.isLocalBrowser(void 0, Bootstrapper._getBrowserName(browser)));\n        const isLocalBrowsers = await Promise.all(isLocalPromises);\n\n        return isLocalBrowsers.every(result => result);\n    }\n\n    private async _bootstrapSequence (browserInfo: BrowserInfoSource[], id: string): Promise<BasicRuntimeResources> {\n        const tests       = await this._getTests(id);\n        const testedApp   = await this._startTestedApp();\n        const browserSet  = await this._getBrowserConnections(browserInfo);\n\n        return { tests, testedApp, browserSet };\n    }\n\n    private _wrapBootstrappingPromise<T> (promise: Promise<T>): Promise<PromiseResult<T>> {\n        return promise\n            .then(result => ({ error: void 0, result }))\n            .catch(error => ({ result: void 0, error }));\n    }\n\n    private async _getBootstrappingError (browserSetStatus: PromiseResult<BrowserSet>, testsStatus: PromiseResult<Test[]>, testedAppStatus: PromiseResult<TestedApp|undefined>): Promise<Error> {\n        if (!isPromiseError(browserSetStatus))\n            await browserSetStatus.result.dispose();\n\n        if (!isPromiseError(browserSetStatus) && !isPromiseError(testedAppStatus) && testedAppStatus.result)\n            await testedAppStatus.result.kill();\n\n        if (isPromiseError(testsStatus))\n            return testsStatus.error;\n\n        if (isPromiseError(testedAppStatus))\n            return testedAppStatus.error;\n\n        if (isPromiseError(browserSetStatus))\n            return browserSetStatus.error;\n\n        return new Error('Unexpected call');\n    }\n\n    private _getBootstrappingPromises<T> (arg: PromiseCollection<T>): PromiseCollection<ResultCollection<T>> {\n        const result = {} as unknown as PromiseCollection<ResultCollection<T>>;\n\n        for (const k in arg)\n            result[k] = this._wrapBootstrappingPromise(arg[k]);\n\n        return result;\n    }\n\n    private async _bootstrapParallel (browserInfo: BrowserInfoSource[], id: string): Promise<BasicRuntimeResources> {\n        const bootstrappingPromises = {\n            browserSet: this._getBrowserConnections(browserInfo),\n            tests:      this._getTests(id),\n            app:        this._startTestedApp(),\n        };\n\n        const bootstrappingResultPromises = this._getBootstrappingPromises(bootstrappingPromises);\n\n        const bootstrappingResults = await Promise.all([\n            bootstrappingResultPromises.browserSet,\n            bootstrappingResultPromises.tests,\n            bootstrappingResultPromises.app,\n        ]);\n\n        const [browserSetResults, testResults, appResults] = bootstrappingResults;\n\n        if (isPromiseError(browserSetResults) || isPromiseError(testResults) || isPromiseError(appResults))\n            throw await this._getBootstrappingError(...bootstrappingResults);\n\n        return {\n            browserSet: browserSetResults.result,\n            tests:      testResults.result,\n            testedApp:  appResults.result,\n        };\n    }\n\n    // API\n    public async createRunnableConfiguration (): Promise<RunnableConfiguration> {\n        const id                  = generateUniqueId();\n        const commonClientScripts = await loadClientScripts(this.clientScripts);\n\n        if (await this._canUseParallelBootstrapping(this.browsers))\n            return { ...await this._bootstrapParallel(this.browsers, id), commonClientScripts, id };\n\n        return { ...await this._bootstrapSequence(this.browsers, id), commonClientScripts, id };\n    }\n}\n"]}