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.
- package/CHANGELOG.md +88 -10
- package/LICENSE +21 -21
- package/README.md +52 -48
- package/bin/testcafe-with-v8-flag-filter.js +0 -0
- package/lib/api/exportable-lib/index.js +50 -50
- package/lib/api/request-hooks/assert-type.js +7 -7
- package/lib/api/request-hooks/hook-method-names.js +11 -0
- package/lib/api/request-hooks/hook.js +33 -39
- package/lib/api/request-hooks/interfaces.js +3 -3
- package/lib/api/request-hooks/request-logger.js +113 -111
- package/lib/api/request-hooks/request-mock/create-request-mock.js +12 -0
- package/lib/api/request-hooks/request-mock/index.js +46 -0
- package/lib/api/request-hooks/request-mock.js +47 -48
- package/lib/api/structure/base-unit.js +11 -11
- package/lib/api/structure/fixture.js +75 -75
- package/lib/api/structure/interfaces.js +2 -2
- package/lib/api/structure/test-file.js +31 -31
- package/lib/api/structure/test-timeout.js +9 -9
- package/lib/api/structure/test.js +85 -85
- package/lib/api/structure/testing-unit.js +89 -89
- package/lib/api/structure/unit-type.js +9 -9
- package/lib/api/test-controller/assertion.js +88 -88
- package/lib/api/test-controller/execution-context.js +82 -82
- package/lib/api/test-controller/index.js +359 -319
- package/lib/api/test-controller/proxy.js +28 -28
- package/lib/api/test-page-url.js +60 -60
- package/lib/api/test-run-tracker.js +68 -68
- package/lib/api/wrap-test-function.js +49 -49
- package/lib/assertions/executor.js +74 -74
- package/lib/assertions/get-fn.js +46 -46
- package/lib/assertions/type.js +20 -20
- package/lib/assets/content-types.js +9 -9
- package/lib/assets/injectables.js +18 -18
- package/lib/browser/connection/command.js +10 -10
- package/lib/browser/connection/error-hints.js +9 -9
- package/lib/browser/connection/gateway.js +159 -159
- package/lib/browser/connection/get-hints.js +33 -33
- package/lib/browser/connection/heartbeat-status.js +8 -8
- package/lib/browser/connection/index.js +328 -328
- package/lib/browser/connection/remotes-queue.js +46 -46
- package/lib/browser/connection/service-routes.js +12 -12
- package/lib/browser/connection/status.js +12 -12
- package/lib/browser/interfaces.js +2 -2
- package/lib/browser/provider/built-in/dedicated/base.js +80 -80
- package/lib/browser/provider/built-in/dedicated/chrome/browser-client.js +204 -204
- package/lib/browser/provider/built-in/dedicated/chrome/build-chrome-args.js +17 -17
- package/lib/browser/provider/built-in/dedicated/chrome/config.js +110 -110
- package/lib/browser/provider/built-in/dedicated/chrome/create-temp-profile.js +45 -45
- package/lib/browser/provider/built-in/dedicated/chrome/elapsed-upperbounds.js +15 -15
- package/lib/browser/provider/built-in/dedicated/chrome/index.js +102 -102
- package/lib/browser/provider/built-in/dedicated/chrome/interfaces.js +2 -2
- package/lib/browser/provider/built-in/dedicated/chrome/local-chrome.js +24 -24
- package/lib/browser/provider/built-in/dedicated/chrome/runtime-info.js +29 -29
- package/lib/browser/provider/built-in/dedicated/edge/index.js +10 -10
- package/lib/browser/provider/built-in/dedicated/edge/runtime-info.js +29 -29
- package/lib/browser/provider/built-in/dedicated/firefox/config.js +33 -33
- package/lib/browser/provider/built-in/dedicated/firefox/create-temp-profile.js +78 -78
- package/lib/browser/provider/built-in/dedicated/firefox/index.js +73 -73
- package/lib/browser/provider/built-in/dedicated/firefox/local-firefox.js +36 -36
- package/lib/browser/provider/built-in/dedicated/firefox/marionette-client/commands.js +13 -13
- package/lib/browser/provider/built-in/dedicated/firefox/marionette-client/index.js +200 -200
- package/lib/browser/provider/built-in/dedicated/firefox/runtime-info.js +17 -17
- package/lib/browser/provider/built-in/index.js +21 -21
- package/lib/browser/provider/built-in/locally-installed.js +30 -30
- package/lib/browser/provider/built-in/path.js +47 -47
- package/lib/browser/provider/built-in/remote.js +58 -58
- package/lib/browser/provider/index.js +303 -303
- package/lib/browser/provider/parse-provider-name.js +16 -16
- package/lib/browser/provider/plugin-host.js +121 -121
- package/lib/browser/provider/pool.js +115 -115
- package/lib/browser/provider/utils/argument-parsing.js +74 -74
- package/lib/browser/provider/utils/browser-starter.js +34 -34
- package/lib/browser/provider/utils/client-functions.js +24 -24
- package/lib/browser/provider/utils/get-maximized-headless-window-size.js +9 -9
- package/lib/cli/argument-parser.js +284 -279
- package/lib/cli/authentication-helper.js +35 -35
- package/lib/cli/cli.js +134 -134
- package/lib/cli/correct-browsers-and-sources.js +40 -40
- package/lib/cli/index.js +19 -19
- package/lib/cli/log.js +43 -43
- package/lib/cli/remotes-wizard.js +36 -36
- package/lib/cli/termination-handler.js +38 -38
- package/lib/client/automation/index.js +144 -46
- package/lib/client/automation/index.min.js +1 -1
- package/lib/client/browser/idle-page/index.html.mustache +35 -35
- package/lib/client/browser/idle-page/logo.svg +86 -86
- package/lib/client/browser/service-worker.js +4 -6
- package/lib/client/core/index.js +19 -13
- package/lib/client/core/index.min.js +1 -1
- package/lib/client/driver/index.js +1807 -451
- package/lib/client/driver/index.min.js +1 -1
- package/lib/client/driver/internal-properties.js +9 -9
- package/lib/client/test-run/iframe.js.mustache +17 -17
- package/lib/client/test-run/index.js.mustache +51 -51
- package/lib/client/ui/index.js +14 -12
- package/lib/client/ui/index.min.js +1 -1
- package/lib/client/ui/sprite.svg +42 -42
- package/lib/client-functions/builder-symbol.js +4 -4
- package/lib/client-functions/client-function-builder.js +156 -135
- package/lib/client-functions/replicator.js +61 -61
- package/lib/client-functions/return-single-prop-mode.js +8 -8
- package/lib/client-functions/selector-api-execution-mode.js +22 -0
- package/lib/client-functions/selectors/add-api.js +646 -588
- package/lib/client-functions/selectors/create-snapshot-methods.js +13 -13
- package/lib/client-functions/selectors/prepare-api-args.js +20 -20
- package/lib/client-functions/selectors/selector-attribute-filter.js +22 -22
- package/lib/client-functions/selectors/selector-builder.js +154 -150
- package/lib/client-functions/selectors/selector-text-filter.js +43 -43
- package/lib/client-functions/selectors/snapshot-properties.js +48 -48
- package/lib/client-functions/types.js +18 -18
- package/lib/compiler/babel/format-babel-produced-code.js +10 -10
- package/lib/compiler/babel/get-base-babel-options.js +11 -11
- package/lib/compiler/babel/load-libs.js +64 -62
- package/lib/compiler/babel/preset-stage-2.js +19 -19
- package/lib/compiler/compile-client-function.js +73 -73
- package/lib/compiler/compilers.js +33 -33
- package/lib/compiler/index.js +92 -92
- package/lib/compiler/interfaces.js +2 -2
- package/lib/compiler/test-file/api-based.js +146 -146
- package/lib/compiler/test-file/base.js +36 -36
- package/lib/compiler/test-file/exportble-lib-path.js +5 -5
- package/lib/compiler/test-file/formats/coffeescript/compiler.js +38 -38
- package/lib/compiler/test-file/formats/coffeescript/get-test-list.js +29 -29
- package/lib/compiler/test-file/formats/es-next/compiler.js +43 -43
- package/lib/compiler/test-file/formats/es-next/get-test-list.js +166 -166
- package/lib/compiler/test-file/formats/es-next/is-flow-code.js +7 -7
- package/lib/compiler/test-file/formats/raw.js +85 -85
- package/lib/compiler/test-file/formats/typescript/compiler.js +135 -135
- package/lib/compiler/test-file/formats/typescript/get-test-list.js +185 -185
- package/lib/compiler/test-file/test-file-parser-base.js +214 -214
- package/lib/configuration/configuration-base.js +165 -165
- package/lib/configuration/constants.js +9 -9
- package/lib/configuration/customizable-compilers.js +7 -7
- package/lib/configuration/default-values.js +51 -51
- package/lib/configuration/interfaces.js +3 -3
- package/lib/configuration/option-names.js +53 -53
- package/lib/configuration/option-source.js +9 -9
- package/lib/configuration/option.js +14 -14
- package/lib/configuration/quarantine-option-names.js +10 -0
- package/lib/configuration/run-option-names.js +26 -26
- package/lib/configuration/screenshot-option-names.js +10 -10
- package/lib/configuration/testcafe-configuration.js +164 -165
- package/lib/configuration/types.js +2 -2
- package/lib/configuration/typescript-configuration.js +62 -62
- package/lib/custom-client-scripts/assert-type.js +7 -7
- package/lib/custom-client-scripts/client-script-init.js +3 -3
- package/lib/custom-client-scripts/client-script.js +107 -108
- package/lib/custom-client-scripts/get-code.js +11 -11
- package/lib/custom-client-scripts/get-url.js +6 -6
- package/lib/custom-client-scripts/load.js +15 -15
- package/lib/custom-client-scripts/problematic-scripts.js +2 -2
- package/lib/custom-client-scripts/routing.js +36 -36
- package/lib/custom-client-scripts/utils.js +60 -60
- package/lib/embedding-utils.js +83 -83
- package/lib/errors/create-stack-filter.js +18 -18
- package/lib/errors/error-list.js +26 -26
- package/lib/errors/get-callsite.js +31 -31
- package/lib/errors/internal-modules-prefix.js +8 -8
- package/lib/errors/is-internal-stack-frame.js +46 -46
- package/lib/errors/process-test-fn-error.js +37 -37
- package/lib/errors/runtime/index.js +123 -123
- package/lib/errors/runtime/templates.js +116 -114
- package/lib/errors/runtime/type-assertions.js +112 -112
- package/lib/errors/stack-cleaning-hook.js +64 -64
- package/lib/errors/test-run/formattable-adapter.js +59 -59
- package/lib/errors/test-run/index.js +302 -302
- package/lib/errors/test-run/render-error-template.js +31 -31
- package/lib/errors/test-run/templates.js +93 -95
- package/lib/errors/test-run/utils.js +90 -85
- package/lib/errors/types.js +157 -155
- package/lib/index.js +81 -81
- package/lib/live/bootstrapper.js +44 -44
- package/lib/live/controller.js +107 -107
- package/lib/live/file-watcher/index.js +67 -67
- package/lib/live/file-watcher/modules-graph.js +58 -58
- package/lib/live/keyboard-observer.js +76 -76
- package/lib/live/logger/index.js +64 -64
- package/lib/live/test-run-controller.js +96 -96
- package/lib/live/test-run-state.js +6 -6
- package/lib/live/test-run.js +56 -56
- package/lib/live/test-runner.js +168 -168
- package/lib/load-assets.js +29 -29
- package/lib/notifications/add-rendered-warning.js +16 -16
- package/lib/notifications/debug-logger.js +78 -78
- package/lib/notifications/deprecated.js +24 -24
- package/lib/notifications/information-message.js +12 -12
- package/lib/notifications/warning-log.js +32 -31
- package/lib/notifications/warning-message.js +48 -48
- package/lib/reporter/command/command-formatter.js +120 -109
- package/lib/reporter/command/format-command.js +8 -8
- package/lib/reporter/command/interfaces.js +2 -2
- package/lib/reporter/index.js +319 -314
- package/lib/reporter/interfaces.js +2 -2
- package/lib/reporter/plugin-host.js +136 -137
- package/lib/reporter/plugin-methods.js +12 -12
- package/lib/role/index.js +74 -74
- package/lib/role/marker-symbol.js +7 -7
- package/lib/role/phase.js +9 -9
- package/lib/runner/bootstrapper.js +272 -272
- package/lib/runner/browser-job-result.js +9 -9
- package/lib/runner/browser-job.js +153 -123
- package/lib/runner/browser-set.js +114 -114
- package/lib/runner/fixture-hook-controller.js +85 -85
- package/lib/runner/index.js +450 -442
- package/lib/runner/interfaces.js +3 -3
- package/lib/runner/reporter-stream-controller.js +28 -28
- package/lib/runner/task/index.js +152 -133
- package/lib/runner/task/phase.js +9 -9
- package/lib/runner/test-run-controller.js +166 -185
- package/lib/runner/tested-app.js +73 -72
- package/lib/screenshots/capturer.js +141 -141
- package/lib/screenshots/constants.js +11 -11
- package/lib/screenshots/crop.js +111 -111
- package/lib/screenshots/default-extension.js +4 -4
- package/lib/screenshots/index.js +67 -67
- package/lib/screenshots/utils.js +39 -39
- package/lib/services/compiler/host.js +190 -106
- package/lib/services/compiler/io.js +9 -9
- package/lib/services/compiler/protocol.js +17 -16
- package/lib/services/compiler/service.js +225 -106
- package/lib/services/compiler/test-run-proxy.js +111 -73
- package/lib/services/interfaces.js +3 -0
- package/lib/services/process-title.js +8 -8
- package/lib/services/serialization/prepare-options.js +17 -17
- package/lib/services/serialization/replicator/create-replicator.js +27 -0
- package/lib/services/serialization/replicator/custom-error-transform.js +28 -0
- package/lib/services/serialization/test-structure.js +93 -77
- package/lib/services/utils/ipc/interfaces.js +30 -30
- package/lib/services/utils/ipc/io.js +108 -108
- package/lib/services/utils/ipc/message.js +76 -73
- package/lib/services/utils/ipc/packet.js +55 -55
- package/lib/services/utils/ipc/proxy.js +110 -118
- package/lib/services/utils/ipc/transport.js +64 -64
- package/lib/shared/errors/index.js +382 -382
- package/lib/shared/node-modules-folder-name.js +4 -4
- package/lib/test-run/bookmark.js +90 -90
- package/lib/test-run/browser-console-messages.js +73 -73
- package/lib/test-run/browser-manipulation-queue.js +92 -92
- package/lib/test-run/client-messages.js +9 -9
- package/lib/test-run/commands/actions.js +486 -425
- package/lib/test-run/commands/assertion.js +45 -45
- package/lib/test-run/commands/base.js +14 -14
- package/lib/test-run/commands/browser-manipulation.js +95 -95
- package/lib/test-run/commands/from-object.js +82 -82
- package/lib/test-run/commands/observation.js +61 -61
- package/lib/test-run/commands/options.js +231 -215
- package/lib/test-run/commands/service.js +54 -48
- package/lib/test-run/commands/type.js +65 -60
- package/lib/test-run/commands/utils.js +87 -87
- package/lib/test-run/commands/validations/argument.js +90 -90
- package/lib/test-run/commands/validations/factories.js +47 -47
- package/lib/test-run/commands/validations/initializers.js +44 -44
- package/lib/test-run/debug-log.js +32 -32
- package/lib/test-run/execute-js-expression.js +74 -74
- package/lib/test-run/index.js +823 -752
- package/lib/test-run/marker-symbol.js +7 -7
- package/lib/test-run/observed-callsites-storage.js +17 -17
- package/lib/test-run/phase.js +16 -16
- package/lib/test-run/session-controller.js +104 -104
- package/lib/testcafe.js +119 -114
- package/lib/utils/assignable.js +39 -39
- package/lib/utils/async-event-emitter.js +28 -28
- package/lib/utils/async-queue.js +14 -14
- package/lib/utils/browser-connection-timeouts.js +19 -19
- package/lib/utils/callsite.js +17 -17
- package/lib/utils/check-file-path.js +31 -31
- package/lib/utils/check-url.js +51 -51
- package/lib/utils/convert-to-best-fit-type.js +16 -16
- package/lib/utils/correct-file-path.js +21 -21
- package/lib/utils/define-lazy-property.js +13 -13
- package/lib/utils/delay.js +6 -6
- package/lib/utils/delegated-api.js +44 -44
- package/lib/utils/detect-display.js +6 -6
- package/lib/utils/detect-ffmpeg.js +44 -44
- package/lib/utils/diff/colors.js +29 -29
- package/lib/utils/diff/index.js +53 -53
- package/lib/utils/diff/util.js +24 -22
- package/lib/utils/diff.js +29 -29
- package/lib/utils/escape-user-agent.js +10 -10
- package/lib/utils/flag-list.js +17 -17
- package/lib/utils/get-any-key.js +8 -8
- package/lib/utils/get-browser.js +8 -8
- package/lib/utils/get-common-path.js +34 -34
- package/lib/utils/get-filter-fn.js +40 -40
- package/lib/utils/get-options/base.js +36 -36
- package/lib/utils/get-options/compiler.js +33 -33
- package/lib/utils/get-options/grep.js +15 -15
- package/lib/utils/get-options/index.js +21 -19
- package/lib/utils/get-options/meta.js +22 -22
- package/lib/utils/get-options/quarantine.js +92 -0
- package/lib/utils/get-options/screenshot.js +17 -17
- package/lib/utils/get-options/ssl.js +45 -45
- package/lib/utils/get-options/video.js +10 -10
- package/lib/utils/get-viewport-width.js +18 -18
- package/lib/utils/guard-time-execution.js +10 -10
- package/lib/utils/handle-errors.js +74 -74
- package/lib/utils/handle-tag-args.js +8 -8
- package/lib/utils/http.js +30 -30
- package/lib/utils/is-localhost.js +11 -11
- package/lib/utils/is-password-input.js +11 -0
- package/lib/utils/is-repl.js +12 -0
- package/lib/utils/is-window-in-iframe.js +6 -6
- package/lib/utils/limit-number.js +10 -10
- package/lib/utils/make-reg-exp.js +7 -7
- package/lib/utils/moment-loader.js +20 -20
- package/lib/utils/parse-file-list.js +71 -71
- package/lib/utils/parse-user-agent.js +55 -55
- package/lib/utils/path-pattern.js +114 -114
- package/lib/utils/prepare-reporters.js +30 -30
- package/lib/utils/prerender-callsite.js +18 -18
- package/lib/utils/process.js +119 -119
- package/lib/utils/promisified-functions.js +46 -46
- package/lib/utils/re-executable-promise.js +39 -39
- package/lib/utils/render-callsite-sync.js +29 -29
- package/lib/utils/render-template.js +10 -10
- package/lib/utils/reporter.js +30 -30
- package/lib/utils/resolve-path-relatively-cwd.js +7 -7
- package/lib/utils/string.js +105 -105
- package/lib/utils/temp-directory/cleanup-process/commands.js +7 -7
- package/lib/utils/temp-directory/cleanup-process/index.js +143 -143
- package/lib/utils/temp-directory/cleanup-process/worker.js +58 -58
- package/lib/utils/temp-directory/index.js +87 -87
- package/lib/utils/temp-directory/lockfile.js +56 -56
- package/lib/utils/thennable.js +7 -7
- package/lib/utils/timer.js +15 -15
- package/lib/utils/to-posix-path.js +8 -8
- package/lib/utils/types.js +2 -2
- package/lib/video-recorder/interfaces.js +2 -2
- package/lib/video-recorder/process.js +126 -126
- package/lib/video-recorder/recorder.js +136 -136
- package/lib/video-recorder/test-run-video-recorder.js +69 -69
- package/lib/video-recorder/videos.js +37 -37
- package/package.json +7 -7
- package/ts-defs/index.d.ts +109 -17
- package/ts-defs/selectors.d.ts +95 -7
- package/ts-defs/testcafe-scripts.d.ts +96 -8
|
@@ -1,107 +1,191 @@
|
|
|
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 child_process_1 = require("child_process");
|
|
7
|
-
const io_1 = require("./io");
|
|
8
|
-
const test_structure_1 = require("../serialization/test-structure");
|
|
9
|
-
const prepare_options_1 = __importDefault(require("../serialization/prepare-options"));
|
|
10
|
-
const test_run_tracker_1 = __importDefault(require("../../api/test-run-tracker"));
|
|
11
|
-
const proxy_1 = require("../utils/ipc/proxy");
|
|
12
|
-
const transport_1 = require("../utils/ipc/transport");
|
|
13
|
-
const async_event_emitter_1 = __importDefault(require("../../utils/async-event-emitter"));
|
|
14
|
-
const error_list_1 = __importDefault(require("../../errors/error-list"));
|
|
15
|
-
const
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
this.
|
|
25
|
-
this.
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
this.
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
}
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
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 child_process_1 = require("child_process");
|
|
7
|
+
const io_1 = require("./io");
|
|
8
|
+
const test_structure_1 = require("../serialization/test-structure");
|
|
9
|
+
const prepare_options_1 = __importDefault(require("../serialization/prepare-options"));
|
|
10
|
+
const test_run_tracker_1 = __importDefault(require("../../api/test-run-tracker"));
|
|
11
|
+
const proxy_1 = require("../utils/ipc/proxy");
|
|
12
|
+
const transport_1 = require("../utils/ipc/transport");
|
|
13
|
+
const async_event_emitter_1 = __importDefault(require("../../utils/async-event-emitter"));
|
|
14
|
+
const error_list_1 = __importDefault(require("../../errors/error-list"));
|
|
15
|
+
const testcafe_hammerhead_1 = require("testcafe-hammerhead");
|
|
16
|
+
const SERVICE_PATH = require.resolve('./service');
|
|
17
|
+
class CompilerHost extends async_event_emitter_1.default {
|
|
18
|
+
constructor() {
|
|
19
|
+
super();
|
|
20
|
+
this.runtime = Promise.resolve(void 0);
|
|
21
|
+
}
|
|
22
|
+
_setupRoutes(proxy) {
|
|
23
|
+
proxy.register([
|
|
24
|
+
this.executeAction,
|
|
25
|
+
this.executeCommand,
|
|
26
|
+
this.ready,
|
|
27
|
+
this.onRequestHookEvent,
|
|
28
|
+
this.setMock,
|
|
29
|
+
this.setConfigureResponseEventOptions,
|
|
30
|
+
this.setHeaderOnConfigureResponseEvent,
|
|
31
|
+
this.removeHeaderOnConfigureResponseEvent,
|
|
32
|
+
this.executeRequestFilterRulePredicate,
|
|
33
|
+
this.executeMockPredicate,
|
|
34
|
+
this.getWarningMessages,
|
|
35
|
+
this.addRequestEventListeners,
|
|
36
|
+
this.removeRequestEventListeners,
|
|
37
|
+
this.initializeTestRunData
|
|
38
|
+
], this);
|
|
39
|
+
}
|
|
40
|
+
async _init(runtime) {
|
|
41
|
+
const resolvedRuntime = await runtime;
|
|
42
|
+
if (resolvedRuntime)
|
|
43
|
+
return resolvedRuntime;
|
|
44
|
+
try {
|
|
45
|
+
const service = child_process_1.spawn(process.argv0, [SERVICE_PATH], { stdio: [0, 1, 2, 'pipe', 'pipe', 'pipe'] });
|
|
46
|
+
// HACK: Node.js definition are not correct when additional I/O channels are sp
|
|
47
|
+
const stdio = service.stdio;
|
|
48
|
+
const proxy = new proxy_1.IPCProxy(new transport_1.HostTransport(stdio[io_1.HOST_INPUT_FD], stdio[io_1.HOST_OUTPUT_FD], stdio[io_1.HOST_SYNC_FD]));
|
|
49
|
+
this._setupRoutes(proxy);
|
|
50
|
+
await this.once('ready');
|
|
51
|
+
return { proxy, service };
|
|
52
|
+
}
|
|
53
|
+
catch (e) {
|
|
54
|
+
return void 0;
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
async _getRuntime() {
|
|
58
|
+
const runtime = await this.runtime;
|
|
59
|
+
if (!runtime)
|
|
60
|
+
throw new Error('Runtime is not available.');
|
|
61
|
+
return runtime;
|
|
62
|
+
}
|
|
63
|
+
_prepareEventData(eventData) {
|
|
64
|
+
// TODO: Remove eventData._requestContext into 'testcafe-hammerhead' module
|
|
65
|
+
// after switching to the compiler service mode.
|
|
66
|
+
// NOTE: Access to the deprecated property inside of the unserializable 'eventData._requestContext' property
|
|
67
|
+
// causes the node's deprecation warning.
|
|
68
|
+
const clonedEventData = Object.assign({}, eventData);
|
|
69
|
+
// @ts-ignore
|
|
70
|
+
delete clonedEventData._requestContext;
|
|
71
|
+
return clonedEventData;
|
|
72
|
+
}
|
|
73
|
+
async init() {
|
|
74
|
+
this.runtime = this._init(this.runtime);
|
|
75
|
+
await this.runtime;
|
|
76
|
+
}
|
|
77
|
+
async stop() {
|
|
78
|
+
const { service } = await this._getRuntime();
|
|
79
|
+
service.kill();
|
|
80
|
+
}
|
|
81
|
+
_wrapTestFunction(id, functionName) {
|
|
82
|
+
return async (testRun) => {
|
|
83
|
+
try {
|
|
84
|
+
return await this.runTestFn({ id, functionName, testRunId: testRun.id });
|
|
85
|
+
}
|
|
86
|
+
catch (err) {
|
|
87
|
+
const errList = new error_list_1.default();
|
|
88
|
+
errList.addError(err);
|
|
89
|
+
throw errList;
|
|
90
|
+
}
|
|
91
|
+
};
|
|
92
|
+
}
|
|
93
|
+
_wrapRequestFilterRulePredicate({ testId, hookId, ruleId }) {
|
|
94
|
+
return async (requestInfo) => {
|
|
95
|
+
return await this.executeRequestFilterRulePredicate({ testId, hookId, ruleId, requestInfo });
|
|
96
|
+
};
|
|
97
|
+
}
|
|
98
|
+
_wrapMockPredicate({ mock, testId, hookId, ruleId }) {
|
|
99
|
+
mock.body = async (requestInfo, res) => {
|
|
100
|
+
return await this.executeMockPredicate({ testId, hookId, ruleId, requestInfo, res });
|
|
101
|
+
};
|
|
102
|
+
}
|
|
103
|
+
async ready() {
|
|
104
|
+
this.emit('ready');
|
|
105
|
+
}
|
|
106
|
+
async executeAction(data) {
|
|
107
|
+
const targetTestRun = test_run_tracker_1.default.activeTestRuns[data.id];
|
|
108
|
+
if (!targetTestRun)
|
|
109
|
+
return void 0;
|
|
110
|
+
return targetTestRun.executeAction(data.apiMethodName, data.command, data.callsite);
|
|
111
|
+
}
|
|
112
|
+
executeActionSync() {
|
|
113
|
+
throw new Error('The method should not be called.');
|
|
114
|
+
}
|
|
115
|
+
async executeCommand({ command, id }) {
|
|
116
|
+
const targetTestRun = test_run_tracker_1.default.activeTestRuns[id];
|
|
117
|
+
if (!targetTestRun)
|
|
118
|
+
return void 0;
|
|
119
|
+
return targetTestRun.executeCommand(command);
|
|
120
|
+
}
|
|
121
|
+
async getTests({ sourceList, compilerOptions }) {
|
|
122
|
+
const { proxy } = await this._getRuntime();
|
|
123
|
+
const units = await proxy.call(this.getTests, { sourceList, compilerOptions });
|
|
124
|
+
return test_structure_1.restore(units, (...args) => this._wrapTestFunction(...args), (ruleLocator) => this._wrapRequestFilterRulePredicate(ruleLocator));
|
|
125
|
+
}
|
|
126
|
+
async runTestFn({ id, functionName, testRunId }) {
|
|
127
|
+
const { proxy } = await this._getRuntime();
|
|
128
|
+
return await proxy.call(this.runTestFn, { id, functionName, testRunId });
|
|
129
|
+
}
|
|
130
|
+
async cleanUp() {
|
|
131
|
+
const { proxy } = await this._getRuntime();
|
|
132
|
+
await proxy.call(this.cleanUp);
|
|
133
|
+
}
|
|
134
|
+
async setOptions({ value }) {
|
|
135
|
+
const { proxy } = await this._getRuntime();
|
|
136
|
+
const preparedOptions = prepare_options_1.default(value);
|
|
137
|
+
await proxy.call(this.setOptions, { value: preparedOptions });
|
|
138
|
+
}
|
|
139
|
+
async onRequestHookEvent({ name, testId, hookId, eventData }) {
|
|
140
|
+
const { proxy } = await this._getRuntime();
|
|
141
|
+
await proxy.call(this.onRequestHookEvent, {
|
|
142
|
+
name,
|
|
143
|
+
testId,
|
|
144
|
+
hookId,
|
|
145
|
+
eventData: this._prepareEventData(eventData)
|
|
146
|
+
});
|
|
147
|
+
}
|
|
148
|
+
async setMock({ testId, hookId, ruleId, responseEventId, mock }) {
|
|
149
|
+
const mockDefinedWithPredicate = mock.isPredicate;
|
|
150
|
+
mock = testcafe_hammerhead_1.ResponseMock.from(mock);
|
|
151
|
+
if (mockDefinedWithPredicate)
|
|
152
|
+
this._wrapMockPredicate({ mock, testId, hookId, ruleId });
|
|
153
|
+
await this.emit('setMock', [responseEventId, mock]);
|
|
154
|
+
}
|
|
155
|
+
async setConfigureResponseEventOptions({ eventId, opts }) {
|
|
156
|
+
await this.emit('setConfigureResponseEventOptions', [eventId, opts]);
|
|
157
|
+
}
|
|
158
|
+
async setHeaderOnConfigureResponseEvent({ eventId, headerName, headerValue }) {
|
|
159
|
+
await this.emit('setHeaderOnConfigureResponseEvent', [eventId, headerName, headerValue]);
|
|
160
|
+
}
|
|
161
|
+
async removeHeaderOnConfigureResponseEvent({ eventId, headerName }) {
|
|
162
|
+
await this.emit('removeHeaderOnConfigureResponseEvent', [eventId, headerName]);
|
|
163
|
+
}
|
|
164
|
+
async executeRequestFilterRulePredicate({ testId, hookId, ruleId, requestInfo }) {
|
|
165
|
+
const { proxy } = await this._getRuntime();
|
|
166
|
+
return await proxy.call(this.executeRequestFilterRulePredicate, { testId, hookId, ruleId, requestInfo });
|
|
167
|
+
}
|
|
168
|
+
async executeMockPredicate({ testId, hookId, ruleId, requestInfo, res }) {
|
|
169
|
+
const { proxy } = await this._getRuntime();
|
|
170
|
+
return await proxy.call(this.executeMockPredicate, { testId, hookId, ruleId, requestInfo, res });
|
|
171
|
+
}
|
|
172
|
+
async getWarningMessages({ testRunId }) {
|
|
173
|
+
const { proxy } = await this._getRuntime();
|
|
174
|
+
return proxy.call(this.getWarningMessages, { testRunId });
|
|
175
|
+
}
|
|
176
|
+
async addRequestEventListeners({ hookId, hookClassName, rules }) {
|
|
177
|
+
rules = testcafe_hammerhead_1.RequestFilterRule.fromArray(rules);
|
|
178
|
+
await this.emit('addRequestEventListeners', { hookId, hookClassName, rules });
|
|
179
|
+
}
|
|
180
|
+
async removeRequestEventListeners({ rules }) {
|
|
181
|
+
rules = testcafe_hammerhead_1.RequestFilterRule.fromArray(rules);
|
|
182
|
+
await this.emit('removeRequestEventListeners', { rules });
|
|
183
|
+
}
|
|
184
|
+
async initializeTestRunData({ testRunId, testId }) {
|
|
185
|
+
const { proxy } = await this._getRuntime();
|
|
186
|
+
return proxy.call(this.initializeTestRunData, { testRunId, testId });
|
|
187
|
+
}
|
|
188
|
+
}
|
|
189
|
+
exports.default = CompilerHost;
|
|
106
190
|
module.exports = exports.default;
|
|
107
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"host.js","sourceRoot":"","sources":["../../../src/services/compiler/host.ts"],"names":[],"mappings":"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","sourcesContent":["import { spawn, ChildProcess } from 'child_process';\nimport {\n    HOST_INPUT_FD,\n    HOST_OUTPUT_FD,\n    HOST_SYNC_FD\n} from './io';\n\nimport { restore as restoreTestStructure } from '../serialization/test-structure';\nimport prepareOptions from '../serialization/prepare-options';\nimport { default as testRunTracker, TestRun } from '../../api/test-run-tracker';\nimport { IPCProxy } from '../utils/ipc/proxy';\nimport { HostTransport } from '../utils/ipc/transport';\nimport EventEmitter from '../../utils/async-event-emitter';\nimport TestCafeErrorList from '../../errors/error-list';\n\nimport {\n    CompilerProtocol,\n    RunTestArguments,\n    ExecuteActionArguments,\n    FunctionProperties,\n    SetOptionsArguments,\n    ExecuteCommandArguments\n} from './protocol';\n\nimport { CompilerArguments } from '../../compiler/interfaces';\nimport Test from '../../api/structure/test';\n\nconst SERVICE_PATH = require.resolve('./service');\n\ninterface RuntimeResources {\n    service: ChildProcess;\n    proxy: IPCProxy;\n}\n\ninterface TestFunction {\n    (testRun: TestRun): Promise<unknown>;\n}\n\nexport default class CompilerHost extends EventEmitter implements CompilerProtocol {\n    private runtime: Promise<RuntimeResources|undefined>;\n\n    public constructor () {\n        super();\n\n        this.runtime = Promise.resolve(void 0);\n    }\n\n    private _setupRoutes (proxy: IPCProxy): void {\n        proxy.register([\n            this.executeAction,\n            this.executeCommand,\n            this.ready\n        ], this);\n    }\n\n    private async _init (runtime: Promise<RuntimeResources|undefined>): Promise<RuntimeResources|undefined> {\n        const resolvedRuntime = await runtime;\n\n        if (resolvedRuntime)\n            return resolvedRuntime;\n\n        try {\n            const service = spawn(process.argv0, [SERVICE_PATH], { stdio: [0, 1, 2, 'pipe', 'pipe', 'pipe'] });\n\n            // HACK: Node.js definition are not correct when additional I/O channels are sp\n            const stdio = service.stdio as any;\n            const proxy = new IPCProxy(new HostTransport(stdio[HOST_INPUT_FD], stdio[HOST_OUTPUT_FD], stdio[HOST_SYNC_FD]));\n\n            this._setupRoutes(proxy);\n\n            await this.once('ready');\n\n            return { proxy, service };\n        }\n        catch (e) {\n            return void 0;\n        }\n    }\n\n    private async _getRuntime (): Promise<RuntimeResources> {\n        const runtime = await this.runtime;\n\n        if (!runtime)\n            throw new Error();\n\n        return runtime;\n    }\n\n    public async init (): Promise<void> {\n        this.runtime = this._init(this.runtime);\n\n        await this.runtime;\n    }\n\n    public async stop (): Promise<void> {\n        const { service } = await this._getRuntime();\n\n        service.kill();\n    }\n\n    private _wrapTestFunction (id: string, functionName: FunctionProperties): TestFunction {\n        return async testRun => {\n            try {\n                return await this.runTest({ id, functionName, testRunId: testRun.id });\n            }\n            catch (err) {\n                const errList = new TestCafeErrorList();\n\n                errList.addError(err);\n\n                throw errList;\n            }\n        };\n    }\n\n    public async ready (): Promise<void> {\n        this.emit('ready');\n    }\n\n    public async executeAction (data: ExecuteActionArguments): Promise<unknown> {\n        const targetTestRun = testRunTracker.activeTestRuns[data.id];\n\n        if (!targetTestRun)\n            return void 0;\n\n        return targetTestRun.executeAction(data.apiMethodName, data.command, data.callsite);\n    }\n\n    public async executeCommand ({ command, id }: ExecuteCommandArguments): Promise<unknown> {\n        const targetTestRun = testRunTracker.activeTestRuns[id];\n\n        if (!targetTestRun)\n            return void 0;\n\n        return targetTestRun.executeCommand(command);\n    }\n\n    public async getTests ({ sourceList, compilerOptions }: CompilerArguments): Promise<Test[]> {\n        const { proxy } = await this._getRuntime();\n\n        const units = await proxy.call(this.getTests, { sourceList, compilerOptions });\n\n        return restoreTestStructure(units, (...args) => this._wrapTestFunction(...args));\n    }\n\n    public async runTest ({ id, functionName, testRunId }: RunTestArguments): Promise<unknown> {\n        const { proxy } = await this._getRuntime();\n\n        return await proxy.call(this.runTest, { id, functionName, testRunId });\n    }\n\n    public async cleanUp (): Promise<void> {\n        const { proxy } = await this._getRuntime();\n\n        await proxy.call(this.cleanUp);\n    }\n\n    public async setOptions ({ value }: SetOptionsArguments): Promise<void> {\n        const { proxy } = await this._getRuntime();\n\n        const preparedOptions = prepareOptions(value);\n\n        await proxy.call(this.setOptions, { value: preparedOptions });\n    }\n}\n"]}
|
|
191
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"host.js","sourceRoot":"","sources":["../../../src/services/compiler/host.ts"],"names":[],"mappings":"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","sourcesContent":["import { spawn, ChildProcess } from 'child_process';\nimport {\n    HOST_INPUT_FD,\n    HOST_OUTPUT_FD,\n    HOST_SYNC_FD\n} from './io';\n\nimport { restore as restoreTestStructure } from '../serialization/test-structure';\nimport prepareOptions from '../serialization/prepare-options';\nimport { default as testRunTracker, TestRun } from '../../api/test-run-tracker';\nimport { IPCProxy } from '../utils/ipc/proxy';\nimport { HostTransport } from '../utils/ipc/transport';\nimport AsyncEventEmitter from '../../utils/async-event-emitter';\nimport TestCafeErrorList from '../../errors/error-list';\n\nimport {\n    CompilerProtocol,\n    RunTestArguments,\n    ExecuteActionArguments,\n    FunctionProperties,\n    SetOptionsArguments,\n    ExecuteCommandArguments,\n    RequestHookEventArguments,\n    SetMockArguments,\n    SetConfigureResponseEventOptionsArguments,\n    SetHeaderOnConfigureResponseEventArguments,\n    RemoveHeaderOnConfigureResponseEventArguments,\n    ExecuteRequestFilterRulePredicateArguments,\n    RequestFilterRuleLocator,\n    ExecuteMockPredicate,\n    GetWarningMessagesArguments,\n    AddRequestEventListenersArguments,\n    RemoveRequestEventListenersArguments,\n    InitializeTestRunDataArguments\n} from './protocol';\n\nimport { CompilerArguments } from '../../compiler/interfaces';\nimport Test from '../../api/structure/test';\nimport {\n    RequestInfo,\n    ResponseMock,\n    IncomingMessageLikeInitOptions,\n    RequestEvent,\n    ConfigureResponseEvent,\n    ResponseEvent,\n    RequestFilterRule\n} from 'testcafe-hammerhead';\n\nconst SERVICE_PATH = require.resolve('./service');\n\ninterface RuntimeResources {\n    service: ChildProcess;\n    proxy: IPCProxy;\n}\n\ninterface TestFunction {\n    (testRun: TestRun): Promise<unknown>;\n}\n\ninterface RequestFilterRulePredicate {\n    (requestInfo: RequestInfo): Promise<boolean>;\n}\n\ninterface WrapMockPredicateArguments extends RequestFilterRuleLocator {\n    mock: ResponseMock;\n}\n\nexport default class CompilerHost extends AsyncEventEmitter implements CompilerProtocol {\n    private runtime: Promise<RuntimeResources|undefined>;\n\n    public constructor () {\n        super();\n\n        this.runtime = Promise.resolve(void 0);\n    }\n\n    private _setupRoutes (proxy: IPCProxy): void {\n        proxy.register([\n            this.executeAction,\n            this.executeCommand,\n            this.ready,\n            this.onRequestHookEvent,\n            this.setMock,\n            this.setConfigureResponseEventOptions,\n            this.setHeaderOnConfigureResponseEvent,\n            this.removeHeaderOnConfigureResponseEvent,\n            this.executeRequestFilterRulePredicate,\n            this.executeMockPredicate,\n            this.getWarningMessages,\n            this.addRequestEventListeners,\n            this.removeRequestEventListeners,\n            this.initializeTestRunData\n        ], this);\n    }\n\n    private async _init (runtime: Promise<RuntimeResources|undefined>): Promise<RuntimeResources|undefined> {\n        const resolvedRuntime = await runtime;\n\n        if (resolvedRuntime)\n            return resolvedRuntime;\n\n        try {\n            const service = spawn(process.argv0, [SERVICE_PATH], { stdio: [0, 1, 2, 'pipe', 'pipe', 'pipe'] });\n\n            // HACK: Node.js definition are not correct when additional I/O channels are sp\n            const stdio = service.stdio as any;\n            const proxy = new IPCProxy(new HostTransport(stdio[HOST_INPUT_FD], stdio[HOST_OUTPUT_FD], stdio[HOST_SYNC_FD]));\n\n            this._setupRoutes(proxy);\n\n            await this.once('ready');\n\n            return { proxy, service };\n        }\n        catch (e) {\n            return void 0;\n        }\n    }\n\n    private async _getRuntime (): Promise<RuntimeResources> {\n        const runtime = await this.runtime;\n\n        if (!runtime)\n            throw new Error('Runtime is not available.');\n\n        return runtime;\n    }\n\n    private _prepareEventData (eventData: RequestEvent | ConfigureResponseEvent | ResponseEvent): RequestEvent | ConfigureResponseEvent | ResponseEvent {\n        // TODO: Remove eventData._requestContext into 'testcafe-hammerhead' module\n        // after switching to the compiler service mode.\n\n        // NOTE: Access to the deprecated property inside of the unserializable 'eventData._requestContext' property\n        // causes the node's deprecation warning.\n\n        const clonedEventData = Object.assign({}, eventData);\n\n        // @ts-ignore\n        delete clonedEventData._requestContext;\n\n        return clonedEventData;\n    }\n\n    public async init (): Promise<void> {\n        this.runtime = this._init(this.runtime);\n\n        await this.runtime;\n    }\n\n    public async stop (): Promise<void> {\n        const { service } = await this._getRuntime();\n\n        service.kill();\n    }\n\n    private _wrapTestFunction (id: string, functionName: FunctionProperties): TestFunction {\n        return async testRun => {\n            try {\n                return await this.runTestFn({ id, functionName, testRunId: testRun.id });\n            }\n            catch (err) {\n                const errList = new TestCafeErrorList();\n\n                errList.addError(err);\n\n                throw errList;\n            }\n        };\n    }\n\n    private _wrapRequestFilterRulePredicate ({ testId, hookId, ruleId }: RequestFilterRuleLocator): RequestFilterRulePredicate {\n        return async (requestInfo: RequestInfo) => {\n            return await this.executeRequestFilterRulePredicate({ testId, hookId, ruleId, requestInfo });\n        };\n    }\n\n    private _wrapMockPredicate ({ mock, testId, hookId, ruleId }: WrapMockPredicateArguments): void {\n        mock.body = async (requestInfo: RequestInfo, res: IncomingMessageLikeInitOptions) => {\n            return await this.executeMockPredicate({ testId, hookId, ruleId, requestInfo, res });\n        };\n    }\n\n    public async ready (): Promise<void> {\n        this.emit('ready');\n    }\n\n    public async executeAction (data: ExecuteActionArguments): Promise<unknown> {\n        const targetTestRun = testRunTracker.activeTestRuns[data.id];\n\n        if (!targetTestRun)\n            return void 0;\n\n        return targetTestRun.executeAction(data.apiMethodName, data.command, data.callsite);\n    }\n\n    public executeActionSync (): never {\n        throw new Error('The method should not be called.');\n    }\n\n    public async executeCommand ({ command, id }: ExecuteCommandArguments): Promise<unknown> {\n        const targetTestRun = testRunTracker.activeTestRuns[id];\n\n        if (!targetTestRun)\n            return void 0;\n\n        return targetTestRun.executeCommand(command);\n    }\n\n    public async getTests ({ sourceList, compilerOptions }: CompilerArguments): Promise<Test[]> {\n        const { proxy } = await this._getRuntime();\n\n        const units = await proxy.call(this.getTests, { sourceList, compilerOptions });\n\n        return restoreTestStructure(\n            units,\n            (...args) => this._wrapTestFunction(...args),\n            (ruleLocator: RequestFilterRuleLocator) => this._wrapRequestFilterRulePredicate(ruleLocator)\n        );\n    }\n\n    public async runTestFn ({ id, functionName, testRunId }: RunTestArguments): Promise<unknown> {\n        const { proxy } = await this._getRuntime();\n\n        return await proxy.call(this.runTestFn, { id, functionName, testRunId });\n    }\n\n    public async cleanUp (): Promise<void> {\n        const { proxy } = await this._getRuntime();\n\n        await proxy.call(this.cleanUp);\n    }\n\n    public async setOptions ({ value }: SetOptionsArguments): Promise<void> {\n        const { proxy } = await this._getRuntime();\n\n        const preparedOptions = prepareOptions(value);\n\n        await proxy.call(this.setOptions, { value: preparedOptions });\n    }\n\n    public async onRequestHookEvent ({ name, testId, hookId, eventData }: RequestHookEventArguments): Promise<void> {\n        const { proxy } = await this._getRuntime();\n\n        await proxy.call(this.onRequestHookEvent, {\n            name,\n            testId,\n            hookId,\n            eventData: this._prepareEventData(eventData)\n        });\n    }\n\n    public async setMock ({ testId, hookId, ruleId, responseEventId, mock }: SetMockArguments): Promise<void> {\n        const mockDefinedWithPredicate = mock.isPredicate;\n\n        mock = ResponseMock.from(mock);\n\n        if (mockDefinedWithPredicate)\n            this._wrapMockPredicate({ mock, testId, hookId, ruleId });\n\n        await this.emit('setMock', [responseEventId, mock]);\n    }\n\n    public async setConfigureResponseEventOptions ({ eventId, opts }: SetConfigureResponseEventOptionsArguments): Promise<void> {\n        await this.emit('setConfigureResponseEventOptions', [eventId, opts]);\n    }\n\n    public async setHeaderOnConfigureResponseEvent ({ eventId, headerName, headerValue }: SetHeaderOnConfigureResponseEventArguments): Promise<void> {\n        await this.emit('setHeaderOnConfigureResponseEvent', [eventId, headerName, headerValue]);\n    }\n\n    public async removeHeaderOnConfigureResponseEvent ({ eventId, headerName }: RemoveHeaderOnConfigureResponseEventArguments): Promise<void> {\n        await this.emit('removeHeaderOnConfigureResponseEvent', [eventId, headerName]);\n    }\n\n    public async executeRequestFilterRulePredicate ({ testId, hookId, ruleId, requestInfo }: ExecuteRequestFilterRulePredicateArguments): Promise<boolean> {\n        const { proxy } = await this._getRuntime();\n\n        return await proxy.call(this.executeRequestFilterRulePredicate, { testId, hookId, ruleId, requestInfo });\n    }\n\n    public async executeMockPredicate ({ testId, hookId, ruleId, requestInfo, res }: ExecuteMockPredicate): Promise<IncomingMessageLikeInitOptions> {\n        const { proxy } = await this._getRuntime();\n\n        return await proxy.call(this.executeMockPredicate, { testId, hookId, ruleId, requestInfo, res });\n    }\n\n    public async getWarningMessages ({ testRunId }: GetWarningMessagesArguments): Promise<string[]> {\n        const { proxy } = await this._getRuntime();\n\n        return proxy.call(this.getWarningMessages, { testRunId });\n    }\n\n    public async addRequestEventListeners ( { hookId, hookClassName, rules }: AddRequestEventListenersArguments): Promise<void> {\n        rules = RequestFilterRule.fromArray(rules as object[]);\n\n        await this.emit('addRequestEventListeners', { hookId, hookClassName, rules });\n    }\n\n    public async removeRequestEventListeners ({ rules }: RemoveRequestEventListenersArguments): Promise<void> {\n        rules = RequestFilterRule.fromArray(rules as object[]);\n\n        await this.emit('removeRequestEventListeners', { rules });\n    }\n\n    public async initializeTestRunData ({ testRunId, testId }: InitializeTestRunDataArguments): Promise<void> {\n        const { proxy } = await this._getRuntime();\n\n        return proxy.call(this.initializeTestRunData, { testRunId, testId });\n    }\n}\n"]}
|
|
@@ -1,10 +1,10 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.HOST_SYNC_FD = exports.HOST_OUTPUT_FD = exports.HOST_INPUT_FD = exports.SERVICE_SYNC_FD = exports.SERVICE_OUTPUT_FD = exports.SERVICE_INPUT_FD = void 0;
|
|
4
|
-
exports.SERVICE_INPUT_FD = 3;
|
|
5
|
-
exports.SERVICE_OUTPUT_FD = 4;
|
|
6
|
-
exports.SERVICE_SYNC_FD = 5;
|
|
7
|
-
exports.HOST_INPUT_FD = exports.SERVICE_OUTPUT_FD;
|
|
8
|
-
exports.HOST_OUTPUT_FD = exports.SERVICE_INPUT_FD;
|
|
9
|
-
exports.HOST_SYNC_FD = exports.SERVICE_SYNC_FD;
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.HOST_SYNC_FD = exports.HOST_OUTPUT_FD = exports.HOST_INPUT_FD = exports.SERVICE_SYNC_FD = exports.SERVICE_OUTPUT_FD = exports.SERVICE_INPUT_FD = void 0;
|
|
4
|
+
exports.SERVICE_INPUT_FD = 3;
|
|
5
|
+
exports.SERVICE_OUTPUT_FD = 4;
|
|
6
|
+
exports.SERVICE_SYNC_FD = 5;
|
|
7
|
+
exports.HOST_INPUT_FD = exports.SERVICE_OUTPUT_FD;
|
|
8
|
+
exports.HOST_OUTPUT_FD = exports.SERVICE_INPUT_FD;
|
|
9
|
+
exports.HOST_SYNC_FD = exports.SERVICE_SYNC_FD;
|
|
10
10
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW8uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvc2VydmljZXMvY29tcGlsZXIvaW8udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQWEsUUFBQSxnQkFBZ0IsR0FBSSxDQUFDLENBQUM7QUFDdEIsUUFBQSxpQkFBaUIsR0FBRyxDQUFDLENBQUM7QUFDdEIsUUFBQSxlQUFlLEdBQUssQ0FBQyxDQUFDO0FBQ3RCLFFBQUEsYUFBYSxHQUFPLHlCQUFpQixDQUFDO0FBQ3RDLFFBQUEsY0FBYyxHQUFNLHdCQUFnQixDQUFDO0FBQ3JDLFFBQUEsWUFBWSxHQUFRLHVCQUFlLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY29uc3QgU0VSVklDRV9JTlBVVF9GRCAgPSAzO1xuZXhwb3J0IGNvbnN0IFNFUlZJQ0VfT1VUUFVUX0ZEID0gNDtcbmV4cG9ydCBjb25zdCBTRVJWSUNFX1NZTkNfRkQgICA9IDU7XG5leHBvcnQgY29uc3QgSE9TVF9JTlBVVF9GRCAgICAgPSBTRVJWSUNFX09VVFBVVF9GRDtcbmV4cG9ydCBjb25zdCBIT1NUX09VVFBVVF9GRCAgICA9IFNFUlZJQ0VfSU5QVVRfRkQ7XG5leHBvcnQgY29uc3QgSE9TVF9TWU5DX0ZEICAgICAgPSBTRVJWSUNFX1NZTkNfRkQ7XG4iXX0=
|
|
@@ -1,16 +1,17 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.isFixtureFunctionProperty = exports.isTestFunctionProperty = exports.FUNCTION_PROPERTIES = exports.TEST_FUNCTION_PROPERTIES = exports.BEFORE_AFTER_EACH_PROPERTIES = exports.BEFORE_AFTER_PROPERTIES = void 0;
|
|
4
|
-
exports.BEFORE_AFTER_PROPERTIES = ['beforeFn', 'afterFn'];
|
|
5
|
-
exports.BEFORE_AFTER_EACH_PROPERTIES = ['beforeEachFn', 'afterEachFn'];
|
|
6
|
-
exports.TEST_FUNCTION_PROPERTIES = ['fn', ...exports.BEFORE_AFTER_PROPERTIES];
|
|
7
|
-
exports.
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.isFixtureFunctionProperty = exports.isTestFunctionProperty = exports.FUNCTION_PROPERTIES = exports.FIXTURE_FUNCTION_PROPERTIES = exports.TEST_FUNCTION_PROPERTIES = exports.BEFORE_AFTER_EACH_PROPERTIES = exports.BEFORE_AFTER_PROPERTIES = void 0;
|
|
4
|
+
exports.BEFORE_AFTER_PROPERTIES = ['beforeFn', 'afterFn'];
|
|
5
|
+
exports.BEFORE_AFTER_EACH_PROPERTIES = ['beforeEachFn', 'afterEachFn'];
|
|
6
|
+
exports.TEST_FUNCTION_PROPERTIES = ['fn', ...exports.BEFORE_AFTER_PROPERTIES];
|
|
7
|
+
exports.FIXTURE_FUNCTION_PROPERTIES = [...exports.BEFORE_AFTER_PROPERTIES, ...exports.BEFORE_AFTER_EACH_PROPERTIES];
|
|
8
|
+
exports.FUNCTION_PROPERTIES = [...exports.TEST_FUNCTION_PROPERTIES, ...exports.BEFORE_AFTER_EACH_PROPERTIES];
|
|
9
|
+
function isTestFunctionProperty(value) {
|
|
10
|
+
return exports.TEST_FUNCTION_PROPERTIES.includes(value);
|
|
11
|
+
}
|
|
12
|
+
exports.isTestFunctionProperty = isTestFunctionProperty;
|
|
13
|
+
function isFixtureFunctionProperty(value) {
|
|
14
|
+
return exports.FIXTURE_FUNCTION_PROPERTIES.includes(value);
|
|
15
|
+
}
|
|
16
|
+
exports.isFixtureFunctionProperty = isFixtureFunctionProperty;
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"protocol.js","sourceRoot":"","sources":["../../../src/services/compiler/protocol.ts"],"names":[],"mappings":";;;AAca,QAAA,uBAAuB,GAAQ,CAAC,UAAU,EAAE,SAAS,CAAU,CAAC;AAChE,QAAA,4BAA4B,GAAG,CAAC,cAAc,EAAE,aAAa,CAAU,CAAC;AACxE,QAAA,wBAAwB,GAAO,CAAC,IAAI,EAAE,GAAG,+BAAuB,CAAU,CAAC;AAC3E,QAAA,2BAA2B,GAAI,CAAC,GAAG,+BAAuB,EAAE,GAAG,oCAA4B,CAAU,CAAC;AACtG,QAAA,mBAAmB,GAAY,CAAC,GAAG,gCAAwB,EAAE,GAAG,oCAA4B,CAAU,CAAC;AAOpH,SAAgB,sBAAsB,CAAE,KAAyB;IAC7D,OAAO,gCAAwB,CAAC,QAAQ,CAAC,KAA+B,CAAC,CAAC;AAC9E,CAAC;AAFD,wDAEC;AAED,SAAgB,yBAAyB,CAAE,KAAyB;IAChE,OAAO,mCAA2B,CAAC,QAAQ,CAAC,KAAkC,CAAC,CAAC;AACpF,CAAC;AAFD,8DAEC","sourcesContent":["import { CompilerArguments } from '../../compiler/interfaces';\nimport { Dictionary } from '../../configuration/interfaces';\nimport RequestHookMethodNames from '../../api/request-hooks/hook-method-names';\nimport {\n    ConfigureResponseEvent,\n    ConfigureResponseEventOptions,\n    RequestEvent,\n    ResponseEvent,\n    ResponseMock,\n    RequestInfo,\n    IncomingMessageLikeInitOptions,\n    RequestFilterRule\n} from 'testcafe-hammerhead';\n\nexport const BEFORE_AFTER_PROPERTIES      = ['beforeFn', 'afterFn'] as const;\nexport const BEFORE_AFTER_EACH_PROPERTIES = ['beforeEachFn', 'afterEachFn'] as const;\nexport const TEST_FUNCTION_PROPERTIES     = ['fn', ...BEFORE_AFTER_PROPERTIES] as const;\nexport const FIXTURE_FUNCTION_PROPERTIES  = [...BEFORE_AFTER_PROPERTIES, ...BEFORE_AFTER_EACH_PROPERTIES] as const;\nexport const FUNCTION_PROPERTIES          = [...TEST_FUNCTION_PROPERTIES, ...BEFORE_AFTER_EACH_PROPERTIES] as const;\n\nexport type FunctionProperties = typeof FUNCTION_PROPERTIES[number];\nexport type TestFunctionProperties = typeof TEST_FUNCTION_PROPERTIES[number];\nexport type FixtureFunctionProperties = typeof FIXTURE_FUNCTION_PROPERTIES[number];\n\n\nexport function isTestFunctionProperty (value: FunctionProperties): value is TestFunctionProperties {\n    return TEST_FUNCTION_PROPERTIES.includes(value as TestFunctionProperties);\n}\n\nexport function isFixtureFunctionProperty (value: FunctionProperties): value is FixtureFunctionProperties {\n    return FIXTURE_FUNCTION_PROPERTIES.includes(value as FixtureFunctionProperties);\n}\n\nexport interface RunTestArguments {\n    id: string;\n    functionName: FunctionProperties;\n    testRunId: string;\n}\n\nexport interface ExecuteActionArguments {\n    id: string;\n    apiMethodName: string;\n    command: unknown;\n    callsite: unknown;\n}\n\nexport interface ExecuteCommandArguments {\n    id: string;\n    command: unknown;\n}\n\nexport interface RemoveRequestEventListenersArguments {\n    rules: RequestFilterRule[];\n}\n\nexport interface AddRequestEventListenersArguments {\n    hookId: string;\n    hookClassName: string;\n    rules: RequestFilterRule[];\n}\n\nexport interface SetOptionsArguments {\n    value: Dictionary<OptionValue>;\n}\n\nexport interface RequestHookEventArguments {\n    name: RequestHookMethodNames;\n    testId: string;\n    hookId: string;\n    eventData: RequestEvent | ConfigureResponseEvent | ResponseEvent;\n}\n\nexport interface SetMockArguments extends RequestFilterRuleLocator {\n    responseEventId: string;\n    mock: ResponseMock;\n}\n\nexport interface SetConfigureResponseEventOptionsArguments {\n    eventId: string;\n    opts: ConfigureResponseEventOptions;\n}\n\nexport interface SetHeaderOnConfigureResponseEventArguments {\n    eventId: string;\n    headerName: string;\n    headerValue: string;\n}\n\nexport interface RemoveHeaderOnConfigureResponseEventArguments {\n    eventId: string;\n    headerName: string;\n}\n\nexport interface RequestHookLocator {\n    testId: string;\n    hookId: string;\n}\n\nexport interface RequestFilterRuleLocator extends RequestHookLocator {\n    ruleId: string;\n}\n\nexport interface ExecuteRequestFilterRulePredicateArguments extends RequestFilterRuleLocator {\n    requestInfo: RequestInfo;\n}\n\nexport interface ExecuteMockPredicate extends RequestFilterRuleLocator {\n    requestInfo: RequestInfo;\n    res: IncomingMessageLikeInitOptions;\n}\n\nexport interface GetWarningMessagesArguments {\n    testRunId: string;\n}\n\nexport interface InitializeTestRunDataArguments {\n    testRunId: string;\n    testId: string;\n}\n\nexport interface TestRunDispatcherProtocol {\n    executeActionSync ({ id, apiMethodName, command, callsite }: ExecuteActionArguments): unknown;\n    executeAction ({ id, apiMethodName, command, callsite }: ExecuteActionArguments): Promise<unknown>;\n    executeCommand ({ command }: ExecuteCommandArguments): Promise<unknown>;\n    addRequestEventListeners ( { hookId, hookClassName, rules }: AddRequestEventListenersArguments): Promise<void>;\n    removeRequestEventListeners ({ rules }: RemoveRequestEventListenersArguments): Promise<void>;\n}\n\nexport interface CompilerProtocol extends TestRunDispatcherProtocol {\n    ready (): Promise<void>;\n\n    getTests ({ sourceList, compilerOptions }: CompilerArguments): Promise<unknown>;\n\n    runTestFn ({ id, functionName, testRunId }: RunTestArguments): Promise<unknown>;\n\n    cleanUp (): Promise<void>;\n\n    setOptions ({ value }: SetOptionsArguments): Promise<void>;\n\n    onRequestHookEvent ({ name, testId, hookId, eventData }: RequestHookEventArguments): Promise<void>;\n\n    setMock ({ responseEventId, mock }: SetMockArguments): Promise<void>;\n\n    setConfigureResponseEventOptions ({ eventId, opts }: SetConfigureResponseEventOptionsArguments): Promise<void>;\n\n    setHeaderOnConfigureResponseEvent ({ eventId, headerName, headerValue }: SetHeaderOnConfigureResponseEventArguments): Promise<void>;\n\n    removeHeaderOnConfigureResponseEvent ({ eventId, headerName }: RemoveHeaderOnConfigureResponseEventArguments): Promise<void>;\n\n    executeRequestFilterRulePredicate ({ testId, hookId, ruleId, requestInfo }: ExecuteRequestFilterRulePredicateArguments): Promise<boolean>;\n\n    executeMockPredicate ({ testId, hookId, ruleId, requestInfo, res }: ExecuteMockPredicate): Promise<IncomingMessageLikeInitOptions>;\n\n    getWarningMessages ({ testRunId }: GetWarningMessagesArguments): Promise<string[]>;\n\n    initializeTestRunData ({ testRunId, testId }: InitializeTestRunDataArguments): Promise<void>;\n}\n"]}
|