phantomwright-driver-core 1.58.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 +3 -0
- package/ThirdPartyNotices.txt +4076 -0
- package/bin/install_media_pack.ps1 +5 -0
- package/bin/install_webkit_wsl.ps1 +33 -0
- package/bin/reinstall_chrome_beta_linux.sh +42 -0
- package/bin/reinstall_chrome_beta_mac.sh +13 -0
- package/bin/reinstall_chrome_beta_win.ps1 +24 -0
- package/bin/reinstall_chrome_stable_linux.sh +42 -0
- package/bin/reinstall_chrome_stable_mac.sh +12 -0
- package/bin/reinstall_chrome_stable_win.ps1 +24 -0
- package/bin/reinstall_msedge_beta_linux.sh +48 -0
- package/bin/reinstall_msedge_beta_mac.sh +11 -0
- package/bin/reinstall_msedge_beta_win.ps1 +23 -0
- package/bin/reinstall_msedge_dev_linux.sh +48 -0
- package/bin/reinstall_msedge_dev_mac.sh +11 -0
- package/bin/reinstall_msedge_dev_win.ps1 +23 -0
- package/bin/reinstall_msedge_stable_linux.sh +48 -0
- package/bin/reinstall_msedge_stable_mac.sh +11 -0
- package/bin/reinstall_msedge_stable_win.ps1 +24 -0
- package/browsers.json +79 -0
- package/cli.js +18 -0
- package/index.d.ts +17 -0
- package/index.js +32 -0
- package/index.mjs +28 -0
- package/lib/androidServerImpl.js +65 -0
- package/lib/browserServerImpl.js +120 -0
- package/lib/cli/driver.js +97 -0
- package/lib/cli/program.js +589 -0
- package/lib/cli/programWithTestStub.js +74 -0
- package/lib/client/android.js +361 -0
- package/lib/client/api.js +137 -0
- package/lib/client/artifact.js +79 -0
- package/lib/client/browser.js +161 -0
- package/lib/client/browserContext.js +601 -0
- package/lib/client/browserType.js +185 -0
- package/lib/client/cdpSession.js +51 -0
- package/lib/client/channelOwner.js +194 -0
- package/lib/client/clientHelper.js +63 -0
- package/lib/client/clientInstrumentation.js +55 -0
- package/lib/client/clientStackTrace.js +69 -0
- package/lib/client/clock.js +69 -0
- package/lib/client/connection.js +318 -0
- package/lib/client/consoleMessage.js +58 -0
- package/lib/client/coverage.js +44 -0
- package/lib/client/dialog.js +56 -0
- package/lib/client/download.js +62 -0
- package/lib/client/electron.js +138 -0
- package/lib/client/elementHandle.js +284 -0
- package/lib/client/errors.js +77 -0
- package/lib/client/eventEmitter.js +314 -0
- package/lib/client/events.js +103 -0
- package/lib/client/fetch.js +368 -0
- package/lib/client/fileChooser.js +46 -0
- package/lib/client/fileUtils.js +34 -0
- package/lib/client/frame.js +409 -0
- package/lib/client/harRouter.js +87 -0
- package/lib/client/input.js +84 -0
- package/lib/client/jsHandle.js +109 -0
- package/lib/client/jsonPipe.js +39 -0
- package/lib/client/localUtils.js +60 -0
- package/lib/client/locator.js +390 -0
- package/lib/client/network.js +747 -0
- package/lib/client/page.js +764 -0
- package/lib/client/pageAgent.js +64 -0
- package/lib/client/platform.js +77 -0
- package/lib/client/playwright.js +71 -0
- package/lib/client/selectors.js +55 -0
- package/lib/client/stream.js +39 -0
- package/lib/client/timeoutSettings.js +79 -0
- package/lib/client/tracing.js +120 -0
- package/lib/client/types.js +28 -0
- package/lib/client/video.js +59 -0
- package/lib/client/waiter.js +142 -0
- package/lib/client/webError.js +39 -0
- package/lib/client/webSocket.js +93 -0
- package/lib/client/worker.js +85 -0
- package/lib/client/writableStream.js +39 -0
- package/lib/generated/bindingsControllerSource.js +28 -0
- package/lib/generated/clockSource.js +28 -0
- package/lib/generated/injectedScriptSource.js +28 -0
- package/lib/generated/pollingRecorderSource.js +28 -0
- package/lib/generated/storageScriptSource.js +28 -0
- package/lib/generated/utilityScriptSource.js +28 -0
- package/lib/generated/webSocketMockSource.js +336 -0
- package/lib/inProcessFactory.js +60 -0
- package/lib/inprocess.js +3 -0
- package/lib/mcpBundle.js +84 -0
- package/lib/mcpBundleImpl/index.js +147 -0
- package/lib/outofprocess.js +76 -0
- package/lib/protocol/serializers.js +197 -0
- package/lib/protocol/validator.js +2981 -0
- package/lib/protocol/validatorPrimitives.js +193 -0
- package/lib/remote/playwrightConnection.js +129 -0
- package/lib/remote/playwrightServer.js +334 -0
- package/lib/server/agent/actionRunner.js +335 -0
- package/lib/server/agent/actions.js +128 -0
- package/lib/server/agent/codegen.js +111 -0
- package/lib/server/agent/context.js +150 -0
- package/lib/server/agent/expectTools.js +156 -0
- package/lib/server/agent/pageAgent.js +204 -0
- package/lib/server/agent/performTools.js +262 -0
- package/lib/server/agent/tool.js +109 -0
- package/lib/server/android/android.js +465 -0
- package/lib/server/android/backendAdb.js +177 -0
- package/lib/server/artifact.js +127 -0
- package/lib/server/bidi/bidiBrowser.js +549 -0
- package/lib/server/bidi/bidiChromium.js +148 -0
- package/lib/server/bidi/bidiConnection.js +213 -0
- package/lib/server/bidi/bidiDeserializer.js +116 -0
- package/lib/server/bidi/bidiExecutionContext.js +267 -0
- package/lib/server/bidi/bidiFirefox.js +128 -0
- package/lib/server/bidi/bidiInput.js +146 -0
- package/lib/server/bidi/bidiNetworkManager.js +383 -0
- package/lib/server/bidi/bidiOverCdp.js +102 -0
- package/lib/server/bidi/bidiPage.js +583 -0
- package/lib/server/bidi/bidiPdf.js +106 -0
- package/lib/server/bidi/third_party/bidiCommands.d.js +22 -0
- package/lib/server/bidi/third_party/bidiKeyboard.js +256 -0
- package/lib/server/bidi/third_party/bidiProtocol.js +24 -0
- package/lib/server/bidi/third_party/bidiProtocolCore.js +180 -0
- package/lib/server/bidi/third_party/bidiProtocolPermissions.js +42 -0
- package/lib/server/bidi/third_party/bidiSerializer.js +148 -0
- package/lib/server/bidi/third_party/firefoxPrefs.js +259 -0
- package/lib/server/browser.js +149 -0
- package/lib/server/browserContext.js +689 -0
- package/lib/server/browserType.js +336 -0
- package/lib/server/callLog.js +82 -0
- package/lib/server/chromium/appIcon.png +0 -0
- package/lib/server/chromium/chromium.js +395 -0
- package/lib/server/chromium/chromiumSwitches.js +92 -0
- package/lib/server/chromium/crBrowser.js +516 -0
- package/lib/server/chromium/crConnection.js +197 -0
- package/lib/server/chromium/crCoverage.js +235 -0
- package/lib/server/chromium/crDevTools.js +110 -0
- package/lib/server/chromium/crDragDrop.js +131 -0
- package/lib/server/chromium/crExecutionContext.js +146 -0
- package/lib/server/chromium/crInput.js +187 -0
- package/lib/server/chromium/crNetworkManager.js +946 -0
- package/lib/server/chromium/crPage.js +1079 -0
- package/lib/server/chromium/crPdf.js +121 -0
- package/lib/server/chromium/crProtocolHelper.js +145 -0
- package/lib/server/chromium/crServiceWorker.js +144 -0
- package/lib/server/chromium/defaultFontFamilies.js +162 -0
- package/lib/server/chromium/protocol.d.js +16 -0
- package/lib/server/clock.js +157 -0
- package/lib/server/codegen/csharp.js +327 -0
- package/lib/server/codegen/java.js +274 -0
- package/lib/server/codegen/javascript.js +247 -0
- package/lib/server/codegen/jsonl.js +52 -0
- package/lib/server/codegen/language.js +132 -0
- package/lib/server/codegen/languages.js +68 -0
- package/lib/server/codegen/python.js +279 -0
- package/lib/server/codegen/types.js +16 -0
- package/lib/server/console.js +57 -0
- package/lib/server/cookieStore.js +206 -0
- package/lib/server/debugController.js +191 -0
- package/lib/server/debugger.js +119 -0
- package/lib/server/deviceDescriptors.js +39 -0
- package/lib/server/deviceDescriptorsSource.json +1779 -0
- package/lib/server/dialog.js +116 -0
- package/lib/server/dispatchers/androidDispatcher.js +325 -0
- package/lib/server/dispatchers/artifactDispatcher.js +118 -0
- package/lib/server/dispatchers/browserContextDispatcher.js +384 -0
- package/lib/server/dispatchers/browserDispatcher.js +118 -0
- package/lib/server/dispatchers/browserTypeDispatcher.js +64 -0
- package/lib/server/dispatchers/cdpSessionDispatcher.js +44 -0
- package/lib/server/dispatchers/debugControllerDispatcher.js +78 -0
- package/lib/server/dispatchers/dialogDispatcher.js +47 -0
- package/lib/server/dispatchers/dispatcher.js +364 -0
- package/lib/server/dispatchers/electronDispatcher.js +89 -0
- package/lib/server/dispatchers/elementHandlerDispatcher.js +181 -0
- package/lib/server/dispatchers/frameDispatcher.js +227 -0
- package/lib/server/dispatchers/jsHandleDispatcher.js +85 -0
- package/lib/server/dispatchers/jsonPipeDispatcher.js +58 -0
- package/lib/server/dispatchers/localUtilsDispatcher.js +149 -0
- package/lib/server/dispatchers/networkDispatchers.js +213 -0
- package/lib/server/dispatchers/pageAgentDispatcher.js +96 -0
- package/lib/server/dispatchers/pageDispatcher.js +393 -0
- package/lib/server/dispatchers/playwrightDispatcher.js +108 -0
- package/lib/server/dispatchers/streamDispatcher.js +67 -0
- package/lib/server/dispatchers/tracingDispatcher.js +68 -0
- package/lib/server/dispatchers/webSocketRouteDispatcher.js +165 -0
- package/lib/server/dispatchers/writableStreamDispatcher.js +79 -0
- package/lib/server/dom.js +815 -0
- package/lib/server/download.js +70 -0
- package/lib/server/electron/electron.js +273 -0
- package/lib/server/electron/loader.js +29 -0
- package/lib/server/errors.js +69 -0
- package/lib/server/fetch.js +621 -0
- package/lib/server/fileChooser.js +43 -0
- package/lib/server/fileUploadUtils.js +84 -0
- package/lib/server/firefox/ffBrowser.js +418 -0
- package/lib/server/firefox/ffConnection.js +142 -0
- package/lib/server/firefox/ffExecutionContext.js +150 -0
- package/lib/server/firefox/ffInput.js +159 -0
- package/lib/server/firefox/ffNetworkManager.js +256 -0
- package/lib/server/firefox/ffPage.js +497 -0
- package/lib/server/firefox/firefox.js +114 -0
- package/lib/server/firefox/protocol.d.js +16 -0
- package/lib/server/formData.js +147 -0
- package/lib/server/frameSelectors.js +322 -0
- package/lib/server/frames.js +1802 -0
- package/lib/server/har/harRecorder.js +147 -0
- package/lib/server/har/harTracer.js +607 -0
- package/lib/server/harBackend.js +157 -0
- package/lib/server/helper.js +96 -0
- package/lib/server/index.js +58 -0
- package/lib/server/input.js +277 -0
- package/lib/server/instrumentation.js +72 -0
- package/lib/server/javascript.js +307 -0
- package/lib/server/launchApp.js +128 -0
- package/lib/server/localUtils.js +214 -0
- package/lib/server/macEditingCommands.js +143 -0
- package/lib/server/network.js +667 -0
- package/lib/server/page.js +812 -0
- package/lib/server/pageBinding.js +87 -0
- package/lib/server/pipeTransport.js +89 -0
- package/lib/server/playwright.js +69 -0
- package/lib/server/progress.js +132 -0
- package/lib/server/protocolError.js +52 -0
- package/lib/server/recorder/chat.js +161 -0
- package/lib/server/recorder/recorderApp.js +366 -0
- package/lib/server/recorder/recorderRunner.js +138 -0
- package/lib/server/recorder/recorderSignalProcessor.js +83 -0
- package/lib/server/recorder/recorderUtils.js +157 -0
- package/lib/server/recorder/throttledFile.js +57 -0
- package/lib/server/recorder.js +499 -0
- package/lib/server/registry/browserFetcher.js +177 -0
- package/lib/server/registry/dependencies.js +371 -0
- package/lib/server/registry/index.js +1422 -0
- package/lib/server/registry/nativeDeps.js +1280 -0
- package/lib/server/registry/oopDownloadBrowserMain.js +127 -0
- package/lib/server/screencast.js +190 -0
- package/lib/server/screenshotter.js +333 -0
- package/lib/server/selectors.js +112 -0
- package/lib/server/socksClientCertificatesInterceptor.js +383 -0
- package/lib/server/socksInterceptor.js +95 -0
- package/lib/server/trace/recorder/snapshotter.js +147 -0
- package/lib/server/trace/recorder/snapshotterInjected.js +561 -0
- package/lib/server/trace/recorder/tracing.js +604 -0
- package/lib/server/trace/viewer/traceParser.js +72 -0
- package/lib/server/trace/viewer/traceViewer.js +245 -0
- package/lib/server/transport.js +181 -0
- package/lib/server/types.js +28 -0
- package/lib/server/usKeyboardLayout.js +145 -0
- package/lib/server/utils/ascii.js +44 -0
- package/lib/server/utils/comparators.js +139 -0
- package/lib/server/utils/crypto.js +216 -0
- package/lib/server/utils/debug.js +42 -0
- package/lib/server/utils/debugLogger.js +122 -0
- package/lib/server/utils/env.js +73 -0
- package/lib/server/utils/eventsHelper.js +39 -0
- package/lib/server/utils/expectUtils.js +123 -0
- package/lib/server/utils/fileUtils.js +191 -0
- package/lib/server/utils/happyEyeballs.js +207 -0
- package/lib/server/utils/hostPlatform.js +123 -0
- package/lib/server/utils/httpServer.js +203 -0
- package/lib/server/utils/imageUtils.js +141 -0
- package/lib/server/utils/image_tools/colorUtils.js +89 -0
- package/lib/server/utils/image_tools/compare.js +109 -0
- package/lib/server/utils/image_tools/imageChannel.js +78 -0
- package/lib/server/utils/image_tools/stats.js +102 -0
- package/lib/server/utils/linuxUtils.js +71 -0
- package/lib/server/utils/network.js +242 -0
- package/lib/server/utils/nodePlatform.js +154 -0
- package/lib/server/utils/pipeTransport.js +84 -0
- package/lib/server/utils/processLauncher.js +241 -0
- package/lib/server/utils/profiler.js +65 -0
- package/lib/server/utils/socksProxy.js +511 -0
- package/lib/server/utils/spawnAsync.js +41 -0
- package/lib/server/utils/task.js +51 -0
- package/lib/server/utils/userAgent.js +98 -0
- package/lib/server/utils/wsServer.js +121 -0
- package/lib/server/utils/zipFile.js +74 -0
- package/lib/server/utils/zones.js +57 -0
- package/lib/server/videoRecorder.js +124 -0
- package/lib/server/webkit/protocol.d.js +16 -0
- package/lib/server/webkit/webkit.js +108 -0
- package/lib/server/webkit/wkBrowser.js +335 -0
- package/lib/server/webkit/wkConnection.js +144 -0
- package/lib/server/webkit/wkExecutionContext.js +154 -0
- package/lib/server/webkit/wkInput.js +181 -0
- package/lib/server/webkit/wkInterceptableRequest.js +197 -0
- package/lib/server/webkit/wkPage.js +1158 -0
- package/lib/server/webkit/wkProvisionalPage.js +83 -0
- package/lib/server/webkit/wkWorkers.js +105 -0
- package/lib/third_party/pixelmatch.js +255 -0
- package/lib/utils/isomorphic/ariaSnapshot.js +455 -0
- package/lib/utils/isomorphic/assert.js +31 -0
- package/lib/utils/isomorphic/colors.js +72 -0
- package/lib/utils/isomorphic/cssParser.js +245 -0
- package/lib/utils/isomorphic/cssTokenizer.js +1051 -0
- package/lib/utils/isomorphic/headers.js +53 -0
- package/lib/utils/isomorphic/locatorGenerators.js +689 -0
- package/lib/utils/isomorphic/locatorParser.js +176 -0
- package/lib/utils/isomorphic/locatorUtils.js +81 -0
- package/lib/utils/isomorphic/lruCache.js +51 -0
- package/lib/utils/isomorphic/manualPromise.js +114 -0
- package/lib/utils/isomorphic/mimeType.js +459 -0
- package/lib/utils/isomorphic/multimap.js +80 -0
- package/lib/utils/isomorphic/oldUtilityScriptSerializers.js +248 -0
- package/lib/utils/isomorphic/protocolFormatter.js +81 -0
- package/lib/utils/isomorphic/protocolMetainfo.js +330 -0
- package/lib/utils/isomorphic/rtti.js +43 -0
- package/lib/utils/isomorphic/selectorParser.js +386 -0
- package/lib/utils/isomorphic/semaphore.js +54 -0
- package/lib/utils/isomorphic/stackTrace.js +158 -0
- package/lib/utils/isomorphic/stringUtils.js +204 -0
- package/lib/utils/isomorphic/time.js +49 -0
- package/lib/utils/isomorphic/timeoutRunner.js +66 -0
- package/lib/utils/isomorphic/trace/entries.js +16 -0
- package/lib/utils/isomorphic/trace/snapshotRenderer.js +499 -0
- package/lib/utils/isomorphic/trace/snapshotServer.js +120 -0
- package/lib/utils/isomorphic/trace/snapshotStorage.js +89 -0
- package/lib/utils/isomorphic/trace/traceLoader.js +131 -0
- package/lib/utils/isomorphic/trace/traceModel.js +365 -0
- package/lib/utils/isomorphic/trace/traceModernizer.js +400 -0
- package/lib/utils/isomorphic/trace/versions/traceV3.js +16 -0
- package/lib/utils/isomorphic/trace/versions/traceV4.js +16 -0
- package/lib/utils/isomorphic/trace/versions/traceV5.js +16 -0
- package/lib/utils/isomorphic/trace/versions/traceV6.js +16 -0
- package/lib/utils/isomorphic/trace/versions/traceV7.js +16 -0
- package/lib/utils/isomorphic/trace/versions/traceV8.js +16 -0
- package/lib/utils/isomorphic/traceUtils.js +58 -0
- package/lib/utils/isomorphic/types.js +16 -0
- package/lib/utils/isomorphic/urlMatch.js +190 -0
- package/lib/utils/isomorphic/utilityScriptSerializers.js +251 -0
- package/lib/utils/isomorphic/yaml.js +84 -0
- package/lib/utils.js +111 -0
- package/lib/utilsBundle.js +109 -0
- package/lib/utilsBundleImpl/index.js +218 -0
- package/lib/utilsBundleImpl/xdg-open +1066 -0
- package/lib/vite/htmlReport/index.html +84 -0
- package/lib/vite/recorder/assets/codeMirrorModule-CFUTFUO7.js +32 -0
- package/lib/vite/recorder/assets/codeMirrorModule-DYBRYzYX.css +1 -0
- package/lib/vite/recorder/assets/codicon-DCmgc-ay.ttf +0 -0
- package/lib/vite/recorder/assets/index-BSjZa4pk.css +1 -0
- package/lib/vite/recorder/assets/index-CVkBxsGf.js +193 -0
- package/lib/vite/recorder/index.html +29 -0
- package/lib/vite/recorder/playwright-logo.svg +9 -0
- package/lib/vite/traceViewer/assets/codeMirrorModule-BVA4h_ZY.js +32 -0
- package/lib/vite/traceViewer/assets/defaultSettingsView-CjfmcdOz.js +266 -0
- package/lib/vite/traceViewer/assets/xtermModule-CsJ4vdCR.js +9 -0
- package/lib/vite/traceViewer/codeMirrorModule.DYBRYzYX.css +1 -0
- package/lib/vite/traceViewer/codicon.DCmgc-ay.ttf +0 -0
- package/lib/vite/traceViewer/defaultSettingsView.7ch9cixO.css +1 -0
- package/lib/vite/traceViewer/index.BVu7tZDe.css +1 -0
- package/lib/vite/traceViewer/index._nZoBaQx.js +2 -0
- package/lib/vite/traceViewer/index.html +43 -0
- package/lib/vite/traceViewer/manifest.webmanifest +16 -0
- package/lib/vite/traceViewer/playwright-logo.svg +9 -0
- package/lib/vite/traceViewer/snapshot.html +21 -0
- package/lib/vite/traceViewer/sw.bundle.js +5 -0
- package/lib/vite/traceViewer/uiMode.Btcz36p_.css +1 -0
- package/lib/vite/traceViewer/uiMode.fyrXARf2.js +5 -0
- package/lib/vite/traceViewer/uiMode.html +17 -0
- package/lib/vite/traceViewer/xtermModule.DYP7pi_n.css +32 -0
- package/lib/zipBundle.js +34 -0
- package/lib/zipBundleImpl.js +5 -0
- package/package.json +43 -0
- package/types/protocol.d.ts +23824 -0
- package/types/structs.d.ts +45 -0
- package/types/types.d.ts +22843 -0
|
@@ -0,0 +1,147 @@
|
|
|
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 formData_exports = {};
|
|
20
|
+
__export(formData_exports, {
|
|
21
|
+
MultipartFormData: () => MultipartFormData
|
|
22
|
+
});
|
|
23
|
+
module.exports = __toCommonJS(formData_exports);
|
|
24
|
+
var import_utilsBundle = require("../utilsBundle");
|
|
25
|
+
class MultipartFormData {
|
|
26
|
+
constructor() {
|
|
27
|
+
this._chunks = [];
|
|
28
|
+
this._boundary = generateUniqueBoundaryString();
|
|
29
|
+
}
|
|
30
|
+
contentTypeHeader() {
|
|
31
|
+
return `multipart/form-data; boundary=${this._boundary}`;
|
|
32
|
+
}
|
|
33
|
+
addField(name, value) {
|
|
34
|
+
this._beginMultiPartHeader(name);
|
|
35
|
+
this._finishMultiPartHeader();
|
|
36
|
+
this._chunks.push(Buffer.from(value));
|
|
37
|
+
this._finishMultiPartField();
|
|
38
|
+
}
|
|
39
|
+
addFileField(name, value) {
|
|
40
|
+
this._beginMultiPartHeader(name);
|
|
41
|
+
this._chunks.push(Buffer.from(`; filename="${value.name}"`));
|
|
42
|
+
this._chunks.push(Buffer.from(`\r
|
|
43
|
+
content-type: ${value.mimeType || import_utilsBundle.mime.getType(value.name) || "application/octet-stream"}`));
|
|
44
|
+
this._finishMultiPartHeader();
|
|
45
|
+
this._chunks.push(value.buffer);
|
|
46
|
+
this._finishMultiPartField();
|
|
47
|
+
}
|
|
48
|
+
finish() {
|
|
49
|
+
this._addBoundary(true);
|
|
50
|
+
return Buffer.concat(this._chunks);
|
|
51
|
+
}
|
|
52
|
+
_beginMultiPartHeader(name) {
|
|
53
|
+
this._addBoundary();
|
|
54
|
+
this._chunks.push(Buffer.from(`content-disposition: form-data; name="${name}"`));
|
|
55
|
+
}
|
|
56
|
+
_finishMultiPartHeader() {
|
|
57
|
+
this._chunks.push(Buffer.from(`\r
|
|
58
|
+
\r
|
|
59
|
+
`));
|
|
60
|
+
}
|
|
61
|
+
_finishMultiPartField() {
|
|
62
|
+
this._chunks.push(Buffer.from(`\r
|
|
63
|
+
`));
|
|
64
|
+
}
|
|
65
|
+
_addBoundary(isLastBoundary) {
|
|
66
|
+
this._chunks.push(Buffer.from("--" + this._boundary));
|
|
67
|
+
if (isLastBoundary)
|
|
68
|
+
this._chunks.push(Buffer.from("--"));
|
|
69
|
+
this._chunks.push(Buffer.from("\r\n"));
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
const alphaNumericEncodingMap = [
|
|
73
|
+
65,
|
|
74
|
+
66,
|
|
75
|
+
67,
|
|
76
|
+
68,
|
|
77
|
+
69,
|
|
78
|
+
70,
|
|
79
|
+
71,
|
|
80
|
+
72,
|
|
81
|
+
73,
|
|
82
|
+
74,
|
|
83
|
+
75,
|
|
84
|
+
76,
|
|
85
|
+
77,
|
|
86
|
+
78,
|
|
87
|
+
79,
|
|
88
|
+
80,
|
|
89
|
+
81,
|
|
90
|
+
82,
|
|
91
|
+
83,
|
|
92
|
+
84,
|
|
93
|
+
85,
|
|
94
|
+
86,
|
|
95
|
+
87,
|
|
96
|
+
88,
|
|
97
|
+
89,
|
|
98
|
+
90,
|
|
99
|
+
97,
|
|
100
|
+
98,
|
|
101
|
+
99,
|
|
102
|
+
100,
|
|
103
|
+
101,
|
|
104
|
+
102,
|
|
105
|
+
103,
|
|
106
|
+
104,
|
|
107
|
+
105,
|
|
108
|
+
106,
|
|
109
|
+
107,
|
|
110
|
+
108,
|
|
111
|
+
109,
|
|
112
|
+
110,
|
|
113
|
+
111,
|
|
114
|
+
112,
|
|
115
|
+
113,
|
|
116
|
+
114,
|
|
117
|
+
115,
|
|
118
|
+
116,
|
|
119
|
+
117,
|
|
120
|
+
118,
|
|
121
|
+
119,
|
|
122
|
+
120,
|
|
123
|
+
121,
|
|
124
|
+
122,
|
|
125
|
+
48,
|
|
126
|
+
49,
|
|
127
|
+
50,
|
|
128
|
+
51,
|
|
129
|
+
52,
|
|
130
|
+
53,
|
|
131
|
+
54,
|
|
132
|
+
55,
|
|
133
|
+
56,
|
|
134
|
+
57,
|
|
135
|
+
65,
|
|
136
|
+
66
|
|
137
|
+
];
|
|
138
|
+
function generateUniqueBoundaryString() {
|
|
139
|
+
const charCodes = [];
|
|
140
|
+
for (let i = 0; i < 16; i++)
|
|
141
|
+
charCodes.push(alphaNumericEncodingMap[Math.floor(Math.random() * alphaNumericEncodingMap.length)]);
|
|
142
|
+
return "----WebKitFormBoundary" + String.fromCharCode(...charCodes);
|
|
143
|
+
}
|
|
144
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
145
|
+
0 && (module.exports = {
|
|
146
|
+
MultipartFormData
|
|
147
|
+
});
|
|
@@ -0,0 +1,322 @@
|
|
|
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 frameSelectors_exports = {};
|
|
20
|
+
__export(frameSelectors_exports, {
|
|
21
|
+
FrameSelectors: () => FrameSelectors
|
|
22
|
+
});
|
|
23
|
+
module.exports = __toCommonJS(frameSelectors_exports);
|
|
24
|
+
var import_dom = require("./dom");
|
|
25
|
+
var import_utils = require("../utils");
|
|
26
|
+
var import_selectorParser = require("../utils/isomorphic/selectorParser");
|
|
27
|
+
class FrameSelectors {
|
|
28
|
+
constructor(frame) {
|
|
29
|
+
this.frame = frame;
|
|
30
|
+
}
|
|
31
|
+
_parseSelector(selector, options) {
|
|
32
|
+
const strict = typeof options?.strict === "boolean" ? options.strict : !!this.frame._page.browserContext._options.strictSelectors;
|
|
33
|
+
return this.frame._page.browserContext.selectors().parseSelector(selector, strict);
|
|
34
|
+
}
|
|
35
|
+
async query(selector, options, scope) {
|
|
36
|
+
const resolved = await this.resolveInjectedForSelector(selector, options, scope);
|
|
37
|
+
if (!resolved)
|
|
38
|
+
return null;
|
|
39
|
+
const handle = await resolved.injected.evaluateHandle((injected, { info, scope: scope2 }) => {
|
|
40
|
+
return injected.querySelector(info.parsed, scope2 || document, info.strict);
|
|
41
|
+
}, { info: resolved.info, scope: resolved.scope });
|
|
42
|
+
const elementHandle = handle.asElement();
|
|
43
|
+
if (!elementHandle) {
|
|
44
|
+
handle.dispose();
|
|
45
|
+
return null;
|
|
46
|
+
}
|
|
47
|
+
return adoptIfNeeded(elementHandle, await resolved.frame._mainContext());
|
|
48
|
+
}
|
|
49
|
+
async queryArrayInMainWorld(selector, scope, isolatedContext) {
|
|
50
|
+
const resolved = await this.resolveInjectedForSelector(selector, { mainWorld: !isolatedContext }, scope);
|
|
51
|
+
if (!resolved)
|
|
52
|
+
throw new Error(`Failed to find frame for selector "${selector}"`);
|
|
53
|
+
return await resolved.injected.evaluateHandle((injected, { info, scope: scope2 }) => {
|
|
54
|
+
const elements = injected.querySelectorAll(info.parsed, scope2 || document);
|
|
55
|
+
injected.checkDeprecatedSelectorUsage(info.parsed, elements);
|
|
56
|
+
return elements;
|
|
57
|
+
}, { info: resolved.info, scope: resolved.scope });
|
|
58
|
+
}
|
|
59
|
+
async queryCount(selector, options) {
|
|
60
|
+
const resolved = await this.resolveInjectedForSelector(selector);
|
|
61
|
+
if (!resolved)
|
|
62
|
+
throw new Error(`Failed to find frame for selector "${selector}"`);
|
|
63
|
+
await options.__testHookBeforeQuery?.();
|
|
64
|
+
return await resolved.injected.evaluate((injected, { info }) => {
|
|
65
|
+
const elements = injected.querySelectorAll(info.parsed, document);
|
|
66
|
+
injected.checkDeprecatedSelectorUsage(info.parsed, elements);
|
|
67
|
+
return elements.length;
|
|
68
|
+
}, { info: resolved.info });
|
|
69
|
+
}
|
|
70
|
+
async queryAll(selector, scope) {
|
|
71
|
+
const resolved = await this.resolveInjectedForSelector(selector, {}, scope);
|
|
72
|
+
if (!resolved)
|
|
73
|
+
return [];
|
|
74
|
+
const arrayHandle = await resolved.injected.evaluateHandle((injected, { info, scope: scope2 }) => {
|
|
75
|
+
const elements = injected.querySelectorAll(info.parsed, scope2 || document);
|
|
76
|
+
injected.checkDeprecatedSelectorUsage(info.parsed, elements);
|
|
77
|
+
return elements;
|
|
78
|
+
}, { info: resolved.info, scope: resolved.scope });
|
|
79
|
+
const properties = await arrayHandle.getProperties();
|
|
80
|
+
arrayHandle.dispose();
|
|
81
|
+
const targetContext = await resolved.frame._mainContext();
|
|
82
|
+
const result = [];
|
|
83
|
+
for (const property of properties.values()) {
|
|
84
|
+
const elementHandle = property.asElement();
|
|
85
|
+
if (elementHandle)
|
|
86
|
+
result.push(adoptIfNeeded(elementHandle, targetContext));
|
|
87
|
+
else
|
|
88
|
+
property.dispose();
|
|
89
|
+
}
|
|
90
|
+
return Promise.all(result);
|
|
91
|
+
}
|
|
92
|
+
_jumpToAriaRefFrameIfNeeded(selector, info, frame) {
|
|
93
|
+
if (info.parsed.parts[0].name !== "aria-ref")
|
|
94
|
+
return frame;
|
|
95
|
+
const body = info.parsed.parts[0].body;
|
|
96
|
+
const match = body.match(/^f(\d+)e\d+$/);
|
|
97
|
+
if (!match)
|
|
98
|
+
return frame;
|
|
99
|
+
const frameSeq = +match[1];
|
|
100
|
+
const jumptToFrame = this.frame._page.frameManager.frames().find((frame2) => frame2.seq === frameSeq);
|
|
101
|
+
if (!jumptToFrame)
|
|
102
|
+
throw new import_selectorParser.InvalidSelectorError(`Invalid frame in aria-ref selector "${selector}"`);
|
|
103
|
+
return jumptToFrame;
|
|
104
|
+
}
|
|
105
|
+
async resolveFrameForSelector(selector, options = {}, scope) {
|
|
106
|
+
let frame = this.frame;
|
|
107
|
+
const frameChunks = (0, import_selectorParser.splitSelectorByFrame)(selector);
|
|
108
|
+
for (const chunk of frameChunks) {
|
|
109
|
+
(0, import_selectorParser.visitAllSelectorParts)(chunk, (part, nested) => {
|
|
110
|
+
if (nested && part.name === "internal:control" && part.body === "enter-frame") {
|
|
111
|
+
const locator = (0, import_utils.asLocator)(this.frame._page.browserContext._browser.sdkLanguage(), selector);
|
|
112
|
+
throw new import_selectorParser.InvalidSelectorError(`Frame locators are not allowed inside composite locators, while querying "${locator}"`);
|
|
113
|
+
}
|
|
114
|
+
});
|
|
115
|
+
}
|
|
116
|
+
for (let i = 0; i < frameChunks.length - 1; ++i) {
|
|
117
|
+
const info = this._parseSelector(frameChunks[i], options);
|
|
118
|
+
frame = this._jumpToAriaRefFrameIfNeeded(selector, info, frame);
|
|
119
|
+
const context = await frame._context(info.world);
|
|
120
|
+
const injectedScript = await context.injectedScript();
|
|
121
|
+
const handle = await injectedScript.evaluateHandle((injected, { info: info2, scope: scope2, selectorString }) => {
|
|
122
|
+
const element2 = injected.querySelector(info2.parsed, scope2 || document, info2.strict);
|
|
123
|
+
if (element2 && element2.nodeName !== "IFRAME" && element2.nodeName !== "FRAME")
|
|
124
|
+
throw injected.createStacklessError(`Selector "${selectorString}" resolved to ${injected.previewNode(element2)}, <iframe> was expected`);
|
|
125
|
+
return element2;
|
|
126
|
+
}, { info, scope: i === 0 ? scope : void 0, selectorString: (0, import_selectorParser.stringifySelector)(info.parsed) });
|
|
127
|
+
let element = handle.asElement();
|
|
128
|
+
if (!element) {
|
|
129
|
+
try {
|
|
130
|
+
var client = frame._page.delegate._sessionForFrame(frame)._client;
|
|
131
|
+
} catch (e) {
|
|
132
|
+
var client = frame._page.delegate._mainFrameSession._client;
|
|
133
|
+
}
|
|
134
|
+
var mainContext = await frame._context("main");
|
|
135
|
+
const documentNode = await client.send("Runtime.evaluate", {
|
|
136
|
+
expression: "document",
|
|
137
|
+
serializationOptions: {
|
|
138
|
+
serialization: "idOnly"
|
|
139
|
+
},
|
|
140
|
+
contextId: mainContext.delegate._contextId
|
|
141
|
+
});
|
|
142
|
+
const documentScope = new import_dom.ElementHandle(mainContext, documentNode.result.objectId);
|
|
143
|
+
var check = await this._customFindFramesByParsed(injectedScript, client, mainContext, documentScope, info.parsed);
|
|
144
|
+
if (check.length > 0) {
|
|
145
|
+
element = check[0];
|
|
146
|
+
} else {
|
|
147
|
+
return null;
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
const maybeFrame = await frame._page.delegate.getContentFrame(element);
|
|
151
|
+
element.dispose();
|
|
152
|
+
if (!maybeFrame)
|
|
153
|
+
return null;
|
|
154
|
+
frame = maybeFrame;
|
|
155
|
+
}
|
|
156
|
+
if (frame !== this.frame)
|
|
157
|
+
scope = void 0;
|
|
158
|
+
const lastChunk = frame.selectors._parseSelector(frameChunks[frameChunks.length - 1], options);
|
|
159
|
+
frame = this._jumpToAriaRefFrameIfNeeded(selector, lastChunk, frame);
|
|
160
|
+
return { frame, info: lastChunk, scope };
|
|
161
|
+
}
|
|
162
|
+
async resolveInjectedForSelector(selector, options, scope) {
|
|
163
|
+
const resolved = await this.resolveFrameForSelector(selector, options, scope);
|
|
164
|
+
if (!resolved)
|
|
165
|
+
return;
|
|
166
|
+
const context = await resolved.frame._context(options?.mainWorld ? "main" : resolved.info.world);
|
|
167
|
+
if (!context) throw new Error("Frame was detached");
|
|
168
|
+
const injected = await context.injectedScript();
|
|
169
|
+
return { injected, info: resolved.info, frame: resolved.frame, scope: resolved.scope };
|
|
170
|
+
}
|
|
171
|
+
async _customFindFramesByParsed(injected, client, context, documentScope, parsed) {
|
|
172
|
+
var parsedEdits = { ...parsed };
|
|
173
|
+
var currentScopingElements = [documentScope];
|
|
174
|
+
while (parsed.parts.length > 0) {
|
|
175
|
+
var part = parsed.parts.shift();
|
|
176
|
+
parsedEdits.parts = [part];
|
|
177
|
+
var elements = [];
|
|
178
|
+
var elementsIndexes = [];
|
|
179
|
+
if (part.name == "nth") {
|
|
180
|
+
const partNth = Number(part.body);
|
|
181
|
+
if (partNth > currentScopingElements.length || partNth < -currentScopingElements.length) {
|
|
182
|
+
return continuePolling;
|
|
183
|
+
} else {
|
|
184
|
+
currentScopingElements = [currentScopingElements.at(partNth)];
|
|
185
|
+
continue;
|
|
186
|
+
}
|
|
187
|
+
} else if (part.name == "internal:or") {
|
|
188
|
+
var orredElements = await this._customFindFramesByParsed(injected, client, context, documentScope, part.body.parsed);
|
|
189
|
+
elements = currentScopingElements.concat(orredElements);
|
|
190
|
+
} else if (part.name == "internal:and") {
|
|
191
|
+
var andedElements = await this._customFindFramesByParsed(injected, client, context, documentScope, part.body.parsed);
|
|
192
|
+
const backendNodeIds = new Set(andedElements.map((item) => item.backendNodeId));
|
|
193
|
+
elements = currentScopingElements.filter((item) => backendNodeIds.has(item.backendNodeId));
|
|
194
|
+
} else {
|
|
195
|
+
for (const scope of currentScopingElements) {
|
|
196
|
+
const describedScope = await client.send("DOM.describeNode", {
|
|
197
|
+
objectId: scope._objectId,
|
|
198
|
+
depth: -1,
|
|
199
|
+
pierce: true
|
|
200
|
+
});
|
|
201
|
+
var queryingElements = [];
|
|
202
|
+
let findClosedShadowRoots2 = function(node, results = []) {
|
|
203
|
+
if (!node || typeof node !== "object") return results;
|
|
204
|
+
if (node.shadowRoots && Array.isArray(node.shadowRoots)) {
|
|
205
|
+
for (const shadowRoot2 of node.shadowRoots) {
|
|
206
|
+
if (shadowRoot2.shadowRootType === "closed" && shadowRoot2.backendNodeId) {
|
|
207
|
+
results.push(shadowRoot2.backendNodeId);
|
|
208
|
+
}
|
|
209
|
+
findClosedShadowRoots2(shadowRoot2, results);
|
|
210
|
+
}
|
|
211
|
+
}
|
|
212
|
+
if (node.nodeName !== "IFRAME" && node.children && Array.isArray(node.children)) {
|
|
213
|
+
for (const child of node.children) {
|
|
214
|
+
findClosedShadowRoots2(child, results);
|
|
215
|
+
}
|
|
216
|
+
}
|
|
217
|
+
return results;
|
|
218
|
+
};
|
|
219
|
+
var findClosedShadowRoots = findClosedShadowRoots2;
|
|
220
|
+
var shadowRootBackendIds = findClosedShadowRoots2(describedScope.node);
|
|
221
|
+
var shadowRoots = [];
|
|
222
|
+
for (var shadowRootBackendId of shadowRootBackendIds) {
|
|
223
|
+
var resolvedShadowRoot = await client.send("DOM.resolveNode", {
|
|
224
|
+
backendNodeId: shadowRootBackendId,
|
|
225
|
+
contextId: context.delegate._contextId
|
|
226
|
+
});
|
|
227
|
+
shadowRoots.push(new import_dom.ElementHandle(context, resolvedShadowRoot.object.objectId));
|
|
228
|
+
}
|
|
229
|
+
for (var shadowRoot of shadowRoots) {
|
|
230
|
+
const shadowElements = await shadowRoot.evaluateHandleInUtility(([injected2, node, { parsed: parsed2 }]) => {
|
|
231
|
+
const elements2 = injected2.querySelectorAll(parsed2, node);
|
|
232
|
+
return elements2;
|
|
233
|
+
}, {
|
|
234
|
+
parsed: parsedEdits
|
|
235
|
+
});
|
|
236
|
+
const shadowElementsAmount = await shadowElements.getProperty("length");
|
|
237
|
+
queryingElements.push([shadowElements, shadowElementsAmount, shadowRoot]);
|
|
238
|
+
}
|
|
239
|
+
const rootElements = await scope.evaluateHandleInUtility(([injected2, node, { parsed: parsed2 }]) => {
|
|
240
|
+
const elements2 = injected2.querySelectorAll(parsed2, node);
|
|
241
|
+
return elements2;
|
|
242
|
+
}, {
|
|
243
|
+
parsed: parsedEdits
|
|
244
|
+
});
|
|
245
|
+
const rootElementsAmount = await rootElements.getProperty("length");
|
|
246
|
+
queryingElements.push([rootElements, rootElementsAmount, injected]);
|
|
247
|
+
for (var queryedElement of queryingElements) {
|
|
248
|
+
var elementsToCheck = queryedElement[0];
|
|
249
|
+
var elementsAmount = await queryedElement[1].jsonValue();
|
|
250
|
+
var parentNode = queryedElement[2];
|
|
251
|
+
for (var i = 0; i < elementsAmount; i++) {
|
|
252
|
+
if (parentNode.constructor.name == "ElementHandle") {
|
|
253
|
+
var elementToCheck = await parentNode.evaluateHandleInUtility(([injected2, node, { index, elementsToCheck: elementsToCheck2 }]) => {
|
|
254
|
+
return elementsToCheck2[index];
|
|
255
|
+
}, { index: i, elementsToCheck });
|
|
256
|
+
} else {
|
|
257
|
+
var elementToCheck = await parentNode.evaluateHandle((injected2, { index, elementsToCheck: elementsToCheck2 }) => {
|
|
258
|
+
return elementsToCheck2[index];
|
|
259
|
+
}, { index: i, elementsToCheck });
|
|
260
|
+
}
|
|
261
|
+
elementToCheck.parentNode = parentNode;
|
|
262
|
+
var resolvedElement = await client.send("DOM.describeNode", {
|
|
263
|
+
objectId: elementToCheck._objectId,
|
|
264
|
+
depth: -1
|
|
265
|
+
});
|
|
266
|
+
elementToCheck.backendNodeId = resolvedElement.node.backendNodeId;
|
|
267
|
+
elementToCheck.nodePosition = this._findElementPositionInDomTree(elementToCheck, describedScope.node, context, "");
|
|
268
|
+
elements.push(elementToCheck);
|
|
269
|
+
}
|
|
270
|
+
}
|
|
271
|
+
}
|
|
272
|
+
}
|
|
273
|
+
const getParts = (pos) => (pos?.match(/../g) || []).map(Number);
|
|
274
|
+
elements.sort((a, b) => {
|
|
275
|
+
const partA = getParts(a.nodePosition);
|
|
276
|
+
const partB = getParts(b.nodePosition);
|
|
277
|
+
const maxLength = Math.max(partA.length, partB.length);
|
|
278
|
+
for (let i2 = 0; i2 < maxLength; i2++) {
|
|
279
|
+
const aVal = partA[i2] ?? -1;
|
|
280
|
+
const bVal = partB[i2] ?? -1;
|
|
281
|
+
if (aVal !== bVal) return aVal - bVal;
|
|
282
|
+
}
|
|
283
|
+
return 0;
|
|
284
|
+
});
|
|
285
|
+
currentScopingElements = Array.from(
|
|
286
|
+
new Map(elements.map((e) => [e.nodePosition, e])).values()
|
|
287
|
+
);
|
|
288
|
+
}
|
|
289
|
+
return currentScopingElements;
|
|
290
|
+
}
|
|
291
|
+
_findElementPositionInDomTree(element, queryingElement, documentScope, currentIndex) {
|
|
292
|
+
if (element.backendNodeId === queryingElement.backendNodeId) {
|
|
293
|
+
return currentIndex;
|
|
294
|
+
}
|
|
295
|
+
for (const child of queryingElement.children || []) {
|
|
296
|
+
const childrenNodeIndex = queryingElement.children.indexOf(child);
|
|
297
|
+
const childIndex = this._findElementPositionInDomTree(element, child, documentScope, currentIndex + "." + childrenNodeIndex.toString());
|
|
298
|
+
if (childIndex !== null) return childIndex;
|
|
299
|
+
}
|
|
300
|
+
if (queryingElement.shadowRoots && Array.isArray(queryingElement.shadowRoots)) {
|
|
301
|
+
for (const shadowRoot of queryingElement.shadowRoots) {
|
|
302
|
+
if (shadowRoot.shadowRootType === "closed" && shadowRoot.backendNodeId) {
|
|
303
|
+
const shadowRootHandle = new import_dom.ElementHandle(documentScope, shadowRoot.backendNodeId);
|
|
304
|
+
const childIndex = this._findElementPositionInDomTree(element, shadowRootHandle, documentScope, currentIndex);
|
|
305
|
+
if (childIndex !== null) return childIndex;
|
|
306
|
+
}
|
|
307
|
+
}
|
|
308
|
+
}
|
|
309
|
+
return null;
|
|
310
|
+
}
|
|
311
|
+
}
|
|
312
|
+
async function adoptIfNeeded(handle, context) {
|
|
313
|
+
if (handle._context === context)
|
|
314
|
+
return handle;
|
|
315
|
+
const adopted = await handle._page.delegate.adoptElementHandle(handle, context);
|
|
316
|
+
handle.dispose();
|
|
317
|
+
return adopted;
|
|
318
|
+
}
|
|
319
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
320
|
+
0 && (module.exports = {
|
|
321
|
+
FrameSelectors
|
|
322
|
+
});
|