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/CHANGELOG.md
CHANGED
package/LICENSE
CHANGED
|
@@ -1,21 +1,21 @@
|
|
|
1
|
-
The MIT License
|
|
2
|
-
|
|
3
|
-
Copyright (C) 2012-2021 Developer Express Inc.
|
|
4
|
-
|
|
5
|
-
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
6
|
-
of this software and associated documentation files (the "Software"), to deal
|
|
7
|
-
in the Software without restriction, including without limitation the rights
|
|
8
|
-
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
9
|
-
copies of the Software, and to permit persons to whom the Software is
|
|
10
|
-
furnished to do so, subject to the following conditions:
|
|
11
|
-
|
|
12
|
-
The above copyright notice and this permission notice shall be included in
|
|
13
|
-
all copies or substantial portions of the Software.
|
|
14
|
-
|
|
15
|
-
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
16
|
-
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
17
|
-
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
18
|
-
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
19
|
-
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
20
|
-
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
21
|
-
THE SOFTWARE.
|
|
1
|
+
The MIT License
|
|
2
|
+
|
|
3
|
+
Copyright (C) 2012-2021 Developer Express Inc.
|
|
4
|
+
|
|
5
|
+
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
6
|
+
of this software and associated documentation files (the "Software"), to deal
|
|
7
|
+
in the Software without restriction, including without limitation the rights
|
|
8
|
+
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
9
|
+
copies of the Software, and to permit persons to whom the Software is
|
|
10
|
+
furnished to do so, subject to the following conditions:
|
|
11
|
+
|
|
12
|
+
The above copyright notice and this permission notice shall be included in
|
|
13
|
+
all copies or substantial portions of the Software.
|
|
14
|
+
|
|
15
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
16
|
+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
17
|
+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
18
|
+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
19
|
+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
20
|
+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
21
|
+
THE SOFTWARE.
|
|
File without changes
|
|
@@ -1,51 +1,51 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
const lazyRequire = require('import-lazy')(require);
|
|
4
|
-
const ClientFunctionBuilder = lazyRequire('../../client-functions/client-function-builder');
|
|
5
|
-
const SelectorBuilder = lazyRequire('../../client-functions/selectors/selector-builder');
|
|
6
|
-
const role = lazyRequire('../../role');
|
|
7
|
-
const createRequestLogger = lazyRequire('../request-hooks/request-logger');
|
|
8
|
-
const createRequestMock = lazyRequire('../request-hooks/request-mock/create-request-mock');
|
|
9
|
-
// NOTE: We can't use lazy require for RequestHook, because it will break base class detection for inherited classes
|
|
10
|
-
let RequestHook = null;
|
|
11
|
-
// NOTE: We can't use lazy require for testControllerProxy, because it will break test controller detection
|
|
12
|
-
let testControllerProxy = null;
|
|
13
|
-
function Role(loginUrl, initFn, options) {
|
|
14
|
-
return role.createRole(loginUrl, initFn, options);
|
|
15
|
-
}
|
|
16
|
-
function RequestMock() {
|
|
17
|
-
return createRequestMock();
|
|
18
|
-
}
|
|
19
|
-
function RequestLogger(requestFilterRuleInit, logOptions) {
|
|
20
|
-
return createRequestLogger(requestFilterRuleInit, logOptions);
|
|
21
|
-
}
|
|
22
|
-
function ClientFunction(fn, options) {
|
|
23
|
-
const builder = new ClientFunctionBuilder(fn, options, { instantiation: 'ClientFunction' });
|
|
24
|
-
return builder.getFunction();
|
|
25
|
-
}
|
|
26
|
-
function Selector(fn, options) {
|
|
27
|
-
const builder = new SelectorBuilder(fn, options, { instantiation: 'Selector' });
|
|
28
|
-
return builder.getFunction();
|
|
29
|
-
}
|
|
30
|
-
Object.defineProperty(Role, 'anonymous', {
|
|
31
|
-
get: () => role.createAnonymousRole
|
|
32
|
-
});
|
|
33
|
-
exports.default = {
|
|
34
|
-
Role,
|
|
35
|
-
ClientFunction,
|
|
36
|
-
Selector,
|
|
37
|
-
RequestLogger,
|
|
38
|
-
RequestMock,
|
|
39
|
-
get RequestHook() {
|
|
40
|
-
if (!RequestHook)
|
|
41
|
-
RequestHook = require('../request-hooks/hook');
|
|
42
|
-
return RequestHook;
|
|
43
|
-
},
|
|
44
|
-
get t() {
|
|
45
|
-
if (!testControllerProxy)
|
|
46
|
-
testControllerProxy = require('../test-controller/proxy');
|
|
47
|
-
return testControllerProxy;
|
|
48
|
-
}
|
|
49
|
-
};
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const lazyRequire = require('import-lazy')(require);
|
|
4
|
+
const ClientFunctionBuilder = lazyRequire('../../client-functions/client-function-builder');
|
|
5
|
+
const SelectorBuilder = lazyRequire('../../client-functions/selectors/selector-builder');
|
|
6
|
+
const role = lazyRequire('../../role');
|
|
7
|
+
const createRequestLogger = lazyRequire('../request-hooks/request-logger');
|
|
8
|
+
const createRequestMock = lazyRequire('../request-hooks/request-mock/create-request-mock');
|
|
9
|
+
// NOTE: We can't use lazy require for RequestHook, because it will break base class detection for inherited classes
|
|
10
|
+
let RequestHook = null;
|
|
11
|
+
// NOTE: We can't use lazy require for testControllerProxy, because it will break test controller detection
|
|
12
|
+
let testControllerProxy = null;
|
|
13
|
+
function Role(loginUrl, initFn, options) {
|
|
14
|
+
return role.createRole(loginUrl, initFn, options);
|
|
15
|
+
}
|
|
16
|
+
function RequestMock() {
|
|
17
|
+
return createRequestMock();
|
|
18
|
+
}
|
|
19
|
+
function RequestLogger(requestFilterRuleInit, logOptions) {
|
|
20
|
+
return createRequestLogger(requestFilterRuleInit, logOptions);
|
|
21
|
+
}
|
|
22
|
+
function ClientFunction(fn, options) {
|
|
23
|
+
const builder = new ClientFunctionBuilder(fn, options, { instantiation: 'ClientFunction' });
|
|
24
|
+
return builder.getFunction();
|
|
25
|
+
}
|
|
26
|
+
function Selector(fn, options) {
|
|
27
|
+
const builder = new SelectorBuilder(fn, options, { instantiation: 'Selector' });
|
|
28
|
+
return builder.getFunction();
|
|
29
|
+
}
|
|
30
|
+
Object.defineProperty(Role, 'anonymous', {
|
|
31
|
+
get: () => role.createAnonymousRole
|
|
32
|
+
});
|
|
33
|
+
exports.default = {
|
|
34
|
+
Role,
|
|
35
|
+
ClientFunction,
|
|
36
|
+
Selector,
|
|
37
|
+
RequestLogger,
|
|
38
|
+
RequestMock,
|
|
39
|
+
get RequestHook() {
|
|
40
|
+
if (!RequestHook)
|
|
41
|
+
RequestHook = require('../request-hooks/hook');
|
|
42
|
+
return RequestHook;
|
|
43
|
+
},
|
|
44
|
+
get t() {
|
|
45
|
+
if (!testControllerProxy)
|
|
46
|
+
testControllerProxy = require('../test-controller/proxy');
|
|
47
|
+
return testControllerProxy;
|
|
48
|
+
}
|
|
49
|
+
};
|
|
50
50
|
module.exports = exports.default;
|
|
51
51
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXBpL2V4cG9ydGFibGUtbGliL2luZGV4LmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsTUFBTSxXQUFXLEdBQWEsT0FBTyxDQUFDLGFBQWEsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxDQUFDO0FBQzlELE1BQU0scUJBQXFCLEdBQUcsV0FBVyxDQUFDLGdEQUFnRCxDQUFDLENBQUM7QUFDNUYsTUFBTSxlQUFlLEdBQVMsV0FBVyxDQUFDLG1EQUFtRCxDQUFDLENBQUM7QUFDL0YsTUFBTSxJQUFJLEdBQW9CLFdBQVcsQ0FBQyxZQUFZLENBQUMsQ0FBQztBQUN4RCxNQUFNLG1CQUFtQixHQUFLLFdBQVcsQ0FBQyxpQ0FBaUMsQ0FBQyxDQUFDO0FBQzdFLE1BQU0saUJBQWlCLEdBQU8sV0FBVyxDQUFDLG1EQUFtRCxDQUFDLENBQUM7QUFFL0Ysb0hBQW9IO0FBQ3BILElBQUksV0FBVyxHQUFHLElBQUksQ0FBQztBQUV2QiwyR0FBMkc7QUFDM0csSUFBSSxtQkFBbUIsR0FBRyxJQUFJLENBQUM7QUFFL0IsU0FBUyxJQUFJLENBQUUsUUFBUSxFQUFFLE1BQU0sRUFBRSxPQUFPO0lBQ3BDLE9BQU8sSUFBSSxDQUFDLFVBQVUsQ0FBQyxRQUFRLEVBQUUsTUFBTSxFQUFFLE9BQU8sQ0FBQyxDQUFDO0FBQ3RELENBQUM7QUFFRCxTQUFTLFdBQVc7SUFDaEIsT0FBTyxpQkFBaUIsRUFBRSxDQUFDO0FBQy9CLENBQUM7QUFFRCxTQUFTLGFBQWEsQ0FBRSxxQkFBcUIsRUFBRSxVQUFVO0lBQ3JELE9BQU8sbUJBQW1CLENBQUMscUJBQXFCLEVBQUUsVUFBVSxDQUFDLENBQUM7QUFDbEUsQ0FBQztBQUVELFNBQVMsY0FBYyxDQUFFLEVBQUUsRUFBRSxPQUFPO0lBQ2hDLE1BQU0sT0FBTyxHQUFHLElBQUkscUJBQXFCLENBQUMsRUFBRSxFQUFFLE9BQU8sRUFBRSxFQUFFLGFBQWEsRUFBRSxnQkFBZ0IsRUFBRSxDQUFDLENBQUM7SUFFNUYsT0FBTyxPQUFPLENBQUMsV0FBVyxFQUFFLENBQUM7QUFDakMsQ0FBQztBQUVELFNBQVMsUUFBUSxDQUFFLEVBQUUsRUFBRSxPQUFPO0lBQzFCLE1BQU0sT0FBTyxHQUFHLElBQUksZUFBZSxDQUFDLEVBQUUsRUFBRSxPQUFPLEVBQUUsRUFBRSxhQUFhLEVBQUUsVUFBVSxFQUFFLENBQUMsQ0FBQztJQUVoRixPQUFPLE9BQU8sQ0FBQyxXQUFXLEVBQUUsQ0FBQztBQUNqQyxDQUFDO0FBRUQsTUFBTSxDQUFDLGNBQWMsQ0FBQyxJQUFJLEVBQUUsV0FBVyxFQUFFO0lBQ3JDLEdBQUcsRUFBRSxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsbUJBQW1CO0NBQ3RDLENBQUMsQ0FBQztBQUVILGtCQUFlO0lBQ1gsSUFBSTtJQUVKLGNBQWM7SUFFZCxRQUFRO0lBRVIsYUFBYTtJQUViLFdBQVc7SUFFWCxJQUFJLFdBQVc7UUFDWCxJQUFJLENBQUMsV0FBVztZQUNaLFdBQVcsR0FBRyxPQUFPLENBQUMsdUJBQXVCLENBQUMsQ0FBQztRQUVuRCxPQUFPLFdBQVcsQ0FBQztJQUN2QixDQUFDO0lBRUQsSUFBSSxDQUFDO1FBQ0QsSUFBSSxDQUFDLG1CQUFtQjtZQUNwQixtQkFBbUIsR0FBRyxPQUFPLENBQUMsMEJBQTBCLENBQUMsQ0FBQztRQUU5RCxPQUFPLG1CQUFtQixDQUFDO0lBQy9CLENBQUM7Q0FDSixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiY29uc3QgbGF6eVJlcXVpcmUgICAgICAgICAgID0gcmVxdWlyZSgnaW1wb3J0LWxhenknKShyZXF1aXJlKTtcbmNvbnN0IENsaWVudEZ1bmN0aW9uQnVpbGRlciA9IGxhenlSZXF1aXJlKCcuLi8uLi9jbGllbnQtZnVuY3Rpb25zL2NsaWVudC1mdW5jdGlvbi1idWlsZGVyJyk7XG5jb25zdCBTZWxlY3RvckJ1aWxkZXIgICAgICAgPSBsYXp5UmVxdWlyZSgnLi4vLi4vY2xpZW50LWZ1bmN0aW9ucy9zZWxlY3RvcnMvc2VsZWN0b3ItYnVpbGRlcicpO1xuY29uc3Qgcm9sZSAgICAgICAgICAgICAgICAgID0gbGF6eVJlcXVpcmUoJy4uLy4uL3JvbGUnKTtcbmNvbnN0IGNyZWF0ZVJlcXVlc3RMb2dnZXIgICA9IGxhenlSZXF1aXJlKCcuLi9yZXF1ZXN0LWhvb2tzL3JlcXVlc3QtbG9nZ2VyJyk7XG5jb25zdCBjcmVhdGVSZXF1ZXN0TW9jayAgICAgPSBsYXp5UmVxdWlyZSgnLi4vcmVxdWVzdC1ob29rcy9yZXF1ZXN0LW1vY2svY3JlYXRlLXJlcXVlc3QtbW9jaycpO1xuXG4vLyBOT1RFOiBXZSBjYW4ndCB1c2UgbGF6eSByZXF1aXJlIGZvciBSZXF1ZXN0SG9vaywgYmVjYXVzZSBpdCB3aWxsIGJyZWFrIGJhc2UgY2xhc3MgZGV0ZWN0aW9uIGZvciBpbmhlcml0ZWQgY2xhc3Nlc1xubGV0IFJlcXVlc3RIb29rID0gbnVsbDtcblxuLy8gTk9URTogV2UgY2FuJ3QgdXNlIGxhenkgcmVxdWlyZSBmb3IgdGVzdENvbnRyb2xsZXJQcm94eSwgYmVjYXVzZSBpdCB3aWxsIGJyZWFrIHRlc3QgY29udHJvbGxlciBkZXRlY3Rpb25cbmxldCB0ZXN0Q29udHJvbGxlclByb3h5ID0gbnVsbDtcblxuZnVuY3Rpb24gUm9sZSAobG9naW5VcmwsIGluaXRGbiwgb3B0aW9ucykge1xuICAgIHJldHVybiByb2xlLmNyZWF0ZVJvbGUobG9naW5VcmwsIGluaXRGbiwgb3B0aW9ucyk7XG59XG5cbmZ1bmN0aW9uIFJlcXVlc3RNb2NrICgpIHtcbiAgICByZXR1cm4gY3JlYXRlUmVxdWVzdE1vY2soKTtcbn1cblxuZnVuY3Rpb24gUmVxdWVzdExvZ2dlciAocmVxdWVzdEZpbHRlclJ1bGVJbml0LCBsb2dPcHRpb25zKSB7XG4gICAgcmV0dXJuIGNyZWF0ZVJlcXVlc3RMb2dnZXIocmVxdWVzdEZpbHRlclJ1bGVJbml0LCBsb2dPcHRpb25zKTtcbn1cblxuZnVuY3Rpb24gQ2xpZW50RnVuY3Rpb24gKGZuLCBvcHRpb25zKSB7XG4gICAgY29uc3QgYnVpbGRlciA9IG5ldyBDbGllbnRGdW5jdGlvbkJ1aWxkZXIoZm4sIG9wdGlvbnMsIHsgaW5zdGFudGlhdGlvbjogJ0NsaWVudEZ1bmN0aW9uJyB9KTtcblxuICAgIHJldHVybiBidWlsZGVyLmdldEZ1bmN0aW9uKCk7XG59XG5cbmZ1bmN0aW9uIFNlbGVjdG9yIChmbiwgb3B0aW9ucykge1xuICAgIGNvbnN0IGJ1aWxkZXIgPSBuZXcgU2VsZWN0b3JCdWlsZGVyKGZuLCBvcHRpb25zLCB7IGluc3RhbnRpYXRpb246ICdTZWxlY3RvcicgfSk7XG5cbiAgICByZXR1cm4gYnVpbGRlci5nZXRGdW5jdGlvbigpO1xufVxuXG5PYmplY3QuZGVmaW5lUHJvcGVydHkoUm9sZSwgJ2Fub255bW91cycsIHtcbiAgICBnZXQ6ICgpID0+IHJvbGUuY3JlYXRlQW5vbnltb3VzUm9sZVxufSk7XG5cbmV4cG9ydCBkZWZhdWx0IHtcbiAgICBSb2xlLFxuXG4gICAgQ2xpZW50RnVuY3Rpb24sXG5cbiAgICBTZWxlY3RvcixcblxuICAgIFJlcXVlc3RMb2dnZXIsXG5cbiAgICBSZXF1ZXN0TW9jayxcblxuICAgIGdldCBSZXF1ZXN0SG9vayAoKSB7XG4gICAgICAgIGlmICghUmVxdWVzdEhvb2spXG4gICAgICAgICAgICBSZXF1ZXN0SG9vayA9IHJlcXVpcmUoJy4uL3JlcXVlc3QtaG9va3MvaG9vaycpO1xuXG4gICAgICAgIHJldHVybiBSZXF1ZXN0SG9vaztcbiAgICB9LFxuXG4gICAgZ2V0IHQgKCkge1xuICAgICAgICBpZiAoIXRlc3RDb250cm9sbGVyUHJveHkpXG4gICAgICAgICAgICB0ZXN0Q29udHJvbGxlclByb3h5ID0gcmVxdWlyZSgnLi4vdGVzdC1jb250cm9sbGVyL3Byb3h5Jyk7XG5cbiAgICAgICAgcmV0dXJuIHRlc3RDb250cm9sbGVyUHJveHk7XG4gICAgfVxufTtcbiJdfQ==
|
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
const type_assertions_1 = require("../../errors/runtime/type-assertions");
|
|
4
|
-
function assertRequestHookType(hooks) {
|
|
5
|
-
hooks.forEach(hook => type_assertions_1.assertType(type_assertions_1.is.requestHookSubclass, 'requestHooks', `Hook`, hook));
|
|
6
|
-
}
|
|
7
|
-
exports.default = assertRequestHookType;
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const type_assertions_1 = require("../../errors/runtime/type-assertions");
|
|
4
|
+
function assertRequestHookType(hooks) {
|
|
5
|
+
hooks.forEach(hook => type_assertions_1.assertType(type_assertions_1.is.requestHookSubclass, 'requestHooks', `Hook`, hook));
|
|
6
|
+
}
|
|
7
|
+
exports.default = assertRequestHookType;
|
|
8
8
|
module.exports = exports.default;
|
|
9
9
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXNzZXJ0LXR5cGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXBpL3JlcXVlc3QtaG9va3MvYXNzZXJ0LXR5cGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSwwRUFBc0U7QUFHdEUsU0FBd0IscUJBQXFCLENBQUUsS0FBb0I7SUFDL0QsS0FBSyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLDRCQUFVLENBQUMsb0JBQUUsQ0FBQyxtQkFBbUIsRUFBRSxjQUFjLEVBQUUsTUFBTSxFQUFFLElBQUksQ0FBQyxDQUFDLENBQUM7QUFDNUYsQ0FBQztBQUZELHdDQUVDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgYXNzZXJ0VHlwZSwgaXMgfSBmcm9tICcuLi8uLi9lcnJvcnMvcnVudGltZS90eXBlLWFzc2VydGlvbnMnO1xuaW1wb3J0IFJlcXVlc3RIb29rIGZyb20gJy4vaG9vayc7XG5cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIGFzc2VydFJlcXVlc3RIb29rVHlwZSAoaG9va3M6IFJlcXVlc3RIb29rW10pOiB2b2lkIHtcbiAgICBob29rcy5mb3JFYWNoKGhvb2sgPT4gYXNzZXJ0VHlwZShpcy5yZXF1ZXN0SG9va1N1YmNsYXNzLCAncmVxdWVzdEhvb2tzJywgYEhvb2tgLCBob29rKSk7XG59XG4iXX0=
|
|
@@ -1,11 +1,11 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
var RequestHookMethodNames;
|
|
4
|
-
(function (RequestHookMethodNames) {
|
|
5
|
-
RequestHookMethodNames["onRequest"] = "onRequest";
|
|
6
|
-
RequestHookMethodNames["_onConfigureResponse"] = "_onConfigureResponse";
|
|
7
|
-
RequestHookMethodNames["onResponse"] = "onResponse";
|
|
8
|
-
})(RequestHookMethodNames || (RequestHookMethodNames = {}));
|
|
9
|
-
exports.default = RequestHookMethodNames;
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
var RequestHookMethodNames;
|
|
4
|
+
(function (RequestHookMethodNames) {
|
|
5
|
+
RequestHookMethodNames["onRequest"] = "onRequest";
|
|
6
|
+
RequestHookMethodNames["_onConfigureResponse"] = "_onConfigureResponse";
|
|
7
|
+
RequestHookMethodNames["onResponse"] = "onResponse";
|
|
8
|
+
})(RequestHookMethodNames || (RequestHookMethodNames = {}));
|
|
9
|
+
exports.default = RequestHookMethodNames;
|
|
10
10
|
module.exports = exports.default;
|
|
11
11
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaG9vay1tZXRob2QtbmFtZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXBpL3JlcXVlc3QtaG9va3MvaG9vay1tZXRob2QtbmFtZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSxJQUFLLHNCQUlKO0FBSkQsV0FBSyxzQkFBc0I7SUFDdkIsaURBQXVCLENBQUE7SUFDdkIsdUVBQTZDLENBQUE7SUFDN0MsbURBQXlCLENBQUE7QUFDN0IsQ0FBQyxFQUpJLHNCQUFzQixLQUF0QixzQkFBc0IsUUFJMUI7QUFFRCxrQkFBZSxzQkFBc0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImVudW0gUmVxdWVzdEhvb2tNZXRob2ROYW1lcyB7XG4gICAgb25SZXF1ZXN0ID0gJ29uUmVxdWVzdCcsXG4gICAgX29uQ29uZmlndXJlUmVzcG9uc2UgPSAnX29uQ29uZmlndXJlUmVzcG9uc2UnLFxuICAgIG9uUmVzcG9uc2UgPSAnb25SZXNwb25zZSdcbn1cblxuZXhwb3J0IGRlZmF1bHQgUmVxdWVzdEhvb2tNZXRob2ROYW1lcztcbiJdfQ==
|
|
@@ -1,34 +1,34 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
const testcafe_hammerhead_1 = require("testcafe-hammerhead");
|
|
4
|
-
const test_run_1 = require("../../errors/test-run");
|
|
5
|
-
class RequestHook {
|
|
6
|
-
constructor(ruleInit, responseEventConfigureOpts) {
|
|
7
|
-
this._requestFilterRules = this._prepareRules(ruleInit);
|
|
8
|
-
this._responseEventConfigureOpts = responseEventConfigureOpts;
|
|
9
|
-
this._warningLog = null;
|
|
10
|
-
this.id = testcafe_hammerhead_1.generateUniqueId();
|
|
11
|
-
this._className = this.constructor.name;
|
|
12
|
-
}
|
|
13
|
-
_prepareRules(ruleInit) {
|
|
14
|
-
if (Array.isArray(ruleInit) && !ruleInit.length)
|
|
15
|
-
return [];
|
|
16
|
-
const rules = testcafe_hammerhead_1.RequestFilterRule.fromArray(ruleInit);
|
|
17
|
-
return !rules.length ? [testcafe_hammerhead_1.RequestFilterRule.ANY] : rules;
|
|
18
|
-
}
|
|
19
|
-
async onRequest(event) {
|
|
20
|
-
throw new test_run_1.RequestHookNotImplementedMethodError('onRequest', this.constructor.name);
|
|
21
|
-
}
|
|
22
|
-
async _onConfigureResponse(event) {
|
|
23
|
-
if (!this._responseEventConfigureOpts)
|
|
24
|
-
return;
|
|
25
|
-
event.opts.includeHeaders = this._responseEventConfigureOpts.includeHeaders;
|
|
26
|
-
event.opts.includeBody = this._responseEventConfigureOpts.includeBody;
|
|
27
|
-
}
|
|
28
|
-
async onResponse(event) {
|
|
29
|
-
throw new test_run_1.RequestHookNotImplementedMethodError('onResponse', this.constructor.name);
|
|
30
|
-
}
|
|
31
|
-
}
|
|
32
|
-
exports.default = RequestHook;
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const testcafe_hammerhead_1 = require("testcafe-hammerhead");
|
|
4
|
+
const test_run_1 = require("../../errors/test-run");
|
|
5
|
+
class RequestHook {
|
|
6
|
+
constructor(ruleInit, responseEventConfigureOpts) {
|
|
7
|
+
this._requestFilterRules = this._prepareRules(ruleInit);
|
|
8
|
+
this._responseEventConfigureOpts = responseEventConfigureOpts;
|
|
9
|
+
this._warningLog = null;
|
|
10
|
+
this.id = testcafe_hammerhead_1.generateUniqueId();
|
|
11
|
+
this._className = this.constructor.name;
|
|
12
|
+
}
|
|
13
|
+
_prepareRules(ruleInit) {
|
|
14
|
+
if (Array.isArray(ruleInit) && !ruleInit.length)
|
|
15
|
+
return [];
|
|
16
|
+
const rules = testcafe_hammerhead_1.RequestFilterRule.fromArray(ruleInit);
|
|
17
|
+
return !rules.length ? [testcafe_hammerhead_1.RequestFilterRule.ANY] : rules;
|
|
18
|
+
}
|
|
19
|
+
async onRequest(event) {
|
|
20
|
+
throw new test_run_1.RequestHookNotImplementedMethodError('onRequest', this.constructor.name);
|
|
21
|
+
}
|
|
22
|
+
async _onConfigureResponse(event) {
|
|
23
|
+
if (!this._responseEventConfigureOpts)
|
|
24
|
+
return;
|
|
25
|
+
event.opts.includeHeaders = this._responseEventConfigureOpts.includeHeaders;
|
|
26
|
+
event.opts.includeBody = this._responseEventConfigureOpts.includeBody;
|
|
27
|
+
}
|
|
28
|
+
async onResponse(event) {
|
|
29
|
+
throw new test_run_1.RequestHookNotImplementedMethodError('onResponse', this.constructor.name);
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
exports.default = RequestHook;
|
|
33
33
|
module.exports = exports.default;
|
|
34
34
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaG9vay5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9hcGkvcmVxdWVzdC1ob29rcy9ob29rLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsNkRBUTZCO0FBRTdCLG9EQUE2RTtBQUk3RSxNQUE4QixXQUFXO0lBT3JDLFlBQXVCLFFBQTBELEVBQUUsMEJBQTBEO1FBQ3pJLElBQUksQ0FBQyxtQkFBbUIsR0FBVyxJQUFJLENBQUMsYUFBYSxDQUFDLFFBQVEsQ0FBQyxDQUFDO1FBQ2hFLElBQUksQ0FBQywyQkFBMkIsR0FBRywwQkFBMEIsQ0FBQztRQUM5RCxJQUFJLENBQUMsV0FBVyxHQUFtQixJQUFJLENBQUM7UUFDeEMsSUFBSSxDQUFDLEVBQUUsR0FBNEIsc0NBQWdCLEVBQUUsQ0FBQztRQUN0RCxJQUFJLENBQUMsVUFBVSxHQUFvQixJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQztJQUM3RCxDQUFDO0lBRU8sYUFBYSxDQUFFLFFBQTBEO1FBQzdFLElBQUksS0FBSyxDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxNQUFNO1lBQzNDLE9BQU8sRUFBRSxDQUFDO1FBRWQsTUFBTSxLQUFLLEdBQUcsdUNBQWlCLENBQUMsU0FBUyxDQUFDLFFBQVEsQ0FBQyxDQUFDO1FBRXBELE9BQU8sQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDLHVDQUFpQixDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUM7SUFDM0QsQ0FBQztJQUVTLEtBQUssQ0FBQyxTQUFTLENBQUUsS0FBbUI7UUFDMUMsTUFBTSxJQUFJLCtDQUFvQyxDQUFDLFdBQVcsRUFBRSxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ3ZGLENBQUM7SUFFTyxLQUFLLENBQUMsb0JBQW9CLENBQUUsS0FBNkI7UUFDN0QsSUFBSSxDQUFDLElBQUksQ0FBQywyQkFBMkI7WUFDakMsT0FBTztRQUVYLEtBQUssQ0FBQyxJQUFJLENBQUMsY0FBYyxHQUFHLElBQUksQ0FBQywyQkFBMkIsQ0FBQyxjQUFjLENBQUM7UUFDNUUsS0FBSyxDQUFDLElBQUksQ0FBQyxXQUFXLEdBQU0sSUFBSSxDQUFDLDJCQUEyQixDQUFDLFdBQVcsQ0FBQztJQUM3RSxDQUFDO0lBRVMsS0FBSyxDQUFDLFVBQVUsQ0FBRSxLQUFvQjtRQUM1QyxNQUFNLElBQUksK0NBQW9DLENBQUMsWUFBWSxFQUFFLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDeEYsQ0FBQztDQUNKO0FBdkNELDhCQXVDQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gICAgQ29uZmlndXJlUmVzcG9uc2VFdmVudCxcbiAgICBDb25maWd1cmVSZXNwb25zZUV2ZW50T3B0aW9ucyxcbiAgICBSZXF1ZXN0RXZlbnQsXG4gICAgUmVzcG9uc2VFdmVudCxcbiAgICBSZXF1ZXN0RmlsdGVyUnVsZSxcbiAgICBSZXF1ZXN0RmlsdGVyUnVsZUluaXQsXG4gICAgZ2VuZXJhdGVVbmlxdWVJZFxufSBmcm9tICd0ZXN0Y2FmZS1oYW1tZXJoZWFkJztcblxuaW1wb3J0IHsgUmVxdWVzdEhvb2tOb3RJbXBsZW1lbnRlZE1ldGhvZEVycm9yIH0gZnJvbSAnLi4vLi4vZXJyb3JzL3Rlc3QtcnVuJztcbmltcG9ydCBXYXJuaW5nTG9nIGZyb20gJy4uLy4uL25vdGlmaWNhdGlvbnMvd2FybmluZy1sb2cnO1xuXG5cbmV4cG9ydCBkZWZhdWx0IGFic3RyYWN0IGNsYXNzIFJlcXVlc3RIb29rIHtcbiAgICBwdWJsaWMgX3JlcXVlc3RGaWx0ZXJSdWxlczogUmVxdWVzdEZpbHRlclJ1bGVbXTtcbiAgICBwdWJsaWMgcmVhZG9ubHkgX3Jlc3BvbnNlRXZlbnRDb25maWd1cmVPcHRzPzogQ29uZmlndXJlUmVzcG9uc2VFdmVudE9wdGlvbnM7XG4gICAgcHVibGljIF93YXJuaW5nTG9nOiBXYXJuaW5nTG9nIHwgbnVsbDtcbiAgICBwdWJsaWMgcmVhZG9ubHkgaWQ6IHN0cmluZztcbiAgICBwdWJsaWMgX2NsYXNzTmFtZTogc3RyaW5nO1xuXG4gICAgcHJvdGVjdGVkIGNvbnN0cnVjdG9yIChydWxlSW5pdD86IFJlcXVlc3RGaWx0ZXJSdWxlSW5pdCB8IFJlcXVlc3RGaWx0ZXJSdWxlSW5pdFtdLCByZXNwb25zZUV2ZW50Q29uZmlndXJlT3B0cz86IENvbmZpZ3VyZVJlc3BvbnNlRXZlbnRPcHRpb25zKSB7XG4gICAgICAgIHRoaXMuX3JlcXVlc3RGaWx0ZXJSdWxlcyAgICAgICAgID0gdGhpcy5fcHJlcGFyZVJ1bGVzKHJ1bGVJbml0KTtcbiAgICAgICAgdGhpcy5fcmVzcG9uc2VFdmVudENvbmZpZ3VyZU9wdHMgPSByZXNwb25zZUV2ZW50Q29uZmlndXJlT3B0cztcbiAgICAgICAgdGhpcy5fd2FybmluZ0xvZyAgICAgICAgICAgICAgICAgPSBudWxsO1xuICAgICAgICB0aGlzLmlkICAgICAgICAgICAgICAgICAgICAgICAgICA9IGdlbmVyYXRlVW5pcXVlSWQoKTtcbiAgICAgICAgdGhpcy5fY2xhc3NOYW1lICAgICAgICAgICAgICAgICAgPSB0aGlzLmNvbnN0cnVjdG9yLm5hbWU7XG4gICAgfVxuXG4gICAgcHJpdmF0ZSBfcHJlcGFyZVJ1bGVzIChydWxlSW5pdD86IFJlcXVlc3RGaWx0ZXJSdWxlSW5pdCB8IFJlcXVlc3RGaWx0ZXJSdWxlSW5pdFtdKTogUmVxdWVzdEZpbHRlclJ1bGVbXSB7XG4gICAgICAgIGlmIChBcnJheS5pc0FycmF5KHJ1bGVJbml0KSAmJiAhcnVsZUluaXQubGVuZ3RoKVxuICAgICAgICAgICAgcmV0dXJuIFtdO1xuXG4gICAgICAgIGNvbnN0IHJ1bGVzID0gUmVxdWVzdEZpbHRlclJ1bGUuZnJvbUFycmF5KHJ1bGVJbml0KTtcblxuICAgICAgICByZXR1cm4gIXJ1bGVzLmxlbmd0aCA/IFtSZXF1ZXN0RmlsdGVyUnVsZS5BTlldIDogcnVsZXM7XG4gICAgfVxuXG4gICAgcHJvdGVjdGVkIGFzeW5jIG9uUmVxdWVzdCAoZXZlbnQ6IFJlcXVlc3RFdmVudCk6IFByb21pc2U8dm9pZD4geyAvLyBlc2xpbnQtZGlzYWJsZS1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby11bnVzZWQtdmFyc1xuICAgICAgICB0aHJvdyBuZXcgUmVxdWVzdEhvb2tOb3RJbXBsZW1lbnRlZE1ldGhvZEVycm9yKCdvblJlcXVlc3QnLCB0aGlzLmNvbnN0cnVjdG9yLm5hbWUpO1xuICAgIH1cblxuICAgIHByaXZhdGUgYXN5bmMgX29uQ29uZmlndXJlUmVzcG9uc2UgKGV2ZW50OiBDb25maWd1cmVSZXNwb25zZUV2ZW50KTogUHJvbWlzZTx2b2lkPiB7XG4gICAgICAgIGlmICghdGhpcy5fcmVzcG9uc2VFdmVudENvbmZpZ3VyZU9wdHMpXG4gICAgICAgICAgICByZXR1cm47XG5cbiAgICAgICAgZXZlbnQub3B0cy5pbmNsdWRlSGVhZGVycyA9IHRoaXMuX3Jlc3BvbnNlRXZlbnRDb25maWd1cmVPcHRzLmluY2x1ZGVIZWFkZXJzO1xuICAgICAgICBldmVudC5vcHRzLmluY2x1ZGVCb2R5ICAgID0gdGhpcy5fcmVzcG9uc2VFdmVudENvbmZpZ3VyZU9wdHMuaW5jbHVkZUJvZHk7XG4gICAgfVxuXG4gICAgcHJvdGVjdGVkIGFzeW5jIG9uUmVzcG9uc2UgKGV2ZW50OiBSZXNwb25zZUV2ZW50KTogUHJvbWlzZTx2b2lkPiB7IC8vIGVzbGludC1kaXNhYmxlLWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLXVudXNlZC12YXJzXG4gICAgICAgIHRocm93IG5ldyBSZXF1ZXN0SG9va05vdEltcGxlbWVudGVkTWV0aG9kRXJyb3IoJ29uUmVzcG9uc2UnLCB0aGlzLmNvbnN0cnVjdG9yLm5hbWUpO1xuICAgIH1cbn1cbiJdfQ==
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZXJmYWNlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9hcGkvcmVxdWVzdC1ob29rcy9pbnRlcmZhY2VzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgaW50ZXJmYWNlIFJlcXVlc3RIb29rTG9nT3B0aW9ucyB7XG4gICAgbG9nUmVxdWVzdEhlYWRlcnM6IGJvb2xlYW47XG4gICAgbG9nUmVxdWVzdEJvZHk6IGJvb2xlYW47XG4gICAgc3RyaW5naWZ5UmVxdWVzdEJvZHk6IGJvb2xlYW47XG4gICAgbG9nUmVzcG9uc2VIZWFkZXJzOiBib29sZWFuO1xuICAgIGxvZ1Jlc3BvbnNlQm9keTogYm9vbGVhbjtcbiAgICBzdHJpbmdpZnlSZXNwb25zZUJvZHk6IGJvb2xlYW47XG59XG5cbmV4cG9ydCB0eXBlIFJlcXVlc3RIb29rTG9nT3B0aW9uc0luaXQgPSBQYXJ0aWFsPFJlcXVlc3RIb29rTG9nT3B0aW9ucz47XG4iXX0=
|
|
@@ -1,114 +1,114 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
-
};
|
|
5
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
const testcafe_hammerhead_1 = require("testcafe-hammerhead");
|
|
7
|
-
const hook_1 = __importDefault(require("./hook"));
|
|
8
|
-
const parse_user_agent_1 = __importDefault(require("../../utils/parse-user-agent"));
|
|
9
|
-
const test_run_tracker_1 = __importDefault(require("../test-run-tracker"));
|
|
10
|
-
const re_executable_promise_1 = __importDefault(require("../../utils/re-executable-promise"));
|
|
11
|
-
const runtime_1 = require("../../errors/runtime");
|
|
12
|
-
const types_1 = require("../../errors/types");
|
|
13
|
-
const DEFAULT_OPTIONS = {
|
|
14
|
-
logRequestHeaders: false,
|
|
15
|
-
logRequestBody: false,
|
|
16
|
-
stringifyRequestBody: false,
|
|
17
|
-
logResponseHeaders: false,
|
|
18
|
-
logResponseBody: false,
|
|
19
|
-
stringifyResponseBody: false
|
|
20
|
-
};
|
|
21
|
-
const REQUEST_LOGGER_CLASS_NAME = 'RequestLogger';
|
|
22
|
-
class RequestLoggerImplementation extends hook_1.default {
|
|
23
|
-
constructor(requestFilterRuleInit, options) {
|
|
24
|
-
const effectiveOptions = Object.assign({}, DEFAULT_OPTIONS, options);
|
|
25
|
-
RequestLoggerImplementation._assertLogOptions(effectiveOptions);
|
|
26
|
-
const configureResponseEventOptions = new testcafe_hammerhead_1.ConfigureResponseEventOptions(effectiveOptions.logResponseHeaders, effectiveOptions.logResponseBody);
|
|
27
|
-
super(requestFilterRuleInit, configureResponseEventOptions);
|
|
28
|
-
this._className = REQUEST_LOGGER_CLASS_NAME;
|
|
29
|
-
this._options = effectiveOptions;
|
|
30
|
-
this._internalRequests = {};
|
|
31
|
-
}
|
|
32
|
-
static _assertLogOptions(logOptions) {
|
|
33
|
-
if (!logOptions.logRequestBody && logOptions.stringifyRequestBody)
|
|
34
|
-
throw new runtime_1.APIError('RequestLogger', types_1.RUNTIME_ERRORS.requestHookConfigureAPIError, 'RequestLogger', 'Cannot stringify the request body because it is not logged. Specify { logRequestBody: true } in log options.');
|
|
35
|
-
if (!logOptions.logResponseBody && logOptions.stringifyResponseBody)
|
|
36
|
-
throw new runtime_1.APIError('RequestLogger', types_1.RUNTIME_ERRORS.requestHookConfigureAPIError, 'RequestLogger', 'Cannot stringify the response body because it is not logged. Specify { logResponseBody: true } in log options.');
|
|
37
|
-
}
|
|
38
|
-
async onRequest(event) {
|
|
39
|
-
const loggedReq = {
|
|
40
|
-
id: event._requestInfo.requestId,
|
|
41
|
-
testRunId: event._requestInfo.sessionId,
|
|
42
|
-
userAgent: parse_user_agent_1.default(event._requestInfo.userAgent).prettyUserAgent,
|
|
43
|
-
request: {
|
|
44
|
-
timestamp: Date.now(),
|
|
45
|
-
url: event._requestInfo.url,
|
|
46
|
-
method: event._requestInfo.method,
|
|
47
|
-
}
|
|
48
|
-
};
|
|
49
|
-
if (this._options.logRequestHeaders)
|
|
50
|
-
loggedReq.request.headers = Object.assign({}, event._requestInfo.headers);
|
|
51
|
-
if (this._options.logRequestBody)
|
|
52
|
-
loggedReq.request.body = this._options.stringifyRequestBody ? event._requestInfo.body.toString() : event._requestInfo.body;
|
|
53
|
-
this._internalRequests[loggedReq.id] = loggedReq;
|
|
54
|
-
}
|
|
55
|
-
async onResponse(event) {
|
|
56
|
-
const loggedReq = this._internalRequests[event.requestId];
|
|
57
|
-
// NOTE: If the 'clear' method is called during a long running request,
|
|
58
|
-
// we should not save a response part - request part has been already removed.
|
|
59
|
-
if (!loggedReq)
|
|
60
|
-
return;
|
|
61
|
-
loggedReq.response = {
|
|
62
|
-
statusCode: event.statusCode,
|
|
63
|
-
timestamp: Date.now()
|
|
64
|
-
};
|
|
65
|
-
if (this._options.logResponseHeaders)
|
|
66
|
-
loggedReq.response.headers = Object.assign({}, event.headers);
|
|
67
|
-
if (this._options.logResponseBody) {
|
|
68
|
-
loggedReq.response.body = this._options.stringifyResponseBody && event.body
|
|
69
|
-
? event.body.toString()
|
|
70
|
-
: event.body;
|
|
71
|
-
}
|
|
72
|
-
}
|
|
73
|
-
_prepareInternalRequestInfo() {
|
|
74
|
-
const testRun = test_run_tracker_1.default.resolveContextTestRun();
|
|
75
|
-
let preparedRequests = Object.values(this._internalRequests);
|
|
76
|
-
if (testRun)
|
|
77
|
-
preparedRequests = preparedRequests.filter(r => r.testRunId === testRun.id);
|
|
78
|
-
return preparedRequests;
|
|
79
|
-
}
|
|
80
|
-
_getCompletedRequests() {
|
|
81
|
-
return this._prepareInternalRequestInfo().filter(r => r.response);
|
|
82
|
-
}
|
|
83
|
-
// API
|
|
84
|
-
contains(predicate) {
|
|
85
|
-
return re_executable_promise_1.default.fromFn(async () => {
|
|
86
|
-
return !!this._getCompletedRequests().find(predicate);
|
|
87
|
-
});
|
|
88
|
-
}
|
|
89
|
-
count(predicate) {
|
|
90
|
-
return re_executable_promise_1.default.fromFn(async () => {
|
|
91
|
-
return this._getCompletedRequests().filter(predicate).length;
|
|
92
|
-
});
|
|
93
|
-
}
|
|
94
|
-
clear() {
|
|
95
|
-
const testRun = test_run_tracker_1.default.resolveContextTestRun();
|
|
96
|
-
if (testRun) {
|
|
97
|
-
Object.keys(this._internalRequests).forEach(id => {
|
|
98
|
-
if (this._internalRequests[id].testRunId === testRun.id)
|
|
99
|
-
delete this._internalRequests[id];
|
|
100
|
-
});
|
|
101
|
-
}
|
|
102
|
-
else
|
|
103
|
-
this._internalRequests = {};
|
|
104
|
-
}
|
|
105
|
-
get requests() {
|
|
106
|
-
return this._prepareInternalRequestInfo();
|
|
107
|
-
}
|
|
108
|
-
}
|
|
109
|
-
function createRequestLogger(requestFilterRuleInit, logOptions) {
|
|
110
|
-
return new RequestLoggerImplementation(requestFilterRuleInit, logOptions);
|
|
111
|
-
}
|
|
112
|
-
exports.default = createRequestLogger;
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
const testcafe_hammerhead_1 = require("testcafe-hammerhead");
|
|
7
|
+
const hook_1 = __importDefault(require("./hook"));
|
|
8
|
+
const parse_user_agent_1 = __importDefault(require("../../utils/parse-user-agent"));
|
|
9
|
+
const test_run_tracker_1 = __importDefault(require("../test-run-tracker"));
|
|
10
|
+
const re_executable_promise_1 = __importDefault(require("../../utils/re-executable-promise"));
|
|
11
|
+
const runtime_1 = require("../../errors/runtime");
|
|
12
|
+
const types_1 = require("../../errors/types");
|
|
13
|
+
const DEFAULT_OPTIONS = {
|
|
14
|
+
logRequestHeaders: false,
|
|
15
|
+
logRequestBody: false,
|
|
16
|
+
stringifyRequestBody: false,
|
|
17
|
+
logResponseHeaders: false,
|
|
18
|
+
logResponseBody: false,
|
|
19
|
+
stringifyResponseBody: false
|
|
20
|
+
};
|
|
21
|
+
const REQUEST_LOGGER_CLASS_NAME = 'RequestLogger';
|
|
22
|
+
class RequestLoggerImplementation extends hook_1.default {
|
|
23
|
+
constructor(requestFilterRuleInit, options) {
|
|
24
|
+
const effectiveOptions = Object.assign({}, DEFAULT_OPTIONS, options);
|
|
25
|
+
RequestLoggerImplementation._assertLogOptions(effectiveOptions);
|
|
26
|
+
const configureResponseEventOptions = new testcafe_hammerhead_1.ConfigureResponseEventOptions(effectiveOptions.logResponseHeaders, effectiveOptions.logResponseBody);
|
|
27
|
+
super(requestFilterRuleInit, configureResponseEventOptions);
|
|
28
|
+
this._className = REQUEST_LOGGER_CLASS_NAME;
|
|
29
|
+
this._options = effectiveOptions;
|
|
30
|
+
this._internalRequests = {};
|
|
31
|
+
}
|
|
32
|
+
static _assertLogOptions(logOptions) {
|
|
33
|
+
if (!logOptions.logRequestBody && logOptions.stringifyRequestBody)
|
|
34
|
+
throw new runtime_1.APIError('RequestLogger', types_1.RUNTIME_ERRORS.requestHookConfigureAPIError, 'RequestLogger', 'Cannot stringify the request body because it is not logged. Specify { logRequestBody: true } in log options.');
|
|
35
|
+
if (!logOptions.logResponseBody && logOptions.stringifyResponseBody)
|
|
36
|
+
throw new runtime_1.APIError('RequestLogger', types_1.RUNTIME_ERRORS.requestHookConfigureAPIError, 'RequestLogger', 'Cannot stringify the response body because it is not logged. Specify { logResponseBody: true } in log options.');
|
|
37
|
+
}
|
|
38
|
+
async onRequest(event) {
|
|
39
|
+
const loggedReq = {
|
|
40
|
+
id: event._requestInfo.requestId,
|
|
41
|
+
testRunId: event._requestInfo.sessionId,
|
|
42
|
+
userAgent: parse_user_agent_1.default(event._requestInfo.userAgent).prettyUserAgent,
|
|
43
|
+
request: {
|
|
44
|
+
timestamp: Date.now(),
|
|
45
|
+
url: event._requestInfo.url,
|
|
46
|
+
method: event._requestInfo.method,
|
|
47
|
+
}
|
|
48
|
+
};
|
|
49
|
+
if (this._options.logRequestHeaders)
|
|
50
|
+
loggedReq.request.headers = Object.assign({}, event._requestInfo.headers);
|
|
51
|
+
if (this._options.logRequestBody)
|
|
52
|
+
loggedReq.request.body = this._options.stringifyRequestBody ? event._requestInfo.body.toString() : event._requestInfo.body;
|
|
53
|
+
this._internalRequests[loggedReq.id] = loggedReq;
|
|
54
|
+
}
|
|
55
|
+
async onResponse(event) {
|
|
56
|
+
const loggedReq = this._internalRequests[event.requestId];
|
|
57
|
+
// NOTE: If the 'clear' method is called during a long running request,
|
|
58
|
+
// we should not save a response part - request part has been already removed.
|
|
59
|
+
if (!loggedReq)
|
|
60
|
+
return;
|
|
61
|
+
loggedReq.response = {
|
|
62
|
+
statusCode: event.statusCode,
|
|
63
|
+
timestamp: Date.now()
|
|
64
|
+
};
|
|
65
|
+
if (this._options.logResponseHeaders)
|
|
66
|
+
loggedReq.response.headers = Object.assign({}, event.headers);
|
|
67
|
+
if (this._options.logResponseBody) {
|
|
68
|
+
loggedReq.response.body = this._options.stringifyResponseBody && event.body
|
|
69
|
+
? event.body.toString()
|
|
70
|
+
: event.body;
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
_prepareInternalRequestInfo() {
|
|
74
|
+
const testRun = test_run_tracker_1.default.resolveContextTestRun();
|
|
75
|
+
let preparedRequests = Object.values(this._internalRequests);
|
|
76
|
+
if (testRun)
|
|
77
|
+
preparedRequests = preparedRequests.filter(r => r.testRunId === testRun.id);
|
|
78
|
+
return preparedRequests;
|
|
79
|
+
}
|
|
80
|
+
_getCompletedRequests() {
|
|
81
|
+
return this._prepareInternalRequestInfo().filter(r => r.response);
|
|
82
|
+
}
|
|
83
|
+
// API
|
|
84
|
+
contains(predicate) {
|
|
85
|
+
return re_executable_promise_1.default.fromFn(async () => {
|
|
86
|
+
return !!this._getCompletedRequests().find(predicate);
|
|
87
|
+
});
|
|
88
|
+
}
|
|
89
|
+
count(predicate) {
|
|
90
|
+
return re_executable_promise_1.default.fromFn(async () => {
|
|
91
|
+
return this._getCompletedRequests().filter(predicate).length;
|
|
92
|
+
});
|
|
93
|
+
}
|
|
94
|
+
clear() {
|
|
95
|
+
const testRun = test_run_tracker_1.default.resolveContextTestRun();
|
|
96
|
+
if (testRun) {
|
|
97
|
+
Object.keys(this._internalRequests).forEach(id => {
|
|
98
|
+
if (this._internalRequests[id].testRunId === testRun.id)
|
|
99
|
+
delete this._internalRequests[id];
|
|
100
|
+
});
|
|
101
|
+
}
|
|
102
|
+
else
|
|
103
|
+
this._internalRequests = {};
|
|
104
|
+
}
|
|
105
|
+
get requests() {
|
|
106
|
+
return this._prepareInternalRequestInfo();
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
function createRequestLogger(requestFilterRuleInit, logOptions) {
|
|
110
|
+
return new RequestLoggerImplementation(requestFilterRuleInit, logOptions);
|
|
111
|
+
}
|
|
112
|
+
exports.default = createRequestLogger;
|
|
113
113
|
module.exports = exports.default;
|
|
114
114
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVxdWVzdC1sb2dnZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXBpL3JlcXVlc3QtaG9va3MvcmVxdWVzdC1sb2dnZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSw2REFLNkI7QUFFN0Isa0RBQWlDO0FBQ2pDLG9GQUEwRDtBQUMxRCwyRUFBaUQ7QUFDakQsOEZBQW9FO0FBQ3BFLGtEQUFnRDtBQUNoRCw4Q0FBb0Q7QUFVcEQsTUFBTSxlQUFlLEdBQTBCO0lBQzNDLGlCQUFpQixFQUFNLEtBQUs7SUFDNUIsY0FBYyxFQUFTLEtBQUs7SUFDNUIsb0JBQW9CLEVBQUcsS0FBSztJQUM1QixrQkFBa0IsRUFBSyxLQUFLO0lBQzVCLGVBQWUsRUFBUSxLQUFLO0lBQzVCLHFCQUFxQixFQUFFLEtBQUs7Q0FDL0IsQ0FBQztBQXlCRixNQUFNLHlCQUF5QixHQUFHLGVBQWUsQ0FBQztBQUVsRCxNQUFNLDJCQUE0QixTQUFRLGNBQVc7SUFJakQsWUFBb0IscUJBQXVFLEVBQUUsT0FBbUM7UUFDNUgsTUFBTSxnQkFBZ0IsR0FBRyxNQUFNLENBQUMsTUFBTSxDQUFDLEVBQUUsRUFBRSxlQUFlLEVBQUUsT0FBTyxDQUEwQixDQUFDO1FBRTlGLDJCQUEyQixDQUFDLGlCQUFpQixDQUFDLGdCQUFnQixDQUFDLENBQUM7UUFFaEUsTUFBTSw2QkFBNkIsR0FBRyxJQUFJLG1EQUE2QixDQUFDLGdCQUFnQixDQUFDLGtCQUFrQixFQUFFLGdCQUFnQixDQUFDLGVBQWUsQ0FBQyxDQUFDO1FBRS9JLEtBQUssQ0FBQyxxQkFBcUIsRUFBRSw2QkFBNkIsQ0FBQyxDQUFDO1FBRTVELElBQUksQ0FBQyxVQUFVLEdBQVUseUJBQXlCLENBQUM7UUFDbkQsSUFBSSxDQUFDLFFBQVEsR0FBWSxnQkFBZ0IsQ0FBQztRQUMxQyxJQUFJLENBQUMsaUJBQWlCLEdBQUcsRUFBRSxDQUFDO0lBQ2hDLENBQUM7SUFFTyxNQUFNLENBQUMsaUJB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QUMsRUFBRSxDQUFDLENBQUM7WUFDMUMsQ0FBQyxDQUFDLENBQUM7U0FDTjs7WUFFRyxJQUFJLENBQUMsaUJBQWlCLEdBQUcsRUFBRSxDQUFDO0lBQ3BDLENBQUM7SUFFRCxJQUFXLFFBQVE7UUFDZixPQUFPLElBQUksQ0FBQywyQkFBMkIsRUFBRSxDQUFDO0lBQzlDLENBQUM7Q0FDSjtBQUVELFNBQXdCLG1CQUFtQixDQUFFLHFCQUFrRixFQUFFLFVBQXFDO0lBQ2xLLE9BQU8sSUFBSSwyQkFBMkIsQ0FBQyxxQkFBcUIsRUFBRSxVQUFVLENBQUMsQ0FBQztBQUM5RSxDQUFDO0FBRkQsc0NBRUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICAgIENvbmZpZ3VyZVJlc3BvbnNlRXZlbnRPcHRpb25zLFxuICAgIFJlcXVlc3RFdmVudCxcbiAgICBSZXNwb25zZUV2ZW50LFxuICAgIFJlcXVlc3RGaWx0ZXJSdWxlSW5pdFxufSBmcm9tICd0ZXN0Y2FmZS1oYW1tZXJoZWFkJztcblxuaW1wb3J0IFJlcXVlc3RIb29rIGZyb20gJy4vaG9vayc7XG5pbXBvcnQgcGFyc2VVc2VyQWdlbnQgZnJvbSAnLi4vLi4vdXRpbHMvcGFyc2UtdXNlci1hZ2VudCc7XG5pbXBvcnQgdGVzdFJ1blRyYWNrZXIgZnJvbSAnLi4vdGVzdC1ydW4tdHJhY2tlcic7XG5pbXBvcnQgUmVFeGVjdXRhYmxlUHJvbWlzZSBmcm9tICcuLi8uLi91dGlscy9yZS1leGVjdXRhYmxlLXByb21pc2UnO1xuaW1wb3J0IHsgQVBJRXJyb3IgfSBmcm9tICcuLi8uLi9lcnJvcnMvcnVudGltZSc7XG5pbXBvcnQgeyBSVU5USU1FX0VSUk9SUyB9IGZyb20gJy4uLy4uL2Vycm9ycy90eXBlcyc7XG5cbmltcG9ydCB7XG4gICAgUmVxdWVzdEhvb2tMb2dPcHRpb25zSW5pdCxcbiAgICBSZXF1ZXN0SG9va0xvZ09wdGlvbnNcbn0gZnJvbSAnLi9pbnRlcmZhY2VzJztcblxuaW1wb3J0IHsgRGljdGlvbmFyeSB9IGZyb20gJy4uLy4uL2NvbmZpZ3VyYXRpb24vaW50ZXJmYWNlcyc7XG5cblxuY29uc3QgREVGQVVMVF9PUFRJT05TOiBSZXF1ZXN0SG9va0xvZ09wdGlvbnMgPSB7XG4gICAgbG9nUmVxdWVzdEhlYWRlcnM6ICAgICBmYWxzZSxcbiAgICBsb2dSZXF1ZXN0Qm9keTogICAgICAgIGZhbHNlLFxuICAgIHN0cmluZ2lmeVJlcXVlc3RCb2R5OiAgZmFsc2UsXG4gICAgbG9nUmVzcG9uc2VIZWFkZXJzOiAgICBmYWxzZSxcbiAgICBsb2dSZXNwb25zZUJvZHk6ICAgICAgIGZhbHNlLFxuICAgIHN0cmluZ2lmeVJlc3BvbnNlQm9keTogZmFsc2Vcbn07XG5cbmludGVyZmFjZSBPcHRpb25hbGx5TG9nZ2VkUGFydCB7XG4gICAgaGVhZGVycz86IGFueTtcbiAgICBib2R5PzogQnVmZmVyIHwgc3RyaW5nO1xufVxuXG5pbnRlcmZhY2UgTG9nZ2VkUmVxdWVzdFBhcnQgZXh0ZW5kcyBPcHRpb25hbGx5TG9nZ2VkUGFydCB7XG4gICAgdGltZXN0YW1wOiBudW1iZXI7XG4gICAgdXJsOiBzdHJpbmc7XG4gICAgbWV0aG9kOiBzdHJpbmc7XG59XG5pbnRlcmZhY2UgTG9nZ2VkUmVzcG9uc2VQYXJ0IGV4dGVuZHMgT3B0aW9uYWxseUxvZ2dlZFBhcnQge1xuICAgIHN0YXR1c0NvZGU6IG51bWJlcjtcbiAgICB0aW1lc3RhbXA6IG51bWJlcjtcbn1cblxuaW50ZXJmYWNlIExvZ2dlZFJlcXVlc3Qge1xuICAgIGlkOiBzdHJpbmc7XG4gICAgdGVzdFJ1bklkOiBzdHJpbmc7XG4gICAgdXNlckFnZW50OiBzdHJpbmc7XG4gICAgcmVxdWVzdDogTG9nZ2VkUmVxdWVzdFBhcnQ7XG4gICAgcmVzcG9uc2U/OiBMb2dnZWRSZXNwb25zZVBhcnQ7XG59XG5cbmNvbnN0IFJFUVVFU1RfTE9HR0VSX0NMQVNTX05BTUUgPSAnUmVxdWVzdExvZ2dlcic7XG5cbmNsYXNzIFJlcXVlc3RMb2dnZXJJbXBsZW1lbnRhdGlvbiBleHRlbmRzIFJlcXVlc3RIb29rIHtcbiAgICBwcml2YXRlIHJlYWRvbmx5IF9vcHRpb25zOiBSZXF1ZXN0SG9va0xvZ09wdGlvbnM7XG4gICAgcHJpdmF0ZSBfaW50ZXJuYWxSZXF1ZXN0czogRGljdGlvbmFyeTxMb2dnZWRSZXF1ZXN0PjtcblxuICAgIHB1YmxpYyBjb25zdHJ1Y3RvciAocmVxdWVzdEZpbHRlclJ1bGVJbml0PzogUmVxdWVzdEZpbHRlclJ1bGVJbml0IHwgUmVxdWVzdEZpbHRlclJ1bGVJbml0W10sIG9wdGlvbnM/OiBSZXF1ZXN0SG9va0xvZ09wdGlvbnNJbml0KSB7XG4gICAgICAgIGNvbnN0IGVmZmVjdGl2ZU9wdGlvbnMgPSBPYmplY3QuYXNzaWduKHt9LCBERUZBVUxUX09QVElPTlMsIG9wdGlvbnMpIGFzIFJlcXVlc3RIb29rTG9nT3B0aW9ucztcblxuICAgICAgICBSZXF1ZXN0TG9nZ2VySW1wbGVtZW50YXRpb24uX2Fzc2VydExvZ09wdGlvbnMoZWZmZWN0aXZlT3B0aW9ucyk7XG5cbiAgICAgICAgY29uc3QgY29uZmlndXJlUmVzcG9uc2VFdmVudE9wdGlvbnMgPSBuZXcgQ29uZmlndXJlUmVzcG9uc2VFdmVudE9wdGlvbnMoZWZmZWN0aXZlT3B0aW9ucy5sb2dSZXNwb25zZUhlYWRlcnMsIGVmZmVjdGl2ZU9wdGlvbnMubG9nUmVzcG9uc2VCb2R5KTtcblxuICAgICAgICBzdXBlcihyZXF1ZXN0RmlsdGVyUnVsZUluaXQsIGNvbmZpZ3VyZVJlc3BvbnNlRXZlbnRPcHRpb25zKTtcblxuICAgICAgICB0aGlzLl9jbGFzc05hbWUgICAgICAgID0gUkVRVUVTVF9MT0dHRVJfQ0xBU1NfTkFNRTtcbiAgICAgICAgdGhpcy5fb3B0aW9ucyAgICAgICAgICA9IGVmZmVjdGl2ZU9wdGlvbnM7XG4gICAgICAgIHRoaXMuX2ludGVybmFsUmVxdWVzdHMgPSB7fTtcbiAgICB9XG5cbiAgICBwcml2YXRlIHN0YXRpYyBfYXNzZXJ0TG9nT3B0aW9ucyAobG9nT3B0aW9uczogUmVxdWVzdEhvb2tMb2dPcHRpb25zKTogdm9pZCB7XG4gICAgICAgIGlmICghbG9nT3B0aW9ucy5sb2dSZXF1ZXN0Qm9keSAmJiBsb2dPcHRpb25zLnN0cmluZ2lmeVJlcXVlc3RCb2R5KVxuICAgICAgICAgICAgdGhyb3cgbmV3IEFQSUVycm9yKCdSZXF1ZXN0TG9nZ2VyJywgUlVOVElNRV9FUlJPUlMucmVxdWVzdEhvb2tDb25maWd1cmVBUElFcnJvciwgJ1JlcXVlc3RMb2dnZXInLCAnQ2Fubm90IHN0cmluZ2lmeSB0aGUgcmVxdWVzdCBib2R5IGJlY2F1c2UgaXQgaXMgbm90IGxvZ2dlZC4gU3BlY2lmeSB7IGxvZ1JlcXVlc3RCb2R5OiB0cnVlIH0gaW4gbG9nIG9wdGlvbnMuJyk7XG5cbiAgICAgICAgaWYgKCFsb2dPcHRpb25zLmxvZ1Jlc3BvbnNlQm9keSAmJiBsb2dPcHRpb25zLnN0cmluZ2lmeVJlc3BvbnNlQm9keSlcbiAgICAgICAgICAgIHRocm93IG5ldyBBUElFcnJvcignUmVxdWVzdExvZ2dlcicsIFJVTlRJTUVfRVJST1JTLnJlcXVlc3RIb29rQ29uZmlndXJlQVBJRXJyb3IsICdSZXF1ZXN0TG9nZ2VyJywgJ0Nhbm5vdCBzdHJpbmdpZnkgdGhlIHJlc3BvbnNlIGJvZHkgYmVjYXVzZSBpdCBpcyBub3QgbG9nZ2VkLiBTcGVjaWZ5IHsgbG9nUmVzcG9uc2VCb2R5OiB0cnVlIH0gaW4gbG9nIG9wdGlvbnMuJyk7XG4gICAgfVxuXG4gICAgcHVibGljIGFzeW5jIG9uUmVxdWVzdCAoZXZlbnQ6IFJlcXVlc3RFdmVudCk6IFByb21pc2U8dm9pZD4ge1xuICAgICAgICBjb25zdCBsb2dnZWRSZXE6IExvZ2dlZFJlcXVlc3QgPSB7XG4gICAgICAgICAgICBpZDogICAgICAgIGV2ZW50Ll9yZXF1ZXN0SW5mby5yZXF1ZXN0SWQsXG4gICAgICAgICAgICB0ZXN0UnVuSWQ6IGV2ZW50Ll9yZXF1ZXN0SW5mby5zZXNzaW9uSWQsXG4gICAgICAgICAgICB1c2VyQWdlbnQ6IHBhcnNlVXNlckFnZW50KGV2ZW50Ll9yZXF1ZXN0SW5mby51c2VyQWdlbnQpLnByZXR0eVVzZXJBZ2VudCxcbiAgICAgICAgICAgIHJlcXVlc3Q6ICAge1xuICAgICAgICAgICAgICAgIHRpbWVzdGFtcDogRGF0ZS5ub3coKSxcbiAgICAgICAgICAgICAgICB1cmw6ICAgICAgIGV2ZW50Ll9yZXF1ZXN0SW5mby51cmwsXG4gICAgICAgICAgICAgICAgbWV0aG9kOiAgICBldmVudC5fcmVxdWVzdEluZm8ubWV0aG9kLFxuICAgICAgICAgICAgfVxuICAgICAgICB9O1xuXG4gICAgICAgIGlmICh0aGlzLl9vcHRpb25zLmxvZ1JlcXVlc3RIZWFkZXJzKVxuICAgICAgICAgICAgbG9nZ2VkUmVxLnJlcXVlc3QuaGVhZGVycyA9IE9iamVjdC5hc3NpZ24oe30sIGV2ZW50Ll9yZXF1ZXN0SW5mby5oZWFkZXJzKTtcblxuICAgICAgICBpZiAodGhpcy5fb3B0aW9ucy5sb2dSZXF1ZXN0Qm9keSlcbiAgICAgICAgICAgIGxvZ2dlZFJlcS5yZXF1ZXN0LmJvZHkgPSB0aGlzLl9vcHRpb25zLnN0cmluZ2lmeVJlcXVlc3RCb2R5ID8gZXZlbnQuX3JlcXVlc3RJbmZvLmJvZHkudG9TdHJpbmcoKSA6IGV2ZW50Ll9yZXF1ZXN0SW5mby5ib2R5O1xuXG4gICAgICAgIHRoaXMuX2ludGVybmFsUmVxdWVzdHNbbG9nZ2VkUmVxLmlkXSA9IGxvZ2dlZFJlcTtcbiAgICB9XG5cbiAgICBwdWJsaWMgYXN5bmMgb25SZXNwb25zZSAoZXZlbnQ6IFJlc3BvbnNlRXZlbnQpOiBQcm9taXNlPHZvaWQ+IHtcbiAgICAgICAgY29uc3QgbG9nZ2VkUmVxID0gdGhpcy5faW50ZXJuYWxSZXF1ZXN0c1tldmVudC5yZXF1ZXN0SWRdO1xuXG4gICAgICAgIC8vIE5PVEU6IElmIHRoZSAnY2xlYXInIG1ldGhvZCBpcyBjYWxsZWQgZHVyaW5nIGEgbG9uZyBydW5uaW5nIHJlcXVlc3QsXG4gICAgICAgIC8vIHdlIHNob3VsZCBub3Qgc2F2ZSBhIHJlc3BvbnNlIHBhcnQgLSByZXF1ZXN0IHBhcnQgaGFzIGJlZW4gYWxyZWFkeSByZW1vdmVkLlxuICAgICAgICBpZiAoIWxvZ2dlZFJlcSlcbiAgICAgICAgICAgIHJldHVybjtcblxuICAgICAgICBsb2dnZWRSZXEucmVzcG9uc2UgPSB7XG4gICAgICAgICAgICBzdGF0dXNDb2RlOiBldmVudC5zdGF0dXNDb2RlLFxuICAgICAgICAgICAgdGltZXN0YW1wOiAgRGF0ZS5ub3coKVxuICAgICAgICB9O1xuXG4gICAgICAgIGlmICh0aGlzLl9vcHRpb25zLmxvZ1Jlc3BvbnNlSGVhZGVycylcbiAgICAgICAgICAgIGxvZ2dlZFJlcS5yZXNwb25zZS5oZWFkZXJzID0gT2JqZWN0LmFzc2lnbih7fSwgZXZlbnQuaGVhZGVycyk7XG5cbiAgICAgICAgaWYgKHRoaXMuX29wdGlvbnMubG9nUmVzcG9uc2VCb2R5KSB7XG4gICAgICAgICAgICBsb2dnZWRSZXEucmVzcG9uc2UuYm9keSA9IHRoaXMuX29wdGlvbnMuc3RyaW5naWZ5UmVzcG9uc2VCb2R5ICYmIGV2ZW50LmJvZHlcbiAgICAgICAgICAgICAgICA/IGV2ZW50LmJvZHkudG9TdHJpbmcoKVxuICAgICAgICAgICAgICAgIDogZXZlbnQuYm9keTtcbiAgICAgICAgfVxuICAgIH1cblxuICAgIHByaXZhdGUgX3ByZXBhcmVJbnRlcm5hbFJlcXVlc3RJbmZvICgpOiBMb2dnZWRSZXF1ZXN0W10ge1xuICAgICAgICBjb25zdCB0ZXN0UnVuICAgICAgICA9IHRlc3RSdW5UcmFja2VyLnJlc29sdmVDb250ZXh0VGVzdFJ1bigpO1xuICAgICAgICBsZXQgcHJlcGFyZWRSZXF1ZXN0cyA9IE9iamVjdC52YWx1ZXModGhpcy5faW50ZXJuYWxSZXF1ZXN0cyk7XG5cbiAgICAgICAgaWYgKHRlc3RSdW4pXG4gICAgICAgICAgICBwcmVwYXJlZFJlcXVlc3RzID0gcHJlcGFyZWRSZXF1ZXN0cy5maWx0ZXIociA9PiByLnRlc3RSdW5JZCA9PT0gdGVzdFJ1bi5pZCk7XG5cbiAgICAgICAgcmV0dXJuIHByZXBhcmVkUmVxdWVzdHM7XG4gICAgfVxuXG4gICAgcHJpdmF0ZSBfZ2V0Q29tcGxldGVkUmVxdWVzdHMgKCk6IExvZ2dlZFJlcXVlc3RbXSB7XG4gICAgICAgIHJldHVybiB0aGlzLl9wcmVwYXJlSW50ZXJuYWxSZXF1ZXN0SW5mbygpLmZpbHRlcihyID0+IHIucmVzcG9uc2UpO1xuICAgIH1cblxuICAgIC8vIEFQSVxuICAgIHB1YmxpYyBjb250YWlucyAocHJlZGljYXRlOiAocmVxdWVzdDogTG9nZ2VkUmVxdWVzdCkgPT4gYm9vbGVhbik6IFJlRXhlY3V0YWJsZVByb21pc2Uge1xuICAgICAgICByZXR1cm4gUmVFeGVjdXRhYmxlUHJvbWlzZS5mcm9tRm4oYXN5bmMgKCkgPT4ge1xuICAgICAgICAgICAgcmV0dXJuICEhdGhpcy5fZ2V0Q29tcGxldGVkUmVxdWVzdHMoKS5maW5kKHByZWRpY2F0ZSk7XG4gICAgICAgIH0pO1xuICAgIH1cblxuICAgIHB1YmxpYyBjb3VudCAocHJlZGljYXRlOiAocmVxdWVzdDogTG9nZ2VkUmVxdWVzdCkgPT4gYm9vbGVhbik6IFJlRXhlY3V0YWJsZVByb21pc2Uge1xuICAgICAgICByZXR1cm4gUmVFeGVjdXRhYmxlUHJvbWlzZS5mcm9tRm4oYXN5bmMgKCkgPT4ge1xuICAgICAgICAgICAgcmV0dXJuIHRoaXMuX2dldENvbXBsZXRlZFJlcXVlc3RzKCkuZmlsdGVyKHByZWRpY2F0ZSkubGVuZ3RoO1xuICAgICAgICB9KTtcbiAgICB9XG5cbiAgICBwdWJsaWMgY2xlYXIgKCk6IHZvaWQge1xuICAgICAgICBjb25zdCB0ZXN0UnVuID0gdGVzdFJ1blRyYWNrZXIucmVzb2x2ZUNvbnRleHRUZXN0UnVuKCk7XG5cbiAgICAgICAgaWYgKHRlc3RSdW4pIHtcbiAgICAgICAgICAgIE9iamVjdC5rZXlzKHRoaXMuX2ludGVybmFsUmVxdWVzdHMpLmZvckVhY2goaWQgPT4ge1xuICAgICAgICAgICAgICAgIGlmICh0aGlzLl9pbnRlcm5hbFJlcXVlc3RzW2lkXS50ZXN0UnVuSWQgPT09IHRlc3RSdW4uaWQpXG4gICAgICAgICAgICAgICAgICAgIGRlbGV0ZSB0aGlzLl9pbnRlcm5hbFJlcXVlc3RzW2lkXTtcbiAgICAgICAgICAgIH0pO1xuICAgICAgICB9XG4gICAgICAgIGVsc2VcbiAgICAgICAgICAgIHRoaXMuX2ludGVybmFsUmVxdWVzdHMgPSB7fTtcbiAgICB9XG5cbiAgICBwdWJsaWMgZ2V0IHJlcXVlc3RzICgpOiBMb2dnZWRSZXF1ZXN0W10ge1xuICAgICAgICByZXR1cm4gdGhpcy5fcHJlcGFyZUludGVybmFsUmVxdWVzdEluZm8oKTtcbiAgICB9XG59XG5cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIGNyZWF0ZVJlcXVlc3RMb2dnZXIgKHJlcXVlc3RGaWx0ZXJSdWxlSW5pdDogUmVxdWVzdEZpbHRlclJ1bGVJbml0IHwgUmVxdWVzdEZpbHRlclJ1bGVJbml0W10gfCB1bmRlZmluZWQsIGxvZ09wdGlvbnM6IFJlcXVlc3RIb29rTG9nT3B0aW9uc0luaXQpOiBSZXF1ZXN0TG9nZ2VySW1wbGVtZW50YXRpb24ge1xuICAgIHJldHVybiBuZXcgUmVxdWVzdExvZ2dlckltcGxlbWVudGF0aW9uKHJlcXVlc3RGaWx0ZXJSdWxlSW5pdCwgbG9nT3B0aW9ucyk7XG59XG4iXX0=
|
|
@@ -1,12 +1,12 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
-
};
|
|
5
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
const index_1 = __importDefault(require("./index"));
|
|
7
|
-
function createRequestMock() {
|
|
8
|
-
return new index_1.default();
|
|
9
|
-
}
|
|
10
|
-
exports.default = createRequestMock;
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
const index_1 = __importDefault(require("./index"));
|
|
7
|
+
function createRequestMock() {
|
|
8
|
+
return new index_1.default();
|
|
9
|
+
}
|
|
10
|
+
exports.default = createRequestMock;
|
|
11
11
|
module.exports = exports.default;
|
|
12
12
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3JlYXRlLXJlcXVlc3QtbW9jay5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9hcGkvcmVxdWVzdC1ob29rcy9yZXF1ZXN0LW1vY2svY3JlYXRlLXJlcXVlc3QtbW9jay50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLG9EQUFrQztBQUVsQyxTQUF3QixpQkFBaUI7SUFDckMsT0FBTyxJQUFJLGVBQVcsRUFBRSxDQUFDO0FBQzdCLENBQUM7QUFGRCxvQ0FFQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZXF1ZXN0TW9jayBmcm9tICcuL2luZGV4JztcblxuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gY3JlYXRlUmVxdWVzdE1vY2sgKCk6IFJlcXVlc3RNb2NrIHtcbiAgICByZXR1cm4gbmV3IFJlcXVlc3RNb2NrKCk7XG59XG4iXX0=
|