testcafe 1.13.0 → 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 (336) hide show
  1. package/CHANGELOG.md +88 -10
  2. package/LICENSE +21 -21
  3. package/README.md +52 -48
  4. package/bin/testcafe-with-v8-flag-filter.js +0 -0
  5. package/lib/api/exportable-lib/index.js +50 -50
  6. package/lib/api/request-hooks/assert-type.js +7 -7
  7. package/lib/api/request-hooks/hook-method-names.js +11 -0
  8. package/lib/api/request-hooks/hook.js +33 -39
  9. package/lib/api/request-hooks/interfaces.js +3 -3
  10. package/lib/api/request-hooks/request-logger.js +113 -111
  11. package/lib/api/request-hooks/request-mock/create-request-mock.js +12 -0
  12. package/lib/api/request-hooks/request-mock/index.js +46 -0
  13. package/lib/api/request-hooks/request-mock.js +47 -48
  14. package/lib/api/structure/base-unit.js +11 -11
  15. package/lib/api/structure/fixture.js +75 -75
  16. package/lib/api/structure/interfaces.js +2 -2
  17. package/lib/api/structure/test-file.js +31 -31
  18. package/lib/api/structure/test-timeout.js +9 -9
  19. package/lib/api/structure/test.js +85 -85
  20. package/lib/api/structure/testing-unit.js +89 -89
  21. package/lib/api/structure/unit-type.js +9 -9
  22. package/lib/api/test-controller/assertion.js +88 -88
  23. package/lib/api/test-controller/execution-context.js +82 -82
  24. package/lib/api/test-controller/index.js +359 -319
  25. package/lib/api/test-controller/proxy.js +28 -28
  26. package/lib/api/test-page-url.js +60 -60
  27. package/lib/api/test-run-tracker.js +68 -68
  28. package/lib/api/wrap-test-function.js +49 -49
  29. package/lib/assertions/executor.js +74 -74
  30. package/lib/assertions/get-fn.js +46 -46
  31. package/lib/assertions/type.js +20 -20
  32. package/lib/assets/content-types.js +9 -9
  33. package/lib/assets/injectables.js +18 -18
  34. package/lib/browser/connection/command.js +10 -10
  35. package/lib/browser/connection/error-hints.js +9 -9
  36. package/lib/browser/connection/gateway.js +159 -159
  37. package/lib/browser/connection/get-hints.js +33 -33
  38. package/lib/browser/connection/heartbeat-status.js +8 -8
  39. package/lib/browser/connection/index.js +328 -328
  40. package/lib/browser/connection/remotes-queue.js +46 -46
  41. package/lib/browser/connection/service-routes.js +12 -12
  42. package/lib/browser/connection/status.js +12 -12
  43. package/lib/browser/interfaces.js +2 -2
  44. package/lib/browser/provider/built-in/dedicated/base.js +80 -80
  45. package/lib/browser/provider/built-in/dedicated/chrome/browser-client.js +204 -204
  46. package/lib/browser/provider/built-in/dedicated/chrome/build-chrome-args.js +17 -17
  47. package/lib/browser/provider/built-in/dedicated/chrome/config.js +110 -110
  48. package/lib/browser/provider/built-in/dedicated/chrome/create-temp-profile.js +45 -45
  49. package/lib/browser/provider/built-in/dedicated/chrome/elapsed-upperbounds.js +15 -15
  50. package/lib/browser/provider/built-in/dedicated/chrome/index.js +102 -102
  51. package/lib/browser/provider/built-in/dedicated/chrome/interfaces.js +2 -2
  52. package/lib/browser/provider/built-in/dedicated/chrome/local-chrome.js +24 -24
  53. package/lib/browser/provider/built-in/dedicated/chrome/runtime-info.js +29 -29
  54. package/lib/browser/provider/built-in/dedicated/edge/index.js +10 -10
  55. package/lib/browser/provider/built-in/dedicated/edge/runtime-info.js +29 -29
  56. package/lib/browser/provider/built-in/dedicated/firefox/config.js +33 -33
  57. package/lib/browser/provider/built-in/dedicated/firefox/create-temp-profile.js +78 -78
  58. package/lib/browser/provider/built-in/dedicated/firefox/index.js +73 -73
  59. package/lib/browser/provider/built-in/dedicated/firefox/local-firefox.js +36 -36
  60. package/lib/browser/provider/built-in/dedicated/firefox/marionette-client/commands.js +13 -13
  61. package/lib/browser/provider/built-in/dedicated/firefox/marionette-client/index.js +200 -200
  62. package/lib/browser/provider/built-in/dedicated/firefox/runtime-info.js +17 -17
  63. package/lib/browser/provider/built-in/index.js +21 -21
  64. package/lib/browser/provider/built-in/locally-installed.js +30 -30
  65. package/lib/browser/provider/built-in/path.js +47 -47
  66. package/lib/browser/provider/built-in/remote.js +58 -58
  67. package/lib/browser/provider/index.js +303 -303
  68. package/lib/browser/provider/parse-provider-name.js +16 -16
  69. package/lib/browser/provider/plugin-host.js +121 -121
  70. package/lib/browser/provider/pool.js +115 -115
  71. package/lib/browser/provider/utils/argument-parsing.js +74 -74
  72. package/lib/browser/provider/utils/browser-starter.js +34 -34
  73. package/lib/browser/provider/utils/client-functions.js +24 -24
  74. package/lib/browser/provider/utils/get-maximized-headless-window-size.js +9 -9
  75. package/lib/cli/argument-parser.js +284 -279
  76. package/lib/cli/authentication-helper.js +35 -35
  77. package/lib/cli/cli.js +134 -134
  78. package/lib/cli/correct-browsers-and-sources.js +40 -40
  79. package/lib/cli/index.js +19 -19
  80. package/lib/cli/log.js +43 -43
  81. package/lib/cli/remotes-wizard.js +36 -36
  82. package/lib/cli/termination-handler.js +38 -38
  83. package/lib/client/automation/index.js +144 -46
  84. package/lib/client/automation/index.min.js +1 -1
  85. package/lib/client/browser/idle-page/index.html.mustache +35 -35
  86. package/lib/client/browser/idle-page/logo.svg +86 -86
  87. package/lib/client/browser/service-worker.js +4 -6
  88. package/lib/client/core/index.js +19 -13
  89. package/lib/client/core/index.min.js +1 -1
  90. package/lib/client/driver/index.js +1807 -451
  91. package/lib/client/driver/index.min.js +1 -1
  92. package/lib/client/driver/internal-properties.js +9 -9
  93. package/lib/client/test-run/iframe.js.mustache +17 -17
  94. package/lib/client/test-run/index.js.mustache +51 -51
  95. package/lib/client/ui/index.js +14 -12
  96. package/lib/client/ui/index.min.js +1 -1
  97. package/lib/client/ui/sprite.svg +42 -42
  98. package/lib/client-functions/builder-symbol.js +4 -4
  99. package/lib/client-functions/client-function-builder.js +156 -135
  100. package/lib/client-functions/replicator.js +61 -61
  101. package/lib/client-functions/return-single-prop-mode.js +8 -8
  102. package/lib/client-functions/selector-api-execution-mode.js +22 -0
  103. package/lib/client-functions/selectors/add-api.js +646 -588
  104. package/lib/client-functions/selectors/create-snapshot-methods.js +13 -13
  105. package/lib/client-functions/selectors/prepare-api-args.js +20 -20
  106. package/lib/client-functions/selectors/selector-attribute-filter.js +22 -22
  107. package/lib/client-functions/selectors/selector-builder.js +154 -150
  108. package/lib/client-functions/selectors/selector-text-filter.js +43 -43
  109. package/lib/client-functions/selectors/snapshot-properties.js +48 -48
  110. package/lib/client-functions/types.js +18 -18
  111. package/lib/compiler/babel/format-babel-produced-code.js +10 -10
  112. package/lib/compiler/babel/get-base-babel-options.js +11 -11
  113. package/lib/compiler/babel/load-libs.js +64 -62
  114. package/lib/compiler/babel/preset-stage-2.js +19 -19
  115. package/lib/compiler/compile-client-function.js +73 -73
  116. package/lib/compiler/compilers.js +33 -33
  117. package/lib/compiler/index.js +92 -92
  118. package/lib/compiler/interfaces.js +2 -2
  119. package/lib/compiler/test-file/api-based.js +146 -146
  120. package/lib/compiler/test-file/base.js +36 -36
  121. package/lib/compiler/test-file/exportble-lib-path.js +5 -5
  122. package/lib/compiler/test-file/formats/coffeescript/compiler.js +38 -38
  123. package/lib/compiler/test-file/formats/coffeescript/get-test-list.js +29 -29
  124. package/lib/compiler/test-file/formats/es-next/compiler.js +43 -43
  125. package/lib/compiler/test-file/formats/es-next/get-test-list.js +166 -166
  126. package/lib/compiler/test-file/formats/es-next/is-flow-code.js +7 -7
  127. package/lib/compiler/test-file/formats/raw.js +85 -85
  128. package/lib/compiler/test-file/formats/typescript/compiler.js +135 -135
  129. package/lib/compiler/test-file/formats/typescript/get-test-list.js +185 -185
  130. package/lib/compiler/test-file/test-file-parser-base.js +214 -214
  131. package/lib/configuration/configuration-base.js +165 -165
  132. package/lib/configuration/constants.js +9 -9
  133. package/lib/configuration/customizable-compilers.js +7 -7
  134. package/lib/configuration/default-values.js +51 -51
  135. package/lib/configuration/interfaces.js +3 -3
  136. package/lib/configuration/option-names.js +53 -53
  137. package/lib/configuration/option-source.js +9 -9
  138. package/lib/configuration/option.js +14 -14
  139. package/lib/configuration/quarantine-option-names.js +10 -0
  140. package/lib/configuration/run-option-names.js +26 -26
  141. package/lib/configuration/screenshot-option-names.js +10 -10
  142. package/lib/configuration/testcafe-configuration.js +164 -165
  143. package/lib/configuration/types.js +2 -2
  144. package/lib/configuration/typescript-configuration.js +62 -62
  145. package/lib/custom-client-scripts/assert-type.js +7 -7
  146. package/lib/custom-client-scripts/client-script-init.js +3 -3
  147. package/lib/custom-client-scripts/client-script.js +107 -108
  148. package/lib/custom-client-scripts/get-code.js +11 -11
  149. package/lib/custom-client-scripts/get-url.js +6 -6
  150. package/lib/custom-client-scripts/load.js +15 -15
  151. package/lib/custom-client-scripts/problematic-scripts.js +2 -2
  152. package/lib/custom-client-scripts/routing.js +36 -36
  153. package/lib/custom-client-scripts/utils.js +60 -60
  154. package/lib/embedding-utils.js +83 -83
  155. package/lib/errors/create-stack-filter.js +18 -18
  156. package/lib/errors/error-list.js +26 -26
  157. package/lib/errors/get-callsite.js +31 -31
  158. package/lib/errors/internal-modules-prefix.js +8 -8
  159. package/lib/errors/is-internal-stack-frame.js +46 -46
  160. package/lib/errors/process-test-fn-error.js +37 -37
  161. package/lib/errors/runtime/index.js +123 -123
  162. package/lib/errors/runtime/templates.js +116 -114
  163. package/lib/errors/runtime/type-assertions.js +112 -112
  164. package/lib/errors/stack-cleaning-hook.js +64 -64
  165. package/lib/errors/test-run/formattable-adapter.js +59 -59
  166. package/lib/errors/test-run/index.js +302 -302
  167. package/lib/errors/test-run/render-error-template.js +31 -31
  168. package/lib/errors/test-run/templates.js +93 -95
  169. package/lib/errors/test-run/utils.js +90 -85
  170. package/lib/errors/types.js +157 -155
  171. package/lib/index.js +81 -81
  172. package/lib/live/bootstrapper.js +44 -44
  173. package/lib/live/controller.js +107 -107
  174. package/lib/live/file-watcher/index.js +67 -67
  175. package/lib/live/file-watcher/modules-graph.js +58 -58
  176. package/lib/live/keyboard-observer.js +76 -76
  177. package/lib/live/logger/index.js +64 -64
  178. package/lib/live/test-run-controller.js +96 -96
  179. package/lib/live/test-run-state.js +6 -6
  180. package/lib/live/test-run.js +56 -56
  181. package/lib/live/test-runner.js +168 -168
  182. package/lib/load-assets.js +29 -29
  183. package/lib/notifications/add-rendered-warning.js +16 -16
  184. package/lib/notifications/debug-logger.js +78 -78
  185. package/lib/notifications/deprecated.js +24 -24
  186. package/lib/notifications/information-message.js +12 -12
  187. package/lib/notifications/warning-log.js +32 -31
  188. package/lib/notifications/warning-message.js +48 -48
  189. package/lib/reporter/command/command-formatter.js +120 -109
  190. package/lib/reporter/command/format-command.js +8 -8
  191. package/lib/reporter/command/interfaces.js +2 -2
  192. package/lib/reporter/index.js +319 -314
  193. package/lib/reporter/interfaces.js +2 -2
  194. package/lib/reporter/plugin-host.js +136 -137
  195. package/lib/reporter/plugin-methods.js +12 -12
  196. package/lib/role/index.js +74 -74
  197. package/lib/role/marker-symbol.js +7 -7
  198. package/lib/role/phase.js +9 -9
  199. package/lib/runner/bootstrapper.js +272 -272
  200. package/lib/runner/browser-job-result.js +9 -9
  201. package/lib/runner/browser-job.js +153 -123
  202. package/lib/runner/browser-set.js +114 -114
  203. package/lib/runner/fixture-hook-controller.js +85 -85
  204. package/lib/runner/index.js +450 -442
  205. package/lib/runner/interfaces.js +3 -3
  206. package/lib/runner/reporter-stream-controller.js +28 -28
  207. package/lib/runner/task/index.js +152 -133
  208. package/lib/runner/task/phase.js +9 -9
  209. package/lib/runner/test-run-controller.js +166 -185
  210. package/lib/runner/tested-app.js +73 -72
  211. package/lib/screenshots/capturer.js +141 -141
  212. package/lib/screenshots/constants.js +11 -11
  213. package/lib/screenshots/crop.js +111 -111
  214. package/lib/screenshots/default-extension.js +4 -4
  215. package/lib/screenshots/index.js +67 -67
  216. package/lib/screenshots/utils.js +39 -39
  217. package/lib/services/compiler/host.js +190 -106
  218. package/lib/services/compiler/io.js +9 -9
  219. package/lib/services/compiler/protocol.js +17 -16
  220. package/lib/services/compiler/service.js +225 -106
  221. package/lib/services/compiler/test-run-proxy.js +111 -73
  222. package/lib/services/interfaces.js +3 -0
  223. package/lib/services/process-title.js +8 -8
  224. package/lib/services/serialization/prepare-options.js +17 -17
  225. package/lib/services/serialization/replicator/create-replicator.js +27 -0
  226. package/lib/services/serialization/replicator/custom-error-transform.js +28 -0
  227. package/lib/services/serialization/test-structure.js +93 -77
  228. package/lib/services/utils/ipc/interfaces.js +30 -30
  229. package/lib/services/utils/ipc/io.js +108 -108
  230. package/lib/services/utils/ipc/message.js +76 -73
  231. package/lib/services/utils/ipc/packet.js +55 -55
  232. package/lib/services/utils/ipc/proxy.js +110 -118
  233. package/lib/services/utils/ipc/transport.js +64 -64
  234. package/lib/shared/errors/index.js +382 -382
  235. package/lib/shared/node-modules-folder-name.js +4 -4
  236. package/lib/test-run/bookmark.js +90 -90
  237. package/lib/test-run/browser-console-messages.js +73 -73
  238. package/lib/test-run/browser-manipulation-queue.js +92 -92
  239. package/lib/test-run/client-messages.js +9 -9
  240. package/lib/test-run/commands/actions.js +486 -425
  241. package/lib/test-run/commands/assertion.js +45 -45
  242. package/lib/test-run/commands/base.js +14 -14
  243. package/lib/test-run/commands/browser-manipulation.js +95 -95
  244. package/lib/test-run/commands/from-object.js +82 -82
  245. package/lib/test-run/commands/observation.js +61 -61
  246. package/lib/test-run/commands/options.js +231 -215
  247. package/lib/test-run/commands/service.js +54 -48
  248. package/lib/test-run/commands/type.js +65 -60
  249. package/lib/test-run/commands/utils.js +87 -87
  250. package/lib/test-run/commands/validations/argument.js +90 -90
  251. package/lib/test-run/commands/validations/factories.js +47 -47
  252. package/lib/test-run/commands/validations/initializers.js +44 -44
  253. package/lib/test-run/debug-log.js +32 -32
  254. package/lib/test-run/execute-js-expression.js +74 -74
  255. package/lib/test-run/index.js +823 -752
  256. package/lib/test-run/marker-symbol.js +7 -7
  257. package/lib/test-run/observed-callsites-storage.js +17 -17
  258. package/lib/test-run/phase.js +16 -16
  259. package/lib/test-run/session-controller.js +104 -104
  260. package/lib/testcafe.js +119 -114
  261. package/lib/utils/assignable.js +39 -39
  262. package/lib/utils/async-event-emitter.js +28 -28
  263. package/lib/utils/async-queue.js +14 -14
  264. package/lib/utils/browser-connection-timeouts.js +19 -19
  265. package/lib/utils/callsite.js +17 -17
  266. package/lib/utils/check-file-path.js +31 -31
  267. package/lib/utils/check-url.js +51 -51
  268. package/lib/utils/convert-to-best-fit-type.js +16 -16
  269. package/lib/utils/correct-file-path.js +21 -21
  270. package/lib/utils/define-lazy-property.js +13 -13
  271. package/lib/utils/delay.js +6 -6
  272. package/lib/utils/delegated-api.js +44 -44
  273. package/lib/utils/detect-display.js +6 -6
  274. package/lib/utils/detect-ffmpeg.js +44 -44
  275. package/lib/utils/diff/colors.js +29 -29
  276. package/lib/utils/diff/index.js +53 -53
  277. package/lib/utils/diff/util.js +24 -22
  278. package/lib/utils/diff.js +29 -29
  279. package/lib/utils/escape-user-agent.js +10 -10
  280. package/lib/utils/flag-list.js +17 -17
  281. package/lib/utils/get-any-key.js +8 -8
  282. package/lib/utils/get-browser.js +8 -8
  283. package/lib/utils/get-common-path.js +34 -34
  284. package/lib/utils/get-filter-fn.js +40 -40
  285. package/lib/utils/get-options/base.js +36 -36
  286. package/lib/utils/get-options/compiler.js +33 -33
  287. package/lib/utils/get-options/grep.js +15 -15
  288. package/lib/utils/get-options/index.js +21 -19
  289. package/lib/utils/get-options/meta.js +22 -22
  290. package/lib/utils/get-options/quarantine.js +92 -0
  291. package/lib/utils/get-options/screenshot.js +17 -17
  292. package/lib/utils/get-options/ssl.js +45 -45
  293. package/lib/utils/get-options/video.js +10 -10
  294. package/lib/utils/get-viewport-width.js +18 -18
  295. package/lib/utils/guard-time-execution.js +10 -10
  296. package/lib/utils/handle-errors.js +74 -74
  297. package/lib/utils/handle-tag-args.js +8 -8
  298. package/lib/utils/http.js +30 -30
  299. package/lib/utils/is-localhost.js +11 -11
  300. package/lib/utils/is-password-input.js +11 -0
  301. package/lib/utils/is-repl.js +12 -0
  302. package/lib/utils/is-window-in-iframe.js +6 -6
  303. package/lib/utils/limit-number.js +10 -10
  304. package/lib/utils/make-reg-exp.js +7 -7
  305. package/lib/utils/moment-loader.js +20 -20
  306. package/lib/utils/parse-file-list.js +71 -71
  307. package/lib/utils/parse-user-agent.js +55 -55
  308. package/lib/utils/path-pattern.js +114 -114
  309. package/lib/utils/prepare-reporters.js +30 -30
  310. package/lib/utils/prerender-callsite.js +18 -18
  311. package/lib/utils/process.js +119 -119
  312. package/lib/utils/promisified-functions.js +46 -46
  313. package/lib/utils/re-executable-promise.js +39 -39
  314. package/lib/utils/render-callsite-sync.js +29 -29
  315. package/lib/utils/render-template.js +10 -10
  316. package/lib/utils/reporter.js +30 -30
  317. package/lib/utils/resolve-path-relatively-cwd.js +7 -7
  318. package/lib/utils/string.js +105 -105
  319. package/lib/utils/temp-directory/cleanup-process/commands.js +7 -7
  320. package/lib/utils/temp-directory/cleanup-process/index.js +143 -143
  321. package/lib/utils/temp-directory/cleanup-process/worker.js +58 -58
  322. package/lib/utils/temp-directory/index.js +87 -87
  323. package/lib/utils/temp-directory/lockfile.js +56 -56
  324. package/lib/utils/thennable.js +7 -7
  325. package/lib/utils/timer.js +15 -15
  326. package/lib/utils/to-posix-path.js +8 -8
  327. package/lib/utils/types.js +2 -2
  328. package/lib/video-recorder/interfaces.js +2 -2
  329. package/lib/video-recorder/process.js +126 -126
  330. package/lib/video-recorder/recorder.js +136 -136
  331. package/lib/video-recorder/test-run-video-recorder.js +69 -69
  332. package/lib/video-recorder/videos.js +37 -37
  333. package/package.json +7 -7
  334. package/ts-defs/index.d.ts +109 -17
  335. package/ts-defs/selectors.d.ts +95 -7
  336. package/ts-defs/testcafe-scripts.d.ts +96 -8
@@ -1,315 +1,320 @@
1
- "use strict";
2
- var __rest = (this && this.__rest) || function (s, e) {
3
- var t = {};
4
- for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
5
- t[p] = s[p];
6
- if (s != null && typeof Object.getOwnPropertySymbols === "function")
7
- for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
8
- if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
9
- t[p[i]] = s[p[i]];
10
- }
11
- return t;
12
- };
13
- var __importDefault = (this && this.__importDefault) || function (mod) {
14
- return (mod && mod.__esModule) ? mod : { "default": mod };
15
- };
16
- Object.defineProperty(exports, "__esModule", { value: true });
17
- const lodash_1 = require("lodash");
18
- const is_stream_1 = require("is-stream");
19
- const plugin_host_1 = __importDefault(require("./plugin-host"));
20
- const plugin_methods_1 = __importDefault(require("./plugin-methods"));
21
- const format_command_1 = __importDefault(require("./command/format-command"));
22
- const get_browser_1 = __importDefault(require("../utils/get-browser"));
23
- const runtime_1 = require("../errors/runtime");
24
- class Reporter {
25
- constructor(plugin, task, outStream, name) {
26
- this.plugin = new plugin_host_1.default(plugin, outStream, name);
27
- this.task = task;
28
- this.disposed = false;
29
- this.passed = 0;
30
- this.failed = 0;
31
- this.skipped = 0;
32
- this.testCount = task.tests.filter(test => !test.skip).length;
33
- this.reportQueue = Reporter._createReportQueue(task);
34
- this.stopOnFirstFail = task.opts.stopOnFirstFail;
35
- this.outStream = outStream;
36
- this.pendingTaskDonePromise = Reporter._createPendingPromise();
37
- this._assignTaskEventHandlers();
38
- }
39
- static _isSpecialStream(stream) {
40
- return stream.isTTY || stream === process.stdout || stream === process.stderr;
41
- }
42
- static _createPendingPromise() {
43
- let resolver = null;
44
- const promise = new Promise(resolve => {
45
- resolver = resolve;
46
- });
47
- promise.resolve = resolver;
48
- return promise;
49
- }
50
- static _createReportItem(test, runsPerTest) {
51
- return {
52
- fixture: test.fixture,
53
- test: test,
54
- testRunIds: [],
55
- screenshotPath: null,
56
- screenshots: [],
57
- videos: [],
58
- quarantine: null,
59
- errs: [],
60
- warnings: [],
61
- unstable: false,
62
- startTime: null,
63
- testRunInfo: null,
64
- pendingRuns: runsPerTest,
65
- pendingStarts: runsPerTest,
66
- pendingTestRunDonePromise: Reporter._createPendingPromise(),
67
- pendingTestRunStartPromise: Reporter._createPendingPromise(),
68
- browsers: []
69
- };
70
- }
71
- static _createReportQueue(task) {
72
- const runsPerTest = task.browserConnectionGroups.length;
73
- return task.tests.map(test => Reporter._createReportItem(test, runsPerTest));
74
- }
75
- static _createTestRunInfo(reportItem) {
76
- return {
77
- errs: lodash_1.sortBy(reportItem.errs, ['userAgent', 'code']),
78
- warnings: reportItem.warnings,
79
- durationMs: new Date() - reportItem.startTime,
80
- unstable: reportItem.unstable,
81
- screenshotPath: reportItem.screenshotPath,
82
- screenshots: reportItem.screenshots,
83
- videos: reportItem.videos,
84
- quarantine: reportItem.quarantine,
85
- skipped: reportItem.test.skip,
86
- browsers: reportItem.browsers,
87
- testId: reportItem.test.id
88
- };
89
- }
90
- _getReportItemForTestRun(testRun) {
91
- return lodash_1.find(this.reportQueue, i => i.test === testRun.test);
92
- }
93
- async _shiftReportQueue(reportItem) {
94
- let currentFixture = null;
95
- let nextReportItem = null;
96
- while (this.reportQueue.length && this.reportQueue[0].testRunInfo) {
97
- reportItem = this.reportQueue.shift();
98
- currentFixture = reportItem.fixture;
99
- // NOTE: here we assume that tests are sorted by fixture.
100
- // Therefore, if the next report item has a different
101
- // fixture, we can report this fixture start.
102
- nextReportItem = this.reportQueue[0];
103
- await this.dispatchToPlugin({
104
- method: plugin_methods_1.default.reportTestDone,
105
- args: [
106
- reportItem.test.name,
107
- reportItem.testRunInfo,
108
- reportItem.test.meta
109
- ]
110
- });
111
- if (!nextReportItem)
112
- continue;
113
- if (nextReportItem.fixture === currentFixture)
114
- continue;
115
- await this.dispatchToPlugin({
116
- method: plugin_methods_1.default.reportFixtureStart,
117
- args: [
118
- nextReportItem.fixture.name,
119
- nextReportItem.fixture.path,
120
- nextReportItem.fixture.meta
121
- ]
122
- });
123
- }
124
- }
125
- async _resolveReportItem(reportItem, testRun) {
126
- if (this.task.screenshots.hasCapturedFor(testRun.test)) {
127
- reportItem.screenshotPath = this.task.screenshots.getPathFor(testRun.test);
128
- reportItem.screenshots = this.task.screenshots.getScreenshotsInfo(testRun.test);
129
- }
130
- if (this.task.videos)
131
- reportItem.videos = this.task.videos.getTestVideos(reportItem.test.id);
132
- if (testRun.quarantine) {
133
- reportItem.quarantine = testRun.quarantine.attempts.reduce((result, errors, index) => {
134
- const passed = !errors.length;
135
- const quarantineAttempt = index + 1;
136
- result[quarantineAttempt] = { passed };
137
- return result;
138
- }, {});
139
- }
140
- if (!reportItem.testRunInfo) {
141
- reportItem.testRunInfo = Reporter._createTestRunInfo(reportItem);
142
- if (reportItem.test.skip)
143
- this.skipped++;
144
- else if (reportItem.errs.length)
145
- this.failed++;
146
- else
147
- this.passed++;
148
- }
149
- await this._shiftReportQueue(reportItem);
150
- reportItem.pendingTestRunDonePromise.resolve();
151
- }
152
- _prepareReportTestActionEventArgs({ command, duration, result, testRun, err }) {
153
- const args = {};
154
- if (err)
155
- args.err = err;
156
- if (typeof duration === 'number')
157
- args.duration = duration;
158
- return Object.assign(args, {
159
- testRunId: testRun.id,
160
- test: {
161
- id: testRun.test.id,
162
- name: testRun.test.name,
163
- phase: testRun.phase,
164
- },
165
- fixture: {
166
- name: testRun.test.fixture.name,
167
- id: testRun.test.fixture.id
168
- },
169
- command: format_command_1.default(command, result),
170
- browser: testRun.controller.browser,
171
- });
172
- }
173
- async dispatchToPlugin({ method, args = [] }) {
174
- try {
175
- await this.plugin[method](...args);
176
- }
177
- catch (originalError) {
178
- const uncaughError = new runtime_1.ReporterPluginError({
179
- name: this.plugin.name,
180
- method,
181
- originalError
182
- });
183
- this.task.emit('error', uncaughError);
184
- }
185
- }
186
- async _onceTaskStartHandler() {
187
- const startTime = new Date();
188
- const userAgents = this.task.browserConnectionGroups.map(group => group[0].userAgent);
189
- const first = this.reportQueue[0];
190
- const taskProperties = {
191
- configuration: this.task.opts
192
- };
193
- await this.dispatchToPlugin({
194
- method: plugin_methods_1.default.reportTaskStart,
195
- args: [
196
- startTime,
197
- userAgents,
198
- this.testCount,
199
- this.task.testStructure,
200
- taskProperties
201
- ]
202
- });
203
- await this.dispatchToPlugin({
204
- method: plugin_methods_1.default.reportFixtureStart,
205
- args: [
206
- first.fixture.name,
207
- first.fixture.path,
208
- first.fixture.meta
209
- ]
210
- });
211
- }
212
- async _onTaskTestRunStartHandler(testRun) {
213
- const reportItem = this._getReportItemForTestRun(testRun);
214
- reportItem.testRunIds.push(testRun.id);
215
- if (!reportItem.startTime)
216
- reportItem.startTime = new Date();
217
- reportItem.pendingStarts--;
218
- if (!reportItem.pendingStarts) {
219
- if (this.plugin.reportTestStart) {
220
- const testStartInfo = { testRunIds: reportItem.testRunIds, testId: reportItem.test.id };
221
- await this.dispatchToPlugin({
222
- method: plugin_methods_1.default.reportTestStart,
223
- args: [
224
- reportItem.test.name,
225
- reportItem.test.meta,
226
- testStartInfo
227
- ]
228
- });
229
- }
230
- reportItem.pendingTestRunStartPromise.resolve();
231
- }
232
- return reportItem.pendingTestRunStartPromise;
233
- }
234
- async _onTaskTestRunDoneHandler(testRun) {
235
- const reportItem = this._getReportItemForTestRun(testRun);
236
- const isTestRunStoppedTaskExecution = !!testRun.errs.length && this.stopOnFirstFail;
237
- reportItem.pendingRuns = isTestRunStoppedTaskExecution ? 0 : reportItem.pendingRuns - 1;
238
- reportItem.unstable = reportItem.unstable || testRun.unstable;
239
- reportItem.errs = reportItem.errs.concat(testRun.errs);
240
- reportItem.warnings = testRun.warningLog ? lodash_1.union(reportItem.warnings, testRun.warningLog.messages) : [];
241
- reportItem.browsers.push(Object.assign({ testRunId: testRun.id }, get_browser_1.default(testRun.browserConnection)));
242
- if (!reportItem.pendingRuns)
243
- await this._resolveReportItem(reportItem, testRun);
244
- await reportItem.pendingTestRunDonePromise;
245
- }
246
- async _onTaskTestActionStart(_a) {
247
- var { apiActionName } = _a, restArgs = __rest(_a, ["apiActionName"]);
248
- if (this.plugin.reportTestActionStart) {
249
- restArgs = this._prepareReportTestActionEventArgs(restArgs);
250
- await this.dispatchToPlugin({
251
- method: plugin_methods_1.default.reportTestActionStart,
252
- args: [
253
- apiActionName,
254
- restArgs
255
- ]
256
- });
257
- }
258
- }
259
- async _onTaskTestActionDone(_a) {
260
- var { apiActionName } = _a, restArgs = __rest(_a, ["apiActionName"]);
261
- if (this.plugin.reportTestActionDone) {
262
- restArgs = this._prepareReportTestActionEventArgs(restArgs);
263
- await this.dispatchToPlugin({
264
- method: plugin_methods_1.default.reportTestActionDone,
265
- args: [
266
- apiActionName,
267
- restArgs
268
- ]
269
- });
270
- }
271
- }
272
- async _onceTaskDoneHandler() {
273
- const endTime = new Date();
274
- const result = {
275
- passedCount: this.passed,
276
- failedCount: this.failed,
277
- skippedCount: this.skipped
278
- };
279
- await this.dispatchToPlugin({
280
- method: plugin_methods_1.default.reportTaskDone,
281
- args: [
282
- endTime,
283
- this.passed,
284
- this.task.warningLog.messages,
285
- result
286
- ]
287
- });
288
- this.pendingTaskDonePromise.resolve();
289
- }
290
- _assignTaskEventHandlers() {
291
- const task = this.task;
292
- task.once('start', async () => await this._onceTaskStartHandler());
293
- task.on('test-run-start', async (testRun) => await this._onTaskTestRunStartHandler(testRun));
294
- task.on('test-run-done', async (testRun) => await this._onTaskTestRunDoneHandler(testRun));
295
- task.on('test-action-start', async (e) => await this._onTaskTestActionStart(e));
296
- task.on('test-action-done', async (e) => await this._onTaskTestActionDone(e));
297
- task.once('done', async () => await this._onceTaskDoneHandler());
298
- }
299
- async dispose() {
300
- if (this.disposed)
301
- return Promise.resolve();
302
- this.disposed = true;
303
- if (!this.outStream || Reporter._isSpecialStream(this.outStream) || !is_stream_1.writable(this.outStream))
304
- return Promise.resolve();
305
- const streamFinishedPromise = new Promise(resolve => {
306
- this.outStream.once('finish', resolve);
307
- this.outStream.once('error', resolve);
308
- });
309
- this.outStream.end();
310
- return streamFinishedPromise;
311
- }
312
- }
313
- exports.default = Reporter;
1
+ "use strict";
2
+ var __rest = (this && this.__rest) || function (s, e) {
3
+ var t = {};
4
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
5
+ t[p] = s[p];
6
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
7
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
8
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
9
+ t[p[i]] = s[p[i]];
10
+ }
11
+ return t;
12
+ };
13
+ var __importDefault = (this && this.__importDefault) || function (mod) {
14
+ return (mod && mod.__esModule) ? mod : { "default": mod };
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ const lodash_1 = require("lodash");
18
+ const is_stream_1 = require("is-stream");
19
+ const plugin_host_1 = __importDefault(require("./plugin-host"));
20
+ const plugin_methods_1 = __importDefault(require("./plugin-methods"));
21
+ const format_command_1 = __importDefault(require("./command/format-command"));
22
+ const get_browser_1 = __importDefault(require("../utils/get-browser"));
23
+ const runtime_1 = require("../errors/runtime");
24
+ class Reporter {
25
+ constructor(plugin, task, outStream, name) {
26
+ this.plugin = new plugin_host_1.default(plugin, outStream, name);
27
+ this.task = task;
28
+ this.disposed = false;
29
+ this.passed = 0;
30
+ this.failed = 0;
31
+ this.skipped = 0;
32
+ this.testCount = task.tests.filter(test => !test.skip).length;
33
+ this.reportQueue = Reporter._createReportQueue(task);
34
+ this.stopOnFirstFail = task.opts.stopOnFirstFail;
35
+ this.outStream = outStream;
36
+ this.pendingTaskDonePromise = Reporter._createPendingPromise();
37
+ this._assignTaskEventHandlers();
38
+ }
39
+ static _isSpecialStream(stream) {
40
+ return stream.isTTY || stream === process.stdout || stream === process.stderr;
41
+ }
42
+ static _createPendingPromise() {
43
+ let resolver = null;
44
+ const promise = new Promise(resolve => {
45
+ resolver = resolve;
46
+ });
47
+ promise.resolve = resolver;
48
+ return promise;
49
+ }
50
+ static _createReportItem(test, runsPerTest) {
51
+ return {
52
+ fixture: test.fixture,
53
+ test: test,
54
+ testRunIds: [],
55
+ screenshotPath: null,
56
+ screenshots: [],
57
+ videos: [],
58
+ quarantine: null,
59
+ errs: [],
60
+ warnings: [],
61
+ unstable: false,
62
+ startTime: null,
63
+ testRunInfo: null,
64
+ pendingRuns: runsPerTest,
65
+ pendingStarts: runsPerTest,
66
+ pendingTestRunDonePromise: Reporter._createPendingPromise(),
67
+ pendingTestRunStartPromise: Reporter._createPendingPromise(),
68
+ browsers: []
69
+ };
70
+ }
71
+ static _createReportQueue(task) {
72
+ const runsPerTest = task.browserConnectionGroups.length;
73
+ return task.tests.map(test => Reporter._createReportItem(test, runsPerTest));
74
+ }
75
+ static _createTestRunInfo(reportItem) {
76
+ return {
77
+ errs: lodash_1.sortBy(reportItem.errs, ['userAgent', 'code']),
78
+ warnings: reportItem.warnings,
79
+ durationMs: +new Date() - reportItem.startTime,
80
+ unstable: reportItem.unstable,
81
+ screenshotPath: reportItem.screenshotPath,
82
+ screenshots: reportItem.screenshots,
83
+ videos: reportItem.videos,
84
+ quarantine: reportItem.quarantine,
85
+ skipped: reportItem.test.skip,
86
+ browsers: reportItem.browsers,
87
+ testId: reportItem.test.id
88
+ };
89
+ }
90
+ _getReportItemForTestRun(testRun) {
91
+ return lodash_1.find(this.reportQueue, i => i.test === testRun.test);
92
+ }
93
+ async _shiftReportQueue() {
94
+ let currentFixture = null;
95
+ let nextReportItem = null;
96
+ let reportItem = null;
97
+ while (this.reportQueue.length && this.reportQueue[0].testRunInfo) {
98
+ reportItem = this.reportQueue.shift();
99
+ currentFixture = reportItem.fixture;
100
+ // NOTE: here we assume that tests are sorted by fixture.
101
+ // Therefore, if the next report item has a different
102
+ // fixture, we can report this fixture start.
103
+ nextReportItem = this.reportQueue[0];
104
+ await this.dispatchToPlugin({
105
+ method: plugin_methods_1.default.reportTestDone,
106
+ args: [
107
+ reportItem.test.name,
108
+ reportItem.testRunInfo,
109
+ reportItem.test.meta
110
+ ]
111
+ });
112
+ if (!nextReportItem)
113
+ continue;
114
+ if (nextReportItem.fixture === currentFixture)
115
+ continue;
116
+ await this.dispatchToPlugin({
117
+ method: plugin_methods_1.default.reportFixtureStart,
118
+ args: [
119
+ nextReportItem.fixture.name,
120
+ nextReportItem.fixture.path,
121
+ nextReportItem.fixture.meta
122
+ ]
123
+ });
124
+ }
125
+ }
126
+ async _resolveReportItem(reportItem, testRun) {
127
+ if (this.task.screenshots.hasCapturedFor(testRun.test)) {
128
+ reportItem.screenshotPath = this.task.screenshots.getPathFor(testRun.test);
129
+ reportItem.screenshots = this.task.screenshots.getScreenshotsInfo(testRun.test);
130
+ }
131
+ if (this.task.videos)
132
+ reportItem.videos = this.task.videos.getTestVideos(reportItem.test.id);
133
+ if (testRun.quarantine) {
134
+ reportItem.quarantine = testRun.quarantine.attempts.reduce((result, errors, index) => {
135
+ const passed = !errors.length;
136
+ const quarantineAttempt = index + 1;
137
+ result[quarantineAttempt] = { passed };
138
+ return result;
139
+ }, {});
140
+ }
141
+ if (!reportItem.testRunInfo) {
142
+ reportItem.testRunInfo = Reporter._createTestRunInfo(reportItem);
143
+ if (reportItem.test.skip)
144
+ this.skipped++;
145
+ else if (reportItem.errs.length)
146
+ this.failed++;
147
+ else
148
+ this.passed++;
149
+ }
150
+ await this._shiftReportQueue();
151
+ reportItem.pendingTestRunDonePromise.resolve();
152
+ }
153
+ _prepareReportTestActionEventArgs({ command, duration, result, testRun, err }) {
154
+ const args = {};
155
+ if (err)
156
+ args.err = err;
157
+ if (typeof duration === 'number')
158
+ args.duration = duration;
159
+ return Object.assign(args, {
160
+ testRunId: testRun.id,
161
+ test: {
162
+ id: testRun.test.id,
163
+ name: testRun.test.name,
164
+ phase: testRun.phase,
165
+ },
166
+ fixture: {
167
+ name: testRun.test.fixture.name,
168
+ id: testRun.test.fixture.id
169
+ },
170
+ command: format_command_1.default(command, result),
171
+ browser: testRun.controller.browser,
172
+ });
173
+ }
174
+ async dispatchToPlugin({ method, args = [] }) {
175
+ try {
176
+ // @ts-ignore
177
+ await this.plugin[method](...args);
178
+ }
179
+ catch (originalError) {
180
+ const uncaughtError = new runtime_1.ReporterPluginError({
181
+ name: this.plugin.name,
182
+ method,
183
+ originalError
184
+ });
185
+ this.task.emit('error', uncaughtError);
186
+ }
187
+ }
188
+ async _onceTaskStartHandler() {
189
+ const startTime = new Date();
190
+ const userAgents = this.task.browserConnectionGroups.map(group => group[0].userAgent);
191
+ const first = this.reportQueue[0];
192
+ const taskProperties = {
193
+ configuration: this.task.opts
194
+ };
195
+ await this.dispatchToPlugin({
196
+ method: plugin_methods_1.default.reportTaskStart,
197
+ args: [
198
+ startTime,
199
+ userAgents,
200
+ this.testCount,
201
+ this.task.testStructure,
202
+ taskProperties
203
+ ]
204
+ });
205
+ await this.dispatchToPlugin({
206
+ method: plugin_methods_1.default.reportFixtureStart,
207
+ args: [
208
+ first.fixture.name,
209
+ first.fixture.path,
210
+ first.fixture.meta
211
+ ]
212
+ });
213
+ }
214
+ async _onTaskTestRunStartHandler(testRun) {
215
+ const reportItem = this._getReportItemForTestRun(testRun);
216
+ reportItem.testRunIds.push(testRun.id);
217
+ if (!reportItem.startTime)
218
+ reportItem.startTime = +new Date();
219
+ reportItem.pendingStarts--;
220
+ if (!reportItem.pendingStarts) {
221
+ // @ts-ignore
222
+ if (this.plugin.reportTestStart) {
223
+ const testStartInfo = { testRunIds: reportItem.testRunIds, testId: reportItem.test.id };
224
+ await this.dispatchToPlugin({
225
+ method: plugin_methods_1.default.reportTestStart,
226
+ args: [
227
+ reportItem.test.name,
228
+ reportItem.test.meta,
229
+ testStartInfo
230
+ ]
231
+ });
232
+ }
233
+ reportItem.pendingTestRunStartPromise.resolve();
234
+ }
235
+ return reportItem.pendingTestRunStartPromise;
236
+ }
237
+ async _onTaskTestRunDoneHandler(testRun) {
238
+ const reportItem = this._getReportItemForTestRun(testRun);
239
+ const isTestRunStoppedTaskExecution = !!testRun.errs.length && this.stopOnFirstFail;
240
+ reportItem.pendingRuns = isTestRunStoppedTaskExecution ? 0 : reportItem.pendingRuns - 1;
241
+ reportItem.unstable = reportItem.unstable || testRun.unstable;
242
+ reportItem.errs = reportItem.errs.concat(testRun.errs);
243
+ reportItem.warnings = testRun.warningLog ? lodash_1.union(reportItem.warnings, testRun.warningLog.messages) : [];
244
+ reportItem.browsers.push(Object.assign({ testRunId: testRun.id }, get_browser_1.default(testRun.browserConnection)));
245
+ if (!reportItem.pendingRuns)
246
+ await this._resolveReportItem(reportItem, testRun);
247
+ await reportItem.pendingTestRunDonePromise;
248
+ }
249
+ async _onTaskTestActionStart(_a) {
250
+ var { apiActionName } = _a, restArgs = __rest(_a, ["apiActionName"]);
251
+ // @ts-ignore
252
+ if (this.plugin.reportTestActionStart) {
253
+ restArgs = this._prepareReportTestActionEventArgs(restArgs);
254
+ await this.dispatchToPlugin({
255
+ method: plugin_methods_1.default.reportTestActionStart,
256
+ args: [
257
+ apiActionName,
258
+ restArgs
259
+ ]
260
+ });
261
+ }
262
+ }
263
+ async _onTaskTestActionDone(_a) {
264
+ var { apiActionName } = _a, restArgs = __rest(_a, ["apiActionName"]);
265
+ // @ts-ignore
266
+ if (this.plugin.reportTestActionDone) {
267
+ restArgs = this._prepareReportTestActionEventArgs(restArgs);
268
+ await this.dispatchToPlugin({
269
+ method: plugin_methods_1.default.reportTestActionDone,
270
+ args: [
271
+ apiActionName,
272
+ restArgs
273
+ ]
274
+ });
275
+ }
276
+ }
277
+ async _onceTaskDoneHandler() {
278
+ const endTime = new Date();
279
+ const result = {
280
+ passedCount: this.passed,
281
+ failedCount: this.failed,
282
+ skippedCount: this.skipped
283
+ };
284
+ await this.dispatchToPlugin({
285
+ method: plugin_methods_1.default.reportTaskDone,
286
+ args: [
287
+ endTime,
288
+ this.passed,
289
+ this.task.warningLog.messages,
290
+ result
291
+ ]
292
+ });
293
+ this.pendingTaskDonePromise.resolve();
294
+ }
295
+ _assignTaskEventHandlers() {
296
+ const task = this.task;
297
+ task.once('start', async () => await this._onceTaskStartHandler());
298
+ task.on('test-run-start', async (testRun) => await this._onTaskTestRunStartHandler(testRun));
299
+ task.on('test-run-done', async (testRun) => await this._onTaskTestRunDoneHandler(testRun));
300
+ task.on('test-action-start', async (e) => await this._onTaskTestActionStart(e));
301
+ task.on('test-action-done', async (e) => await this._onTaskTestActionDone(e));
302
+ task.once('done', async () => await this._onceTaskDoneHandler());
303
+ }
304
+ async dispose() {
305
+ if (this.disposed)
306
+ return Promise.resolve();
307
+ this.disposed = true;
308
+ if (!this.outStream || Reporter._isSpecialStream(this.outStream) || !is_stream_1.writable(this.outStream))
309
+ return Promise.resolve();
310
+ const streamFinishedPromise = new Promise(resolve => {
311
+ this.outStream.once('finish', resolve);
312
+ this.outStream.once('error', resolve);
313
+ });
314
+ this.outStream.end();
315
+ return streamFinishedPromise;
316
+ }
317
+ }
318
+ exports.default = Reporter;
314
319
  module.exports = exports.default;
315
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/reporter/index.js"],"names":[],"mappings":"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","sourcesContent":["import {\n    find,\n    sortBy,\n    union\n} from 'lodash';\n\nimport { writable as isWritableStream } from 'is-stream';\nimport ReporterPluginHost from './plugin-host';\nimport ReporterPluginMethod from './plugin-methods';\nimport formatCommand from './command/format-command';\nimport getBrowser from '../utils/get-browser';\nimport { ReporterPluginError } from '../errors/runtime';\n\nexport default class Reporter {\n    constructor (plugin, task, outStream, name) {\n        this.plugin = new ReporterPluginHost(plugin, outStream, name);\n        this.task   = task;\n\n        this.disposed        = false;\n        this.passed          = 0;\n        this.failed          = 0;\n        this.skipped         = 0;\n        this.testCount       = task.tests.filter(test => !test.skip).length;\n        this.reportQueue     = Reporter._createReportQueue(task);\n        this.stopOnFirstFail = task.opts.stopOnFirstFail;\n        this.outStream       = outStream;\n\n        this.pendingTaskDonePromise = Reporter._createPendingPromise();\n\n        this._assignTaskEventHandlers();\n    }\n\n    static _isSpecialStream (stream) {\n        return stream.isTTY || stream === process.stdout || stream === process.stderr;\n    }\n\n    static _createPendingPromise () {\n        let resolver = null;\n\n        const promise = new Promise(resolve => {\n            resolver = resolve;\n        });\n\n        promise.resolve = resolver;\n\n        return promise;\n    }\n\n    static _createReportItem (test, runsPerTest) {\n        return {\n            fixture:                    test.fixture,\n            test:                       test,\n            testRunIds:                 [],\n            screenshotPath:             null,\n            screenshots:                [],\n            videos:                     [],\n            quarantine:                 null,\n            errs:                       [],\n            warnings:                   [],\n            unstable:                   false,\n            startTime:                  null,\n            testRunInfo:                null,\n            pendingRuns:                runsPerTest,\n            pendingStarts:              runsPerTest,\n            pendingTestRunDonePromise:  Reporter._createPendingPromise(),\n            pendingTestRunStartPromise: Reporter._createPendingPromise(),\n            browsers:                   []\n        };\n    }\n\n    static _createReportQueue (task) {\n        const runsPerTest = task.browserConnectionGroups.length;\n\n        return task.tests.map(test => Reporter._createReportItem(test, runsPerTest));\n    }\n\n    static _createTestRunInfo (reportItem) {\n        return {\n            errs:           sortBy(reportItem.errs, ['userAgent', 'code']),\n            warnings:       reportItem.warnings,\n            durationMs:     new Date() - reportItem.startTime,\n            unstable:       reportItem.unstable,\n            screenshotPath: reportItem.screenshotPath,\n            screenshots:    reportItem.screenshots,\n            videos:         reportItem.videos,\n            quarantine:     reportItem.quarantine,\n            skipped:        reportItem.test.skip,\n            browsers:       reportItem.browsers,\n            testId:         reportItem.test.id\n        };\n    }\n\n    _getReportItemForTestRun (testRun) {\n        return find(this.reportQueue, i => i.test === testRun.test);\n    }\n\n    async _shiftReportQueue (reportItem) {\n        let currentFixture = null;\n        let nextReportItem = null;\n\n        while (this.reportQueue.length && this.reportQueue[0].testRunInfo) {\n            reportItem     = this.reportQueue.shift();\n            currentFixture = reportItem.fixture;\n\n            // NOTE: here we assume that tests are sorted by fixture.\n            // Therefore, if the next report item has a different\n            // fixture, we can report this fixture start.\n            nextReportItem = this.reportQueue[0];\n\n            await this.dispatchToPlugin({\n                method: ReporterPluginMethod.reportTestDone,\n                args:   [\n                    reportItem.test.name,\n                    reportItem.testRunInfo,\n                    reportItem.test.meta\n                ]\n            });\n\n            if (!nextReportItem)\n                continue;\n\n            if (nextReportItem.fixture === currentFixture)\n                continue;\n\n            await this.dispatchToPlugin({\n                method: ReporterPluginMethod.reportFixtureStart,\n                args:   [\n                    nextReportItem.fixture.name,\n                    nextReportItem.fixture.path,\n                    nextReportItem.fixture.meta\n                ]\n            });\n        }\n    }\n\n    async _resolveReportItem (reportItem, testRun) {\n        if (this.task.screenshots.hasCapturedFor(testRun.test)) {\n            reportItem.screenshotPath = this.task.screenshots.getPathFor(testRun.test);\n            reportItem.screenshots    = this.task.screenshots.getScreenshotsInfo(testRun.test);\n        }\n\n        if (this.task.videos)\n            reportItem.videos = this.task.videos.getTestVideos(reportItem.test.id);\n\n        if (testRun.quarantine) {\n            reportItem.quarantine = testRun.quarantine.attempts.reduce((result, errors, index) => {\n                const passed            = !errors.length;\n                const quarantineAttempt = index + 1;\n\n                result[quarantineAttempt] = { passed };\n\n                return result;\n            }, {});\n        }\n\n        if (!reportItem.testRunInfo) {\n            reportItem.testRunInfo = Reporter._createTestRunInfo(reportItem);\n\n            if (reportItem.test.skip)\n                this.skipped++;\n            else if (reportItem.errs.length)\n                this.failed++;\n            else\n                this.passed++;\n        }\n\n        await this._shiftReportQueue(reportItem);\n\n        reportItem.pendingTestRunDonePromise.resolve();\n    }\n\n    _prepareReportTestActionEventArgs ({ command, duration, result, testRun, err }) {\n        const args = {};\n\n        if (err)\n            args.err = err;\n\n        if (typeof duration === 'number')\n            args.duration = duration;\n\n        return Object.assign(args, {\n            testRunId: testRun.id,\n            test:      {\n                id:    testRun.test.id,\n                name:  testRun.test.name,\n                phase: testRun.phase,\n            },\n            fixture: {\n                name: testRun.test.fixture.name,\n                id:   testRun.test.fixture.id\n            },\n            command: formatCommand(command, result),\n            browser: testRun.controller.browser,\n        });\n    }\n\n    async dispatchToPlugin ({ method, args = [] }) {\n        try {\n            await this.plugin[method](...args);\n        }\n        catch (originalError) {\n            const uncaughError = new ReporterPluginError({\n                name: this.plugin.name,\n                method,\n                originalError\n            });\n\n            this.task.emit('error', uncaughError);\n        }\n    }\n\n    async _onceTaskStartHandler () {\n        const startTime  = new Date();\n        const userAgents = this.task.browserConnectionGroups.map(group => group[0].userAgent);\n        const first      = this.reportQueue[0];\n\n        const taskProperties = {\n            configuration: this.task.opts\n        };\n\n        await this.dispatchToPlugin({\n            method: ReporterPluginMethod.reportTaskStart,\n            args:   [\n                startTime,\n                userAgents,\n                this.testCount,\n                this.task.testStructure,\n                taskProperties\n            ]\n        });\n\n        await this.dispatchToPlugin({\n            method: ReporterPluginMethod.reportFixtureStart,\n            args:   [\n                first.fixture.name,\n                first.fixture.path,\n                first.fixture.meta\n            ]\n        });\n    }\n\n    async _onTaskTestRunStartHandler (testRun) {\n        const reportItem = this._getReportItemForTestRun(testRun);\n\n        reportItem.testRunIds.push(testRun.id);\n\n        if (!reportItem.startTime)\n            reportItem.startTime = new Date();\n\n        reportItem.pendingStarts--;\n\n        if (!reportItem.pendingStarts) {\n            if (this.plugin.reportTestStart) {\n                const testStartInfo = { testRunIds: reportItem.testRunIds, testId: reportItem.test.id };\n\n                await this.dispatchToPlugin({\n                    method: ReporterPluginMethod.reportTestStart,\n                    args:   [\n                        reportItem.test.name,\n                        reportItem.test.meta,\n                        testStartInfo\n                    ]\n                });\n            }\n\n            reportItem.pendingTestRunStartPromise.resolve();\n        }\n\n        return reportItem.pendingTestRunStartPromise;\n    }\n\n    async _onTaskTestRunDoneHandler (testRun) {\n        const reportItem                    = this._getReportItemForTestRun(testRun);\n        const isTestRunStoppedTaskExecution = !!testRun.errs.length && this.stopOnFirstFail;\n\n        reportItem.pendingRuns = isTestRunStoppedTaskExecution ? 0 : reportItem.pendingRuns - 1;\n        reportItem.unstable    = reportItem.unstable || testRun.unstable;\n        reportItem.errs        = reportItem.errs.concat(testRun.errs);\n        reportItem.warnings    = testRun.warningLog ? union(reportItem.warnings, testRun.warningLog.messages) : [];\n\n        reportItem.browsers.push(Object.assign({ testRunId: testRun.id }, getBrowser(testRun.browserConnection)));\n\n        if (!reportItem.pendingRuns)\n            await this._resolveReportItem(reportItem, testRun);\n\n        await reportItem.pendingTestRunDonePromise;\n    }\n\n    async _onTaskTestActionStart ({ apiActionName, ...restArgs }) {\n        if (this.plugin.reportTestActionStart) {\n            restArgs = this._prepareReportTestActionEventArgs(restArgs);\n\n            await this.dispatchToPlugin({\n                method: ReporterPluginMethod.reportTestActionStart,\n                args:   [\n                    apiActionName,\n                    restArgs\n                ]\n            });\n        }\n    }\n\n    async _onTaskTestActionDone ({ apiActionName, ...restArgs }) {\n        if (this.plugin.reportTestActionDone) {\n            restArgs = this._prepareReportTestActionEventArgs(restArgs);\n\n            await this.dispatchToPlugin({\n                method: ReporterPluginMethod.reportTestActionDone,\n                args:   [\n                    apiActionName,\n                    restArgs\n                ]\n            });\n        }\n    }\n\n    async _onceTaskDoneHandler () {\n        const endTime = new Date();\n\n        const result = {\n            passedCount:  this.passed,\n            failedCount:  this.failed,\n            skippedCount: this.skipped\n        };\n\n        await this.dispatchToPlugin({\n            method: ReporterPluginMethod.reportTaskDone,\n            args:   [\n                endTime,\n                this.passed,\n                this.task.warningLog.messages,\n                result\n            ]\n        });\n\n        this.pendingTaskDonePromise.resolve();\n    }\n\n    _assignTaskEventHandlers () {\n        const task = this.task;\n\n        task.once('start', async () => await this._onceTaskStartHandler());\n\n        task.on('test-run-start', async testRun => await this._onTaskTestRunStartHandler(testRun));\n\n        task.on('test-run-done', async testRun => await this._onTaskTestRunDoneHandler(testRun));\n\n        task.on('test-action-start', async e => await this._onTaskTestActionStart(e));\n\n        task.on('test-action-done', async e => await this._onTaskTestActionDone(e));\n\n        task.once('done', async () => await this._onceTaskDoneHandler());\n    }\n\n    async dispose () {\n        if (this.disposed)\n            return Promise.resolve();\n\n        this.disposed = true;\n\n        if (!this.outStream || Reporter._isSpecialStream(this.outStream) || !isWritableStream(this.outStream))\n            return Promise.resolve();\n\n        const streamFinishedPromise = new Promise(resolve => {\n            this.outStream.once('finish', resolve);\n            this.outStream.once('error', resolve);\n        });\n\n        this.outStream.end();\n\n        return streamFinishedPromise;\n    }\n}\n"]}
320
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/reporter/index.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    find,\n    sortBy,\n    union\n} from 'lodash';\n\nimport { writable as isWritableStream } from 'is-stream';\nimport ReporterPluginHost from './plugin-host';\nimport ReporterPluginMethod from './plugin-methods';\nimport formatCommand from './command/format-command';\nimport getBrowser from '../utils/get-browser';\nimport { ReporterPluginError } from '../errors/runtime';\nimport Task from '../runner/task';\nimport { Writable } from 'stream';\nimport { WriteStream } from 'tty';\nimport TestRun from '../test-run';\nimport Test from '../api/structure/test';\nimport Fixture from '../api/structure/fixture';\nimport TestRunErrorFormattableAdapter from '../errors/test-run/formattable-adapter';\nimport { Command } from './command/interfaces';\n\ninterface PendingPromise {\n    resolve: Function | null;\n    then: Function;\n}\n\ninterface ReportItem {\n    fixture: Fixture;\n    test: Test;\n    testRunIds: string[];\n    screenshotPath: null | string;\n    screenshots: unknown[];\n    videos: unknown[];\n    quarantine: null;\n    errs: TestRunErrorFormattableAdapter[];\n    warnings: string[];\n    unstable: boolean;\n    startTime: null | number;\n    testRunInfo: null | TestRunInfo;\n    pendingRuns: number;\n    pendingStarts: number;\n    pendingTestRunDonePromise: PendingPromise;\n    pendingTestRunStartPromise: PendingPromise;\n    browsers: unknown[];\n}\n\ninterface TestRunInfo {\n    errs: TestRunErrorFormattableAdapter[];\n    warnings: string[];\n    durationMs: number;\n    unstable: boolean;\n    screenshotPath: string;\n    screenshots: unknown;\n    videos: unknown;\n    quarantine: unknown;\n    skipped: boolean;\n    browsers: unknown[];\n    testId: string;\n}\n\ninterface PluginMethodArguments {\n    method: string;\n    args: unknown[];\n}\n\ninterface ReportTestActionEventArguments {\n    command: Command;\n    duration: number;\n    result: unknown;\n    testRun: TestRun;\n    err: TestRunErrorFormattableAdapter;\n}\n\ninterface ReportTaskActionEventArguments {\n    apiActionName: string;\n    restArgs: object;\n}\n\nexport default class Reporter {\n    public readonly plugin: ReporterPluginHost;\n    public readonly task: Task;\n    public disposed: boolean;\n    public passed: number;\n    public failed: number;\n    public skipped: number;\n    public testCount: number;\n    public readonly reportQueue: ReportItem[];\n    public readonly stopOnFirstFail: boolean;\n    public readonly outStream: Writable;\n    public readonly pendingTaskDonePromise: PendingPromise;\n\n    public constructor (plugin: ReporterPluginHost, task: Task, outStream: Writable, name: string) {\n        this.plugin = new ReporterPluginHost(plugin, outStream, name);\n        this.task   = task;\n\n        this.disposed               = false;\n        this.passed                 = 0;\n        this.failed                 = 0;\n        this.skipped                = 0;\n        this.testCount              = task.tests.filter(test => !test.skip).length;\n        this.reportQueue            = Reporter._createReportQueue(task);\n        this.stopOnFirstFail        = task.opts.stopOnFirstFail as boolean;\n        this.outStream              = outStream;\n        this.pendingTaskDonePromise = Reporter._createPendingPromise();\n\n        this._assignTaskEventHandlers();\n    }\n\n    private static _isSpecialStream (stream: Writable): boolean {\n        return (stream as WriteStream).isTTY || stream === process.stdout || stream === process.stderr;\n    }\n\n    private static _createPendingPromise (): PendingPromise {\n        let resolver = null;\n\n        const promise = new Promise(resolve => {\n            resolver = resolve;\n        }) as unknown as PendingPromise;\n\n        promise.resolve = resolver;\n\n        return promise;\n    }\n\n    private static _createReportItem (test: Test, runsPerTest: number): ReportItem {\n        return {\n            fixture:                    test.fixture,\n            test:                       test,\n            testRunIds:                 [],\n            screenshotPath:             null,\n            screenshots:                [],\n            videos:                     [],\n            quarantine:                 null,\n            errs:                       [],\n            warnings:                   [],\n            unstable:                   false,\n            startTime:                  null,\n            testRunInfo:                null,\n            pendingRuns:                runsPerTest,\n            pendingStarts:              runsPerTest,\n            pendingTestRunDonePromise:  Reporter._createPendingPromise(),\n            pendingTestRunStartPromise: Reporter._createPendingPromise(),\n            browsers:                   []\n        };\n    }\n\n    private static _createReportQueue (task: Task): ReportItem[] {\n        const runsPerTest = task.browserConnectionGroups.length;\n\n        return task.tests.map(test => Reporter._createReportItem(test, runsPerTest));\n    }\n\n    private static _createTestRunInfo (reportItem: ReportItem): TestRunInfo {\n        return {\n            errs:           sortBy(reportItem.errs, ['userAgent', 'code']),\n            warnings:       reportItem.warnings,\n            durationMs:     +new Date() - (reportItem.startTime as number), //eslint-disable-line  @typescript-eslint/no-extra-parens\n            unstable:       reportItem.unstable,\n            screenshotPath: reportItem.screenshotPath as string,\n            screenshots:    reportItem.screenshots,\n            videos:         reportItem.videos,\n            quarantine:     reportItem.quarantine,\n            skipped:        reportItem.test.skip,\n            browsers:       reportItem.browsers,\n            testId:         reportItem.test.id\n        };\n    }\n\n    private _getReportItemForTestRun (testRun: TestRun): ReportItem | undefined {\n        return find(this.reportQueue, i => i.test === testRun.test);\n    }\n\n    private async _shiftReportQueue (): Promise<void> {\n        let currentFixture = null;\n        let nextReportItem = null;\n        let reportItem     = null;\n\n        while (this.reportQueue.length && this.reportQueue[0].testRunInfo) {\n            reportItem     = this.reportQueue.shift() as ReportItem;\n            currentFixture = reportItem.fixture;\n\n            // NOTE: here we assume that tests are sorted by fixture.\n            // Therefore, if the next report item has a different\n            // fixture, we can report this fixture start.\n            nextReportItem = this.reportQueue[0];\n\n            await this.dispatchToPlugin({\n                method: ReporterPluginMethod.reportTestDone,\n                args:   [\n                    reportItem.test.name,\n                    reportItem.testRunInfo,\n                    reportItem.test.meta\n                ]\n            });\n\n            if (!nextReportItem)\n                continue;\n\n            if (nextReportItem.fixture === currentFixture)\n                continue;\n\n            await this.dispatchToPlugin({\n                method: ReporterPluginMethod.reportFixtureStart,\n                args:   [\n                    nextReportItem.fixture.name,\n                    nextReportItem.fixture.path,\n                    nextReportItem.fixture.meta\n                ]\n            });\n        }\n    }\n\n    private async _resolveReportItem (reportItem: ReportItem, testRun: TestRun): Promise<void> {\n        if (this.task.screenshots.hasCapturedFor(testRun.test)) {\n            reportItem.screenshotPath = this.task.screenshots.getPathFor(testRun.test);\n            reportItem.screenshots    = this.task.screenshots.getScreenshotsInfo(testRun.test);\n        }\n\n        if (this.task.videos)\n            reportItem.videos = this.task.videos.getTestVideos(reportItem.test.id);\n\n        if (testRun.quarantine) {\n            reportItem.quarantine = testRun.quarantine.attempts.reduce((result: Record<string, object>, errors: TestRunErrorFormattableAdapter[], index: number) => {\n                const passed            = !errors.length;\n                const quarantineAttempt = index + 1;\n\n                result[quarantineAttempt] = { passed };\n\n                return result;\n            }, {});\n        }\n\n        if (!reportItem.testRunInfo) {\n            reportItem.testRunInfo = Reporter._createTestRunInfo(reportItem);\n\n            if (reportItem.test.skip)\n                this.skipped++;\n            else if (reportItem.errs.length)\n                this.failed++;\n            else\n                this.passed++;\n        }\n\n        await this._shiftReportQueue();\n\n        (reportItem.pendingTestRunDonePromise.resolve as Function)();\n    }\n\n    private _prepareReportTestActionEventArgs ({ command, duration, result, testRun, err }: ReportTestActionEventArguments): any {\n        const args: any = {};\n\n        if (err)\n            args.err = err;\n\n        if (typeof duration === 'number')\n            args.duration = duration;\n\n        return Object.assign(args, {\n            testRunId: testRun.id,\n            test:      {\n                id:    testRun.test.id,\n                name:  testRun.test.name,\n                phase: testRun.phase,\n            },\n            fixture: {\n                name: testRun.test.fixture.name,\n                id:   testRun.test.fixture.id\n            },\n            command: formatCommand(command, result),\n            browser: testRun.controller.browser,\n        });\n    }\n\n    public async dispatchToPlugin ({ method, args = [] }: PluginMethodArguments): Promise<void> {\n        try {\n            // @ts-ignore\n            await this.plugin[method](...args);\n        }\n        catch (originalError) {\n            const uncaughtError = new ReporterPluginError({\n                name: this.plugin.name,\n                method,\n                originalError\n            });\n\n            this.task.emit('error', uncaughtError);\n        }\n    }\n\n    private async _onceTaskStartHandler (): Promise<void> {\n        const startTime  = new Date();\n        const userAgents = this.task.browserConnectionGroups.map(group => group[0].userAgent);\n        const first      = this.reportQueue[0];\n\n        const taskProperties = {\n            configuration: this.task.opts\n        };\n\n        await this.dispatchToPlugin({\n            method: ReporterPluginMethod.reportTaskStart,\n            args:   [\n                startTime,\n                userAgents,\n                this.testCount,\n                this.task.testStructure,\n                taskProperties\n            ]\n        });\n\n        await this.dispatchToPlugin({\n            method: ReporterPluginMethod.reportFixtureStart,\n            args:   [\n                first.fixture.name,\n                first.fixture.path,\n                first.fixture.meta\n            ]\n        });\n    }\n\n    private async _onTaskTestRunStartHandler (testRun: TestRun): Promise<unknown> {\n        const reportItem = this._getReportItemForTestRun(testRun) as ReportItem;\n\n        reportItem.testRunIds.push(testRun.id);\n\n        if (!reportItem.startTime)\n            reportItem.startTime = +new Date();\n\n        reportItem.pendingStarts--;\n\n        if (!reportItem.pendingStarts) {\n            // @ts-ignore\n            if (this.plugin.reportTestStart) {\n                const testStartInfo = { testRunIds: reportItem.testRunIds, testId: reportItem.test.id };\n\n                await this.dispatchToPlugin({\n                    method: ReporterPluginMethod.reportTestStart as string,\n                    args:   [\n                        reportItem.test.name,\n                        reportItem.test.meta,\n                        testStartInfo\n                    ]\n                });\n            }\n\n            (reportItem.pendingTestRunStartPromise.resolve as Function)();\n        }\n\n        return reportItem.pendingTestRunStartPromise;\n    }\n\n    private async _onTaskTestRunDoneHandler (testRun: TestRun): Promise<void> {\n        const reportItem                    = this._getReportItemForTestRun(testRun) as ReportItem;\n        const isTestRunStoppedTaskExecution = !!testRun.errs.length && this.stopOnFirstFail;\n\n        reportItem.pendingRuns = isTestRunStoppedTaskExecution ? 0 : reportItem.pendingRuns - 1;\n        reportItem.unstable    = reportItem.unstable || testRun.unstable;\n        reportItem.errs        = reportItem.errs.concat(testRun.errs);\n        reportItem.warnings    = testRun.warningLog ? union(reportItem.warnings, testRun.warningLog.messages) : [];\n\n        reportItem.browsers.push(Object.assign({ testRunId: testRun.id }, getBrowser(testRun.browserConnection)));\n\n        if (!reportItem.pendingRuns)\n            await this._resolveReportItem(reportItem, testRun);\n\n        await reportItem.pendingTestRunDonePromise;\n    }\n\n    private async _onTaskTestActionStart ({ apiActionName, ...restArgs }: ReportTaskActionEventArguments): Promise<void> {\n        // @ts-ignore\n        if (this.plugin.reportTestActionStart) {\n            restArgs = this._prepareReportTestActionEventArgs(restArgs as unknown as ReportTestActionEventArguments);\n\n            await this.dispatchToPlugin({\n                method: ReporterPluginMethod.reportTestActionStart as string,\n                args:   [\n                    apiActionName,\n                    restArgs\n                ]\n            });\n        }\n    }\n\n    private async _onTaskTestActionDone ({ apiActionName, ...restArgs }: ReportTaskActionEventArguments): Promise<void> {\n        // @ts-ignore\n        if (this.plugin.reportTestActionDone) {\n            restArgs = this._prepareReportTestActionEventArgs(restArgs as unknown as ReportTestActionEventArguments);\n\n            await this.dispatchToPlugin({\n                method: ReporterPluginMethod.reportTestActionDone as string,\n                args:   [\n                    apiActionName,\n                    restArgs\n                ]\n            });\n        }\n    }\n\n    private async _onceTaskDoneHandler (): Promise<void> {\n        const endTime = new Date();\n\n        const result = {\n            passedCount:  this.passed,\n            failedCount:  this.failed,\n            skippedCount: this.skipped\n        };\n\n        await this.dispatchToPlugin({\n            method: ReporterPluginMethod.reportTaskDone,\n            args:   [\n                endTime,\n                this.passed,\n                this.task.warningLog.messages,\n                result\n            ]\n        });\n\n        (this.pendingTaskDonePromise.resolve as Function)();\n    }\n\n    private _assignTaskEventHandlers (): void {\n        const task = this.task;\n\n        task.once('start', async () => await this._onceTaskStartHandler());\n\n        task.on('test-run-start', async testRun => await this._onTaskTestRunStartHandler(testRun));\n\n        task.on('test-run-done', async testRun => await this._onTaskTestRunDoneHandler(testRun));\n\n        task.on('test-action-start', async e => await this._onTaskTestActionStart(e));\n\n        task.on('test-action-done', async e => await this._onTaskTestActionDone(e));\n\n        task.once('done', async () => await this._onceTaskDoneHandler());\n    }\n\n    public async dispose (): Promise<unknown> {\n        if (this.disposed)\n            return Promise.resolve();\n\n        this.disposed = true;\n\n        if (!this.outStream || Reporter._isSpecialStream(this.outStream) || !isWritableStream(this.outStream))\n            return Promise.resolve();\n\n        const streamFinishedPromise = new Promise(resolve => {\n            this.outStream.once('finish', resolve);\n            this.outStream.once('error', resolve);\n        });\n\n        this.outStream.end();\n\n        return streamFinishedPromise;\n    }\n}\n"]}