testcafe 2.3.1 → 2.6.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 (235) hide show
  1. package/CHANGELOG.md +150 -0
  2. package/LICENSE +1 -1
  3. package/README.md +40 -46
  4. package/bin/testcafe-with-v8-flag-filter.js +10 -16
  5. package/lib/api/exportable-lib/index.js +1 -11
  6. package/lib/api/structure/test.js +4 -11
  7. package/lib/api/test-controller/execution-context.js +4 -2
  8. package/lib/api/test-controller/index.js +8 -10
  9. package/lib/api/test-run-tracker.js +1 -1
  10. package/lib/assertions/executor.js +2 -11
  11. package/lib/browser/connection/gateway/index.js +272 -0
  12. package/lib/browser/connection/gateway/status.js +10 -0
  13. package/lib/browser/connection/index.js +60 -47
  14. package/lib/browser/connection/service-routes.js +4 -2
  15. package/lib/browser/provider/built-in/dedicated/chrome/cdp-client/index.js +3 -2
  16. package/lib/browser/provider/built-in/dedicated/chrome/index.js +48 -23
  17. package/lib/browser/provider/built-in/dedicated/edge/index.js +4 -1
  18. package/lib/browser/provider/index.js +13 -4
  19. package/lib/browser/provider/plugin-host.js +7 -1
  20. package/lib/cli/argument-parser/index.js +10 -16
  21. package/lib/cli/cli.js +4 -13
  22. package/lib/cli/remotes-wizard.js +2 -1
  23. package/lib/cli/utils/should-move-option-to-end.js +17 -0
  24. package/lib/client/automation/deps/hammerhead.js +24 -0
  25. package/lib/client/automation/deps/testcafe-core.js +24 -0
  26. package/lib/client/automation/index.js +567 -187
  27. package/lib/client/automation/index.min.js +1 -1
  28. package/lib/client/automation/playback/press/get-key-info.js +44 -0
  29. package/lib/client/automation/playback/press/utils.js +142 -0
  30. package/lib/client/automation/utils/get-key-code.js +15 -0
  31. package/lib/client/automation/utils/get-key-identifier.js +14 -0
  32. package/lib/client/automation/utils/is-letter.js +7 -0
  33. package/lib/client/automation/utils/key-identifier-maps.js +93 -0
  34. package/lib/client/browser/idle-page/index.html.mustache +2 -2
  35. package/lib/client/browser/idle-page/index.js +24 -11
  36. package/lib/client/core/index.js +67 -13
  37. package/lib/client/core/index.min.js +1 -1
  38. package/lib/client/core/utils/array.js +77 -0
  39. package/lib/client/core/utils/dom.js +459 -0
  40. package/lib/client/core/utils/send-request-to-frame.js +22 -0
  41. package/lib/client/core/utils/style.js +102 -0
  42. package/lib/client/core/utils/values/boundary-values.js +41 -0
  43. package/lib/client/driver/index.js +270 -242
  44. package/lib/client/driver/index.min.js +1 -1
  45. package/lib/client/test-run/iframe.js.mustache +6 -6
  46. package/lib/client/test-run/index.js.mustache +37 -33
  47. package/lib/client/ui/index.js +3238 -54
  48. package/lib/client/ui/index.min.js +1 -1
  49. package/lib/client/ui/sprite.svg +15 -0
  50. package/lib/client/ui/styles.css +184 -41
  51. package/lib/compiler/babel/load-libs.js +6 -6
  52. package/lib/compiler/compilers.js +7 -7
  53. package/lib/compiler/index.js +6 -6
  54. package/lib/compiler/interfaces.js +1 -1
  55. package/lib/compiler/test-file/add-export-api.js +3 -3
  56. package/lib/compiler/test-file/api-based.js +8 -37
  57. package/lib/compiler/test-file/formats/es-next/compiler.js +5 -5
  58. package/lib/compiler/test-file/formats/typescript/compiler.js +9 -9
  59. package/lib/compiler/test-file/get-exportable-lib-path.js +3 -3
  60. package/lib/configuration/configuration-base.js +9 -6
  61. package/lib/configuration/default-values.js +3 -3
  62. package/lib/configuration/formats.js +9 -5
  63. package/lib/configuration/interfaces.js +1 -1
  64. package/lib/configuration/option-names.js +3 -4
  65. package/lib/configuration/run-option-names.js +2 -2
  66. package/lib/configuration/testcafe-configuration.js +41 -24
  67. package/lib/configuration/types.js +1 -1
  68. package/lib/configuration/utils.js +32 -0
  69. package/lib/custom-client-scripts/client-script.js +2 -2
  70. package/lib/custom-client-scripts/get-code.js +3 -3
  71. package/lib/custom-client-scripts/routing.js +10 -12
  72. package/lib/errors/runtime/templates.js +3 -2
  73. package/lib/errors/test-run/templates.js +4 -1
  74. package/lib/errors/types.js +3 -1
  75. package/lib/index.js +6 -31
  76. package/lib/live/bootstrapper.js +3 -3
  77. package/lib/live/test-runner.js +9 -7
  78. package/lib/native-automation/add-custom-debug-formatters.js +23 -0
  79. package/lib/native-automation/api-base.js +27 -0
  80. package/lib/native-automation/client/event-descriptor.js +118 -0
  81. package/lib/native-automation/client/input.js +46 -0
  82. package/lib/native-automation/client/key-press/utils.js +31 -0
  83. package/lib/native-automation/client/types.js +11 -0
  84. package/lib/native-automation/client/utils.js +54 -0
  85. package/lib/native-automation/cookie-provider.js +115 -0
  86. package/lib/native-automation/empty-page-markup.js +11 -0
  87. package/lib/native-automation/error-route.js +7 -0
  88. package/lib/native-automation/errors.js +20 -0
  89. package/lib/native-automation/index.js +53 -0
  90. package/lib/native-automation/request-hooks/event-factory/frame-navigated-event-based.js +40 -0
  91. package/lib/native-automation/request-hooks/event-factory/request-paused-event-based.js +94 -0
  92. package/lib/native-automation/request-hooks/event-provider.js +55 -0
  93. package/lib/native-automation/request-hooks/pipeline-context.js +11 -0
  94. package/lib/{proxyless → native-automation}/request-pipeline/constants.js +1 -1
  95. package/lib/native-automation/request-pipeline/context-info.js +58 -0
  96. package/lib/native-automation/request-pipeline/index.js +329 -0
  97. package/lib/native-automation/request-pipeline/resendAuthRequest.js +23 -0
  98. package/lib/native-automation/request-pipeline/safe-api.js +66 -0
  99. package/lib/native-automation/request-pipeline/special-handlers.js +76 -0
  100. package/lib/native-automation/request-pipeline/test-run-bridge.js +45 -0
  101. package/lib/native-automation/resource-injector.js +175 -0
  102. package/lib/native-automation/session-storage/index.js +43 -0
  103. package/lib/native-automation/storages-provider.js +17 -0
  104. package/lib/native-automation/types.js +12 -0
  105. package/lib/native-automation/utils/cdp.js +71 -0
  106. package/lib/native-automation/utils/convert.js +11 -0
  107. package/lib/native-automation/utils/get-active-client.js +8 -0
  108. package/lib/native-automation/utils/headers.js +30 -0
  109. package/lib/native-automation/utils/string.js +32 -0
  110. package/lib/reporter/index.js +52 -4
  111. package/lib/reporter/interfaces.js +1 -1
  112. package/lib/reporter/plugin-host.js +44 -4
  113. package/lib/reporter/plugin-methods.js +2 -1
  114. package/lib/reporter/report-data-log.js +25 -0
  115. package/lib/role/role.js +4 -39
  116. package/lib/runner/bootstrapper.js +40 -15
  117. package/lib/runner/browser-job.js +4 -5
  118. package/lib/runner/fixture-hook-controller.js +1 -7
  119. package/lib/runner/index.js +87 -94
  120. package/lib/runner/interfaces.js +1 -1
  121. package/lib/runner/task/index.js +2 -32
  122. package/lib/runner/test-run-controller.js +46 -4
  123. package/lib/shared/errors/index.js +8 -2
  124. package/lib/shared/utils/is-file-protocol.js +2 -2
  125. package/lib/test-run/bookmark.js +5 -23
  126. package/lib/test-run/commands/actions.js +16 -4
  127. package/lib/test-run/commands/service.js +2 -3
  128. package/lib/test-run/commands/type.js +2 -1
  129. package/lib/test-run/commands/utils.js +4 -2
  130. package/lib/test-run/cookies/base.js +4 -1
  131. package/lib/test-run/cookies/factory.js +4 -4
  132. package/lib/test-run/cookies/provider.js +9 -2
  133. package/lib/test-run/execute-js-expression/index.js +4 -2
  134. package/lib/test-run/index.js +35 -151
  135. package/lib/test-run/request/create-request-options.js +37 -24
  136. package/lib/test-run/request/send.js +2 -3
  137. package/lib/test-run/role-provider.js +5 -5
  138. package/lib/test-run/session-controller.js +5 -5
  139. package/lib/test-run/storages/factory.js +4 -4
  140. package/lib/testcafe.js +17 -18
  141. package/lib/utils/check-is-vm.js +58 -0
  142. package/lib/utils/debug-loggers.js +9 -7
  143. package/lib/utils/get-browser.js +5 -2
  144. package/lib/utils/get-options/boolean-or-object-option.js +18 -0
  145. package/lib/utils/get-options/quarantine.js +10 -13
  146. package/lib/utils/get-options/skip-js-errors.js +12 -16
  147. package/lib/utils/parse-user-agent.js +20 -13
  148. package/lib/utils/string.js +1 -1
  149. package/package.json +14 -11
  150. package/ts-defs/index.d.ts +12 -2
  151. package/ts-defs/selectors.d.ts +8 -1
  152. package/ts-defs/testcafe-scripts.d.ts +8 -1
  153. package/lib/browser/connection/gateway.js +0 -205
  154. package/lib/compiler/test-file/test-file-temp-variable-name.js +0 -6
  155. package/lib/dashboard/config-storage.js +0 -26
  156. package/lib/dashboard/connector.js +0 -84
  157. package/lib/dashboard/documentation-url.js +0 -6
  158. package/lib/dashboard/formatting.js +0 -26
  159. package/lib/dashboard/get-dashboard-url.js +0 -10
  160. package/lib/dashboard/get-default-project-link.js +0 -23
  161. package/lib/dashboard/get-env-options.js +0 -26
  162. package/lib/dashboard/index.js +0 -145
  163. package/lib/dashboard/interfaces.js +0 -3
  164. package/lib/dashboard/messages.js +0 -21
  165. package/lib/proxyless/add-custom-debug-formatters.js +0 -22
  166. package/lib/proxyless/api-base.js +0 -25
  167. package/lib/proxyless/client/event-simulator.js +0 -40
  168. package/lib/proxyless/client/types.js +0 -11
  169. package/lib/proxyless/client/utils.js +0 -24
  170. package/lib/proxyless/cookie-provider.js +0 -87
  171. package/lib/proxyless/default-setup-options.js +0 -9
  172. package/lib/proxyless/empty-page-markup.js +0 -11
  173. package/lib/proxyless/error-route.js +0 -7
  174. package/lib/proxyless/index.js +0 -53
  175. package/lib/proxyless/request-hooks/event-factory/frame-navigated-event-based.js +0 -40
  176. package/lib/proxyless/request-hooks/event-factory/request-paused-event-based.js +0 -95
  177. package/lib/proxyless/request-hooks/event-provider.js +0 -52
  178. package/lib/proxyless/request-hooks/pipeline-context.js +0 -11
  179. package/lib/proxyless/request-pipeline/context-info.js +0 -55
  180. package/lib/proxyless/request-pipeline/index.js +0 -230
  181. package/lib/proxyless/request-pipeline/resendAuthRequest.js +0 -23
  182. package/lib/proxyless/request-pipeline/safe-api.js +0 -62
  183. package/lib/proxyless/request-pipeline/special-handlers.js +0 -73
  184. package/lib/proxyless/request-pipeline/test-run-bridge.js +0 -45
  185. package/lib/proxyless/resource-injector.js +0 -162
  186. package/lib/proxyless/session-storage/index.js +0 -39
  187. package/lib/proxyless/storages-provider.js +0 -17
  188. package/lib/proxyless/types.js +0 -10
  189. package/lib/proxyless/utils/cdp.js +0 -66
  190. package/lib/proxyless/utils/get-active-client.js +0 -8
  191. package/lib/proxyless/utils/headers.js +0 -30
  192. package/lib/proxyless/utils/string.js +0 -32
  193. package/lib/services/compiler/esm-runtime-holder-name.js +0 -6
  194. package/lib/services/compiler/host.js +0 -370
  195. package/lib/services/compiler/interfaces.js +0 -3
  196. package/lib/services/compiler/io.js +0 -10
  197. package/lib/services/compiler/protocol.js +0 -17
  198. package/lib/services/compiler/service-loader.js +0 -18
  199. package/lib/services/compiler/service.js +0 -361
  200. package/lib/services/compiler/test-run-proxy.js +0 -156
  201. package/lib/services/interfaces.js +0 -3
  202. package/lib/services/process-title.js +0 -10
  203. package/lib/services/serialization/prepare-options.js +0 -23
  204. package/lib/services/serialization/replicator/create-replicator.js +0 -58
  205. package/lib/services/serialization/replicator/interfaces.js +0 -3
  206. package/lib/services/serialization/replicator/transforms/base-transform.js +0 -16
  207. package/lib/services/serialization/replicator/transforms/browser-console-messages-transform.js +0 -23
  208. package/lib/services/serialization/replicator/transforms/callsite-record-transform.js +0 -24
  209. package/lib/services/serialization/replicator/transforms/command-base-trasform/assertion-command-constructors.js +0 -28
  210. package/lib/services/serialization/replicator/transforms/command-base-trasform/command-constructors.js +0 -66
  211. package/lib/services/serialization/replicator/transforms/command-base-trasform/index.js +0 -49
  212. package/lib/services/serialization/replicator/transforms/command-base-trasform/types.js +0 -3
  213. package/lib/services/serialization/replicator/transforms/configure-response-event-option-transform.js +0 -21
  214. package/lib/services/serialization/replicator/transforms/custom-error-transform.js +0 -29
  215. package/lib/services/serialization/replicator/transforms/function-marker-transform/index.js +0 -21
  216. package/lib/services/serialization/replicator/transforms/function-marker-transform/marker.js +0 -9
  217. package/lib/services/serialization/replicator/transforms/promise-marker-transform/index.js +0 -21
  218. package/lib/services/serialization/replicator/transforms/promise-marker-transform/marker.js +0 -9
  219. package/lib/services/serialization/replicator/transforms/raw-command-callsite-record-transform.js +0 -22
  220. package/lib/services/serialization/replicator/transforms/re-executable-promise-transform/index.js +0 -22
  221. package/lib/services/serialization/replicator/transforms/re-executable-promise-transform/marker.js +0 -6
  222. package/lib/services/serialization/replicator/transforms/request-filter-rule-transform.js +0 -23
  223. package/lib/services/serialization/replicator/transforms/request-hook-event-data-transform.js +0 -41
  224. package/lib/services/serialization/replicator/transforms/response-mock-transform.js +0 -23
  225. package/lib/services/serialization/replicator/transforms/role-transform.js +0 -21
  226. package/lib/services/serialization/replicator/transforms/testcafe-error-list-transform.js +0 -23
  227. package/lib/services/serialization/replicator/transforms/url-transform.js +0 -23
  228. package/lib/services/serialization/test-structure.js +0 -91
  229. package/lib/services/utils/ipc/interfaces.js +0 -29
  230. package/lib/services/utils/ipc/io.js +0 -109
  231. package/lib/services/utils/ipc/message.js +0 -84
  232. package/lib/services/utils/ipc/packet.js +0 -57
  233. package/lib/services/utils/ipc/proxy.js +0 -94
  234. package/lib/services/utils/ipc/transport.js +0 -65
  235. package/lib/services/utils/method-should-not-be-called-error.js +0 -10
package/CHANGELOG.md CHANGED
@@ -1,5 +1,155 @@
1
1
  # Changelog
2
2
 
3
+ ## v2.6.1 (2023-05-29)
4
+
5
+ TestCafe v2.6.1 retires **Experimental Debug** mode, and introduces a number of important bug fixes.
6
+
7
+ ### Removed: Experimental debug mode
8
+
9
+ TestCafe v1.18.0 introduced [Experimental Debug mode](https://testcafe.io/403664/release-notes/framework/2021-12-22-testcafe-v1-18-0-released) --- a way to debug Selectors and Client Functions in the text editor. TestCafe v2.4.0 shipped with the [Visual Selector Debugger](https://testcafe.io/documentation/404288/guides/intermediate-guides/visual-selector-debugger), which allows users to troubleshoot Selector queries directly in the browser.
10
+
11
+ The two capabilities serve the same purpose, but the Visual Selector Debugger is more user-friendly. As such, beginning with TestCafe v2.6.1, the framework **no longer includes** Experimental Debug mode. Thank you to all the TestCafe users who tried out the capability.
12
+
13
+ ### Bug fixes
14
+
15
+ * When TestCafe runs in Native Automation mode, Request Hooks yield an error ([#7683](https://github.com/DevExpress/testcafe/issues/7683)).
16
+ * When TestCafe runs in Native Automation mode, the framework incorrectly processes pages with the pound sign ("#") in the URL ([#7652](https://github.com/DevExpress/testcafe/issues/7652)).
17
+ * TestCafe incorrectly handles XHR headers in Native Automation mode ([#7664](https://github.com/DevExpress/testcafe/issues/7664), [#7686](https://github.com/DevExpress/testcafe/issues/7686), [#7645](https://github.com/DevExpress/testcafe/issues/7645)).
18
+ * TestCafe reports an incorrect browser alias when it runs tests in Microsoft Edge ([#7647](https://github.com/DevExpress/testcafe/issues/7647)).
19
+ * TestCafe fails to intercept all HTTP requests when it runs in Native Automation mode. ([#7640](https://github.com/DevExpress/testcafe/issues/7640)).
20
+ * TestCafe cannot resize browser windows in the latest version of Chrome for macOS ([#7684](https://github.com/DevExpress/testcafe/issues/7684)).
21
+ * TestCafe incorrectly processes client-side styles, causing slowdowns and errors ([#6726](https://github.com/DevExpress/testcafe/issues/6726), [#6747](https://github.com/DevExpress/testcafe/issues/6747)).
22
+ * TestCafe crashes when you use the TestCafe Test Runner API to launch multiple tests simultaneously ([#7711](https://github.com/DevExpress/testcafe/issues/7711)).
23
+
24
+ ## v2.6.0 (2023-05-11)
25
+
26
+ TestCafe v2.6.0 introduces two enhancements: a new hook that allows users to modify reporter output, and support for JavaScript configuration files with the `.cjs` extension.
27
+
28
+ ### New reporter hook
29
+
30
+ The [onBeforeWrite](https://testcafe.io/documentation/404388/guides/advanced-guides/modify-reporter-output) hook allows you to modify the output of a reporter.
31
+
32
+ If you want your test reports to include custom content, you can create a custom reporter from scratch. However, this approach takes time and effort. Use the `onBeforeWrite` hook if you want to make minor changes to the output of an existing reporter.
33
+
34
+ Define an `onBeforeWrite` hook in a JavaScript configuration file. The following hook adds the duration in milliseconds to every test entry in the report:
35
+
36
+ ```js
37
+ //.testcaferc.js or .testcaferc.cjs
38
+ function onBeforeWriteHook(writeInfo) { // This function will fire every time the reporter calls the "write" method.
39
+ if (writeInfo.initiator === 'reportTestDone') { // The "initiator" property contains the name of the reporter event that triggered the hook.
40
+ const {
41
+ name,
42
+ testRunInfo,
43
+ meta
44
+ } = writeInfo.data || {}; // If you attached this hook to a compatible reporter (such as "spec" or "list"), the hook can process data related to the event.
45
+ const testDuration = testRunInfo.durationMs; // Save the duration of the test.
46
+ writeInfo.formattedText = writeInfo.formattedText + ' (' + testDuration + 'ms)'; // Add test duration to the reporter output.
47
+ };
48
+ }
49
+
50
+
51
+ module.exports = { // Attach the hook
52
+ hooks: {
53
+ reporter: {
54
+ onBeforeWrite: {
55
+ 'spec': onBeforeWriteHook, // This hook will fire when you use the default "spec" reporter.
56
+ },
57
+ },
58
+ },
59
+ };
60
+ ```
61
+
62
+ ![Reporter hook demonstration](https://testcafe.io/images/reporter-hook.png)
63
+
64
+ ### CJS support
65
+
66
+ If you run TestCafe v2.6.0 and higher, you can now use a configuration file with the `.cjs` file extension. TestCafe detects the `.testcaferc.cjs` file on startup, alongside its `.js` and `.json` counterparts.
67
+
68
+ [TestCafe configuration files](https://testcafe.io/documentation/402638/reference/configuration-file) **only** support CommonJS syntax. Meanwhile, modern JavaScript tools often default to ESM syntax. If a JavaScript project is of type `module`, Node.js expects the project's `.js` files to contain ESM syntax.
69
+
70
+ Use the `.cjs` configuration file extension to let Node.js know that the file contains CommonJS syntax.
71
+
72
+ Many thanks to the TestCafe contributor Damien Guérin ([@gigaga](https://github.com/DevExpress/testcafe/pull/7614)) for the implementation of this capability.
73
+
74
+ ### Bug fixes
75
+
76
+ * If you call the `t.skipJsErrors` method without arguments, TestCafe passes a `false` value to the method. This behavior is inconsistent with similar methods of a greater scope --- `test.skipJsErrors` and `fixture.skipJsErrors` ([#7648](https://github.com/DevExpress/testcafe/issues/7648)).
77
+ * Users cannot disable the "quarantine mode" or "skipJsErrors" settings from the command line ([#7077](https://github.com/DevExpress/testcafe/issues/7077)).
78
+ * TestCafe incorrectly processes exceptions of types other than `Error` ([#7627](https://github.com/DevExpress/testcafe/issues/7627)).
79
+ * TestCafe does not consistently execute the `t.pressKey` action in Mozilla Firefox. Attempts to press the "backspace" key and the "tab" key, among others, may fail. ([#7623](https://github.com/DevExpress/testcafe/pull/7623))
80
+ * When TestCafe runs in Native Automation mode, it incorrectly executes some instances of the `t.request` method. ([#7609](https://github.com/DevExpress/testcafe/issues/7609))
81
+ * The TestCafe proxy incorrectly processes private class properties in client-side scripts, which leads to page load failure ([#7632](https://github.com/DevExpress/testcafe/issues/7632), PR by [@sorin-davidoi](https://github.com/sorin-davidoi)).
82
+
83
+ ## v2.5.0 (2023-04-06)
84
+
85
+ TestCafe v2.5.0 introduces three major enhancements:
86
+ * The new `t.report` method passes custom data to the test reporter.
87
+ * The new `--native-automation` flag enables TestCafe to automate all Chromium-based browsers with the native CDP protocol.
88
+ * The new `--esm` flag allows users to import ESM modules in test files.
89
+
90
+ ### t.report
91
+
92
+ Include the [t.report()](https://testcafe.io/documentation/404350/reference/test-api/testcontroller/report) method in your test to pass custom data to the reporter.
93
+
94
+ Specify arguments of any type (string, array, Object, etc). Separate arguments with a comma:
95
+
96
+ ```js
97
+ await
98
+ t.report(
99
+ 'text',
100
+ {'key': 'value'},
101
+ ['arrayItem1', 'arrayItem2']
102
+ );
103
+ ```
104
+
105
+ The default `spec` reporter displays custom data after test completion, once for each browser that runs the test.
106
+
107
+ ![Report with custom data](https://testcafe.io/images/treport.png)
108
+
109
+ ### CDP Automation: Now Stable
110
+
111
+ TestCafe v2.2.0 introduced an experimental [proxyless mode](https://testcafe.io/documentation/404237/guides/intermediate-guides/native-automation-mode) that automated Google Chrome with the native CDP protocol.
112
+
113
+ For the v2.5.0 release, the TestCafe team addressed most issues that our users discovered when the capability was "experimental", and gave it a new name --- Native Automation mode.
114
+
115
+ Unlike its predecessor, the Native Automation mode supports **all** Chromium-based browsers, including Microsoft Edge. Enable the `nativeAutomation` option in the [command line interface](https://testcafe.io/documentation/402639/reference/command-line-interface#--native-automation), the [configuration file](https://testcafe.io/documentation/402638/reference/configuration-file#nativeautomation), or the [runner.run()](https://testcafe.io/documentation/402655/reference/testcafe-api/runner/run#nativeautomation) function to try this capability.
116
+
117
+ > [!IMPORTANT]
118
+ > TestCafe v2.5.0 removed the `experimentalProxyless` option from the [createTestCafe](https://testcafe.io/documentation/402662/reference/testcafe-api/global/createtestcafe) function. Use the [runner.run()](https://testcafe.io/documentation/402655/reference/testcafe-api/runner/run#nativeautomation) function to enable Native Automation mode from the TestCafe Test Runner API.
119
+
120
+ ### ESM Module Support: Now Stable
121
+
122
+ TestCafe v2.5.0 **drops** the `experimental` prefix from the `--esm` [CLI flag](https://testcafe.io/documentation/402639/reference/command-line-interface#--esm). Enable the `--esm` flag to import modules that do not support CommonJS.
123
+
124
+ ```sh
125
+ testcafe chrome test.js --esm
126
+ ```
127
+
128
+ ## v2.4.0 (2023-03-06)
129
+ TestCafe v2.4.0 introduces the Visual Selector Debugger. You can now create and debug Selector queries in the browser window.
130
+
131
+ ### Visual Selector Debugger
132
+
133
+ TestCafe v2.4.0 displays the Visual Selector Debugger panel when you activate [Debug Mode](https://testcafe.io/documentation/402835/guides/basic-guides/debug-tests). Use the panel to debug Selector queries from your test, or generate new Selector queries.
134
+
135
+ ![](https://testcafe.io/images/inspector/enter-query.gif)
136
+
137
+ If a Selector query causes your test to fail, add the [t.debug()](https://testcafe.io/documentation/402707/reference/test-api/testcontroller/debug) command after the last successful action, and launch the test.
138
+
139
+ When the test reaches the breakpoint, the window that runs the test displays the Selector Debugger panel. Copy the failing Selector query from test code to the Selector Debugger input field.
140
+
141
+ * TestCafe highlights page elements that match the Selector query.
142
+ * If no elements match the Selector query, the panel displays the **No Matching Elements** warning.
143
+ * If your Selector query contians a syntax error, the panel displays the **Invalid Selector** warning.
144
+
145
+ To interactively generate a Selector query, click the **Pick** button, and select the target element on the page.
146
+
147
+ For more information on the panel, its capabilities, and limitations, read the [Visual Selector Debugger Guide](https://testcafe.io/documentation/404288/guides/intermediate-guides/visual-selector-debugger).
148
+
149
+ ### Bug Fixes
150
+
151
+ * TestCafe cannot execute the [t.request](https://testcafe.io/documentation/403981/reference/test-api/testcontroller/request) action in [proxyless mode](https://testcafe.io/documentation/404237/guides/experimental-capabilities/proxyless-mode) ([#7523](https://github.com/DevExpress/testcafe/issues/7523)).
152
+
3
153
  ## v2.3.1 (2023-02-09)
4
154
  TestCafe v2.3.1 introduces a number of bug fixes.
5
155
 
package/LICENSE CHANGED
@@ -1,6 +1,6 @@
1
1
  The MIT License
2
2
 
3
- Copyright (C) 2012-2022 Developer Express Inc.
3
+ Copyright (C) 2012-2023 Developer Express Inc.
4
4
 
5
5
  Permission is hereby granted, free of charge, to any person obtaining a copy
6
6
  of this software and associated documentation files (the "Software"), to deal
package/README.md CHANGED
@@ -1,7 +1,7 @@
1
1
  <p align="center">
2
- <a href="https://testcafe.io/surveys/open-source-feedback-2022">
3
- <img src="https://raw.github.com/DevExpress/testcafe/master/media/2022-feedback-survey-banner.png" alt="2022 TestCafe Feedback Survey" />
4
- </a>
2
+ <a href="https://www.devexpress.com/products/testcafestudio/?utm_source=github.com&utm_medium=referral&utm_campaign=tc-gh-banner">
3
+ <img src="https://raw.github.com/DevExpress/testcafe/master/media/testcafe-studio-banner.png" alt="Try TestCafe Studio IDE" />
4
+ </a>
5
5
  </p>
6
6
 
7
7
  <p align="center">
@@ -17,7 +17,9 @@
17
17
  </p>
18
18
 
19
19
  <p align="center">
20
- <i>A Node.js tool to automate end-to-end web testing.<br/>Write tests in JS or TypeScript, run them and view results.</i>
20
+ <i> Automate end-to-end web testing with TestCafe, a Node.js-based testing framework.</i><br><br>
21
+ TestCafe is <strong>free</strong> and as easy to use as <strong>1-2-3</strong>:<br>
22
+ <strong>1.</strong> Write your tests in JS or TypeScript.<br><strong>2.</strong> Execute your tests.<br><strong>3.</strong> View test results.
21
23
  </p>
22
24
 
23
25
  <p align="center">
@@ -29,7 +31,7 @@
29
31
 
30
32
  * **Works on all popular environments**: TestCafe runs on Windows, MacOS, and Linux. It supports desktop, mobile, remote and cloud [browsers](https://testcafe.io/documentation/402828/guides/concepts/browsers#browser-support) (UI or headless).
31
33
  * **1 minute to set up**: You [do not need WebDriver](https://testcafe.io/402636/faq#i-have-heard-that-testcafe-does-not-use-selenium-how-does-it-operate) or any other testing software. Install TestCafe with one command, and you are ready to test: `npm install -g testcafe`
32
- * **Free and open source**: TestCafe is free to use under the [MIT license](https://github.com/DevExpress/testcafe/blob/master/LICENSE). [Plugins](#plugins) provide custom reports, integration with other tools, launching tests from IDE, etc. You can use the plugins made by the GitHub community or make your own.
34
+ * **Free and open source**: TestCafe is free to use under the [MIT license](https://github.com/DevExpress/testcafe/blob/master/LICENSE). [Plugins](#plugins) provide custom reports, integration with other tools, launching tests from IDE, etc. You can use the plugins made by the GitHub community or create your own.
33
35
 
34
36
  ![Install TestCafe and Run a Test](https://raw.githubusercontent.com/DevExpress/testcafe/master/media/install-and-run-test.gif)
35
37
 
@@ -62,26 +64,20 @@ You can change the maximum wait time.
62
64
  If elements load faster, tests skip the timeout and continue.
63
65
 
64
66
  **Rapid test development tool**<br/>
65
- Changes in test code immediately restart the test, and you see the results instantly.<br/>
66
- See how it works in the [TestCafe Live repository](https://github.com/DevExpress/testcafe-live).
67
+ When you enable [live mode](https://testcafe.io/documentation/403842/guides/intermediate-guides/live-mode), changes to test code immediately restart the test, and you instantly see the results.
67
68
 
68
69
  **Latest JS and TypeScript support**<br/>
69
- TestCafe supports the latest JavaScript features, including ES2017 (for example, async/await).
70
- You can also [use TypeScript](https://testcafe.io/documentation/402824/guides/concepts/typescript-and-coffeescript#typescript-support)
71
- if you prefer a strongly typed language.
70
+ TestCafe supports the most recent JavaScript-related features, including ES2017 (async/await). You can also [use TypeScript](https://testcafe.io/documentation/402824/guides/concepts/typescript-and-coffeescript#typescript-support) if you prefer a strongly typed language instead.
72
71
 
73
72
  **Detects JS errors in your code**<br/>
74
- TestCafe reports JS errors that it finds on the webpage.
75
- Tests automatically fail because of that.
76
- However, you can disable this.
73
+ TestCafe reports JS errors that it locates on a given webpage. Tests automatically fail if TestCafe encounters such errors.<br />
74
+ You can, however, disable this option.<br />
77
75
 
78
76
  **Concurrent test launch**<br/>
79
- TestCafe can open multiple instances of the same browser to run parallel
80
- tests which decreases test execution time.
77
+ TestCafe can open multiple instances of the same browser and run parallel tests (to help decrease test execution time).
81
78
 
82
79
  **PageObject pattern support**<br/>
83
- The TestCafe's [Test API](https://testcafe.io/documentation/402632/reference)
84
- includes a high-level selector library, assertions, etc.
80
+ The TestCafe's [Test API](https://testcafe.io/documentation/402632/reference) includes a high-level selector library, assertions, etc.
85
81
  You can combine them to implement readable tests with the [PageObject pattern](https://testcafe.io/documentation/402826/guides/concepts/page-model).
86
82
 
87
83
  ```js
@@ -89,14 +85,15 @@ const macOSInput = Selector('.column').find('label').withText('MacOS').child('in
89
85
  ```
90
86
 
91
87
  **Easy to include in a continuous integration system**<br/>
92
- You can run TestCafe from a console, and its reports can be viewed in a CI system's interface
93
- (TeamCity, Jenkins, Travis & etc.)
88
+ You can run TestCafe from a console, and its reports can be viewed within CI systems (TeamCity, Jenkins, Travis & etc.)
89
+
90
+ # Love TestCafe Open-source Edition? Want to Record Tests without Writing JavaScript or TypeScript Code?
94
91
 
95
92
  ## TestCafe Studio: IDE for End-to-End Web Testing
96
93
 
97
- TestCafe works great for JavaScript developers, but at some point you will need to delegate testing tasks to your Q&A department. If that's the case and you are looking for a codeless way to record and maintain tests compatible with your existing infrastructure, check out [TestCafe Studio](https://www.devexpress.com/products/testcafestudio/?utm_source=github.com&utm_medium=referral&utm_campaign=tc-gh-ide) - a testing IDE built on top of the open-source TestCafe.
94
+ TestCafe is the perfect choice for JavaScript developers and experienced Q&A teams. If you’d like to delegate testing to QA engineers and are looking for a code-free way to record and maintain tests compatible with your existing infrastructure, check out [TestCafe Studio](https://www.devexpress.com/products/testcafestudio/?utm_source=github.com&utm_medium=referral&utm_campaign=tc-gh-ide) - a testing IDE built atop the open-source version of TestCafe.
98
95
 
99
- Read the following article to learn how TestCafe Studio could fit into your workflow: [What's Better than TestCafe? TestCafe Studio](https://www.devexpress.com/products/testcafestudio/qa-end-to-end-web-testing.xml).
96
+ Review the following article to learn how TestCafe Studio can fit into any workflow: [What's Better than TestCafe? TestCafe Studio](https://www.devexpress.com/products/testcafestudio/qa-end-to-end-web-testing.xml).
100
97
 
101
98
  ![Get Started with TestCafe Studio](https://raw.githubusercontent.com/DevExpress/testcafe/master/media/testcafe-studio-get-started.gif)
102
99
 
@@ -104,11 +101,11 @@ Read the following article to learn how TestCafe Studio could fit into your work
104
101
  <i>Record and Run a Test in TestCafe Studio</i>
105
102
  </p>
106
103
 
107
- ## Getting Started
104
+ # Getting Started
108
105
 
109
106
  ### Installation
110
107
 
111
- Ensure that [Node.js](https://nodejs.org/) ([Current or Active LTS](https://github.com/nodejs/Release#release-phases) is recommended, version 12 at minimum) and [npm](https://www.npmjs.com/) are installed on your computer before running it:
108
+ Ensure that you run [Node.js](https://nodejs.org/) version 16 or higher, and run the following command:
112
109
 
113
110
  ```sh
114
111
  npm install -g testcafe
@@ -116,11 +113,9 @@ npm install -g testcafe
116
113
 
117
114
  ### Creating the Test
118
115
 
119
- As an example, we are going to test the [https://devexpress.github.io/testcafe/example](https://devexpress.github.io/testcafe/example) page.
116
+ For this simple example, we will test the following page: [https://devexpress.github.io/testcafe/example](https://devexpress.github.io/testcafe/example)
120
117
 
121
- Create a `.js` or `.ts` file on your computer.
122
- Note that it needs to have a specific structure: tests must be organized into fixtures.
123
- You can paste the following code to see the test in action:
118
+ Create a .js or .ts file on your computer. Remember that a .js or .ts file must maintain a specific structure: tests must be organized into fixtures. You can paste the following code to see the test in action:
124
119
 
125
120
  ```js
126
121
  import { Selector } from 'testcafe'; // first import testcafe selectors
@@ -129,57 +124,57 @@ fixture `Getting Started`// declare the fixture
129
124
  .page `https://devexpress.github.io/testcafe/example`; // specify the start page
130
125
 
131
126
 
132
- //then create a test and place your code there
127
+ //then create a test and place your code within it
133
128
  test('My first test', async t => {
134
129
  await t
135
130
  .typeText('#developer-name', 'John Smith')
136
131
  .click('#submit-button')
137
132
 
138
- // Use the assertion to check if the actual header text is equal to the expected one
133
+ // Use the assertion to check if actual header text equals expected text
139
134
  .expect(Selector('#article-header').innerText).eql('Thank you, John Smith!');
140
135
  });
141
136
  ```
142
137
 
143
138
  ### Running the Test
144
139
 
145
- Call the following command in a command shell.
146
- Specify the [target browser](https://testcafe.io/documentation/402639/reference/command-line-interface#browser-list)
147
- and [file path](https://testcafe.io/documentation/402639/reference/command-line-interface#file-pathglob-pattern).
140
+ Call the following command in a command shell. Specify the [target browser](https://testcafe.io/documentation/402639/reference/command-line-interface#browser-list) and [file path](https://testcafe.io/documentation/402639/reference/command-line-interface#file-pathglob-pattern).
148
141
 
149
142
  ```sh
150
143
  testcafe chrome test1.js
151
144
  ```
152
145
 
153
- TestCafe opens the browser and starts executing the test.
146
+ TestCafe opens the browser and begins test execution.
147
+
148
+ > Important: Make certain the browser tab that runs tests stays active.
149
+ > Do not minimize the browser window.
150
+ > Inactive tabs and minimized browser windows switch to lower resource consumption mode.
151
+ > In low consumption mode, tests may not execute correctly.
154
152
 
155
- > Important! Make sure the browser tab that runs tests stays active.
156
- > Do not minimize the browser window. Inactive tabs and minimized browser windows switch
157
- > to a lower resource consumption mode where tests are not guaranteed to execute correctly.
158
153
 
159
154
  ### Viewing the Results
160
155
 
161
- TestCafe outputs the results into a command shell by default. See [Reporters](https://testcafe.io/documentation/402825/guides/concepts/reporters)
162
- for more information. You can also use [plugins](#plugins) to customize the reports.
156
+ TestCafe outputs results into a command shell by default. See [Reporters](https://testcafe.io/documentation/402825/guides/concepts/reporters)
157
+ for more information. You can also use [plugins](#plugins) to customize reports.
163
158
 
164
159
  ![Test Report](https://testcafe.io/images/report.png)
165
160
 
166
- Read the [Getting Started](https://testcafe.io/documentation/402635/getting-started) page for a more detailed guide.
161
+ Read the [Getting Started](https://testcafe.io/documentation/402635/getting-started) page for additional assistance.
167
162
 
168
163
  ## Documentation
169
164
 
170
- Go to our website for full [documentation](https://testcafe.io/documentation/402635/getting-started) on TestCafe.
165
+ Visit the following webpage to review our online help system: [Documentation](https://testcafe.io/documentation/402635/getting-started).
171
166
 
172
167
  ## Get Help
173
168
 
174
- Join the TestCafe community on Stack Overflow to get help. Ask and answer [questions with the TestCafe tag](https://stackoverflow.com/questions/tagged/testcafe).
169
+ Join the TestCafe community on Stack Overflow. Ask and answer questions [using the TestCafe tag](https://stackoverflow.com/questions/tagged/testcafe).
175
170
 
176
171
  ## Issue Tracker
177
172
 
178
- Use our GitHub issues page to [report bugs](https://github.com/DevExpress/testcafe/issues/new?template=bug-report.md) and [suggest improvements](https://github.com/DevExpress/testcafe/issues/new?template=feature_request.md).
173
+ Use our GitHub issues page to [report bugs](https://github.com/DevExpress/testcafe/issues/new?template=bug-report.md) and [suggest enhancements](https://github.com/DevExpress/testcafe/issues/new?template=feature_request.md).
179
174
 
180
175
  ## Stay in Touch
181
176
 
182
- Follow us on [Twitter](https://twitter.com/DXTestCafe). We post TestCafe news and updates, several times a week.
177
+ Follow us on [Twitter](https://twitter.com/DXTestCafe). We post TestCafe news and updates.
183
178
 
184
179
  ## Contributing
185
180
 
@@ -187,14 +182,13 @@ Read our [Contributing Guide](https://github.com/DevExpress/testcafe/blob/master
187
182
 
188
183
  To create your own plugin for TestCafe, you can use these plugin generators:
189
184
 
190
- * [Build a browser provider](https://testcafe.io/documentation/402812/guides/extend-testcafe/browser-provider-plugin)
191
- to set up tests on your on-premises server farm, to use a cloud testing platform, or to start your local browsers in a special way. Use this [Yeoman generator](https://www.npmjs.com/package/generator-testcafe-browser-provider) to write only a few lines of code.
185
+ * [Build a browser provider](https://testcafe.io/documentation/402812/guides/extend-testcafe/browser-provider-plugin) to set up tests on your on-premises server farm, to use a cloud testing platform, or to start your local browsers in a special way. Use this [Yeoman generator](https://www.npmjs.com/package/generator-testcafe-browser-provider) to write only a few lines of code.
192
186
  * To [build a custom reporter](https://testcafe.io/documentation/402810/guides/extend-testcafe/reporter-plugin)
193
187
  with your formatting and style, check out this [generator](https://www.npmjs.com/package/generator-testcafe-reporter).
194
188
 
195
189
  If you want your plugin to be listed below, [send us a note in a Github issue](https://github.com/DevExpress/testcafe/issues/new).
196
190
 
197
- Thank you to all the people who already contributed to TestCafe!
191
+ Thanks to all of our contributors We appreciate your commitment to the TestCafe community.
198
192
 
199
193
  [<img alt="aha-oretama" src="https://avatars.githubusercontent.com/u/7259161?v=4&s=117" width="117">](https://github.com/aha-oretama) |[<img alt="ai" src="https://avatars.githubusercontent.com/u/19343?v=4&s=117" width="117">](https://github.com/ai) |[<img alt="aleks-pro" src="https://avatars.githubusercontent.com/u/14822473?v=4&s=117" width="117">](https://github.com/aleks-pro) |[<img alt="Aleksey28" src="https://avatars.githubusercontent.com/u/32869530?v=4&s=117" width="117">](https://github.com/Aleksey28) |[<img alt="AlexanderMoiseev" src="https://avatars.githubusercontent.com/u/1498953?v=4&s=117" width="117">](https://github.com/AlexanderMoiseev) |[<img alt="AlexanderMoskovkin" src="https://avatars.githubusercontent.com/u/12047804?v=4&s=117" width="117">](https://github.com/AlexanderMoskovkin) |
200
194
  :---: |:---: |:---: |:---: |:---: |:---: |
@@ -6,22 +6,16 @@ const path = require('path');
6
6
  const url = require('url');
7
7
  const v8FlagsFilter = require('@devexpress/bin-v8-flags-filter');
8
8
 
9
- const EXPERIMENTAL_DEBUG_OPTION = '--experimental-debug';
10
- const EXPERIMENTAL_ESM_OPTION = '--experimental-esm';
9
+ const ESM_OPTION = '--esm';
11
10
 
12
- if (process.argv.slice(2).includes(EXPERIMENTAL_DEBUG_OPTION))
13
- require('../lib/cli');
11
+ const forcedArgs = [];
14
12
 
15
- else {
16
- const forcedArgs = [];
17
-
18
- if (process.argv.slice(2).includes(EXPERIMENTAL_ESM_OPTION)) {
19
- forcedArgs.push('--no-warnings');
20
- forcedArgs.push(`--experimental-loader=${url.pathToFileURL(path.join(__dirname, '../lib/compiler/esm-loader.js')).href}`);
21
- }
22
-
23
- v8FlagsFilter(path.join(__dirname, '../lib/cli'), {
24
- useShutdownMessage: true,
25
- forcedArgs,
26
- });
13
+ if (process.argv.slice(2).includes(ESM_OPTION)) {
14
+ forcedArgs.push('--no-warnings');
15
+ forcedArgs.push(`--experimental-loader=${url.pathToFileURL(path.join(__dirname, '../lib/compiler/esm-loader.js')).href}`);
27
16
  }
17
+
18
+ v8FlagsFilter(path.join(__dirname, '../lib/cli'), {
19
+ useShutdownMessage: true,
20
+ forcedArgs,
21
+ });
@@ -1,9 +1,5 @@
1
1
  "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
2
  Object.defineProperty(exports, "__esModule", { value: true });
6
- const test_file_temp_variable_name_1 = __importDefault(require("../../compiler/test-file/test-file-temp-variable-name"));
7
3
  const lazyRequire = require('import-lazy')(require);
8
4
  const ClientFunctionBuilder = lazyRequire('../../client-functions/client-function-builder');
9
5
  const SelectorBuilder = lazyRequire('../../client-functions/selectors/selector-builder');
@@ -11,7 +7,6 @@ const role = lazyRequire('../../role');
11
7
  const createRequestLogger = lazyRequire('../request-hooks/request-logger');
12
8
  const createRequestMock = lazyRequire('../request-hooks/request-mock/create-request-mock');
13
9
  const userVariables = lazyRequire('../user-variables');
14
- const addExportAPI = lazyRequire('../../compiler/test-file/add-export-api');
15
10
  // NOTE: We can't use lazy require for RequestHook, because it will break base class detection for inherited classes
16
11
  let RequestHook = null;
17
12
  // NOTE: We can't use lazy require for testControllerProxy, because it will break test controller detection
@@ -56,11 +51,6 @@ const exportableLib = {
56
51
  return userVariables.value;
57
52
  },
58
53
  };
59
- if (global[test_file_temp_variable_name_1.default]) {
60
- const { testFile, baseUrl } = global[test_file_temp_variable_name_1.default];
61
- addExportAPI(testFile, exportableLib, { isCompilerServiceMode: true, baseUrl });
62
- delete global[test_file_temp_variable_name_1.default];
63
- }
64
54
  exports.default = exportableLib;
65
55
  module.exports = exports.default;
66
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXBpL2V4cG9ydGFibGUtbGliL2luZGV4LmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUEseUhBQWlHO0FBRWpHLE1BQU0sV0FBVyxHQUFhLE9BQU8sQ0FBQyxhQUFhLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQztBQUM5RCxNQUFNLHFCQUFxQixHQUFHLFdBQVcsQ0FBQyxnREFBZ0QsQ0FBQyxDQUFDO0FBQzVGLE1BQU0sZUFBZSxHQUFTLFdBQVcsQ0FBQyxtREFBbUQsQ0FBQyxDQUFDO0FBQy9GLE1BQU0sSUFBSSxHQUFvQixXQUFXLENBQUMsWUFBWSxDQUFDLENBQUM7QUFDeEQsTUFBTSxtQkFBbUIsR0FBSyxXQUFXLENBQUMsaUNBQWlDLENBQUMsQ0FBQztBQUM3RSxNQUFNLGlCQUFpQixHQUFPLFdBQVcsQ0FBQyxtREFBbUQsQ0FBQyxDQUFDO0FBQy9GLE1BQU0sYUFBYSxHQUFXLFdBQVcsQ0FBQyxtQkFBbUIsQ0FBQyxDQUFDO0FBQy9ELE1BQU0sWUFBWSxHQUFZLFdBQVcsQ0FBQyx5Q0FBeUMsQ0FBQyxDQUFDO0FBRXJGLG9IQUFvSDtBQUNwSCxJQUFJLFdBQVcsR0FBRyxJQUFJLENBQUM7QUFFdkIsMkdBQTJHO0FBQzNHLElBQUksbUJBQW1CLEdBQUcsSUFBSSxDQUFDO0FBRS9CLFNBQVMsSUFBSSxDQUFFLFFBQVEsRUFBRSxNQUFNLEVBQUUsT0FBTztJQUNwQyxPQUFPLElBQUksQ0FBQyxVQUFVLENBQUMsUUFBUSxFQUFFLE1BQU0sRUFBRSxPQUFPLENBQUMsQ0FBQztBQUN0RCxDQUFDO0FBRUQsU0FBUyxXQUFXO0lBQ2hCLE9BQU8saUJBQWlCLEVBQUUsQ0FBQztBQUMvQixDQUFDO0FBRUQsU0FBUyxhQUFhLENBQUUscUJBQXFCLEVBQUUsVUFBVTtJQUNyRCxPQUFPLG1CQUFtQixDQUFDLHFCQUFxQixFQUFFLFVBQVUsQ0FBQyxDQUFDO0FBQ2xFLENBQUM7QUFFRCxTQUFTLGNBQWMsQ0FBRSxFQUFFLEVBQUUsT0FBTztJQUNoQyxNQUFNLE9BQU8sR0FBRyxJQUFJLHFCQUFxQixDQUFDLEVBQUUsRUFBRSxPQUFPLEVBQUUsRUFBRSxhQUFhLEVBQUUsZ0JBQWdCLEVBQUUsQ0FBQyxDQUFDO0lBRTVGLE9BQU8sT0FBTyxDQUFDLFdBQVcsRUFBRSxDQUFDO0FBQ2pDLENBQUM7QUFFRCxTQUFTLFFBQVEsQ0FBRSxFQUFFLEVBQUUsT0FBTztJQUMxQixNQUFNLE9BQU8sR0FBRyxJQUFJLGVBQWUsQ0FBQyxFQUFFLEVBQUUsT0FBTyxFQUFFLEVBQUUsYUFBYSxFQUFFLFVBQVUsRUFBRSxDQUFDLENBQUM7SUFFaEYsT0FBTyxPQUFPLENBQUMsV0FBVyxFQUFFLENBQUM7QUFDakMsQ0FBQztBQUVELE1BQU0sQ0FBQyxjQUFjLENBQUMsSUFBSSxFQUFFLFdBQVcsRUFBRTtJQUNyQyxHQUFHLEVBQUUsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLG1CQUFtQjtDQUN0QyxDQUFDLENBQUM7QUFFSCxNQUFNLGFBQWEsR0FBRztJQUNsQixJQUFJO0lBRUosY0FBYztJQUVkLFFBQVE7SUFFUixhQUFhO0lBRWIsV0FBVztJQUVYLElBQUksV0FBVztRQUNYLElBQUksQ0FBQyxXQUFXO1lBQ1osV0FBVyxHQUFHLE9BQU8sQ0FBQyx1QkFBdUIsQ0FBQyxDQUFDO1FBRW5ELE9BQU8sV0FBVyxDQUFDO0lBQ3ZCLENBQUM7SUFFRCxJQUFJLENBQUM7UUFDRCxJQUFJLENBQUMsbUJBQW1CO1lBQ3BCLG1CQUFtQixHQUFHLE9BQU8sQ0FBQywwQkFBMEIsQ0FBQyxDQUFDO1FBRTlELE9BQU8sbUJBQW1CLENBQUM7SUFDL0IsQ0FBQztJQUVELElBQUksYUFBYTtRQUNiLE9BQU8sYUFBYSxDQUFDLEtBQUssQ0FBQztJQUMvQixDQUFDO0NBQ0osQ0FBQztBQUVGLElBQUksTUFBTSxDQUFDLHNDQUE0QixDQUFDLEVBQUU7SUFDdEMsTUFBTSxFQUFFLFFBQVEsRUFBRSxPQUFPLEVBQUUsR0FBRyxNQUFNLENBQUMsc0NBQTRCLENBQUMsQ0FBQztJQUVuRSxZQUFZLENBQUMsUUFBUSxFQUFFLGFBQWEsRUFBRSxFQUFFLHFCQUFxQixFQUFFLElBQUksRUFBRSxPQUFPLEVBQUUsQ0FBQyxDQUFDO0lBRWhGLE9BQU8sTUFBTSxDQUFDLHNDQUE0QixDQUFDLENBQUM7Q0FDL0M7QUFFRCxrQkFBZSxhQUFhLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgVEVTVF9GSUxFX1RFTVBfVkFSSUFCTEVfTkFNRSBmcm9tICcuLi8uLi9jb21waWxlci90ZXN0LWZpbGUvdGVzdC1maWxlLXRlbXAtdmFyaWFibGUtbmFtZSc7XG5cbmNvbnN0IGxhenlSZXF1aXJlICAgICAgICAgICA9IHJlcXVpcmUoJ2ltcG9ydC1sYXp5JykocmVxdWlyZSk7XG5jb25zdCBDbGllbnRGdW5jdGlvbkJ1aWxkZXIgPSBsYXp5UmVxdWlyZSgnLi4vLi4vY2xpZW50LWZ1bmN0aW9ucy9jbGllbnQtZnVuY3Rpb24tYnVpbGRlcicpO1xuY29uc3QgU2VsZWN0b3JCdWlsZGVyICAgICAgID0gbGF6eVJlcXVpcmUoJy4uLy4uL2NsaWVudC1mdW5jdGlvbnMvc2VsZWN0b3JzL3NlbGVjdG9yLWJ1aWxkZXInKTtcbmNvbnN0IHJvbGUgICAgICAgICAgICAgICAgICA9IGxhenlSZXF1aXJlKCcuLi8uLi9yb2xlJyk7XG5jb25zdCBjcmVhdGVSZXF1ZXN0TG9nZ2VyICAgPSBsYXp5UmVxdWlyZSgnLi4vcmVxdWVzdC1ob29rcy9yZXF1ZXN0LWxvZ2dlcicpO1xuY29uc3QgY3JlYXRlUmVxdWVzdE1vY2sgICAgID0gbGF6eVJlcXVpcmUoJy4uL3JlcXVlc3QtaG9va3MvcmVxdWVzdC1tb2NrL2NyZWF0ZS1yZXF1ZXN0LW1vY2snKTtcbmNvbnN0IHVzZXJWYXJpYWJsZXMgICAgICAgICA9IGxhenlSZXF1aXJlKCcuLi91c2VyLXZhcmlhYmxlcycpO1xuY29uc3QgYWRkRXhwb3J0QVBJICAgICAgICAgID0gbGF6eVJlcXVpcmUoJy4uLy4uL2NvbXBpbGVyL3Rlc3QtZmlsZS9hZGQtZXhwb3J0LWFwaScpO1xuXG4vLyBOT1RFOiBXZSBjYW4ndCB1c2UgbGF6eSByZXF1aXJlIGZvciBSZXF1ZXN0SG9vaywgYmVjYXVzZSBpdCB3aWxsIGJyZWFrIGJhc2UgY2xhc3MgZGV0ZWN0aW9uIGZvciBpbmhlcml0ZWQgY2xhc3Nlc1xubGV0IFJlcXVlc3RIb29rID0gbnVsbDtcblxuLy8gTk9URTogV2UgY2FuJ3QgdXNlIGxhenkgcmVxdWlyZSBmb3IgdGVzdENvbnRyb2xsZXJQcm94eSwgYmVjYXVzZSBpdCB3aWxsIGJyZWFrIHRlc3QgY29udHJvbGxlciBkZXRlY3Rpb25cbmxldCB0ZXN0Q29udHJvbGxlclByb3h5ID0gbnVsbDtcblxuZnVuY3Rpb24gUm9sZSAobG9naW5VcmwsIGluaXRGbiwgb3B0aW9ucykge1xuICAgIHJldHVybiByb2xlLmNyZWF0ZVJvbGUobG9naW5VcmwsIGluaXRGbiwgb3B0aW9ucyk7XG59XG5cbmZ1bmN0aW9uIFJlcXVlc3RNb2NrICgpIHtcbiAgICByZXR1cm4gY3JlYXRlUmVxdWVzdE1vY2soKTtcbn1cblxuZnVuY3Rpb24gUmVxdWVzdExvZ2dlciAocmVxdWVzdEZpbHRlclJ1bGVJbml0LCBsb2dPcHRpb25zKSB7XG4gICAgcmV0dXJuIGNyZWF0ZVJlcXVlc3RMb2dnZXIocmVxdWVzdEZpbHRlclJ1bGVJbml0LCBsb2dPcHRpb25zKTtcbn1cblxuZnVuY3Rpb24gQ2xpZW50RnVuY3Rpb24gKGZuLCBvcHRpb25zKSB7XG4gICAgY29uc3QgYnVpbGRlciA9IG5ldyBDbGllbnRGdW5jdGlvbkJ1aWxkZXIoZm4sIG9wdGlvbnMsIHsgaW5zdGFudGlhdGlvbjogJ0NsaWVudEZ1bmN0aW9uJyB9KTtcblxuICAgIHJldHVybiBidWlsZGVyLmdldEZ1bmN0aW9uKCk7XG59XG5cbmZ1bmN0aW9uIFNlbGVjdG9yIChmbiwgb3B0aW9ucykge1xuICAgIGNvbnN0IGJ1aWxkZXIgPSBuZXcgU2VsZWN0b3JCdWlsZGVyKGZuLCBvcHRpb25zLCB7IGluc3RhbnRpYXRpb246ICdTZWxlY3RvcicgfSk7XG5cbiAgICByZXR1cm4gYnVpbGRlci5nZXRGdW5jdGlvbigpO1xufVxuXG5PYmplY3QuZGVmaW5lUHJvcGVydHkoUm9sZSwgJ2Fub255bW91cycsIHtcbiAgICBnZXQ6ICgpID0+IHJvbGUuY3JlYXRlQW5vbnltb3VzUm9sZSxcbn0pO1xuXG5jb25zdCBleHBvcnRhYmxlTGliID0ge1xuICAgIFJvbGUsXG5cbiAgICBDbGllbnRGdW5jdGlvbixcblxuICAgIFNlbGVjdG9yLFxuXG4gICAgUmVxdWVzdExvZ2dlcixcblxuICAgIFJlcXVlc3RNb2NrLFxuXG4gICAgZ2V0IFJlcXVlc3RIb29rICgpIHtcbiAgICAgICAgaWYgKCFSZXF1ZXN0SG9vaylcbiAgICAgICAgICAgIFJlcXVlc3RIb29rID0gcmVxdWlyZSgnLi4vcmVxdWVzdC1ob29rcy9ob29rJyk7XG5cbiAgICAgICAgcmV0dXJuIFJlcXVlc3RIb29rO1xuICAgIH0sXG5cbiAgICBnZXQgdCAoKSB7XG4gICAgICAgIGlmICghdGVzdENvbnRyb2xsZXJQcm94eSlcbiAgICAgICAgICAgIHRlc3RDb250cm9sbGVyUHJveHkgPSByZXF1aXJlKCcuLi90ZXN0LWNvbnRyb2xsZXIvcHJveHknKTtcblxuICAgICAgICByZXR1cm4gdGVzdENvbnRyb2xsZXJQcm94eTtcbiAgICB9LFxuXG4gICAgZ2V0IHVzZXJWYXJpYWJsZXMgKCkge1xuICAgICAgICByZXR1cm4gdXNlclZhcmlhYmxlcy52YWx1ZTtcbiAgICB9LFxufTtcblxuaWYgKGdsb2JhbFtURVNUX0ZJTEVfVEVNUF9WQVJJQUJMRV9OQU1FXSkge1xuICAgIGNvbnN0IHsgdGVzdEZpbGUsIGJhc2VVcmwgfSA9IGdsb2JhbFtURVNUX0ZJTEVfVEVNUF9WQVJJQUJMRV9OQU1FXTtcblxuICAgIGFkZEV4cG9ydEFQSSh0ZXN0RmlsZSwgZXhwb3J0YWJsZUxpYiwgeyBpc0NvbXBpbGVyU2VydmljZU1vZGU6IHRydWUsIGJhc2VVcmwgfSk7XG5cbiAgICBkZWxldGUgZ2xvYmFsW1RFU1RfRklMRV9URU1QX1ZBUklBQkxFX05BTUVdO1xufVxuXG5leHBvcnQgZGVmYXVsdCBleHBvcnRhYmxlTGliO1xuXG4iXX0=
56
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXBpL2V4cG9ydGFibGUtbGliL2luZGV4LmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsTUFBTSxXQUFXLEdBQWEsT0FBTyxDQUFDLGFBQWEsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxDQUFDO0FBQzlELE1BQU0scUJBQXFCLEdBQUcsV0FBVyxDQUFDLGdEQUFnRCxDQUFDLENBQUM7QUFDNUYsTUFBTSxlQUFlLEdBQVMsV0FBVyxDQUFDLG1EQUFtRCxDQUFDLENBQUM7QUFDL0YsTUFBTSxJQUFJLEdBQW9CLFdBQVcsQ0FBQyxZQUFZLENBQUMsQ0FBQztBQUN4RCxNQUFNLG1CQUFtQixHQUFLLFdBQVcsQ0FBQyxpQ0FBaUMsQ0FBQyxDQUFDO0FBQzdFLE1BQU0saUJBQWlCLEdBQU8sV0FBVyxDQUFDLG1EQUFtRCxDQUFDLENBQUM7QUFDL0YsTUFBTSxhQUFhLEdBQVcsV0FBVyxDQUFDLG1CQUFtQixDQUFDLENBQUM7QUFFL0Qsb0hBQW9IO0FBQ3BILElBQUksV0FBVyxHQUFHLElBQUksQ0FBQztBQUV2QiwyR0FBMkc7QUFDM0csSUFBSSxtQkFBbUIsR0FBRyxJQUFJLENBQUM7QUFFL0IsU0FBUyxJQUFJLENBQUUsUUFBUSxFQUFFLE1BQU0sRUFBRSxPQUFPO0lBQ3BDLE9BQU8sSUFBSSxDQUFDLFVBQVUsQ0FBQyxRQUFRLEVBQUUsTUFBTSxFQUFFLE9BQU8sQ0FBQyxDQUFDO0FBQ3RELENBQUM7QUFFRCxTQUFTLFdBQVc7SUFDaEIsT0FBTyxpQkFBaUIsRUFBRSxDQUFDO0FBQy9CLENBQUM7QUFFRCxTQUFTLGFBQWEsQ0FBRSxxQkFBcUIsRUFBRSxVQUFVO0lBQ3JELE9BQU8sbUJBQW1CLENBQUMscUJBQXFCLEVBQUUsVUFBVSxDQUFDLENBQUM7QUFDbEUsQ0FBQztBQUVELFNBQVMsY0FBYyxDQUFFLEVBQUUsRUFBRSxPQUFPO0lBQ2hDLE1BQU0sT0FBTyxHQUFHLElBQUkscUJBQXFCLENBQUMsRUFBRSxFQUFFLE9BQU8sRUFBRSxFQUFFLGFBQWEsRUFBRSxnQkFBZ0IsRUFBRSxDQUFDLENBQUM7SUFFNUYsT0FBTyxPQUFPLENBQUMsV0FBVyxFQUFFLENBQUM7QUFDakMsQ0FBQztBQUVELFNBQVMsUUFBUSxDQUFFLEVBQUUsRUFBRSxPQUFPO0lBQzFCLE1BQU0sT0FBTyxHQUFHLElBQUksZUFBZSxDQUFDLEVBQUUsRUFBRSxPQUFPLEVBQUUsRUFBRSxhQUFhLEVBQUUsVUFBVSxFQUFFLENBQUMsQ0FBQztJQUVoRixPQUFPLE9BQU8sQ0FBQyxXQUFXLEVBQUUsQ0FBQztBQUNqQyxDQUFDO0FBRUQsTUFBTSxDQUFDLGNBQWMsQ0FBQyxJQUFJLEVBQUUsV0FBVyxFQUFFO0lBQ3JDLEdBQUcsRUFBRSxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsbUJBQW1CO0NBQ3RDLENBQUMsQ0FBQztBQUVILE1BQU0sYUFBYSxHQUFHO0lBQ2xCLElBQUk7SUFFSixjQUFjO0lBRWQsUUFBUTtJQUVSLGFBQWE7SUFFYixXQUFXO0lBRVgsSUFBSSxXQUFXO1FBQ1gsSUFBSSxDQUFDLFdBQVc7WUFDWixXQUFXLEdBQUcsT0FBTyxDQUFDLHVCQUF1QixDQUFDLENBQUM7UUFFbkQsT0FBTyxXQUFXLENBQUM7SUFDdkIsQ0FBQztJQUVELElBQUksQ0FBQztRQUNELElBQUksQ0FBQyxtQkFBbUI7WUFDcEIsbUJBQW1CLEdBQUcsT0FBTyxDQUFDLDBCQUEwQixDQUFDLENBQUM7UUFFOUQsT0FBTyxtQkFBbUIsQ0FBQztJQUMvQixDQUFDO0lBRUQsSUFBSSxhQUFhO1FBQ2IsT0FBTyxhQUFhLENBQUMsS0FBSyxDQUFDO0lBQy9CLENBQUM7Q0FDSixDQUFDO0FBRUYsa0JBQWUsYUFBYSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiY29uc3QgbGF6eVJlcXVpcmUgICAgICAgICAgID0gcmVxdWlyZSgnaW1wb3J0LWxhenknKShyZXF1aXJlKTtcbmNvbnN0IENsaWVudEZ1bmN0aW9uQnVpbGRlciA9IGxhenlSZXF1aXJlKCcuLi8uLi9jbGllbnQtZnVuY3Rpb25zL2NsaWVudC1mdW5jdGlvbi1idWlsZGVyJyk7XG5jb25zdCBTZWxlY3RvckJ1aWxkZXIgICAgICAgPSBsYXp5UmVxdWlyZSgnLi4vLi4vY2xpZW50LWZ1bmN0aW9ucy9zZWxlY3RvcnMvc2VsZWN0b3ItYnVpbGRlcicpO1xuY29uc3Qgcm9sZSAgICAgICAgICAgICAgICAgID0gbGF6eVJlcXVpcmUoJy4uLy4uL3JvbGUnKTtcbmNvbnN0IGNyZWF0ZVJlcXVlc3RMb2dnZXIgICA9IGxhenlSZXF1aXJlKCcuLi9yZXF1ZXN0LWhvb2tzL3JlcXVlc3QtbG9nZ2VyJyk7XG5jb25zdCBjcmVhdGVSZXF1ZXN0TW9jayAgICAgPSBsYXp5UmVxdWlyZSgnLi4vcmVxdWVzdC1ob29rcy9yZXF1ZXN0LW1vY2svY3JlYXRlLXJlcXVlc3QtbW9jaycpO1xuY29uc3QgdXNlclZhcmlhYmxlcyAgICAgICAgID0gbGF6eVJlcXVpcmUoJy4uL3VzZXItdmFyaWFibGVzJyk7XG5cbi8vIE5PVEU6IFdlIGNhbid0IHVzZSBsYXp5IHJlcXVpcmUgZm9yIFJlcXVlc3RIb29rLCBiZWNhdXNlIGl0IHdpbGwgYnJlYWsgYmFzZSBjbGFzcyBkZXRlY3Rpb24gZm9yIGluaGVyaXRlZCBjbGFzc2VzXG5sZXQgUmVxdWVzdEhvb2sgPSBudWxsO1xuXG4vLyBOT1RFOiBXZSBjYW4ndCB1c2UgbGF6eSByZXF1aXJlIGZvciB0ZXN0Q29udHJvbGxlclByb3h5LCBiZWNhdXNlIGl0IHdpbGwgYnJlYWsgdGVzdCBjb250cm9sbGVyIGRldGVjdGlvblxubGV0IHRlc3RDb250cm9sbGVyUHJveHkgPSBudWxsO1xuXG5mdW5jdGlvbiBSb2xlIChsb2dpblVybCwgaW5pdEZuLCBvcHRpb25zKSB7XG4gICAgcmV0dXJuIHJvbGUuY3JlYXRlUm9sZShsb2dpblVybCwgaW5pdEZuLCBvcHRpb25zKTtcbn1cblxuZnVuY3Rpb24gUmVxdWVzdE1vY2sgKCkge1xuICAgIHJldHVybiBjcmVhdGVSZXF1ZXN0TW9jaygpO1xufVxuXG5mdW5jdGlvbiBSZXF1ZXN0TG9nZ2VyIChyZXF1ZXN0RmlsdGVyUnVsZUluaXQsIGxvZ09wdGlvbnMpIHtcbiAgICByZXR1cm4gY3JlYXRlUmVxdWVzdExvZ2dlcihyZXF1ZXN0RmlsdGVyUnVsZUluaXQsIGxvZ09wdGlvbnMpO1xufVxuXG5mdW5jdGlvbiBDbGllbnRGdW5jdGlvbiAoZm4sIG9wdGlvbnMpIHtcbiAgICBjb25zdCBidWlsZGVyID0gbmV3IENsaWVudEZ1bmN0aW9uQnVpbGRlcihmbiwgb3B0aW9ucywgeyBpbnN0YW50aWF0aW9uOiAnQ2xpZW50RnVuY3Rpb24nIH0pO1xuXG4gICAgcmV0dXJuIGJ1aWxkZXIuZ2V0RnVuY3Rpb24oKTtcbn1cblxuZnVuY3Rpb24gU2VsZWN0b3IgKGZuLCBvcHRpb25zKSB7XG4gICAgY29uc3QgYnVpbGRlciA9IG5ldyBTZWxlY3RvckJ1aWxkZXIoZm4sIG9wdGlvbnMsIHsgaW5zdGFudGlhdGlvbjogJ1NlbGVjdG9yJyB9KTtcblxuICAgIHJldHVybiBidWlsZGVyLmdldEZ1bmN0aW9uKCk7XG59XG5cbk9iamVjdC5kZWZpbmVQcm9wZXJ0eShSb2xlLCAnYW5vbnltb3VzJywge1xuICAgIGdldDogKCkgPT4gcm9sZS5jcmVhdGVBbm9ueW1vdXNSb2xlLFxufSk7XG5cbmNvbnN0IGV4cG9ydGFibGVMaWIgPSB7XG4gICAgUm9sZSxcblxuICAgIENsaWVudEZ1bmN0aW9uLFxuXG4gICAgU2VsZWN0b3IsXG5cbiAgICBSZXF1ZXN0TG9nZ2VyLFxuXG4gICAgUmVxdWVzdE1vY2ssXG5cbiAgICBnZXQgUmVxdWVzdEhvb2sgKCkge1xuICAgICAgICBpZiAoIVJlcXVlc3RIb29rKVxuICAgICAgICAgICAgUmVxdWVzdEhvb2sgPSByZXF1aXJlKCcuLi9yZXF1ZXN0LWhvb2tzL2hvb2snKTtcblxuICAgICAgICByZXR1cm4gUmVxdWVzdEhvb2s7XG4gICAgfSxcblxuICAgIGdldCB0ICgpIHtcbiAgICAgICAgaWYgKCF0ZXN0Q29udHJvbGxlclByb3h5KVxuICAgICAgICAgICAgdGVzdENvbnRyb2xsZXJQcm94eSA9IHJlcXVpcmUoJy4uL3Rlc3QtY29udHJvbGxlci9wcm94eScpO1xuXG4gICAgICAgIHJldHVybiB0ZXN0Q29udHJvbGxlclByb3h5O1xuICAgIH0sXG5cbiAgICBnZXQgdXNlclZhcmlhYmxlcyAoKSB7XG4gICAgICAgIHJldHVybiB1c2VyVmFyaWFibGVzLnZhbHVlO1xuICAgIH0sXG59O1xuXG5leHBvcnQgZGVmYXVsdCBleHBvcnRhYmxlTGliO1xuXG4iXX0=
@@ -15,9 +15,8 @@ const runtime_1 = require("../../errors/runtime");
15
15
  const option_names_1 = __importDefault(require("../../configuration/option-names"));
16
16
  const testcafe_hammerhead_1 = require("testcafe-hammerhead");
17
17
  const test_timeout_1 = __importDefault(require("./test-timeout"));
18
- const esm_runtime_holder_name_1 = __importDefault(require("../../services/compiler/esm-runtime-holder-name"));
19
18
  class Test extends testing_unit_1.default {
20
- constructor(testFile, isCompilerServiceMode = false, baseUrl, returnApiOrigin = true) {
19
+ constructor(testFile, baseUrl, returnApiOrigin = true) {
21
20
  // NOTE: 'fixture' directive can be missing
22
21
  const fixture = testFile.currentFixture;
23
22
  const pageUrl = (fixture === null || fixture === void 0 ? void 0 : fixture.pageUrl) || testcafe_hammerhead_1.SPECIAL_BLANK_PAGE;
@@ -29,16 +28,12 @@ class Test extends testing_unit_1.default {
29
28
  this.globalBeforeFn = null;
30
29
  this.globalAfterFn = null;
31
30
  this.timeouts = null;
32
- this._isCompilerService = isCompilerServiceMode;
33
31
  this._initFixture(testFile);
34
- // NOTE: This is internal data of 'esm' module
35
- // @ts-ignore
36
- this.esmRuntime = global[esm_runtime_holder_name_1.default] || null;
37
32
  if (returnApiOrigin)
38
33
  return this.apiOrigin;
39
34
  }
40
- static init({ testFile, baseUrl, isCompilerServiceMode }) {
41
- return testing_unit_1.default.init(Test, testFile, isCompilerServiceMode, baseUrl);
35
+ static init({ testFile, baseUrl }) {
36
+ return testing_unit_1.default.init(Test, testFile, baseUrl);
42
37
  }
43
38
  _initFixture(testFile) {
44
39
  this.fixture = testFile.currentFixture;
@@ -50,8 +45,6 @@ class Test extends testing_unit_1.default {
50
45
  this.skipJsErrorsOptions = this.fixture.skipJsErrorsOptions;
51
46
  }
52
47
  _add(name, fn) {
53
- if (this._isCompilerService && !this.fixture)
54
- this._initFixture(this.testFile);
55
48
  (0, type_assertions_1.assertType)(type_assertions_1.is.string, 'apiOrigin', 'The test name', name);
56
49
  (0, type_assertions_1.assertType)(type_assertions_1.is.function, 'apiOrigin', 'The test body', fn);
57
50
  (0, type_assertions_1.assertType)(type_assertions_1.is.nonNullObject, 'apiOrigin', `The fixture of '${name}' test`, this.fixture);
@@ -103,4 +96,4 @@ class Test extends testing_unit_1.default {
103
96
  exports.default = Test;
104
97
  testing_unit_1.default.makeAPIListForChildClass(Test);
105
98
  module.exports = exports.default;
106
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.js","sourceRoot":"","sources":["../../../src/api/structure/test.ts"],"names":[],"mappings":"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","sourcesContent":["import { flattenDeep as flatten, union } from 'lodash';\nimport TestingUnit from './testing-unit';\nimport UnitType from './unit-type';\nimport { assertType, is } from '../../errors/runtime/type-assertions';\nimport wrapTestFunction from '../wrap-test-function';\nimport assertRequestHookType from '../request-hooks/assert-type';\nimport assertClientScriptType from '../../custom-client-scripts/assert-type';\nimport { RUNTIME_ERRORS } from '../../errors/types';\nimport { APIError } from '../../errors/runtime';\nimport OPTION_NAMES from '../../configuration/option-names';\nimport TestFile from './test-file';\nimport Fixture from './fixture';\nimport RequestHook from '../request-hooks/hook';\nimport ClientScriptInit from '../../custom-client-scripts/client-script-init';\nimport { SPECIAL_BLANK_PAGE } from 'testcafe-hammerhead';\nimport { TestTimeouts } from './interfaces';\nimport TestTimeout from './test-timeout';\nimport ESM_RUNTIME_HOLDER_NAME from '../../services/compiler/esm-runtime-holder-name';\n\ninterface TestInitOptions {\n    testFile: TestFile;\n    baseUrl?: string;\n    isCompilerServiceMode?: boolean;\n}\n\nexport default class Test extends TestingUnit {\n    public fixture: Fixture | null;\n    public fn: Function | null;\n    public beforeFn: Function | null;\n    public afterFn: Function | null;\n    public globalBeforeFn: Function | null;\n    public globalAfterFn: Function | null;\n    public timeouts: TestTimeouts | null;\n    private readonly _isCompilerService: boolean;\n    public readonly esmRuntime: string;\n\n    public constructor (testFile: TestFile, isCompilerServiceMode = false, baseUrl?: string, returnApiOrigin = true) {\n        // NOTE: 'fixture' directive can be missing\n        const fixture = testFile.currentFixture as Fixture;\n        const pageUrl = fixture?.pageUrl || SPECIAL_BLANK_PAGE;\n\n        super(testFile, UnitType.test, pageUrl, baseUrl);\n\n        this.fixture        = null;\n        this.fn             = null;\n        this.beforeFn       = null;\n        this.afterFn        = null;\n        this.globalBeforeFn = null;\n        this.globalAfterFn  = null;\n        this.timeouts       = null;\n\n        this._isCompilerService = isCompilerServiceMode;\n\n        this._initFixture(testFile);\n\n        // NOTE: This is internal data of 'esm' module\n        // @ts-ignore\n        this.esmRuntime = global[ESM_RUNTIME_HOLDER_NAME] || null;\n\n        if (returnApiOrigin)\n            return this.apiOrigin as unknown as Test;\n    }\n\n    public static init ({ testFile, baseUrl, isCompilerServiceMode }: TestInitOptions): Test {\n        return TestingUnit.init(Test, testFile, isCompilerServiceMode, baseUrl) as unknown as Test;\n    }\n\n    private _initFixture (testFile: TestFile): void {\n        this.fixture = testFile.currentFixture;\n\n        if (!this.fixture)\n            return;\n\n        this.pageUrl             = this.fixture.pageUrl || SPECIAL_BLANK_PAGE;\n        this.requestHooks        = this.fixture.requestHooks.slice();\n        this.clientScripts       = this.fixture.clientScripts.slice();\n        this.skipJsErrorsOptions = this.fixture.skipJsErrorsOptions;\n    }\n\n    protected _add (name: string, fn: Function): Function {\n        if (this._isCompilerService && !this.fixture)\n            this._initFixture(this.testFile);\n\n        assertType(is.string, 'apiOrigin', 'The test name', name);\n        assertType(is.function, 'apiOrigin', 'The test body', fn);\n        assertType(is.nonNullObject, 'apiOrigin', `The fixture of '${name}' test`, this.fixture);\n\n        this.name = name;\n        this.fn   = wrapTestFunction(fn);\n\n        if (!this.testFile.collectedTests.includes(this))\n            this.testFile.collectedTests.push(this);\n\n        return this.apiOrigin;\n    }\n\n    private _before$ (fn: Function): Function {\n        assertType(is.function, 'before', 'The test.before hook', fn);\n\n        this.beforeFn = wrapTestFunction(fn);\n\n        return this.apiOrigin;\n    }\n\n    private _after$ (fn: Function): Function {\n        assertType(is.function, 'after', 'The test.after hook', fn);\n\n        this.afterFn = wrapTestFunction(fn);\n\n        return this.apiOrigin;\n    }\n\n    private _requestHooks$ (...hooks: RequestHook[]): Function {\n        if (this.apiMethodWasCalled.requestHooks)\n            throw new APIError(OPTION_NAMES.requestHooks, RUNTIME_ERRORS.multipleAPIMethodCallForbidden, OPTION_NAMES.requestHooks);\n\n        hooks = flatten(hooks);\n\n        assertRequestHookType(hooks);\n\n        this.requestHooks                    = union(this.requestHooks, hooks);\n        this.apiMethodWasCalled.requestHooks = true;\n\n        return this.apiOrigin;\n    }\n\n    private _clientScripts$ (...scripts: ClientScriptInit[]): Function {\n        if (this.apiMethodWasCalled.clientScripts)\n            throw new APIError(OPTION_NAMES.clientScripts, RUNTIME_ERRORS.multipleAPIMethodCallForbidden, OPTION_NAMES.clientScripts);\n\n        scripts = flatten(scripts);\n\n        assertClientScriptType(scripts);\n\n        this.clientScripts                    = union(this.clientScripts, scripts);\n        this.apiMethodWasCalled.clientScripts = true;\n\n        return this.apiOrigin;\n    }\n\n    private _timeouts$ (timeouts: TestTimeouts): Function {\n        assertType(is.testTimeouts, 'timeouts', 'test.timeouts', timeouts);\n\n        Object.keys(TestTimeout)\n            .filter(timeout => timeout in timeouts)\n            .forEach(timeout => {\n                assertType(is.nonNegativeNumber, 'timeouts', `test.timeouts.${timeout}`, timeouts[timeout as keyof TestTimeouts]);\n            });\n\n        this.timeouts = timeouts;\n\n        return this.apiOrigin;\n    }\n}\n\nTestingUnit.makeAPIListForChildClass(Test);\n"]}
99
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.js","sourceRoot":"","sources":["../../../src/api/structure/test.ts"],"names":[],"mappings":";;;;;AAAA,mCAAuD;AACvD,kEAAyC;AACzC,4DAAmC;AACnC,0EAAsE;AACtE,+EAAqD;AACrD,+EAAiE;AACjE,0FAA6E;AAC7E,8CAAoD;AACpD,kDAAgD;AAChD,oFAA4D;AAK5D,6DAAyD;AAEzD,kEAAyC;AAOzC,MAAqB,IAAK,SAAQ,sBAAW;IASzC,YAAoB,QAAkB,EAAE,OAAgB,EAAE,eAAe,GAAG,IAAI;QAC5E,2CAA2C;QAC3C,MAAM,OAAO,GAAG,QAAQ,CAAC,cAAyB,CAAC;QACnD,MAAM,OAAO,GAAG,CAAA,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,OAAO,KAAI,wCAAkB,CAAC;QAEvD,KAAK,CAAC,QAAQ,EAAE,mBAAQ,CAAC,IAAI,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC;QAEjD,IAAI,CAAC,OAAO,GAAU,IAAI,CAAC;QAC3B,IAAI,CAAC,EAAE,GAAe,IAAI,CAAC;QAC3B,IAAI,CAAC,QAAQ,GAAS,IAAI,CAAC;QAC3B,IAAI,CAAC,OAAO,GAAU,IAAI,CAAC;QAC3B,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;QAC3B,IAAI,CAAC,aAAa,GAAI,IAAI,CAAC;QAC3B,IAAI,CAAC,QAAQ,GAAS,IAAI,CAAC;QAE3B,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;QAE5B,IAAI,eAAe;YACf,OAAO,IAAI,CAAC,SAA4B,CAAC;IACjD,CAAC;IAEM,MAAM,CAAC,IAAI,CAAE,EAAE,QAAQ,EAAE,OAAO,EAAmB;QACtD,OAAO,sBAAW,CAAC,IAAI,CAAC,IAAI,EAAE,QAAQ,EAAE,OAAO,CAAoB,CAAC;IACxE,CAAC;IAEO,YAAY,CAAE,QAAkB;QACpC,IAAI,CAAC,OAAO,GAAG,QAAQ,CAAC,cAAc,CAAC;QAEvC,IAAI,CAAC,IAAI,CAAC,OAAO;YACb,OAAO;QAEX,IAAI,CAAC,OAAO,GAAe,IAAI,CAAC,OAAO,CAAC,OAAO,IAAI,wCAAkB,CAAC;QACtE,IAAI,CAAC,YAAY,GAAU,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,KAAK,EAAE,CAAC;QAC7D,IAAI,CAAC,aAAa,GAAS,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;QAC9D,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,OAAO,CAAC,mBAAmB,CAAC;IAChE,CAAC;IAES,IAAI,CAAE,IAAY,EAAE,EAAY;QACtC,IAAA,4BAAU,EAAC,oBAAE,CAAC,MAAM,EAAE,WAAW,EAAE,eAAe,EAAE,IAAI,CAAC,CAAC;QAC1D,IAAA,4BAAU,EAAC,oBAAE,CAAC,QAAQ,EAAE,WAAW,EAAE,eAAe,EAAE,EAAE,CAAC,CAAC;QAC1D,IAAA,4BAAU,EAAC,oBAAE,CAAC,aAAa,EAAE,WAAW,EAAE,mBAAmB,IAAI,QAAQ,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;QAEzF,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjB,IAAI,CAAC,EAAE,GAAK,IAAA,4BAAgB,EAAC,EAAE,CAAC,CAAC;QAEjC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,QAAQ,CAAC,IAAI,CAAC;YAC5C,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAE5C,OAAO,IAAI,CAAC,SAAS,CAAC;IAC1B,CAAC;IAEO,QAAQ,CAAE,EAAY;QAC1B,IAAA,4BAAU,EAAC,oBAAE,CAAC,QAAQ,EAAE,QAAQ,EAAE,sBAAsB,EAAE,EAAE,CAAC,CAAC;QAE9D,IAAI,CAAC,QAAQ,GAAG,IAAA,4BAAgB,EAAC,EAAE,CAAC,CAAC;QAErC,OAAO,IAAI,CAAC,SAAS,CAAC;IAC1B,CAAC;IAEO,OAAO,CAAE,EAAY;QACzB,IAAA,4BAAU,EAAC,oBAAE,CAAC,QAAQ,EAAE,OAAO,EAAE,qBAAqB,EAAE,EAAE,CAAC,CAAC;QAE5D,IAAI,CAAC,OAAO,GAAG,IAAA,4BAAgB,EAAC,EAAE,CAAC,CAAC;QAEpC,OAAO,IAAI,CAAC,SAAS,CAAC;IAC1B,CAAC;IAEO,cAAc,CAAE,GAAG,KAAoB;QAC3C,IAAI,IAAI,CAAC,kBAAkB,CAAC,YAAY;YACpC,MAAM,IAAI,kBAAQ,CAAC,sBAAY,CAAC,YAAY,EAAE,sBAAc,CAAC,8BAA8B,EAAE,sBAAY,CAAC,YAAY,CAAC,CAAC;QAE5H,KAAK,GAAG,IAAA,oBAAO,EAAC,KAAK,CAAC,CAAC;QAEvB,IAAA,qBAAqB,EAAC,KAAK,CAAC,CAAC;QAE7B,IAAI,CAAC,YAAY,GAAsB,IAAA,cAAK,EAAC,IAAI,CAAC,YAAY,EAAE,KAAK,CAAC,CAAC;QACvE,IAAI,CAAC,kBAAkB,CAAC,YAAY,GAAG,IAAI,CAAC;QAE5C,OAAO,IAAI,CAAC,SAAS,CAAC;IAC1B,CAAC;IAEO,eAAe,CAAE,GAAG,OAA2B;QACnD,IAAI,IAAI,CAAC,kBAAkB,CAAC,aAAa;YACrC,MAAM,IAAI,kBAAQ,CAAC,sBAAY,CAAC,aAAa,EAAE,sBAAc,CAAC,8BAA8B,EAAE,sBAAY,CAAC,aAAa,CAAC,CAAC;QAE9H,OAAO,GAAG,IAAA,oBAAO,EAAC,OAAO,CAAC,CAAC;QAE3B,IAAA,qBAAsB,EAAC,OAAO,CAAC,CAAC;QAEhC,IAAI,CAAC,aAAa,GAAsB,IAAA,cAAK,EAAC,IAAI,CAAC,aAAa,EAAE,OAAO,CAAC,CAAC;QAC3E,IAAI,CAAC,kBAAkB,CAAC,aAAa,GAAG,IAAI,CAAC;QAE7C,OAAO,IAAI,CAAC,SAAS,CAAC;IAC1B,CAAC;IAEO,UAAU,CAAE,QAAsB;QACtC,IAAA,4BAAU,EAAC,oBAAE,CAAC,YAAY,EAAE,UAAU,EAAE,eAAe,EAAE,QAAQ,CAAC,CAAC;QAEnE,MAAM,CAAC,IAAI,CAAC,sBAAW,CAAC;aACnB,MAAM,CAAC,OAAO,CAAC,EAAE,CAAC,OAAO,IAAI,QAAQ,CAAC;aACtC,OAAO,CAAC,OAAO,CAAC,EAAE;YACf,IAAA,4BAAU,EAAC,oBAAE,CAAC,iBAAiB,EAAE,UAAU,EAAE,iBAAiB,OAAO,EAAE,EAAE,QAAQ,CAAC,OAA6B,CAAC,CAAC,CAAC;QACtH,CAAC,CAAC,CAAC;QAEP,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QAEzB,OAAO,IAAI,CAAC,SAAS,CAAC;IAC1B,CAAC;CACJ;AArHD,uBAqHC;AAED,sBAAW,CAAC,wBAAwB,CAAC,IAAI,CAAC,CAAC","sourcesContent":["import { flattenDeep as flatten, union } from 'lodash';\nimport TestingUnit from './testing-unit';\nimport UnitType from './unit-type';\nimport { assertType, is } from '../../errors/runtime/type-assertions';\nimport wrapTestFunction from '../wrap-test-function';\nimport assertRequestHookType from '../request-hooks/assert-type';\nimport assertClientScriptType from '../../custom-client-scripts/assert-type';\nimport { RUNTIME_ERRORS } from '../../errors/types';\nimport { APIError } from '../../errors/runtime';\nimport OPTION_NAMES from '../../configuration/option-names';\nimport TestFile from './test-file';\nimport Fixture from './fixture';\nimport RequestHook from '../request-hooks/hook';\nimport ClientScriptInit from '../../custom-client-scripts/client-script-init';\nimport { SPECIAL_BLANK_PAGE } from 'testcafe-hammerhead';\nimport { TestTimeouts } from './interfaces';\nimport TestTimeout from './test-timeout';\n\ninterface TestInitOptions {\n    testFile: TestFile;\n    baseUrl?: string;\n}\n\nexport default class Test extends TestingUnit {\n    public fixture: Fixture | null;\n    public fn: Function | null;\n    public beforeFn: Function | null;\n    public afterFn: Function | null;\n    public globalBeforeFn: Function | null;\n    public globalAfterFn: Function | null;\n    public timeouts: TestTimeouts | null;\n\n    public constructor (testFile: TestFile, baseUrl?: string, returnApiOrigin = true) {\n        // NOTE: 'fixture' directive can be missing\n        const fixture = testFile.currentFixture as Fixture;\n        const pageUrl = fixture?.pageUrl || SPECIAL_BLANK_PAGE;\n\n        super(testFile, UnitType.test, pageUrl, baseUrl);\n\n        this.fixture        = null;\n        this.fn             = null;\n        this.beforeFn       = null;\n        this.afterFn        = null;\n        this.globalBeforeFn = null;\n        this.globalAfterFn  = null;\n        this.timeouts       = null;\n\n        this._initFixture(testFile);\n\n        if (returnApiOrigin)\n            return this.apiOrigin as unknown as Test;\n    }\n\n    public static init ({ testFile, baseUrl }: TestInitOptions): Test {\n        return TestingUnit.init(Test, testFile, baseUrl) as unknown as Test;\n    }\n\n    private _initFixture (testFile: TestFile): void {\n        this.fixture = testFile.currentFixture;\n\n        if (!this.fixture)\n            return;\n\n        this.pageUrl             = this.fixture.pageUrl || SPECIAL_BLANK_PAGE;\n        this.requestHooks        = this.fixture.requestHooks.slice();\n        this.clientScripts       = this.fixture.clientScripts.slice();\n        this.skipJsErrorsOptions = this.fixture.skipJsErrorsOptions;\n    }\n\n    protected _add (name: string, fn: Function): Function {\n        assertType(is.string, 'apiOrigin', 'The test name', name);\n        assertType(is.function, 'apiOrigin', 'The test body', fn);\n        assertType(is.nonNullObject, 'apiOrigin', `The fixture of '${name}' test`, this.fixture);\n\n        this.name = name;\n        this.fn   = wrapTestFunction(fn);\n\n        if (!this.testFile.collectedTests.includes(this))\n            this.testFile.collectedTests.push(this);\n\n        return this.apiOrigin;\n    }\n\n    private _before$ (fn: Function): Function {\n        assertType(is.function, 'before', 'The test.before hook', fn);\n\n        this.beforeFn = wrapTestFunction(fn);\n\n        return this.apiOrigin;\n    }\n\n    private _after$ (fn: Function): Function {\n        assertType(is.function, 'after', 'The test.after hook', fn);\n\n        this.afterFn = wrapTestFunction(fn);\n\n        return this.apiOrigin;\n    }\n\n    private _requestHooks$ (...hooks: RequestHook[]): Function {\n        if (this.apiMethodWasCalled.requestHooks)\n            throw new APIError(OPTION_NAMES.requestHooks, RUNTIME_ERRORS.multipleAPIMethodCallForbidden, OPTION_NAMES.requestHooks);\n\n        hooks = flatten(hooks);\n\n        assertRequestHookType(hooks);\n\n        this.requestHooks                    = union(this.requestHooks, hooks);\n        this.apiMethodWasCalled.requestHooks = true;\n\n        return this.apiOrigin;\n    }\n\n    private _clientScripts$ (...scripts: ClientScriptInit[]): Function {\n        if (this.apiMethodWasCalled.clientScripts)\n            throw new APIError(OPTION_NAMES.clientScripts, RUNTIME_ERRORS.multipleAPIMethodCallForbidden, OPTION_NAMES.clientScripts);\n\n        scripts = flatten(scripts);\n\n        assertClientScriptType(scripts);\n\n        this.clientScripts                    = union(this.clientScripts, scripts);\n        this.apiMethodWasCalled.clientScripts = true;\n\n        return this.apiOrigin;\n    }\n\n    private _timeouts$ (timeouts: TestTimeouts): Function {\n        assertType(is.testTimeouts, 'timeouts', 'test.timeouts', timeouts);\n\n        Object.keys(TestTimeout)\n            .filter(timeout => timeout in timeouts)\n            .forEach(timeout => {\n                assertType(is.nonNegativeNumber, 'timeouts', `test.timeouts.${timeout}`, timeouts[timeout as keyof TestTimeouts]);\n            });\n\n        this.timeouts = timeouts;\n\n        return this.apiOrigin;\n    }\n}\n\nTestingUnit.makeAPIListForChildClass(Test);\n"]}
@@ -38,7 +38,9 @@ function createRequire(filename) {
38
38
  }
39
39
  function createSelectorDefinition(testRun) {
40
40
  return (fn, options = {}) => {
41
- const { skipVisibilityCheck, collectionMode } = testRun.controller.getExecutionContext()[OPTIONS_KEY];
41
+ const { skipVisibilityCheck, collectionMode } = testRun.controller ?
42
+ testRun.controller.getExecutionContext()[OPTIONS_KEY] :
43
+ createExecutionContext(testRun)[OPTIONS_KEY];
42
44
  if (skipVisibilityCheck)
43
45
  options.visibilityCheck = false;
44
46
  if (testRun && testRun.id)
@@ -86,4 +88,4 @@ function createExecutionContext(testRun) {
86
88
  }));
87
89
  }
88
90
  exports.createExecutionContext = createExecutionContext;
89
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"execution-context.js","sourceRoot":"","sources":["../../../src/api/test-controller/execution-context.js"],"names":[],"mappings":"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","sourcesContent":["import { createContext } from 'vm';\nimport Module from 'module';\nimport path from 'path';\nimport exportableLib from '../exportable-lib';\nimport NODE_MODULES from '../../utils/node-modules-folder-name';\n\nconst OPTIONS_KEY = Symbol('options');\n\nexport const DEFAULT_CONTEXT_OPTIONS = {\n    skipVisibilityCheck: false,\n    collectionMode:      false,\n};\n\nfunction getModuleBasePaths (currentPath) {\n    const nodePaths = [];\n    let parentDir   = path.dirname(currentPath);\n\n    while (currentPath !== parentDir) {\n        currentPath = parentDir;\n        parentDir   = path.dirname(currentPath);\n\n        nodePaths.push(path.join(currentPath, NODE_MODULES));\n    }\n\n    return nodePaths;\n}\n\nfunction createRequire (filename) {\n    //Deprecated since: Node v12.2.0\n    if (Module.createRequireFromPath)\n        return Module.createRequireFromPath(filename);\n\n    if (Module.createRequire)\n        return Module.createRequire(filename);\n\n    const dummyModule          = new Module(filename, module);\n    const localModulesPaths    = getModuleBasePaths(filename);\n\n    dummyModule.filename = filename;\n    dummyModule.paths    = localModulesPaths.concat(module.paths);\n\n    return id => dummyModule.require(id);\n}\n\nfunction createSelectorDefinition (testRun) {\n    return (fn, options = {}) => {\n        const { skipVisibilityCheck, collectionMode } = testRun.controller.getExecutionContext()[OPTIONS_KEY];\n\n        if (skipVisibilityCheck)\n            options.visibilityCheck = false;\n\n        if (testRun && testRun.id)\n            options.boundTestRun = testRun;\n\n        if (collectionMode)\n            options.collectionMode = collectionMode;\n\n        return exportableLib.Selector(fn, options);\n    };\n}\n\nfunction createClientFunctionDefinition (testRun) {\n    return (fn, options = {}) => {\n        if (testRun && testRun.id)\n            options.boundTestRun = testRun;\n\n        return exportableLib.ClientFunction(fn, options);\n    };\n}\n\nexport function setContextOptions (context, options) {\n    context[OPTIONS_KEY] = options;\n}\n\nexport function createExecutionContext (testRun) {\n    const filename = testRun.test.testFile.filename;\n\n    const replacers = {\n        require:        createRequire(filename),\n        __filename:     filename,\n        __dirname:      path.dirname(filename),\n        t:              testRun.controller,\n        Selector:       createSelectorDefinition(testRun),\n        ClientFunction: createClientFunctionDefinition(testRun),\n        Role:           exportableLib.Role,\n        RequestLogger:  exportableLib.RequestLogger,\n        RequestMock:    exportableLib.RequestMock,\n        RequestHook:    exportableLib.RequestHook,\n        [OPTIONS_KEY]:  DEFAULT_CONTEXT_OPTIONS,\n        userVariables:  exportableLib.userVariables,\n    };\n\n    return createContext(new Proxy(replacers, {\n        get: (target, property) => {\n            if (replacers.hasOwnProperty(property))\n                return replacers[property];\n\n            if (global.hasOwnProperty(property))\n                return global[property];\n\n            throw new Error(`${property} is not defined`);\n        },\n    }));\n}\n"]}
91
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"execution-context.js","sourceRoot":"","sources":["../../../src/api/test-controller/execution-context.js"],"names":[],"mappings":";;;;;;AAAA,2BAAmC;AACnC,oDAA4B;AAC5B,gDAAwB;AACxB,uEAA8C;AAC9C,oGAAgE;AAEhE,MAAM,WAAW,GAAG,MAAM,CAAC,SAAS,CAAC,CAAC;AAEzB,QAAA,uBAAuB,GAAG;IACnC,mBAAmB,EAAE,KAAK;IAC1B,cAAc,EAAO,KAAK;CAC7B,CAAC;AAEF,SAAS,kBAAkB,CAAE,WAAW;IACpC,MAAM,SAAS,GAAG,EAAE,CAAC;IACrB,IAAI,SAAS,GAAK,cAAI,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;IAE5C,OAAO,WAAW,KAAK,SAAS,EAAE;QAC9B,WAAW,GAAG,SAAS,CAAC;QACxB,SAAS,GAAK,cAAI,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;QAExC,SAAS,CAAC,IAAI,CAAC,cAAI,CAAC,IAAI,CAAC,WAAW,EAAE,kCAAY,CAAC,CAAC,CAAC;KACxD;IAED,OAAO,SAAS,CAAC;AACrB,CAAC;AAED,SAAS,aAAa,CAAE,QAAQ;IAC5B,gCAAgC;IAChC,IAAI,gBAAM,CAAC,qBAAqB;QAC5B,OAAO,gBAAM,CAAC,qBAAqB,CAAC,QAAQ,CAAC,CAAC;IAElD,IAAI,gBAAM,CAAC,aAAa;QACpB,OAAO,gBAAM,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;IAE1C,MAAM,WAAW,GAAY,IAAI,gBAAM,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAC;IAC1D,MAAM,iBAAiB,GAAM,kBAAkB,CAAC,QAAQ,CAAC,CAAC;IAE1D,WAAW,CAAC,QAAQ,GAAG,QAAQ,CAAC;IAChC,WAAW,CAAC,KAAK,GAAM,iBAAiB,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IAE9D,OAAO,EAAE,CAAC,EAAE,CAAC,WAAW,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;AACzC,CAAC;AAED,SAAS,wBAAwB,CAAE,OAAO;IACtC,OAAO,CAAC,EAAE,EAAE,OAAO,GAAG,EAAE,EAAE,EAAE;QACxB,MAAM,EAAE,mBAAmB,EAAE,cAAc,EAAE,GAAG,OAAO,CAAC,UAAU,CAAC,CAAC;YAChE,OAAO,CAAC,UAAU,CAAC,mBAAmB,EAAE,CAAC,WAAW,CAAC,CAAC,CAAC;YACvD,sBAAsB,CAAC,OAAO,CAAC,CAAC,WAAW,CAAC,CAAC;QAEjD,IAAI,mBAAmB;YACnB,OAAO,CAAC,eAAe,GAAG,KAAK,CAAC;QAEpC,IAAI,OAAO,IAAI,OAAO,CAAC,EAAE;YACrB,OAAO,CAAC,YAAY,GAAG,OAAO,CAAC;QAEnC,IAAI,cAAc;YACd,OAAO,CAAC,cAAc,GAAG,cAAc,CAAC;QAE5C,OAAO,wBAAa,CAAC,QAAQ,CAAC,EAAE,EAAE,OAAO,CAAC,CAAC;IAC/C,CAAC,CAAC;AACN,CAAC;AAED,SAAS,8BAA8B,CAAE,OAAO;IAC5C,OAAO,CAAC,EAAE,EAAE,OAAO,GAAG,EAAE,EAAE,EAAE;QACxB,IAAI,OAAO,IAAI,OAAO,CAAC,EAAE;YACrB,OAAO,CAAC,YAAY,GAAG,OAAO,CAAC;QAEnC,OAAO,wBAAa,CAAC,cAAc,CAAC,EAAE,EAAE,OAAO,CAAC,CAAC;IACrD,CAAC,CAAC;AACN,CAAC;AAED,SAAgB,iBAAiB,CAAE,OAAO,EAAE,OAAO;IAC/C,OAAO,CAAC,WAAW,CAAC,GAAG,OAAO,CAAC;AACnC,CAAC;AAFD,8CAEC;AAED,SAAgB,sBAAsB,CAAE,OAAO;IAC3C,MAAM,QAAQ,GAAG,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC;IAEhD,MAAM,SAAS,GAAG;QACd,OAAO,EAAS,aAAa,CAAC,QAAQ,CAAC;QACvC,UAAU,EAAM,QAAQ;QACxB,SAAS,EAAO,cAAI,CAAC,OAAO,CAAC,QAAQ,CAAC;QACtC,CAAC,EAAe,OAAO,CAAC,UAAU;QAClC,QAAQ,EAAQ,wBAAwB,CAAC,OAAO,CAAC;QACjD,cAAc,EAAE,8BAA8B,CAAC,OAAO,CAAC;QACvD,IAAI,EAAY,wBAAa,CAAC,IAAI;QAClC,aAAa,EAAG,wBAAa,CAAC,aAAa;QAC3C,WAAW,EAAK,wBAAa,CAAC,WAAW;QACzC,WAAW,EAAK,wBAAa,CAAC,WAAW;QACzC,CAAC,WAAW,CAAC,EAAG,+BAAuB;QACvC,aAAa,EAAG,wBAAa,CAAC,aAAa;KAC9C,CAAC;IAEF,OAAO,IAAA,kBAAa,EAAC,IAAI,KAAK,CAAC,SAAS,EAAE;QACtC,GAAG,EAAE,CAAC,MAAM,EAAE,QAAQ,EAAE,EAAE;YACtB,IAAI,SAAS,CAAC,cAAc,CAAC,QAAQ,CAAC;gBAClC,OAAO,SAAS,CAAC,QAAQ,CAAC,CAAC;YAE/B,IAAI,MAAM,CAAC,cAAc,CAAC,QAAQ,CAAC;gBAC/B,OAAO,MAAM,CAAC,QAAQ,CAAC,CAAC;YAE5B,MAAM,IAAI,KAAK,CAAC,GAAG,QAAQ,iBAAiB,CAAC,CAAC;QAClD,CAAC;KACJ,CAAC,CAAC,CAAC;AACR,CAAC;AA7BD,wDA6BC","sourcesContent":["import { createContext } from 'vm';\nimport Module from 'module';\nimport path from 'path';\nimport exportableLib from '../exportable-lib';\nimport NODE_MODULES from '../../utils/node-modules-folder-name';\n\nconst OPTIONS_KEY = Symbol('options');\n\nexport const DEFAULT_CONTEXT_OPTIONS = {\n    skipVisibilityCheck: false,\n    collectionMode:      false,\n};\n\nfunction getModuleBasePaths (currentPath) {\n    const nodePaths = [];\n    let parentDir   = path.dirname(currentPath);\n\n    while (currentPath !== parentDir) {\n        currentPath = parentDir;\n        parentDir   = path.dirname(currentPath);\n\n        nodePaths.push(path.join(currentPath, NODE_MODULES));\n    }\n\n    return nodePaths;\n}\n\nfunction createRequire (filename) {\n    //Deprecated since: Node v12.2.0\n    if (Module.createRequireFromPath)\n        return Module.createRequireFromPath(filename);\n\n    if (Module.createRequire)\n        return Module.createRequire(filename);\n\n    const dummyModule          = new Module(filename, module);\n    const localModulesPaths    = getModuleBasePaths(filename);\n\n    dummyModule.filename = filename;\n    dummyModule.paths    = localModulesPaths.concat(module.paths);\n\n    return id => dummyModule.require(id);\n}\n\nfunction createSelectorDefinition (testRun) {\n    return (fn, options = {}) => {\n        const { skipVisibilityCheck, collectionMode } = testRun.controller ?\n            testRun.controller.getExecutionContext()[OPTIONS_KEY] :\n            createExecutionContext(testRun)[OPTIONS_KEY];\n\n        if (skipVisibilityCheck)\n            options.visibilityCheck = false;\n\n        if (testRun && testRun.id)\n            options.boundTestRun = testRun;\n\n        if (collectionMode)\n            options.collectionMode = collectionMode;\n\n        return exportableLib.Selector(fn, options);\n    };\n}\n\nfunction createClientFunctionDefinition (testRun) {\n    return (fn, options = {}) => {\n        if (testRun && testRun.id)\n            options.boundTestRun = testRun;\n\n        return exportableLib.ClientFunction(fn, options);\n    };\n}\n\nexport function setContextOptions (context, options) {\n    context[OPTIONS_KEY] = options;\n}\n\nexport function createExecutionContext (testRun) {\n    const filename = testRun.test.testFile.filename;\n\n    const replacers = {\n        require:        createRequire(filename),\n        __filename:     filename,\n        __dirname:      path.dirname(filename),\n        t:              testRun.controller,\n        Selector:       createSelectorDefinition(testRun),\n        ClientFunction: createClientFunctionDefinition(testRun),\n        Role:           exportableLib.Role,\n        RequestLogger:  exportableLib.RequestLogger,\n        RequestMock:    exportableLib.RequestMock,\n        RequestHook:    exportableLib.RequestHook,\n        [OPTIONS_KEY]:  DEFAULT_CONTEXT_OPTIONS,\n        userVariables:  exportableLib.userVariables,\n    };\n\n    return createContext(new Proxy(replacers, {\n        get: (target, property) => {\n            if (replacers.hasOwnProperty(property))\n                return replacers[property];\n\n            if (global.hasOwnProperty(property))\n                return global[property];\n\n            throw new Error(`${property} is not defined`);\n        },\n    }));\n}\n"]}