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