patchright-bun-core 1.58.0 → 1.59.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/README.md +2 -2
- package/ThirdPartyNotices.txt +3551 -4075
- package/bin/install_media_pack.ps1 +5 -5
- package/bin/install_webkit_wsl.ps1 +32 -32
- package/bin/reinstall_chrome_beta_linux.sh +42 -42
- package/bin/reinstall_chrome_beta_mac.sh +13 -13
- package/bin/reinstall_chrome_beta_win.ps1 +24 -24
- package/bin/reinstall_chrome_stable_linux.sh +42 -42
- package/bin/reinstall_chrome_stable_mac.sh +12 -12
- package/bin/reinstall_chrome_stable_win.ps1 +24 -24
- package/bin/reinstall_msedge_beta_linux.sh +48 -48
- package/bin/reinstall_msedge_beta_mac.sh +11 -11
- package/bin/reinstall_msedge_beta_win.ps1 +23 -23
- package/bin/reinstall_msedge_dev_linux.sh +48 -48
- package/bin/reinstall_msedge_dev_mac.sh +11 -11
- package/bin/reinstall_msedge_dev_win.ps1 +23 -23
- package/bin/reinstall_msedge_stable_linux.sh +48 -48
- package/bin/reinstall_msedge_stable_mac.sh +11 -11
- package/bin/reinstall_msedge_stable_win.ps1 +23 -23
- package/browsers.json +81 -79
- package/cli.js +18 -18
- package/index.d.ts +17 -17
- package/index.js +32 -32
- package/index.mjs +28 -28
- package/lib/androidServerImpl.js +65 -65
- package/lib/bootstrap.js +77 -0
- package/lib/browserServerImpl.js +120 -120
- package/lib/cli/browserActions.js +308 -0
- package/lib/cli/driver.js +98 -97
- package/lib/cli/installActions.js +171 -0
- package/lib/cli/program.js +225 -589
- package/lib/cli/programWithTestStub.js +74 -74
- package/lib/client/android.js +361 -361
- package/lib/client/api.js +137 -137
- package/lib/client/artifact.js +79 -79
- package/lib/client/browser.js +169 -161
- package/lib/client/browserContext.js +563 -582
- package/lib/client/browserType.js +153 -185
- package/lib/client/cdpSession.js +55 -51
- package/lib/client/channelOwner.js +194 -194
- package/lib/client/clientHelper.js +64 -64
- package/lib/client/clientInstrumentation.js +55 -55
- package/lib/client/clientStackTrace.js +69 -69
- package/lib/client/clock.js +68 -68
- package/lib/client/{webSocket.js → connect.js} +143 -93
- package/lib/client/connection.js +322 -318
- package/lib/client/consoleMessage.js +61 -58
- package/lib/client/coverage.js +44 -44
- package/lib/client/debugger.js +57 -0
- package/lib/client/dialog.js +63 -56
- package/lib/client/disposable.js +76 -0
- package/lib/client/download.js +62 -62
- package/lib/client/electron.js +139 -138
- package/lib/client/elementHandle.js +281 -284
- package/lib/client/errors.js +77 -77
- package/lib/client/eventEmitter.js +314 -314
- package/lib/client/events.js +103 -103
- package/lib/client/fetch.js +367 -368
- package/lib/client/fileChooser.js +46 -46
- package/lib/client/fileUtils.js +34 -34
- package/lib/client/frame.js +404 -409
- package/lib/client/harRouter.js +99 -87
- package/lib/client/input.js +84 -84
- package/lib/client/jsHandle.js +105 -109
- package/lib/client/jsonPipe.js +39 -39
- package/lib/client/localUtils.js +60 -60
- package/lib/client/locator.js +367 -369
- package/lib/client/network.js +750 -747
- package/lib/client/page.js +731 -745
- package/lib/client/platform.js +74 -77
- package/lib/client/playwright.js +71 -71
- package/lib/client/screencast.js +88 -0
- package/lib/client/selectors.js +57 -55
- package/lib/client/stream.js +39 -39
- package/lib/client/timeoutSettings.js +79 -79
- package/lib/client/tracing.js +126 -119
- package/lib/client/types.js +28 -28
- package/lib/client/video.js +52 -59
- package/lib/client/waiter.js +142 -142
- package/lib/client/webError.js +39 -39
- package/lib/client/worker.js +85 -85
- package/lib/client/writableStream.js +39 -39
- package/lib/generated/bindingsControllerSource.js +28 -28
- package/lib/generated/clockSource.js +28 -28
- package/lib/generated/injectedScriptSource.js +28 -28
- package/lib/generated/pollingRecorderSource.js +28 -28
- package/lib/generated/storageScriptSource.js +28 -28
- package/lib/generated/utilityScriptSource.js +28 -28
- package/lib/generated/webSocketMockSource.js +336 -336
- package/lib/inProcessFactory.js +60 -60
- package/lib/inprocess.js +3 -3
- package/lib/mcpBundle.js +78 -84
- package/lib/mcpBundleImpl.js +91 -0
- package/lib/outofprocess.js +76 -76
- package/lib/protocol/serializers.js +197 -197
- package/lib/protocol/validator.js +3067 -2969
- package/lib/protocol/validatorPrimitives.js +193 -193
- package/lib/remote/playwrightConnection.js +131 -129
- package/lib/remote/playwrightPipeServer.js +100 -0
- package/lib/remote/playwrightServer.js +339 -334
- package/lib/remote/playwrightWebSocketServer.js +73 -0
- package/lib/remote/serverTransport.js +96 -0
- package/lib/server/android/android.js +465 -465
- package/lib/server/android/backendAdb.js +177 -177
- package/lib/server/artifact.js +127 -127
- package/lib/server/bidi/bidiBrowser.js +571 -549
- package/lib/server/bidi/bidiChromium.js +162 -148
- package/lib/server/bidi/bidiConnection.js +213 -213
- package/lib/server/bidi/bidiDeserializer.js +116 -116
- package/lib/server/bidi/bidiExecutionContext.js +267 -267
- package/lib/server/bidi/bidiFirefox.js +128 -128
- package/lib/server/bidi/bidiInput.js +146 -146
- package/lib/server/bidi/bidiNetworkManager.js +411 -383
- package/lib/server/bidi/bidiOverCdp.js +102 -102
- package/lib/server/bidi/bidiPage.js +599 -583
- package/lib/server/bidi/bidiPdf.js +106 -106
- package/lib/server/bidi/third_party/bidiCommands.d.js +22 -22
- package/lib/server/bidi/third_party/bidiKeyboard.js +256 -256
- package/lib/server/bidi/third_party/bidiProtocol.js +24 -24
- package/lib/server/bidi/third_party/bidiProtocolCore.js +180 -180
- package/lib/server/bidi/third_party/bidiProtocolPermissions.js +42 -42
- package/lib/server/bidi/third_party/bidiSerializer.js +148 -148
- package/lib/server/bidi/third_party/firefoxPrefs.js +261 -259
- package/lib/server/browser.js +212 -149
- package/lib/server/browserContext.js +741 -702
- package/lib/server/browserType.js +338 -336
- package/lib/server/callLog.js +82 -82
- package/lib/server/chromium/chromium.js +399 -395
- package/lib/server/chromium/chromiumSwitches.js +104 -104
- package/lib/server/chromium/crBrowser.js +528 -511
- package/lib/server/chromium/crConnection.js +197 -197
- package/lib/server/chromium/crCoverage.js +235 -235
- package/lib/server/chromium/crDevTools.js +111 -111
- package/lib/server/chromium/crDragDrop.js +131 -131
- package/lib/server/chromium/crExecutionContext.js +146 -146
- package/lib/server/chromium/crInput.js +187 -187
- package/lib/server/chromium/crNetworkManager.js +707 -707
- package/lib/server/chromium/crPage.js +963 -1001
- package/lib/server/chromium/crPdf.js +121 -121
- package/lib/server/chromium/crProtocolHelper.js +145 -145
- package/lib/server/chromium/crServiceWorker.js +137 -136
- package/lib/server/chromium/defaultFontFamilies.js +162 -162
- package/lib/server/chromium/protocol.d.js +16 -16
- package/lib/server/clock.js +149 -149
- package/lib/server/codegen/csharp.js +327 -327
- package/lib/server/codegen/java.js +274 -274
- package/lib/server/codegen/javascript.js +247 -247
- package/lib/server/codegen/jsonl.js +52 -52
- package/lib/server/codegen/language.js +132 -132
- package/lib/server/codegen/languages.js +68 -68
- package/lib/server/codegen/python.js +279 -279
- package/lib/server/codegen/types.js +16 -16
- package/lib/server/console.js +61 -57
- package/lib/server/cookieStore.js +206 -206
- package/lib/server/debugController.js +197 -191
- package/lib/server/debugger.js +112 -119
- package/lib/server/deviceDescriptors.js +39 -39
- package/lib/server/deviceDescriptorsSource.json +1778 -1778
- package/lib/server/dialog.js +116 -116
- package/lib/server/dispatchers/androidDispatcher.js +325 -325
- package/lib/server/dispatchers/artifactDispatcher.js +118 -118
- package/lib/server/dispatchers/browserContextDispatcher.js +381 -384
- package/lib/server/dispatchers/browserDispatcher.js +124 -118
- package/lib/server/dispatchers/browserTypeDispatcher.js +71 -64
- package/lib/server/dispatchers/cdpSessionDispatcher.js +47 -44
- package/lib/server/dispatchers/debugControllerDispatcher.js +78 -78
- package/lib/server/dispatchers/debuggerDispatcher.js +84 -0
- package/lib/server/dispatchers/dialogDispatcher.js +47 -47
- package/lib/server/dispatchers/dispatcher.js +364 -364
- package/lib/server/dispatchers/disposableDispatcher.js +39 -0
- package/lib/server/dispatchers/electronDispatcher.js +90 -89
- package/lib/server/dispatchers/elementHandlerDispatcher.js +181 -181
- package/lib/server/dispatchers/frameDispatcher.js +227 -227
- package/lib/server/dispatchers/jsHandleDispatcher.js +85 -85
- package/lib/server/dispatchers/jsonPipeDispatcher.js +58 -58
- package/lib/server/dispatchers/localUtilsDispatcher.js +185 -149
- package/lib/server/dispatchers/networkDispatchers.js +214 -213
- package/lib/server/dispatchers/pageDispatcher.js +456 -393
- package/lib/server/dispatchers/playwrightDispatcher.js +108 -108
- package/lib/server/dispatchers/streamDispatcher.js +67 -67
- package/lib/server/dispatchers/tracingDispatcher.js +68 -68
- package/lib/server/dispatchers/webSocketRouteDispatcher.js +164 -165
- package/lib/server/dispatchers/writableStreamDispatcher.js +79 -79
- package/lib/server/disposable.js +41 -0
- package/lib/server/dom.js +833 -815
- package/lib/server/download.js +71 -70
- package/lib/server/electron/electron.js +278 -273
- package/lib/server/electron/loader.js +29 -29
- package/lib/server/errors.js +69 -69
- package/lib/server/fetch.js +621 -621
- package/lib/server/fileChooser.js +43 -43
- package/lib/server/fileUploadUtils.js +84 -84
- package/lib/server/firefox/ffBrowser.js +408 -418
- package/lib/server/firefox/ffConnection.js +142 -142
- package/lib/server/firefox/ffExecutionContext.js +150 -150
- package/lib/server/firefox/ffInput.js +175 -159
- package/lib/server/firefox/ffNetworkManager.js +256 -256
- package/lib/server/firefox/ffPage.js +494 -497
- package/lib/server/firefox/firefox.js +114 -114
- package/lib/server/firefox/protocol.d.js +16 -16
- package/lib/server/formData.js +147 -147
- package/lib/server/frameSelectors.js +160 -160
- package/lib/server/frames.js +1500 -1471
- package/lib/server/har/harRecorder.js +147 -147
- package/lib/server/har/harTracer.js +608 -607
- package/lib/server/harBackend.js +157 -157
- package/lib/server/helper.js +96 -96
- package/lib/server/index.js +58 -58
- package/lib/server/input.js +322 -277
- package/lib/server/instrumentation.js +77 -72
- package/lib/server/javascript.js +291 -291
- package/lib/server/launchApp.js +127 -128
- package/lib/server/localUtils.js +214 -214
- package/lib/server/macEditingCommands.js +143 -143
- package/lib/server/network.js +668 -667
- package/lib/server/overlay.js +138 -0
- package/lib/server/page.js +890 -830
- package/lib/server/pipeTransport.js +89 -89
- package/lib/server/playwright.js +69 -69
- package/lib/server/progress.js +138 -132
- package/lib/server/protocolError.js +52 -52
- package/lib/server/recorder/chat.js +161 -161
- package/lib/server/recorder/recorderApp.js +367 -366
- package/lib/server/recorder/recorderRunner.js +138 -138
- package/lib/server/recorder/recorderSignalProcessor.js +83 -83
- package/lib/server/recorder/recorderUtils.js +157 -157
- package/lib/server/recorder/throttledFile.js +57 -57
- package/lib/server/recorder.js +535 -499
- package/lib/server/registry/browserFetcher.js +177 -177
- package/lib/server/registry/dependencies.js +371 -371
- package/lib/server/registry/index.js +1395 -1422
- package/lib/server/registry/nativeDeps.js +1281 -1280
- package/lib/server/registry/oopDownloadBrowserMain.js +127 -127
- package/lib/server/screencast.js +137 -190
- package/lib/server/screenshotter.js +333 -333
- package/lib/server/selectors.js +112 -112
- package/lib/server/socksClientCertificatesInterceptor.js +383 -383
- package/lib/server/socksInterceptor.js +95 -95
- package/lib/server/trace/recorder/snapshotter.js +147 -147
- package/lib/server/trace/recorder/snapshotterInjected.js +561 -561
- package/lib/server/trace/recorder/tracing.js +655 -604
- package/lib/server/trace/viewer/traceViewer.js +244 -245
- package/lib/server/transport.js +254 -254
- package/lib/server/types.js +28 -28
- package/lib/server/usKeyboardLayout.js +152 -145
- package/lib/server/utils/ascii.js +44 -44
- package/lib/server/utils/comparators.js +139 -139
- package/lib/server/utils/crypto.js +216 -216
- package/lib/server/utils/debug.js +42 -42
- package/lib/server/utils/debugLogger.js +122 -122
- package/lib/server/utils/disposable.js +32 -0
- package/lib/server/utils/env.js +73 -73
- package/lib/server/utils/eventsHelper.js +41 -39
- package/lib/server/utils/expectUtils.js +123 -123
- package/lib/server/utils/fileUtils.js +205 -191
- package/lib/server/utils/happyEyeballs.js +210 -207
- package/lib/server/utils/hostPlatform.js +123 -123
- package/lib/server/utils/httpServer.js +205 -203
- package/lib/server/utils/image_tools/colorUtils.js +89 -89
- package/lib/server/utils/image_tools/compare.js +109 -109
- package/lib/server/utils/image_tools/imageChannel.js +78 -78
- package/lib/server/utils/image_tools/stats.js +102 -102
- package/lib/server/utils/linuxUtils.js +71 -71
- package/lib/server/utils/network.js +243 -242
- package/lib/server/utils/nodePlatform.js +148 -154
- package/lib/server/utils/pipeTransport.js +84 -84
- package/lib/server/utils/processLauncher.js +243 -241
- package/lib/server/utils/profiler.js +65 -65
- package/lib/server/utils/socksProxy.js +511 -511
- package/lib/server/utils/spawnAsync.js +41 -41
- package/lib/server/utils/task.js +51 -51
- package/lib/server/utils/userAgent.js +98 -98
- package/lib/server/utils/wsServer.js +121 -121
- package/lib/server/utils/zipFile.js +74 -74
- package/lib/server/utils/zones.js +57 -57
- package/lib/server/videoRecorder.js +194 -124
- package/lib/server/webkit/protocol.d.js +16 -16
- package/lib/server/webkit/webkit.js +108 -108
- package/lib/server/webkit/wkBrowser.js +330 -335
- package/lib/server/webkit/wkConnection.js +144 -144
- package/lib/server/webkit/wkExecutionContext.js +154 -154
- package/lib/server/webkit/wkInput.js +181 -181
- package/lib/server/webkit/wkInterceptableRequest.js +197 -197
- package/lib/server/webkit/wkPage.js +1161 -1158
- package/lib/server/webkit/wkProvisionalPage.js +83 -83
- package/lib/server/webkit/wkWorkers.js +106 -105
- package/lib/serverRegistry.js +156 -0
- package/lib/third_party/pixelmatch.js +255 -255
- package/lib/tools/backend/browserBackend.js +79 -0
- package/lib/tools/backend/common.js +63 -0
- package/lib/tools/backend/config.js +41 -0
- package/lib/tools/backend/console.js +66 -0
- package/lib/tools/backend/context.js +296 -0
- package/lib/tools/backend/cookies.js +152 -0
- package/lib/tools/backend/devtools.js +69 -0
- package/lib/tools/backend/dialogs.js +59 -0
- package/lib/tools/backend/evaluate.js +64 -0
- package/lib/tools/backend/files.js +60 -0
- package/lib/tools/backend/form.js +64 -0
- package/lib/tools/backend/keyboard.js +155 -0
- package/lib/tools/backend/logFile.js +95 -0
- package/lib/tools/backend/mouse.js +168 -0
- package/lib/tools/backend/navigate.js +106 -0
- package/lib/tools/backend/network.js +135 -0
- package/lib/tools/backend/pdf.js +48 -0
- package/lib/tools/backend/response.js +305 -0
- package/lib/tools/backend/route.js +140 -0
- package/lib/tools/backend/runCode.js +77 -0
- package/lib/tools/backend/screenshot.js +88 -0
- package/lib/tools/backend/sessionLog.js +74 -0
- package/lib/tools/backend/snapshot.js +208 -0
- package/lib/tools/backend/storage.js +68 -0
- package/lib/tools/backend/tab.js +445 -0
- package/lib/tools/backend/tabs.js +67 -0
- package/lib/tools/backend/tool.js +47 -0
- package/lib/tools/backend/tools.js +102 -0
- package/lib/tools/backend/tracing.js +78 -0
- package/lib/tools/backend/utils.js +83 -0
- package/lib/tools/backend/verify.js +151 -0
- package/lib/tools/backend/video.js +98 -0
- package/lib/tools/backend/wait.js +63 -0
- package/lib/tools/backend/webstorage.js +223 -0
- package/lib/tools/cli-client/cli.js +6 -0
- package/lib/tools/cli-client/help.json +399 -0
- package/lib/tools/cli-client/minimist.js +128 -0
- package/lib/tools/cli-client/program.js +350 -0
- package/lib/tools/cli-client/registry.js +176 -0
- package/lib/tools/cli-client/session.js +289 -0
- package/lib/tools/cli-client/skill/SKILL.md +328 -0
- package/lib/tools/cli-client/skill/references/element-attributes.md +23 -0
- package/lib/tools/cli-client/skill/references/playwright-tests.md +39 -0
- package/lib/tools/cli-client/skill/references/request-mocking.md +87 -0
- package/lib/tools/cli-client/skill/references/running-code.md +231 -0
- package/lib/tools/cli-client/skill/references/session-management.md +169 -0
- package/lib/tools/cli-client/skill/references/storage-state.md +275 -0
- package/lib/tools/cli-client/skill/references/test-generation.md +88 -0
- package/lib/tools/cli-client/skill/references/tracing.md +139 -0
- package/lib/tools/cli-client/skill/references/video-recording.md +143 -0
- package/lib/tools/cli-daemon/command.js +73 -0
- package/lib/tools/cli-daemon/commands.js +956 -0
- package/lib/tools/cli-daemon/daemon.js +157 -0
- package/lib/tools/cli-daemon/helpGenerator.js +177 -0
- package/lib/tools/cli-daemon/program.js +129 -0
- package/lib/tools/dashboard/appIcon.png +0 -0
- package/lib/tools/dashboard/dashboardApp.js +284 -0
- package/lib/tools/dashboard/dashboardController.js +296 -0
- package/lib/tools/exports.js +60 -0
- package/lib/tools/mcp/browserFactory.js +233 -0
- package/lib/tools/mcp/cdpRelay.js +352 -0
- package/lib/tools/mcp/cli-stub.js +7 -0
- package/lib/tools/mcp/config.d.js +16 -0
- package/lib/tools/mcp/config.js +446 -0
- package/lib/tools/mcp/configIni.js +189 -0
- package/lib/{server/trace/viewer/traceParser.js → tools/mcp/extensionContextFactory.js} +55 -72
- package/lib/tools/mcp/index.js +62 -0
- package/lib/tools/mcp/log.js +35 -0
- package/lib/tools/mcp/program.js +107 -0
- package/lib/tools/mcp/protocol.js +28 -0
- package/lib/tools/mcp/watchdog.js +44 -0
- package/lib/tools/trace/SKILL.md +171 -0
- package/lib/tools/trace/installSkill.js +48 -0
- package/lib/tools/trace/traceActions.js +142 -0
- package/lib/tools/trace/traceAttachments.js +69 -0
- package/lib/tools/trace/traceCli.js +87 -0
- package/lib/tools/trace/traceConsole.js +97 -0
- package/lib/tools/trace/traceErrors.js +55 -0
- package/lib/tools/trace/traceOpen.js +69 -0
- package/lib/tools/trace/traceParser.js +96 -0
- package/lib/tools/trace/traceRequests.js +182 -0
- package/lib/tools/trace/traceScreenshot.js +68 -0
- package/lib/tools/trace/traceSnapshot.js +149 -0
- package/lib/tools/trace/traceUtils.js +153 -0
- package/lib/tools/utils/connect.js +32 -0
- package/lib/tools/utils/mcp/http.js +152 -0
- package/lib/tools/utils/mcp/server.js +230 -0
- package/lib/tools/utils/mcp/tool.js +47 -0
- package/lib/tools/utils/socketConnection.js +108 -0
- package/lib/utils/isomorphic/ariaSnapshot.js +455 -455
- package/lib/utils/isomorphic/assert.js +31 -31
- package/lib/utils/isomorphic/colors.js +72 -72
- package/lib/utils/isomorphic/cssParser.js +245 -245
- package/lib/utils/isomorphic/cssTokenizer.js +1051 -1051
- package/lib/utils/isomorphic/formatUtils.js +64 -0
- package/lib/utils/isomorphic/headers.js +53 -53
- package/lib/{server/utils → utils/isomorphic}/imageUtils.js +141 -141
- package/lib/utils/isomorphic/jsonSchema.js +89 -0
- package/lib/utils/isomorphic/locatorGenerators.js +689 -689
- package/lib/utils/isomorphic/locatorParser.js +176 -176
- package/lib/utils/isomorphic/locatorUtils.js +81 -81
- package/lib/utils/isomorphic/lruCache.js +51 -51
- package/lib/utils/isomorphic/manualPromise.js +114 -114
- package/lib/utils/isomorphic/mimeType.js +464 -459
- package/lib/utils/isomorphic/multimap.js +80 -80
- package/lib/utils/isomorphic/protocolFormatter.js +81 -81
- package/lib/utils/isomorphic/protocolMetainfo.js +351 -330
- package/lib/utils/isomorphic/rtti.js +43 -43
- package/lib/utils/isomorphic/selectorParser.js +386 -386
- package/lib/utils/isomorphic/semaphore.js +54 -54
- package/lib/utils/isomorphic/stackTrace.js +158 -158
- package/lib/utils/isomorphic/stringUtils.js +204 -204
- package/lib/utils/isomorphic/time.js +49 -49
- package/lib/utils/isomorphic/timeoutRunner.js +66 -66
- package/lib/utils/isomorphic/trace/entries.js +16 -16
- package/lib/utils/isomorphic/trace/snapshotRenderer.js +492 -499
- package/lib/utils/isomorphic/trace/snapshotServer.js +120 -120
- package/lib/utils/isomorphic/trace/snapshotStorage.js +89 -89
- package/lib/utils/isomorphic/trace/traceLoader.js +132 -131
- package/lib/utils/isomorphic/trace/traceModel.js +366 -365
- package/lib/utils/isomorphic/trace/traceModernizer.js +401 -400
- package/lib/utils/isomorphic/{traceUtils.js → trace/traceUtils.js} +58 -58
- package/lib/utils/isomorphic/trace/versions/traceV3.js +16 -16
- package/lib/utils/isomorphic/trace/versions/traceV4.js +16 -16
- package/lib/utils/isomorphic/trace/versions/traceV5.js +16 -16
- package/lib/utils/isomorphic/trace/versions/traceV6.js +16 -16
- package/lib/utils/isomorphic/trace/versions/traceV7.js +16 -16
- package/lib/utils/isomorphic/trace/versions/traceV8.js +16 -16
- package/lib/utils/isomorphic/types.js +16 -16
- package/lib/utils/isomorphic/urlMatch.js +243 -190
- package/lib/utils/isomorphic/utilityScriptSerializers.js +262 -251
- package/lib/utils/isomorphic/yaml.js +84 -84
- package/lib/utils.js +115 -111
- package/lib/utilsBundle.js +91 -109
- package/lib/utilsBundleImpl/index.js +217 -218
- package/lib/utilsBundleImpl/xdg-open +1066 -1066
- package/lib/vite/dashboard/assets/index-BAOybkp8.js +50 -0
- package/lib/vite/dashboard/assets/index-CZAYOG76.css +1 -0
- package/lib/vite/dashboard/index.html +28 -0
- package/lib/vite/htmlReport/index.html +16 -84
- package/lib/vite/htmlReport/report.css +1 -0
- package/lib/vite/htmlReport/report.js +72 -0
- package/lib/vite/recorder/assets/{codeMirrorModule-DadYNm1I.js → codeMirrorModule-C8KMvO9L.js} +32 -32
- package/lib/vite/recorder/assets/codeMirrorModule-DYBRYzYX.css +1 -1
- package/lib/vite/recorder/assets/index-BSjZa4pk.css +1 -1
- package/lib/vite/recorder/assets/index-CqAYX1I3.js +193 -0
- package/lib/vite/recorder/index.html +29 -29
- package/lib/vite/recorder/playwright-logo.svg +9 -9
- package/lib/vite/traceViewer/assets/{codeMirrorModule-a5XoALAZ.js → codeMirrorModule-DS0FLvoc.js} +32 -32
- package/lib/vite/traceViewer/assets/defaultSettingsView-GTWI-W_B.js +262 -0
- package/lib/vite/traceViewer/assets/xtermModule-CsJ4vdCR.js +9 -9
- package/lib/vite/traceViewer/codeMirrorModule.DYBRYzYX.css +1 -1
- package/lib/vite/traceViewer/defaultSettingsView.B4dS75f0.css +1 -0
- package/lib/vite/traceViewer/{index.BVu7tZDe.css → index.CzXZzn5A.css} +1 -1
- package/lib/vite/traceViewer/{index.Bk2uYQRV.js → index.Dtstcb7U.js} +2 -2
- package/lib/vite/traceViewer/index.html +43 -43
- package/lib/vite/traceViewer/manifest.webmanifest +16 -16
- package/lib/vite/traceViewer/playwright-logo.svg +9 -9
- package/lib/vite/traceViewer/snapshot.html +21 -21
- package/lib/vite/traceViewer/sw.bundle.js +5 -5
- package/lib/vite/traceViewer/uiMode.Btcz36p_.css +1 -1
- package/lib/vite/traceViewer/uiMode.Vipi55dB.js +6 -0
- package/lib/vite/traceViewer/uiMode.html +17 -17
- package/lib/vite/traceViewer/xtermModule.DYP7pi_n.css +32 -32
- package/lib/zipBundle.js +34 -34
- package/lib/zipBundleImpl.js +5 -5
- package/lib/zodBundle.js +39 -0
- package/lib/zodBundleImpl.js +40 -0
- package/package.json +6 -1
- package/types/protocol.d.ts +24720 -23824
- package/types/structs.d.ts +45 -45
- package/types/types.d.ts +23623 -22843
- package/lib/client/pageAgent.js +0 -64
- package/lib/mcpBundleImpl/index.js +0 -147
- package/lib/server/agent/actionRunner.js +0 -335
- package/lib/server/agent/actions.js +0 -128
- package/lib/server/agent/codegen.js +0 -111
- package/lib/server/agent/context.js +0 -150
- package/lib/server/agent/expectTools.js +0 -156
- package/lib/server/agent/pageAgent.js +0 -204
- package/lib/server/agent/performTools.js +0 -262
- package/lib/server/agent/tool.js +0 -109
- package/lib/server/dispatchers/pageAgentDispatcher.js +0 -96
- package/lib/vite/recorder/assets/index-BhTWtUlo.js +0 -193
- package/lib/vite/traceViewer/assets/defaultSettingsView-CJSZINFr.js +0 -266
- package/lib/vite/traceViewer/defaultSettingsView.7ch9cixO.css +0 -1
- package/lib/vite/traceViewer/uiMode.CQJ9SCIQ.js +0 -5
|
@@ -1,284 +1,281 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __defProp = Object.defineProperty;
|
|
3
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
-
var __export = (target, all) => {
|
|
7
|
-
for (var name in all)
|
|
8
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
-
};
|
|
10
|
-
var __copyProps = (to, from, except, desc) => {
|
|
11
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
-
for (let key of __getOwnPropNames(from))
|
|
13
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
-
}
|
|
16
|
-
return to;
|
|
17
|
-
};
|
|
18
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
-
var elementHandle_exports = {};
|
|
20
|
-
__export(elementHandle_exports, {
|
|
21
|
-
ElementHandle: () => ElementHandle,
|
|
22
|
-
convertInputFiles: () => convertInputFiles,
|
|
23
|
-
convertSelectOptionValues: () => convertSelectOptionValues,
|
|
24
|
-
determineScreenshotType: () => determineScreenshotType
|
|
25
|
-
});
|
|
26
|
-
module.exports = __toCommonJS(elementHandle_exports);
|
|
27
|
-
var import_frame = require("./frame");
|
|
28
|
-
var import_jsHandle = require("./jsHandle");
|
|
29
|
-
var import_assert = require("../utils/isomorphic/assert");
|
|
30
|
-
var import_fileUtils = require("./fileUtils");
|
|
31
|
-
var import_rtti = require("../utils/isomorphic/rtti");
|
|
32
|
-
var import_writableStream = require("./writableStream");
|
|
33
|
-
var import_mimeType = require("../utils/isomorphic/mimeType");
|
|
34
|
-
class ElementHandle extends import_jsHandle.JSHandle {
|
|
35
|
-
static from(handle) {
|
|
36
|
-
return handle._object;
|
|
37
|
-
}
|
|
38
|
-
static fromNullable(handle) {
|
|
39
|
-
return handle ? ElementHandle.from(handle) : null;
|
|
40
|
-
}
|
|
41
|
-
constructor(parent, type, guid, initializer) {
|
|
42
|
-
super(parent, type, guid, initializer);
|
|
43
|
-
this._frame = parent;
|
|
44
|
-
this._elementChannel = this._channel;
|
|
45
|
-
}
|
|
46
|
-
asElement() {
|
|
47
|
-
return this;
|
|
48
|
-
}
|
|
49
|
-
async ownerFrame() {
|
|
50
|
-
return import_frame.Frame.fromNullable((await this._elementChannel.ownerFrame()).frame);
|
|
51
|
-
}
|
|
52
|
-
async contentFrame() {
|
|
53
|
-
return import_frame.Frame.fromNullable((await this._elementChannel.contentFrame()).frame);
|
|
54
|
-
}
|
|
55
|
-
async getAttribute(name) {
|
|
56
|
-
const value = (await this._elementChannel.getAttribute({ name })).value;
|
|
57
|
-
return value === void 0 ? null : value;
|
|
58
|
-
}
|
|
59
|
-
async inputValue() {
|
|
60
|
-
return (await this._elementChannel.inputValue()).value;
|
|
61
|
-
}
|
|
62
|
-
async textContent() {
|
|
63
|
-
const value = (await this._elementChannel.textContent()).value;
|
|
64
|
-
return value === void 0 ? null : value;
|
|
65
|
-
}
|
|
66
|
-
async innerText() {
|
|
67
|
-
return (await this._elementChannel.innerText()).value;
|
|
68
|
-
}
|
|
69
|
-
async innerHTML() {
|
|
70
|
-
return (await this._elementChannel.innerHTML()).value;
|
|
71
|
-
}
|
|
72
|
-
async isChecked() {
|
|
73
|
-
return (await this._elementChannel.isChecked()).value;
|
|
74
|
-
}
|
|
75
|
-
async isDisabled() {
|
|
76
|
-
return (await this._elementChannel.isDisabled()).value;
|
|
77
|
-
}
|
|
78
|
-
async isEditable() {
|
|
79
|
-
return (await this._elementChannel.isEditable()).value;
|
|
80
|
-
}
|
|
81
|
-
async isEnabled() {
|
|
82
|
-
return (await this._elementChannel.isEnabled()).value;
|
|
83
|
-
}
|
|
84
|
-
async isHidden() {
|
|
85
|
-
return (await this._elementChannel.isHidden()).value;
|
|
86
|
-
}
|
|
87
|
-
async isVisible() {
|
|
88
|
-
return (await this._elementChannel.isVisible()).value;
|
|
89
|
-
}
|
|
90
|
-
async dispatchEvent(type, eventInit = {}) {
|
|
91
|
-
await this._elementChannel.dispatchEvent({ type, eventInit: (0, import_jsHandle.serializeArgument)(eventInit) });
|
|
92
|
-
}
|
|
93
|
-
async scrollIntoViewIfNeeded(options = {}) {
|
|
94
|
-
await this._elementChannel.scrollIntoViewIfNeeded({ ...options, timeout: this._frame._timeout(options) });
|
|
95
|
-
}
|
|
96
|
-
async hover(options = {}) {
|
|
97
|
-
await this._elementChannel.hover({ ...options, timeout: this._frame._timeout(options) });
|
|
98
|
-
}
|
|
99
|
-
async click(options = {}) {
|
|
100
|
-
return await this._elementChannel.click({ ...options, timeout: this._frame._timeout(options) });
|
|
101
|
-
}
|
|
102
|
-
async dblclick(options = {}) {
|
|
103
|
-
return await this._elementChannel.dblclick({ ...options, timeout: this._frame._timeout(options) });
|
|
104
|
-
}
|
|
105
|
-
async tap(options = {}) {
|
|
106
|
-
return await this._elementChannel.tap({ ...options, timeout: this._frame._timeout(options) });
|
|
107
|
-
}
|
|
108
|
-
async selectOption(values, options = {}) {
|
|
109
|
-
const result = await this._elementChannel.selectOption({ ...convertSelectOptionValues(values), ...options, timeout: this._frame._timeout(options) });
|
|
110
|
-
return result.values;
|
|
111
|
-
}
|
|
112
|
-
async fill(value, options = {}) {
|
|
113
|
-
return await this._elementChannel.fill({ value, ...options, timeout: this._frame._timeout(options) });
|
|
114
|
-
}
|
|
115
|
-
async selectText(options = {}) {
|
|
116
|
-
await this._elementChannel.selectText({ ...options, timeout: this._frame._timeout(options) });
|
|
117
|
-
}
|
|
118
|
-
async setInputFiles(files, options = {}) {
|
|
119
|
-
const frame = await this.ownerFrame();
|
|
120
|
-
if (!frame)
|
|
121
|
-
throw new Error("Cannot set input files to detached element");
|
|
122
|
-
const converted = await convertInputFiles(this._platform, files, frame.page().context());
|
|
123
|
-
await this._elementChannel.setInputFiles({ ...converted, ...options, timeout: this._frame._timeout(options) });
|
|
124
|
-
}
|
|
125
|
-
async focus() {
|
|
126
|
-
await this._elementChannel.focus();
|
|
127
|
-
}
|
|
128
|
-
async type(text, options = {}) {
|
|
129
|
-
await this._elementChannel.type({ text, ...options, timeout: this._frame._timeout(options) });
|
|
130
|
-
}
|
|
131
|
-
async press(key, options = {}) {
|
|
132
|
-
await this._elementChannel.press({ key, ...options, timeout: this._frame._timeout(options) });
|
|
133
|
-
}
|
|
134
|
-
async check(options = {}) {
|
|
135
|
-
return await this._elementChannel.check({ ...options, timeout: this._frame._timeout(options) });
|
|
136
|
-
}
|
|
137
|
-
async uncheck(options = {}) {
|
|
138
|
-
return await this._elementChannel.uncheck({ ...options, timeout: this._frame._timeout(options) });
|
|
139
|
-
}
|
|
140
|
-
async setChecked(checked, options) {
|
|
141
|
-
if (checked)
|
|
142
|
-
await this.check(options);
|
|
143
|
-
else
|
|
144
|
-
await this.uncheck(options);
|
|
145
|
-
}
|
|
146
|
-
async boundingBox() {
|
|
147
|
-
const value = (await this._elementChannel.boundingBox()).value;
|
|
148
|
-
return value === void 0 ? null : value;
|
|
149
|
-
}
|
|
150
|
-
async screenshot(options = {}) {
|
|
151
|
-
const mask = options.mask;
|
|
152
|
-
const copy = { ...options, mask: void 0, timeout: this._frame._timeout(options) };
|
|
153
|
-
if (!copy.type)
|
|
154
|
-
copy.type = determineScreenshotType(options);
|
|
155
|
-
if (mask) {
|
|
156
|
-
copy.mask = mask.map((locator) => ({
|
|
157
|
-
frame: locator._frame._channel,
|
|
158
|
-
selector: locator._selector
|
|
159
|
-
}));
|
|
160
|
-
}
|
|
161
|
-
const result = await this._elementChannel.screenshot(copy);
|
|
162
|
-
if (options.path) {
|
|
163
|
-
await (0, import_fileUtils.mkdirIfNeeded)(this._platform, options.path);
|
|
164
|
-
await this._platform.fs().promises.writeFile(options.path, result.binary);
|
|
165
|
-
}
|
|
166
|
-
return result.binary;
|
|
167
|
-
}
|
|
168
|
-
async $(selector) {
|
|
169
|
-
return ElementHandle.fromNullable((await this._elementChannel.querySelector({ selector })).element);
|
|
170
|
-
}
|
|
171
|
-
async $$(selector) {
|
|
172
|
-
const result = await this._elementChannel.querySelectorAll({ selector });
|
|
173
|
-
return result.elements.map((h) => ElementHandle.from(h));
|
|
174
|
-
}
|
|
175
|
-
async $eval(selector, pageFunction, arg) {
|
|
176
|
-
const result = await this._elementChannel.evalOnSelector({ selector, expression: String(pageFunction), isFunction: typeof pageFunction === "function", arg: (0, import_jsHandle.serializeArgument)(arg) });
|
|
177
|
-
return (0, import_jsHandle.parseResult)(result.value);
|
|
178
|
-
}
|
|
179
|
-
async $$eval(selector, pageFunction, arg) {
|
|
180
|
-
const result = await this._elementChannel.evalOnSelectorAll({ selector, expression: String(pageFunction), isFunction: typeof pageFunction === "function", arg: (0, import_jsHandle.serializeArgument)(arg) });
|
|
181
|
-
return (0, import_jsHandle.parseResult)(result.value);
|
|
182
|
-
}
|
|
183
|
-
async waitForElementState(state, options = {}) {
|
|
184
|
-
return await this._elementChannel.waitForElementState({ state, ...options, timeout: this._frame._timeout(options) });
|
|
185
|
-
}
|
|
186
|
-
async waitForSelector(selector, options = {}) {
|
|
187
|
-
const result = await this._elementChannel.waitForSelector({ selector, ...options, timeout: this._frame._timeout(options) });
|
|
188
|
-
return ElementHandle.fromNullable(result.element);
|
|
189
|
-
}
|
|
190
|
-
}
|
|
191
|
-
function convertSelectOptionValues(values) {
|
|
192
|
-
if (values === null)
|
|
193
|
-
return {};
|
|
194
|
-
if (!Array.isArray(values))
|
|
195
|
-
values = [values];
|
|
196
|
-
if (!values.length)
|
|
197
|
-
return {};
|
|
198
|
-
for (let i = 0; i < values.length; i++)
|
|
199
|
-
(0, import_assert.assert)(values[i] !== null, `options[${i}]: expected object, got null`);
|
|
200
|
-
if (values[0] instanceof ElementHandle)
|
|
201
|
-
return { elements: values.map((v) => v._elementChannel) };
|
|
202
|
-
if ((0, import_rtti.isString)(values[0]))
|
|
203
|
-
return { options: values.map((valueOrLabel) => ({ valueOrLabel })) };
|
|
204
|
-
return { options: values };
|
|
205
|
-
}
|
|
206
|
-
function filePayloadExceedsSizeLimit(payloads) {
|
|
207
|
-
return payloads.reduce((size, item) => size + (item.buffer ? item.buffer.byteLength : 0), 0) >= import_fileUtils.fileUploadSizeLimit;
|
|
208
|
-
}
|
|
209
|
-
async function resolvePathsAndDirectoryForInputFiles(platform, items) {
|
|
210
|
-
let localPaths;
|
|
211
|
-
let localDirectory;
|
|
212
|
-
for (const item of items) {
|
|
213
|
-
const stat = await platform.fs().promises.stat(item);
|
|
214
|
-
if (stat.isDirectory()) {
|
|
215
|
-
if (localDirectory)
|
|
216
|
-
throw new Error("Multiple directories are not supported");
|
|
217
|
-
localDirectory = platform.path().resolve(item);
|
|
218
|
-
} else {
|
|
219
|
-
localPaths ??= [];
|
|
220
|
-
localPaths.push(platform.path().resolve(item));
|
|
221
|
-
}
|
|
222
|
-
}
|
|
223
|
-
if (localPaths?.length && localDirectory)
|
|
224
|
-
throw new Error("File paths must be all files or a single directory");
|
|
225
|
-
return [localPaths, localDirectory];
|
|
226
|
-
}
|
|
227
|
-
async function convertInputFiles(platform, files, context) {
|
|
228
|
-
const items = Array.isArray(files) ? files.slice() : [files];
|
|
229
|
-
if (items.some((item) => typeof item === "string")) {
|
|
230
|
-
if (!items.every((item) => typeof item === "string"))
|
|
231
|
-
throw new Error("File paths cannot be mixed with buffers");
|
|
232
|
-
const [localPaths, localDirectory] = await resolvePathsAndDirectoryForInputFiles(platform, items);
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
context.
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
282
|
-
convertSelectOptionValues,
|
|
283
|
-
determineScreenshotType
|
|
284
|
-
});
|
|
1
|
+
"use strict";
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
+
var __export = (target, all) => {
|
|
7
|
+
for (var name in all)
|
|
8
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
+
};
|
|
10
|
+
var __copyProps = (to, from, except, desc) => {
|
|
11
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
+
for (let key of __getOwnPropNames(from))
|
|
13
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
+
}
|
|
16
|
+
return to;
|
|
17
|
+
};
|
|
18
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
+
var elementHandle_exports = {};
|
|
20
|
+
__export(elementHandle_exports, {
|
|
21
|
+
ElementHandle: () => ElementHandle,
|
|
22
|
+
convertInputFiles: () => convertInputFiles,
|
|
23
|
+
convertSelectOptionValues: () => convertSelectOptionValues,
|
|
24
|
+
determineScreenshotType: () => determineScreenshotType
|
|
25
|
+
});
|
|
26
|
+
module.exports = __toCommonJS(elementHandle_exports);
|
|
27
|
+
var import_frame = require("./frame");
|
|
28
|
+
var import_jsHandle = require("./jsHandle");
|
|
29
|
+
var import_assert = require("../utils/isomorphic/assert");
|
|
30
|
+
var import_fileUtils = require("./fileUtils");
|
|
31
|
+
var import_rtti = require("../utils/isomorphic/rtti");
|
|
32
|
+
var import_writableStream = require("./writableStream");
|
|
33
|
+
var import_mimeType = require("../utils/isomorphic/mimeType");
|
|
34
|
+
class ElementHandle extends import_jsHandle.JSHandle {
|
|
35
|
+
static from(handle) {
|
|
36
|
+
return handle._object;
|
|
37
|
+
}
|
|
38
|
+
static fromNullable(handle) {
|
|
39
|
+
return handle ? ElementHandle.from(handle) : null;
|
|
40
|
+
}
|
|
41
|
+
constructor(parent, type, guid, initializer) {
|
|
42
|
+
super(parent, type, guid, initializer);
|
|
43
|
+
this._frame = parent;
|
|
44
|
+
this._elementChannel = this._channel;
|
|
45
|
+
}
|
|
46
|
+
asElement() {
|
|
47
|
+
return this;
|
|
48
|
+
}
|
|
49
|
+
async ownerFrame() {
|
|
50
|
+
return import_frame.Frame.fromNullable((await this._elementChannel.ownerFrame()).frame);
|
|
51
|
+
}
|
|
52
|
+
async contentFrame() {
|
|
53
|
+
return import_frame.Frame.fromNullable((await this._elementChannel.contentFrame()).frame);
|
|
54
|
+
}
|
|
55
|
+
async getAttribute(name) {
|
|
56
|
+
const value = (await this._elementChannel.getAttribute({ name })).value;
|
|
57
|
+
return value === void 0 ? null : value;
|
|
58
|
+
}
|
|
59
|
+
async inputValue() {
|
|
60
|
+
return (await this._elementChannel.inputValue()).value;
|
|
61
|
+
}
|
|
62
|
+
async textContent() {
|
|
63
|
+
const value = (await this._elementChannel.textContent()).value;
|
|
64
|
+
return value === void 0 ? null : value;
|
|
65
|
+
}
|
|
66
|
+
async innerText() {
|
|
67
|
+
return (await this._elementChannel.innerText()).value;
|
|
68
|
+
}
|
|
69
|
+
async innerHTML() {
|
|
70
|
+
return (await this._elementChannel.innerHTML()).value;
|
|
71
|
+
}
|
|
72
|
+
async isChecked() {
|
|
73
|
+
return (await this._elementChannel.isChecked()).value;
|
|
74
|
+
}
|
|
75
|
+
async isDisabled() {
|
|
76
|
+
return (await this._elementChannel.isDisabled()).value;
|
|
77
|
+
}
|
|
78
|
+
async isEditable() {
|
|
79
|
+
return (await this._elementChannel.isEditable()).value;
|
|
80
|
+
}
|
|
81
|
+
async isEnabled() {
|
|
82
|
+
return (await this._elementChannel.isEnabled()).value;
|
|
83
|
+
}
|
|
84
|
+
async isHidden() {
|
|
85
|
+
return (await this._elementChannel.isHidden()).value;
|
|
86
|
+
}
|
|
87
|
+
async isVisible() {
|
|
88
|
+
return (await this._elementChannel.isVisible()).value;
|
|
89
|
+
}
|
|
90
|
+
async dispatchEvent(type, eventInit = {}) {
|
|
91
|
+
await this._elementChannel.dispatchEvent({ type, eventInit: (0, import_jsHandle.serializeArgument)(eventInit) });
|
|
92
|
+
}
|
|
93
|
+
async scrollIntoViewIfNeeded(options = {}) {
|
|
94
|
+
await this._elementChannel.scrollIntoViewIfNeeded({ ...options, timeout: this._frame._timeout(options) });
|
|
95
|
+
}
|
|
96
|
+
async hover(options = {}) {
|
|
97
|
+
await this._elementChannel.hover({ ...options, timeout: this._frame._timeout(options) });
|
|
98
|
+
}
|
|
99
|
+
async click(options = {}) {
|
|
100
|
+
return await this._elementChannel.click({ ...options, timeout: this._frame._timeout(options) });
|
|
101
|
+
}
|
|
102
|
+
async dblclick(options = {}) {
|
|
103
|
+
return await this._elementChannel.dblclick({ ...options, timeout: this._frame._timeout(options) });
|
|
104
|
+
}
|
|
105
|
+
async tap(options = {}) {
|
|
106
|
+
return await this._elementChannel.tap({ ...options, timeout: this._frame._timeout(options) });
|
|
107
|
+
}
|
|
108
|
+
async selectOption(values, options = {}) {
|
|
109
|
+
const result = await this._elementChannel.selectOption({ ...convertSelectOptionValues(values), ...options, timeout: this._frame._timeout(options) });
|
|
110
|
+
return result.values;
|
|
111
|
+
}
|
|
112
|
+
async fill(value, options = {}) {
|
|
113
|
+
return await this._elementChannel.fill({ value, ...options, timeout: this._frame._timeout(options) });
|
|
114
|
+
}
|
|
115
|
+
async selectText(options = {}) {
|
|
116
|
+
await this._elementChannel.selectText({ ...options, timeout: this._frame._timeout(options) });
|
|
117
|
+
}
|
|
118
|
+
async setInputFiles(files, options = {}) {
|
|
119
|
+
const frame = await this.ownerFrame();
|
|
120
|
+
if (!frame)
|
|
121
|
+
throw new Error("Cannot set input files to detached element");
|
|
122
|
+
const converted = await convertInputFiles(this._platform, files, frame.page().context());
|
|
123
|
+
await this._elementChannel.setInputFiles({ ...converted, ...options, timeout: this._frame._timeout(options) });
|
|
124
|
+
}
|
|
125
|
+
async focus() {
|
|
126
|
+
await this._elementChannel.focus();
|
|
127
|
+
}
|
|
128
|
+
async type(text, options = {}) {
|
|
129
|
+
await this._elementChannel.type({ text, ...options, timeout: this._frame._timeout(options) });
|
|
130
|
+
}
|
|
131
|
+
async press(key, options = {}) {
|
|
132
|
+
await this._elementChannel.press({ key, ...options, timeout: this._frame._timeout(options) });
|
|
133
|
+
}
|
|
134
|
+
async check(options = {}) {
|
|
135
|
+
return await this._elementChannel.check({ ...options, timeout: this._frame._timeout(options) });
|
|
136
|
+
}
|
|
137
|
+
async uncheck(options = {}) {
|
|
138
|
+
return await this._elementChannel.uncheck({ ...options, timeout: this._frame._timeout(options) });
|
|
139
|
+
}
|
|
140
|
+
async setChecked(checked, options) {
|
|
141
|
+
if (checked)
|
|
142
|
+
await this.check(options);
|
|
143
|
+
else
|
|
144
|
+
await this.uncheck(options);
|
|
145
|
+
}
|
|
146
|
+
async boundingBox() {
|
|
147
|
+
const value = (await this._elementChannel.boundingBox()).value;
|
|
148
|
+
return value === void 0 ? null : value;
|
|
149
|
+
}
|
|
150
|
+
async screenshot(options = {}) {
|
|
151
|
+
const mask = options.mask;
|
|
152
|
+
const copy = { ...options, mask: void 0, timeout: this._frame._timeout(options) };
|
|
153
|
+
if (!copy.type)
|
|
154
|
+
copy.type = determineScreenshotType(options);
|
|
155
|
+
if (mask) {
|
|
156
|
+
copy.mask = mask.map((locator) => ({
|
|
157
|
+
frame: locator._frame._channel,
|
|
158
|
+
selector: locator._selector
|
|
159
|
+
}));
|
|
160
|
+
}
|
|
161
|
+
const result = await this._elementChannel.screenshot(copy);
|
|
162
|
+
if (options.path) {
|
|
163
|
+
await (0, import_fileUtils.mkdirIfNeeded)(this._platform, options.path);
|
|
164
|
+
await this._platform.fs().promises.writeFile(options.path, result.binary);
|
|
165
|
+
}
|
|
166
|
+
return result.binary;
|
|
167
|
+
}
|
|
168
|
+
async $(selector) {
|
|
169
|
+
return ElementHandle.fromNullable((await this._elementChannel.querySelector({ selector })).element);
|
|
170
|
+
}
|
|
171
|
+
async $$(selector) {
|
|
172
|
+
const result = await this._elementChannel.querySelectorAll({ selector });
|
|
173
|
+
return result.elements.map((h) => ElementHandle.from(h));
|
|
174
|
+
}
|
|
175
|
+
async $eval(selector, pageFunction, arg) {
|
|
176
|
+
const result = await this._elementChannel.evalOnSelector({ selector, expression: String(pageFunction), isFunction: typeof pageFunction === "function", arg: (0, import_jsHandle.serializeArgument)(arg) });
|
|
177
|
+
return (0, import_jsHandle.parseResult)(result.value);
|
|
178
|
+
}
|
|
179
|
+
async $$eval(selector, pageFunction, arg) {
|
|
180
|
+
const result = await this._elementChannel.evalOnSelectorAll({ selector, expression: String(pageFunction), isFunction: typeof pageFunction === "function", arg: (0, import_jsHandle.serializeArgument)(arg) });
|
|
181
|
+
return (0, import_jsHandle.parseResult)(result.value);
|
|
182
|
+
}
|
|
183
|
+
async waitForElementState(state, options = {}) {
|
|
184
|
+
return await this._elementChannel.waitForElementState({ state, ...options, timeout: this._frame._timeout(options) });
|
|
185
|
+
}
|
|
186
|
+
async waitForSelector(selector, options = {}) {
|
|
187
|
+
const result = await this._elementChannel.waitForSelector({ selector, ...options, timeout: this._frame._timeout(options) });
|
|
188
|
+
return ElementHandle.fromNullable(result.element);
|
|
189
|
+
}
|
|
190
|
+
}
|
|
191
|
+
function convertSelectOptionValues(values) {
|
|
192
|
+
if (values === null)
|
|
193
|
+
return {};
|
|
194
|
+
if (!Array.isArray(values))
|
|
195
|
+
values = [values];
|
|
196
|
+
if (!values.length)
|
|
197
|
+
return {};
|
|
198
|
+
for (let i = 0; i < values.length; i++)
|
|
199
|
+
(0, import_assert.assert)(values[i] !== null, `options[${i}]: expected object, got null`);
|
|
200
|
+
if (values[0] instanceof ElementHandle)
|
|
201
|
+
return { elements: values.map((v) => v._elementChannel) };
|
|
202
|
+
if ((0, import_rtti.isString)(values[0]))
|
|
203
|
+
return { options: values.map((valueOrLabel) => ({ valueOrLabel })) };
|
|
204
|
+
return { options: values };
|
|
205
|
+
}
|
|
206
|
+
function filePayloadExceedsSizeLimit(payloads) {
|
|
207
|
+
return payloads.reduce((size, item) => size + (item.buffer ? item.buffer.byteLength : 0), 0) >= import_fileUtils.fileUploadSizeLimit;
|
|
208
|
+
}
|
|
209
|
+
async function resolvePathsAndDirectoryForInputFiles(platform, items) {
|
|
210
|
+
let localPaths;
|
|
211
|
+
let localDirectory;
|
|
212
|
+
for (const item of items) {
|
|
213
|
+
const stat = await platform.fs().promises.stat(item);
|
|
214
|
+
if (stat.isDirectory()) {
|
|
215
|
+
if (localDirectory)
|
|
216
|
+
throw new Error("Multiple directories are not supported");
|
|
217
|
+
localDirectory = platform.path().resolve(item);
|
|
218
|
+
} else {
|
|
219
|
+
localPaths ??= [];
|
|
220
|
+
localPaths.push(platform.path().resolve(item));
|
|
221
|
+
}
|
|
222
|
+
}
|
|
223
|
+
if (localPaths?.length && localDirectory)
|
|
224
|
+
throw new Error("File paths must be all files or a single directory");
|
|
225
|
+
return [localPaths, localDirectory];
|
|
226
|
+
}
|
|
227
|
+
async function convertInputFiles(platform, files, context) {
|
|
228
|
+
const items = Array.isArray(files) ? files.slice() : [files];
|
|
229
|
+
if (items.some((item) => typeof item === "string")) {
|
|
230
|
+
if (!items.every((item) => typeof item === "string"))
|
|
231
|
+
throw new Error("File paths cannot be mixed with buffers");
|
|
232
|
+
const [localPaths, localDirectory] = await resolvePathsAndDirectoryForInputFiles(platform, items);
|
|
233
|
+
if (context._connection.isRemote()) {
|
|
234
|
+
const files2 = localDirectory ? (await platform.fs().promises.readdir(localDirectory, { withFileTypes: true, recursive: true })).filter((f) => f.isFile()).map((f) => platform.path().join(f.parentPath, f.name)) : localPaths;
|
|
235
|
+
const { writableStreams, rootDir } = await context._wrapApiCall(async () => context._channel.createTempFiles({
|
|
236
|
+
rootDirName: localDirectory ? platform.path().basename(localDirectory) : void 0,
|
|
237
|
+
items: await Promise.all(files2.map(async (file) => {
|
|
238
|
+
const lastModifiedMs = (await platform.fs().promises.stat(file)).mtimeMs;
|
|
239
|
+
return {
|
|
240
|
+
name: localDirectory ? platform.path().relative(localDirectory, file) : platform.path().basename(file),
|
|
241
|
+
lastModifiedMs
|
|
242
|
+
};
|
|
243
|
+
}))
|
|
244
|
+
}), { internal: true });
|
|
245
|
+
for (let i = 0; i < files2.length; i++) {
|
|
246
|
+
const writable = import_writableStream.WritableStream.from(writableStreams[i]);
|
|
247
|
+
await platform.streamFile(files2[i], writable.stream());
|
|
248
|
+
}
|
|
249
|
+
return {
|
|
250
|
+
directoryStream: rootDir,
|
|
251
|
+
streams: localDirectory ? void 0 : writableStreams
|
|
252
|
+
};
|
|
253
|
+
}
|
|
254
|
+
return {
|
|
255
|
+
localPaths,
|
|
256
|
+
localDirectory
|
|
257
|
+
};
|
|
258
|
+
}
|
|
259
|
+
const payloads = items;
|
|
260
|
+
if (filePayloadExceedsSizeLimit(payloads))
|
|
261
|
+
throw new Error("Cannot set buffer larger than 50Mb, please write it to a file and pass its path instead.");
|
|
262
|
+
return { payloads };
|
|
263
|
+
}
|
|
264
|
+
function determineScreenshotType(options) {
|
|
265
|
+
if (options.path) {
|
|
266
|
+
const mimeType = (0, import_mimeType.getMimeTypeForPath)(options.path);
|
|
267
|
+
if (mimeType === "image/png")
|
|
268
|
+
return "png";
|
|
269
|
+
else if (mimeType === "image/jpeg")
|
|
270
|
+
return "jpeg";
|
|
271
|
+
throw new Error(`path: unsupported mime type "${mimeType}"`);
|
|
272
|
+
}
|
|
273
|
+
return options.type;
|
|
274
|
+
}
|
|
275
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
276
|
+
0 && (module.exports = {
|
|
277
|
+
ElementHandle,
|
|
278
|
+
convertInputFiles,
|
|
279
|
+
convertSelectOptionValues,
|
|
280
|
+
determineScreenshotType
|
|
281
|
+
});
|