testcafe 1.18.6 → 1.19.0-alpha.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (429) hide show
  1. package/bin/testcafe-with-v8-flag-filter.js +0 -0
  2. package/lib/api/exportable-lib/index.js +64 -64
  3. package/lib/api/request-hooks/assert-type.js +7 -7
  4. package/lib/api/request-hooks/hook-method-names.js +9 -9
  5. package/lib/api/request-hooks/hook.js +32 -32
  6. package/lib/api/request-hooks/interfaces.js +2 -2
  7. package/lib/api/request-hooks/request-logger.js +112 -112
  8. package/lib/api/request-hooks/request-mock/create-request-mock.js +10 -10
  9. package/lib/api/request-hooks/request-mock/index.js +43 -43
  10. package/lib/api/request-hooks/request-mock.js +46 -46
  11. package/lib/api/structure/base-unit.js +11 -11
  12. package/lib/api/structure/fixture.js +77 -77
  13. package/lib/api/structure/interfaces.js +2 -2
  14. package/lib/api/structure/test-file.js +32 -32
  15. package/lib/api/structure/test-timeout.js +9 -9
  16. package/lib/api/structure/test.js +98 -98
  17. package/lib/api/structure/testing-unit.js +89 -89
  18. package/lib/api/structure/unit-type.js +9 -9
  19. package/lib/api/test-controller/assertion.js +105 -105
  20. package/lib/api/test-controller/execution-context.js +88 -88
  21. package/lib/api/test-controller/index.js +413 -413
  22. package/lib/api/test-controller/proxy.js +28 -28
  23. package/lib/api/test-page-url.js +60 -60
  24. package/lib/api/test-run-tracker.js +86 -86
  25. package/lib/api/user-variables/index.js +11 -11
  26. package/lib/api/wrap-test-function.js +49 -49
  27. package/lib/assertions/executor.js +87 -87
  28. package/lib/assertions/get-fn.js +46 -46
  29. package/lib/assertions/type.js +20 -20
  30. package/lib/assets/content-types.js +9 -9
  31. package/lib/assets/injectables.js +18 -18
  32. package/lib/browser/connection/command.js +10 -10
  33. package/lib/browser/connection/error-hints.js +9 -9
  34. package/lib/browser/connection/gateway.js +168 -168
  35. package/lib/browser/connection/get-hints.js +33 -33
  36. package/lib/browser/connection/heartbeat-status.js +8 -8
  37. package/lib/browser/connection/index.js +335 -335
  38. package/lib/browser/connection/remotes-queue.js +46 -46
  39. package/lib/browser/connection/service-routes.js +12 -12
  40. package/lib/browser/connection/status.js +12 -12
  41. package/lib/browser/interfaces.js +2 -2
  42. package/lib/browser/provider/built-in/dedicated/base.js +105 -105
  43. package/lib/browser/provider/built-in/dedicated/chrome/build-chrome-args.js +17 -17
  44. package/lib/browser/provider/built-in/dedicated/chrome/cdp-client/automations/click/create-mouse-click-strategy.js +57 -57
  45. package/lib/browser/provider/built-in/dedicated/chrome/cdp-client/barriers/emitters/client-request.js +44 -44
  46. package/lib/browser/provider/built-in/dedicated/chrome/cdp-client/barriers/emitters/script-execution.js +37 -37
  47. package/lib/browser/provider/built-in/dedicated/chrome/cdp-client/barriers/page-unload-barrier.js +37 -37
  48. package/lib/browser/provider/built-in/dedicated/chrome/cdp-client/client-function-executor.js +123 -123
  49. package/lib/browser/provider/built-in/dedicated/chrome/cdp-client/clients-manager.js +13 -13
  50. package/lib/browser/provider/built-in/dedicated/chrome/cdp-client/execution-context.js +83 -83
  51. package/lib/browser/provider/built-in/dedicated/chrome/cdp-client/index.js +312 -312
  52. package/lib/browser/provider/built-in/dedicated/chrome/cdp-client/shared-adapter-initializer.js +98 -98
  53. package/lib/browser/provider/built-in/dedicated/chrome/cdp-client/utils/create-event-sequence.js +38 -38
  54. package/lib/browser/provider/built-in/dedicated/chrome/cdp-client/utils/cursor.js +102 -102
  55. package/lib/browser/provider/built-in/dedicated/chrome/cdp-client/utils/dom-utils.js +194 -194
  56. package/lib/browser/provider/built-in/dedicated/chrome/cdp-client/utils/event-utils.js +8 -8
  57. package/lib/browser/provider/built-in/dedicated/chrome/cdp-client/utils/index.js +9 -9
  58. package/lib/browser/provider/built-in/dedicated/chrome/cdp-client/utils/position-utils.js +128 -128
  59. package/lib/browser/provider/built-in/dedicated/chrome/cdp-client/utils/style-utils.js +147 -147
  60. package/lib/browser/provider/built-in/dedicated/chrome/config.js +110 -110
  61. package/lib/browser/provider/built-in/dedicated/chrome/create-temp-profile.js +45 -45
  62. package/lib/browser/provider/built-in/dedicated/chrome/elapsed-upperbounds.js +15 -15
  63. package/lib/browser/provider/built-in/dedicated/chrome/index.js +110 -110
  64. package/lib/browser/provider/built-in/dedicated/chrome/interfaces.js +2 -2
  65. package/lib/browser/provider/built-in/dedicated/chrome/local-chrome.js +54 -54
  66. package/lib/browser/provider/built-in/dedicated/chrome/runtime-info.js +28 -28
  67. package/lib/browser/provider/built-in/dedicated/edge/index.js +10 -10
  68. package/lib/browser/provider/built-in/dedicated/edge/runtime-info.js +29 -29
  69. package/lib/browser/provider/built-in/dedicated/firefox/config.js +33 -33
  70. package/lib/browser/provider/built-in/dedicated/firefox/create-temp-profile.js +123 -123
  71. package/lib/browser/provider/built-in/dedicated/firefox/index.js +73 -73
  72. package/lib/browser/provider/built-in/dedicated/firefox/interfaces.js +2 -2
  73. package/lib/browser/provider/built-in/dedicated/firefox/local-firefox.js +36 -36
  74. package/lib/browser/provider/built-in/dedicated/firefox/marionette-client/commands.js +13 -13
  75. package/lib/browser/provider/built-in/dedicated/firefox/marionette-client/index.js +200 -200
  76. package/lib/browser/provider/built-in/dedicated/firefox/runtime-info.js +15 -15
  77. package/lib/browser/provider/built-in/index.js +21 -21
  78. package/lib/browser/provider/built-in/locally-installed.js +30 -30
  79. package/lib/browser/provider/built-in/path.js +47 -47
  80. package/lib/browser/provider/built-in/remote.js +58 -58
  81. package/lib/browser/provider/index.js +318 -318
  82. package/lib/browser/provider/parse-provider-name.js +16 -16
  83. package/lib/browser/provider/plugin-host.js +127 -127
  84. package/lib/browser/provider/pool.js +123 -123
  85. package/lib/browser/provider/utils/argument-parsing.js +74 -74
  86. package/lib/browser/provider/utils/browser-starter.js +34 -34
  87. package/lib/browser/provider/utils/client-functions.js +24 -24
  88. package/lib/browser/provider/utils/get-maximized-headless-window-size.js +9 -9
  89. package/lib/cli/argument-parser.js +319 -319
  90. package/lib/cli/authentication-helper.js +35 -35
  91. package/lib/cli/cli.js +143 -143
  92. package/lib/cli/correct-browsers-and-sources.js +40 -40
  93. package/lib/cli/index.js +19 -19
  94. package/lib/cli/log.js +43 -43
  95. package/lib/cli/node-arguments-filter.js +48 -48
  96. package/lib/cli/remotes-wizard.js +36 -36
  97. package/lib/cli/termination-handler.js +38 -38
  98. package/lib/client/core/index.js +3 -1
  99. package/lib/client/core/index.min.js +1 -1
  100. package/lib/client/core/scroll/adapter/index.js +14 -14
  101. package/lib/client/core/scroll/index.js +234 -234
  102. package/lib/client/core/utils/shared/adapter/index.js +17 -17
  103. package/lib/client/core/utils/shared/position.js +85 -85
  104. package/lib/client/core/utils/shared/scroll.js +84 -84
  105. package/lib/client/core/utils/shared/style.js +26 -26
  106. package/lib/client/driver/command-executors/client-functions/adapter/index.js +17 -17
  107. package/lib/client/driver/command-executors/client-functions/selector-executor/check-element-delay.js +4 -4
  108. package/lib/client/driver/command-executors/client-functions/selector-executor/filter.js +85 -85
  109. package/lib/client/driver/command-executors/client-functions/selector-executor/utils.js +37 -37
  110. package/lib/client/driver/deps/hammerhead.js +15 -15
  111. package/lib/client/driver/generate-id.js +7 -7
  112. package/lib/client/driver/internal-properties.js +8 -8
  113. package/lib/client/driver/status.js +37 -37
  114. package/lib/client-functions/builder-symbol.js +4 -4
  115. package/lib/client-functions/client-function-builder.js +174 -174
  116. package/lib/client-functions/replicator.js +61 -61
  117. package/lib/client-functions/return-single-prop-mode.js +8 -8
  118. package/lib/client-functions/selector-api-execution-mode.js +20 -20
  119. package/lib/client-functions/selectors/add-api.js +651 -651
  120. package/lib/client-functions/selectors/create-snapshot-methods.js +13 -13
  121. package/lib/client-functions/selectors/prepare-api-args.js +20 -20
  122. package/lib/client-functions/selectors/selector-attribute-filter.js +22 -22
  123. package/lib/client-functions/selectors/selector-builder.js +154 -154
  124. package/lib/client-functions/selectors/selector-text-filter.js +43 -43
  125. package/lib/client-functions/selectors/snapshot-properties.js +48 -48
  126. package/lib/client-functions/types.js +18 -18
  127. package/lib/compiler/babel/format-babel-produced-code.js +10 -10
  128. package/lib/compiler/babel/get-base-babel-options.js +11 -11
  129. package/lib/compiler/babel/load-libs.js +66 -66
  130. package/lib/compiler/babel/preset-stage-2.js +19 -19
  131. package/lib/compiler/compile-client-function.js +82 -82
  132. package/lib/compiler/compilers.js +33 -33
  133. package/lib/compiler/index.js +92 -92
  134. package/lib/compiler/interfaces.js +2 -2
  135. package/lib/compiler/test-file/add-export-api.js +24 -24
  136. package/lib/compiler/test-file/api-based.js +202 -202
  137. package/lib/compiler/test-file/base.js +36 -36
  138. package/lib/compiler/test-file/cache-proxy.js +44 -44
  139. package/lib/compiler/test-file/disable-v8-optimization-note.js +4 -4
  140. package/lib/compiler/test-file/exportble-lib-path.js +5 -5
  141. package/lib/compiler/test-file/formats/coffeescript/compiler.js +38 -38
  142. package/lib/compiler/test-file/formats/coffeescript/get-test-list.js +29 -29
  143. package/lib/compiler/test-file/formats/es-next/compiler.js +49 -49
  144. package/lib/compiler/test-file/formats/es-next/get-test-list.js +167 -167
  145. package/lib/compiler/test-file/formats/es-next/is-flow-code.js +7 -7
  146. package/lib/compiler/test-file/formats/raw.js +86 -86
  147. package/lib/compiler/test-file/formats/typescript/compiler.js +169 -169
  148. package/lib/compiler/test-file/formats/typescript/get-test-list.js +186 -186
  149. package/lib/compiler/test-file/test-file-parser-base.js +231 -231
  150. package/lib/compiler/test-file/test-file-temp-variable-name.js +4 -4
  151. package/lib/configuration/configuration-base.js +231 -225
  152. package/lib/configuration/constants.js +9 -9
  153. package/lib/configuration/customizable-compilers.js +7 -7
  154. package/lib/configuration/default-values.js +55 -55
  155. package/lib/configuration/formats.js +6 -6
  156. package/lib/configuration/interfaces.js +2 -2
  157. package/lib/configuration/option-names.js +61 -61
  158. package/lib/configuration/option-source.js +10 -10
  159. package/lib/configuration/option.js +14 -14
  160. package/lib/configuration/quarantine-option-names.js +8 -8
  161. package/lib/configuration/run-option-names.js +29 -29
  162. package/lib/configuration/screenshot-option-names.js +11 -11
  163. package/lib/configuration/testcafe-configuration.js +207 -199
  164. package/lib/configuration/types.js +2 -2
  165. package/lib/configuration/typescript-configuration.js +65 -65
  166. package/lib/custom-client-scripts/assert-type.js +7 -7
  167. package/lib/custom-client-scripts/client-script-init.js +2 -2
  168. package/lib/custom-client-scripts/client-script.js +106 -106
  169. package/lib/custom-client-scripts/get-code.js +11 -11
  170. package/lib/custom-client-scripts/get-url.js +6 -6
  171. package/lib/custom-client-scripts/load.js +15 -15
  172. package/lib/custom-client-scripts/problematic-scripts.js +2 -2
  173. package/lib/custom-client-scripts/routing.js +36 -36
  174. package/lib/custom-client-scripts/utils.js +60 -60
  175. package/lib/embedding-utils.js +83 -83
  176. package/lib/errors/create-stack-filter.js +18 -18
  177. package/lib/errors/error-list.js +27 -27
  178. package/lib/errors/get-callsite.js +31 -31
  179. package/lib/errors/internal-modules-prefix.js +8 -8
  180. package/lib/errors/is-internal-stack-frame.js +45 -45
  181. package/lib/errors/process-test-fn-error.js +37 -37
  182. package/lib/errors/runtime/index.js +124 -124
  183. package/lib/errors/runtime/templates.js +120 -119
  184. package/lib/errors/runtime/type-assertions.js +112 -112
  185. package/lib/errors/stack-cleaning-hook.js +64 -64
  186. package/lib/errors/test-run/formattable-adapter.js +60 -60
  187. package/lib/errors/test-run/index.js +359 -359
  188. package/lib/errors/test-run/render-error-template/index.js +28 -28
  189. package/lib/errors/test-run/render-error-template/utils.js +20 -20
  190. package/lib/errors/test-run/templates.js +102 -102
  191. package/lib/errors/test-run/utils.js +91 -91
  192. package/lib/errors/types.js +171 -170
  193. package/lib/index.js +89 -89
  194. package/lib/live/bootstrapper.js +45 -45
  195. package/lib/live/controller.js +107 -107
  196. package/lib/live/file-watcher/index.js +67 -67
  197. package/lib/live/file-watcher/modules-graph.js +58 -58
  198. package/lib/live/keyboard-observer.js +76 -76
  199. package/lib/live/logger/index.js +64 -64
  200. package/lib/live/test-run-controller.js +96 -96
  201. package/lib/live/test-run-state.js +6 -6
  202. package/lib/live/test-run.js +56 -56
  203. package/lib/live/test-runner.js +172 -172
  204. package/lib/load-assets.js +29 -29
  205. package/lib/notifications/add-rendered-warning.js +21 -21
  206. package/lib/notifications/debug-logger.js +78 -78
  207. package/lib/notifications/deprecated.js +24 -24
  208. package/lib/notifications/information-message.js +9 -9
  209. package/lib/notifications/warning-log.js +61 -61
  210. package/lib/notifications/warning-message.js +49 -49
  211. package/lib/reporter/command/command-formatter.js +127 -127
  212. package/lib/reporter/command/format-command.js +8 -8
  213. package/lib/reporter/command/interfaces.js +2 -2
  214. package/lib/reporter/index.js +420 -419
  215. package/lib/reporter/interfaces.js +2 -2
  216. package/lib/reporter/plugin-host.js +141 -141
  217. package/lib/reporter/plugin-methods.js +14 -14
  218. package/lib/role/index.js +26 -26
  219. package/lib/role/marker-symbol.js +7 -7
  220. package/lib/role/phase.js +9 -9
  221. package/lib/role/role.js +120 -120
  222. package/lib/runner/bootstrapper.js +237 -237
  223. package/lib/runner/browser-job-result.js +9 -9
  224. package/lib/runner/browser-job.js +155 -155
  225. package/lib/runner/browser-set.js +114 -114
  226. package/lib/runner/dashboard-config-storage/base.js +12 -12
  227. package/lib/runner/dashboard-config-storage/index.js +11 -11
  228. package/lib/runner/fixture-hook-controller.js +105 -105
  229. package/lib/runner/index.js +602 -584
  230. package/lib/runner/interfaces.js +2 -2
  231. package/lib/runner/reporter-stream-controller.js +27 -27
  232. package/lib/runner/task/index.js +140 -140
  233. package/lib/runner/task/phase.js +9 -9
  234. package/lib/runner/test-run-controller.js +169 -169
  235. package/lib/runner/test-run-hook-controller.js +64 -64
  236. package/lib/runner/tested-app.js +73 -73
  237. package/lib/screenshots/capturer.js +145 -145
  238. package/lib/screenshots/constants.js +11 -11
  239. package/lib/screenshots/crop.js +111 -111
  240. package/lib/screenshots/default-extension.js +4 -4
  241. package/lib/screenshots/index.js +68 -68
  242. package/lib/screenshots/utils.js +36 -36
  243. package/lib/services/compiler/esm-runtime-holder-name.js +4 -4
  244. package/lib/services/compiler/host.js +368 -368
  245. package/lib/services/compiler/interfaces.js +2 -2
  246. package/lib/services/compiler/io.js +9 -9
  247. package/lib/services/compiler/protocol.js +16 -16
  248. package/lib/services/compiler/service-loader.js +17 -17
  249. package/lib/services/compiler/service.js +359 -359
  250. package/lib/services/compiler/test-run-proxy.js +154 -154
  251. package/lib/services/interfaces.js +2 -2
  252. package/lib/services/process-title.js +8 -8
  253. package/lib/services/serialization/prepare-options.js +21 -21
  254. package/lib/services/serialization/replicator/create-replicator.js +56 -56
  255. package/lib/services/serialization/replicator/interfaces.js +2 -2
  256. package/lib/services/serialization/replicator/transforms/base-transform.js +14 -14
  257. package/lib/services/serialization/replicator/transforms/browser-console-messages-transform.js +21 -21
  258. package/lib/services/serialization/replicator/transforms/callsite-record-transform.js +22 -22
  259. package/lib/services/serialization/replicator/transforms/command-base-trasform/assertion-command-constructors.js +26 -26
  260. package/lib/services/serialization/replicator/transforms/command-base-trasform/command-constructors.js +60 -60
  261. package/lib/services/serialization/replicator/transforms/command-base-trasform/index.js +47 -47
  262. package/lib/services/serialization/replicator/transforms/command-base-trasform/types.js +2 -2
  263. package/lib/services/serialization/replicator/transforms/configure-response-event-option-transform.js +19 -19
  264. package/lib/services/serialization/replicator/transforms/custom-error-transform.js +27 -27
  265. package/lib/services/serialization/replicator/transforms/function-marker-transform/index.js +19 -19
  266. package/lib/services/serialization/replicator/transforms/function-marker-transform/marker.js +8 -8
  267. package/lib/services/serialization/replicator/transforms/promise-marker-transform/index.js +19 -19
  268. package/lib/services/serialization/replicator/transforms/promise-marker-transform/marker.js +8 -8
  269. package/lib/services/serialization/replicator/transforms/raw-command-callsite-record-transform.js +20 -20
  270. package/lib/services/serialization/replicator/transforms/re-executable-promise-transform/index.js +20 -20
  271. package/lib/services/serialization/replicator/transforms/re-executable-promise-transform/marker.js +5 -5
  272. package/lib/services/serialization/replicator/transforms/request-filter-rule-transform.js +21 -21
  273. package/lib/services/serialization/replicator/transforms/request-hook-event-data-transform.js +39 -39
  274. package/lib/services/serialization/replicator/transforms/response-mock-transform.js +21 -21
  275. package/lib/services/serialization/replicator/transforms/role-transform.js +19 -19
  276. package/lib/services/serialization/replicator/transforms/testcafe-error-list-transform.js +21 -21
  277. package/lib/services/serialization/replicator/transforms/url-transform.js +21 -21
  278. package/lib/services/serialization/test-structure.js +90 -90
  279. package/lib/services/utils/ipc/interfaces.js +30 -30
  280. package/lib/services/utils/ipc/io.js +108 -108
  281. package/lib/services/utils/ipc/message.js +83 -83
  282. package/lib/services/utils/ipc/packet.js +55 -55
  283. package/lib/services/utils/ipc/proxy.js +96 -96
  284. package/lib/services/utils/ipc/transport.js +64 -64
  285. package/lib/services/utils/method-should-not-be-called-error.js +8 -8
  286. package/lib/shared/actions/action-executor.js +157 -157
  287. package/lib/shared/actions/automations/click/index.js +51 -51
  288. package/lib/shared/actions/automations/click/mouse-click-strategy-base.js +20 -20
  289. package/lib/shared/actions/automations/last-hovered-element-holder.js +11 -11
  290. package/lib/shared/actions/automations/move.js +218 -218
  291. package/lib/shared/actions/automations/settings.js +29 -29
  292. package/lib/shared/actions/automations/visible-element-automation.js +160 -160
  293. package/lib/shared/actions/cursor.js +61 -61
  294. package/lib/shared/actions/get-element.js +66 -66
  295. package/lib/shared/actions/utils/get-automation-point.js +19 -19
  296. package/lib/shared/actions/utils/get-device-point.js +20 -20
  297. package/lib/shared/actions/utils/is-window-iframe.js +6 -6
  298. package/lib/shared/actions/utils/offsets.js +32 -32
  299. package/lib/shared/actions/utils/screen-point-to-client.js +13 -13
  300. package/lib/shared/adapter/index.js +13 -13
  301. package/lib/shared/barriers/complex-barrier.js +27 -27
  302. package/lib/shared/barriers/request.js +77 -77
  303. package/lib/shared/barriers/script-execution.js +71 -71
  304. package/lib/shared/errors/automation-errors.js +6 -6
  305. package/lib/shared/errors/index.js +400 -400
  306. package/lib/shared/errors/selector-error-ctor-callback.js +29 -29
  307. package/lib/shared/node-modules-folder-name.js +4 -4
  308. package/lib/shared/utils/delay.js +8 -8
  309. package/lib/shared/utils/elements-retriever.js +47 -47
  310. package/lib/shared/utils/event-emitter.js +50 -50
  311. package/lib/shared/utils/get-line-rect-intersection.js +40 -40
  312. package/lib/shared/utils/next-tick.js +10 -10
  313. package/lib/shared/utils/node-type-descriptions.js +17 -17
  314. package/lib/shared/utils/position.js +19 -19
  315. package/lib/shared/utils/promise.js +13 -13
  316. package/lib/shared/utils/values/axis-values.js +42 -42
  317. package/lib/shared/utils/values/boundary-values.js +40 -40
  318. package/lib/shared/utils/values/dimensions.js +16 -16
  319. package/lib/test-run/bookmark.js +131 -131
  320. package/lib/test-run/browser-console-messages.js +73 -73
  321. package/lib/test-run/browser-manipulation-queue.js +105 -105
  322. package/lib/test-run/client-messages.js +9 -9
  323. package/lib/test-run/commands/actions.js +582 -582
  324. package/lib/test-run/commands/assertion.js +118 -118
  325. package/lib/test-run/commands/base.js +27 -27
  326. package/lib/test-run/commands/browser-manipulation.js +105 -105
  327. package/lib/test-run/commands/from-object.js +88 -88
  328. package/lib/test-run/commands/observation.js +75 -75
  329. package/lib/test-run/commands/options.js +254 -254
  330. package/lib/test-run/commands/service.js +61 -61
  331. package/lib/test-run/commands/type.js +70 -70
  332. package/lib/test-run/commands/utils.js +92 -92
  333. package/lib/test-run/commands/validations/argument.js +131 -131
  334. package/lib/test-run/commands/validations/factories.js +69 -69
  335. package/lib/test-run/commands/validations/initializers.js +44 -44
  336. package/lib/test-run/debug-log.js +23 -23
  337. package/lib/test-run/execute-js-expression/constants.js +11 -11
  338. package/lib/test-run/execute-js-expression/index.js +85 -85
  339. package/lib/test-run/index.js +1072 -1072
  340. package/lib/test-run/marker-symbol.js +7 -7
  341. package/lib/test-run/observed-callsites-storage.js +17 -17
  342. package/lib/test-run/phase.js +19 -19
  343. package/lib/test-run/proxyless-commands-support.js +12 -12
  344. package/lib/test-run/session-controller.js +107 -107
  345. package/lib/testcafe.js +115 -115
  346. package/lib/utils/assignable.js +39 -39
  347. package/lib/utils/async-event-emitter.js +28 -28
  348. package/lib/utils/async-filter.js +7 -7
  349. package/lib/utils/async-queue.js +14 -14
  350. package/lib/utils/browser-connection-timeouts.js +19 -19
  351. package/lib/utils/callsite.js +17 -17
  352. package/lib/utils/check-file-path.js +31 -31
  353. package/lib/utils/check-url.js +51 -51
  354. package/lib/utils/convert-to-best-fit-type.js +16 -16
  355. package/lib/utils/correct-file-path.js +21 -21
  356. package/lib/utils/debug-action.js +6 -6
  357. package/lib/utils/define-lazy-property.js +13 -13
  358. package/lib/utils/delay.js +6 -6
  359. package/lib/utils/delegated-api.js +71 -71
  360. package/lib/utils/detect-display.js +6 -6
  361. package/lib/utils/detect-ffmpeg.js +44 -44
  362. package/lib/utils/diff/colors.js +29 -29
  363. package/lib/utils/diff/index.js +52 -52
  364. package/lib/utils/diff/util.js +23 -23
  365. package/lib/utils/diff.js +29 -29
  366. package/lib/utils/escape-user-agent.js +10 -10
  367. package/lib/utils/execute-fn-with-timeout.js +16 -16
  368. package/lib/utils/flag-list.js +17 -17
  369. package/lib/utils/get-any-key.js +8 -8
  370. package/lib/utils/get-browser.js +8 -8
  371. package/lib/utils/get-common-path.js +34 -34
  372. package/lib/utils/get-filter-fn.js +42 -42
  373. package/lib/utils/get-options/base.js +36 -36
  374. package/lib/utils/get-options/compiler.js +33 -33
  375. package/lib/utils/get-options/dashboard.js +17 -17
  376. package/lib/utils/get-options/get-assertion-timeout.js +10 -10
  377. package/lib/utils/get-options/grep.js +15 -15
  378. package/lib/utils/get-options/index.js +22 -22
  379. package/lib/utils/get-options/meta.js +22 -22
  380. package/lib/utils/get-options/quarantine.js +98 -98
  381. package/lib/utils/get-options/screenshot.js +17 -17
  382. package/lib/utils/get-options/ssl.js +45 -45
  383. package/lib/utils/get-options/video.js +10 -10
  384. package/lib/utils/get-renderes.js +9 -9
  385. package/lib/utils/get-viewport-width.js +17 -17
  386. package/lib/utils/guard-time-execution.js +10 -10
  387. package/lib/utils/handle-errors.js +77 -77
  388. package/lib/utils/handle-tag-args.js +8 -8
  389. package/lib/utils/http.js +30 -30
  390. package/lib/utils/is-localhost.js +11 -11
  391. package/lib/utils/is-password-input.js +9 -9
  392. package/lib/utils/is-repl.js +10 -10
  393. package/lib/utils/is-window-in-iframe.js +6 -6
  394. package/lib/utils/limit-number.js +10 -10
  395. package/lib/utils/log-entry.js +24 -24
  396. package/lib/utils/make-reg-exp.js +7 -7
  397. package/lib/utils/message-bus.js +12 -12
  398. package/lib/utils/moment-loader.js +20 -20
  399. package/lib/utils/parse-file-list.js +84 -84
  400. package/lib/utils/parse-user-agent.js +55 -55
  401. package/lib/utils/path-pattern.js +114 -114
  402. package/lib/utils/prepare-reporters.js +30 -30
  403. package/lib/utils/prerender-callsite.js +19 -19
  404. package/lib/utils/process.js +131 -131
  405. package/lib/utils/promisified-functions.js +46 -46
  406. package/lib/utils/raw-command-callsite-record.js +69 -69
  407. package/lib/utils/re-executable-promise.js +39 -39
  408. package/lib/utils/render-callsite-sync.js +30 -30
  409. package/lib/utils/render-template.js +9 -9
  410. package/lib/utils/reporter.js +30 -30
  411. package/lib/utils/resolve-path-relatively-cwd.js +7 -7
  412. package/lib/utils/setup-sourcemap-support.js +14 -14
  413. package/lib/utils/string.js +105 -105
  414. package/lib/utils/temp-directory/cleanup-process/commands.js +7 -7
  415. package/lib/utils/temp-directory/cleanup-process/index.js +143 -143
  416. package/lib/utils/temp-directory/cleanup-process/worker.js +58 -58
  417. package/lib/utils/temp-directory/index.js +87 -87
  418. package/lib/utils/temp-directory/lockfile.js +56 -56
  419. package/lib/utils/thennable.js +7 -7
  420. package/lib/utils/timer.js +15 -15
  421. package/lib/utils/to-posix-path.js +8 -8
  422. package/lib/utils/types.js +2 -2
  423. package/lib/video-recorder/interfaces.js +2 -2
  424. package/lib/video-recorder/process.js +138 -138
  425. package/lib/video-recorder/recorder.js +153 -153
  426. package/lib/video-recorder/test-run-video-recorder.js +83 -83
  427. package/lib/video-recorder/videos.js +40 -40
  428. package/package.json +5 -4
  429. package/CHANGELOG.md +0 -4360
File without changes
@@ -1,66 +1,66 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- const test_file_temp_variable_name_1 = __importDefault(require("../../compiler/test-file/test-file-temp-variable-name"));
7
- const lazyRequire = require('import-lazy')(require);
8
- const ClientFunctionBuilder = lazyRequire('../../client-functions/client-function-builder');
9
- const SelectorBuilder = lazyRequire('../../client-functions/selectors/selector-builder');
10
- const role = lazyRequire('../../role');
11
- const createRequestLogger = lazyRequire('../request-hooks/request-logger');
12
- const createRequestMock = lazyRequire('../request-hooks/request-mock/create-request-mock');
13
- const userVariables = lazyRequire('../user-variables');
14
- const addExportAPI = lazyRequire('../../compiler/test-file/add-export-api');
15
- // NOTE: We can't use lazy require for RequestHook, because it will break base class detection for inherited classes
16
- let RequestHook = null;
17
- // NOTE: We can't use lazy require for testControllerProxy, because it will break test controller detection
18
- let testControllerProxy = null;
19
- function Role(loginUrl, initFn, options) {
20
- return role.createRole(loginUrl, initFn, options);
21
- }
22
- function RequestMock() {
23
- return createRequestMock();
24
- }
25
- function RequestLogger(requestFilterRuleInit, logOptions) {
26
- return createRequestLogger(requestFilterRuleInit, logOptions);
27
- }
28
- function ClientFunction(fn, options) {
29
- const builder = new ClientFunctionBuilder(fn, options, { instantiation: 'ClientFunction' });
30
- return builder.getFunction();
31
- }
32
- function Selector(fn, options) {
33
- const builder = new SelectorBuilder(fn, options, { instantiation: 'Selector' });
34
- return builder.getFunction();
35
- }
36
- Object.defineProperty(Role, 'anonymous', {
37
- get: () => role.createAnonymousRole,
38
- });
39
- const exportableLib = {
40
- Role,
41
- ClientFunction,
42
- Selector,
43
- RequestLogger,
44
- RequestMock,
45
- get RequestHook() {
46
- if (!RequestHook)
47
- RequestHook = require('../request-hooks/hook');
48
- return RequestHook;
49
- },
50
- get t() {
51
- if (!testControllerProxy)
52
- testControllerProxy = require('../test-controller/proxy');
53
- return testControllerProxy;
54
- },
55
- get userVariables() {
56
- return userVariables.value;
57
- },
58
- };
59
- const tempTestFile = global[test_file_temp_variable_name_1.default];
60
- if (tempTestFile) {
61
- addExportAPI(tempTestFile, exportableLib, true);
62
- delete global[test_file_temp_variable_name_1.default];
63
- }
64
- exports.default = exportableLib;
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const test_file_temp_variable_name_1 = __importDefault(require("../../compiler/test-file/test-file-temp-variable-name"));
7
+ const lazyRequire = require('import-lazy')(require);
8
+ const ClientFunctionBuilder = lazyRequire('../../client-functions/client-function-builder');
9
+ const SelectorBuilder = lazyRequire('../../client-functions/selectors/selector-builder');
10
+ const role = lazyRequire('../../role');
11
+ const createRequestLogger = lazyRequire('../request-hooks/request-logger');
12
+ const createRequestMock = lazyRequire('../request-hooks/request-mock/create-request-mock');
13
+ const userVariables = lazyRequire('../user-variables');
14
+ const addExportAPI = lazyRequire('../../compiler/test-file/add-export-api');
15
+ // NOTE: We can't use lazy require for RequestHook, because it will break base class detection for inherited classes
16
+ let RequestHook = null;
17
+ // NOTE: We can't use lazy require for testControllerProxy, because it will break test controller detection
18
+ let testControllerProxy = null;
19
+ function Role(loginUrl, initFn, options) {
20
+ return role.createRole(loginUrl, initFn, options);
21
+ }
22
+ function RequestMock() {
23
+ return createRequestMock();
24
+ }
25
+ function RequestLogger(requestFilterRuleInit, logOptions) {
26
+ return createRequestLogger(requestFilterRuleInit, logOptions);
27
+ }
28
+ function ClientFunction(fn, options) {
29
+ const builder = new ClientFunctionBuilder(fn, options, { instantiation: 'ClientFunction' });
30
+ return builder.getFunction();
31
+ }
32
+ function Selector(fn, options) {
33
+ const builder = new SelectorBuilder(fn, options, { instantiation: 'Selector' });
34
+ return builder.getFunction();
35
+ }
36
+ Object.defineProperty(Role, 'anonymous', {
37
+ get: () => role.createAnonymousRole,
38
+ });
39
+ const exportableLib = {
40
+ Role,
41
+ ClientFunction,
42
+ Selector,
43
+ RequestLogger,
44
+ RequestMock,
45
+ get RequestHook() {
46
+ if (!RequestHook)
47
+ RequestHook = require('../request-hooks/hook');
48
+ return RequestHook;
49
+ },
50
+ get t() {
51
+ if (!testControllerProxy)
52
+ testControllerProxy = require('../test-controller/proxy');
53
+ return testControllerProxy;
54
+ },
55
+ get userVariables() {
56
+ return userVariables.value;
57
+ },
58
+ };
59
+ const tempTestFile = global[test_file_temp_variable_name_1.default];
60
+ if (tempTestFile) {
61
+ addExportAPI(tempTestFile, exportableLib, true);
62
+ delete global[test_file_temp_variable_name_1.default];
63
+ }
64
+ exports.default = exportableLib;
65
65
  module.exports = exports.default;
66
66
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXBpL2V4cG9ydGFibGUtbGliL2luZGV4LmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUEseUhBQWlHO0FBRWpHLE1BQU0sV0FBVyxHQUFhLE9BQU8sQ0FBQyxhQUFhLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQztBQUM5RCxNQUFNLHFCQUFxQixHQUFHLFdBQVcsQ0FBQyxnREFBZ0QsQ0FBQyxDQUFDO0FBQzVGLE1BQU0sZUFBZSxHQUFTLFdBQVcsQ0FBQyxtREFBbUQsQ0FBQyxDQUFDO0FBQy9GLE1BQU0sSUFBSSxHQUFvQixXQUFXLENBQUMsWUFBWSxDQUFDLENBQUM7QUFDeEQsTUFBTSxtQkFBbUIsR0FBSyxXQUFXLENBQUMsaUNBQWlDLENBQUMsQ0FBQztBQUM3RSxNQUFNLGlCQUFpQixHQUFPLFdBQVcsQ0FBQyxtREFBbUQsQ0FBQyxDQUFDO0FBQy9GLE1BQU0sYUFBYSxHQUFXLFdBQVcsQ0FBQyxtQkFBbUIsQ0FBQyxDQUFDO0FBQy9ELE1BQU0sWUFBWSxHQUFZLFdBQVcsQ0FBQyx5Q0FBeUMsQ0FBQyxDQUFDO0FBRXJGLG9IQUFvSDtBQUNwSCxJQUFJLFdBQVcsR0FBRyxJQUFJLENBQUM7QUFFdkIsMkdBQTJHO0FBQzNHLElBQUksbUJBQW1CLEdBQUcsSUFBSSxDQUFDO0FBRS9CLFNBQVMsSUFBSSxDQUFFLFFBQVEsRUFBRSxNQUFNLEVBQUUsT0FBTztJQUNwQyxPQUFPLElBQUksQ0FBQyxVQUFVLENBQUMsUUFBUSxFQUFFLE1BQU0sRUFBRSxPQUFPLENBQUMsQ0FBQztBQUN0RCxDQUFDO0FBRUQsU0FBUyxXQUFXO0lBQ2hCLE9BQU8saUJBQWlCLEVBQUUsQ0FBQztBQUMvQixDQUFDO0FBRUQsU0FBUyxhQUFhLENBQUUscUJBQXFCLEVBQUUsVUFBVTtJQUNyRCxPQUFPLG1CQUFtQixDQUFDLHFCQUFxQixFQUFFLFVBQVUsQ0FBQyxDQUFDO0FBQ2xFLENBQUM7QUFFRCxTQUFTLGNBQWMsQ0FBRSxFQUFFLEVBQUUsT0FBTztJQUNoQyxNQUFNLE9BQU8sR0FBRyxJQUFJLHFCQUFxQixDQUFDLEVBQUUsRUFBRSxPQUFPLEVBQUUsRUFBRSxhQUFhLEVBQUUsZ0JBQWdCLEVBQUUsQ0FBQyxDQUFDO0lBRTVGLE9BQU8sT0FBTyxDQUFDLFdBQVcsRUFBRSxDQUFDO0FBQ2pDLENBQUM7QUFFRCxTQUFTLFFBQVEsQ0FBRSxFQUFFLEVBQUUsT0FBTztJQUMxQixNQUFNLE9BQU8sR0FBRyxJQUFJLGVBQWUsQ0FBQyxFQUFFLEVBQUUsT0FBTyxFQUFFLEVBQUUsYUFBYSxFQUFFLFVBQVUsRUFBRSxDQUFDLENBQUM7SUFFaEYsT0FBTyxPQUFPLENBQUMsV0FBVyxFQUFFLENBQUM7QUFDakMsQ0FBQztBQUVELE1BQU0sQ0FBQyxjQUFjLENBQUMsSUFBSSxFQUFFLFdBQVcsRUFBRTtJQUNyQyxHQUFHLEVBQUUsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLG1CQUFtQjtDQUN0QyxDQUFDLENBQUM7QUFFSCxNQUFNLGFBQWEsR0FBRztJQUNsQixJQUFJO0lBRUosY0FBYztJQUVkLFFBQVE7SUFFUixhQUFhO0lBRWIsV0FBVztJQUVYLElBQUksV0FBVztRQUNYLElBQUksQ0FBQyxXQUFXO1lBQ1osV0FBVyxHQUFHLE9BQU8sQ0FBQyx1QkFBdUIsQ0FBQyxDQUFDO1FBRW5ELE9BQU8sV0FBVyxDQUFDO0lBQ3ZCLENBQUM7SUFFRCxJQUFJLENBQUM7UUFDRCxJQUFJLENBQUMsbUJBQW1CO1lBQ3BCLG1CQUFtQixHQUFHLE9BQU8sQ0FBQywwQkFBMEIsQ0FBQyxDQUFDO1FBRTlELE9BQU8sbUJBQW1CLENBQUM7SUFDL0IsQ0FBQztJQUVELElBQUksYUFBYTtRQUNiLE9BQU8sYUFBYSxDQUFDLEtBQUssQ0FBQztJQUMvQixDQUFDO0NBQ0osQ0FBQztBQUVGLE1BQU0sWUFBWSxHQUFHLE1BQU0sQ0FBQyxzQ0FBNEIsQ0FBQyxDQUFDO0FBRTFELElBQUksWUFBWSxFQUFFO0lBQ2QsWUFBWSxDQUFDLFlBQVksRUFBRSxhQUFhLEVBQUUsSUFBSSxDQUFDLENBQUM7SUFFaEQsT0FBTyxNQUFNLENBQUMsc0NBQTRCLENBQUMsQ0FBQztDQUMvQztBQUVELGtCQUFlLGFBQWEsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBURVNUX0ZJTEVfVEVNUF9WQVJJQUJMRV9OQU1FIGZyb20gJy4uLy4uL2NvbXBpbGVyL3Rlc3QtZmlsZS90ZXN0LWZpbGUtdGVtcC12YXJpYWJsZS1uYW1lJztcblxuY29uc3QgbGF6eVJlcXVpcmUgICAgICAgICAgID0gcmVxdWlyZSgnaW1wb3J0LWxhenknKShyZXF1aXJlKTtcbmNvbnN0IENsaWVudEZ1bmN0aW9uQnVpbGRlciA9IGxhenlSZXF1aXJlKCcuLi8uLi9jbGllbnQtZnVuY3Rpb25zL2NsaWVudC1mdW5jdGlvbi1idWlsZGVyJyk7XG5jb25zdCBTZWxlY3RvckJ1aWxkZXIgICAgICAgPSBsYXp5UmVxdWlyZSgnLi4vLi4vY2xpZW50LWZ1bmN0aW9ucy9zZWxlY3RvcnMvc2VsZWN0b3ItYnVpbGRlcicpO1xuY29uc3Qgcm9sZSAgICAgICAgICAgICAgICAgID0gbGF6eVJlcXVpcmUoJy4uLy4uL3JvbGUnKTtcbmNvbnN0IGNyZWF0ZVJlcXVlc3RMb2dnZXIgICA9IGxhenlSZXF1aXJlKCcuLi9yZXF1ZXN0LWhvb2tzL3JlcXVlc3QtbG9nZ2VyJyk7XG5jb25zdCBjcmVhdGVSZXF1ZXN0TW9jayAgICAgPSBsYXp5UmVxdWlyZSgnLi4vcmVxdWVzdC1ob29rcy9yZXF1ZXN0LW1vY2svY3JlYXRlLXJlcXVlc3QtbW9jaycpO1xuY29uc3QgdXNlclZhcmlhYmxlcyAgICAgICAgID0gbGF6eVJlcXVpcmUoJy4uL3VzZXItdmFyaWFibGVzJyk7XG5jb25zdCBhZGRFeHBvcnRBUEkgICAgICAgICAgPSBsYXp5UmVxdWlyZSgnLi4vLi4vY29tcGlsZXIvdGVzdC1maWxlL2FkZC1leHBvcnQtYXBpJyk7XG5cbi8vIE5PVEU6IFdlIGNhbid0IHVzZSBsYXp5IHJlcXVpcmUgZm9yIFJlcXVlc3RIb29rLCBiZWNhdXNlIGl0IHdpbGwgYnJlYWsgYmFzZSBjbGFzcyBkZXRlY3Rpb24gZm9yIGluaGVyaXRlZCBjbGFzc2VzXG5sZXQgUmVxdWVzdEhvb2sgPSBudWxsO1xuXG4vLyBOT1RFOiBXZSBjYW4ndCB1c2UgbGF6eSByZXF1aXJlIGZvciB0ZXN0Q29udHJvbGxlclByb3h5LCBiZWNhdXNlIGl0IHdpbGwgYnJlYWsgdGVzdCBjb250cm9sbGVyIGRldGVjdGlvblxubGV0IHRlc3RDb250cm9sbGVyUHJveHkgPSBudWxsO1xuXG5mdW5jdGlvbiBSb2xlIChsb2dpblVybCwgaW5pdEZuLCBvcHRpb25zKSB7XG4gICAgcmV0dXJuIHJvbGUuY3JlYXRlUm9sZShsb2dpblVybCwgaW5pdEZuLCBvcHRpb25zKTtcbn1cblxuZnVuY3Rpb24gUmVxdWVzdE1vY2sgKCkge1xuICAgIHJldHVybiBjcmVhdGVSZXF1ZXN0TW9jaygpO1xufVxuXG5mdW5jdGlvbiBSZXF1ZXN0TG9nZ2VyIChyZXF1ZXN0RmlsdGVyUnVsZUluaXQsIGxvZ09wdGlvbnMpIHtcbiAgICByZXR1cm4gY3JlYXRlUmVxdWVzdExvZ2dlcihyZXF1ZXN0RmlsdGVyUnVsZUluaXQsIGxvZ09wdGlvbnMpO1xufVxuXG5mdW5jdGlvbiBDbGllbnRGdW5jdGlvbiAoZm4sIG9wdGlvbnMpIHtcbiAgICBjb25zdCBidWlsZGVyID0gbmV3IENsaWVudEZ1bmN0aW9uQnVpbGRlcihmbiwgb3B0aW9ucywgeyBpbnN0YW50aWF0aW9uOiAnQ2xpZW50RnVuY3Rpb24nIH0pO1xuXG4gICAgcmV0dXJuIGJ1aWxkZXIuZ2V0RnVuY3Rpb24oKTtcbn1cblxuZnVuY3Rpb24gU2VsZWN0b3IgKGZuLCBvcHRpb25zKSB7XG4gICAgY29uc3QgYnVpbGRlciA9IG5ldyBTZWxlY3RvckJ1aWxkZXIoZm4sIG9wdGlvbnMsIHsgaW5zdGFudGlhdGlvbjogJ1NlbGVjdG9yJyB9KTtcblxuICAgIHJldHVybiBidWlsZGVyLmdldEZ1bmN0aW9uKCk7XG59XG5cbk9iamVjdC5kZWZpbmVQcm9wZXJ0eShSb2xlLCAnYW5vbnltb3VzJywge1xuICAgIGdldDogKCkgPT4gcm9sZS5jcmVhdGVBbm9ueW1vdXNSb2xlLFxufSk7XG5cbmNvbnN0IGV4cG9ydGFibGVMaWIgPSB7XG4gICAgUm9sZSxcblxuICAgIENsaWVudEZ1bmN0aW9uLFxuXG4gICAgU2VsZWN0b3IsXG5cbiAgICBSZXF1ZXN0TG9nZ2VyLFxuXG4gICAgUmVxdWVzdE1vY2ssXG5cbiAgICBnZXQgUmVxdWVzdEhvb2sgKCkge1xuICAgICAgICBpZiAoIVJlcXVlc3RIb29rKVxuICAgICAgICAgICAgUmVxdWVzdEhvb2sgPSByZXF1aXJlKCcuLi9yZXF1ZXN0LWhvb2tzL2hvb2snKTtcblxuICAgICAgICByZXR1cm4gUmVxdWVzdEhvb2s7XG4gICAgfSxcblxuICAgIGdldCB0ICgpIHtcbiAgICAgICAgaWYgKCF0ZXN0Q29udHJvbGxlclByb3h5KVxuICAgICAgICAgICAgdGVzdENvbnRyb2xsZXJQcm94eSA9IHJlcXVpcmUoJy4uL3Rlc3QtY29udHJvbGxlci9wcm94eScpO1xuXG4gICAgICAgIHJldHVybiB0ZXN0Q29udHJvbGxlclByb3h5O1xuICAgIH0sXG5cbiAgICBnZXQgdXNlclZhcmlhYmxlcyAoKSB7XG4gICAgICAgIHJldHVybiB1c2VyVmFyaWFibGVzLnZhbHVlO1xuICAgIH0sXG59O1xuXG5jb25zdCB0ZW1wVGVzdEZpbGUgPSBnbG9iYWxbVEVTVF9GSUxFX1RFTVBfVkFSSUFCTEVfTkFNRV07XG5cbmlmICh0ZW1wVGVzdEZpbGUpIHtcbiAgICBhZGRFeHBvcnRBUEkodGVtcFRlc3RGaWxlLCBleHBvcnRhYmxlTGliLCB0cnVlKTtcblxuICAgIGRlbGV0ZSBnbG9iYWxbVEVTVF9GSUxFX1RFTVBfVkFSSUFCTEVfTkFNRV07XG59XG5cbmV4cG9ydCBkZWZhdWx0IGV4cG9ydGFibGVMaWI7XG5cbiJdfQ==
@@ -1,9 +1,9 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- const type_assertions_1 = require("../../errors/runtime/type-assertions");
4
- function assertRequestHookType(hooks) {
5
- hooks.forEach(hook => type_assertions_1.assertType(type_assertions_1.is.requestHookSubclass, 'requestHooks', 'The hook', hook));
6
- }
7
- exports.default = assertRequestHookType;
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const type_assertions_1 = require("../../errors/runtime/type-assertions");
4
+ function assertRequestHookType(hooks) {
5
+ hooks.forEach(hook => type_assertions_1.assertType(type_assertions_1.is.requestHookSubclass, 'requestHooks', 'The hook', hook));
6
+ }
7
+ exports.default = assertRequestHookType;
8
8
  module.exports = exports.default;
9
9
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXNzZXJ0LXR5cGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXBpL3JlcXVlc3QtaG9va3MvYXNzZXJ0LXR5cGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSwwRUFBc0U7QUFHdEUsU0FBd0IscUJBQXFCLENBQUUsS0FBb0I7SUFDL0QsS0FBSyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLDRCQUFVLENBQUMsb0JBQUUsQ0FBQyxtQkFBbUIsRUFBRSxjQUFjLEVBQUUsVUFBVSxFQUFFLElBQUksQ0FBQyxDQUFDLENBQUM7QUFDaEcsQ0FBQztBQUZELHdDQUVDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgYXNzZXJ0VHlwZSwgaXMgfSBmcm9tICcuLi8uLi9lcnJvcnMvcnVudGltZS90eXBlLWFzc2VydGlvbnMnO1xuaW1wb3J0IFJlcXVlc3RIb29rIGZyb20gJy4vaG9vayc7XG5cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIGFzc2VydFJlcXVlc3RIb29rVHlwZSAoaG9va3M6IFJlcXVlc3RIb29rW10pOiB2b2lkIHtcbiAgICBob29rcy5mb3JFYWNoKGhvb2sgPT4gYXNzZXJ0VHlwZShpcy5yZXF1ZXN0SG9va1N1YmNsYXNzLCAncmVxdWVzdEhvb2tzJywgJ1RoZSBob29rJywgaG9vaykpO1xufVxuIl19
@@ -1,11 +1,11 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- var RequestHookMethodNames;
4
- (function (RequestHookMethodNames) {
5
- RequestHookMethodNames["onRequest"] = "onRequest";
6
- RequestHookMethodNames["_onConfigureResponse"] = "_onConfigureResponse";
7
- RequestHookMethodNames["onResponse"] = "onResponse";
8
- })(RequestHookMethodNames || (RequestHookMethodNames = {}));
9
- exports.default = RequestHookMethodNames;
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ var RequestHookMethodNames;
4
+ (function (RequestHookMethodNames) {
5
+ RequestHookMethodNames["onRequest"] = "onRequest";
6
+ RequestHookMethodNames["_onConfigureResponse"] = "_onConfigureResponse";
7
+ RequestHookMethodNames["onResponse"] = "onResponse";
8
+ })(RequestHookMethodNames || (RequestHookMethodNames = {}));
9
+ exports.default = RequestHookMethodNames;
10
10
  module.exports = exports.default;
11
11
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaG9vay1tZXRob2QtbmFtZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXBpL3JlcXVlc3QtaG9va3MvaG9vay1tZXRob2QtbmFtZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSxJQUFLLHNCQUlKO0FBSkQsV0FBSyxzQkFBc0I7SUFDdkIsaURBQXVCLENBQUE7SUFDdkIsdUVBQTZDLENBQUE7SUFDN0MsbURBQXlCLENBQUE7QUFDN0IsQ0FBQyxFQUpJLHNCQUFzQixLQUF0QixzQkFBc0IsUUFJMUI7QUFFRCxrQkFBZSxzQkFBc0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImVudW0gUmVxdWVzdEhvb2tNZXRob2ROYW1lcyB7XG4gICAgb25SZXF1ZXN0ID0gJ29uUmVxdWVzdCcsXG4gICAgX29uQ29uZmlndXJlUmVzcG9uc2UgPSAnX29uQ29uZmlndXJlUmVzcG9uc2UnLFxuICAgIG9uUmVzcG9uc2UgPSAnb25SZXNwb25zZSdcbn1cblxuZXhwb3J0IGRlZmF1bHQgUmVxdWVzdEhvb2tNZXRob2ROYW1lcztcbiJdfQ==
@@ -1,34 +1,34 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- const testcafe_hammerhead_1 = require("testcafe-hammerhead");
4
- const test_run_1 = require("../../errors/test-run");
5
- class RequestHook {
6
- constructor(ruleInit, responseEventConfigureOpts) {
7
- this._requestFilterRules = this._prepareRules(ruleInit);
8
- this._responseEventConfigureOpts = responseEventConfigureOpts;
9
- this._warningLog = null;
10
- this.id = testcafe_hammerhead_1.generateUniqueId();
11
- this._className = this.constructor.name;
12
- }
13
- _prepareRules(ruleInit) {
14
- if (Array.isArray(ruleInit) && !ruleInit.length)
15
- return [];
16
- const rules = testcafe_hammerhead_1.RequestFilterRule.fromArray(ruleInit);
17
- return !rules.length ? [testcafe_hammerhead_1.RequestFilterRule.ANY] : rules;
18
- }
19
- async onRequest(event) {
20
- throw new test_run_1.RequestHookNotImplementedMethodError('onRequest', this.constructor.name);
21
- }
22
- async _onConfigureResponse(event) {
23
- if (!this._responseEventConfigureOpts)
24
- return;
25
- event.opts.includeHeaders = this._responseEventConfigureOpts.includeHeaders;
26
- event.opts.includeBody = this._responseEventConfigureOpts.includeBody;
27
- }
28
- async onResponse(event) {
29
- throw new test_run_1.RequestHookNotImplementedMethodError('onResponse', this.constructor.name);
30
- }
31
- }
32
- exports.default = RequestHook;
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const testcafe_hammerhead_1 = require("testcafe-hammerhead");
4
+ const test_run_1 = require("../../errors/test-run");
5
+ class RequestHook {
6
+ constructor(ruleInit, responseEventConfigureOpts) {
7
+ this._requestFilterRules = this._prepareRules(ruleInit);
8
+ this._responseEventConfigureOpts = responseEventConfigureOpts;
9
+ this._warningLog = null;
10
+ this.id = testcafe_hammerhead_1.generateUniqueId();
11
+ this._className = this.constructor.name;
12
+ }
13
+ _prepareRules(ruleInit) {
14
+ if (Array.isArray(ruleInit) && !ruleInit.length)
15
+ return [];
16
+ const rules = testcafe_hammerhead_1.RequestFilterRule.fromArray(ruleInit);
17
+ return !rules.length ? [testcafe_hammerhead_1.RequestFilterRule.ANY] : rules;
18
+ }
19
+ async onRequest(event) {
20
+ throw new test_run_1.RequestHookNotImplementedMethodError('onRequest', this.constructor.name);
21
+ }
22
+ async _onConfigureResponse(event) {
23
+ if (!this._responseEventConfigureOpts)
24
+ return;
25
+ event.opts.includeHeaders = this._responseEventConfigureOpts.includeHeaders;
26
+ event.opts.includeBody = this._responseEventConfigureOpts.includeBody;
27
+ }
28
+ async onResponse(event) {
29
+ throw new test_run_1.RequestHookNotImplementedMethodError('onResponse', this.constructor.name);
30
+ }
31
+ }
32
+ exports.default = RequestHook;
33
33
  module.exports = exports.default;
34
34
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaG9vay5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9hcGkvcmVxdWVzdC1ob29rcy9ob29rLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsNkRBUTZCO0FBRTdCLG9EQUE2RTtBQUk3RSxNQUE4QixXQUFXO0lBT3JDLFlBQXVCLFFBQTBELEVBQUUsMEJBQTBEO1FBQ3pJLElBQUksQ0FBQyxtQkFBbUIsR0FBVyxJQUFJLENBQUMsYUFBYSxDQUFDLFFBQVEsQ0FBQyxDQUFDO1FBQ2hFLElBQUksQ0FBQywyQkFBMkIsR0FBRywwQkFBMEIsQ0FBQztRQUM5RCxJQUFJLENBQUMsV0FBVyxHQUFtQixJQUFJLENBQUM7UUFDeEMsSUFBSSxDQUFDLEVBQUUsR0FBNEIsc0NBQWdCLEVBQUUsQ0FBQztRQUN0RCxJQUFJLENBQUMsVUFBVSxHQUFvQixJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQztJQUM3RCxDQUFDO0lBRU8sYUFBYSxDQUFFLFFBQTBEO1FBQzdFLElBQUksS0FBSyxDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxNQUFNO1lBQzNDLE9BQU8sRUFBRSxDQUFDO1FBRWQsTUFBTSxLQUFLLEdBQUcsdUNBQWlCLENBQUMsU0FBUyxDQUFDLFFBQVEsQ0FBQyxDQUFDO1FBRXBELE9BQU8sQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDLHVDQUFpQixDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUM7SUFDM0QsQ0FBQztJQUVNLEtBQUssQ0FBQyxTQUFTLENBQUUsS0FBbUI7UUFDdkMsTUFBTSxJQUFJLCtDQUFvQyxDQUFDLFdBQVcsRUFBRSxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ3ZGLENBQUM7SUFFTSxLQUFLLENBQUMsb0JBQW9CLENBQUUsS0FBNkI7UUFDNUQsSUFBSSxDQUFDLElBQUksQ0FBQywyQkFBMkI7WUFDakMsT0FBTztRQUVYLEtBQUssQ0FBQyxJQUFJLENBQUMsY0FBYyxHQUFHLElBQUksQ0FBQywyQkFBMkIsQ0FBQyxjQUFjLENBQUM7UUFDNUUsS0FBSyxDQUFDLElBQUksQ0FBQyxXQUFXLEdBQU0sSUFBSSxDQUFDLDJCQUEyQixDQUFDLFdBQVcsQ0FBQztJQUM3RSxDQUFDO0lBRU0sS0FBSyxDQUFDLFVBQVUsQ0FBRSxLQUFvQjtRQUN6QyxNQUFNLElBQUksK0NBQW9DLENBQUMsWUFBWSxFQUFFLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDeEYsQ0FBQztDQUNKO0FBdkNELDhCQXVDQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gICAgQ29uZmlndXJlUmVzcG9uc2VFdmVudCxcbiAgICBDb25maWd1cmVSZXNwb25zZUV2ZW50T3B0aW9ucyxcbiAgICBSZXF1ZXN0RXZlbnQsXG4gICAgUmVzcG9uc2VFdmVudCxcbiAgICBSZXF1ZXN0RmlsdGVyUnVsZSxcbiAgICBSZXF1ZXN0RmlsdGVyUnVsZUluaXQsXG4gICAgZ2VuZXJhdGVVbmlxdWVJZCxcbn0gZnJvbSAndGVzdGNhZmUtaGFtbWVyaGVhZCc7XG5cbmltcG9ydCB7IFJlcXVlc3RIb29rTm90SW1wbGVtZW50ZWRNZXRob2RFcnJvciB9IGZyb20gJy4uLy4uL2Vycm9ycy90ZXN0LXJ1bic7XG5pbXBvcnQgV2FybmluZ0xvZyBmcm9tICcuLi8uLi9ub3RpZmljYXRpb25zL3dhcm5pbmctbG9nJztcblxuXG5leHBvcnQgZGVmYXVsdCBhYnN0cmFjdCBjbGFzcyBSZXF1ZXN0SG9vayB7XG4gICAgcHVibGljIF9yZXF1ZXN0RmlsdGVyUnVsZXM6IFJlcXVlc3RGaWx0ZXJSdWxlW107XG4gICAgcHVibGljIHJlYWRvbmx5IF9yZXNwb25zZUV2ZW50Q29uZmlndXJlT3B0cz86IENvbmZpZ3VyZVJlc3BvbnNlRXZlbnRPcHRpb25zO1xuICAgIHB1YmxpYyBfd2FybmluZ0xvZzogV2FybmluZ0xvZyB8IG51bGw7XG4gICAgcHVibGljIHJlYWRvbmx5IGlkOiBzdHJpbmc7XG4gICAgcHVibGljIF9jbGFzc05hbWU6IHN0cmluZztcblxuICAgIHByb3RlY3RlZCBjb25zdHJ1Y3RvciAocnVsZUluaXQ/OiBSZXF1ZXN0RmlsdGVyUnVsZUluaXQgfCBSZXF1ZXN0RmlsdGVyUnVsZUluaXRbXSwgcmVzcG9uc2VFdmVudENvbmZpZ3VyZU9wdHM/OiBDb25maWd1cmVSZXNwb25zZUV2ZW50T3B0aW9ucykge1xuICAgICAgICB0aGlzLl9yZXF1ZXN0RmlsdGVyUnVsZXMgICAgICAgICA9IHRoaXMuX3ByZXBhcmVSdWxlcyhydWxlSW5pdCk7XG4gICAgICAgIHRoaXMuX3Jlc3BvbnNlRXZlbnRDb25maWd1cmVPcHRzID0gcmVzcG9uc2VFdmVudENvbmZpZ3VyZU9wdHM7XG4gICAgICAgIHRoaXMuX3dhcm5pbmdMb2cgICAgICAgICAgICAgICAgID0gbnVsbDtcbiAgICAgICAgdGhpcy5pZCAgICAgICAgICAgICAgICAgICAgICAgICAgPSBnZW5lcmF0ZVVuaXF1ZUlkKCk7XG4gICAgICAgIHRoaXMuX2NsYXNzTmFtZSAgICAgICAgICAgICAgICAgID0gdGhpcy5jb25zdHJ1Y3Rvci5uYW1lO1xuICAgIH1cblxuICAgIHByaXZhdGUgX3ByZXBhcmVSdWxlcyAocnVsZUluaXQ/OiBSZXF1ZXN0RmlsdGVyUnVsZUluaXQgfCBSZXF1ZXN0RmlsdGVyUnVsZUluaXRbXSk6IFJlcXVlc3RGaWx0ZXJSdWxlW10ge1xuICAgICAgICBpZiAoQXJyYXkuaXNBcnJheShydWxlSW5pdCkgJiYgIXJ1bGVJbml0Lmxlbmd0aClcbiAgICAgICAgICAgIHJldHVybiBbXTtcblxuICAgICAgICBjb25zdCBydWxlcyA9IFJlcXVlc3RGaWx0ZXJSdWxlLmZyb21BcnJheShydWxlSW5pdCk7XG5cbiAgICAgICAgcmV0dXJuICFydWxlcy5sZW5ndGggPyBbUmVxdWVzdEZpbHRlclJ1bGUuQU5ZXSA6IHJ1bGVzO1xuICAgIH1cblxuICAgIHB1YmxpYyBhc3luYyBvblJlcXVlc3QgKGV2ZW50OiBSZXF1ZXN0RXZlbnQpOiBQcm9taXNlPHZvaWQ+IHsgLy8gZXNsaW50LWRpc2FibGUtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tdW51c2VkLXZhcnNcbiAgICAgICAgdGhyb3cgbmV3IFJlcXVlc3RIb29rTm90SW1wbGVtZW50ZWRNZXRob2RFcnJvcignb25SZXF1ZXN0JywgdGhpcy5jb25zdHJ1Y3Rvci5uYW1lKTtcbiAgICB9XG5cbiAgICBwdWJsaWMgYXN5bmMgX29uQ29uZmlndXJlUmVzcG9uc2UgKGV2ZW50OiBDb25maWd1cmVSZXNwb25zZUV2ZW50KTogUHJvbWlzZTx2b2lkPiB7XG4gICAgICAgIGlmICghdGhpcy5fcmVzcG9uc2VFdmVudENvbmZpZ3VyZU9wdHMpXG4gICAgICAgICAgICByZXR1cm47XG5cbiAgICAgICAgZXZlbnQub3B0cy5pbmNsdWRlSGVhZGVycyA9IHRoaXMuX3Jlc3BvbnNlRXZlbnRDb25maWd1cmVPcHRzLmluY2x1ZGVIZWFkZXJzO1xuICAgICAgICBldmVudC5vcHRzLmluY2x1ZGVCb2R5ICAgID0gdGhpcy5fcmVzcG9uc2VFdmVudENvbmZpZ3VyZU9wdHMuaW5jbHVkZUJvZHk7XG4gICAgfVxuXG4gICAgcHVibGljIGFzeW5jIG9uUmVzcG9uc2UgKGV2ZW50OiBSZXNwb25zZUV2ZW50KTogUHJvbWlzZTx2b2lkPiB7IC8vIGVzbGludC1kaXNhYmxlLWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLXVudXNlZC12YXJzXG4gICAgICAgIHRocm93IG5ldyBSZXF1ZXN0SG9va05vdEltcGxlbWVudGVkTWV0aG9kRXJyb3IoJ29uUmVzcG9uc2UnLCB0aGlzLmNvbnN0cnVjdG9yLm5hbWUpO1xuICAgIH1cbn1cbiJdfQ==
@@ -1,3 +1,3 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZXJmYWNlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9hcGkvcmVxdWVzdC1ob29rcy9pbnRlcmZhY2VzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgaW50ZXJmYWNlIFJlcXVlc3RIb29rTG9nT3B0aW9ucyB7XG4gICAgbG9nUmVxdWVzdEhlYWRlcnM6IGJvb2xlYW47XG4gICAgbG9nUmVxdWVzdEJvZHk6IGJvb2xlYW47XG4gICAgc3RyaW5naWZ5UmVxdWVzdEJvZHk6IGJvb2xlYW47XG4gICAgbG9nUmVzcG9uc2VIZWFkZXJzOiBib29sZWFuO1xuICAgIGxvZ1Jlc3BvbnNlQm9keTogYm9vbGVhbjtcbiAgICBzdHJpbmdpZnlSZXNwb25zZUJvZHk6IGJvb2xlYW47XG59XG5cbmV4cG9ydCB0eXBlIFJlcXVlc3RIb29rTG9nT3B0aW9uc0luaXQgPSBQYXJ0aWFsPFJlcXVlc3RIb29rTG9nT3B0aW9ucz47XG4iXX0=
@@ -1,114 +1,114 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- const testcafe_hammerhead_1 = require("testcafe-hammerhead");
7
- const hook_1 = __importDefault(require("./hook"));
8
- const parse_user_agent_1 = __importDefault(require("../../utils/parse-user-agent"));
9
- const test_run_tracker_1 = __importDefault(require("../test-run-tracker"));
10
- const re_executable_promise_1 = __importDefault(require("../../utils/re-executable-promise"));
11
- const runtime_1 = require("../../errors/runtime");
12
- const types_1 = require("../../errors/types");
13
- const DEFAULT_OPTIONS = {
14
- logRequestHeaders: false,
15
- logRequestBody: false,
16
- stringifyRequestBody: false,
17
- logResponseHeaders: false,
18
- logResponseBody: false,
19
- stringifyResponseBody: false,
20
- };
21
- const REQUEST_LOGGER_CLASS_NAME = 'RequestLogger';
22
- class RequestLoggerImplementation extends hook_1.default {
23
- constructor(requestFilterRuleInit, options) {
24
- const effectiveOptions = Object.assign({}, DEFAULT_OPTIONS, options);
25
- RequestLoggerImplementation._assertLogOptions(effectiveOptions);
26
- const configureResponseEventOptions = new testcafe_hammerhead_1.ConfigureResponseEventOptions(effectiveOptions.logResponseHeaders, effectiveOptions.logResponseBody);
27
- super(requestFilterRuleInit, configureResponseEventOptions);
28
- this._className = REQUEST_LOGGER_CLASS_NAME;
29
- this._options = effectiveOptions;
30
- this._internalRequests = {};
31
- }
32
- static _assertLogOptions(logOptions) {
33
- if (!logOptions.logRequestBody && logOptions.stringifyRequestBody)
34
- throw new runtime_1.APIError('RequestLogger', types_1.RUNTIME_ERRORS.requestHookConfigureAPIError, 'RequestLogger', 'Cannot stringify the request body because it is not logged. Specify { logRequestBody: true } in log options.');
35
- if (!logOptions.logResponseBody && logOptions.stringifyResponseBody)
36
- throw new runtime_1.APIError('RequestLogger', types_1.RUNTIME_ERRORS.requestHookConfigureAPIError, 'RequestLogger', 'Cannot stringify the response body because it is not logged. Specify { logResponseBody: true } in log options.');
37
- }
38
- async onRequest(event) {
39
- const loggedReq = {
40
- id: event._requestInfo.requestId,
41
- testRunId: event._requestInfo.sessionId,
42
- userAgent: parse_user_agent_1.default(event._requestInfo.userAgent).prettyUserAgent,
43
- request: {
44
- timestamp: Date.now(),
45
- url: event._requestInfo.url,
46
- method: event._requestInfo.method,
47
- },
48
- };
49
- if (this._options.logRequestHeaders)
50
- loggedReq.request.headers = Object.assign({}, event._requestInfo.headers);
51
- if (this._options.logRequestBody)
52
- loggedReq.request.body = this._options.stringifyRequestBody ? event._requestInfo.body.toString() : event._requestInfo.body;
53
- this._internalRequests[loggedReq.id] = loggedReq;
54
- }
55
- async onResponse(event) {
56
- const loggedReq = this._internalRequests[event.requestId];
57
- // NOTE: If the 'clear' method is called during a long running request,
58
- // we should not save a response part - request part has been already removed.
59
- if (!loggedReq)
60
- return;
61
- loggedReq.response = {
62
- statusCode: event.statusCode,
63
- timestamp: Date.now(),
64
- };
65
- if (this._options.logResponseHeaders)
66
- loggedReq.response.headers = Object.assign({}, event.headers);
67
- if (this._options.logResponseBody) {
68
- loggedReq.response.body = this._options.stringifyResponseBody && event.body
69
- ? event.body.toString()
70
- : event.body;
71
- }
72
- }
73
- _prepareInternalRequestInfo() {
74
- const testRun = test_run_tracker_1.default.resolveContextTestRun();
75
- let preparedRequests = Object.values(this._internalRequests);
76
- if (testRun)
77
- preparedRequests = preparedRequests.filter(r => r.testRunId === testRun.id);
78
- return preparedRequests;
79
- }
80
- _getCompletedRequests() {
81
- return this._prepareInternalRequestInfo().filter(r => r.response);
82
- }
83
- // API
84
- contains(predicate) {
85
- return re_executable_promise_1.default.fromFn(async () => {
86
- return !!this._getCompletedRequests().find(predicate);
87
- });
88
- }
89
- count(predicate) {
90
- return re_executable_promise_1.default.fromFn(async () => {
91
- return this._getCompletedRequests().filter(predicate).length;
92
- });
93
- }
94
- clear() {
95
- const testRun = test_run_tracker_1.default.resolveContextTestRun();
96
- if (testRun) {
97
- Object.keys(this._internalRequests).forEach(id => {
98
- if (this._internalRequests[id].testRunId === testRun.id)
99
- delete this._internalRequests[id];
100
- });
101
- }
102
- else
103
- this._internalRequests = {};
104
- }
105
- get requests() {
106
- return this._prepareInternalRequestInfo();
107
- }
108
- }
109
- function createRequestLogger(requestFilterRuleInit, logOptions) {
110
- return new RequestLoggerImplementation(requestFilterRuleInit, logOptions);
111
- }
112
- exports.default = createRequestLogger;
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const testcafe_hammerhead_1 = require("testcafe-hammerhead");
7
+ const hook_1 = __importDefault(require("./hook"));
8
+ const parse_user_agent_1 = __importDefault(require("../../utils/parse-user-agent"));
9
+ const test_run_tracker_1 = __importDefault(require("../test-run-tracker"));
10
+ const re_executable_promise_1 = __importDefault(require("../../utils/re-executable-promise"));
11
+ const runtime_1 = require("../../errors/runtime");
12
+ const types_1 = require("../../errors/types");
13
+ const DEFAULT_OPTIONS = {
14
+ logRequestHeaders: false,
15
+ logRequestBody: false,
16
+ stringifyRequestBody: false,
17
+ logResponseHeaders: false,
18
+ logResponseBody: false,
19
+ stringifyResponseBody: false,
20
+ };
21
+ const REQUEST_LOGGER_CLASS_NAME = 'RequestLogger';
22
+ class RequestLoggerImplementation extends hook_1.default {
23
+ constructor(requestFilterRuleInit, options) {
24
+ const effectiveOptions = Object.assign({}, DEFAULT_OPTIONS, options);
25
+ RequestLoggerImplementation._assertLogOptions(effectiveOptions);
26
+ const configureResponseEventOptions = new testcafe_hammerhead_1.ConfigureResponseEventOptions(effectiveOptions.logResponseHeaders, effectiveOptions.logResponseBody);
27
+ super(requestFilterRuleInit, configureResponseEventOptions);
28
+ this._className = REQUEST_LOGGER_CLASS_NAME;
29
+ this._options = effectiveOptions;
30
+ this._internalRequests = {};
31
+ }
32
+ static _assertLogOptions(logOptions) {
33
+ if (!logOptions.logRequestBody && logOptions.stringifyRequestBody)
34
+ throw new runtime_1.APIError('RequestLogger', types_1.RUNTIME_ERRORS.requestHookConfigureAPIError, 'RequestLogger', 'Cannot stringify the request body because it is not logged. Specify { logRequestBody: true } in log options.');
35
+ if (!logOptions.logResponseBody && logOptions.stringifyResponseBody)
36
+ throw new runtime_1.APIError('RequestLogger', types_1.RUNTIME_ERRORS.requestHookConfigureAPIError, 'RequestLogger', 'Cannot stringify the response body because it is not logged. Specify { logResponseBody: true } in log options.');
37
+ }
38
+ async onRequest(event) {
39
+ const loggedReq = {
40
+ id: event._requestInfo.requestId,
41
+ testRunId: event._requestInfo.sessionId,
42
+ userAgent: parse_user_agent_1.default(event._requestInfo.userAgent).prettyUserAgent,
43
+ request: {
44
+ timestamp: Date.now(),
45
+ url: event._requestInfo.url,
46
+ method: event._requestInfo.method,
47
+ },
48
+ };
49
+ if (this._options.logRequestHeaders)
50
+ loggedReq.request.headers = Object.assign({}, event._requestInfo.headers);
51
+ if (this._options.logRequestBody)
52
+ loggedReq.request.body = this._options.stringifyRequestBody ? event._requestInfo.body.toString() : event._requestInfo.body;
53
+ this._internalRequests[loggedReq.id] = loggedReq;
54
+ }
55
+ async onResponse(event) {
56
+ const loggedReq = this._internalRequests[event.requestId];
57
+ // NOTE: If the 'clear' method is called during a long running request,
58
+ // we should not save a response part - request part has been already removed.
59
+ if (!loggedReq)
60
+ return;
61
+ loggedReq.response = {
62
+ statusCode: event.statusCode,
63
+ timestamp: Date.now(),
64
+ };
65
+ if (this._options.logResponseHeaders)
66
+ loggedReq.response.headers = Object.assign({}, event.headers);
67
+ if (this._options.logResponseBody) {
68
+ loggedReq.response.body = this._options.stringifyResponseBody && event.body
69
+ ? event.body.toString()
70
+ : event.body;
71
+ }
72
+ }
73
+ _prepareInternalRequestInfo() {
74
+ const testRun = test_run_tracker_1.default.resolveContextTestRun();
75
+ let preparedRequests = Object.values(this._internalRequests);
76
+ if (testRun)
77
+ preparedRequests = preparedRequests.filter(r => r.testRunId === testRun.id);
78
+ return preparedRequests;
79
+ }
80
+ _getCompletedRequests() {
81
+ return this._prepareInternalRequestInfo().filter(r => r.response);
82
+ }
83
+ // API
84
+ contains(predicate) {
85
+ return re_executable_promise_1.default.fromFn(async () => {
86
+ return !!this._getCompletedRequests().find(predicate);
87
+ });
88
+ }
89
+ count(predicate) {
90
+ return re_executable_promise_1.default.fromFn(async () => {
91
+ return this._getCompletedRequests().filter(predicate).length;
92
+ });
93
+ }
94
+ clear() {
95
+ const testRun = test_run_tracker_1.default.resolveContextTestRun();
96
+ if (testRun) {
97
+ Object.keys(this._internalRequests).forEach(id => {
98
+ if (this._internalRequests[id].testRunId === testRun.id)
99
+ delete this._internalRequests[id];
100
+ });
101
+ }
102
+ else
103
+ this._internalRequests = {};
104
+ }
105
+ get requests() {
106
+ return this._prepareInternalRequestInfo();
107
+ }
108
+ }
109
+ function createRequestLogger(requestFilterRuleInit, logOptions) {
110
+ return new RequestLoggerImplementation(requestFilterRuleInit, logOptions);
111
+ }
112
+ exports.default = createRequestLogger;
113
113
  module.exports = exports.default;
114
114
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVxdWVzdC1sb2dnZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXBpL3JlcXVlc3QtaG9va3MvcmVxdWVzdC1sb2dnZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSw2REFLNkI7QUFFN0Isa0RBQWlDO0FBQ2pDLG9GQUEwRDtBQUMxRCwyRUFBaUQ7QUFDakQsOEZBQW9FO0FBQ3BFLGtEQUFnRDtBQUNoRCw4Q0FBb0Q7QUFVcEQsTUFBTSxlQUFlLEdBQTBCO0lBQzNDLGlCQUFpQixFQUFNLEtBQUs7SUFDNUIsY0FBYyxFQUFTLEtBQUs7SUFDNUIsb0JBQW9CLEVBQUcsS0FBSztJQUM1QixrQkFBa0IsRUFBSyxLQUFLO0lBQzVCLGVBQWUsRUFBUSxLQUFLO0lBQzVCLHFCQUFxQixFQUFFLEtBQUs7Q0FDL0IsQ0FBQztBQXlCRixNQUFNLHlCQUF5QixHQUFHLGVBQWUsQ0FBQztBQUVsRCxNQUFNLDJCQUE0QixTQUFRLGNBQVc7SUFJakQsWUFBb0IscUJBQXVFLEVBQUUsT0FBbUM7UUFDNUgsTUFBTSxnQkFBZ0IsR0FBRyxNQUFNLENBQUMsTUFBTSxDQUFDLEVBQUUsRUFBRSxlQUFlLEVBQUUsT0FBTyxDQUEwQixDQUFDO1FBRTlGLDJCQUEyQixDQUFDLGlCQUFpQixDQUFDLGdCQUFnQixDQUFDLENBQUM7UUFFaEUsTUFBTSw2QkFBNkIsR0FBRyxJQUFJLG1EQUE2QixDQUFDLGdCQUFnQixDQUFDLGtCQUFrQixFQUFFLGdCQUFnQixDQUFDLGVBQWUsQ0FBQyxDQUFDO1FBRS9JLEtBQUssQ0FBQyxxQkFBcUIsRUFBRSw2QkFBNkIsQ0FBQyxDQUFDO1FBRTVELElBQUksQ0FBQyxVQUFVLEdBQVUseUJBQXlCLENBQUM7UUFDbkQsSUFBSSxDQUFDLFFBQVEsR0FBWSxnQkFBZ0IsQ0FBQztRQUMxQyxJQUFJLENBQUMsaUJBQWlCLEdBQUcsRUFBRSxDQUFDO0lBQ2hDLENBQUM7SUFFTyxNQUFNLENBQUMsaUJB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QUMsRUFBRSxDQUFDLENBQUM7WUFDMUMsQ0FBQyxDQUFDLENBQUM7U0FDTjs7WUFFRyxJQUFJLENBQUMsaUJBQWlCLEdBQUcsRUFBRSxDQUFDO0lBQ3BDLENBQUM7SUFFRCxJQUFXLFFBQVE7UUFDZixPQUFPLElBQUksQ0FBQywyQkFBMkIsRUFBRSxDQUFDO0lBQzlDLENBQUM7Q0FDSjtBQUVELFNBQXdCLG1CQUFtQixDQUFFLHFCQUFrRixFQUFFLFVBQXFDO0lBQ2xLLE9BQU8sSUFBSSwyQkFBMkIsQ0FBQyxxQkFBcUIsRUFBRSxVQUFVLENBQUMsQ0FBQztBQUM5RSxDQUFDO0FBRkQsc0NBRUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICAgIENvbmZpZ3VyZVJlc3BvbnNlRXZlbnRPcHRpb25zLFxuICAgIFJlcXVlc3RFdmVudCxcbiAgICBSZXNwb25zZUV2ZW50LFxuICAgIFJlcXVlc3RGaWx0ZXJSdWxlSW5pdCxcbn0gZnJvbSAndGVzdGNhZmUtaGFtbWVyaGVhZCc7XG5cbmltcG9ydCBSZXF1ZXN0SG9vayBmcm9tICcuL2hvb2snO1xuaW1wb3J0IHBhcnNlVXNlckFnZW50IGZyb20gJy4uLy4uL3V0aWxzL3BhcnNlLXVzZXItYWdlbnQnO1xuaW1wb3J0IHRlc3RSdW5UcmFja2VyIGZyb20gJy4uL3Rlc3QtcnVuLXRyYWNrZXInO1xuaW1wb3J0IFJlRXhlY3V0YWJsZVByb21pc2UgZnJvbSAnLi4vLi4vdXRpbHMvcmUtZXhlY3V0YWJsZS1wcm9taXNlJztcbmltcG9ydCB7IEFQSUVycm9yIH0gZnJvbSAnLi4vLi4vZXJyb3JzL3J1bnRpbWUnO1xuaW1wb3J0IHsgUlVOVElNRV9FUlJPUlMgfSBmcm9tICcuLi8uLi9lcnJvcnMvdHlwZXMnO1xuXG5pbXBvcnQge1xuICAgIFJlcXVlc3RIb29rTG9nT3B0aW9uc0luaXQsXG4gICAgUmVxdWVzdEhvb2tMb2dPcHRpb25zLFxufSBmcm9tICcuL2ludGVyZmFjZXMnO1xuXG5pbXBvcnQgeyBEaWN0aW9uYXJ5IH0gZnJvbSAnLi4vLi4vY29uZmlndXJhdGlvbi9pbnRlcmZhY2VzJztcblxuXG5jb25zdCBERUZBVUxUX09QVElPTlM6IFJlcXVlc3RIb29rTG9nT3B0aW9ucyA9IHtcbiAgICBsb2dSZXF1ZXN0SGVhZGVyczogICAgIGZhbHNlLFxuICAgIGxvZ1JlcXVlc3RCb2R5OiAgICAgICAgZmFsc2UsXG4gICAgc3RyaW5naWZ5UmVxdWVzdEJvZHk6ICBmYWxzZSxcbiAgICBsb2dSZXNwb25zZUhlYWRlcnM6ICAgIGZhbHNlLFxuICAgIGxvZ1Jlc3BvbnNlQm9keTogICAgICAgZmFsc2UsXG4gICAgc3RyaW5naWZ5UmVzcG9uc2VCb2R5OiBmYWxzZSxcbn07XG5cbmludGVyZmFjZSBPcHRpb25hbGx5TG9nZ2VkUGFydCB7XG4gICAgaGVhZGVycz86IGFueTtcbiAgICBib2R5PzogQnVmZmVyIHwgc3RyaW5nO1xufVxuXG5pbnRlcmZhY2UgTG9nZ2VkUmVxdWVzdFBhcnQgZXh0ZW5kcyBPcHRpb25hbGx5TG9nZ2VkUGFydCB7XG4gICAgdGltZXN0YW1wOiBudW1iZXI7XG4gICAgdXJsOiBzdHJpbmc7XG4gICAgbWV0aG9kOiBzdHJpbmc7XG59XG5pbnRlcmZhY2UgTG9nZ2VkUmVzcG9uc2VQYXJ0IGV4dGVuZHMgT3B0aW9uYWxseUxvZ2dlZFBhcnQge1xuICAgIHN0YXR1c0NvZGU6IG51bWJlcjtcbiAgICB0aW1lc3RhbXA6IG51bWJlcjtcbn1cblxuaW50ZXJmYWNlIExvZ2dlZFJlcXVlc3Qge1xuICAgIGlkOiBzdHJpbmc7XG4gICAgdGVzdFJ1bklkOiBzdHJpbmc7XG4gICAgdXNlckFnZW50OiBzdHJpbmc7XG4gICAgcmVxdWVzdDogTG9nZ2VkUmVxdWVzdFBhcnQ7XG4gICAgcmVzcG9uc2U/OiBMb2dnZWRSZXNwb25zZVBhcnQ7XG59XG5cbmNvbnN0IFJFUVVFU1RfTE9HR0VSX0NMQVNTX05BTUUgPSAnUmVxdWVzdExvZ2dlcic7XG5cbmNsYXNzIFJlcXVlc3RMb2dnZXJJbXBsZW1lbnRhdGlvbiBleHRlbmRzIFJlcXVlc3RIb29rIHtcbiAgICBwcml2YXRlIHJlYWRvbmx5IF9vcHRpb25zOiBSZXF1ZXN0SG9va0xvZ09wdGlvbnM7XG4gICAgcHJpdmF0ZSBfaW50ZXJuYWxSZXF1ZXN0czogRGljdGlvbmFyeTxMb2dnZWRSZXF1ZXN0PjtcblxuICAgIHB1YmxpYyBjb25zdHJ1Y3RvciAocmVxdWVzdEZpbHRlclJ1bGVJbml0PzogUmVxdWVzdEZpbHRlclJ1bGVJbml0IHwgUmVxdWVzdEZpbHRlclJ1bGVJbml0W10sIG9wdGlvbnM/OiBSZXF1ZXN0SG9va0xvZ09wdGlvbnNJbml0KSB7XG4gICAgICAgIGNvbnN0IGVmZmVjdGl2ZU9wdGlvbnMgPSBPYmplY3QuYXNzaWduKHt9LCBERUZBVUxUX09QVElPTlMsIG9wdGlvbnMpIGFzIFJlcXVlc3RIb29rTG9nT3B0aW9ucztcblxuICAgICAgICBSZXF1ZXN0TG9nZ2VySW1wbGVtZW50YXRpb24uX2Fzc2VydExvZ09wdGlvbnMoZWZmZWN0aXZlT3B0aW9ucyk7XG5cbiAgICAgICAgY29uc3QgY29uZmlndXJlUmVzcG9uc2VFdmVudE9wdGlvbnMgPSBuZXcgQ29uZmlndXJlUmVzcG9uc2VFdmVudE9wdGlvbnMoZWZmZWN0aXZlT3B0aW9ucy5sb2dSZXNwb25zZUhlYWRlcnMsIGVmZmVjdGl2ZU9wdGlvbnMubG9nUmVzcG9uc2VCb2R5KTtcblxuICAgICAgICBzdXBlcihyZXF1ZXN0RmlsdGVyUnVsZUluaXQsIGNvbmZpZ3VyZVJlc3BvbnNlRXZlbnRPcHRpb25zKTtcblxuICAgICAgICB0aGlzLl9jbGFzc05hbWUgICAgICAgID0gUkVRVUVTVF9MT0dHRVJfQ0xBU1NfTkFNRTtcbiAgICAgICAgdGhpcy5fb3B0aW9ucyAgICAgICAgICA9IGVmZmVjdGl2ZU9wdGlvbnM7XG4gICAgICAgIHRoaXMuX2ludGVybmFsUmVxdWVzdHMgPSB7fTtcbiAgICB9XG5cbiAgICBwcml2YXRlIHN0YXRpYyBfYXNzZXJ0TG9nT3B0aW9ucyAobG9nT3B0aW9uczogUmVxdWVzdEhvb2tMb2dPcHRpb25zKTogdm9pZCB7XG4gICAgICAgIGlmICghbG9nT3B0aW9ucy5sb2dSZXF1ZXN0Qm9keSAmJiBsb2dPcHRpb25zLnN0cmluZ2lmeVJlcXVlc3RCb2R5KVxuICAgICAgICAgICAgdGhyb3cgbmV3IEFQSUVycm9yKCdSZXF1ZXN0TG9nZ2VyJywgUlVOVElNRV9FUlJPUlMucmVxdWVzdEhvb2tDb25maWd1cmVBUElFcnJvciwgJ1JlcXVlc3RMb2dnZXInLCAnQ2Fubm90IHN0cmluZ2lmeSB0aGUgcmVxdWVzdCBib2R5IGJlY2F1c2UgaXQgaXMgbm90IGxvZ2dlZC4gU3BlY2lmeSB7IGxvZ1JlcXVlc3RCb2R5OiB0cnVlIH0gaW4gbG9nIG9wdGlvbnMuJyk7XG5cbiAgICAgICAgaWYgKCFsb2dPcHRpb25zLmxvZ1Jlc3BvbnNlQm9keSAmJiBsb2dPcHRpb25zLnN0cmluZ2lmeVJlc3BvbnNlQm9keSlcbiAgICAgICAgICAgIHRocm93IG5ldyBBUElFcnJvcignUmVxdWVzdExvZ2dlcicsIFJVTlRJTUVfRVJST1JTLnJlcXVlc3RIb29rQ29uZmlndXJlQVBJRXJyb3IsICdSZXF1ZXN0TG9nZ2VyJywgJ0Nhbm5vdCBzdHJpbmdpZnkgdGhlIHJlc3BvbnNlIGJvZHkgYmVjYXVzZSBpdCBpcyBub3QgbG9nZ2VkLiBTcGVjaWZ5IHsgbG9nUmVzcG9uc2VCb2R5OiB0cnVlIH0gaW4gbG9nIG9wdGlvbnMuJyk7XG4gICAgfVxuXG4gICAgcHVibGljIGFzeW5jIG9uUmVxdWVzdCAoZXZlbnQ6IFJlcXVlc3RFdmVudCk6IFByb21pc2U8dm9pZD4ge1xuICAgICAgICBjb25zdCBsb2dnZWRSZXE6IExvZ2dlZFJlcXVlc3QgPSB7XG4gICAgICAgICAgICBpZDogICAgICAgIGV2ZW50Ll9yZXF1ZXN0SW5mby5yZXF1ZXN0SWQsXG4gICAgICAgICAgICB0ZXN0UnVuSWQ6IGV2ZW50Ll9yZXF1ZXN0SW5mby5zZXNzaW9uSWQsXG4gICAgICAgICAgICB1c2VyQWdlbnQ6IHBhcnNlVXNlckFnZW50KGV2ZW50Ll9yZXF1ZXN0SW5mby51c2VyQWdlbnQpLnByZXR0eVVzZXJBZ2VudCxcbiAgICAgICAgICAgIHJlcXVlc3Q6ICAge1xuICAgICAgICAgICAgICAgIHRpbWVzdGFtcDogRGF0ZS5ub3coKSxcbiAgICAgICAgICAgICAgICB1cmw6ICAgICAgIGV2ZW50Ll9yZXF1ZXN0SW5mby51cmwsXG4gICAgICAgICAgICAgICAgbWV0aG9kOiAgICBldmVudC5fcmVxdWVzdEluZm8ubWV0aG9kLFxuICAgICAgICAgICAgfSxcbiAgICAgICAgfTtcblxuICAgICAgICBpZiAodGhpcy5fb3B0aW9ucy5sb2dSZXF1ZXN0SGVhZGVycylcbiAgICAgICAgICAgIGxvZ2dlZFJlcS5yZXF1ZXN0LmhlYWRlcnMgPSBPYmplY3QuYXNzaWduKHt9LCBldmVudC5fcmVxdWVzdEluZm8uaGVhZGVycyk7XG5cbiAgICAgICAgaWYgKHRoaXMuX29wdGlvbnMubG9nUmVxdWVzdEJvZHkpXG4gICAgICAgICAgICBsb2dnZWRSZXEucmVxdWVzdC5ib2R5ID0gdGhpcy5fb3B0aW9ucy5zdHJpbmdpZnlSZXF1ZXN0Qm9keSA/IGV2ZW50Ll9yZXF1ZXN0SW5mby5ib2R5LnRvU3RyaW5nKCkgOiBldmVudC5fcmVxdWVzdEluZm8uYm9keTtcblxuICAgICAgICB0aGlzLl9pbnRlcm5hbFJlcXVlc3RzW2xvZ2dlZFJlcS5pZF0gPSBsb2dnZWRSZXE7XG4gICAgfVxuXG4gICAgcHVibGljIGFzeW5jIG9uUmVzcG9uc2UgKGV2ZW50OiBSZXNwb25zZUV2ZW50KTogUHJvbWlzZTx2b2lkPiB7XG4gICAgICAgIGNvbnN0IGxvZ2dlZFJlcSA9IHRoaXMuX2ludGVybmFsUmVxdWVzdHNbZXZlbnQucmVxdWVzdElkXTtcblxuICAgICAgICAvLyBOT1RFOiBJZiB0aGUgJ2NsZWFyJyBtZXRob2QgaXMgY2FsbGVkIGR1cmluZyBhIGxvbmcgcnVubmluZyByZXF1ZXN0LFxuICAgICAgICAvLyB3ZSBzaG91bGQgbm90IHNhdmUgYSByZXNwb25zZSBwYXJ0IC0gcmVxdWVzdCBwYXJ0IGhhcyBiZWVuIGFscmVhZHkgcmVtb3ZlZC5cbiAgICAgICAgaWYgKCFsb2dnZWRSZXEpXG4gICAgICAgICAgICByZXR1cm47XG5cbiAgICAgICAgbG9nZ2VkUmVxLnJlc3BvbnNlID0ge1xuICAgICAgICAgICAgc3RhdHVzQ29kZTogZXZlbnQuc3RhdHVzQ29kZSxcbiAgICAgICAgICAgIHRpbWVzdGFtcDogIERhdGUubm93KCksXG4gICAgICAgIH07XG5cbiAgICAgICAgaWYgKHRoaXMuX29wdGlvbnMubG9nUmVzcG9uc2VIZWFkZXJzKVxuICAgICAgICAgICAgbG9nZ2VkUmVxLnJlc3BvbnNlLmhlYWRlcnMgPSBPYmplY3QuYXNzaWduKHt9LCBldmVudC5oZWFkZXJzKTtcblxuICAgICAgICBpZiAodGhpcy5fb3B0aW9ucy5sb2dSZXNwb25zZUJvZHkpIHtcbiAgICAgICAgICAgIGxvZ2dlZFJlcS5yZXNwb25zZS5ib2R5ID0gdGhpcy5fb3B0aW9ucy5zdHJpbmdpZnlSZXNwb25zZUJvZHkgJiYgZXZlbnQuYm9keVxuICAgICAgICAgICAgICAgID8gZXZlbnQuYm9keS50b1N0cmluZygpXG4gICAgICAgICAgICAgICAgOiBldmVudC5ib2R5O1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgcHJpdmF0ZSBfcHJlcGFyZUludGVybmFsUmVxdWVzdEluZm8gKCk6IExvZ2dlZFJlcXVlc3RbXSB7XG4gICAgICAgIGNvbnN0IHRlc3RSdW4gICAgICAgID0gdGVzdFJ1blRyYWNrZXIucmVzb2x2ZUNvbnRleHRUZXN0UnVuKCk7XG4gICAgICAgIGxldCBwcmVwYXJlZFJlcXVlc3RzID0gT2JqZWN0LnZhbHVlcyh0aGlzLl9pbnRlcm5hbFJlcXVlc3RzKTtcblxuICAgICAgICBpZiAodGVzdFJ1bilcbiAgICAgICAgICAgIHByZXBhcmVkUmVxdWVzdHMgPSBwcmVwYXJlZFJlcXVlc3RzLmZpbHRlcihyID0+IHIudGVzdFJ1bklkID09PSB0ZXN0UnVuLmlkKTtcblxuICAgICAgICByZXR1cm4gcHJlcGFyZWRSZXF1ZXN0cztcbiAgICB9XG5cbiAgICBwcml2YXRlIF9nZXRDb21wbGV0ZWRSZXF1ZXN0cyAoKTogTG9nZ2VkUmVxdWVzdFtdIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuX3ByZXBhcmVJbnRlcm5hbFJlcXVlc3RJbmZvKCkuZmlsdGVyKHIgPT4gci5yZXNwb25zZSk7XG4gICAgfVxuXG4gICAgLy8gQVBJXG4gICAgcHVibGljIGNvbnRhaW5zIChwcmVkaWNhdGU6IChyZXF1ZXN0OiBMb2dnZWRSZXF1ZXN0KSA9PiBib29sZWFuKTogUmVFeGVjdXRhYmxlUHJvbWlzZSB7XG4gICAgICAgIHJldHVybiBSZUV4ZWN1dGFibGVQcm9taXNlLmZyb21Gbihhc3luYyAoKSA9PiB7XG4gICAgICAgICAgICByZXR1cm4gISF0aGlzLl9nZXRDb21wbGV0ZWRSZXF1ZXN0cygpLmZpbmQocHJlZGljYXRlKTtcbiAgICAgICAgfSk7XG4gICAgfVxuXG4gICAgcHVibGljIGNvdW50IChwcmVkaWNhdGU6IChyZXF1ZXN0OiBMb2dnZWRSZXF1ZXN0KSA9PiBib29sZWFuKTogUmVFeGVjdXRhYmxlUHJvbWlzZSB7XG4gICAgICAgIHJldHVybiBSZUV4ZWN1dGFibGVQcm9taXNlLmZyb21Gbihhc3luYyAoKSA9PiB7XG4gICAgICAgICAgICByZXR1cm4gdGhpcy5fZ2V0Q29tcGxldGVkUmVxdWVzdHMoKS5maWx0ZXIocHJlZGljYXRlKS5sZW5ndGg7XG4gICAgICAgIH0pO1xuICAgIH1cblxuICAgIHB1YmxpYyBjbGVhciAoKTogdm9pZCB7XG4gICAgICAgIGNvbnN0IHRlc3RSdW4gPSB0ZXN0UnVuVHJhY2tlci5yZXNvbHZlQ29udGV4dFRlc3RSdW4oKTtcblxuICAgICAgICBpZiAodGVzdFJ1bikge1xuICAgICAgICAgICAgT2JqZWN0LmtleXModGhpcy5faW50ZXJuYWxSZXF1ZXN0cykuZm9yRWFjaChpZCA9PiB7XG4gICAgICAgICAgICAgICAgaWYgKHRoaXMuX2ludGVybmFsUmVxdWVzdHNbaWRdLnRlc3RSdW5JZCA9PT0gdGVzdFJ1bi5pZClcbiAgICAgICAgICAgICAgICAgICAgZGVsZXRlIHRoaXMuX2ludGVybmFsUmVxdWVzdHNbaWRdO1xuICAgICAgICAgICAgfSk7XG4gICAgICAgIH1cbiAgICAgICAgZWxzZVxuICAgICAgICAgICAgdGhpcy5faW50ZXJuYWxSZXF1ZXN0cyA9IHt9O1xuICAgIH1cblxuICAgIHB1YmxpYyBnZXQgcmVxdWVzdHMgKCk6IExvZ2dlZFJlcXVlc3RbXSB7XG4gICAgICAgIHJldHVybiB0aGlzLl9wcmVwYXJlSW50ZXJuYWxSZXF1ZXN0SW5mbygpO1xuICAgIH1cbn1cblxuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gY3JlYXRlUmVxdWVzdExvZ2dlciAocmVxdWVzdEZpbHRlclJ1bGVJbml0OiBSZXF1ZXN0RmlsdGVyUnVsZUluaXQgfCBSZXF1ZXN0RmlsdGVyUnVsZUluaXRbXSB8IHVuZGVmaW5lZCwgbG9nT3B0aW9uczogUmVxdWVzdEhvb2tMb2dPcHRpb25zSW5pdCk6IFJlcXVlc3RMb2dnZXJJbXBsZW1lbnRhdGlvbiB7XG4gICAgcmV0dXJuIG5ldyBSZXF1ZXN0TG9nZ2VySW1wbGVtZW50YXRpb24ocmVxdWVzdEZpbHRlclJ1bGVJbml0LCBsb2dPcHRpb25zKTtcbn1cbiJdfQ==
@@ -1,12 +1,12 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- const index_1 = __importDefault(require("./index"));
7
- function createRequestMock() {
8
- return new index_1.default();
9
- }
10
- exports.default = createRequestMock;
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const index_1 = __importDefault(require("./index"));
7
+ function createRequestMock() {
8
+ return new index_1.default();
9
+ }
10
+ exports.default = createRequestMock;
11
11
  module.exports = exports.default;
12
12
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3JlYXRlLXJlcXVlc3QtbW9jay5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9hcGkvcmVxdWVzdC1ob29rcy9yZXF1ZXN0LW1vY2svY3JlYXRlLXJlcXVlc3QtbW9jay50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLG9EQUFrQztBQUVsQyxTQUF3QixpQkFBaUI7SUFDckMsT0FBTyxJQUFJLGVBQVcsRUFBRSxDQUFDO0FBQzdCLENBQUM7QUFGRCxvQ0FFQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZXF1ZXN0TW9jayBmcm9tICcuL2luZGV4JztcblxuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gY3JlYXRlUmVxdWVzdE1vY2sgKCk6IFJlcXVlc3RNb2NrIHtcbiAgICByZXR1cm4gbmV3IFJlcXVlc3RNb2NrKCk7XG59XG4iXX0=