testcafe 1.14.1 → 1.14.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (332) hide show
  1. package/CHANGELOG.md +6 -0
  2. package/LICENSE +21 -21
  3. package/bin/testcafe-with-v8-flag-filter.js +0 -0
  4. package/lib/api/exportable-lib/index.js +49 -49
  5. package/lib/api/request-hooks/assert-type.js +7 -7
  6. package/lib/api/request-hooks/hook-method-names.js +9 -9
  7. package/lib/api/request-hooks/hook.js +32 -32
  8. package/lib/api/request-hooks/interfaces.js +2 -2
  9. package/lib/api/request-hooks/request-logger.js +112 -112
  10. package/lib/api/request-hooks/request-mock/create-request-mock.js +10 -10
  11. package/lib/api/request-hooks/request-mock/index.js +44 -44
  12. package/lib/api/request-hooks/request-mock.js +46 -46
  13. package/lib/api/structure/base-unit.js +11 -11
  14. package/lib/api/structure/fixture.js +75 -75
  15. package/lib/api/structure/interfaces.js +2 -2
  16. package/lib/api/structure/test-file.js +31 -31
  17. package/lib/api/structure/test-timeout.js +9 -9
  18. package/lib/api/structure/test.js +85 -85
  19. package/lib/api/structure/testing-unit.js +89 -89
  20. package/lib/api/structure/unit-type.js +9 -9
  21. package/lib/api/test-controller/assertion.js +88 -88
  22. package/lib/api/test-controller/execution-context.js +82 -82
  23. package/lib/api/test-controller/index.js +358 -358
  24. package/lib/api/test-controller/proxy.js +28 -28
  25. package/lib/api/test-page-url.js +60 -60
  26. package/lib/api/test-run-tracker.js +68 -68
  27. package/lib/api/wrap-test-function.js +49 -49
  28. package/lib/assertions/executor.js +74 -74
  29. package/lib/assertions/get-fn.js +46 -46
  30. package/lib/assertions/type.js +20 -20
  31. package/lib/assets/content-types.js +9 -9
  32. package/lib/assets/injectables.js +18 -18
  33. package/lib/browser/connection/command.js +10 -10
  34. package/lib/browser/connection/error-hints.js +9 -9
  35. package/lib/browser/connection/gateway.js +159 -159
  36. package/lib/browser/connection/get-hints.js +33 -33
  37. package/lib/browser/connection/heartbeat-status.js +8 -8
  38. package/lib/browser/connection/index.js +328 -328
  39. package/lib/browser/connection/remotes-queue.js +46 -46
  40. package/lib/browser/connection/service-routes.js +12 -12
  41. package/lib/browser/connection/status.js +12 -12
  42. package/lib/browser/interfaces.js +2 -2
  43. package/lib/browser/provider/built-in/dedicated/base.js +80 -80
  44. package/lib/browser/provider/built-in/dedicated/chrome/browser-client.js +204 -204
  45. package/lib/browser/provider/built-in/dedicated/chrome/build-chrome-args.js +17 -17
  46. package/lib/browser/provider/built-in/dedicated/chrome/config.js +110 -110
  47. package/lib/browser/provider/built-in/dedicated/chrome/create-temp-profile.js +45 -45
  48. package/lib/browser/provider/built-in/dedicated/chrome/elapsed-upperbounds.js +15 -15
  49. package/lib/browser/provider/built-in/dedicated/chrome/index.js +102 -102
  50. package/lib/browser/provider/built-in/dedicated/chrome/interfaces.js +2 -2
  51. package/lib/browser/provider/built-in/dedicated/chrome/local-chrome.js +24 -24
  52. package/lib/browser/provider/built-in/dedicated/chrome/runtime-info.js +29 -29
  53. package/lib/browser/provider/built-in/dedicated/edge/index.js +10 -10
  54. package/lib/browser/provider/built-in/dedicated/edge/runtime-info.js +29 -29
  55. package/lib/browser/provider/built-in/dedicated/firefox/config.js +33 -33
  56. package/lib/browser/provider/built-in/dedicated/firefox/create-temp-profile.js +78 -78
  57. package/lib/browser/provider/built-in/dedicated/firefox/index.js +73 -73
  58. package/lib/browser/provider/built-in/dedicated/firefox/local-firefox.js +36 -36
  59. package/lib/browser/provider/built-in/dedicated/firefox/marionette-client/commands.js +13 -13
  60. package/lib/browser/provider/built-in/dedicated/firefox/marionette-client/index.js +200 -200
  61. package/lib/browser/provider/built-in/dedicated/firefox/runtime-info.js +17 -17
  62. package/lib/browser/provider/built-in/index.js +21 -21
  63. package/lib/browser/provider/built-in/locally-installed.js +30 -30
  64. package/lib/browser/provider/built-in/path.js +47 -47
  65. package/lib/browser/provider/built-in/remote.js +58 -58
  66. package/lib/browser/provider/index.js +303 -303
  67. package/lib/browser/provider/parse-provider-name.js +16 -16
  68. package/lib/browser/provider/plugin-host.js +121 -121
  69. package/lib/browser/provider/pool.js +115 -115
  70. package/lib/browser/provider/utils/argument-parsing.js +74 -74
  71. package/lib/browser/provider/utils/browser-starter.js +34 -34
  72. package/lib/browser/provider/utils/client-functions.js +24 -24
  73. package/lib/browser/provider/utils/get-maximized-headless-window-size.js +9 -9
  74. package/lib/cli/argument-parser.js +284 -284
  75. package/lib/cli/authentication-helper.js +35 -35
  76. package/lib/cli/cli.js +134 -134
  77. package/lib/cli/correct-browsers-and-sources.js +40 -40
  78. package/lib/cli/index.js +19 -19
  79. package/lib/cli/log.js +43 -43
  80. package/lib/cli/remotes-wizard.js +36 -36
  81. package/lib/cli/termination-handler.js +38 -38
  82. package/lib/client/automation/index.js +34 -16
  83. package/lib/client/automation/index.min.js +1 -1
  84. package/lib/client/browser/idle-page/index.html.mustache +35 -35
  85. package/lib/client/browser/idle-page/logo.svg +86 -86
  86. package/lib/client/core/index.js +14 -14
  87. package/lib/client/driver/index.js +46 -16
  88. package/lib/client/driver/index.min.js +1 -1
  89. package/lib/client/driver/internal-properties.js +9 -9
  90. package/lib/client/test-run/iframe.js.mustache +17 -17
  91. package/lib/client/test-run/index.js.mustache +51 -51
  92. package/lib/client/ui/index.js +14 -14
  93. package/lib/client/ui/sprite.svg +42 -42
  94. package/lib/client-functions/builder-symbol.js +4 -4
  95. package/lib/client-functions/client-function-builder.js +155 -155
  96. package/lib/client-functions/replicator.js +61 -61
  97. package/lib/client-functions/return-single-prop-mode.js +8 -8
  98. package/lib/client-functions/selector-api-execution-mode.js +20 -20
  99. package/lib/client-functions/selectors/add-api.js +645 -645
  100. package/lib/client-functions/selectors/create-snapshot-methods.js +13 -13
  101. package/lib/client-functions/selectors/prepare-api-args.js +20 -20
  102. package/lib/client-functions/selectors/selector-attribute-filter.js +22 -22
  103. package/lib/client-functions/selectors/selector-builder.js +153 -153
  104. package/lib/client-functions/selectors/selector-text-filter.js +43 -43
  105. package/lib/client-functions/selectors/snapshot-properties.js +48 -48
  106. package/lib/client-functions/types.js +18 -18
  107. package/lib/compiler/babel/format-babel-produced-code.js +10 -10
  108. package/lib/compiler/babel/get-base-babel-options.js +11 -11
  109. package/lib/compiler/babel/load-libs.js +63 -63
  110. package/lib/compiler/babel/preset-stage-2.js +19 -19
  111. package/lib/compiler/compile-client-function.js +73 -73
  112. package/lib/compiler/compilers.js +33 -33
  113. package/lib/compiler/index.js +92 -92
  114. package/lib/compiler/interfaces.js +2 -2
  115. package/lib/compiler/test-file/api-based.js +146 -146
  116. package/lib/compiler/test-file/base.js +36 -36
  117. package/lib/compiler/test-file/exportble-lib-path.js +5 -5
  118. package/lib/compiler/test-file/formats/coffeescript/compiler.js +38 -38
  119. package/lib/compiler/test-file/formats/coffeescript/get-test-list.js +29 -29
  120. package/lib/compiler/test-file/formats/es-next/compiler.js +42 -42
  121. package/lib/compiler/test-file/formats/es-next/get-test-list.js +166 -166
  122. package/lib/compiler/test-file/formats/es-next/is-flow-code.js +7 -7
  123. package/lib/compiler/test-file/formats/raw.js +85 -85
  124. package/lib/compiler/test-file/formats/typescript/compiler.js +135 -135
  125. package/lib/compiler/test-file/formats/typescript/get-test-list.js +185 -185
  126. package/lib/compiler/test-file/test-file-parser-base.js +214 -214
  127. package/lib/configuration/configuration-base.js +165 -165
  128. package/lib/configuration/constants.js +9 -9
  129. package/lib/configuration/customizable-compilers.js +7 -7
  130. package/lib/configuration/default-values.js +51 -51
  131. package/lib/configuration/interfaces.js +2 -2
  132. package/lib/configuration/option-names.js +53 -53
  133. package/lib/configuration/option-source.js +9 -9
  134. package/lib/configuration/option.js +14 -14
  135. package/lib/configuration/quarantine-option-names.js +8 -8
  136. package/lib/configuration/run-option-names.js +26 -26
  137. package/lib/configuration/screenshot-option-names.js +10 -10
  138. package/lib/configuration/testcafe-configuration.js +163 -163
  139. package/lib/configuration/types.js +2 -2
  140. package/lib/configuration/typescript-configuration.js +62 -62
  141. package/lib/custom-client-scripts/assert-type.js +7 -7
  142. package/lib/custom-client-scripts/client-script-init.js +2 -2
  143. package/lib/custom-client-scripts/client-script.js +106 -106
  144. package/lib/custom-client-scripts/get-code.js +11 -11
  145. package/lib/custom-client-scripts/get-url.js +6 -6
  146. package/lib/custom-client-scripts/load.js +15 -15
  147. package/lib/custom-client-scripts/problematic-scripts.js +2 -2
  148. package/lib/custom-client-scripts/routing.js +36 -36
  149. package/lib/custom-client-scripts/utils.js +60 -60
  150. package/lib/embedding-utils.js +83 -83
  151. package/lib/errors/create-stack-filter.js +18 -18
  152. package/lib/errors/error-list.js +26 -26
  153. package/lib/errors/get-callsite.js +31 -31
  154. package/lib/errors/internal-modules-prefix.js +8 -8
  155. package/lib/errors/is-internal-stack-frame.js +45 -45
  156. package/lib/errors/process-test-fn-error.js +37 -37
  157. package/lib/errors/runtime/index.js +123 -123
  158. package/lib/errors/runtime/templates.js +115 -115
  159. package/lib/errors/runtime/type-assertions.js +112 -112
  160. package/lib/errors/stack-cleaning-hook.js +64 -64
  161. package/lib/errors/test-run/formattable-adapter.js +59 -59
  162. package/lib/errors/test-run/index.js +301 -301
  163. package/lib/errors/test-run/render-error-template.js +31 -31
  164. package/lib/errors/test-run/templates.js +91 -91
  165. package/lib/errors/test-run/utils.js +89 -89
  166. package/lib/errors/types.js +156 -156
  167. package/lib/index.js +81 -81
  168. package/lib/live/bootstrapper.js +43 -43
  169. package/lib/live/controller.js +107 -107
  170. package/lib/live/file-watcher/index.js +67 -67
  171. package/lib/live/file-watcher/modules-graph.js +58 -58
  172. package/lib/live/keyboard-observer.js +76 -76
  173. package/lib/live/logger/index.js +64 -64
  174. package/lib/live/test-run-controller.js +96 -96
  175. package/lib/live/test-run-state.js +6 -6
  176. package/lib/live/test-run.js +56 -56
  177. package/lib/live/test-runner.js +167 -167
  178. package/lib/load-assets.js +29 -29
  179. package/lib/notifications/add-rendered-warning.js +16 -16
  180. package/lib/notifications/debug-logger.js +78 -78
  181. package/lib/notifications/deprecated.js +24 -24
  182. package/lib/notifications/information-message.js +9 -9
  183. package/lib/notifications/warning-log.js +31 -31
  184. package/lib/notifications/warning-message.js +47 -47
  185. package/lib/reporter/command/command-formatter.js +120 -109
  186. package/lib/reporter/command/format-command.js +8 -8
  187. package/lib/reporter/command/interfaces.js +2 -2
  188. package/lib/reporter/index.js +319 -314
  189. package/lib/reporter/interfaces.js +2 -2
  190. package/lib/reporter/plugin-host.js +135 -135
  191. package/lib/reporter/plugin-methods.js +12 -12
  192. package/lib/role/index.js +74 -74
  193. package/lib/role/marker-symbol.js +7 -7
  194. package/lib/role/phase.js +9 -9
  195. package/lib/runner/bootstrapper.js +271 -271
  196. package/lib/runner/browser-job-result.js +9 -9
  197. package/lib/runner/browser-job.js +152 -152
  198. package/lib/runner/browser-set.js +114 -114
  199. package/lib/runner/fixture-hook-controller.js +85 -85
  200. package/lib/runner/index.js +449 -449
  201. package/lib/runner/interfaces.js +2 -2
  202. package/lib/runner/reporter-stream-controller.js +27 -27
  203. package/lib/runner/task/index.js +151 -151
  204. package/lib/runner/task/phase.js +9 -9
  205. package/lib/runner/test-run-controller.js +165 -165
  206. package/lib/runner/tested-app.js +72 -72
  207. package/lib/screenshots/capturer.js +141 -141
  208. package/lib/screenshots/constants.js +11 -11
  209. package/lib/screenshots/crop.js +111 -111
  210. package/lib/screenshots/default-extension.js +4 -4
  211. package/lib/screenshots/index.js +67 -67
  212. package/lib/screenshots/utils.js +39 -39
  213. package/lib/services/compiler/host.js +190 -190
  214. package/lib/services/compiler/io.js +9 -9
  215. package/lib/services/compiler/protocol.js +17 -16
  216. package/lib/services/compiler/service.js +225 -212
  217. package/lib/services/compiler/test-run-proxy.js +111 -111
  218. package/lib/services/interfaces.js +2 -2
  219. package/lib/services/process-title.js +8 -8
  220. package/lib/services/serialization/prepare-options.js +17 -17
  221. package/lib/services/serialization/replicator/create-replicator.js +25 -25
  222. package/lib/services/serialization/replicator/custom-error-transform.js +26 -26
  223. package/lib/services/serialization/test-structure.js +92 -92
  224. package/lib/services/utils/ipc/interfaces.js +30 -30
  225. package/lib/services/utils/ipc/io.js +108 -108
  226. package/lib/services/utils/ipc/message.js +75 -75
  227. package/lib/services/utils/ipc/packet.js +55 -55
  228. package/lib/services/utils/ipc/proxy.js +109 -109
  229. package/lib/services/utils/ipc/transport.js +64 -64
  230. package/lib/shared/errors/index.js +382 -382
  231. package/lib/shared/node-modules-folder-name.js +4 -4
  232. package/lib/test-run/bookmark.js +90 -90
  233. package/lib/test-run/browser-console-messages.js +73 -73
  234. package/lib/test-run/browser-manipulation-queue.js +92 -92
  235. package/lib/test-run/client-messages.js +9 -9
  236. package/lib/test-run/commands/actions.js +486 -483
  237. package/lib/test-run/commands/assertion.js +45 -45
  238. package/lib/test-run/commands/base.js +14 -14
  239. package/lib/test-run/commands/browser-manipulation.js +95 -95
  240. package/lib/test-run/commands/from-object.js +82 -82
  241. package/lib/test-run/commands/observation.js +61 -61
  242. package/lib/test-run/commands/options.js +231 -215
  243. package/lib/test-run/commands/service.js +54 -48
  244. package/lib/test-run/commands/type.js +65 -64
  245. package/lib/test-run/commands/utils.js +87 -87
  246. package/lib/test-run/commands/validations/argument.js +90 -90
  247. package/lib/test-run/commands/validations/factories.js +47 -47
  248. package/lib/test-run/commands/validations/initializers.js +44 -44
  249. package/lib/test-run/debug-log.js +32 -32
  250. package/lib/test-run/execute-js-expression.js +74 -74
  251. package/lib/test-run/index.js +823 -799
  252. package/lib/test-run/marker-symbol.js +7 -7
  253. package/lib/test-run/observed-callsites-storage.js +17 -17
  254. package/lib/test-run/phase.js +16 -16
  255. package/lib/test-run/session-controller.js +104 -104
  256. package/lib/testcafe.js +118 -118
  257. package/lib/utils/assignable.js +39 -39
  258. package/lib/utils/async-event-emitter.js +28 -28
  259. package/lib/utils/async-queue.js +14 -14
  260. package/lib/utils/browser-connection-timeouts.js +19 -19
  261. package/lib/utils/callsite.js +17 -17
  262. package/lib/utils/check-file-path.js +31 -31
  263. package/lib/utils/check-url.js +51 -51
  264. package/lib/utils/convert-to-best-fit-type.js +16 -16
  265. package/lib/utils/correct-file-path.js +21 -21
  266. package/lib/utils/define-lazy-property.js +13 -13
  267. package/lib/utils/delay.js +6 -6
  268. package/lib/utils/delegated-api.js +44 -44
  269. package/lib/utils/detect-display.js +6 -6
  270. package/lib/utils/detect-ffmpeg.js +44 -44
  271. package/lib/utils/diff/colors.js +29 -29
  272. package/lib/utils/diff/index.js +52 -52
  273. package/lib/utils/diff/util.js +23 -23
  274. package/lib/utils/diff.js +29 -29
  275. package/lib/utils/escape-user-agent.js +10 -10
  276. package/lib/utils/flag-list.js +17 -17
  277. package/lib/utils/get-any-key.js +8 -8
  278. package/lib/utils/get-browser.js +8 -8
  279. package/lib/utils/get-common-path.js +34 -34
  280. package/lib/utils/get-filter-fn.js +40 -40
  281. package/lib/utils/get-options/base.js +36 -36
  282. package/lib/utils/get-options/compiler.js +33 -33
  283. package/lib/utils/get-options/grep.js +15 -15
  284. package/lib/utils/get-options/index.js +20 -20
  285. package/lib/utils/get-options/meta.js +22 -22
  286. package/lib/utils/get-options/quarantine.js +91 -91
  287. package/lib/utils/get-options/screenshot.js +17 -17
  288. package/lib/utils/get-options/ssl.js +45 -45
  289. package/lib/utils/get-options/video.js +10 -10
  290. package/lib/utils/get-viewport-width.js +17 -17
  291. package/lib/utils/guard-time-execution.js +10 -10
  292. package/lib/utils/handle-errors.js +74 -74
  293. package/lib/utils/handle-tag-args.js +8 -8
  294. package/lib/utils/http.js +30 -30
  295. package/lib/utils/is-localhost.js +11 -11
  296. package/lib/utils/is-password-input.js +11 -0
  297. package/lib/utils/is-repl.js +10 -10
  298. package/lib/utils/is-window-in-iframe.js +6 -6
  299. package/lib/utils/limit-number.js +10 -10
  300. package/lib/utils/make-reg-exp.js +7 -7
  301. package/lib/utils/moment-loader.js +20 -20
  302. package/lib/utils/parse-file-list.js +71 -71
  303. package/lib/utils/parse-user-agent.js +55 -55
  304. package/lib/utils/path-pattern.js +114 -114
  305. package/lib/utils/prepare-reporters.js +30 -30
  306. package/lib/utils/prerender-callsite.js +18 -18
  307. package/lib/utils/process.js +119 -119
  308. package/lib/utils/promisified-functions.js +46 -46
  309. package/lib/utils/re-executable-promise.js +39 -39
  310. package/lib/utils/render-callsite-sync.js +29 -29
  311. package/lib/utils/render-template.js +9 -9
  312. package/lib/utils/reporter.js +30 -30
  313. package/lib/utils/resolve-path-relatively-cwd.js +7 -7
  314. package/lib/utils/string.js +105 -105
  315. package/lib/utils/temp-directory/cleanup-process/commands.js +7 -7
  316. package/lib/utils/temp-directory/cleanup-process/index.js +143 -143
  317. package/lib/utils/temp-directory/cleanup-process/worker.js +58 -58
  318. package/lib/utils/temp-directory/index.js +87 -87
  319. package/lib/utils/temp-directory/lockfile.js +56 -56
  320. package/lib/utils/thennable.js +7 -7
  321. package/lib/utils/timer.js +15 -15
  322. package/lib/utils/to-posix-path.js +8 -8
  323. package/lib/utils/types.js +2 -2
  324. package/lib/video-recorder/interfaces.js +2 -2
  325. package/lib/video-recorder/process.js +126 -126
  326. package/lib/video-recorder/recorder.js +136 -136
  327. package/lib/video-recorder/test-run-video-recorder.js +69 -69
  328. package/lib/video-recorder/videos.js +37 -37
  329. package/package.json +2 -2
  330. package/ts-defs/index.d.ts +25 -14
  331. package/ts-defs/selectors.d.ts +16 -5
  332. package/ts-defs/testcafe-scripts.d.ts +17 -6
@@ -1,800 +1,824 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
5
- }) : (function(o, m, k, k2) {
6
- if (k2 === undefined) k2 = k;
7
- o[k2] = m[k];
8
- }));
9
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
10
- Object.defineProperty(o, "default", { enumerable: true, value: v });
11
- }) : function(o, v) {
12
- o["default"] = v;
13
- });
14
- var __importStar = (this && this.__importStar) || function (mod) {
15
- if (mod && mod.__esModule) return mod;
16
- var result = {};
17
- if (mod != null) for (var k in mod) if (k !== "default" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
18
- __setModuleDefault(result, mod);
19
- return result;
20
- };
21
- var __importDefault = (this && this.__importDefault) || function (mod) {
22
- return (mod && mod.__esModule) ? mod : { "default": mod };
23
- };
24
- Object.defineProperty(exports, "__esModule", { value: true });
25
- const lodash_1 = require("lodash");
26
- const read_file_relative_1 = require("read-file-relative");
27
- const promisify_event_1 = __importDefault(require("promisify-event"));
28
- const mustache_1 = __importDefault(require("mustache"));
29
- const async_event_emitter_1 = __importDefault(require("../utils/async-event-emitter"));
30
- const debug_log_1 = __importDefault(require("./debug-log"));
31
- const formattable_adapter_1 = __importDefault(require("../errors/test-run/formattable-adapter"));
32
- const error_list_1 = __importDefault(require("../errors/error-list"));
33
- const runtime_1 = require("../errors/runtime");
34
- const test_run_1 = require("../errors/test-run/");
35
- const phase_1 = __importDefault(require("./phase"));
36
- const client_messages_1 = __importDefault(require("./client-messages"));
37
- const type_1 = __importDefault(require("./commands/type"));
38
- const delay_1 = __importDefault(require("../utils/delay"));
39
- const marker_symbol_1 = __importDefault(require("./marker-symbol"));
40
- const test_run_tracker_1 = __importDefault(require("../api/test-run-tracker"));
41
- const phase_2 = __importDefault(require("../role/phase"));
42
- const plugin_host_1 = __importDefault(require("../reporter/plugin-host"));
43
- const browser_console_messages_1 = __importDefault(require("./browser-console-messages"));
44
- const warning_log_1 = __importDefault(require("../notifications/warning-log"));
45
- const warning_message_1 = __importDefault(require("../notifications/warning-message"));
46
- const testcafe_hammerhead_1 = require("testcafe-hammerhead");
47
- const INJECTABLES = __importStar(require("../assets/injectables"));
48
- const utils_1 = require("../custom-client-scripts/utils");
49
- const get_url_1 = __importDefault(require("../custom-client-scripts/get-url"));
50
- const string_1 = require("../utils/string");
51
- const utils_2 = require("./commands/utils");
52
- const actions_1 = require("./commands/actions");
53
- const types_1 = require("../errors/types");
54
- const process_test_fn_error_1 = __importDefault(require("../errors/process-test-fn-error"));
55
- const hook_method_names_1 = __importDefault(require("../api/request-hooks/hook-method-names"));
56
- const lazyRequire = require('import-lazy')(require);
57
- const SessionController = lazyRequire('./session-controller');
58
- const ObservedCallsitesStorage = lazyRequire('./observed-callsites-storage');
59
- const ClientFunctionBuilder = lazyRequire('../client-functions/client-function-builder');
60
- const BrowserManipulationQueue = lazyRequire('./browser-manipulation-queue');
61
- const TestRunBookmark = lazyRequire('./bookmark');
62
- const AssertionExecutor = lazyRequire('../assertions/executor');
63
- const actionCommands = lazyRequire('./commands/actions');
64
- const browserManipulationCommands = lazyRequire('./commands/browser-manipulation');
65
- const serviceCommands = lazyRequire('./commands/service');
66
- const observationCommands = lazyRequire('./commands/observation');
67
- const { executeJsExpression, executeAsyncJsExpression } = lazyRequire('./execute-js-expression');
68
- const TEST_RUN_TEMPLATE = read_file_relative_1.readSync('../client/test-run/index.js.mustache');
69
- const IFRAME_TEST_RUN_TEMPLATE = read_file_relative_1.readSync('../client/test-run/iframe.js.mustache');
70
- const TEST_DONE_CONFIRMATION_RESPONSE = 'test-done-confirmation';
71
- const MAX_RESPONSE_DELAY = 3000;
72
- const CHILD_WINDOW_READY_TIMEOUT = 30 * 1000;
73
- const ALL_DRIVER_TASKS_ADDED_TO_QUEUE_EVENT = 'all-driver-tasks-added-to-queue';
74
- const COMPILER_SERVICE_EVENTS = [
75
- 'setMock',
76
- 'setConfigureResponseEventOptions',
77
- 'setHeaderOnConfigureResponseEvent',
78
- 'removeHeaderOnConfigureResponseEvent'
79
- ];
80
- class TestRun extends async_event_emitter_1.default {
81
- constructor({ test, browserConnection, screenshotCapturer, globalWarningLog, opts, compilerService }) {
82
- super();
83
- this[marker_symbol_1.default] = true;
84
- this.warningLog = new warning_log_1.default(globalWarningLog);
85
- this.opts = opts;
86
- this.test = test;
87
- this.browserConnection = browserConnection;
88
- this.phase = phase_1.default.initial;
89
- this.driverTaskQueue = [];
90
- this.testDoneCommandQueued = false;
91
- this.activeDialogHandler = null;
92
- this.activeIframeSelector = null;
93
- this.speed = this.opts.speed;
94
- this.pageLoadTimeout = this._getPageLoadTimeout(test, opts);
95
- this.disablePageReloads = test.disablePageReloads || opts.disablePageReloads && test.disablePageReloads !== false;
96
- this.disablePageCaching = test.disablePageCaching || opts.disablePageCaching;
97
- this.disableMultipleWindows = opts.disableMultipleWindows;
98
- this.requestTimeout = this._getRequestTimeout(test, opts);
99
- this.session = SessionController.getSession(this);
100
- this.consoleMessages = new browser_console_messages_1.default();
101
- this.pendingRequest = null;
102
- this.pendingPageError = null;
103
- this.controller = null;
104
- this.ctx = Object.create(null);
105
- this.fixtureCtx = null;
106
- this.currentRoleId = null;
107
- this.usedRoleStates = Object.create(null);
108
- this.errs = [];
109
- this.lastDriverStatusId = null;
110
- this.lastDriverStatusResponse = null;
111
- this.fileDownloadingHandled = false;
112
- this.resolveWaitForFileDownloadingPromise = null;
113
- this.addingDriverTasksCount = 0;
114
- this.debugging = this.opts.debugMode;
115
- this.debugOnFail = this.opts.debugOnFail;
116
- this.disableDebugBreakpoints = false;
117
- this.debugReporterPluginHost = new plugin_host_1.default({ noColors: false });
118
- this.browserManipulationQueue = new BrowserManipulationQueue(browserConnection, screenshotCapturer, this.warningLog);
119
- this.debugLog = new debug_log_1.default(this.browserConnection.userAgent);
120
- this.quarantine = null;
121
- this.debugLogger = this.opts.debugLogger;
122
- this.observedCallsites = new ObservedCallsitesStorage();
123
- this.compilerService = compilerService;
124
- this._addInjectables();
125
- this._initRequestHooks();
126
- }
127
- _getPageLoadTimeout(test, opts) {
128
- var _a;
129
- if (((_a = test.timeouts) === null || _a === void 0 ? void 0 : _a.pageLoadTimeout) !== void 0)
130
- return test.timeouts.pageLoadTimeout;
131
- return opts.pageLoadTimeout;
132
- }
133
- _getRequestTimeout(test, opts) {
134
- var _a, _b;
135
- return {
136
- page: ((_a = test.timeouts) === null || _a === void 0 ? void 0 : _a.pageRequestTimeout) || opts.pageRequestTimeout,
137
- ajax: ((_b = test.timeouts) === null || _b === void 0 ? void 0 : _b.ajaxRequestTimeout) || opts.ajaxRequestTimeout
138
- };
139
- }
140
- _addClientScriptContentWarningsIfNecessary() {
141
- const { empty, duplicatedContent } = utils_1.findProblematicScripts(this.test.clientScripts);
142
- if (empty.length)
143
- this.warningLog.addWarning(warning_message_1.default.clientScriptsWithEmptyContent);
144
- if (duplicatedContent.length) {
145
- const suffix = string_1.getPluralSuffix(duplicatedContent);
146
- const duplicatedContentClientScriptsStr = string_1.getConcatenatedValuesString(duplicatedContent, '\n');
147
- this.warningLog.addWarning(warning_message_1.default.clientScriptsWithDuplicatedContent, suffix, duplicatedContentClientScriptsStr);
148
- }
149
- }
150
- _addInjectables() {
151
- this._addClientScriptContentWarningsIfNecessary();
152
- this.injectable.scripts.push(...INJECTABLES.SCRIPTS);
153
- this.injectable.userScripts.push(...this.test.clientScripts.map(script => {
154
- return {
155
- url: get_url_1.default(script),
156
- page: script.page
157
- };
158
- }));
159
- this.injectable.styles.push(INJECTABLES.TESTCAFE_UI_STYLES);
160
- }
161
- get id() {
162
- return this.session.id;
163
- }
164
- get injectable() {
165
- return this.session.injectable;
166
- }
167
- addQuarantineInfo(quarantine) {
168
- this.quarantine = quarantine;
169
- }
170
- addRequestHook(hook) {
171
- if (this.test.requestHooks.includes(hook))
172
- return;
173
- this.test.requestHooks.push(hook);
174
- this._initRequestHook(hook);
175
- }
176
- removeRequestHook(hook) {
177
- if (!this.test.requestHooks.includes(hook))
178
- return;
179
- lodash_1.pull(this.test.requestHooks, hook);
180
- this._disposeRequestHook(hook);
181
- }
182
- _initRequestHook(hook) {
183
- hook._warningLog = this.warningLog;
184
- hook._requestFilterRules.forEach(rule => {
185
- this.session.addRequestEventListeners(rule, {
186
- onRequest: hook.onRequest.bind(hook),
187
- onConfigureResponse: hook._onConfigureResponse.bind(hook),
188
- onResponse: hook.onResponse.bind(hook)
189
- }, err => this._onRequestHookMethodError(err, hook._className));
190
- });
191
- }
192
- _initRequestHookForCompilerService(hookId, hookClassName, rules) {
193
- const testId = this.test.id;
194
- rules.forEach(rule => {
195
- this.session.addRequestEventListeners(rule, {
196
- onRequest: event => this.compilerService.onRequestHookEvent({ testId, hookId, name: hook_method_names_1.default.onRequest, eventData: event }),
197
- onConfigureResponse: event => this.compilerService.onRequestHookEvent({ testId, hookId, name: hook_method_names_1.default._onConfigureResponse, eventData: event }),
198
- onResponse: event => this.compilerService.onRequestHookEvent({ testId, hookId, name: hook_method_names_1.default.onResponse, eventData: event })
199
- }, err => this._onRequestHookMethodError(err, hookClassName));
200
- });
201
- }
202
- _onRequestHookMethodError(event, hookClassName) {
203
- let err = event.error;
204
- const isRequestHookNotImplementedMethodError = (err === null || err === void 0 ? void 0 : err.code) === types_1.TEST_RUN_ERRORS.requestHookNotImplementedError;
205
- if (!isRequestHookNotImplementedMethodError)
206
- err = new test_run_1.RequestHookUnhandledError(err, hookClassName, event.methodName);
207
- this.addError(err);
208
- }
209
- _disposeRequestHook(hook) {
210
- hook._warningLog = null;
211
- hook._requestFilterRules.forEach(rule => {
212
- this.session.removeRequestEventListeners(rule);
213
- });
214
- }
215
- _detachRequestEventListeners(rules) {
216
- rules.forEach(rule => {
217
- this.session.removeRequestEventListeners(rule);
218
- });
219
- }
220
- _subscribeOnCompilerServiceEvents() {
221
- COMPILER_SERVICE_EVENTS.forEach(eventName => {
222
- this.compilerService.on(eventName, async (args) => {
223
- await this.session[eventName](...args);
224
- });
225
- });
226
- this.compilerService.on('addRequestEventListeners', async ({ hookId, hookClassName, rules }) => {
227
- this._initRequestHookForCompilerService(hookId, hookClassName, rules);
228
- });
229
- this.compilerService.on('removeRequestEventListeners', async ({ rules }) => {
230
- this._detachRequestEventListeners(rules);
231
- });
232
- }
233
- _initRequestHooks() {
234
- if (this.compilerService) {
235
- this._subscribeOnCompilerServiceEvents();
236
- this.test.requestHooks.forEach(hook => {
237
- this._initRequestHookForCompilerService(hook.id, hook._className, hook._requestFilterRules);
238
- });
239
- }
240
- else
241
- this.test.requestHooks.forEach(hook => this._initRequestHook(hook));
242
- }
243
- // Hammerhead payload
244
- async getPayloadScript() {
245
- this.fileDownloadingHandled = false;
246
- this.resolveWaitForFileDownloadingPromise = null;
247
- return mustache_1.default.render(TEST_RUN_TEMPLATE, {
248
- testRunId: JSON.stringify(this.session.id),
249
- browserId: JSON.stringify(this.browserConnection.id),
250
- browserHeartbeatRelativeUrl: JSON.stringify(this.browserConnection.heartbeatRelativeUrl),
251
- browserStatusRelativeUrl: JSON.stringify(this.browserConnection.statusRelativeUrl),
252
- browserStatusDoneRelativeUrl: JSON.stringify(this.browserConnection.statusDoneRelativeUrl),
253
- browserActiveWindowIdUrl: JSON.stringify(this.browserConnection.activeWindowIdUrl),
254
- userAgent: JSON.stringify(this.browserConnection.userAgent),
255
- testName: JSON.stringify(this.test.name),
256
- fixtureName: JSON.stringify(this.test.fixture.name),
257
- selectorTimeout: this.opts.selectorTimeout,
258
- pageLoadTimeout: this.pageLoadTimeout,
259
- childWindowReadyTimeout: CHILD_WINDOW_READY_TIMEOUT,
260
- skipJsErrors: this.opts.skipJsErrors,
261
- retryTestPages: this.opts.retryTestPages,
262
- speed: this.speed,
263
- dialogHandler: JSON.stringify(this.activeDialogHandler),
264
- canUseDefaultWindowActions: JSON.stringify(await this.browserConnection.canUseDefaultWindowActions())
265
- });
266
- }
267
- async getIframePayloadScript() {
268
- return mustache_1.default.render(IFRAME_TEST_RUN_TEMPLATE, {
269
- testRunId: JSON.stringify(this.session.id),
270
- selectorTimeout: this.opts.selectorTimeout,
271
- pageLoadTimeout: this.pageLoadTimeout,
272
- retryTestPages: !!this.opts.retryTestPages,
273
- speed: this.speed,
274
- dialogHandler: JSON.stringify(this.activeDialogHandler)
275
- });
276
- }
277
- // Hammerhead handlers
278
- getAuthCredentials() {
279
- return this.test.authCredentials;
280
- }
281
- handleFileDownload() {
282
- if (this.resolveWaitForFileDownloadingPromise) {
283
- this.resolveWaitForFileDownloadingPromise(true);
284
- this.resolveWaitForFileDownloadingPromise = null;
285
- }
286
- else
287
- this.fileDownloadingHandled = true;
288
- }
289
- handlePageError(ctx, err) {
290
- this.pendingPageError = new test_run_1.PageLoadError(err, ctx.reqOpts.url);
291
- ctx.redirect(ctx.toProxyUrl(testcafe_hammerhead_1.SPECIAL_ERROR_PAGE));
292
- }
293
- // Test function execution
294
- async _executeTestFn(phase, fn) {
295
- this.phase = phase;
296
- try {
297
- await fn(this);
298
- }
299
- catch (err) {
300
- await this._makeScreenshotOnFail();
301
- this.addError(err);
302
- return false;
303
- }
304
- finally {
305
- this.errScreenshotPath = null;
306
- }
307
- return !this._addPendingPageErrorIfAny();
308
- }
309
- async _runBeforeHook() {
310
- if (this.test.beforeFn)
311
- return await this._executeTestFn(phase_1.default.inTestBeforeHook, this.test.beforeFn);
312
- if (this.test.fixture.beforeEachFn)
313
- return await this._executeTestFn(phase_1.default.inFixtureBeforeEachHook, this.test.fixture.beforeEachFn);
314
- return true;
315
- }
316
- async _runAfterHook() {
317
- if (this.test.afterFn)
318
- return await this._executeTestFn(phase_1.default.inTestAfterHook, this.test.afterFn);
319
- if (this.test.fixture.afterEachFn)
320
- return await this._executeTestFn(phase_1.default.inFixtureAfterEachHook, this.test.fixture.afterEachFn);
321
- return true;
322
- }
323
- async start() {
324
- test_run_tracker_1.default.activeTestRuns[this.session.id] = this;
325
- await this.emit('start');
326
- const onDisconnected = err => this._disconnect(err);
327
- this.browserConnection.once('disconnected', onDisconnected);
328
- await this.once('connected');
329
- await this.emit('ready');
330
- if (await this._runBeforeHook()) {
331
- await this._executeTestFn(phase_1.default.inTest, this.test.fn);
332
- await this._runAfterHook();
333
- }
334
- if (this.disconnected)
335
- return;
336
- this.browserConnection.removeListener('disconnected', onDisconnected);
337
- if (this.errs.length && this.debugOnFail)
338
- await this._enqueueSetBreakpointCommand(null, this.debugReporterPluginHost.formatError(this.errs[0]));
339
- await this.emit('before-done');
340
- await this.executeCommand(new serviceCommands.TestDoneCommand());
341
- this._addPendingPageErrorIfAny();
342
- this.session.clearRequestEventListeners();
343
- this.normalizeRequestHookErrors();
344
- delete test_run_tracker_1.default.activeTestRuns[this.session.id];
345
- await this.emit('done');
346
- }
347
- // Errors
348
- _addPendingPageErrorIfAny() {
349
- if (this.pendingPageError) {
350
- this.addError(this.pendingPageError);
351
- this.pendingPageError = null;
352
- return true;
353
- }
354
- return false;
355
- }
356
- _createErrorAdapter(err) {
357
- return new formattable_adapter_1.default(err, {
358
- userAgent: this.browserConnection.userAgent,
359
- screenshotPath: this.errScreenshotPath || '',
360
- testRunId: this.id,
361
- testRunPhase: this.phase
362
- });
363
- }
364
- addError(err) {
365
- const errList = err instanceof error_list_1.default ? err.items : [err];
366
- errList.forEach(item => {
367
- const adapter = this._createErrorAdapter(item);
368
- this.errs.push(adapter);
369
- });
370
- }
371
- normalizeRequestHookErrors() {
372
- const requestHookErrors = lodash_1.remove(this.errs, e => e.code === types_1.TEST_RUN_ERRORS.requestHookNotImplementedError ||
373
- e.code === types_1.TEST_RUN_ERRORS.requestHookUnhandledError);
374
- if (!requestHookErrors.length)
375
- return;
376
- const uniqRequestHookErrors = lodash_1.chain(requestHookErrors)
377
- .uniqBy(e => e.hookClassName + e.methodName)
378
- .sortBy(['hookClassName', 'methodName'])
379
- .value();
380
- this.errs = this.errs.concat(uniqRequestHookErrors);
381
- }
382
- // Task queue
383
- _enqueueCommand(command, callsite) {
384
- if (this.pendingRequest)
385
- this._resolvePendingRequest(command);
386
- return new Promise(async (resolve, reject) => {
387
- this.addingDriverTasksCount--;
388
- this.driverTaskQueue.push({ command, resolve, reject, callsite });
389
- if (!this.addingDriverTasksCount)
390
- await this.emit(ALL_DRIVER_TASKS_ADDED_TO_QUEUE_EVENT, this.driverTaskQueue.length);
391
- });
392
- }
393
- get driverTaskQueueLength() {
394
- return this.addingDriverTasksCount ? promisify_event_1.default(this, ALL_DRIVER_TASKS_ADDED_TO_QUEUE_EVENT) : Promise.resolve(this.driverTaskQueue.length);
395
- }
396
- async _enqueueBrowserConsoleMessagesCommand(command, callsite) {
397
- await this._enqueueCommand(command, callsite);
398
- const consoleMessageCopy = this.consoleMessages.getCopy();
399
- return consoleMessageCopy[this.browserConnection.activeWindowId];
400
- }
401
- async _enqueueSetBreakpointCommand(callsite, error) {
402
- if (this.browserConnection.isHeadlessBrowser()) {
403
- this.warningLog.addWarning(warning_message_1.default.debugInHeadlessError);
404
- return;
405
- }
406
- if (this.debugLogger)
407
- this.debugLogger.showBreakpoint(this.session.id, this.browserConnection.userAgent, callsite, error);
408
- this.debugging = await this.executeCommand(new serviceCommands.SetBreakpointCommand(!!error), callsite);
409
- }
410
- _removeAllNonServiceTasks() {
411
- this.driverTaskQueue = this.driverTaskQueue.filter(driverTask => utils_2.isServiceCommand(driverTask.command));
412
- this.browserManipulationQueue.removeAllNonServiceManipulations();
413
- }
414
- // Current driver task
415
- get currentDriverTask() {
416
- return this.driverTaskQueue[0];
417
- }
418
- _resolveCurrentDriverTask(result) {
419
- this.currentDriverTask.resolve(result);
420
- this.driverTaskQueue.shift();
421
- if (this.testDoneCommandQueued)
422
- this._removeAllNonServiceTasks();
423
- }
424
- _rejectCurrentDriverTask(err) {
425
- err.callsite = err.callsite || this.currentDriverTask.callsite;
426
- this.currentDriverTask.reject(err);
427
- this._removeAllNonServiceTasks();
428
- }
429
- // Pending request
430
- _clearPendingRequest() {
431
- if (this.pendingRequest) {
432
- clearTimeout(this.pendingRequest.responseTimeout);
433
- this.pendingRequest = null;
434
- }
435
- }
436
- _resolvePendingRequest(command) {
437
- this.lastDriverStatusResponse = command;
438
- this.pendingRequest.resolve(command);
439
- this._clearPendingRequest();
440
- }
441
- // Handle driver request
442
- _shouldResolveCurrentDriverTask(driverStatus) {
443
- const currentCommand = this.currentDriverTask.command;
444
- const isExecutingObservationCommand = currentCommand instanceof observationCommands.ExecuteSelectorCommand ||
445
- currentCommand instanceof observationCommands.ExecuteClientFunctionCommand;
446
- const isDebugActive = currentCommand instanceof serviceCommands.SetBreakpointCommand;
447
- const shouldExecuteCurrentCommand = driverStatus.isFirstRequestAfterWindowSwitching && (isExecutingObservationCommand || isDebugActive);
448
- return !shouldExecuteCurrentCommand;
449
- }
450
- _fulfillCurrentDriverTask(driverStatus) {
451
- if (!this.currentDriverTask)
452
- return;
453
- if (driverStatus.executionError)
454
- this._rejectCurrentDriverTask(driverStatus.executionError);
455
- else if (this._shouldResolveCurrentDriverTask(driverStatus))
456
- this._resolveCurrentDriverTask(driverStatus.result);
457
- }
458
- _handlePageErrorStatus(pageError) {
459
- if (this.currentDriverTask && utils_2.isCommandRejectableByPageError(this.currentDriverTask.command)) {
460
- this._rejectCurrentDriverTask(pageError);
461
- this.pendingPageError = null;
462
- return true;
463
- }
464
- this.pendingPageError = this.pendingPageError || pageError;
465
- return false;
466
- }
467
- _handleDriverRequest(driverStatus) {
468
- const isTestDone = this.currentDriverTask && this.currentDriverTask.command.type ===
469
- type_1.default.testDone;
470
- const pageError = this.pendingPageError || driverStatus.pageError;
471
- const currentTaskRejectedByError = pageError && this._handlePageErrorStatus(pageError);
472
- this.consoleMessages.concat(driverStatus.consoleMessages);
473
- if (!currentTaskRejectedByError && driverStatus.isCommandResult) {
474
- if (isTestDone) {
475
- this._resolveCurrentDriverTask();
476
- return TEST_DONE_CONFIRMATION_RESPONSE;
477
- }
478
- this._fulfillCurrentDriverTask(driverStatus);
479
- if (driverStatus.isPendingWindowSwitching)
480
- return null;
481
- }
482
- return this._getCurrentDriverTaskCommand();
483
- }
484
- _getCurrentDriverTaskCommand() {
485
- if (!this.currentDriverTask)
486
- return null;
487
- const command = this.currentDriverTask.command;
488
- if (command.type === type_1.default.navigateTo && command.stateSnapshot)
489
- this.session.useStateSnapshot(JSON.parse(command.stateSnapshot));
490
- return command;
491
- }
492
- // Execute command
493
- _executeJsExpression(command) {
494
- const resultVariableName = command.resultVariableName;
495
- let expression = command.expression;
496
- if (resultVariableName)
497
- expression = `${resultVariableName} = ${expression}, ${resultVariableName}`;
498
- return executeJsExpression(expression, this, { skipVisibilityCheck: false });
499
- }
500
- async _executeAssertion(command, callsite) {
501
- const assertionTimeout = command.options.timeout ===
502
- void 0 ? this.opts.assertionTimeout : command.options.timeout;
503
- const executor = new AssertionExecutor(command, assertionTimeout, callsite);
504
- executor.once('start-assertion-retries', timeout => this.executeCommand(new serviceCommands.ShowAssertionRetriesStatusCommand(timeout)));
505
- executor.once('end-assertion-retries', success => this.executeCommand(new serviceCommands.HideAssertionRetriesStatusCommand(success)));
506
- const executeFn = this.decoratePreventEmitActionEvents(() => executor.run(), { prevent: true });
507
- return await executeFn();
508
- }
509
- _adjustConfigurationWithCommand(command) {
510
- if (command.type === type_1.default.testDone) {
511
- this.testDoneCommandQueued = true;
512
- if (this.debugLogger)
513
- this.debugLogger.hideBreakpoint(this.session.id);
514
- }
515
- else if (command.type === type_1.default.setNativeDialogHandler)
516
- this.activeDialogHandler = command.dialogHandler;
517
- else if (command.type === type_1.default.switchToIframe)
518
- this.activeIframeSelector = command.selector;
519
- else if (command.type === type_1.default.switchToMainWindow)
520
- this.activeIframeSelector = null;
521
- else if (command.type === type_1.default.setTestSpeed)
522
- this.speed = command.speed;
523
- else if (command.type === type_1.default.setPageLoadTimeout)
524
- this.pageLoadTimeout = command.duration;
525
- else if (command.type === type_1.default.debug)
526
- this.debugging = true;
527
- }
528
- async _adjustScreenshotCommand(command) {
529
- const browserId = this.browserConnection.id;
530
- const { hasChromelessScreenshots } = await this.browserConnection.provider.hasCustomActionForBrowser(browserId);
531
- if (!hasChromelessScreenshots)
532
- command.generateScreenshotMark();
533
- }
534
- async _setBreakpointIfNecessary(command, callsite) {
535
- if (!this.disableDebugBreakpoints && this.debugging && utils_2.canSetDebuggerBreakpointBeforeCommand(command))
536
- await this._enqueueSetBreakpointCommand(callsite);
537
- }
538
- async executeAction(apiActionName, command, callsite) {
539
- const actionArgs = { apiActionName, command };
540
- let errorAdapter = null;
541
- let error = null;
542
- let result = null;
543
- await this.emitActionEvent('action-start', actionArgs);
544
- const start = new Date();
545
- try {
546
- result = await this.executeCommand(command, callsite);
547
- }
548
- catch (err) {
549
- error = err;
550
- }
551
- const duration = new Date() - start;
552
- if (error) {
553
- // NOTE: check if error is TestCafeErrorList is specific for the `useRole` action
554
- // if error is TestCafeErrorList we do not need to create an adapter,
555
- // since error is already was processed in role initializer
556
- if (!(error instanceof error_list_1.default)) {
557
- await this._makeScreenshotOnFail();
558
- errorAdapter = this._createErrorAdapter(process_test_fn_error_1.default(error));
559
- }
560
- }
561
- Object.assign(actionArgs, {
562
- result,
563
- duration,
564
- err: errorAdapter
565
- });
566
- await this.emitActionEvent('action-done', actionArgs);
567
- if (error)
568
- throw error;
569
- return result;
570
- }
571
- async executeCommand(command, callsite) {
572
- this.debugLog.command(command);
573
- if (this.pendingPageError && utils_2.isCommandRejectableByPageError(command))
574
- return this._rejectCommandWithPageError(callsite);
575
- if (utils_2.isExecutableOnClientCommand(command))
576
- this.addingDriverTasksCount++;
577
- this._adjustConfigurationWithCommand(command);
578
- await this._setBreakpointIfNecessary(command, callsite);
579
- if (utils_2.isScreenshotCommand(command)) {
580
- if (this.opts.disableScreenshots) {
581
- this.warningLog.addWarning(warning_message_1.default.screenshotsDisabled);
582
- return null;
583
- }
584
- await this._adjustScreenshotCommand(command);
585
- }
586
- if (utils_2.isBrowserManipulationCommand(command)) {
587
- this.browserManipulationQueue.push(command);
588
- if (utils_2.isResizeWindowCommand(command) && this.opts.videoPath)
589
- this.warningLog.addWarning(warning_message_1.default.videoBrowserResizing, this.test.name);
590
- }
591
- if (command.type === type_1.default.wait)
592
- return delay_1.default(command.timeout);
593
- if (command.type === type_1.default.setPageLoadTimeout)
594
- return null;
595
- if (command.type === type_1.default.debug)
596
- return await this._enqueueSetBreakpointCommand(callsite);
597
- if (command.type === type_1.default.useRole) {
598
- let fn = () => this._useRole(command.role, callsite);
599
- fn = this.decoratePreventEmitActionEvents(fn, { prevent: true });
600
- fn = this.decorateDisableDebugBreakpoints(fn, { disable: true });
601
- return await fn();
602
- }
603
- if (command.type === type_1.default.assertion)
604
- return this._executeAssertion(command, callsite);
605
- if (command.type === type_1.default.executeExpression)
606
- return await this._executeJsExpression(command, callsite);
607
- if (command.type === type_1.default.executeAsyncExpression)
608
- return await executeAsyncJsExpression(command.expression, this, callsite);
609
- if (command.type === type_1.default.getBrowserConsoleMessages)
610
- return await this._enqueueBrowserConsoleMessagesCommand(command, callsite);
611
- if (command.type === type_1.default.switchToPreviousWindow)
612
- command.windowId = this.browserConnection.previousActiveWindowId;
613
- if (command.type === type_1.default.switchToWindowByPredicate)
614
- return this._switchToWindowByPredicate(command);
615
- return this._enqueueCommand(command, callsite);
616
- }
617
- _rejectCommandWithPageError(callsite) {
618
- const err = this.pendingPageError;
619
- err.callsite = callsite;
620
- this.pendingPageError = null;
621
- return Promise.reject(err);
622
- }
623
- async _makeScreenshotOnFail() {
624
- const { screenshots } = this.opts;
625
- if (!this.errScreenshotPath && screenshots && screenshots.takeOnFails)
626
- this.errScreenshotPath = await this.executeCommand(new browserManipulationCommands.TakeScreenshotOnFailCommand());
627
- }
628
- _decorateWithFlag(fn, flagName, value) {
629
- return async () => {
630
- this[flagName] = value;
631
- try {
632
- return await fn();
633
- }
634
- catch (err) {
635
- throw err;
636
- }
637
- finally {
638
- this[flagName] = !value;
639
- }
640
- };
641
- }
642
- decoratePreventEmitActionEvents(fn, { prevent }) {
643
- return this._decorateWithFlag(fn, 'preventEmitActionEvents', prevent);
644
- }
645
- decorateDisableDebugBreakpoints(fn, { disable }) {
646
- return this._decorateWithFlag(fn, 'disableDebugBreakpoints', disable);
647
- }
648
- // Role management
649
- async getStateSnapshot() {
650
- const state = this.session.getStateSnapshot();
651
- state.storages = await this.executeCommand(new serviceCommands.BackupStoragesCommand());
652
- return state;
653
- }
654
- async switchToCleanRun(url) {
655
- this.ctx = Object.create(null);
656
- this.fixtureCtx = Object.create(null);
657
- this.consoleMessages = new browser_console_messages_1.default();
658
- this.session.useStateSnapshot(testcafe_hammerhead_1.StateSnapshot.empty());
659
- if (this.speed !== this.opts.speed) {
660
- const setSpeedCommand = new actionCommands.SetTestSpeedCommand({ speed: this.opts.speed });
661
- await this.executeCommand(setSpeedCommand);
662
- }
663
- if (this.pageLoadTimeout !== this.opts.pageLoadTimeout) {
664
- const setPageLoadTimeoutCommand = new actionCommands.SetPageLoadTimeoutCommand({ duration: this.opts.pageLoadTimeout });
665
- await this.executeCommand(setPageLoadTimeoutCommand);
666
- }
667
- await this.navigateToUrl(url, true);
668
- if (this.activeDialogHandler) {
669
- const removeDialogHandlerCommand = new actionCommands.SetNativeDialogHandlerCommand({ dialogHandler: { fn: null } });
670
- await this.executeCommand(removeDialogHandlerCommand);
671
- }
672
- }
673
- async navigateToUrl(url, forceReload, stateSnapshot) {
674
- const navigateCommand = new actionCommands.NavigateToCommand({ url, forceReload, stateSnapshot });
675
- await this.executeCommand(navigateCommand);
676
- }
677
- async _getStateSnapshotFromRole(role) {
678
- const prevPhase = this.phase;
679
- this.phase = phase_1.default.inRoleInitializer;
680
- if (role.phase === phase_2.default.uninitialized)
681
- await role.initialize(this);
682
- else if (role.phase === phase_2.default.pendingInitialization)
683
- await promisify_event_1.default(role, 'initialized');
684
- if (role.initErr)
685
- throw role.initErr;
686
- this.phase = prevPhase;
687
- return role.stateSnapshot;
688
- }
689
- async _useRole(role, callsite) {
690
- if (this.phase === phase_1.default.inRoleInitializer)
691
- throw new test_run_1.RoleSwitchInRoleInitializerError(callsite);
692
- const bookmark = new TestRunBookmark(this, role);
693
- await bookmark.init();
694
- if (this.currentRoleId)
695
- this.usedRoleStates[this.currentRoleId] = await this.getStateSnapshot();
696
- const stateSnapshot = this.usedRoleStates[role.id] || await this._getStateSnapshotFromRole(role);
697
- this.session.useStateSnapshot(stateSnapshot);
698
- this.currentRoleId = role.id;
699
- await bookmark.restore(callsite, stateSnapshot);
700
- }
701
- async getCurrentUrl() {
702
- const builder = new ClientFunctionBuilder(() => {
703
- /* eslint-disable no-undef */
704
- return window.location.href;
705
- /* eslint-enable no-undef */
706
- }, { boundTestRun: this });
707
- const getLocation = builder.getFunction();
708
- return await getLocation();
709
- }
710
- async _switchToWindowByPredicate(command) {
711
- const currentWindows = await this.executeCommand(new actions_1.GetCurrentWindowsCommand({}, this));
712
- const windows = currentWindows.filter(wnd => {
713
- try {
714
- const url = new URL(wnd.url);
715
- return command.findWindow({ url, title: wnd.title });
716
- }
717
- catch (e) {
718
- throw new test_run_1.SwitchToWindowPredicateError(e.message);
719
- }
720
- });
721
- if (!windows.length)
722
- throw new test_run_1.WindowNotFoundError();
723
- if (windows.length > 1)
724
- this.warningLog.addWarning(warning_message_1.default.multipleWindowsFoundByPredicate);
725
- await this.executeCommand(new actions_1.SwitchToWindowCommand({ windowId: windows[0].id }), this);
726
- }
727
- _disconnect(err) {
728
- this.disconnected = true;
729
- if (this.currentDriverTask)
730
- this._rejectCurrentDriverTask(err);
731
- this.emit('disconnected', err);
732
- delete test_run_tracker_1.default.activeTestRuns[this.session.id];
733
- }
734
- async emitActionEvent(eventName, args) {
735
- if (!this.preventEmitActionEvents)
736
- await this.emit(eventName, args);
737
- }
738
- static isMultipleWindowsAllowed(testRun) {
739
- const { disableMultipleWindows, test, browserConnection } = testRun;
740
- return !disableMultipleWindows && !test.isLegacy && !!browserConnection.activeWindowId;
741
- }
742
- async initialize() {
743
- if (!this.compilerService)
744
- return;
745
- await this.compilerService.initializeTestRunProxy({
746
- testRunId: this.id,
747
- testId: this.test.id
748
- });
749
- }
750
- }
751
- exports.default = TestRun;
752
- // Service message handlers
753
- const ServiceMessages = TestRun.prototype;
754
- // NOTE: this function is time-critical and must return ASAP to avoid client disconnection
755
- ServiceMessages[client_messages_1.default.ready] = function (msg) {
756
- this.debugLog.driverMessage(msg);
757
- if (this.disconnected)
758
- return Promise.reject(new runtime_1.GeneralError(types_1.RUNTIME_ERRORS.testRunRequestInDisconnectedBrowser, this.browserConnection.browserInfo.alias));
759
- this.emit('connected');
760
- this._clearPendingRequest();
761
- // NOTE: the driver sends the status for the second time if it didn't get a response at the
762
- // first try. This is possible when the page was unloaded after the driver sent the status.
763
- if (msg.status.id === this.lastDriverStatusId)
764
- return this.lastDriverStatusResponse;
765
- this.lastDriverStatusId = msg.status.id;
766
- this.lastDriverStatusResponse = this._handleDriverRequest(msg.status);
767
- if (this.lastDriverStatusResponse || msg.status.isPendingWindowSwitching)
768
- return this.lastDriverStatusResponse;
769
- // NOTE: we send an empty response after the MAX_RESPONSE_DELAY timeout is exceeded to keep connection
770
- // with the client and prevent the response timeout exception on the client side
771
- const responseTimeout = setTimeout(() => this._resolvePendingRequest(null), MAX_RESPONSE_DELAY);
772
- return new Promise((resolve, reject) => {
773
- this.pendingRequest = { resolve, reject, responseTimeout };
774
- });
775
- };
776
- ServiceMessages[client_messages_1.default.readyForBrowserManipulation] = async function (msg) {
777
- this.debugLog.driverMessage(msg);
778
- let result = null;
779
- let error = null;
780
- try {
781
- result = await this.browserManipulationQueue.executePendingManipulation(msg);
782
- }
783
- catch (err) {
784
- error = err;
785
- }
786
- return { result, error };
787
- };
788
- ServiceMessages[client_messages_1.default.waitForFileDownload] = function (msg) {
789
- this.debugLog.driverMessage(msg);
790
- return new Promise(resolve => {
791
- if (this.fileDownloadingHandled) {
792
- this.fileDownloadingHandled = false;
793
- resolve(true);
794
- }
795
- else
796
- this.resolveWaitForFileDownloadingPromise = resolve;
797
- });
798
- };
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
5
+ }) : (function(o, m, k, k2) {
6
+ if (k2 === undefined) k2 = k;
7
+ o[k2] = m[k];
8
+ }));
9
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
10
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
11
+ }) : function(o, v) {
12
+ o["default"] = v;
13
+ });
14
+ var __importStar = (this && this.__importStar) || function (mod) {
15
+ if (mod && mod.__esModule) return mod;
16
+ var result = {};
17
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
18
+ __setModuleDefault(result, mod);
19
+ return result;
20
+ };
21
+ var __importDefault = (this && this.__importDefault) || function (mod) {
22
+ return (mod && mod.__esModule) ? mod : { "default": mod };
23
+ };
24
+ Object.defineProperty(exports, "__esModule", { value: true });
25
+ const lodash_1 = require("lodash");
26
+ const read_file_relative_1 = require("read-file-relative");
27
+ const promisify_event_1 = __importDefault(require("promisify-event"));
28
+ const mustache_1 = __importDefault(require("mustache"));
29
+ const async_event_emitter_1 = __importDefault(require("../utils/async-event-emitter"));
30
+ const debug_log_1 = __importDefault(require("./debug-log"));
31
+ const formattable_adapter_1 = __importDefault(require("../errors/test-run/formattable-adapter"));
32
+ const error_list_1 = __importDefault(require("../errors/error-list"));
33
+ const runtime_1 = require("../errors/runtime");
34
+ const test_run_1 = require("../errors/test-run/");
35
+ const phase_1 = __importDefault(require("./phase"));
36
+ const client_messages_1 = __importDefault(require("./client-messages"));
37
+ const type_1 = __importDefault(require("./commands/type"));
38
+ const delay_1 = __importDefault(require("../utils/delay"));
39
+ const is_password_input_1 = __importDefault(require("../utils/is-password-input"));
40
+ const marker_symbol_1 = __importDefault(require("./marker-symbol"));
41
+ const test_run_tracker_1 = __importDefault(require("../api/test-run-tracker"));
42
+ const phase_2 = __importDefault(require("../role/phase"));
43
+ const plugin_host_1 = __importDefault(require("../reporter/plugin-host"));
44
+ const browser_console_messages_1 = __importDefault(require("./browser-console-messages"));
45
+ const warning_log_1 = __importDefault(require("../notifications/warning-log"));
46
+ const warning_message_1 = __importDefault(require("../notifications/warning-message"));
47
+ const testcafe_hammerhead_1 = require("testcafe-hammerhead");
48
+ const INJECTABLES = __importStar(require("../assets/injectables"));
49
+ const utils_1 = require("../custom-client-scripts/utils");
50
+ const get_url_1 = __importDefault(require("../custom-client-scripts/get-url"));
51
+ const string_1 = require("../utils/string");
52
+ const utils_2 = require("./commands/utils");
53
+ const actions_1 = require("./commands/actions");
54
+ const types_1 = require("../errors/types");
55
+ const process_test_fn_error_1 = __importDefault(require("../errors/process-test-fn-error"));
56
+ const hook_method_names_1 = __importDefault(require("../api/request-hooks/hook-method-names"));
57
+ const replicator_1 = require("../client-functions/replicator");
58
+ const lazyRequire = require('import-lazy')(require);
59
+ const SessionController = lazyRequire('./session-controller');
60
+ const ObservedCallsitesStorage = lazyRequire('./observed-callsites-storage');
61
+ const ClientFunctionBuilder = lazyRequire('../client-functions/client-function-builder');
62
+ const BrowserManipulationQueue = lazyRequire('./browser-manipulation-queue');
63
+ const TestRunBookmark = lazyRequire('./bookmark');
64
+ const AssertionExecutor = lazyRequire('../assertions/executor');
65
+ const actionCommands = lazyRequire('./commands/actions');
66
+ const browserManipulationCommands = lazyRequire('./commands/browser-manipulation');
67
+ const serviceCommands = lazyRequire('./commands/service');
68
+ const observationCommands = lazyRequire('./commands/observation');
69
+ const { executeJsExpression, executeAsyncJsExpression } = lazyRequire('./execute-js-expression');
70
+ const TEST_RUN_TEMPLATE = read_file_relative_1.readSync('../client/test-run/index.js.mustache');
71
+ const IFRAME_TEST_RUN_TEMPLATE = read_file_relative_1.readSync('../client/test-run/iframe.js.mustache');
72
+ const TEST_DONE_CONFIRMATION_RESPONSE = 'test-done-confirmation';
73
+ const MAX_RESPONSE_DELAY = 3000;
74
+ const CHILD_WINDOW_READY_TIMEOUT = 30 * 1000;
75
+ const ALL_DRIVER_TASKS_ADDED_TO_QUEUE_EVENT = 'all-driver-tasks-added-to-queue';
76
+ const COMPILER_SERVICE_EVENTS = [
77
+ 'setMock',
78
+ 'setConfigureResponseEventOptions',
79
+ 'setHeaderOnConfigureResponseEvent',
80
+ 'removeHeaderOnConfigureResponseEvent'
81
+ ];
82
+ class TestRun extends async_event_emitter_1.default {
83
+ constructor({ test, browserConnection, screenshotCapturer, globalWarningLog, opts, compilerService }) {
84
+ super();
85
+ this[marker_symbol_1.default] = true;
86
+ this.warningLog = new warning_log_1.default(globalWarningLog);
87
+ this.opts = opts;
88
+ this.test = test;
89
+ this.browserConnection = browserConnection;
90
+ this.unstable = false;
91
+ this.phase = phase_1.default.initial;
92
+ this.driverTaskQueue = [];
93
+ this.testDoneCommandQueued = false;
94
+ this.activeDialogHandler = null;
95
+ this.activeIframeSelector = null;
96
+ this.speed = this.opts.speed;
97
+ this.pageLoadTimeout = this._getPageLoadTimeout(test, opts);
98
+ this.disablePageReloads = test.disablePageReloads || opts.disablePageReloads && test.disablePageReloads !== false;
99
+ this.disablePageCaching = test.disablePageCaching || opts.disablePageCaching;
100
+ this.disableMultipleWindows = opts.disableMultipleWindows;
101
+ this.requestTimeout = this._getRequestTimeout(test, opts);
102
+ this.session = SessionController.getSession(this);
103
+ this.consoleMessages = new browser_console_messages_1.default();
104
+ this.pendingRequest = null;
105
+ this.pendingPageError = null;
106
+ this.controller = null;
107
+ this.ctx = Object.create(null);
108
+ this.fixtureCtx = null;
109
+ this.currentRoleId = null;
110
+ this.usedRoleStates = Object.create(null);
111
+ this.errs = [];
112
+ this.lastDriverStatusId = null;
113
+ this.lastDriverStatusResponse = null;
114
+ this.fileDownloadingHandled = false;
115
+ this.resolveWaitForFileDownloadingPromise = null;
116
+ this.addingDriverTasksCount = 0;
117
+ this.debugging = this.opts.debugMode;
118
+ this.debugOnFail = this.opts.debugOnFail;
119
+ this.disableDebugBreakpoints = false;
120
+ this.debugReporterPluginHost = new plugin_host_1.default({ noColors: false });
121
+ this.browserManipulationQueue = new BrowserManipulationQueue(browserConnection, screenshotCapturer, this.warningLog);
122
+ this.debugLog = new debug_log_1.default(this.browserConnection.userAgent);
123
+ this.quarantine = null;
124
+ this.debugLogger = this.opts.debugLogger;
125
+ this.observedCallsites = new ObservedCallsitesStorage();
126
+ this.compilerService = compilerService;
127
+ this.replicator = replicator_1.createReplicator([new replicator_1.SelectorNodeTransform()]);
128
+ this._addInjectables();
129
+ this._initRequestHooks();
130
+ }
131
+ _getPageLoadTimeout(test, opts) {
132
+ var _a;
133
+ if (((_a = test.timeouts) === null || _a === void 0 ? void 0 : _a.pageLoadTimeout) !== void 0)
134
+ return test.timeouts.pageLoadTimeout;
135
+ return opts.pageLoadTimeout;
136
+ }
137
+ _getRequestTimeout(test, opts) {
138
+ var _a, _b;
139
+ return {
140
+ page: ((_a = test.timeouts) === null || _a === void 0 ? void 0 : _a.pageRequestTimeout) || opts.pageRequestTimeout,
141
+ ajax: ((_b = test.timeouts) === null || _b === void 0 ? void 0 : _b.ajaxRequestTimeout) || opts.ajaxRequestTimeout
142
+ };
143
+ }
144
+ _addClientScriptContentWarningsIfNecessary() {
145
+ const { empty, duplicatedContent } = utils_1.findProblematicScripts(this.test.clientScripts);
146
+ if (empty.length)
147
+ this.warningLog.addWarning(warning_message_1.default.clientScriptsWithEmptyContent);
148
+ if (duplicatedContent.length) {
149
+ const suffix = string_1.getPluralSuffix(duplicatedContent);
150
+ const duplicatedContentClientScriptsStr = string_1.getConcatenatedValuesString(duplicatedContent, '\n');
151
+ this.warningLog.addWarning(warning_message_1.default.clientScriptsWithDuplicatedContent, suffix, duplicatedContentClientScriptsStr);
152
+ }
153
+ }
154
+ _addInjectables() {
155
+ this._addClientScriptContentWarningsIfNecessary();
156
+ this.injectable.scripts.push(...INJECTABLES.SCRIPTS);
157
+ this.injectable.userScripts.push(...this.test.clientScripts.map(script => {
158
+ return {
159
+ url: get_url_1.default(script),
160
+ page: script.page
161
+ };
162
+ }));
163
+ this.injectable.styles.push(INJECTABLES.TESTCAFE_UI_STYLES);
164
+ }
165
+ get id() {
166
+ return this.session.id;
167
+ }
168
+ get injectable() {
169
+ return this.session.injectable;
170
+ }
171
+ addQuarantineInfo(quarantine) {
172
+ this.quarantine = quarantine;
173
+ }
174
+ addRequestHook(hook) {
175
+ if (this.test.requestHooks.includes(hook))
176
+ return;
177
+ this.test.requestHooks.push(hook);
178
+ this._initRequestHook(hook);
179
+ }
180
+ removeRequestHook(hook) {
181
+ if (!this.test.requestHooks.includes(hook))
182
+ return;
183
+ lodash_1.pull(this.test.requestHooks, hook);
184
+ this._disposeRequestHook(hook);
185
+ }
186
+ _initRequestHook(hook) {
187
+ hook._warningLog = this.warningLog;
188
+ hook._requestFilterRules.forEach(rule => {
189
+ this.session.addRequestEventListeners(rule, {
190
+ onRequest: hook.onRequest.bind(hook),
191
+ onConfigureResponse: hook._onConfigureResponse.bind(hook),
192
+ onResponse: hook.onResponse.bind(hook)
193
+ }, err => this._onRequestHookMethodError(err, hook._className));
194
+ });
195
+ }
196
+ _initRequestHookForCompilerService(hookId, hookClassName, rules) {
197
+ const testId = this.test.id;
198
+ rules.forEach(rule => {
199
+ this.session.addRequestEventListeners(rule, {
200
+ onRequest: event => this.compilerService.onRequestHookEvent({ testId, hookId, name: hook_method_names_1.default.onRequest, eventData: event }),
201
+ onConfigureResponse: event => this.compilerService.onRequestHookEvent({ testId, hookId, name: hook_method_names_1.default._onConfigureResponse, eventData: event }),
202
+ onResponse: event => this.compilerService.onRequestHookEvent({ testId, hookId, name: hook_method_names_1.default.onResponse, eventData: event })
203
+ }, err => this._onRequestHookMethodError(err, hookClassName));
204
+ });
205
+ }
206
+ _onRequestHookMethodError(event, hookClassName) {
207
+ let err = event.error;
208
+ const isRequestHookNotImplementedMethodError = (err === null || err === void 0 ? void 0 : err.code) === types_1.TEST_RUN_ERRORS.requestHookNotImplementedError;
209
+ if (!isRequestHookNotImplementedMethodError)
210
+ err = new test_run_1.RequestHookUnhandledError(err, hookClassName, event.methodName);
211
+ this.addError(err);
212
+ }
213
+ _disposeRequestHook(hook) {
214
+ hook._warningLog = null;
215
+ hook._requestFilterRules.forEach(rule => {
216
+ this.session.removeRequestEventListeners(rule);
217
+ });
218
+ }
219
+ _detachRequestEventListeners(rules) {
220
+ rules.forEach(rule => {
221
+ this.session.removeRequestEventListeners(rule);
222
+ });
223
+ }
224
+ _subscribeOnCompilerServiceEvents() {
225
+ COMPILER_SERVICE_EVENTS.forEach(eventName => {
226
+ this.compilerService.on(eventName, async (args) => {
227
+ await this.session[eventName](...args);
228
+ });
229
+ });
230
+ this.compilerService.on('addRequestEventListeners', async ({ hookId, hookClassName, rules }) => {
231
+ this._initRequestHookForCompilerService(hookId, hookClassName, rules);
232
+ });
233
+ this.compilerService.on('removeRequestEventListeners', async ({ rules }) => {
234
+ this._detachRequestEventListeners(rules);
235
+ });
236
+ }
237
+ _initRequestHooks() {
238
+ if (this.compilerService) {
239
+ this._subscribeOnCompilerServiceEvents();
240
+ this.test.requestHooks.forEach(hook => {
241
+ this._initRequestHookForCompilerService(hook.id, hook._className, hook._requestFilterRules);
242
+ });
243
+ }
244
+ else
245
+ this.test.requestHooks.forEach(hook => this._initRequestHook(hook));
246
+ }
247
+ // Hammerhead payload
248
+ async getPayloadScript() {
249
+ this.fileDownloadingHandled = false;
250
+ this.resolveWaitForFileDownloadingPromise = null;
251
+ return mustache_1.default.render(TEST_RUN_TEMPLATE, {
252
+ testRunId: JSON.stringify(this.session.id),
253
+ browserId: JSON.stringify(this.browserConnection.id),
254
+ browserHeartbeatRelativeUrl: JSON.stringify(this.browserConnection.heartbeatRelativeUrl),
255
+ browserStatusRelativeUrl: JSON.stringify(this.browserConnection.statusRelativeUrl),
256
+ browserStatusDoneRelativeUrl: JSON.stringify(this.browserConnection.statusDoneRelativeUrl),
257
+ browserActiveWindowIdUrl: JSON.stringify(this.browserConnection.activeWindowIdUrl),
258
+ userAgent: JSON.stringify(this.browserConnection.userAgent),
259
+ testName: JSON.stringify(this.test.name),
260
+ fixtureName: JSON.stringify(this.test.fixture.name),
261
+ selectorTimeout: this.opts.selectorTimeout,
262
+ pageLoadTimeout: this.pageLoadTimeout,
263
+ childWindowReadyTimeout: CHILD_WINDOW_READY_TIMEOUT,
264
+ skipJsErrors: this.opts.skipJsErrors,
265
+ retryTestPages: this.opts.retryTestPages,
266
+ speed: this.speed,
267
+ dialogHandler: JSON.stringify(this.activeDialogHandler),
268
+ canUseDefaultWindowActions: JSON.stringify(await this.browserConnection.canUseDefaultWindowActions())
269
+ });
270
+ }
271
+ async getIframePayloadScript() {
272
+ return mustache_1.default.render(IFRAME_TEST_RUN_TEMPLATE, {
273
+ testRunId: JSON.stringify(this.session.id),
274
+ selectorTimeout: this.opts.selectorTimeout,
275
+ pageLoadTimeout: this.pageLoadTimeout,
276
+ retryTestPages: !!this.opts.retryTestPages,
277
+ speed: this.speed,
278
+ dialogHandler: JSON.stringify(this.activeDialogHandler)
279
+ });
280
+ }
281
+ // Hammerhead handlers
282
+ getAuthCredentials() {
283
+ return this.test.authCredentials;
284
+ }
285
+ handleFileDownload() {
286
+ if (this.resolveWaitForFileDownloadingPromise) {
287
+ this.resolveWaitForFileDownloadingPromise(true);
288
+ this.resolveWaitForFileDownloadingPromise = null;
289
+ }
290
+ else
291
+ this.fileDownloadingHandled = true;
292
+ }
293
+ handlePageError(ctx, err) {
294
+ this.pendingPageError = new test_run_1.PageLoadError(err, ctx.reqOpts.url);
295
+ ctx.redirect(ctx.toProxyUrl(testcafe_hammerhead_1.SPECIAL_ERROR_PAGE));
296
+ }
297
+ // Test function execution
298
+ async _executeTestFn(phase, fn) {
299
+ this.phase = phase;
300
+ try {
301
+ await fn(this);
302
+ }
303
+ catch (err) {
304
+ await this._makeScreenshotOnFail();
305
+ this.addError(err);
306
+ return false;
307
+ }
308
+ finally {
309
+ this.errScreenshotPath = null;
310
+ }
311
+ return !this._addPendingPageErrorIfAny();
312
+ }
313
+ async _runBeforeHook() {
314
+ if (this.test.beforeFn)
315
+ return await this._executeTestFn(phase_1.default.inTestBeforeHook, this.test.beforeFn);
316
+ if (this.test.fixture.beforeEachFn)
317
+ return await this._executeTestFn(phase_1.default.inFixtureBeforeEachHook, this.test.fixture.beforeEachFn);
318
+ return true;
319
+ }
320
+ async _runAfterHook() {
321
+ if (this.test.afterFn)
322
+ return await this._executeTestFn(phase_1.default.inTestAfterHook, this.test.afterFn);
323
+ if (this.test.fixture.afterEachFn)
324
+ return await this._executeTestFn(phase_1.default.inFixtureAfterEachHook, this.test.fixture.afterEachFn);
325
+ return true;
326
+ }
327
+ async start() {
328
+ test_run_tracker_1.default.activeTestRuns[this.session.id] = this;
329
+ await this.emit('start');
330
+ const onDisconnected = err => this._disconnect(err);
331
+ this.browserConnection.once('disconnected', onDisconnected);
332
+ await this.once('connected');
333
+ await this.emit('ready');
334
+ if (await this._runBeforeHook()) {
335
+ await this._executeTestFn(phase_1.default.inTest, this.test.fn);
336
+ await this._runAfterHook();
337
+ }
338
+ if (this.disconnected)
339
+ return;
340
+ this.browserConnection.removeListener('disconnected', onDisconnected);
341
+ if (this.errs.length && this.debugOnFail)
342
+ await this._enqueueSetBreakpointCommand(null, this.debugReporterPluginHost.formatError(this.errs[0]));
343
+ await this.emit('before-done');
344
+ await this.executeCommand(new serviceCommands.TestDoneCommand());
345
+ this._addPendingPageErrorIfAny();
346
+ this.session.clearRequestEventListeners();
347
+ this.normalizeRequestHookErrors();
348
+ delete test_run_tracker_1.default.activeTestRuns[this.session.id];
349
+ await this.emit('done');
350
+ }
351
+ // Errors
352
+ _addPendingPageErrorIfAny() {
353
+ if (this.pendingPageError) {
354
+ this.addError(this.pendingPageError);
355
+ this.pendingPageError = null;
356
+ return true;
357
+ }
358
+ return false;
359
+ }
360
+ _createErrorAdapter(err) {
361
+ return new formattable_adapter_1.default(err, {
362
+ userAgent: this.browserConnection.userAgent,
363
+ screenshotPath: this.errScreenshotPath || '',
364
+ testRunId: this.id,
365
+ testRunPhase: this.phase
366
+ });
367
+ }
368
+ addError(err) {
369
+ const errList = err instanceof error_list_1.default ? err.items : [err];
370
+ errList.forEach(item => {
371
+ const adapter = this._createErrorAdapter(item);
372
+ this.errs.push(adapter);
373
+ });
374
+ }
375
+ normalizeRequestHookErrors() {
376
+ const requestHookErrors = lodash_1.remove(this.errs, e => e.code === types_1.TEST_RUN_ERRORS.requestHookNotImplementedError ||
377
+ e.code === types_1.TEST_RUN_ERRORS.requestHookUnhandledError);
378
+ if (!requestHookErrors.length)
379
+ return;
380
+ const uniqRequestHookErrors = lodash_1.chain(requestHookErrors)
381
+ .uniqBy(e => e.hookClassName + e.methodName)
382
+ .sortBy(['hookClassName', 'methodName'])
383
+ .value();
384
+ this.errs = this.errs.concat(uniqRequestHookErrors);
385
+ }
386
+ // Task queue
387
+ _enqueueCommand(command, callsite) {
388
+ if (this.pendingRequest)
389
+ this._resolvePendingRequest(command);
390
+ return new Promise(async (resolve, reject) => {
391
+ this.addingDriverTasksCount--;
392
+ this.driverTaskQueue.push({ command, resolve, reject, callsite });
393
+ if (!this.addingDriverTasksCount)
394
+ await this.emit(ALL_DRIVER_TASKS_ADDED_TO_QUEUE_EVENT, this.driverTaskQueue.length);
395
+ });
396
+ }
397
+ get driverTaskQueueLength() {
398
+ return this.addingDriverTasksCount ? promisify_event_1.default(this, ALL_DRIVER_TASKS_ADDED_TO_QUEUE_EVENT) : Promise.resolve(this.driverTaskQueue.length);
399
+ }
400
+ async _enqueueBrowserConsoleMessagesCommand(command, callsite) {
401
+ await this._enqueueCommand(command, callsite);
402
+ const consoleMessageCopy = this.consoleMessages.getCopy();
403
+ return consoleMessageCopy[this.browserConnection.activeWindowId];
404
+ }
405
+ async _enqueueSetBreakpointCommand(callsite, error) {
406
+ if (this.browserConnection.isHeadlessBrowser()) {
407
+ this.warningLog.addWarning(warning_message_1.default.debugInHeadlessError);
408
+ return;
409
+ }
410
+ if (this.debugLogger)
411
+ this.debugLogger.showBreakpoint(this.session.id, this.browserConnection.userAgent, callsite, error);
412
+ this.debugging = await this.executeCommand(new serviceCommands.SetBreakpointCommand(!!error), callsite);
413
+ }
414
+ _removeAllNonServiceTasks() {
415
+ this.driverTaskQueue = this.driverTaskQueue.filter(driverTask => utils_2.isServiceCommand(driverTask.command));
416
+ this.browserManipulationQueue.removeAllNonServiceManipulations();
417
+ }
418
+ // Current driver task
419
+ get currentDriverTask() {
420
+ return this.driverTaskQueue[0];
421
+ }
422
+ _resolveCurrentDriverTask(result) {
423
+ this.currentDriverTask.resolve(result);
424
+ this.driverTaskQueue.shift();
425
+ if (this.testDoneCommandQueued)
426
+ this._removeAllNonServiceTasks();
427
+ }
428
+ _rejectCurrentDriverTask(err) {
429
+ err.callsite = err.callsite || this.currentDriverTask.callsite;
430
+ this.currentDriverTask.reject(err);
431
+ this._removeAllNonServiceTasks();
432
+ }
433
+ // Pending request
434
+ _clearPendingRequest() {
435
+ if (this.pendingRequest) {
436
+ clearTimeout(this.pendingRequest.responseTimeout);
437
+ this.pendingRequest = null;
438
+ }
439
+ }
440
+ _resolvePendingRequest(command) {
441
+ this.lastDriverStatusResponse = command;
442
+ this.pendingRequest.resolve(command);
443
+ this._clearPendingRequest();
444
+ }
445
+ // Handle driver request
446
+ _shouldResolveCurrentDriverTask(driverStatus) {
447
+ const currentCommand = this.currentDriverTask.command;
448
+ const isExecutingObservationCommand = currentCommand instanceof observationCommands.ExecuteSelectorCommand ||
449
+ currentCommand instanceof observationCommands.ExecuteClientFunctionCommand;
450
+ const isDebugActive = currentCommand instanceof serviceCommands.SetBreakpointCommand;
451
+ const shouldExecuteCurrentCommand = driverStatus.isFirstRequestAfterWindowSwitching && (isExecutingObservationCommand || isDebugActive);
452
+ return !shouldExecuteCurrentCommand;
453
+ }
454
+ _fulfillCurrentDriverTask(driverStatus) {
455
+ if (!this.currentDriverTask)
456
+ return;
457
+ if (driverStatus.executionError)
458
+ this._rejectCurrentDriverTask(driverStatus.executionError);
459
+ else if (this._shouldResolveCurrentDriverTask(driverStatus))
460
+ this._resolveCurrentDriverTask(driverStatus.result);
461
+ }
462
+ _handlePageErrorStatus(pageError) {
463
+ if (this.currentDriverTask && utils_2.isCommandRejectableByPageError(this.currentDriverTask.command)) {
464
+ this._rejectCurrentDriverTask(pageError);
465
+ this.pendingPageError = null;
466
+ return true;
467
+ }
468
+ this.pendingPageError = this.pendingPageError || pageError;
469
+ return false;
470
+ }
471
+ _handleDriverRequest(driverStatus) {
472
+ const isTestDone = this.currentDriverTask && this.currentDriverTask.command.type ===
473
+ type_1.default.testDone;
474
+ const pageError = this.pendingPageError || driverStatus.pageError;
475
+ const currentTaskRejectedByError = pageError && this._handlePageErrorStatus(pageError);
476
+ this.consoleMessages.concat(driverStatus.consoleMessages);
477
+ if (!currentTaskRejectedByError && driverStatus.isCommandResult) {
478
+ if (isTestDone) {
479
+ this._resolveCurrentDriverTask();
480
+ return TEST_DONE_CONFIRMATION_RESPONSE;
481
+ }
482
+ this._fulfillCurrentDriverTask(driverStatus);
483
+ if (driverStatus.isPendingWindowSwitching)
484
+ return null;
485
+ }
486
+ return this._getCurrentDriverTaskCommand();
487
+ }
488
+ _getCurrentDriverTaskCommand() {
489
+ if (!this.currentDriverTask)
490
+ return null;
491
+ const command = this.currentDriverTask.command;
492
+ if (command.type === type_1.default.navigateTo && command.stateSnapshot)
493
+ this.session.useStateSnapshot(JSON.parse(command.stateSnapshot));
494
+ return command;
495
+ }
496
+ // Execute command
497
+ _executeJsExpression(command) {
498
+ const resultVariableName = command.resultVariableName;
499
+ let expression = command.expression;
500
+ if (resultVariableName)
501
+ expression = `${resultVariableName} = ${expression}, ${resultVariableName}`;
502
+ return executeJsExpression(expression, this, { skipVisibilityCheck: false });
503
+ }
504
+ async _executeAssertion(command, callsite) {
505
+ const assertionTimeout = command.options.timeout ===
506
+ void 0 ? this.opts.assertionTimeout : command.options.timeout;
507
+ const executor = new AssertionExecutor(command, assertionTimeout, callsite);
508
+ executor.once('start-assertion-retries', timeout => this.executeCommand(new serviceCommands.ShowAssertionRetriesStatusCommand(timeout)));
509
+ executor.once('end-assertion-retries', success => this.executeCommand(new serviceCommands.HideAssertionRetriesStatusCommand(success)));
510
+ const executeFn = this.decoratePreventEmitActionEvents(() => executor.run(), { prevent: true });
511
+ return await executeFn();
512
+ }
513
+ _adjustConfigurationWithCommand(command) {
514
+ if (command.type === type_1.default.testDone) {
515
+ this.testDoneCommandQueued = true;
516
+ if (this.debugLogger)
517
+ this.debugLogger.hideBreakpoint(this.session.id);
518
+ }
519
+ else if (command.type === type_1.default.setNativeDialogHandler)
520
+ this.activeDialogHandler = command.dialogHandler;
521
+ else if (command.type === type_1.default.switchToIframe)
522
+ this.activeIframeSelector = command.selector;
523
+ else if (command.type === type_1.default.switchToMainWindow)
524
+ this.activeIframeSelector = null;
525
+ else if (command.type === type_1.default.setTestSpeed)
526
+ this.speed = command.speed;
527
+ else if (command.type === type_1.default.setPageLoadTimeout)
528
+ this.pageLoadTimeout = command.duration;
529
+ else if (command.type === type_1.default.debug)
530
+ this.debugging = true;
531
+ }
532
+ async _adjustScreenshotCommand(command) {
533
+ const browserId = this.browserConnection.id;
534
+ const { hasChromelessScreenshots } = await this.browserConnection.provider.hasCustomActionForBrowser(browserId);
535
+ if (!hasChromelessScreenshots)
536
+ command.generateScreenshotMark();
537
+ }
538
+ async _adjustCommandOptions(command) {
539
+ var _a;
540
+ if (((_a = command.options) === null || _a === void 0 ? void 0 : _a.confidential) !== void 0)
541
+ return;
542
+ if (command.type === type_1.default.typeText) {
543
+ const result = await this.executeCommand(command.selector);
544
+ if (!result)
545
+ return;
546
+ const node = this.replicator.decode(result);
547
+ command.options.confidential = is_password_input_1.default(node);
548
+ }
549
+ else if (command.type === type_1.default.pressKey) {
550
+ const result = await this.executeCommand(new serviceCommands.GetActiveElementCommand());
551
+ if (!result)
552
+ return;
553
+ const node = this.replicator.decode(result);
554
+ command.options.confidential = is_password_input_1.default(node);
555
+ }
556
+ }
557
+ async _setBreakpointIfNecessary(command, callsite) {
558
+ if (!this.disableDebugBreakpoints && this.debugging && utils_2.canSetDebuggerBreakpointBeforeCommand(command))
559
+ await this._enqueueSetBreakpointCommand(callsite);
560
+ }
561
+ async executeAction(apiActionName, command, callsite) {
562
+ const actionArgs = { apiActionName, command };
563
+ let errorAdapter = null;
564
+ let error = null;
565
+ let result = null;
566
+ await this._adjustCommandOptions(command);
567
+ await this.emitActionEvent('action-start', actionArgs);
568
+ const start = new Date();
569
+ try {
570
+ result = await this.executeCommand(command, callsite);
571
+ }
572
+ catch (err) {
573
+ error = err;
574
+ }
575
+ const duration = new Date() - start;
576
+ if (error) {
577
+ // NOTE: check if error is TestCafeErrorList is specific for the `useRole` action
578
+ // if error is TestCafeErrorList we do not need to create an adapter,
579
+ // since error is already was processed in role initializer
580
+ if (!(error instanceof error_list_1.default)) {
581
+ await this._makeScreenshotOnFail();
582
+ errorAdapter = this._createErrorAdapter(process_test_fn_error_1.default(error));
583
+ }
584
+ }
585
+ Object.assign(actionArgs, {
586
+ result,
587
+ duration,
588
+ err: errorAdapter
589
+ });
590
+ await this.emitActionEvent('action-done', actionArgs);
591
+ if (error)
592
+ throw error;
593
+ return result;
594
+ }
595
+ async executeCommand(command, callsite) {
596
+ this.debugLog.command(command);
597
+ if (this.pendingPageError && utils_2.isCommandRejectableByPageError(command))
598
+ return this._rejectCommandWithPageError(callsite);
599
+ if (utils_2.isExecutableOnClientCommand(command))
600
+ this.addingDriverTasksCount++;
601
+ this._adjustConfigurationWithCommand(command);
602
+ await this._setBreakpointIfNecessary(command, callsite);
603
+ if (utils_2.isScreenshotCommand(command)) {
604
+ if (this.opts.disableScreenshots) {
605
+ this.warningLog.addWarning(warning_message_1.default.screenshotsDisabled);
606
+ return null;
607
+ }
608
+ await this._adjustScreenshotCommand(command);
609
+ }
610
+ if (utils_2.isBrowserManipulationCommand(command)) {
611
+ this.browserManipulationQueue.push(command);
612
+ if (utils_2.isResizeWindowCommand(command) && this.opts.videoPath)
613
+ this.warningLog.addWarning(warning_message_1.default.videoBrowserResizing, this.test.name);
614
+ }
615
+ if (command.type === type_1.default.wait)
616
+ return delay_1.default(command.timeout);
617
+ if (command.type === type_1.default.setPageLoadTimeout)
618
+ return null;
619
+ if (command.type === type_1.default.debug)
620
+ return await this._enqueueSetBreakpointCommand(callsite);
621
+ if (command.type === type_1.default.useRole) {
622
+ let fn = () => this._useRole(command.role, callsite);
623
+ fn = this.decoratePreventEmitActionEvents(fn, { prevent: true });
624
+ fn = this.decorateDisableDebugBreakpoints(fn, { disable: true });
625
+ return await fn();
626
+ }
627
+ if (command.type === type_1.default.assertion)
628
+ return this._executeAssertion(command, callsite);
629
+ if (command.type === type_1.default.executeExpression)
630
+ return await this._executeJsExpression(command, callsite);
631
+ if (command.type === type_1.default.executeAsyncExpression)
632
+ return await executeAsyncJsExpression(command.expression, this, callsite);
633
+ if (command.type === type_1.default.getBrowserConsoleMessages)
634
+ return await this._enqueueBrowserConsoleMessagesCommand(command, callsite);
635
+ if (command.type === type_1.default.switchToPreviousWindow)
636
+ command.windowId = this.browserConnection.previousActiveWindowId;
637
+ if (command.type === type_1.default.switchToWindowByPredicate)
638
+ return this._switchToWindowByPredicate(command);
639
+ return this._enqueueCommand(command, callsite);
640
+ }
641
+ _rejectCommandWithPageError(callsite) {
642
+ const err = this.pendingPageError;
643
+ err.callsite = callsite;
644
+ this.pendingPageError = null;
645
+ return Promise.reject(err);
646
+ }
647
+ async _makeScreenshotOnFail() {
648
+ const { screenshots } = this.opts;
649
+ if (!this.errScreenshotPath && screenshots && screenshots.takeOnFails)
650
+ this.errScreenshotPath = await this.executeCommand(new browserManipulationCommands.TakeScreenshotOnFailCommand());
651
+ }
652
+ _decorateWithFlag(fn, flagName, value) {
653
+ return async () => {
654
+ this[flagName] = value;
655
+ try {
656
+ return await fn();
657
+ }
658
+ catch (err) {
659
+ throw err;
660
+ }
661
+ finally {
662
+ this[flagName] = !value;
663
+ }
664
+ };
665
+ }
666
+ decoratePreventEmitActionEvents(fn, { prevent }) {
667
+ return this._decorateWithFlag(fn, 'preventEmitActionEvents', prevent);
668
+ }
669
+ decorateDisableDebugBreakpoints(fn, { disable }) {
670
+ return this._decorateWithFlag(fn, 'disableDebugBreakpoints', disable);
671
+ }
672
+ // Role management
673
+ async getStateSnapshot() {
674
+ const state = this.session.getStateSnapshot();
675
+ state.storages = await this.executeCommand(new serviceCommands.BackupStoragesCommand());
676
+ return state;
677
+ }
678
+ async switchToCleanRun(url) {
679
+ this.ctx = Object.create(null);
680
+ this.fixtureCtx = Object.create(null);
681
+ this.consoleMessages = new browser_console_messages_1.default();
682
+ this.session.useStateSnapshot(testcafe_hammerhead_1.StateSnapshot.empty());
683
+ if (this.speed !== this.opts.speed) {
684
+ const setSpeedCommand = new actionCommands.SetTestSpeedCommand({ speed: this.opts.speed });
685
+ await this.executeCommand(setSpeedCommand);
686
+ }
687
+ if (this.pageLoadTimeout !== this.opts.pageLoadTimeout) {
688
+ const setPageLoadTimeoutCommand = new actionCommands.SetPageLoadTimeoutCommand({ duration: this.opts.pageLoadTimeout });
689
+ await this.executeCommand(setPageLoadTimeoutCommand);
690
+ }
691
+ await this.navigateToUrl(url, true);
692
+ if (this.activeDialogHandler) {
693
+ const removeDialogHandlerCommand = new actionCommands.SetNativeDialogHandlerCommand({ dialogHandler: { fn: null } });
694
+ await this.executeCommand(removeDialogHandlerCommand);
695
+ }
696
+ }
697
+ async navigateToUrl(url, forceReload, stateSnapshot) {
698
+ const navigateCommand = new actionCommands.NavigateToCommand({ url, forceReload, stateSnapshot });
699
+ await this.executeCommand(navigateCommand);
700
+ }
701
+ async _getStateSnapshotFromRole(role) {
702
+ const prevPhase = this.phase;
703
+ this.phase = phase_1.default.inRoleInitializer;
704
+ if (role.phase === phase_2.default.uninitialized)
705
+ await role.initialize(this);
706
+ else if (role.phase === phase_2.default.pendingInitialization)
707
+ await promisify_event_1.default(role, 'initialized');
708
+ if (role.initErr)
709
+ throw role.initErr;
710
+ this.phase = prevPhase;
711
+ return role.stateSnapshot;
712
+ }
713
+ async _useRole(role, callsite) {
714
+ if (this.phase === phase_1.default.inRoleInitializer)
715
+ throw new test_run_1.RoleSwitchInRoleInitializerError(callsite);
716
+ const bookmark = new TestRunBookmark(this, role);
717
+ await bookmark.init();
718
+ if (this.currentRoleId)
719
+ this.usedRoleStates[this.currentRoleId] = await this.getStateSnapshot();
720
+ const stateSnapshot = this.usedRoleStates[role.id] || await this._getStateSnapshotFromRole(role);
721
+ this.session.useStateSnapshot(stateSnapshot);
722
+ this.currentRoleId = role.id;
723
+ await bookmark.restore(callsite, stateSnapshot);
724
+ }
725
+ async getCurrentUrl() {
726
+ const builder = new ClientFunctionBuilder(() => {
727
+ /* eslint-disable no-undef */
728
+ return window.location.href;
729
+ /* eslint-enable no-undef */
730
+ }, { boundTestRun: this });
731
+ const getLocation = builder.getFunction();
732
+ return await getLocation();
733
+ }
734
+ async _switchToWindowByPredicate(command) {
735
+ const currentWindows = await this.executeCommand(new actions_1.GetCurrentWindowsCommand({}, this));
736
+ const windows = currentWindows.filter(wnd => {
737
+ try {
738
+ const url = new URL(wnd.url);
739
+ return command.findWindow({ url, title: wnd.title });
740
+ }
741
+ catch (e) {
742
+ throw new test_run_1.SwitchToWindowPredicateError(e.message);
743
+ }
744
+ });
745
+ if (!windows.length)
746
+ throw new test_run_1.WindowNotFoundError();
747
+ if (windows.length > 1)
748
+ this.warningLog.addWarning(warning_message_1.default.multipleWindowsFoundByPredicate);
749
+ await this.executeCommand(new actions_1.SwitchToWindowCommand({ windowId: windows[0].id }), this);
750
+ }
751
+ _disconnect(err) {
752
+ this.disconnected = true;
753
+ if (this.currentDriverTask)
754
+ this._rejectCurrentDriverTask(err);
755
+ this.emit('disconnected', err);
756
+ delete test_run_tracker_1.default.activeTestRuns[this.session.id];
757
+ }
758
+ async emitActionEvent(eventName, args) {
759
+ if (!this.preventEmitActionEvents)
760
+ await this.emit(eventName, args);
761
+ }
762
+ static isMultipleWindowsAllowed(testRun) {
763
+ const { disableMultipleWindows, test, browserConnection } = testRun;
764
+ return !disableMultipleWindows && !test.isLegacy && !!browserConnection.activeWindowId;
765
+ }
766
+ async initialize() {
767
+ if (!this.compilerService)
768
+ return;
769
+ await this.compilerService.initializeTestRunData({
770
+ testRunId: this.id,
771
+ testId: this.test.id
772
+ });
773
+ }
774
+ }
775
+ exports.default = TestRun;
776
+ // Service message handlers
777
+ const ServiceMessages = TestRun.prototype;
778
+ // NOTE: this function is time-critical and must return ASAP to avoid client disconnection
779
+ ServiceMessages[client_messages_1.default.ready] = function (msg) {
780
+ this.debugLog.driverMessage(msg);
781
+ if (this.disconnected)
782
+ return Promise.reject(new runtime_1.GeneralError(types_1.RUNTIME_ERRORS.testRunRequestInDisconnectedBrowser, this.browserConnection.browserInfo.alias));
783
+ this.emit('connected');
784
+ this._clearPendingRequest();
785
+ // NOTE: the driver sends the status for the second time if it didn't get a response at the
786
+ // first try. This is possible when the page was unloaded after the driver sent the status.
787
+ if (msg.status.id === this.lastDriverStatusId)
788
+ return this.lastDriverStatusResponse;
789
+ this.lastDriverStatusId = msg.status.id;
790
+ this.lastDriverStatusResponse = this._handleDriverRequest(msg.status);
791
+ if (this.lastDriverStatusResponse || msg.status.isPendingWindowSwitching)
792
+ return this.lastDriverStatusResponse;
793
+ // NOTE: we send an empty response after the MAX_RESPONSE_DELAY timeout is exceeded to keep connection
794
+ // with the client and prevent the response timeout exception on the client side
795
+ const responseTimeout = setTimeout(() => this._resolvePendingRequest(null), MAX_RESPONSE_DELAY);
796
+ return new Promise((resolve, reject) => {
797
+ this.pendingRequest = { resolve, reject, responseTimeout };
798
+ });
799
+ };
800
+ ServiceMessages[client_messages_1.default.readyForBrowserManipulation] = async function (msg) {
801
+ this.debugLog.driverMessage(msg);
802
+ let result = null;
803
+ let error = null;
804
+ try {
805
+ result = await this.browserManipulationQueue.executePendingManipulation(msg);
806
+ }
807
+ catch (err) {
808
+ error = err;
809
+ }
810
+ return { result, error };
811
+ };
812
+ ServiceMessages[client_messages_1.default.waitForFileDownload] = function (msg) {
813
+ this.debugLog.driverMessage(msg);
814
+ return new Promise(resolve => {
815
+ if (this.fileDownloadingHandled) {
816
+ this.fileDownloadingHandled = false;
817
+ resolve(true);
818
+ }
819
+ else
820
+ this.resolveWaitForFileDownloadingPromise = resolve;
821
+ });
822
+ };
799
823
  module.exports = exports.default;
800
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/test-run/index.js"],"names":[],"mappings":"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","sourcesContent":["import {\n    pull,\n    remove,\n    chain\n} from 'lodash';\n\nimport { readSync as read } from 'read-file-relative';\nimport promisifyEvent from 'promisify-event';\nimport Mustache from 'mustache';\nimport AsyncEventEmitter from '../utils/async-event-emitter';\nimport TestRunDebugLog from './debug-log';\nimport TestRunErrorFormattableAdapter from '../errors/test-run/formattable-adapter';\nimport TestCafeErrorList from '../errors/error-list';\nimport { GeneralError } from '../errors/runtime';\nimport {\n    RequestHookUnhandledError,\n    PageLoadError,\n    RoleSwitchInRoleInitializerError,\n    SwitchToWindowPredicateError,\n    WindowNotFoundError\n} from '../errors/test-run/';\n\nimport PHASE from './phase';\nimport CLIENT_MESSAGES from './client-messages';\nimport COMMAND_TYPE from './commands/type';\nimport delay from '../utils/delay';\nimport testRunMarker from './marker-symbol';\nimport testRunTracker from '../api/test-run-tracker';\nimport ROLE_PHASE from '../role/phase';\nimport ReporterPluginHost from '../reporter/plugin-host';\nimport BrowserConsoleMessages from './browser-console-messages';\nimport WarningLog from '../notifications/warning-log';\nimport WARNING_MESSAGE from '../notifications/warning-message';\nimport { StateSnapshot, SPECIAL_ERROR_PAGE } from 'testcafe-hammerhead';\nimport * as INJECTABLES from '../assets/injectables';\nimport { findProblematicScripts } from '../custom-client-scripts/utils';\nimport getCustomClientScriptUrl from '../custom-client-scripts/get-url';\nimport { getPluralSuffix, getConcatenatedValuesString } from '../utils/string';\n\nimport {\n    isCommandRejectableByPageError,\n    isBrowserManipulationCommand,\n    isScreenshotCommand,\n    isServiceCommand,\n    canSetDebuggerBreakpointBeforeCommand,\n    isExecutableOnClientCommand,\n    isResizeWindowCommand\n} from './commands/utils';\n\nimport { GetCurrentWindowsCommand, SwitchToWindowCommand } from './commands/actions';\n\nimport { RUNTIME_ERRORS, TEST_RUN_ERRORS } from '../errors/types';\nimport processTestFnError from '../errors/process-test-fn-error';\nimport RequestHookMethodNames from '../api/request-hooks/hook-method-names';\n\nconst lazyRequire                 = require('import-lazy')(require);\nconst SessionController           = lazyRequire('./session-controller');\nconst ObservedCallsitesStorage    = lazyRequire('./observed-callsites-storage');\nconst ClientFunctionBuilder       = lazyRequire('../client-functions/client-function-builder');\nconst BrowserManipulationQueue    = lazyRequire('./browser-manipulation-queue');\nconst TestRunBookmark             = lazyRequire('./bookmark');\nconst AssertionExecutor           = lazyRequire('../assertions/executor');\nconst actionCommands              = lazyRequire('./commands/actions');\nconst browserManipulationCommands = lazyRequire('./commands/browser-manipulation');\nconst serviceCommands             = lazyRequire('./commands/service');\nconst observationCommands         = lazyRequire('./commands/observation');\n\nconst { executeJsExpression, executeAsyncJsExpression } = lazyRequire('./execute-js-expression');\n\nconst TEST_RUN_TEMPLATE               = read('../client/test-run/index.js.mustache');\nconst IFRAME_TEST_RUN_TEMPLATE        = read('../client/test-run/iframe.js.mustache');\nconst TEST_DONE_CONFIRMATION_RESPONSE = 'test-done-confirmation';\nconst MAX_RESPONSE_DELAY              = 3000;\nconst CHILD_WINDOW_READY_TIMEOUT      = 30 * 1000;\n\nconst ALL_DRIVER_TASKS_ADDED_TO_QUEUE_EVENT = 'all-driver-tasks-added-to-queue';\n\nconst COMPILER_SERVICE_EVENTS = [\n    'setMock',\n    'setConfigureResponseEventOptions',\n    'setHeaderOnConfigureResponseEvent',\n    'removeHeaderOnConfigureResponseEvent'\n];\n\nexport default class TestRun extends AsyncEventEmitter {\n    constructor ({ test, browserConnection, screenshotCapturer, globalWarningLog, opts, compilerService }) {\n        super();\n\n        this[testRunMarker] = true;\n\n        this.warningLog = new WarningLog(globalWarningLog);\n\n        this.opts              = opts;\n        this.test              = test;\n        this.browserConnection = browserConnection;\n\n        this.phase = PHASE.initial;\n\n        this.driverTaskQueue       = [];\n        this.testDoneCommandQueued = false;\n\n        this.activeDialogHandler  = null;\n        this.activeIframeSelector = null;\n        this.speed                = this.opts.speed;\n        this.pageLoadTimeout      = this._getPageLoadTimeout(test, opts);\n\n        this.disablePageReloads   = test.disablePageReloads || opts.disablePageReloads && test.disablePageReloads !== false;\n        this.disablePageCaching   = test.disablePageCaching || opts.disablePageCaching;\n\n        this.disableMultipleWindows = opts.disableMultipleWindows;\n\n        this.requestTimeout = this._getRequestTimeout(test, opts);\n\n        this.session = SessionController.getSession(this);\n\n        this.consoleMessages = new BrowserConsoleMessages();\n\n        this.pendingRequest   = null;\n        this.pendingPageError = null;\n\n        this.controller = null;\n        this.ctx        = Object.create(null);\n        this.fixtureCtx = null;\n\n        this.currentRoleId  = null;\n        this.usedRoleStates = Object.create(null);\n\n        this.errs = [];\n\n        this.lastDriverStatusId       = null;\n        this.lastDriverStatusResponse = null;\n\n        this.fileDownloadingHandled               = false;\n        this.resolveWaitForFileDownloadingPromise = null;\n\n        this.addingDriverTasksCount = 0;\n\n        this.debugging               = this.opts.debugMode;\n        this.debugOnFail             = this.opts.debugOnFail;\n        this.disableDebugBreakpoints = false;\n        this.debugReporterPluginHost = new ReporterPluginHost({ noColors: false });\n\n        this.browserManipulationQueue = new BrowserManipulationQueue(browserConnection, screenshotCapturer, this.warningLog);\n\n        this.debugLog = new TestRunDebugLog(this.browserConnection.userAgent);\n\n        this.quarantine  = null;\n\n        this.debugLogger = this.opts.debugLogger;\n\n        this.observedCallsites = new ObservedCallsitesStorage();\n        this.compilerService   = compilerService;\n\n        this._addInjectables();\n        this._initRequestHooks();\n    }\n\n    _getPageLoadTimeout (test, opts) {\n        if (test.timeouts?.pageLoadTimeout !== void 0)\n            return test.timeouts.pageLoadTimeout;\n\n        return opts.pageLoadTimeout;\n    }\n\n    _getRequestTimeout (test, opts) {\n        return {\n            page: test.timeouts?.pageRequestTimeout || opts.pageRequestTimeout,\n            ajax: test.timeouts?.ajaxRequestTimeout || opts.ajaxRequestTimeout\n        };\n    }\n\n    _addClientScriptContentWarningsIfNecessary () {\n        const { empty, duplicatedContent } = findProblematicScripts(this.test.clientScripts);\n\n        if (empty.length)\n            this.warningLog.addWarning(WARNING_MESSAGE.clientScriptsWithEmptyContent);\n\n        if (duplicatedContent.length) {\n            const suffix                            = getPluralSuffix(duplicatedContent);\n            const duplicatedContentClientScriptsStr = getConcatenatedValuesString(duplicatedContent, '\\n');\n\n            this.warningLog.addWarning(WARNING_MESSAGE.clientScriptsWithDuplicatedContent, suffix, duplicatedContentClientScriptsStr);\n        }\n    }\n\n    _addInjectables () {\n        this._addClientScriptContentWarningsIfNecessary();\n        this.injectable.scripts.push(...INJECTABLES.SCRIPTS);\n        this.injectable.userScripts.push(...this.test.clientScripts.map(script => {\n            return {\n                url:  getCustomClientScriptUrl(script),\n                page: script.page\n            };\n        }));\n        this.injectable.styles.push(INJECTABLES.TESTCAFE_UI_STYLES);\n    }\n\n    get id () {\n        return this.session.id;\n    }\n\n    get injectable () {\n        return this.session.injectable;\n    }\n\n    addQuarantineInfo (quarantine) {\n        this.quarantine = quarantine;\n    }\n\n    addRequestHook (hook) {\n        if (this.test.requestHooks.includes(hook))\n            return;\n\n        this.test.requestHooks.push(hook);\n        this._initRequestHook(hook);\n    }\n\n    removeRequestHook (hook) {\n        if (!this.test.requestHooks.includes(hook))\n            return;\n\n        pull(this.test.requestHooks, hook);\n        this._disposeRequestHook(hook);\n    }\n\n    _initRequestHook (hook) {\n        hook._warningLog = this.warningLog;\n\n        hook._requestFilterRules.forEach(rule => {\n            this.session.addRequestEventListeners(rule, {\n                onRequest:           hook.onRequest.bind(hook),\n                onConfigureResponse: hook._onConfigureResponse.bind(hook),\n                onResponse:          hook.onResponse.bind(hook)\n            }, err => this._onRequestHookMethodError(err, hook._className));\n        });\n    }\n\n    _initRequestHookForCompilerService (hookId, hookClassName, rules) {\n        const testId = this.test.id;\n\n        rules.forEach(rule => {\n            this.session.addRequestEventListeners(rule, {\n                onRequest:           event => this.compilerService.onRequestHookEvent({ testId, hookId, name: RequestHookMethodNames.onRequest, eventData: event }),\n                onConfigureResponse: event => this.compilerService.onRequestHookEvent({ testId, hookId, name: RequestHookMethodNames._onConfigureResponse, eventData: event }),\n                onResponse:          event => this.compilerService.onRequestHookEvent({ testId, hookId, name: RequestHookMethodNames.onResponse, eventData: event })\n            }, err => this._onRequestHookMethodError(err, hookClassName));\n        });\n    }\n\n    _onRequestHookMethodError (event, hookClassName) {\n        let err                                      = event.error;\n        const isRequestHookNotImplementedMethodError = err?.code === TEST_RUN_ERRORS.requestHookNotImplementedError;\n\n        if (!isRequestHookNotImplementedMethodError)\n            err = new RequestHookUnhandledError(err, hookClassName, event.methodName);\n\n        this.addError(err);\n    }\n\n    _disposeRequestHook (hook) {\n        hook._warningLog = null;\n\n        hook._requestFilterRules.forEach(rule => {\n            this.session.removeRequestEventListeners(rule);\n        });\n    }\n\n    _detachRequestEventListeners (rules) {\n        rules.forEach(rule => {\n            this.session.removeRequestEventListeners(rule);\n        });\n    }\n\n    _subscribeOnCompilerServiceEvents () {\n        COMPILER_SERVICE_EVENTS.forEach(eventName => {\n            this.compilerService.on(eventName, async args => {\n                await this.session[eventName](...args);\n            });\n        });\n\n        this.compilerService.on('addRequestEventListeners', async ({ hookId, hookClassName, rules }) => {\n            this._initRequestHookForCompilerService(hookId, hookClassName, rules);\n        });\n\n        this.compilerService.on('removeRequestEventListeners', async ({ rules }) => {\n            this._detachRequestEventListeners(rules);\n        });\n    }\n\n    _initRequestHooks () {\n        if (this.compilerService) {\n            this._subscribeOnCompilerServiceEvents();\n            this.test.requestHooks.forEach(hook => {\n                this._initRequestHookForCompilerService(hook.id, hook._className, hook._requestFilterRules);\n            });\n        }\n        else\n            this.test.requestHooks.forEach(hook => this._initRequestHook(hook));\n    }\n\n    // Hammerhead payload\n    async getPayloadScript () {\n        this.fileDownloadingHandled               = false;\n        this.resolveWaitForFileDownloadingPromise = null;\n\n        return Mustache.render(TEST_RUN_TEMPLATE, {\n            testRunId:                    JSON.stringify(this.session.id),\n            browserId:                    JSON.stringify(this.browserConnection.id),\n            browserHeartbeatRelativeUrl:  JSON.stringify(this.browserConnection.heartbeatRelativeUrl),\n            browserStatusRelativeUrl:     JSON.stringify(this.browserConnection.statusRelativeUrl),\n            browserStatusDoneRelativeUrl: JSON.stringify(this.browserConnection.statusDoneRelativeUrl),\n            browserActiveWindowIdUrl:     JSON.stringify(this.browserConnection.activeWindowIdUrl),\n            userAgent:                    JSON.stringify(this.browserConnection.userAgent),\n            testName:                     JSON.stringify(this.test.name),\n            fixtureName:                  JSON.stringify(this.test.fixture.name),\n            selectorTimeout:              this.opts.selectorTimeout,\n            pageLoadTimeout:              this.pageLoadTimeout,\n            childWindowReadyTimeout:      CHILD_WINDOW_READY_TIMEOUT,\n            skipJsErrors:                 this.opts.skipJsErrors,\n            retryTestPages:               this.opts.retryTestPages,\n            speed:                        this.speed,\n            dialogHandler:                JSON.stringify(this.activeDialogHandler),\n            canUseDefaultWindowActions:   JSON.stringify(await this.browserConnection.canUseDefaultWindowActions())\n        });\n    }\n\n    async getIframePayloadScript () {\n        return Mustache.render(IFRAME_TEST_RUN_TEMPLATE, {\n            testRunId:       JSON.stringify(this.session.id),\n            selectorTimeout: this.opts.selectorTimeout,\n            pageLoadTimeout: this.pageLoadTimeout,\n            retryTestPages:  !!this.opts.retryTestPages,\n            speed:           this.speed,\n            dialogHandler:   JSON.stringify(this.activeDialogHandler)\n        });\n    }\n\n    // Hammerhead handlers\n    getAuthCredentials () {\n        return this.test.authCredentials;\n    }\n\n    handleFileDownload () {\n        if (this.resolveWaitForFileDownloadingPromise) {\n            this.resolveWaitForFileDownloadingPromise(true);\n            this.resolveWaitForFileDownloadingPromise = null;\n        }\n        else\n            this.fileDownloadingHandled = true;\n    }\n\n    handlePageError (ctx, err) {\n        this.pendingPageError = new PageLoadError(err, ctx.reqOpts.url);\n\n        ctx.redirect(ctx.toProxyUrl(SPECIAL_ERROR_PAGE));\n    }\n\n    // Test function execution\n    async _executeTestFn (phase, fn) {\n        this.phase = phase;\n\n        try {\n            await fn(this);\n        }\n        catch (err) {\n            await this._makeScreenshotOnFail();\n\n            this.addError(err);\n\n            return false;\n        }\n        finally {\n            this.errScreenshotPath = null;\n        }\n\n        return !this._addPendingPageErrorIfAny();\n    }\n\n    async _runBeforeHook () {\n        if (this.test.beforeFn)\n            return await this._executeTestFn(PHASE.inTestBeforeHook, this.test.beforeFn);\n\n        if (this.test.fixture.beforeEachFn)\n            return await this._executeTestFn(PHASE.inFixtureBeforeEachHook, this.test.fixture.beforeEachFn);\n\n        return true;\n    }\n\n    async _runAfterHook () {\n        if (this.test.afterFn)\n            return await this._executeTestFn(PHASE.inTestAfterHook, this.test.afterFn);\n\n        if (this.test.fixture.afterEachFn)\n            return await this._executeTestFn(PHASE.inFixtureAfterEachHook, this.test.fixture.afterEachFn);\n\n        return true;\n    }\n\n    async start () {\n        testRunTracker.activeTestRuns[this.session.id] = this;\n\n        await this.emit('start');\n\n        const onDisconnected = err => this._disconnect(err);\n\n        this.browserConnection.once('disconnected', onDisconnected);\n\n        await this.once('connected');\n\n        await this.emit('ready');\n\n        if (await this._runBeforeHook()) {\n            await this._executeTestFn(PHASE.inTest, this.test.fn);\n            await this._runAfterHook();\n        }\n\n        if (this.disconnected)\n            return;\n\n        this.browserConnection.removeListener('disconnected', onDisconnected);\n\n        if (this.errs.length && this.debugOnFail)\n            await this._enqueueSetBreakpointCommand(null, this.debugReporterPluginHost.formatError(this.errs[0]));\n\n        await this.emit('before-done');\n\n        await this.executeCommand(new serviceCommands.TestDoneCommand());\n\n        this._addPendingPageErrorIfAny();\n        this.session.clearRequestEventListeners();\n        this.normalizeRequestHookErrors();\n\n        delete testRunTracker.activeTestRuns[this.session.id];\n\n        await this.emit('done');\n    }\n\n    // Errors\n    _addPendingPageErrorIfAny () {\n        if (this.pendingPageError) {\n            this.addError(this.pendingPageError);\n            this.pendingPageError = null;\n            return true;\n        }\n\n        return false;\n    }\n\n    _createErrorAdapter (err) {\n        return new TestRunErrorFormattableAdapter(err, {\n            userAgent:      this.browserConnection.userAgent,\n            screenshotPath: this.errScreenshotPath || '',\n            testRunId:      this.id,\n            testRunPhase:   this.phase\n        });\n    }\n\n    addError (err) {\n        const errList = err instanceof TestCafeErrorList ? err.items : [err];\n\n        errList.forEach(item => {\n            const adapter = this._createErrorAdapter(item);\n\n            this.errs.push(adapter);\n        });\n    }\n\n    normalizeRequestHookErrors () {\n        const requestHookErrors = remove(this.errs, e =>\n            e.code === TEST_RUN_ERRORS.requestHookNotImplementedError ||\n            e.code === TEST_RUN_ERRORS.requestHookUnhandledError);\n\n        if (!requestHookErrors.length)\n            return;\n\n        const uniqRequestHookErrors = chain(requestHookErrors)\n            .uniqBy(e => e.hookClassName + e.methodName)\n            .sortBy(['hookClassName', 'methodName'])\n            .value();\n\n        this.errs = this.errs.concat(uniqRequestHookErrors);\n    }\n\n    // Task queue\n    _enqueueCommand (command, callsite) {\n        if (this.pendingRequest)\n            this._resolvePendingRequest(command);\n\n        return new Promise(async (resolve, reject) => {\n            this.addingDriverTasksCount--;\n            this.driverTaskQueue.push({ command, resolve, reject, callsite });\n\n            if (!this.addingDriverTasksCount)\n                await this.emit(ALL_DRIVER_TASKS_ADDED_TO_QUEUE_EVENT, this.driverTaskQueue.length);\n        });\n    }\n\n    get driverTaskQueueLength () {\n        return this.addingDriverTasksCount ? promisifyEvent(this, ALL_DRIVER_TASKS_ADDED_TO_QUEUE_EVENT) : Promise.resolve(this.driverTaskQueue.length);\n    }\n\n    async _enqueueBrowserConsoleMessagesCommand (command, callsite) {\n        await this._enqueueCommand(command, callsite);\n\n        const consoleMessageCopy = this.consoleMessages.getCopy();\n\n        return consoleMessageCopy[this.browserConnection.activeWindowId];\n    }\n\n    async _enqueueSetBreakpointCommand (callsite, error) {\n        if (this.browserConnection.isHeadlessBrowser()) {\n            this.warningLog.addWarning(WARNING_MESSAGE.debugInHeadlessError);\n            return;\n        }\n\n        if (this.debugLogger)\n            this.debugLogger.showBreakpoint(this.session.id, this.browserConnection.userAgent, callsite, error);\n\n        this.debugging = await this.executeCommand(new serviceCommands.SetBreakpointCommand(!!error), callsite);\n    }\n\n    _removeAllNonServiceTasks () {\n        this.driverTaskQueue = this.driverTaskQueue.filter(driverTask => isServiceCommand(driverTask.command));\n\n        this.browserManipulationQueue.removeAllNonServiceManipulations();\n    }\n\n    // Current driver task\n    get currentDriverTask () {\n        return this.driverTaskQueue[0];\n    }\n\n    _resolveCurrentDriverTask (result) {\n        this.currentDriverTask.resolve(result);\n        this.driverTaskQueue.shift();\n\n        if (this.testDoneCommandQueued)\n            this._removeAllNonServiceTasks();\n    }\n\n    _rejectCurrentDriverTask (err) {\n        err.callsite = err.callsite || this.currentDriverTask.callsite;\n\n        this.currentDriverTask.reject(err);\n        this._removeAllNonServiceTasks();\n    }\n\n    // Pending request\n    _clearPendingRequest () {\n        if (this.pendingRequest) {\n            clearTimeout(this.pendingRequest.responseTimeout);\n            this.pendingRequest = null;\n        }\n    }\n\n    _resolvePendingRequest (command) {\n        this.lastDriverStatusResponse = command;\n        this.pendingRequest.resolve(command);\n        this._clearPendingRequest();\n    }\n\n    // Handle driver request\n    _shouldResolveCurrentDriverTask (driverStatus) {\n        const currentCommand = this.currentDriverTask.command;\n\n        const isExecutingObservationCommand = currentCommand instanceof observationCommands.ExecuteSelectorCommand ||\n            currentCommand instanceof observationCommands.ExecuteClientFunctionCommand;\n\n        const isDebugActive = currentCommand instanceof serviceCommands.SetBreakpointCommand;\n\n        const shouldExecuteCurrentCommand =\n            driverStatus.isFirstRequestAfterWindowSwitching && (isExecutingObservationCommand || isDebugActive);\n\n        return !shouldExecuteCurrentCommand;\n    }\n\n    _fulfillCurrentDriverTask (driverStatus) {\n        if (!this.currentDriverTask)\n            return;\n\n        if (driverStatus.executionError)\n            this._rejectCurrentDriverTask(driverStatus.executionError);\n        else if (this._shouldResolveCurrentDriverTask(driverStatus))\n            this._resolveCurrentDriverTask(driverStatus.result);\n    }\n\n    _handlePageErrorStatus (pageError) {\n        if (this.currentDriverTask && isCommandRejectableByPageError(this.currentDriverTask.command)) {\n            this._rejectCurrentDriverTask(pageError);\n            this.pendingPageError = null;\n\n            return true;\n        }\n\n        this.pendingPageError = this.pendingPageError || pageError;\n\n        return false;\n    }\n\n    _handleDriverRequest (driverStatus) {\n        const isTestDone                 = this.currentDriverTask && this.currentDriverTask.command.type ===\n                                           COMMAND_TYPE.testDone;\n        const pageError                  = this.pendingPageError || driverStatus.pageError;\n        const currentTaskRejectedByError = pageError && this._handlePageErrorStatus(pageError);\n\n        this.consoleMessages.concat(driverStatus.consoleMessages);\n\n        if (!currentTaskRejectedByError && driverStatus.isCommandResult) {\n            if (isTestDone) {\n                this._resolveCurrentDriverTask();\n\n                return TEST_DONE_CONFIRMATION_RESPONSE;\n            }\n\n            this._fulfillCurrentDriverTask(driverStatus);\n\n            if (driverStatus.isPendingWindowSwitching)\n                return null;\n        }\n\n        return this._getCurrentDriverTaskCommand();\n    }\n\n    _getCurrentDriverTaskCommand () {\n        if (!this.currentDriverTask)\n            return null;\n\n        const command = this.currentDriverTask.command;\n\n        if (command.type === COMMAND_TYPE.navigateTo && command.stateSnapshot)\n            this.session.useStateSnapshot(JSON.parse(command.stateSnapshot));\n\n        return command;\n    }\n\n    // Execute command\n    _executeJsExpression (command) {\n        const resultVariableName = command.resultVariableName;\n        let expression           = command.expression;\n\n        if (resultVariableName)\n            expression = `${resultVariableName} = ${expression}, ${resultVariableName}`;\n\n        return executeJsExpression(expression, this, { skipVisibilityCheck: false });\n    }\n\n    async _executeAssertion (command, callsite) {\n        const assertionTimeout = command.options.timeout ===\n                                 void 0 ? this.opts.assertionTimeout : command.options.timeout;\n        const executor         = new AssertionExecutor(command, assertionTimeout, callsite);\n\n        executor.once('start-assertion-retries', timeout => this.executeCommand(new serviceCommands.ShowAssertionRetriesStatusCommand(timeout)));\n        executor.once('end-assertion-retries', success => this.executeCommand(new serviceCommands.HideAssertionRetriesStatusCommand(success)));\n\n        const executeFn = this.decoratePreventEmitActionEvents(() => executor.run(), { prevent: true });\n\n        return await executeFn();\n    }\n\n    _adjustConfigurationWithCommand (command) {\n        if (command.type === COMMAND_TYPE.testDone) {\n            this.testDoneCommandQueued = true;\n            if (this.debugLogger)\n                this.debugLogger.hideBreakpoint(this.session.id);\n        }\n\n        else if (command.type === COMMAND_TYPE.setNativeDialogHandler)\n            this.activeDialogHandler = command.dialogHandler;\n\n        else if (command.type === COMMAND_TYPE.switchToIframe)\n            this.activeIframeSelector = command.selector;\n\n        else if (command.type === COMMAND_TYPE.switchToMainWindow)\n            this.activeIframeSelector = null;\n\n        else if (command.type === COMMAND_TYPE.setTestSpeed)\n            this.speed = command.speed;\n\n        else if (command.type === COMMAND_TYPE.setPageLoadTimeout)\n            this.pageLoadTimeout = command.duration;\n\n        else if (command.type === COMMAND_TYPE.debug)\n            this.debugging = true;\n    }\n\n    async _adjustScreenshotCommand (command) {\n        const browserId                    = this.browserConnection.id;\n        const { hasChromelessScreenshots } = await this.browserConnection.provider.hasCustomActionForBrowser(browserId);\n\n        if (!hasChromelessScreenshots)\n            command.generateScreenshotMark();\n    }\n\n    async _setBreakpointIfNecessary (command, callsite) {\n        if (!this.disableDebugBreakpoints && this.debugging && canSetDebuggerBreakpointBeforeCommand(command))\n            await this._enqueueSetBreakpointCommand(callsite);\n    }\n\n    async executeAction (apiActionName, command, callsite) {\n        const actionArgs = { apiActionName, command };\n\n        let errorAdapter = null;\n        let error        = null;\n        let result       = null;\n\n        await this.emitActionEvent('action-start', actionArgs);\n\n        const start = new Date();\n\n        try {\n            result = await this.executeCommand(command, callsite);\n        }\n        catch (err) {\n            error = err;\n        }\n\n        const duration = new Date() - start;\n\n        if (error) {\n            // NOTE: check if error is TestCafeErrorList is specific for the `useRole` action\n            // if error is TestCafeErrorList we do not need to create an adapter,\n            // since error is already was processed in role initializer\n            if (!(error instanceof TestCafeErrorList)) {\n                await this._makeScreenshotOnFail();\n\n                errorAdapter = this._createErrorAdapter(processTestFnError(error));\n            }\n        }\n\n        Object.assign(actionArgs, {\n            result,\n            duration,\n            err: errorAdapter\n        });\n\n        await this.emitActionEvent('action-done', actionArgs);\n\n        if (error)\n            throw error;\n\n        return result;\n    }\n\n    async executeCommand (command, callsite) {\n        this.debugLog.command(command);\n\n        if (this.pendingPageError && isCommandRejectableByPageError(command))\n            return this._rejectCommandWithPageError(callsite);\n\n        if (isExecutableOnClientCommand(command))\n            this.addingDriverTasksCount++;\n\n        this._adjustConfigurationWithCommand(command);\n\n        await this._setBreakpointIfNecessary(command, callsite);\n\n        if (isScreenshotCommand(command)) {\n            if (this.opts.disableScreenshots) {\n                this.warningLog.addWarning(WARNING_MESSAGE.screenshotsDisabled);\n\n                return null;\n            }\n\n            await this._adjustScreenshotCommand(command);\n        }\n\n        if (isBrowserManipulationCommand(command)) {\n            this.browserManipulationQueue.push(command);\n\n            if (isResizeWindowCommand(command) && this.opts.videoPath)\n                this.warningLog.addWarning(WARNING_MESSAGE.videoBrowserResizing, this.test.name);\n        }\n\n        if (command.type === COMMAND_TYPE.wait)\n            return delay(command.timeout);\n\n        if (command.type === COMMAND_TYPE.setPageLoadTimeout)\n            return null;\n\n        if (command.type === COMMAND_TYPE.debug)\n            return await this._enqueueSetBreakpointCommand(callsite);\n\n        if (command.type === COMMAND_TYPE.useRole) {\n            let fn = () => this._useRole(command.role, callsite);\n\n            fn = this.decoratePreventEmitActionEvents(fn, { prevent: true });\n            fn = this.decorateDisableDebugBreakpoints(fn, { disable: true });\n\n            return await fn();\n        }\n\n        if (command.type === COMMAND_TYPE.assertion)\n            return this._executeAssertion(command, callsite);\n\n        if (command.type === COMMAND_TYPE.executeExpression)\n            return await this._executeJsExpression(command, callsite);\n\n        if (command.type === COMMAND_TYPE.executeAsyncExpression)\n            return await executeAsyncJsExpression(command.expression, this, callsite);\n\n        if (command.type === COMMAND_TYPE.getBrowserConsoleMessages)\n            return await this._enqueueBrowserConsoleMessagesCommand(command, callsite);\n\n        if (command.type === COMMAND_TYPE.switchToPreviousWindow)\n            command.windowId = this.browserConnection.previousActiveWindowId;\n\n        if (command.type === COMMAND_TYPE.switchToWindowByPredicate)\n            return this._switchToWindowByPredicate(command);\n\n\n        return this._enqueueCommand(command, callsite);\n    }\n\n    _rejectCommandWithPageError (callsite) {\n        const err = this.pendingPageError;\n\n        err.callsite          = callsite;\n        this.pendingPageError = null;\n\n        return Promise.reject(err);\n    }\n\n    async _makeScreenshotOnFail () {\n        const { screenshots } = this.opts;\n\n        if (!this.errScreenshotPath && screenshots && screenshots.takeOnFails)\n            this.errScreenshotPath = await this.executeCommand(new browserManipulationCommands.TakeScreenshotOnFailCommand());\n    }\n\n    _decorateWithFlag (fn, flagName, value) {\n        return async () => {\n            this[flagName] = value;\n\n            try {\n                return await fn();\n            }\n            catch (err) {\n                throw err;\n            }\n            finally {\n                this[flagName] = !value;\n            }\n        };\n    }\n\n    decoratePreventEmitActionEvents (fn, { prevent }) {\n        return this._decorateWithFlag(fn, 'preventEmitActionEvents', prevent);\n    }\n\n    decorateDisableDebugBreakpoints (fn, { disable }) {\n        return this._decorateWithFlag(fn, 'disableDebugBreakpoints', disable);\n    }\n\n    // Role management\n    async getStateSnapshot () {\n        const state = this.session.getStateSnapshot();\n\n        state.storages = await this.executeCommand(new serviceCommands.BackupStoragesCommand());\n\n        return state;\n    }\n\n    async switchToCleanRun (url) {\n        this.ctx             = Object.create(null);\n        this.fixtureCtx      = Object.create(null);\n        this.consoleMessages = new BrowserConsoleMessages();\n\n        this.session.useStateSnapshot(StateSnapshot.empty());\n\n        if (this.speed !== this.opts.speed) {\n            const setSpeedCommand = new actionCommands.SetTestSpeedCommand({ speed: this.opts.speed });\n\n            await this.executeCommand(setSpeedCommand);\n        }\n\n        if (this.pageLoadTimeout !== this.opts.pageLoadTimeout) {\n            const setPageLoadTimeoutCommand = new actionCommands.SetPageLoadTimeoutCommand({ duration: this.opts.pageLoadTimeout });\n\n            await this.executeCommand(setPageLoadTimeoutCommand);\n        }\n\n        await this.navigateToUrl(url, true);\n\n        if (this.activeDialogHandler) {\n            const removeDialogHandlerCommand = new actionCommands.SetNativeDialogHandlerCommand({ dialogHandler: { fn: null } });\n\n            await this.executeCommand(removeDialogHandlerCommand);\n        }\n    }\n\n    async navigateToUrl (url, forceReload, stateSnapshot) {\n        const navigateCommand = new actionCommands.NavigateToCommand({ url, forceReload, stateSnapshot });\n\n        await this.executeCommand(navigateCommand);\n    }\n\n    async _getStateSnapshotFromRole (role) {\n        const prevPhase = this.phase;\n\n        this.phase = PHASE.inRoleInitializer;\n\n        if (role.phase === ROLE_PHASE.uninitialized)\n            await role.initialize(this);\n\n        else if (role.phase === ROLE_PHASE.pendingInitialization)\n            await promisifyEvent(role, 'initialized');\n\n        if (role.initErr)\n            throw role.initErr;\n\n        this.phase = prevPhase;\n\n        return role.stateSnapshot;\n    }\n\n    async _useRole (role, callsite) {\n        if (this.phase === PHASE.inRoleInitializer)\n            throw new RoleSwitchInRoleInitializerError(callsite);\n\n        const bookmark = new TestRunBookmark(this, role);\n\n        await bookmark.init();\n\n        if (this.currentRoleId)\n            this.usedRoleStates[this.currentRoleId] = await this.getStateSnapshot();\n\n        const stateSnapshot = this.usedRoleStates[role.id] || await this._getStateSnapshotFromRole(role);\n\n        this.session.useStateSnapshot(stateSnapshot);\n\n        this.currentRoleId = role.id;\n\n        await bookmark.restore(callsite, stateSnapshot);\n    }\n\n    async getCurrentUrl () {\n        const builder = new ClientFunctionBuilder(() => {\n            /* eslint-disable no-undef */\n            return window.location.href;\n            /* eslint-enable no-undef */\n        }, { boundTestRun: this });\n\n        const getLocation = builder.getFunction();\n\n        return await getLocation();\n    }\n\n    async _switchToWindowByPredicate (command) {\n        const currentWindows = await this.executeCommand(new GetCurrentWindowsCommand({}, this));\n\n        const windows = currentWindows.filter(wnd => {\n            try {\n                const url = new URL(wnd.url);\n\n                return command.findWindow({ url, title: wnd.title });\n            }\n            catch (e) {\n                throw new SwitchToWindowPredicateError(e.message);\n            }\n        });\n\n        if (!windows.length)\n            throw new WindowNotFoundError();\n\n        if (windows.length > 1)\n            this.warningLog.addWarning(WARNING_MESSAGE.multipleWindowsFoundByPredicate);\n\n        await this.executeCommand(new SwitchToWindowCommand({ windowId: windows[0].id }), this);\n    }\n\n    _disconnect (err) {\n        this.disconnected = true;\n\n        if (this.currentDriverTask)\n            this._rejectCurrentDriverTask(err);\n\n        this.emit('disconnected', err);\n\n        delete testRunTracker.activeTestRuns[this.session.id];\n    }\n\n    async emitActionEvent (eventName, args) {\n        if (!this.preventEmitActionEvents)\n            await this.emit(eventName, args);\n    }\n\n    static isMultipleWindowsAllowed (testRun) {\n        const { disableMultipleWindows, test, browserConnection } = testRun;\n\n        return !disableMultipleWindows && !test.isLegacy && !!browserConnection.activeWindowId;\n    }\n\n    async initialize () {\n        if (!this.compilerService)\n            return;\n\n        await this.compilerService.initializeTestRunProxy({\n            testRunId: this.id,\n            testId:    this.test.id\n        });\n    }\n}\n\n// Service message handlers\nconst ServiceMessages = TestRun.prototype;\n\n// NOTE: this function is time-critical and must return ASAP to avoid client disconnection\nServiceMessages[CLIENT_MESSAGES.ready] = function (msg) {\n    this.debugLog.driverMessage(msg);\n\n    if (this.disconnected)\n        return Promise.reject(new GeneralError(RUNTIME_ERRORS.testRunRequestInDisconnectedBrowser, this.browserConnection.browserInfo.alias));\n\n    this.emit('connected');\n\n    this._clearPendingRequest();\n\n    // NOTE: the driver sends the status for the second time if it didn't get a response at the\n    // first try. This is possible when the page was unloaded after the driver sent the status.\n    if (msg.status.id === this.lastDriverStatusId)\n        return this.lastDriverStatusResponse;\n\n    this.lastDriverStatusId       = msg.status.id;\n    this.lastDriverStatusResponse = this._handleDriverRequest(msg.status);\n\n    if (this.lastDriverStatusResponse || msg.status.isPendingWindowSwitching)\n        return this.lastDriverStatusResponse;\n\n    // NOTE: we send an empty response after the MAX_RESPONSE_DELAY timeout is exceeded to keep connection\n    // with the client and prevent the response timeout exception on the client side\n    const responseTimeout = setTimeout(() => this._resolvePendingRequest(null), MAX_RESPONSE_DELAY);\n\n    return new Promise((resolve, reject) => {\n        this.pendingRequest = { resolve, reject, responseTimeout };\n    });\n};\n\nServiceMessages[CLIENT_MESSAGES.readyForBrowserManipulation] = async function (msg) {\n    this.debugLog.driverMessage(msg);\n\n    let result = null;\n    let error  = null;\n\n    try {\n        result = await this.browserManipulationQueue.executePendingManipulation(msg);\n    }\n    catch (err) {\n        error = err;\n    }\n\n    return { result, error };\n};\n\nServiceMessages[CLIENT_MESSAGES.waitForFileDownload] = function (msg) {\n    this.debugLog.driverMessage(msg);\n\n    return new Promise(resolve => {\n        if (this.fileDownloadingHandled) {\n            this.fileDownloadingHandled = false;\n            resolve(true);\n        }\n        else\n            this.resolveWaitForFileDownloadingPromise = resolve;\n    });\n};\n"]}
824
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/test-run/index.js"],"names":[],"mappings":"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","sourcesContent":["import {\n    pull,\n    remove,\n    chain\n} from 'lodash';\n\nimport { readSync as read } from 'read-file-relative';\nimport promisifyEvent from 'promisify-event';\nimport Mustache from 'mustache';\nimport AsyncEventEmitter from '../utils/async-event-emitter';\nimport TestRunDebugLog from './debug-log';\nimport TestRunErrorFormattableAdapter from '../errors/test-run/formattable-adapter';\nimport TestCafeErrorList from '../errors/error-list';\nimport { GeneralError } from '../errors/runtime';\nimport {\n    RequestHookUnhandledError,\n    PageLoadError,\n    RoleSwitchInRoleInitializerError,\n    SwitchToWindowPredicateError,\n    WindowNotFoundError\n} from '../errors/test-run/';\n\nimport PHASE from './phase';\nimport CLIENT_MESSAGES from './client-messages';\nimport COMMAND_TYPE from './commands/type';\nimport delay from '../utils/delay';\nimport isPasswordInput from '../utils/is-password-input';\nimport testRunMarker from './marker-symbol';\nimport testRunTracker from '../api/test-run-tracker';\nimport ROLE_PHASE from '../role/phase';\nimport ReporterPluginHost from '../reporter/plugin-host';\nimport BrowserConsoleMessages from './browser-console-messages';\nimport WarningLog from '../notifications/warning-log';\nimport WARNING_MESSAGE from '../notifications/warning-message';\nimport { StateSnapshot, SPECIAL_ERROR_PAGE } from 'testcafe-hammerhead';\nimport * as INJECTABLES from '../assets/injectables';\nimport { findProblematicScripts } from '../custom-client-scripts/utils';\nimport getCustomClientScriptUrl from '../custom-client-scripts/get-url';\nimport { getPluralSuffix, getConcatenatedValuesString } from '../utils/string';\n\nimport {\n    isCommandRejectableByPageError,\n    isBrowserManipulationCommand,\n    isScreenshotCommand,\n    isServiceCommand,\n    canSetDebuggerBreakpointBeforeCommand,\n    isExecutableOnClientCommand,\n    isResizeWindowCommand\n} from './commands/utils';\n\nimport { GetCurrentWindowsCommand, SwitchToWindowCommand } from './commands/actions';\n\nimport { RUNTIME_ERRORS, TEST_RUN_ERRORS } from '../errors/types';\nimport processTestFnError from '../errors/process-test-fn-error';\nimport RequestHookMethodNames from '../api/request-hooks/hook-method-names';\n\nimport { createReplicator, SelectorNodeTransform } from '../client-functions/replicator';\n\nconst lazyRequire                 = require('import-lazy')(require);\nconst SessionController           = lazyRequire('./session-controller');\nconst ObservedCallsitesStorage    = lazyRequire('./observed-callsites-storage');\nconst ClientFunctionBuilder       = lazyRequire('../client-functions/client-function-builder');\nconst BrowserManipulationQueue    = lazyRequire('./browser-manipulation-queue');\nconst TestRunBookmark             = lazyRequire('./bookmark');\nconst AssertionExecutor           = lazyRequire('../assertions/executor');\nconst actionCommands              = lazyRequire('./commands/actions');\nconst browserManipulationCommands = lazyRequire('./commands/browser-manipulation');\nconst serviceCommands             = lazyRequire('./commands/service');\nconst observationCommands         = lazyRequire('./commands/observation');\n\nconst { executeJsExpression, executeAsyncJsExpression } = lazyRequire('./execute-js-expression');\n\nconst TEST_RUN_TEMPLATE               = read('../client/test-run/index.js.mustache');\nconst IFRAME_TEST_RUN_TEMPLATE        = read('../client/test-run/iframe.js.mustache');\nconst TEST_DONE_CONFIRMATION_RESPONSE = 'test-done-confirmation';\nconst MAX_RESPONSE_DELAY              = 3000;\nconst CHILD_WINDOW_READY_TIMEOUT      = 30 * 1000;\n\nconst ALL_DRIVER_TASKS_ADDED_TO_QUEUE_EVENT = 'all-driver-tasks-added-to-queue';\n\nconst COMPILER_SERVICE_EVENTS = [\n    'setMock',\n    'setConfigureResponseEventOptions',\n    'setHeaderOnConfigureResponseEvent',\n    'removeHeaderOnConfigureResponseEvent'\n];\n\nexport default class TestRun extends AsyncEventEmitter {\n    constructor ({ test, browserConnection, screenshotCapturer, globalWarningLog, opts, compilerService }) {\n        super();\n\n        this[testRunMarker] = true;\n\n        this.warningLog = new WarningLog(globalWarningLog);\n\n        this.opts              = opts;\n        this.test              = test;\n        this.browserConnection = browserConnection;\n        this.unstable          = false;\n\n        this.phase = PHASE.initial;\n\n        this.driverTaskQueue       = [];\n        this.testDoneCommandQueued = false;\n\n        this.activeDialogHandler  = null;\n        this.activeIframeSelector = null;\n        this.speed                = this.opts.speed;\n        this.pageLoadTimeout      = this._getPageLoadTimeout(test, opts);\n\n        this.disablePageReloads   = test.disablePageReloads || opts.disablePageReloads && test.disablePageReloads !== false;\n        this.disablePageCaching   = test.disablePageCaching || opts.disablePageCaching;\n\n        this.disableMultipleWindows = opts.disableMultipleWindows;\n\n        this.requestTimeout = this._getRequestTimeout(test, opts);\n\n        this.session = SessionController.getSession(this);\n\n        this.consoleMessages = new BrowserConsoleMessages();\n\n        this.pendingRequest   = null;\n        this.pendingPageError = null;\n\n        this.controller = null;\n        this.ctx        = Object.create(null);\n        this.fixtureCtx = null;\n\n        this.currentRoleId  = null;\n        this.usedRoleStates = Object.create(null);\n\n        this.errs = [];\n\n        this.lastDriverStatusId       = null;\n        this.lastDriverStatusResponse = null;\n\n        this.fileDownloadingHandled               = false;\n        this.resolveWaitForFileDownloadingPromise = null;\n\n        this.addingDriverTasksCount = 0;\n\n        this.debugging               = this.opts.debugMode;\n        this.debugOnFail             = this.opts.debugOnFail;\n        this.disableDebugBreakpoints = false;\n        this.debugReporterPluginHost = new ReporterPluginHost({ noColors: false });\n\n        this.browserManipulationQueue = new BrowserManipulationQueue(browserConnection, screenshotCapturer, this.warningLog);\n\n        this.debugLog = new TestRunDebugLog(this.browserConnection.userAgent);\n\n        this.quarantine  = null;\n\n        this.debugLogger = this.opts.debugLogger;\n\n        this.observedCallsites = new ObservedCallsitesStorage();\n        this.compilerService   = compilerService;\n\n        this.replicator = createReplicator([ new SelectorNodeTransform() ]);\n\n        this._addInjectables();\n        this._initRequestHooks();\n    }\n\n    _getPageLoadTimeout (test, opts) {\n        if (test.timeouts?.pageLoadTimeout !== void 0)\n            return test.timeouts.pageLoadTimeout;\n\n        return opts.pageLoadTimeout;\n    }\n\n    _getRequestTimeout (test, opts) {\n        return {\n            page: test.timeouts?.pageRequestTimeout || opts.pageRequestTimeout,\n            ajax: test.timeouts?.ajaxRequestTimeout || opts.ajaxRequestTimeout\n        };\n    }\n\n    _addClientScriptContentWarningsIfNecessary () {\n        const { empty, duplicatedContent } = findProblematicScripts(this.test.clientScripts);\n\n        if (empty.length)\n            this.warningLog.addWarning(WARNING_MESSAGE.clientScriptsWithEmptyContent);\n\n        if (duplicatedContent.length) {\n            const suffix                            = getPluralSuffix(duplicatedContent);\n            const duplicatedContentClientScriptsStr = getConcatenatedValuesString(duplicatedContent, '\\n');\n\n            this.warningLog.addWarning(WARNING_MESSAGE.clientScriptsWithDuplicatedContent, suffix, duplicatedContentClientScriptsStr);\n        }\n    }\n\n    _addInjectables () {\n        this._addClientScriptContentWarningsIfNecessary();\n        this.injectable.scripts.push(...INJECTABLES.SCRIPTS);\n        this.injectable.userScripts.push(...this.test.clientScripts.map(script => {\n            return {\n                url:  getCustomClientScriptUrl(script),\n                page: script.page\n            };\n        }));\n        this.injectable.styles.push(INJECTABLES.TESTCAFE_UI_STYLES);\n    }\n\n    get id () {\n        return this.session.id;\n    }\n\n    get injectable () {\n        return this.session.injectable;\n    }\n\n    addQuarantineInfo (quarantine) {\n        this.quarantine = quarantine;\n    }\n\n    addRequestHook (hook) {\n        if (this.test.requestHooks.includes(hook))\n            return;\n\n        this.test.requestHooks.push(hook);\n        this._initRequestHook(hook);\n    }\n\n    removeRequestHook (hook) {\n        if (!this.test.requestHooks.includes(hook))\n            return;\n\n        pull(this.test.requestHooks, hook);\n        this._disposeRequestHook(hook);\n    }\n\n    _initRequestHook (hook) {\n        hook._warningLog = this.warningLog;\n\n        hook._requestFilterRules.forEach(rule => {\n            this.session.addRequestEventListeners(rule, {\n                onRequest:           hook.onRequest.bind(hook),\n                onConfigureResponse: hook._onConfigureResponse.bind(hook),\n                onResponse:          hook.onResponse.bind(hook)\n            }, err => this._onRequestHookMethodError(err, hook._className));\n        });\n    }\n\n    _initRequestHookForCompilerService (hookId, hookClassName, rules) {\n        const testId = this.test.id;\n\n        rules.forEach(rule => {\n            this.session.addRequestEventListeners(rule, {\n                onRequest:           event => this.compilerService.onRequestHookEvent({ testId, hookId, name: RequestHookMethodNames.onRequest, eventData: event }),\n                onConfigureResponse: event => this.compilerService.onRequestHookEvent({ testId, hookId, name: RequestHookMethodNames._onConfigureResponse, eventData: event }),\n                onResponse:          event => this.compilerService.onRequestHookEvent({ testId, hookId, name: RequestHookMethodNames.onResponse, eventData: event })\n            }, err => this._onRequestHookMethodError(err, hookClassName));\n        });\n    }\n\n    _onRequestHookMethodError (event, hookClassName) {\n        let err                                      = event.error;\n        const isRequestHookNotImplementedMethodError = err?.code === TEST_RUN_ERRORS.requestHookNotImplementedError;\n\n        if (!isRequestHookNotImplementedMethodError)\n            err = new RequestHookUnhandledError(err, hookClassName, event.methodName);\n\n        this.addError(err);\n    }\n\n    _disposeRequestHook (hook) {\n        hook._warningLog = null;\n\n        hook._requestFilterRules.forEach(rule => {\n            this.session.removeRequestEventListeners(rule);\n        });\n    }\n\n    _detachRequestEventListeners (rules) {\n        rules.forEach(rule => {\n            this.session.removeRequestEventListeners(rule);\n        });\n    }\n\n    _subscribeOnCompilerServiceEvents () {\n        COMPILER_SERVICE_EVENTS.forEach(eventName => {\n            this.compilerService.on(eventName, async args => {\n                await this.session[eventName](...args);\n            });\n        });\n\n        this.compilerService.on('addRequestEventListeners', async ({ hookId, hookClassName, rules }) => {\n            this._initRequestHookForCompilerService(hookId, hookClassName, rules);\n        });\n\n        this.compilerService.on('removeRequestEventListeners', async ({ rules }) => {\n            this._detachRequestEventListeners(rules);\n        });\n    }\n\n    _initRequestHooks () {\n        if (this.compilerService) {\n            this._subscribeOnCompilerServiceEvents();\n            this.test.requestHooks.forEach(hook => {\n                this._initRequestHookForCompilerService(hook.id, hook._className, hook._requestFilterRules);\n            });\n        }\n        else\n            this.test.requestHooks.forEach(hook => this._initRequestHook(hook));\n    }\n\n    // Hammerhead payload\n    async getPayloadScript () {\n        this.fileDownloadingHandled               = false;\n        this.resolveWaitForFileDownloadingPromise = null;\n\n        return Mustache.render(TEST_RUN_TEMPLATE, {\n            testRunId:                    JSON.stringify(this.session.id),\n            browserId:                    JSON.stringify(this.browserConnection.id),\n            browserHeartbeatRelativeUrl:  JSON.stringify(this.browserConnection.heartbeatRelativeUrl),\n            browserStatusRelativeUrl:     JSON.stringify(this.browserConnection.statusRelativeUrl),\n            browserStatusDoneRelativeUrl: JSON.stringify(this.browserConnection.statusDoneRelativeUrl),\n            browserActiveWindowIdUrl:     JSON.stringify(this.browserConnection.activeWindowIdUrl),\n            userAgent:                    JSON.stringify(this.browserConnection.userAgent),\n            testName:                     JSON.stringify(this.test.name),\n            fixtureName:                  JSON.stringify(this.test.fixture.name),\n            selectorTimeout:              this.opts.selectorTimeout,\n            pageLoadTimeout:              this.pageLoadTimeout,\n            childWindowReadyTimeout:      CHILD_WINDOW_READY_TIMEOUT,\n            skipJsErrors:                 this.opts.skipJsErrors,\n            retryTestPages:               this.opts.retryTestPages,\n            speed:                        this.speed,\n            dialogHandler:                JSON.stringify(this.activeDialogHandler),\n            canUseDefaultWindowActions:   JSON.stringify(await this.browserConnection.canUseDefaultWindowActions())\n        });\n    }\n\n    async getIframePayloadScript () {\n        return Mustache.render(IFRAME_TEST_RUN_TEMPLATE, {\n            testRunId:       JSON.stringify(this.session.id),\n            selectorTimeout: this.opts.selectorTimeout,\n            pageLoadTimeout: this.pageLoadTimeout,\n            retryTestPages:  !!this.opts.retryTestPages,\n            speed:           this.speed,\n            dialogHandler:   JSON.stringify(this.activeDialogHandler)\n        });\n    }\n\n    // Hammerhead handlers\n    getAuthCredentials () {\n        return this.test.authCredentials;\n    }\n\n    handleFileDownload () {\n        if (this.resolveWaitForFileDownloadingPromise) {\n            this.resolveWaitForFileDownloadingPromise(true);\n            this.resolveWaitForFileDownloadingPromise = null;\n        }\n        else\n            this.fileDownloadingHandled = true;\n    }\n\n    handlePageError (ctx, err) {\n        this.pendingPageError = new PageLoadError(err, ctx.reqOpts.url);\n\n        ctx.redirect(ctx.toProxyUrl(SPECIAL_ERROR_PAGE));\n    }\n\n    // Test function execution\n    async _executeTestFn (phase, fn) {\n        this.phase = phase;\n\n        try {\n            await fn(this);\n        }\n        catch (err) {\n            await this._makeScreenshotOnFail();\n\n            this.addError(err);\n\n            return false;\n        }\n        finally {\n            this.errScreenshotPath = null;\n        }\n\n        return !this._addPendingPageErrorIfAny();\n    }\n\n    async _runBeforeHook () {\n        if (this.test.beforeFn)\n            return await this._executeTestFn(PHASE.inTestBeforeHook, this.test.beforeFn);\n\n        if (this.test.fixture.beforeEachFn)\n            return await this._executeTestFn(PHASE.inFixtureBeforeEachHook, this.test.fixture.beforeEachFn);\n\n        return true;\n    }\n\n    async _runAfterHook () {\n        if (this.test.afterFn)\n            return await this._executeTestFn(PHASE.inTestAfterHook, this.test.afterFn);\n\n        if (this.test.fixture.afterEachFn)\n            return await this._executeTestFn(PHASE.inFixtureAfterEachHook, this.test.fixture.afterEachFn);\n\n        return true;\n    }\n\n    async start () {\n        testRunTracker.activeTestRuns[this.session.id] = this;\n\n        await this.emit('start');\n\n        const onDisconnected = err => this._disconnect(err);\n\n        this.browserConnection.once('disconnected', onDisconnected);\n\n        await this.once('connected');\n\n        await this.emit('ready');\n\n        if (await this._runBeforeHook()) {\n            await this._executeTestFn(PHASE.inTest, this.test.fn);\n            await this._runAfterHook();\n        }\n\n        if (this.disconnected)\n            return;\n\n        this.browserConnection.removeListener('disconnected', onDisconnected);\n\n        if (this.errs.length && this.debugOnFail)\n            await this._enqueueSetBreakpointCommand(null, this.debugReporterPluginHost.formatError(this.errs[0]));\n\n        await this.emit('before-done');\n\n        await this.executeCommand(new serviceCommands.TestDoneCommand());\n\n        this._addPendingPageErrorIfAny();\n        this.session.clearRequestEventListeners();\n        this.normalizeRequestHookErrors();\n\n        delete testRunTracker.activeTestRuns[this.session.id];\n\n        await this.emit('done');\n    }\n\n    // Errors\n    _addPendingPageErrorIfAny () {\n        if (this.pendingPageError) {\n            this.addError(this.pendingPageError);\n            this.pendingPageError = null;\n            return true;\n        }\n\n        return false;\n    }\n\n    _createErrorAdapter (err) {\n        return new TestRunErrorFormattableAdapter(err, {\n            userAgent:      this.browserConnection.userAgent,\n            screenshotPath: this.errScreenshotPath || '',\n            testRunId:      this.id,\n            testRunPhase:   this.phase\n        });\n    }\n\n    addError (err) {\n        const errList = err instanceof TestCafeErrorList ? err.items : [err];\n\n        errList.forEach(item => {\n            const adapter = this._createErrorAdapter(item);\n\n            this.errs.push(adapter);\n        });\n    }\n\n    normalizeRequestHookErrors () {\n        const requestHookErrors = remove(this.errs, e =>\n            e.code === TEST_RUN_ERRORS.requestHookNotImplementedError ||\n            e.code === TEST_RUN_ERRORS.requestHookUnhandledError);\n\n        if (!requestHookErrors.length)\n            return;\n\n        const uniqRequestHookErrors = chain(requestHookErrors)\n            .uniqBy(e => e.hookClassName + e.methodName)\n            .sortBy(['hookClassName', 'methodName'])\n            .value();\n\n        this.errs = this.errs.concat(uniqRequestHookErrors);\n    }\n\n    // Task queue\n    _enqueueCommand (command, callsite) {\n        if (this.pendingRequest)\n            this._resolvePendingRequest(command);\n\n        return new Promise(async (resolve, reject) => {\n            this.addingDriverTasksCount--;\n            this.driverTaskQueue.push({ command, resolve, reject, callsite });\n\n            if (!this.addingDriverTasksCount)\n                await this.emit(ALL_DRIVER_TASKS_ADDED_TO_QUEUE_EVENT, this.driverTaskQueue.length);\n        });\n    }\n\n    get driverTaskQueueLength () {\n        return this.addingDriverTasksCount ? promisifyEvent(this, ALL_DRIVER_TASKS_ADDED_TO_QUEUE_EVENT) : Promise.resolve(this.driverTaskQueue.length);\n    }\n\n    async _enqueueBrowserConsoleMessagesCommand (command, callsite) {\n        await this._enqueueCommand(command, callsite);\n\n        const consoleMessageCopy = this.consoleMessages.getCopy();\n\n        return consoleMessageCopy[this.browserConnection.activeWindowId];\n    }\n\n    async _enqueueSetBreakpointCommand (callsite, error) {\n        if (this.browserConnection.isHeadlessBrowser()) {\n            this.warningLog.addWarning(WARNING_MESSAGE.debugInHeadlessError);\n            return;\n        }\n\n        if (this.debugLogger)\n            this.debugLogger.showBreakpoint(this.session.id, this.browserConnection.userAgent, callsite, error);\n\n        this.debugging = await this.executeCommand(new serviceCommands.SetBreakpointCommand(!!error), callsite);\n    }\n\n    _removeAllNonServiceTasks () {\n        this.driverTaskQueue = this.driverTaskQueue.filter(driverTask => isServiceCommand(driverTask.command));\n\n        this.browserManipulationQueue.removeAllNonServiceManipulations();\n    }\n\n    // Current driver task\n    get currentDriverTask () {\n        return this.driverTaskQueue[0];\n    }\n\n    _resolveCurrentDriverTask (result) {\n        this.currentDriverTask.resolve(result);\n        this.driverTaskQueue.shift();\n\n        if (this.testDoneCommandQueued)\n            this._removeAllNonServiceTasks();\n    }\n\n    _rejectCurrentDriverTask (err) {\n        err.callsite = err.callsite || this.currentDriverTask.callsite;\n\n        this.currentDriverTask.reject(err);\n        this._removeAllNonServiceTasks();\n    }\n\n    // Pending request\n    _clearPendingRequest () {\n        if (this.pendingRequest) {\n            clearTimeout(this.pendingRequest.responseTimeout);\n            this.pendingRequest = null;\n        }\n    }\n\n    _resolvePendingRequest (command) {\n        this.lastDriverStatusResponse = command;\n        this.pendingRequest.resolve(command);\n        this._clearPendingRequest();\n    }\n\n    // Handle driver request\n    _shouldResolveCurrentDriverTask (driverStatus) {\n        const currentCommand = this.currentDriverTask.command;\n\n        const isExecutingObservationCommand = currentCommand instanceof observationCommands.ExecuteSelectorCommand ||\n            currentCommand instanceof observationCommands.ExecuteClientFunctionCommand;\n\n        const isDebugActive = currentCommand instanceof serviceCommands.SetBreakpointCommand;\n\n        const shouldExecuteCurrentCommand =\n            driverStatus.isFirstRequestAfterWindowSwitching && (isExecutingObservationCommand || isDebugActive);\n\n        return !shouldExecuteCurrentCommand;\n    }\n\n    _fulfillCurrentDriverTask (driverStatus) {\n        if (!this.currentDriverTask)\n            return;\n\n        if (driverStatus.executionError)\n            this._rejectCurrentDriverTask(driverStatus.executionError);\n        else if (this._shouldResolveCurrentDriverTask(driverStatus))\n            this._resolveCurrentDriverTask(driverStatus.result);\n    }\n\n    _handlePageErrorStatus (pageError) {\n        if (this.currentDriverTask && isCommandRejectableByPageError(this.currentDriverTask.command)) {\n            this._rejectCurrentDriverTask(pageError);\n            this.pendingPageError = null;\n\n            return true;\n        }\n\n        this.pendingPageError = this.pendingPageError || pageError;\n\n        return false;\n    }\n\n    _handleDriverRequest (driverStatus) {\n        const isTestDone                 = this.currentDriverTask && this.currentDriverTask.command.type ===\n                                           COMMAND_TYPE.testDone;\n        const pageError                  = this.pendingPageError || driverStatus.pageError;\n        const currentTaskRejectedByError = pageError && this._handlePageErrorStatus(pageError);\n\n        this.consoleMessages.concat(driverStatus.consoleMessages);\n\n        if (!currentTaskRejectedByError && driverStatus.isCommandResult) {\n            if (isTestDone) {\n                this._resolveCurrentDriverTask();\n\n                return TEST_DONE_CONFIRMATION_RESPONSE;\n            }\n\n            this._fulfillCurrentDriverTask(driverStatus);\n\n            if (driverStatus.isPendingWindowSwitching)\n                return null;\n        }\n\n        return this._getCurrentDriverTaskCommand();\n    }\n\n    _getCurrentDriverTaskCommand () {\n        if (!this.currentDriverTask)\n            return null;\n\n        const command = this.currentDriverTask.command;\n\n        if (command.type === COMMAND_TYPE.navigateTo && command.stateSnapshot)\n            this.session.useStateSnapshot(JSON.parse(command.stateSnapshot));\n\n        return command;\n    }\n\n    // Execute command\n    _executeJsExpression (command) {\n        const resultVariableName = command.resultVariableName;\n        let expression           = command.expression;\n\n        if (resultVariableName)\n            expression = `${resultVariableName} = ${expression}, ${resultVariableName}`;\n\n        return executeJsExpression(expression, this, { skipVisibilityCheck: false });\n    }\n\n    async _executeAssertion (command, callsite) {\n        const assertionTimeout = command.options.timeout ===\n                                 void 0 ? this.opts.assertionTimeout : command.options.timeout;\n        const executor         = new AssertionExecutor(command, assertionTimeout, callsite);\n\n        executor.once('start-assertion-retries', timeout => this.executeCommand(new serviceCommands.ShowAssertionRetriesStatusCommand(timeout)));\n        executor.once('end-assertion-retries', success => this.executeCommand(new serviceCommands.HideAssertionRetriesStatusCommand(success)));\n\n        const executeFn = this.decoratePreventEmitActionEvents(() => executor.run(), { prevent: true });\n\n        return await executeFn();\n    }\n\n    _adjustConfigurationWithCommand (command) {\n        if (command.type === COMMAND_TYPE.testDone) {\n            this.testDoneCommandQueued = true;\n            if (this.debugLogger)\n                this.debugLogger.hideBreakpoint(this.session.id);\n        }\n\n        else if (command.type === COMMAND_TYPE.setNativeDialogHandler)\n            this.activeDialogHandler = command.dialogHandler;\n\n        else if (command.type === COMMAND_TYPE.switchToIframe)\n            this.activeIframeSelector = command.selector;\n\n        else if (command.type === COMMAND_TYPE.switchToMainWindow)\n            this.activeIframeSelector = null;\n\n        else if (command.type === COMMAND_TYPE.setTestSpeed)\n            this.speed = command.speed;\n\n        else if (command.type === COMMAND_TYPE.setPageLoadTimeout)\n            this.pageLoadTimeout = command.duration;\n\n        else if (command.type === COMMAND_TYPE.debug)\n            this.debugging = true;\n    }\n\n    async _adjustScreenshotCommand (command) {\n        const browserId                    = this.browserConnection.id;\n        const { hasChromelessScreenshots } = await this.browserConnection.provider.hasCustomActionForBrowser(browserId);\n\n        if (!hasChromelessScreenshots)\n            command.generateScreenshotMark();\n    }\n\n    async _adjustCommandOptions (command) {\n        if (command.options?.confidential !== void 0)\n            return;\n\n        if (command.type === COMMAND_TYPE.typeText) {\n            const result = await this.executeCommand(command.selector);\n\n            if (!result)\n                return;\n\n            const node = this.replicator.decode(result);\n\n            command.options.confidential = isPasswordInput(node);\n        }\n\n        else if (command.type === COMMAND_TYPE.pressKey) {\n            const result = await this.executeCommand(new serviceCommands.GetActiveElementCommand());\n\n            if (!result)\n                return;\n\n            const node = this.replicator.decode(result);\n\n            command.options.confidential = isPasswordInput(node);\n        }\n    }\n\n    async _setBreakpointIfNecessary (command, callsite) {\n        if (!this.disableDebugBreakpoints && this.debugging && canSetDebuggerBreakpointBeforeCommand(command))\n            await this._enqueueSetBreakpointCommand(callsite);\n    }\n\n    async executeAction (apiActionName, command, callsite) {\n        const actionArgs = { apiActionName, command };\n\n        let errorAdapter = null;\n        let error        = null;\n        let result       = null;\n\n        await this._adjustCommandOptions(command);\n\n        await this.emitActionEvent('action-start', actionArgs);\n\n        const start = new Date();\n\n        try {\n            result = await this.executeCommand(command, callsite);\n        }\n        catch (err) {\n            error = err;\n        }\n\n        const duration = new Date() - start;\n\n        if (error) {\n            // NOTE: check if error is TestCafeErrorList is specific for the `useRole` action\n            // if error is TestCafeErrorList we do not need to create an adapter,\n            // since error is already was processed in role initializer\n            if (!(error instanceof TestCafeErrorList)) {\n                await this._makeScreenshotOnFail();\n\n                errorAdapter = this._createErrorAdapter(processTestFnError(error));\n            }\n        }\n\n        Object.assign(actionArgs, {\n            result,\n            duration,\n            err: errorAdapter\n        });\n\n        await this.emitActionEvent('action-done', actionArgs);\n\n        if (error)\n            throw error;\n\n        return result;\n    }\n\n    async executeCommand (command, callsite) {\n        this.debugLog.command(command);\n\n        if (this.pendingPageError && isCommandRejectableByPageError(command))\n            return this._rejectCommandWithPageError(callsite);\n\n        if (isExecutableOnClientCommand(command))\n            this.addingDriverTasksCount++;\n\n        this._adjustConfigurationWithCommand(command);\n\n        await this._setBreakpointIfNecessary(command, callsite);\n\n        if (isScreenshotCommand(command)) {\n            if (this.opts.disableScreenshots) {\n                this.warningLog.addWarning(WARNING_MESSAGE.screenshotsDisabled);\n\n                return null;\n            }\n\n            await this._adjustScreenshotCommand(command);\n        }\n\n        if (isBrowserManipulationCommand(command)) {\n            this.browserManipulationQueue.push(command);\n\n            if (isResizeWindowCommand(command) && this.opts.videoPath)\n                this.warningLog.addWarning(WARNING_MESSAGE.videoBrowserResizing, this.test.name);\n        }\n\n        if (command.type === COMMAND_TYPE.wait)\n            return delay(command.timeout);\n\n        if (command.type === COMMAND_TYPE.setPageLoadTimeout)\n            return null;\n\n        if (command.type === COMMAND_TYPE.debug)\n            return await this._enqueueSetBreakpointCommand(callsite);\n\n        if (command.type === COMMAND_TYPE.useRole) {\n            let fn = () => this._useRole(command.role, callsite);\n\n            fn = this.decoratePreventEmitActionEvents(fn, { prevent: true });\n            fn = this.decorateDisableDebugBreakpoints(fn, { disable: true });\n\n            return await fn();\n        }\n\n        if (command.type === COMMAND_TYPE.assertion)\n            return this._executeAssertion(command, callsite);\n\n        if (command.type === COMMAND_TYPE.executeExpression)\n            return await this._executeJsExpression(command, callsite);\n\n        if (command.type === COMMAND_TYPE.executeAsyncExpression)\n            return await executeAsyncJsExpression(command.expression, this, callsite);\n\n        if (command.type === COMMAND_TYPE.getBrowserConsoleMessages)\n            return await this._enqueueBrowserConsoleMessagesCommand(command, callsite);\n\n        if (command.type === COMMAND_TYPE.switchToPreviousWindow)\n            command.windowId = this.browserConnection.previousActiveWindowId;\n\n        if (command.type === COMMAND_TYPE.switchToWindowByPredicate)\n            return this._switchToWindowByPredicate(command);\n\n\n        return this._enqueueCommand(command, callsite);\n    }\n\n    _rejectCommandWithPageError (callsite) {\n        const err = this.pendingPageError;\n\n        err.callsite          = callsite;\n        this.pendingPageError = null;\n\n        return Promise.reject(err);\n    }\n\n    async _makeScreenshotOnFail () {\n        const { screenshots } = this.opts;\n\n        if (!this.errScreenshotPath && screenshots && screenshots.takeOnFails)\n            this.errScreenshotPath = await this.executeCommand(new browserManipulationCommands.TakeScreenshotOnFailCommand());\n    }\n\n    _decorateWithFlag (fn, flagName, value) {\n        return async () => {\n            this[flagName] = value;\n\n            try {\n                return await fn();\n            }\n            catch (err) {\n                throw err;\n            }\n            finally {\n                this[flagName] = !value;\n            }\n        };\n    }\n\n    decoratePreventEmitActionEvents (fn, { prevent }) {\n        return this._decorateWithFlag(fn, 'preventEmitActionEvents', prevent);\n    }\n\n    decorateDisableDebugBreakpoints (fn, { disable }) {\n        return this._decorateWithFlag(fn, 'disableDebugBreakpoints', disable);\n    }\n\n    // Role management\n    async getStateSnapshot () {\n        const state = this.session.getStateSnapshot();\n\n        state.storages = await this.executeCommand(new serviceCommands.BackupStoragesCommand());\n\n        return state;\n    }\n\n    async switchToCleanRun (url) {\n        this.ctx             = Object.create(null);\n        this.fixtureCtx      = Object.create(null);\n        this.consoleMessages = new BrowserConsoleMessages();\n\n        this.session.useStateSnapshot(StateSnapshot.empty());\n\n        if (this.speed !== this.opts.speed) {\n            const setSpeedCommand = new actionCommands.SetTestSpeedCommand({ speed: this.opts.speed });\n\n            await this.executeCommand(setSpeedCommand);\n        }\n\n        if (this.pageLoadTimeout !== this.opts.pageLoadTimeout) {\n            const setPageLoadTimeoutCommand = new actionCommands.SetPageLoadTimeoutCommand({ duration: this.opts.pageLoadTimeout });\n\n            await this.executeCommand(setPageLoadTimeoutCommand);\n        }\n\n        await this.navigateToUrl(url, true);\n\n        if (this.activeDialogHandler) {\n            const removeDialogHandlerCommand = new actionCommands.SetNativeDialogHandlerCommand({ dialogHandler: { fn: null } });\n\n            await this.executeCommand(removeDialogHandlerCommand);\n        }\n    }\n\n    async navigateToUrl (url, forceReload, stateSnapshot) {\n        const navigateCommand = new actionCommands.NavigateToCommand({ url, forceReload, stateSnapshot });\n\n        await this.executeCommand(navigateCommand);\n    }\n\n    async _getStateSnapshotFromRole (role) {\n        const prevPhase = this.phase;\n\n        this.phase = PHASE.inRoleInitializer;\n\n        if (role.phase === ROLE_PHASE.uninitialized)\n            await role.initialize(this);\n\n        else if (role.phase === ROLE_PHASE.pendingInitialization)\n            await promisifyEvent(role, 'initialized');\n\n        if (role.initErr)\n            throw role.initErr;\n\n        this.phase = prevPhase;\n\n        return role.stateSnapshot;\n    }\n\n    async _useRole (role, callsite) {\n        if (this.phase === PHASE.inRoleInitializer)\n            throw new RoleSwitchInRoleInitializerError(callsite);\n\n        const bookmark = new TestRunBookmark(this, role);\n\n        await bookmark.init();\n\n        if (this.currentRoleId)\n            this.usedRoleStates[this.currentRoleId] = await this.getStateSnapshot();\n\n        const stateSnapshot = this.usedRoleStates[role.id] || await this._getStateSnapshotFromRole(role);\n\n        this.session.useStateSnapshot(stateSnapshot);\n\n        this.currentRoleId = role.id;\n\n        await bookmark.restore(callsite, stateSnapshot);\n    }\n\n    async getCurrentUrl () {\n        const builder = new ClientFunctionBuilder(() => {\n            /* eslint-disable no-undef */\n            return window.location.href;\n            /* eslint-enable no-undef */\n        }, { boundTestRun: this });\n\n        const getLocation = builder.getFunction();\n\n        return await getLocation();\n    }\n\n    async _switchToWindowByPredicate (command) {\n        const currentWindows = await this.executeCommand(new GetCurrentWindowsCommand({}, this));\n\n        const windows = currentWindows.filter(wnd => {\n            try {\n                const url = new URL(wnd.url);\n\n                return command.findWindow({ url, title: wnd.title });\n            }\n            catch (e) {\n                throw new SwitchToWindowPredicateError(e.message);\n            }\n        });\n\n        if (!windows.length)\n            throw new WindowNotFoundError();\n\n        if (windows.length > 1)\n            this.warningLog.addWarning(WARNING_MESSAGE.multipleWindowsFoundByPredicate);\n\n        await this.executeCommand(new SwitchToWindowCommand({ windowId: windows[0].id }), this);\n    }\n\n    _disconnect (err) {\n        this.disconnected = true;\n\n        if (this.currentDriverTask)\n            this._rejectCurrentDriverTask(err);\n\n        this.emit('disconnected', err);\n\n        delete testRunTracker.activeTestRuns[this.session.id];\n    }\n\n    async emitActionEvent (eventName, args) {\n        if (!this.preventEmitActionEvents)\n            await this.emit(eventName, args);\n    }\n\n    static isMultipleWindowsAllowed (testRun) {\n        const { disableMultipleWindows, test, browserConnection } = testRun;\n\n        return !disableMultipleWindows && !test.isLegacy && !!browserConnection.activeWindowId;\n    }\n\n    async initialize () {\n        if (!this.compilerService)\n            return;\n\n        await this.compilerService.initializeTestRunData({\n            testRunId: this.id,\n            testId:    this.test.id\n        });\n    }\n}\n\n// Service message handlers\nconst ServiceMessages = TestRun.prototype;\n\n// NOTE: this function is time-critical and must return ASAP to avoid client disconnection\nServiceMessages[CLIENT_MESSAGES.ready] = function (msg) {\n    this.debugLog.driverMessage(msg);\n\n    if (this.disconnected)\n        return Promise.reject(new GeneralError(RUNTIME_ERRORS.testRunRequestInDisconnectedBrowser, this.browserConnection.browserInfo.alias));\n\n    this.emit('connected');\n\n    this._clearPendingRequest();\n\n    // NOTE: the driver sends the status for the second time if it didn't get a response at the\n    // first try. This is possible when the page was unloaded after the driver sent the status.\n    if (msg.status.id === this.lastDriverStatusId)\n        return this.lastDriverStatusResponse;\n\n    this.lastDriverStatusId       = msg.status.id;\n    this.lastDriverStatusResponse = this._handleDriverRequest(msg.status);\n\n    if (this.lastDriverStatusResponse || msg.status.isPendingWindowSwitching)\n        return this.lastDriverStatusResponse;\n\n    // NOTE: we send an empty response after the MAX_RESPONSE_DELAY timeout is exceeded to keep connection\n    // with the client and prevent the response timeout exception on the client side\n    const responseTimeout = setTimeout(() => this._resolvePendingRequest(null), MAX_RESPONSE_DELAY);\n\n    return new Promise((resolve, reject) => {\n        this.pendingRequest = { resolve, reject, responseTimeout };\n    });\n};\n\nServiceMessages[CLIENT_MESSAGES.readyForBrowserManipulation] = async function (msg) {\n    this.debugLog.driverMessage(msg);\n\n    let result = null;\n    let error  = null;\n\n    try {\n        result = await this.browserManipulationQueue.executePendingManipulation(msg);\n    }\n    catch (err) {\n        error = err;\n    }\n\n    return { result, error };\n};\n\nServiceMessages[CLIENT_MESSAGES.waitForFileDownload] = function (msg) {\n    this.debugLog.driverMessage(msg);\n\n    return new Promise(resolve => {\n        if (this.fileDownloadingHandled) {\n            this.fileDownloadingHandled = false;\n            resolve(true);\n        }\n        else\n            this.resolveWaitForFileDownloadingPromise = resolve;\n    });\n};\n"]}