@checkly/playwright-core 1.51.17-beta.1 → 1.54.2-beta.0
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/ThirdPartyNotices.txt +65 -123
- package/browsers.json +16 -14
- package/index.js +1 -1
- package/lib/androidServerImpl.js +47 -50
- package/lib/browserServerImpl.js +89 -69
- package/lib/checkly/escapeRegExp.js +23 -27
- package/lib/checkly/fetch.js +64 -46
- package/lib/checkly/secretsFilter.js +49 -36
- package/lib/cli/driver.js +71 -69
- package/lib/cli/program.js +400 -359
- package/lib/cli/programWithTestStub.js +51 -45
- package/lib/client/accessibility.js +31 -32
- package/lib/client/android.js +151 -242
- package/lib/client/api.js +135 -283
- package/lib/client/artifact.js +39 -36
- package/lib/client/browser.js +96 -71
- package/lib/client/browserContext.js +314 -345
- package/lib/client/browserType.js +103 -127
- package/lib/client/cdpSession.js +29 -31
- package/lib/client/channelOwner.js +90 -113
- package/lib/client/clientHelper.js +48 -39
- package/lib/client/clientInstrumentation.js +40 -37
- package/lib/client/clientStackTrace.js +41 -37
- package/lib/client/clock.js +36 -36
- package/lib/client/connection.js +188 -214
- package/lib/client/consoleMessage.js +31 -28
- package/lib/client/coverage.js +25 -22
- package/lib/client/dialog.js +30 -31
- package/lib/client/download.js +25 -25
- package/lib/client/electron.js +80 -77
- package/lib/client/elementHandle.js +120 -159
- package/lib/client/errors.js +53 -53
- package/lib/client/eventEmitter.js +124 -121
- package/lib/client/events.js +72 -68
- package/lib/client/fetch.js +166 -190
- package/lib/client/fileChooser.js +25 -24
- package/lib/client/fileUtils.js +31 -28
- package/lib/client/frame.js +207 -306
- package/lib/client/harRouter.js +42 -52
- package/lib/client/input.js +42 -69
- package/lib/client/jsHandle.js +54 -69
- package/lib/client/jsonPipe.js +27 -23
- package/lib/client/localUtils.js +29 -29
- package/lib/client/locator.js +145 -237
- package/lib/client/network.js +282 -307
- package/lib/client/page.js +269 -318
- package/lib/client/platform.js +46 -43
- package/lib/client/playwright.js +51 -76
- package/lib/client/selectors.js +45 -63
- package/lib/client/stream.js +29 -25
- package/lib/client/timeoutSettings.js +55 -41
- package/lib/client/tracing.js +49 -96
- package/lib/client/types.js +26 -22
- package/lib/client/video.js +35 -27
- package/lib/client/waiter.js +69 -88
- package/lib/client/webError.js +25 -23
- package/lib/client/webSocket.js +43 -56
- package/lib/client/worker.js +48 -56
- package/lib/client/writableStream.js +27 -23
- package/lib/generated/bindingsControllerSource.js +28 -0
- package/lib/generated/clockSource.js +26 -6
- package/lib/generated/consoleApiSource.js +26 -6
- package/lib/generated/injectedScriptSource.js +26 -6
- package/lib/generated/pollingRecorderSource.js +26 -6
- package/lib/generated/storageScriptSource.js +28 -0
- package/lib/generated/utilityScriptSource.js +26 -6
- package/lib/generated/webSocketMockSource.js +333 -5
- package/lib/inProcessFactory.js +51 -53
- package/lib/inprocess.js +2 -19
- package/lib/outofprocess.js +51 -46
- package/lib/protocol/serializers.js +153 -134
- package/lib/protocol/validator.js +2807 -2739
- package/lib/protocol/validatorPrimitives.js +114 -73
- package/lib/remote/playwrightConnection.js +88 -242
- package/lib/remote/playwrightServer.js +305 -92
- package/lib/server/accessibility.js +44 -37
- package/lib/server/android/android.js +251 -241
- package/lib/server/android/backendAdb.js +87 -82
- package/lib/server/artifact.js +78 -55
- package/lib/server/bidi/bidiBrowser.js +297 -158
- package/lib/server/bidi/bidiChromium.js +119 -89
- package/lib/server/bidi/bidiConnection.js +66 -83
- package/lib/server/bidi/bidiExecutionContext.js +129 -113
- package/lib/server/bidi/bidiFirefox.js +86 -76
- package/lib/server/bidi/bidiInput.js +106 -117
- package/lib/server/bidi/bidiNetworkManager.js +142 -159
- package/lib/server/bidi/bidiOverCdp.js +57 -58
- package/lib/server/bidi/bidiPage.js +260 -260
- package/lib/server/bidi/bidiPdf.js +52 -86
- package/lib/server/bidi/third_party/bidiCommands.d.js +22 -0
- package/lib/server/bidi/third_party/bidiDeserializer.js +55 -50
- package/lib/server/bidi/third_party/bidiKeyboard.js +236 -220
- package/lib/server/bidi/third_party/bidiProtocol.js +22 -137
- package/lib/server/bidi/third_party/bidiProtocolCore.js +152 -0
- package/lib/server/bidi/third_party/bidiProtocolPermissions.js +42 -0
- package/lib/server/bidi/third_party/bidiSerializer.js +67 -63
- package/lib/server/bidi/third_party/firefoxPrefs.js +141 -119
- package/lib/server/browser.js +93 -95
- package/lib/server/browserContext.js +419 -429
- package/lib/server/browserType.js +186 -216
- package/lib/server/callLog.js +47 -44
- package/lib/server/chromium/chromium.js +235 -203
- package/lib/server/chromium/chromiumSwitches.js +100 -67
- package/lib/server/chromium/crAccessibility.js +157 -131
- package/lib/server/chromium/crBrowser.js +310 -292
- package/lib/server/chromium/crConnection.js +95 -121
- package/lib/server/chromium/crCoverage.js +121 -131
- package/lib/server/chromium/crDevTools.js +60 -51
- package/lib/server/chromium/crDragDrop.js +68 -84
- package/lib/server/chromium/crExecutionContext.js +89 -83
- package/lib/server/chromium/crInput.js +118 -113
- package/lib/server/chromium/crNetworkManager.js +274 -375
- package/lib/server/chromium/crPage.js +536 -593
- package/lib/server/chromium/crPdf.js +54 -86
- package/lib/server/chromium/crProtocolHelper.js +92 -80
- package/lib/server/chromium/crServiceWorker.js +84 -73
- package/lib/server/chromium/defaultFontFamilies.js +152 -135
- package/lib/server/chromium/protocol.d.js +16 -0
- package/lib/server/chromium/videoRecorder.js +66 -99
- package/lib/server/clock.js +107 -83
- package/lib/server/codegen/csharp.js +192 -162
- package/lib/server/codegen/java.js +156 -129
- package/lib/server/codegen/javascript.js +163 -148
- package/lib/server/codegen/jsonl.js +32 -28
- package/lib/server/codegen/language.js +75 -52
- package/lib/server/codegen/languages.js +65 -27
- package/lib/server/codegen/python.js +141 -126
- package/lib/server/codegen/types.js +15 -4
- package/lib/server/console.js +28 -32
- package/lib/server/cookieStore.js +108 -86
- package/lib/server/debugController.js +147 -151
- package/lib/server/debugger.js +86 -78
- package/lib/server/deviceDescriptors.js +37 -24
- package/lib/server/deviceDescriptorsSource.json +238 -128
- package/lib/server/dialog.js +84 -39
- package/lib/server/dispatchers/androidDispatcher.js +257 -148
- package/lib/server/dispatchers/artifactDispatcher.js +79 -79
- package/lib/server/dispatchers/browserContextDispatcher.js +289 -259
- package/lib/server/dispatchers/browserDispatcher.js +96 -148
- package/lib/server/dispatchers/browserTypeDispatcher.js +50 -41
- package/lib/server/dispatchers/cdpSessionDispatcher.js +35 -39
- package/lib/server/dispatchers/debugControllerDispatcher.js +65 -83
- package/lib/server/dispatchers/dialogDispatcher.js +34 -31
- package/lib/server/dispatchers/dispatcher.js +208 -248
- package/lib/server/dispatchers/electronDispatcher.js +66 -70
- package/lib/server/dispatchers/elementHandlerDispatcher.js +164 -216
- package/lib/server/dispatchers/frameDispatcher.js +211 -272
- package/lib/server/dispatchers/jsHandleDispatcher.js +63 -75
- package/lib/server/dispatchers/jsonPipeDispatcher.js +37 -38
- package/lib/server/dispatchers/localUtilsDispatcher.js +121 -119
- package/lib/server/dispatchers/networkDispatchers.js +117 -128
- package/lib/server/dispatchers/pageDispatcher.js +256 -248
- package/lib/server/dispatchers/playwrightDispatcher.js +92 -87
- package/lib/server/dispatchers/streamDispatcher.js +52 -48
- package/lib/server/dispatchers/tracingDispatcher.js +47 -52
- package/lib/server/dispatchers/webSocketRouteDispatcher.js +126 -150
- package/lib/server/dispatchers/writableStreamDispatcher.js +65 -43
- package/lib/server/dom.js +485 -582
- package/lib/server/download.js +47 -37
- package/lib/server/electron/electron.js +216 -243
- package/lib/server/electron/loader.js +9 -37
- package/lib/server/errors.js +47 -46
- package/lib/server/fetch.js +317 -360
- package/lib/server/fileChooser.js +25 -24
- package/lib/server/fileUploadUtils.js +66 -60
- package/lib/server/firefox/ffAccessibility.js +153 -131
- package/lib/server/firefox/ffBrowser.js +268 -305
- package/lib/server/firefox/ffConnection.js +63 -84
- package/lib/server/firefox/ffExecutionContext.js +92 -73
- package/lib/server/firefox/ffInput.js +82 -84
- package/lib/server/firefox/ffNetworkManager.js +137 -114
- package/lib/server/firefox/ffPage.js +261 -293
- package/lib/server/firefox/firefox.js +80 -72
- package/lib/server/firefox/protocol.d.js +16 -0
- package/lib/server/formData.js +107 -35
- package/lib/server/frameSelectors.js +98 -114
- package/lib/server/frames.js +845 -1055
- package/lib/server/har/harRecorder.js +85 -77
- package/lib/server/har/harTracer.js +290 -223
- package/lib/server/harBackend.js +80 -80
- package/lib/server/helper.js +55 -59
- package/lib/server/index.js +59 -99
- package/lib/server/input.js +151 -189
- package/lib/server/instrumentation.js +57 -44
- package/lib/server/javascript.js +133 -134
- package/lib/server/launchApp.js +113 -75
- package/lib/server/localUtils.js +150 -142
- package/lib/server/macEditingCommands.js +141 -137
- package/lib/server/network.js +299 -303
- package/lib/server/page.js +513 -544
- package/lib/server/pipeTransport.js +49 -45
- package/lib/server/playwright.js +58 -67
- package/lib/server/progress.js +137 -68
- package/lib/server/protocolError.js +34 -31
- package/lib/server/recorder/chat.js +70 -86
- package/lib/server/recorder/recorderApp.js +341 -176
- package/lib/server/recorder/recorderInTraceViewer.js +65 -94
- package/lib/server/recorder/recorderRunner.js +93 -116
- package/lib/server/recorder/recorderSignalProcessor.js +83 -0
- package/lib/server/recorder/recorderUtils.js +104 -47
- package/lib/server/recorder/throttledFile.js +42 -30
- package/lib/server/recorder.js +395 -275
- package/lib/server/registry/browserFetcher.js +106 -101
- package/lib/server/registry/dependencies.js +245 -196
- package/lib/server/registry/index.js +930 -803
- package/lib/server/registry/nativeDeps.js +1073 -464
- package/lib/server/registry/oopDownloadBrowserMain.js +57 -75
- package/lib/server/screenshotter.js +160 -191
- package/lib/server/selectors.js +90 -51
- package/lib/server/socksClientCertificatesInterceptor.js +171 -186
- package/lib/server/socksInterceptor.js +62 -70
- package/lib/server/trace/recorder/snapshotter.js +76 -102
- package/lib/server/trace/recorder/snapshotterInjected.js +238 -217
- package/lib/server/trace/recorder/tracing.js +354 -362
- package/lib/server/trace/test/inMemorySnapshotter.js +46 -52
- package/lib/server/trace/viewer/traceViewer.js +160 -147
- package/lib/server/transport.js +119 -134
- package/lib/server/types.js +26 -22
- package/lib/server/usKeyboardLayout.js +135 -545
- package/lib/server/utils/ascii.js +39 -26
- package/lib/server/utils/comparators.js +105 -103
- package/lib/server/utils/crypto.js +157 -112
- package/lib/server/utils/debug.js +36 -32
- package/lib/server/utils/debugLogger.js +77 -48
- package/lib/server/utils/env.js +52 -37
- package/lib/server/utils/eventsHelper.js +29 -28
- package/lib/server/utils/expectUtils.js +31 -26
- package/lib/server/utils/fileUtils.js +123 -136
- package/lib/server/utils/happyEyeballs.js +141 -126
- package/lib/server/utils/hostPlatform.js +84 -120
- package/lib/server/utils/httpServer.js +106 -121
- package/lib/server/utils/image_tools/colorUtils.js +42 -51
- package/lib/server/utils/image_tools/compare.js +44 -43
- package/lib/server/utils/image_tools/imageChannel.js +38 -30
- package/lib/server/utils/image_tools/stats.js +40 -40
- package/lib/server/utils/linuxUtils.js +50 -37
- package/lib/server/utils/network.js +152 -96
- package/lib/server/utils/nodePlatform.js +87 -79
- package/lib/server/utils/pipeTransport.js +44 -42
- package/lib/server/utils/processLauncher.js +111 -121
- package/lib/server/utils/profiler.js +52 -39
- package/lib/server/utils/socksProxy.js +280 -339
- package/lib/server/utils/spawnAsync.js +37 -41
- package/lib/server/utils/task.js +31 -38
- package/lib/server/utils/userAgent.js +73 -66
- package/lib/server/utils/wsServer.js +68 -75
- package/lib/server/utils/zipFile.js +36 -37
- package/lib/server/utils/zones.js +37 -34
- package/lib/server/webkit/protocol.d.js +16 -0
- package/lib/server/webkit/webkit.js +77 -61
- package/lib/server/webkit/wkAccessibility.js +161 -118
- package/lib/server/webkit/wkBrowser.js +193 -184
- package/lib/server/webkit/wkConnection.js +59 -83
- package/lib/server/webkit/wkExecutionContext.js +85 -70
- package/lib/server/webkit/wkInput.js +97 -95
- package/lib/server/webkit/wkInterceptableRequest.js +102 -95
- package/lib/server/webkit/wkPage.js +568 -667
- package/lib/server/webkit/wkProvisionalPage.js +45 -56
- package/lib/server/webkit/wkWorkers.js +79 -79
- package/lib/utils/expectUtils.js +31 -26
- package/lib/utils/isomorphic/ariaSnapshot.js +149 -152
- package/lib/utils/isomorphic/assert.js +28 -22
- package/lib/utils/isomorphic/colors.js +66 -59
- package/lib/utils/isomorphic/cssParser.js +120 -125
- package/lib/utils/isomorphic/cssTokenizer.js +436 -364
- package/lib/utils/isomorphic/headers.js +38 -37
- package/lib/utils/isomorphic/locatorGenerators.js +358 -357
- package/lib/utils/isomorphic/locatorParser.js +96 -105
- package/lib/utils/isomorphic/locatorUtils.js +63 -44
- package/lib/utils/isomorphic/manualPromise.js +46 -39
- package/lib/utils/isomorphic/mimeType.js +447 -25
- package/lib/utils/isomorphic/multimap.js +34 -27
- package/lib/utils/isomorphic/protocolFormatter.js +68 -0
- package/lib/utils/isomorphic/protocolMetainfo.js +321 -0
- package/lib/utils/isomorphic/recorderUtils.js +140 -181
- package/lib/utils/isomorphic/rtti.js +35 -33
- package/lib/utils/isomorphic/selectorParser.js +182 -193
- package/lib/utils/isomorphic/semaphore.js +27 -24
- package/lib/utils/isomorphic/stackTrace.js +87 -98
- package/lib/utils/isomorphic/stringUtils.js +98 -112
- package/lib/utils/isomorphic/time.js +46 -22
- package/lib/utils/isomorphic/timeoutRunner.js +53 -53
- package/lib/utils/isomorphic/traceUtils.js +37 -41
- package/lib/utils/isomorphic/types.js +15 -4
- package/lib/utils/isomorphic/urlMatch.js +113 -67
- package/lib/utils/isomorphic/utilityScriptSerializers.js +251 -0
- package/lib/utils.js +101 -443
- package/lib/utilsBundle.js +101 -52
- package/lib/utilsBundleImpl/index.js +160 -150
- package/lib/zipBundle.js +32 -23
- package/lib/zipBundleImpl.js +4 -4
- package/package.json +1 -1
- package/types/protocol.d.ts +1267 -1057
- package/types/types.d.ts +131 -29
- package/lib/common/socksProxy.js +0 -569
- package/lib/common/timeoutSettings.js +0 -73
- package/lib/common/types.js +0 -5
- package/lib/image_tools/colorUtils.js +0 -98
- package/lib/image_tools/compare.js +0 -108
- package/lib/image_tools/imageChannel.js +0 -70
- package/lib/image_tools/stats.js +0 -102
- package/lib/protocol/debug.js +0 -27
- package/lib/protocol/transport.js +0 -82
- package/lib/server/dispatchers/selectorsDispatcher.js +0 -36
- package/lib/server/isomorphic/utilityScriptSerializers.js +0 -229
- package/lib/server/recorder/contextRecorder.js +0 -290
- package/lib/server/recorder/recorderCollection.js +0 -104
- package/lib/server/recorder/recorderFrontend.js +0 -5
- package/lib/server/storageScript.js +0 -160
- package/lib/server/timeoutSettings.js +0 -74
- package/lib/third_party/diff_match_patch.js +0 -2222
- package/lib/utils/ascii.js +0 -31
- package/lib/utils/comparators.js +0 -171
- package/lib/utils/crypto.js +0 -174
- package/lib/utils/debug.js +0 -46
- package/lib/utils/debugLogger.js +0 -91
- package/lib/utils/env.js +0 -49
- package/lib/utils/eventsHelper.js +0 -38
- package/lib/utils/fileUtils.js +0 -205
- package/lib/utils/happy-eyeballs.js +0 -210
- package/lib/utils/headers.js +0 -52
- package/lib/utils/hostPlatform.js +0 -133
- package/lib/utils/httpServer.js +0 -237
- package/lib/utils/index.js +0 -368
- package/lib/utils/linuxUtils.js +0 -78
- package/lib/utils/manualPromise.js +0 -109
- package/lib/utils/multimap.js +0 -75
- package/lib/utils/network.js +0 -160
- package/lib/utils/processLauncher.js +0 -248
- package/lib/utils/profiler.js +0 -53
- package/lib/utils/rtti.js +0 -44
- package/lib/utils/semaphore.js +0 -51
- package/lib/utils/spawnAsync.js +0 -45
- package/lib/utils/stackTrace.js +0 -121
- package/lib/utils/task.js +0 -58
- package/lib/utils/time.js +0 -37
- package/lib/utils/timeoutRunner.js +0 -66
- package/lib/utils/traceUtils.js +0 -44
- package/lib/utils/userAgent.js +0 -105
- package/lib/utils/wsServer.js +0 -127
- package/lib/utils/zipFile.js +0 -75
- package/lib/utils/zones.js +0 -62
- package/lib/vite/htmlReport/index.html +0 -69
- package/lib/vite/recorder/assets/codeMirrorModule-DrMbgOIo.js +0 -16684
- package/lib/vite/recorder/assets/codeMirrorModule-DuST8d_k.css +0 -344
- package/lib/vite/recorder/assets/codicon-DCmgc-ay.ttf +0 -0
- package/lib/vite/recorder/assets/index-5NM3V7eb.css +0 -2524
- package/lib/vite/recorder/assets/index-CT-scFHn.js +0 -16848
- package/lib/vite/recorder/index.html +0 -29
- package/lib/vite/recorder/playwright-logo.svg +0 -9
- package/lib/vite/traceViewer/assets/codeMirrorModule-CB-2okZ8.js +0 -16684
- package/lib/vite/traceViewer/assets/defaultSettingsView-CBiB4avC.js +0 -217
- package/lib/vite/traceViewer/assets/inspectorTab-CwgfffWb.js +0 -25143
- package/lib/vite/traceViewer/assets/workbench-CWZselvp.js +0 -2470
- package/lib/vite/traceViewer/assets/xtermModule-Es_gt_u7.js +0 -5994
- package/lib/vite/traceViewer/codeMirrorModule.DuST8d_k.css +0 -344
- package/lib/vite/traceViewer/codicon.DCmgc-ay.ttf +0 -0
- package/lib/vite/traceViewer/defaultSettingsView.Dp3b_92q.css +0 -41
- package/lib/vite/traceViewer/embedded.BeldSa2G.css +0 -68
- package/lib/vite/traceViewer/embedded.gzudoghF.js +0 -106
- package/lib/vite/traceViewer/embedded.html +0 -18
- package/lib/vite/traceViewer/index.DilotR1h.js +0 -314
- package/lib/vite/traceViewer/index.QewjJ85u.css +0 -131
- package/lib/vite/traceViewer/index.html +0 -47
- package/lib/vite/traceViewer/inspectorTab.DnGm18kV.css +0 -3178
- package/lib/vite/traceViewer/playwright-logo.svg +0 -9
- package/lib/vite/traceViewer/recorder.DLgqV9db.css +0 -15
- package/lib/vite/traceViewer/recorder.DVrkq3Um.js +0 -551
- package/lib/vite/traceViewer/recorder.html +0 -17
- package/lib/vite/traceViewer/snapshot.html +0 -21
- package/lib/vite/traceViewer/sw.bundle.js +0 -3
- package/lib/vite/traceViewer/uiMode.C9_OcpPU.js +0 -1756
- package/lib/vite/traceViewer/uiMode.c5ORgcrX.css +0 -1424
- package/lib/vite/traceViewer/uiMode.html +0 -21
- package/lib/vite/traceViewer/workbench.xUZSA8PY.css +0 -787
- package/lib/vite/traceViewer/xtermModule.EsaqrrTX.css +0 -209
|
@@ -1,357 +1,387 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
|
|
3
|
-
Object.defineProperty
|
|
4
|
-
|
|
2
|
+
var __create = Object.create;
|
|
3
|
+
var __defProp = Object.defineProperty;
|
|
4
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
5
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
6
|
+
var __getProtoOf = Object.getPrototypeOf;
|
|
7
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
8
|
+
var __export = (target, all) => {
|
|
9
|
+
for (var name in all)
|
|
10
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
11
|
+
};
|
|
12
|
+
var __copyProps = (to, from, except, desc) => {
|
|
13
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
14
|
+
for (let key of __getOwnPropNames(from))
|
|
15
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
16
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
17
|
+
}
|
|
18
|
+
return to;
|
|
19
|
+
};
|
|
20
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
21
|
+
// If the importer is in node compatibility mode or this is not an ESM
|
|
22
|
+
// file that has been converted to a CommonJS file using a Babel-
|
|
23
|
+
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
24
|
+
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
25
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
26
|
+
mod
|
|
27
|
+
));
|
|
28
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
29
|
+
var browserContextDispatcher_exports = {};
|
|
30
|
+
__export(browserContextDispatcher_exports, {
|
|
31
|
+
BrowserContextDispatcher: () => BrowserContextDispatcher
|
|
5
32
|
});
|
|
6
|
-
exports
|
|
7
|
-
var
|
|
8
|
-
var
|
|
9
|
-
var
|
|
10
|
-
var
|
|
11
|
-
var
|
|
12
|
-
var
|
|
13
|
-
var
|
|
14
|
-
var
|
|
15
|
-
var
|
|
16
|
-
var
|
|
17
|
-
var
|
|
18
|
-
var
|
|
19
|
-
var
|
|
20
|
-
var
|
|
21
|
-
var
|
|
22
|
-
var
|
|
23
|
-
var
|
|
24
|
-
var
|
|
25
|
-
var
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
*
|
|
30
|
-
* Licensed under the Apache License, Version 2.0 (the 'License");
|
|
31
|
-
* you may not use this file except in compliance with the License.
|
|
32
|
-
* You may obtain a copy of the License at
|
|
33
|
-
*
|
|
34
|
-
* http://www.apache.org/licenses/LICENSE-2.0
|
|
35
|
-
*
|
|
36
|
-
* Unless required by applicable law or agreed to in writing, software
|
|
37
|
-
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
38
|
-
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
39
|
-
* See the License for the specific language governing permissions and
|
|
40
|
-
* limitations under the License.
|
|
41
|
-
*/
|
|
42
|
-
|
|
43
|
-
class BrowserContextDispatcher extends _dispatcher.Dispatcher {
|
|
33
|
+
module.exports = __toCommonJS(browserContextDispatcher_exports);
|
|
34
|
+
var import_fs = __toESM(require("fs"));
|
|
35
|
+
var import_path = __toESM(require("path"));
|
|
36
|
+
var import_browserContext = require("../browserContext");
|
|
37
|
+
var import_artifactDispatcher = require("./artifactDispatcher");
|
|
38
|
+
var import_cdpSessionDispatcher = require("./cdpSessionDispatcher");
|
|
39
|
+
var import_dialogDispatcher = require("./dialogDispatcher");
|
|
40
|
+
var import_dispatcher = require("./dispatcher");
|
|
41
|
+
var import_elementHandlerDispatcher = require("./elementHandlerDispatcher");
|
|
42
|
+
var import_frameDispatcher = require("./frameDispatcher");
|
|
43
|
+
var import_jsHandleDispatcher = require("./jsHandleDispatcher");
|
|
44
|
+
var import_networkDispatchers = require("./networkDispatchers");
|
|
45
|
+
var import_pageDispatcher = require("./pageDispatcher");
|
|
46
|
+
var import_crBrowser = require("../chromium/crBrowser");
|
|
47
|
+
var import_errors = require("../errors");
|
|
48
|
+
var import_tracingDispatcher = require("./tracingDispatcher");
|
|
49
|
+
var import_webSocketRouteDispatcher = require("./webSocketRouteDispatcher");
|
|
50
|
+
var import_writableStreamDispatcher = require("./writableStreamDispatcher");
|
|
51
|
+
var import_crypto = require("../utils/crypto");
|
|
52
|
+
var import_urlMatch = require("../../utils/isomorphic/urlMatch");
|
|
53
|
+
var import_recorder = require("../recorder");
|
|
54
|
+
var import_recorderApp = require("../recorder/recorderApp");
|
|
55
|
+
class BrowserContextDispatcher extends import_dispatcher.Dispatcher {
|
|
44
56
|
constructor(parentScope, context) {
|
|
45
|
-
|
|
46
|
-
const
|
|
47
|
-
|
|
48
|
-
super(parentScope, context, 'BrowserContext', {
|
|
57
|
+
const requestContext = import_networkDispatchers.APIRequestContextDispatcher.from(parentScope, context.fetchRequest);
|
|
58
|
+
const tracing = import_tracingDispatcher.TracingDispatcher.from(parentScope, context.tracing);
|
|
59
|
+
super(parentScope, context, "BrowserContext", {
|
|
49
60
|
isChromium: context._browser.options.isChromium,
|
|
50
|
-
isLocalBrowserOnServer: context._browser._isCollocatedWithServer,
|
|
51
61
|
requestContext,
|
|
52
|
-
tracing
|
|
62
|
+
tracing,
|
|
63
|
+
options: context._options
|
|
53
64
|
});
|
|
54
65
|
this._type_EventTarget = true;
|
|
55
66
|
this._type_BrowserContext = true;
|
|
56
|
-
this.
|
|
57
|
-
this._subscriptions = new Set();
|
|
67
|
+
this._subscriptions = /* @__PURE__ */ new Set();
|
|
58
68
|
this._webSocketInterceptionPatterns = [];
|
|
69
|
+
this._bindings = [];
|
|
70
|
+
this._initScripts = [];
|
|
71
|
+
this._clockPaused = false;
|
|
72
|
+
this._interceptionUrlMatchers = [];
|
|
59
73
|
this.adopt(requestContext);
|
|
60
74
|
this.adopt(tracing);
|
|
75
|
+
this._requestInterceptor = (route, request) => {
|
|
76
|
+
const matchesSome = this._interceptionUrlMatchers.some((urlMatch) => (0, import_urlMatch.urlMatches)(this._context._options.baseURL, request.url(), urlMatch));
|
|
77
|
+
const routeDispatcher = this.connection.existingDispatcher(route);
|
|
78
|
+
if (!matchesSome || routeDispatcher) {
|
|
79
|
+
route.continue({ isFallback: true }).catch(() => {
|
|
80
|
+
});
|
|
81
|
+
return;
|
|
82
|
+
}
|
|
83
|
+
this._dispatchEvent("route", { route: new import_networkDispatchers.RouteDispatcher(import_networkDispatchers.RequestDispatcher.from(this, request), route) });
|
|
84
|
+
};
|
|
61
85
|
this._context = context;
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
const onVideo = artifact => {
|
|
66
|
-
// Note: Video must outlive Page and BrowserContext, so that client can saveAs it
|
|
67
|
-
// after closing the context. We use |scope| for it.
|
|
68
|
-
const artifactDispatcher = _artifactDispatcher.ArtifactDispatcher.from(parentScope, artifact);
|
|
69
|
-
this._dispatchEvent('video', {
|
|
70
|
-
artifact: artifactDispatcher
|
|
71
|
-
});
|
|
86
|
+
const onVideo = (artifact) => {
|
|
87
|
+
const artifactDispatcher = import_artifactDispatcher.ArtifactDispatcher.from(parentScope, artifact);
|
|
88
|
+
this._dispatchEvent("video", { artifact: artifactDispatcher });
|
|
72
89
|
};
|
|
73
|
-
this.addObjectListener(
|
|
90
|
+
this.addObjectListener(import_browserContext.BrowserContext.Events.VideoStarted, onVideo);
|
|
74
91
|
for (const video of context._browser._idToVideo.values()) {
|
|
75
|
-
if (video.context === context)
|
|
92
|
+
if (video.context === context)
|
|
93
|
+
onVideo(video.artifact);
|
|
76
94
|
}
|
|
77
|
-
for (const page of context.pages())
|
|
78
|
-
page:
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
this._dispatchEvent('page', {
|
|
82
|
-
page: _pageDispatcher.PageDispatcher.from(this, page)
|
|
83
|
-
});
|
|
95
|
+
for (const page of context.pages())
|
|
96
|
+
this._dispatchEvent("page", { page: import_pageDispatcher.PageDispatcher.from(this, page) });
|
|
97
|
+
this.addObjectListener(import_browserContext.BrowserContext.Events.Page, (page) => {
|
|
98
|
+
this._dispatchEvent("page", { page: import_pageDispatcher.PageDispatcher.from(this, page) });
|
|
84
99
|
});
|
|
85
|
-
this.addObjectListener(
|
|
86
|
-
this._dispatchEvent(
|
|
100
|
+
this.addObjectListener(import_browserContext.BrowserContext.Events.Close, () => {
|
|
101
|
+
this._dispatchEvent("close");
|
|
87
102
|
this._dispose();
|
|
88
103
|
});
|
|
89
|
-
this.addObjectListener(
|
|
90
|
-
this._dispatchEvent(
|
|
91
|
-
error: (0, _errors.serializeError)(error),
|
|
92
|
-
page: _pageDispatcher.PageDispatcher.from(this, page)
|
|
93
|
-
});
|
|
104
|
+
this.addObjectListener(import_browserContext.BrowserContext.Events.PageError, (error, page) => {
|
|
105
|
+
this._dispatchEvent("pageError", { error: (0, import_errors.serializeError)(error), page: import_pageDispatcher.PageDispatcher.from(this, page) });
|
|
94
106
|
});
|
|
95
|
-
this.addObjectListener(
|
|
107
|
+
this.addObjectListener(import_browserContext.BrowserContext.Events.Console, (message) => {
|
|
96
108
|
const page = message.page();
|
|
97
|
-
if (this._shouldDispatchEvent(page,
|
|
98
|
-
const pageDispatcher =
|
|
99
|
-
this._dispatchEvent(
|
|
109
|
+
if (this._shouldDispatchEvent(page, "console")) {
|
|
110
|
+
const pageDispatcher = import_pageDispatcher.PageDispatcher.from(this, page);
|
|
111
|
+
this._dispatchEvent("console", {
|
|
100
112
|
page: pageDispatcher,
|
|
101
113
|
type: message.type(),
|
|
102
114
|
text: message.text(),
|
|
103
|
-
args: message.args().map(a =>
|
|
115
|
+
args: message.args().map((a) => {
|
|
116
|
+
const elementHandle = a.asElement();
|
|
117
|
+
if (elementHandle)
|
|
118
|
+
return import_elementHandlerDispatcher.ElementHandleDispatcher.from(import_frameDispatcher.FrameDispatcher.from(this, elementHandle._frame), elementHandle);
|
|
119
|
+
return import_jsHandleDispatcher.JSHandleDispatcher.fromJSHandle(pageDispatcher, a);
|
|
120
|
+
}),
|
|
104
121
|
location: message.location()
|
|
105
122
|
});
|
|
106
123
|
}
|
|
107
124
|
});
|
|
108
|
-
this.
|
|
109
|
-
if (this._shouldDispatchEvent(dialog.page(),
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
});
|
|
123
|
-
this.addObjectListener(_crBrowser.CRBrowserContext.CREvents.ServiceWorker, serviceWorker => this._dispatchEvent('serviceWorker', {
|
|
124
|
-
worker: new _pageDispatcher.WorkerDispatcher(this, serviceWorker)
|
|
125
|
-
}));
|
|
125
|
+
this._dialogHandler = (dialog) => {
|
|
126
|
+
if (!this._shouldDispatchEvent(dialog.page(), "dialog"))
|
|
127
|
+
return false;
|
|
128
|
+
this._dispatchEvent("dialog", { dialog: new import_dialogDispatcher.DialogDispatcher(this, dialog) });
|
|
129
|
+
return true;
|
|
130
|
+
};
|
|
131
|
+
context.dialogManager.addDialogHandler(this._dialogHandler);
|
|
132
|
+
if (context._browser.options.name === "chromium") {
|
|
133
|
+
for (const page of context.backgroundPages())
|
|
134
|
+
this._dispatchEvent("backgroundPage", { page: import_pageDispatcher.PageDispatcher.from(this, page) });
|
|
135
|
+
this.addObjectListener(import_crBrowser.CRBrowserContext.CREvents.BackgroundPage, (page) => this._dispatchEvent("backgroundPage", { page: import_pageDispatcher.PageDispatcher.from(this, page) }));
|
|
136
|
+
for (const serviceWorker of context.serviceWorkers())
|
|
137
|
+
this._dispatchEvent("serviceWorker", { worker: new import_pageDispatcher.WorkerDispatcher(this, serviceWorker) });
|
|
138
|
+
this.addObjectListener(import_crBrowser.CRBrowserContext.CREvents.ServiceWorker, (serviceWorker) => this._dispatchEvent("serviceWorker", { worker: new import_pageDispatcher.WorkerDispatcher(this, serviceWorker) }));
|
|
126
139
|
}
|
|
127
|
-
this.addObjectListener(
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
// By the time requestFinished is triggered to update the request, we should have a request on the client already.
|
|
134
|
-
const redirectFromDispatcher = request.redirectedFrom() && (0, _dispatcher.existingDispatcher)(request.redirectedFrom());
|
|
135
|
-
if (!redirectFromDispatcher && !this._shouldDispatchNetworkEvent(request, 'request') && !request.isNavigationRequest()) return;
|
|
136
|
-
const requestDispatcher = _networkDispatchers.RequestDispatcher.from(this, request);
|
|
137
|
-
this._dispatchEvent('request', {
|
|
140
|
+
this.addObjectListener(import_browserContext.BrowserContext.Events.Request, (request) => {
|
|
141
|
+
const redirectFromDispatcher = request.redirectedFrom() && this.connection.existingDispatcher(request.redirectedFrom());
|
|
142
|
+
if (!redirectFromDispatcher && !this._shouldDispatchNetworkEvent(request, "request") && !request.isNavigationRequest())
|
|
143
|
+
return;
|
|
144
|
+
const requestDispatcher = import_networkDispatchers.RequestDispatcher.from(this, request);
|
|
145
|
+
this._dispatchEvent("request", {
|
|
138
146
|
request: requestDispatcher,
|
|
139
|
-
page:
|
|
147
|
+
page: import_pageDispatcher.PageDispatcher.fromNullable(this, request.frame()?._page.initializedOrUndefined())
|
|
140
148
|
});
|
|
141
149
|
});
|
|
142
|
-
this.addObjectListener(
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
this._dispatchEvent(
|
|
147
|
-
response:
|
|
148
|
-
page:
|
|
150
|
+
this.addObjectListener(import_browserContext.BrowserContext.Events.Response, (response) => {
|
|
151
|
+
const requestDispatcher = this.connection.existingDispatcher(response.request());
|
|
152
|
+
if (!requestDispatcher && !this._shouldDispatchNetworkEvent(response.request(), "response"))
|
|
153
|
+
return;
|
|
154
|
+
this._dispatchEvent("response", {
|
|
155
|
+
response: import_networkDispatchers.ResponseDispatcher.from(this, response),
|
|
156
|
+
page: import_pageDispatcher.PageDispatcher.fromNullable(this, response.frame()?._page.initializedOrUndefined())
|
|
149
157
|
});
|
|
150
158
|
});
|
|
151
|
-
this.addObjectListener(
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
this._dispatchEvent(
|
|
156
|
-
request:
|
|
157
|
-
failureText: request._failureText ||
|
|
159
|
+
this.addObjectListener(import_browserContext.BrowserContext.Events.RequestFailed, (request) => {
|
|
160
|
+
const requestDispatcher = this.connection.existingDispatcher(request);
|
|
161
|
+
if (!requestDispatcher && !this._shouldDispatchNetworkEvent(request, "requestFailed"))
|
|
162
|
+
return;
|
|
163
|
+
this._dispatchEvent("requestFailed", {
|
|
164
|
+
request: import_networkDispatchers.RequestDispatcher.from(this, request),
|
|
165
|
+
failureText: request._failureText || void 0,
|
|
158
166
|
responseEndTiming: request._responseEndTiming,
|
|
159
|
-
page:
|
|
167
|
+
page: import_pageDispatcher.PageDispatcher.fromNullable(this, request.frame()?._page.initializedOrUndefined())
|
|
160
168
|
});
|
|
161
169
|
});
|
|
162
|
-
this.addObjectListener(
|
|
163
|
-
request
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
this._dispatchEvent('requestFinished', {
|
|
170
|
-
request: _networkDispatchers.RequestDispatcher.from(this, request),
|
|
171
|
-
response: _networkDispatchers.ResponseDispatcher.fromNullable(this, response),
|
|
170
|
+
this.addObjectListener(import_browserContext.BrowserContext.Events.RequestFinished, ({ request, response }) => {
|
|
171
|
+
const requestDispatcher = this.connection.existingDispatcher(request);
|
|
172
|
+
if (!requestDispatcher && !this._shouldDispatchNetworkEvent(request, "requestFinished"))
|
|
173
|
+
return;
|
|
174
|
+
this._dispatchEvent("requestFinished", {
|
|
175
|
+
request: import_networkDispatchers.RequestDispatcher.from(this, request),
|
|
176
|
+
response: import_networkDispatchers.ResponseDispatcher.fromNullable(this, response),
|
|
172
177
|
responseEndTiming: request._responseEndTiming,
|
|
173
|
-
page:
|
|
178
|
+
page: import_pageDispatcher.PageDispatcher.fromNullable(this, request.frame()?._page.initializedOrUndefined())
|
|
174
179
|
});
|
|
175
180
|
});
|
|
181
|
+
this.addObjectListener(import_browserContext.BrowserContext.Events.RecorderEvent, ({ event, data, page }) => {
|
|
182
|
+
this._dispatchEvent("recorderEvent", { event, data, page: import_pageDispatcher.PageDispatcher.from(this, page) });
|
|
183
|
+
});
|
|
184
|
+
}
|
|
185
|
+
static from(parentScope, context) {
|
|
186
|
+
const result = parentScope.connection.existingDispatcher(context);
|
|
187
|
+
return result || new BrowserContextDispatcher(parentScope, context);
|
|
176
188
|
}
|
|
177
189
|
_shouldDispatchNetworkEvent(request, event) {
|
|
178
|
-
|
|
179
|
-
return this._shouldDispatchEvent((_request$frame4 = request.frame()) === null || _request$frame4 === void 0 || (_request$frame4 = _request$frame4._page) === null || _request$frame4 === void 0 ? void 0 : _request$frame4.initializedOrUndefined(), event);
|
|
190
|
+
return this._shouldDispatchEvent(request.frame()?._page?.initializedOrUndefined(), event);
|
|
180
191
|
}
|
|
181
192
|
_shouldDispatchEvent(page, event) {
|
|
182
|
-
if (this._subscriptions.has(event))
|
|
183
|
-
|
|
184
|
-
|
|
193
|
+
if (this._subscriptions.has(event))
|
|
194
|
+
return true;
|
|
195
|
+
const pageDispatcher = page ? this.connection.existingDispatcher(page) : void 0;
|
|
196
|
+
if (pageDispatcher?._subscriptions.has(event))
|
|
197
|
+
return true;
|
|
185
198
|
return false;
|
|
186
199
|
}
|
|
187
|
-
async createTempFiles(params) {
|
|
200
|
+
async createTempFiles(params, progress) {
|
|
188
201
|
const dir = this._context._browser.options.artifactsDir;
|
|
189
|
-
const tmpDir =
|
|
190
|
-
const tempDirWithRootName = params.rootDirName ?
|
|
191
|
-
await
|
|
192
|
-
recursive: true
|
|
193
|
-
});
|
|
202
|
+
const tmpDir = import_path.default.join(dir, "upload-" + (0, import_crypto.createGuid)());
|
|
203
|
+
const tempDirWithRootName = params.rootDirName ? import_path.default.join(tmpDir, import_path.default.basename(params.rootDirName)) : tmpDir;
|
|
204
|
+
await progress.race(import_fs.default.promises.mkdir(tempDirWithRootName, { recursive: true }));
|
|
194
205
|
this._context._tempDirs.push(tmpDir);
|
|
195
206
|
return {
|
|
196
|
-
rootDir: params.rootDirName ? new
|
|
197
|
-
writableStreams: await Promise.all(params.items.map(async item => {
|
|
198
|
-
await
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
const file = _fs.default.createWriteStream(_path.default.join(tempDirWithRootName, item.name));
|
|
202
|
-
return new _writableStreamDispatcher.WritableStreamDispatcher(this, file, item.lastModifiedMs);
|
|
207
|
+
rootDir: params.rootDirName ? new import_writableStreamDispatcher.WritableStreamDispatcher(this, tempDirWithRootName) : void 0,
|
|
208
|
+
writableStreams: await Promise.all(params.items.map(async (item) => {
|
|
209
|
+
await progress.race(import_fs.default.promises.mkdir(import_path.default.dirname(import_path.default.join(tempDirWithRootName, item.name)), { recursive: true }));
|
|
210
|
+
const file = import_fs.default.createWriteStream(import_path.default.join(tempDirWithRootName, item.name));
|
|
211
|
+
return new import_writableStreamDispatcher.WritableStreamDispatcher(this, file, item.lastModifiedMs);
|
|
203
212
|
}))
|
|
204
213
|
};
|
|
205
214
|
}
|
|
206
|
-
async
|
|
207
|
-
this._context.
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
// When reusing the context, we might have some bindings called late enough,
|
|
215
|
-
// after context and page dispatchers have been disposed.
|
|
216
|
-
if (this._disposed) return;
|
|
217
|
-
const pageDispatcher = _pageDispatcher.PageDispatcher.from(this, source.page);
|
|
218
|
-
const binding = new _pageDispatcher.BindingCallDispatcher(pageDispatcher, params.name, !!params.needsHandle, source, args);
|
|
219
|
-
this._dispatchEvent('bindingCall', {
|
|
220
|
-
binding
|
|
221
|
-
});
|
|
222
|
-
return binding.promise();
|
|
215
|
+
async exposeBinding(params, progress) {
|
|
216
|
+
const binding = await this._context.exposeBinding(progress, params.name, !!params.needsHandle, (source, ...args) => {
|
|
217
|
+
if (this._disposed)
|
|
218
|
+
return;
|
|
219
|
+
const pageDispatcher = import_pageDispatcher.PageDispatcher.from(this, source.page);
|
|
220
|
+
const binding2 = new import_pageDispatcher.BindingCallDispatcher(pageDispatcher, params.name, !!params.needsHandle, source, args);
|
|
221
|
+
this._dispatchEvent("bindingCall", { binding: binding2 });
|
|
222
|
+
return binding2.promise();
|
|
223
223
|
});
|
|
224
|
+
this._bindings.push(binding);
|
|
224
225
|
}
|
|
225
|
-
async newPage(params,
|
|
226
|
-
return {
|
|
227
|
-
|
|
228
|
-
|
|
226
|
+
async newPage(params, progress) {
|
|
227
|
+
return { page: import_pageDispatcher.PageDispatcher.from(this, await this._context.newPage(
|
|
228
|
+
progress,
|
|
229
|
+
false
|
|
230
|
+
/* isServerSide */
|
|
231
|
+
)) };
|
|
229
232
|
}
|
|
230
|
-
async cookies(params) {
|
|
231
|
-
return {
|
|
232
|
-
cookies: await this._context.cookies(params.urls)
|
|
233
|
-
};
|
|
233
|
+
async cookies(params, progress) {
|
|
234
|
+
return { cookies: await progress.race(this._context.cookies(params.urls)) };
|
|
234
235
|
}
|
|
235
|
-
async addCookies(params) {
|
|
236
|
+
async addCookies(params, progress) {
|
|
236
237
|
await this._context.addCookies(params.cookies);
|
|
237
238
|
}
|
|
238
|
-
async clearCookies(params) {
|
|
239
|
-
const nameRe = params.nameRegexSource !==
|
|
240
|
-
const domainRe = params.domainRegexSource !==
|
|
241
|
-
const pathRe = params.pathRegexSource !==
|
|
239
|
+
async clearCookies(params, progress) {
|
|
240
|
+
const nameRe = params.nameRegexSource !== void 0 && params.nameRegexFlags !== void 0 ? new RegExp(params.nameRegexSource, params.nameRegexFlags) : void 0;
|
|
241
|
+
const domainRe = params.domainRegexSource !== void 0 && params.domainRegexFlags !== void 0 ? new RegExp(params.domainRegexSource, params.domainRegexFlags) : void 0;
|
|
242
|
+
const pathRe = params.pathRegexSource !== void 0 && params.pathRegexFlags !== void 0 ? new RegExp(params.pathRegexSource, params.pathRegexFlags) : void 0;
|
|
242
243
|
await this._context.clearCookies({
|
|
243
244
|
name: nameRe || params.name,
|
|
244
245
|
domain: domainRe || params.domain,
|
|
245
246
|
path: pathRe || params.path
|
|
246
247
|
});
|
|
247
248
|
}
|
|
248
|
-
async grantPermissions(params) {
|
|
249
|
+
async grantPermissions(params, progress) {
|
|
249
250
|
await this._context.grantPermissions(params.permissions, params.origin);
|
|
250
251
|
}
|
|
251
|
-
async clearPermissions() {
|
|
252
|
+
async clearPermissions(params, progress) {
|
|
252
253
|
await this._context.clearPermissions();
|
|
253
254
|
}
|
|
254
|
-
async setGeolocation(params) {
|
|
255
|
+
async setGeolocation(params, progress) {
|
|
255
256
|
await this._context.setGeolocation(params.geolocation);
|
|
256
257
|
}
|
|
257
|
-
async setExtraHTTPHeaders(params) {
|
|
258
|
-
await this._context.setExtraHTTPHeaders(params.headers);
|
|
258
|
+
async setExtraHTTPHeaders(params, progress) {
|
|
259
|
+
await this._context.setExtraHTTPHeaders(progress, params.headers);
|
|
259
260
|
}
|
|
260
|
-
async setOffline(params) {
|
|
261
|
-
await this._context.setOffline(params.offline);
|
|
261
|
+
async setOffline(params, progress) {
|
|
262
|
+
await this._context.setOffline(progress, params.offline);
|
|
262
263
|
}
|
|
263
|
-
async setHTTPCredentials(params) {
|
|
264
|
-
await this._context.setHTTPCredentials(params.httpCredentials);
|
|
264
|
+
async setHTTPCredentials(params, progress) {
|
|
265
|
+
await progress.race(this._context.setHTTPCredentials(params.httpCredentials));
|
|
265
266
|
}
|
|
266
|
-
async addInitScript(params) {
|
|
267
|
-
await this._context.addInitScript(params.source);
|
|
267
|
+
async addInitScript(params, progress) {
|
|
268
|
+
this._initScripts.push(await this._context.addInitScript(progress, params.source));
|
|
268
269
|
}
|
|
269
|
-
async setNetworkInterceptionPatterns(params) {
|
|
270
|
+
async setNetworkInterceptionPatterns(params, progress) {
|
|
271
|
+
const hadMatchers = this._interceptionUrlMatchers.length > 0;
|
|
270
272
|
if (!params.patterns.length) {
|
|
271
|
-
|
|
272
|
-
|
|
273
|
+
if (hadMatchers)
|
|
274
|
+
await this._context.removeRequestInterceptor(this._requestInterceptor);
|
|
275
|
+
this._interceptionUrlMatchers = [];
|
|
276
|
+
} else {
|
|
277
|
+
this._interceptionUrlMatchers = params.patterns.map((pattern) => pattern.regexSource ? new RegExp(pattern.regexSource, pattern.regexFlags) : pattern.glob);
|
|
278
|
+
if (!hadMatchers)
|
|
279
|
+
await this._context.addRequestInterceptor(progress, this._requestInterceptor);
|
|
273
280
|
}
|
|
274
|
-
const urlMatchers = params.patterns.map(pattern => pattern.regexSource ? new RegExp(pattern.regexSource, pattern.regexFlags) : pattern.glob);
|
|
275
|
-
await this._context.setRequestInterceptor((route, request) => {
|
|
276
|
-
const matchesSome = urlMatchers.some(urlMatch => (0, _urlMatch.urlMatches)(this._context._options.baseURL, request.url(), urlMatch));
|
|
277
|
-
if (!matchesSome) return false;
|
|
278
|
-
this._dispatchEvent('route', {
|
|
279
|
-
route: _networkDispatchers.RouteDispatcher.from(_networkDispatchers.RequestDispatcher.from(this, request), route)
|
|
280
|
-
});
|
|
281
|
-
return true;
|
|
282
|
-
});
|
|
283
281
|
}
|
|
284
|
-
async setWebSocketInterceptionPatterns(params,
|
|
282
|
+
async setWebSocketInterceptionPatterns(params, progress) {
|
|
285
283
|
this._webSocketInterceptionPatterns = params.patterns;
|
|
286
|
-
if (params.patterns.length
|
|
284
|
+
if (params.patterns.length && !this._routeWebSocketInitScript)
|
|
285
|
+
this._routeWebSocketInitScript = await import_webSocketRouteDispatcher.WebSocketRouteDispatcher.install(progress, this.connection, this._context);
|
|
287
286
|
}
|
|
288
|
-
async storageState(params,
|
|
289
|
-
return await this._context.storageState(params.indexedDB);
|
|
287
|
+
async storageState(params, progress) {
|
|
288
|
+
return await progress.race(this._context.storageState(progress, params.indexedDB));
|
|
290
289
|
}
|
|
291
|
-
async close(params,
|
|
292
|
-
metadata.potentiallyClosesScope = true;
|
|
290
|
+
async close(params, progress) {
|
|
291
|
+
progress.metadata.potentiallyClosesScope = true;
|
|
293
292
|
await this._context.close(params);
|
|
294
293
|
}
|
|
295
|
-
async enableRecorder(params) {
|
|
296
|
-
await
|
|
294
|
+
async enableRecorder(params, progress) {
|
|
295
|
+
const recorder = await import_recorder.Recorder.forContext(this._context, params);
|
|
296
|
+
if (params.recorderMode === "api") {
|
|
297
|
+
await import_recorderApp.ProgrammaticRecorderApp.run(this._context, recorder);
|
|
298
|
+
return;
|
|
299
|
+
}
|
|
300
|
+
await import_recorderApp.RecorderApp.show(this._context, params);
|
|
301
|
+
}
|
|
302
|
+
async disableRecorder(params, progress) {
|
|
303
|
+
const recorder = import_recorder.Recorder.existingForContext(this._context);
|
|
304
|
+
if (recorder)
|
|
305
|
+
recorder.setMode("none");
|
|
297
306
|
}
|
|
298
|
-
async pause(params,
|
|
299
|
-
// Debugger will take care of this.
|
|
307
|
+
async pause(params, progress) {
|
|
300
308
|
}
|
|
301
|
-
async newCDPSession(params) {
|
|
302
|
-
if (!this._object._browser.options.isChromium)
|
|
303
|
-
|
|
309
|
+
async newCDPSession(params, progress) {
|
|
310
|
+
if (!this._object._browser.options.isChromium)
|
|
311
|
+
throw new Error(`CDP session is only available in Chromium`);
|
|
312
|
+
if (!params.page && !params.frame || params.page && params.frame)
|
|
313
|
+
throw new Error(`CDP session must be initiated with either Page or Frame, not none or both`);
|
|
304
314
|
const crBrowserContext = this._object;
|
|
305
|
-
return {
|
|
306
|
-
session: new _cdpSessionDispatcher.CDPSessionDispatcher(this, await crBrowserContext.newCDPSession((params.page ? params.page : params.frame)._object))
|
|
307
|
-
};
|
|
315
|
+
return { session: new import_cdpSessionDispatcher.CDPSessionDispatcher(this, await progress.race(crBrowserContext.newCDPSession((params.page ? params.page : params.frame)._object))) };
|
|
308
316
|
}
|
|
309
|
-
async harStart(params) {
|
|
310
|
-
const harId =
|
|
311
|
-
return {
|
|
312
|
-
harId
|
|
313
|
-
};
|
|
317
|
+
async harStart(params, progress) {
|
|
318
|
+
const harId = this._context.harStart(params.page ? params.page._object : null, params.options);
|
|
319
|
+
return { harId };
|
|
314
320
|
}
|
|
315
|
-
async harExport(params) {
|
|
316
|
-
const artifact = await this._context.
|
|
317
|
-
if (!artifact)
|
|
318
|
-
|
|
319
|
-
|
|
320
|
-
};
|
|
321
|
+
async harExport(params, progress) {
|
|
322
|
+
const artifact = await progress.race(this._context.harExport(params.harId));
|
|
323
|
+
if (!artifact)
|
|
324
|
+
throw new Error("No HAR artifact. Ensure record.harPath is set.");
|
|
325
|
+
return { artifact: import_artifactDispatcher.ArtifactDispatcher.from(this, artifact) };
|
|
321
326
|
}
|
|
322
|
-
async clockFastForward(params,
|
|
323
|
-
|
|
324
|
-
await this._context.clock.fastForward((_ref = (_params$ticksString = params.ticksString) !== null && _params$ticksString !== void 0 ? _params$ticksString : params.ticksNumber) !== null && _ref !== void 0 ? _ref : 0);
|
|
327
|
+
async clockFastForward(params, progress) {
|
|
328
|
+
await this._context.clock.fastForward(progress, params.ticksString ?? params.ticksNumber ?? 0);
|
|
325
329
|
}
|
|
326
|
-
async clockInstall(params,
|
|
327
|
-
|
|
328
|
-
await this._context.clock.install((_ref2 = (_params$timeString = params.timeString) !== null && _params$timeString !== void 0 ? _params$timeString : params.timeNumber) !== null && _ref2 !== void 0 ? _ref2 : undefined);
|
|
330
|
+
async clockInstall(params, progress) {
|
|
331
|
+
await this._context.clock.install(progress, params.timeString ?? params.timeNumber ?? void 0);
|
|
329
332
|
}
|
|
330
|
-
async clockPauseAt(params,
|
|
331
|
-
|
|
332
|
-
|
|
333
|
+
async clockPauseAt(params, progress) {
|
|
334
|
+
await this._context.clock.pauseAt(progress, params.timeString ?? params.timeNumber ?? 0);
|
|
335
|
+
this._clockPaused = true;
|
|
333
336
|
}
|
|
334
|
-
async clockResume(params,
|
|
335
|
-
await this._context.clock.resume();
|
|
337
|
+
async clockResume(params, progress) {
|
|
338
|
+
await this._context.clock.resume(progress);
|
|
339
|
+
this._clockPaused = false;
|
|
336
340
|
}
|
|
337
|
-
async clockRunFor(params,
|
|
338
|
-
|
|
339
|
-
await this._context.clock.runFor((_ref4 = (_params$ticksString2 = params.ticksString) !== null && _params$ticksString2 !== void 0 ? _params$ticksString2 : params.ticksNumber) !== null && _ref4 !== void 0 ? _ref4 : 0);
|
|
341
|
+
async clockRunFor(params, progress) {
|
|
342
|
+
await this._context.clock.runFor(progress, params.ticksString ?? params.ticksNumber ?? 0);
|
|
340
343
|
}
|
|
341
|
-
async clockSetFixedTime(params,
|
|
342
|
-
|
|
343
|
-
await this._context.clock.setFixedTime((_ref5 = (_params$timeString3 = params.timeString) !== null && _params$timeString3 !== void 0 ? _params$timeString3 : params.timeNumber) !== null && _ref5 !== void 0 ? _ref5 : 0);
|
|
344
|
+
async clockSetFixedTime(params, progress) {
|
|
345
|
+
await this._context.clock.setFixedTime(progress, params.timeString ?? params.timeNumber ?? 0);
|
|
344
346
|
}
|
|
345
|
-
async clockSetSystemTime(params,
|
|
346
|
-
|
|
347
|
-
await this._context.clock.setSystemTime((_ref6 = (_params$timeString4 = params.timeString) !== null && _params$timeString4 !== void 0 ? _params$timeString4 : params.timeNumber) !== null && _ref6 !== void 0 ? _ref6 : 0);
|
|
347
|
+
async clockSetSystemTime(params, progress) {
|
|
348
|
+
await this._context.clock.setSystemTime(progress, params.timeString ?? params.timeNumber ?? 0);
|
|
348
349
|
}
|
|
349
|
-
async updateSubscription(params) {
|
|
350
|
-
if (params.enabled)
|
|
350
|
+
async updateSubscription(params, progress) {
|
|
351
|
+
if (params.enabled)
|
|
352
|
+
this._subscriptions.add(params.event);
|
|
353
|
+
else
|
|
354
|
+
this._subscriptions.delete(params.event);
|
|
355
|
+
}
|
|
356
|
+
async registerSelectorEngine(params, progress) {
|
|
357
|
+
this._object.selectors().register(params.selectorEngine);
|
|
358
|
+
}
|
|
359
|
+
async setTestIdAttributeName(params, progress) {
|
|
360
|
+
this._object.selectors().setTestIdAttributeName(params.testIdAttributeName);
|
|
351
361
|
}
|
|
352
362
|
_onDispose() {
|
|
353
|
-
|
|
354
|
-
|
|
363
|
+
if (this._context.isClosingOrClosed())
|
|
364
|
+
return;
|
|
365
|
+
this._context.dialogManager.removeDialogHandler(this._dialogHandler);
|
|
366
|
+
this._interceptionUrlMatchers = [];
|
|
367
|
+
this._context.removeRequestInterceptor(this._requestInterceptor).catch(() => {
|
|
368
|
+
});
|
|
369
|
+
this._context.removeExposedBindings(this._bindings).catch(() => {
|
|
370
|
+
});
|
|
371
|
+
this._bindings = [];
|
|
372
|
+
this._context.removeInitScripts(this._initScripts).catch(() => {
|
|
373
|
+
});
|
|
374
|
+
this._initScripts = [];
|
|
375
|
+
if (this._routeWebSocketInitScript)
|
|
376
|
+
import_webSocketRouteDispatcher.WebSocketRouteDispatcher.uninstall(this.connection, this._context, this._routeWebSocketInitScript).catch(() => {
|
|
377
|
+
});
|
|
378
|
+
this._routeWebSocketInitScript = void 0;
|
|
379
|
+
if (this._clockPaused)
|
|
380
|
+
this._context.clock.resumeNoReply();
|
|
381
|
+
this._clockPaused = false;
|
|
355
382
|
}
|
|
356
383
|
}
|
|
357
|
-
|
|
384
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
385
|
+
0 && (module.exports = {
|
|
386
|
+
BrowserContextDispatcher
|
|
387
|
+
});
|