phantomwright-driver-core 1.57.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 +1161 -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 +80 -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 +590 -0
- package/lib/cli/programWithTestStub.js +74 -0
- package/lib/client/android.js +361 -0
- package/lib/client/api.js +134 -0
- package/lib/client/artifact.js +79 -0
- package/lib/client/browser.js +163 -0
- package/lib/client/browserContext.js +547 -0
- package/lib/client/browserType.js +184 -0
- package/lib/client/cdpSession.js +51 -0
- package/lib/client/channelOwner.js +194 -0
- package/lib/client/clientHelper.js +64 -0
- package/lib/client/clientInstrumentation.js +55 -0
- package/lib/client/clientStackTrace.js +69 -0
- package/lib/client/clock.js +68 -0
- package/lib/client/connection.js +314 -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 +281 -0
- package/lib/client/errors.js +77 -0
- package/lib/client/eventEmitter.js +314 -0
- package/lib/client/events.js +100 -0
- package/lib/client/fetch.js +369 -0
- package/lib/client/fileChooser.js +46 -0
- package/lib/client/fileUtils.js +34 -0
- package/lib/client/frame.js +408 -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 +369 -0
- package/lib/client/network.js +747 -0
- package/lib/client/page.js +718 -0
- package/lib/client/platform.js +74 -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 +119 -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/outofprocess.js +76 -0
- package/lib/protocol/serializers.js +192 -0
- package/lib/protocol/validator.js +2890 -0
- package/lib/protocol/validatorPrimitives.js +193 -0
- package/lib/remote/playwrightConnection.js +129 -0
- package/lib/remote/playwrightServer.js +335 -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 +505 -0
- package/lib/server/bidi/bidiChromium.js +153 -0
- package/lib/server/bidi/bidiConnection.js +212 -0
- package/lib/server/bidi/bidiExecutionContext.js +221 -0
- package/lib/server/bidi/bidiFirefox.js +130 -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 +572 -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/bidiDeserializer.js +98 -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 +179 -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 +695 -0
- package/lib/server/browserType.js +328 -0
- package/lib/server/callLog.js +82 -0
- package/lib/server/chromium/appIcon.png +0 -0
- package/lib/server/chromium/chromium.js +402 -0
- package/lib/server/chromium/chromiumSwitches.js +104 -0
- package/lib/server/chromium/crBrowser.js +510 -0
- package/lib/server/chromium/crConnection.js +202 -0
- package/lib/server/chromium/crCoverage.js +235 -0
- package/lib/server/chromium/crDevTools.js +113 -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 +666 -0
- package/lib/server/chromium/crPage.js +1069 -0
- package/lib/server/chromium/crPdf.js +121 -0
- package/lib/server/chromium/crProtocolHelper.js +145 -0
- package/lib/server/chromium/crServiceWorker.js +136 -0
- package/lib/server/chromium/defaultFontFamilies.js +162 -0
- package/lib/server/chromium/protocol.d.js +16 -0
- package/lib/server/chromium/videoRecorder.js +115 -0
- package/lib/server/clock.js +149 -0
- package/lib/server/codegen/csharp.js +327 -0
- package/lib/server/codegen/java.js +274 -0
- package/lib/server/codegen/javascript.js +270 -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 +381 -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 +371 -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/pageDispatcher.js +389 -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 +806 -0
- package/lib/server/download.js +70 -0
- package/lib/server/electron/electron.js +270 -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 +428 -0
- package/lib/server/firefox/ffConnection.js +147 -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 +500 -0
- package/lib/server/firefox/firefox.js +116 -0
- package/lib/server/firefox/protocol.d.js +16 -0
- package/lib/server/formData.js +147 -0
- package/lib/server/frameSelectors.js +154 -0
- package/lib/server/frames.js +1455 -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 +69 -0
- package/lib/server/javascript.js +291 -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 +629 -0
- package/lib/server/page.js +886 -0
- package/lib/server/pipeTransport.js +89 -0
- package/lib/server/playwright.js +69 -0
- package/lib/server/progress.js +112 -0
- package/lib/server/protocolError.js +52 -0
- package/lib/server/recorder/chat.js +161 -0
- package/lib/server/recorder/recorderApp.js +387 -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 +175 -0
- package/lib/server/registry/dependencies.js +371 -0
- package/lib/server/registry/index.js +1399 -0
- package/lib/server/registry/nativeDeps.js +1280 -0
- package/lib/server/registry/oopDownloadBrowserMain.js +124 -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 +541 -0
- package/lib/server/trace/recorder/tracing.js +604 -0
- package/lib/server/trace/test/inMemorySnapshotter.js +87 -0
- package/lib/server/trace/viewer/traceViewer.js +241 -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 +38 -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 +218 -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 +233 -0
- package/lib/server/utils/nodePlatform.js +148 -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/webkit/protocol.d.js +16 -0
- package/lib/server/webkit/webkit.js +110 -0
- package/lib/server/webkit/wkBrowser.js +339 -0
- package/lib/server/webkit/wkConnection.js +149 -0
- package/lib/server/webkit/wkExecutionContext.js +154 -0
- package/lib/server/webkit/wkInput.js +181 -0
- package/lib/server/webkit/wkInterceptableRequest.js +169 -0
- package/lib/server/webkit/wkPage.js +1130 -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 +397 -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/manualPromise.js +114 -0
- package/lib/utils/isomorphic/mimeType.js +459 -0
- package/lib/utils/isomorphic/multimap.js +80 -0
- package/lib/utils/isomorphic/protocolFormatter.js +81 -0
- package/lib/utils/isomorphic/protocolMetainfo.js +322 -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 +155 -0
- package/lib/utils/isomorphic/time.js +49 -0
- package/lib/utils/isomorphic/timeoutRunner.js +66 -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.js +109 -0
- package/lib/utilsBundle.js +112 -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-BoWUGj0J.js +25 -0
- package/lib/vite/recorder/assets/codeMirrorModule-C3UTv-Ge.css +1 -0
- package/lib/vite/recorder/assets/codicon-DCmgc-ay.ttf +0 -0
- package/lib/vite/recorder/assets/index-DJqDAOZp.js +193 -0
- package/lib/vite/recorder/assets/index-Ri0uHF7I.css +1 -0
- package/lib/vite/recorder/index.html +29 -0
- package/lib/vite/recorder/playwright-logo.svg +9 -0
- package/lib/vite/traceViewer/assets/codeMirrorModule-Bucv2d7q.js +25 -0
- package/lib/vite/traceViewer/assets/defaultSettingsView-BEpdCv1S.js +266 -0
- package/lib/vite/traceViewer/assets/xtermModule-CsJ4vdCR.js +9 -0
- package/lib/vite/traceViewer/codeMirrorModule.C3UTv-Ge.css +1 -0
- package/lib/vite/traceViewer/codicon.DCmgc-ay.ttf +0 -0
- package/lib/vite/traceViewer/defaultSettingsView.ConWv5KN.css +1 -0
- package/lib/vite/traceViewer/index.BxQ34UMZ.js +2 -0
- package/lib/vite/traceViewer/index.C4Y3Aw8n.css +1 -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 +3 -0
- package/lib/vite/traceViewer/uiMode.BWTwXl41.js +5 -0
- package/lib/vite/traceViewer/uiMode.Btcz36p_.css +1 -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 +42 -0
- package/types/protocol.d.ts +23245 -0
- package/types/structs.d.ts +45 -0
- package/types/types.d.ts +22856 -0
|
@@ -0,0 +1,153 @@
|
|
|
1
|
+
"use strict";
|
|
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 bidiChromium_exports = {};
|
|
30
|
+
__export(bidiChromium_exports, {
|
|
31
|
+
BidiChromium: () => BidiChromium
|
|
32
|
+
});
|
|
33
|
+
module.exports = __toCommonJS(bidiChromium_exports);
|
|
34
|
+
var import_os = __toESM(require("os"));
|
|
35
|
+
var import_ascii = require("../utils/ascii");
|
|
36
|
+
var import_browserType = require("../browserType");
|
|
37
|
+
var import_bidiBrowser = require("./bidiBrowser");
|
|
38
|
+
var import_bidiConnection = require("./bidiConnection");
|
|
39
|
+
var import_chromiumSwitches = require("../chromium/chromiumSwitches");
|
|
40
|
+
var import_chromium = require("../chromium/chromium");
|
|
41
|
+
class BidiChromium extends import_browserType.BrowserType {
|
|
42
|
+
constructor(parent) {
|
|
43
|
+
super(parent, "chromium");
|
|
44
|
+
}
|
|
45
|
+
async connectToTransport(transport, options, browserLogsCollector) {
|
|
46
|
+
const bidiTransport = await require("./bidiOverCdp").connectBidiOverCdp(transport);
|
|
47
|
+
transport[kBidiOverCdpWrapper] = bidiTransport;
|
|
48
|
+
try {
|
|
49
|
+
return import_bidiBrowser.BidiBrowser.connect(this.attribution.playwright, bidiTransport, options);
|
|
50
|
+
} catch (e) {
|
|
51
|
+
if (browserLogsCollector.recentLogs().some((log) => log.includes("Failed to create a ProcessSingleton for your profile directory."))) {
|
|
52
|
+
throw new Error(
|
|
53
|
+
"Failed to create a ProcessSingleton for your profile directory. This usually means that the profile is already in use by another instance of Chromium."
|
|
54
|
+
);
|
|
55
|
+
}
|
|
56
|
+
throw e;
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
doRewriteStartupLog(error) {
|
|
60
|
+
if (!error.logs)
|
|
61
|
+
return error;
|
|
62
|
+
if (error.logs.includes("Missing X server"))
|
|
63
|
+
error.logs = "\n" + (0, import_ascii.wrapInASCIIBox)(import_browserType.kNoXServerRunningError, 1);
|
|
64
|
+
if (!error.logs.includes("crbug.com/357670") && !error.logs.includes("No usable sandbox!") && !error.logs.includes("crbug.com/638180"))
|
|
65
|
+
return error;
|
|
66
|
+
error.logs = [
|
|
67
|
+
`Chromium sandboxing failed!`,
|
|
68
|
+
`================================`,
|
|
69
|
+
`To avoid the sandboxing issue, do either of the following:`,
|
|
70
|
+
` - (preferred): Configure your environment to support sandboxing`,
|
|
71
|
+
` - (alternative): Launch Chromium without sandbox using 'chromiumSandbox: false' option`,
|
|
72
|
+
`================================`,
|
|
73
|
+
``
|
|
74
|
+
].join("\n");
|
|
75
|
+
return error;
|
|
76
|
+
}
|
|
77
|
+
amendEnvironment(env) {
|
|
78
|
+
return env;
|
|
79
|
+
}
|
|
80
|
+
attemptToGracefullyCloseBrowser(transport) {
|
|
81
|
+
const bidiTransport = transport[kBidiOverCdpWrapper];
|
|
82
|
+
if (bidiTransport)
|
|
83
|
+
transport = bidiTransport;
|
|
84
|
+
transport.send({ method: "browser.close", params: {}, id: import_bidiConnection.kBrowserCloseMessageId });
|
|
85
|
+
}
|
|
86
|
+
supportsPipeTransport() {
|
|
87
|
+
return false;
|
|
88
|
+
}
|
|
89
|
+
async defaultArgs(options, isPersistent, userDataDir) {
|
|
90
|
+
const chromeArguments = this._innerDefaultArgs(options);
|
|
91
|
+
chromeArguments.push(`--user-data-dir=${userDataDir}`);
|
|
92
|
+
chromeArguments.push("--remote-debugging-port=0");
|
|
93
|
+
if (isPersistent)
|
|
94
|
+
chromeArguments.push("about:blank");
|
|
95
|
+
else
|
|
96
|
+
chromeArguments.push("--no-startup-window");
|
|
97
|
+
return chromeArguments;
|
|
98
|
+
}
|
|
99
|
+
async waitForReadyState(options, browserLogsCollector) {
|
|
100
|
+
return (0, import_chromium.waitForReadyState)({ ...options, cdpPort: 0 }, browserLogsCollector);
|
|
101
|
+
}
|
|
102
|
+
_innerDefaultArgs(options) {
|
|
103
|
+
const { args = [] } = options;
|
|
104
|
+
const userDataDirArg = args.find((arg) => arg.startsWith("--user-data-dir"));
|
|
105
|
+
if (userDataDirArg)
|
|
106
|
+
throw this._createUserDataDirArgMisuseError("--user-data-dir");
|
|
107
|
+
if (args.find((arg) => arg.startsWith("--remote-debugging-pipe")))
|
|
108
|
+
throw new Error("Playwright manages remote debugging connection itself.");
|
|
109
|
+
if (args.find((arg) => !arg.startsWith("-")))
|
|
110
|
+
throw new Error("Arguments can not specify page to be opened");
|
|
111
|
+
const chromeArguments = [...(0, import_chromiumSwitches.chromiumSwitches)(options.assistantMode)];
|
|
112
|
+
if (import_os.default.platform() === "darwin") {
|
|
113
|
+
chromeArguments.push("--enable-unsafe-swiftshader");
|
|
114
|
+
}
|
|
115
|
+
if (options.devtools)
|
|
116
|
+
chromeArguments.push("--auto-open-devtools-for-tabs");
|
|
117
|
+
if (options.headless) {
|
|
118
|
+
chromeArguments.push("--headless");
|
|
119
|
+
chromeArguments.push(
|
|
120
|
+
"--hide-scrollbars",
|
|
121
|
+
"--mute-audio",
|
|
122
|
+
"--blink-settings=primaryHoverType=2,availableHoverTypes=2,primaryPointerType=4,availablePointerTypes=4"
|
|
123
|
+
);
|
|
124
|
+
}
|
|
125
|
+
if (options.chromiumSandbox !== true)
|
|
126
|
+
chromeArguments.push("--no-sandbox");
|
|
127
|
+
const proxy = options.proxyOverride || options.proxy;
|
|
128
|
+
if (proxy) {
|
|
129
|
+
const proxyURL = new URL(proxy.server);
|
|
130
|
+
const isSocks = proxyURL.protocol === "socks5:";
|
|
131
|
+
if (isSocks && !options.socksProxyPort) {
|
|
132
|
+
chromeArguments.push(`--host-resolver-rules="MAP * ~NOTFOUND , EXCLUDE ${proxyURL.hostname}"`);
|
|
133
|
+
}
|
|
134
|
+
chromeArguments.push(`--proxy-server=${proxy.server}`);
|
|
135
|
+
const proxyBypassRules = [];
|
|
136
|
+
if (options.socksProxyPort)
|
|
137
|
+
proxyBypassRules.push("<-loopback>");
|
|
138
|
+
if (proxy.bypass)
|
|
139
|
+
proxyBypassRules.push(...proxy.bypass.split(",").map((t) => t.trim()).map((t) => t.startsWith(".") ? "*" + t : t));
|
|
140
|
+
if (!process.env.PLAYWRIGHT_DISABLE_FORCED_CHROMIUM_PROXIED_LOOPBACK && !proxyBypassRules.includes("<-loopback>"))
|
|
141
|
+
proxyBypassRules.push("<-loopback>");
|
|
142
|
+
if (proxyBypassRules.length > 0)
|
|
143
|
+
chromeArguments.push(`--proxy-bypass-list=${proxyBypassRules.join(";")}`);
|
|
144
|
+
}
|
|
145
|
+
chromeArguments.push(...args);
|
|
146
|
+
return chromeArguments;
|
|
147
|
+
}
|
|
148
|
+
}
|
|
149
|
+
const kBidiOverCdpWrapper = Symbol("kBidiConnectionWrapper");
|
|
150
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
151
|
+
0 && (module.exports = {
|
|
152
|
+
BidiChromium
|
|
153
|
+
});
|
|
@@ -0,0 +1,212 @@
|
|
|
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 bidiConnection_exports = {};
|
|
20
|
+
__export(bidiConnection_exports, {
|
|
21
|
+
BidiConnection: () => BidiConnection,
|
|
22
|
+
BidiSession: () => BidiSession,
|
|
23
|
+
kBrowserCloseMessageId: () => kBrowserCloseMessageId,
|
|
24
|
+
kShutdownSessionNewMessageId: () => kShutdownSessionNewMessageId
|
|
25
|
+
});
|
|
26
|
+
module.exports = __toCommonJS(bidiConnection_exports);
|
|
27
|
+
var import_events = require("events");
|
|
28
|
+
var import_debugLogger = require("../utils/debugLogger");
|
|
29
|
+
var import_helper = require("../helper");
|
|
30
|
+
var import_protocolError = require("../protocolError");
|
|
31
|
+
const kBrowserCloseMessageId = Number.MAX_SAFE_INTEGER - 1;
|
|
32
|
+
const kShutdownSessionNewMessageId = kBrowserCloseMessageId - 1;
|
|
33
|
+
class BidiConnection {
|
|
34
|
+
constructor(transport, onDisconnect, protocolLogger, browserLogsCollector) {
|
|
35
|
+
this._lastId = 0;
|
|
36
|
+
this._closed = false;
|
|
37
|
+
this._browsingContextToSession = /* @__PURE__ */ new Map();
|
|
38
|
+
this._realmToBrowsingContext = /* @__PURE__ */ new Map();
|
|
39
|
+
// TODO: shared/service workers might have multiple owner realms.
|
|
40
|
+
this._realmToOwnerRealm = /* @__PURE__ */ new Map();
|
|
41
|
+
this._transport = transport;
|
|
42
|
+
this._onDisconnect = onDisconnect;
|
|
43
|
+
this._protocolLogger = protocolLogger;
|
|
44
|
+
this._browserLogsCollector = browserLogsCollector;
|
|
45
|
+
this.browserSession = new BidiSession(this, "", (message) => {
|
|
46
|
+
this.rawSend(message);
|
|
47
|
+
});
|
|
48
|
+
this._transport.onmessage = this._dispatchMessage.bind(this);
|
|
49
|
+
this._transport.onclose = this._onClose.bind(this);
|
|
50
|
+
}
|
|
51
|
+
nextMessageId() {
|
|
52
|
+
return ++this._lastId;
|
|
53
|
+
}
|
|
54
|
+
rawSend(message) {
|
|
55
|
+
this._protocolLogger("send", message);
|
|
56
|
+
this._transport.send(message);
|
|
57
|
+
}
|
|
58
|
+
_dispatchMessage(message) {
|
|
59
|
+
this._protocolLogger("receive", message);
|
|
60
|
+
const object = message;
|
|
61
|
+
if (object.type === "event") {
|
|
62
|
+
if (object.method === "script.realmCreated") {
|
|
63
|
+
if ("context" in object.params)
|
|
64
|
+
this._realmToBrowsingContext.set(object.params.realm, object.params.context);
|
|
65
|
+
if (object.params.type === "dedicated-worker")
|
|
66
|
+
this._realmToOwnerRealm.set(object.params.realm, object.params.owners[0]);
|
|
67
|
+
} else if (object.method === "script.realmDestroyed") {
|
|
68
|
+
this._realmToBrowsingContext.delete(object.params.realm);
|
|
69
|
+
this._realmToOwnerRealm.delete(object.params.realm);
|
|
70
|
+
}
|
|
71
|
+
let context;
|
|
72
|
+
let realm;
|
|
73
|
+
if ("context" in object.params) {
|
|
74
|
+
context = object.params.context;
|
|
75
|
+
} else if (object.method === "log.entryAdded" || object.method === "script.message") {
|
|
76
|
+
context = object.params.source?.context;
|
|
77
|
+
realm = object.params.source?.realm;
|
|
78
|
+
} else if (object.method === "script.realmCreated" && object.params.type === "dedicated-worker") {
|
|
79
|
+
realm = object.params.owners[0];
|
|
80
|
+
}
|
|
81
|
+
if (!context && realm) {
|
|
82
|
+
while (this._realmToOwnerRealm.get(realm))
|
|
83
|
+
realm = this._realmToOwnerRealm.get(realm);
|
|
84
|
+
context = this._realmToBrowsingContext.get(realm);
|
|
85
|
+
}
|
|
86
|
+
if (context) {
|
|
87
|
+
const session = this._browsingContextToSession.get(context);
|
|
88
|
+
if (session) {
|
|
89
|
+
session.dispatchMessage(message);
|
|
90
|
+
return;
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
} else if (message.id) {
|
|
94
|
+
for (const session of this._browsingContextToSession.values()) {
|
|
95
|
+
if (session.hasCallback(message.id)) {
|
|
96
|
+
session.dispatchMessage(message);
|
|
97
|
+
return;
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
this.browserSession.dispatchMessage(message);
|
|
102
|
+
}
|
|
103
|
+
_onClose(reason) {
|
|
104
|
+
this._closed = true;
|
|
105
|
+
this._transport.onmessage = void 0;
|
|
106
|
+
this._transport.onclose = void 0;
|
|
107
|
+
this._browserDisconnectedLogs = import_helper.helper.formatBrowserLogs(this._browserLogsCollector.recentLogs(), reason);
|
|
108
|
+
this.browserSession.dispose();
|
|
109
|
+
this._onDisconnect();
|
|
110
|
+
}
|
|
111
|
+
isClosed() {
|
|
112
|
+
return this._closed;
|
|
113
|
+
}
|
|
114
|
+
close() {
|
|
115
|
+
if (!this._closed)
|
|
116
|
+
this._transport.close();
|
|
117
|
+
}
|
|
118
|
+
createMainFrameBrowsingContextSession(bowsingContextId) {
|
|
119
|
+
const result = new BidiSession(this, bowsingContextId, (message) => this.rawSend(message));
|
|
120
|
+
this._browsingContextToSession.set(bowsingContextId, result);
|
|
121
|
+
return result;
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
class BidiSession extends import_events.EventEmitter {
|
|
125
|
+
constructor(connection, sessionId, rawSend) {
|
|
126
|
+
super();
|
|
127
|
+
this._disposed = false;
|
|
128
|
+
this._callbacks = /* @__PURE__ */ new Map();
|
|
129
|
+
this._crashed = false;
|
|
130
|
+
this._browsingContexts = /* @__PURE__ */ new Set();
|
|
131
|
+
this.setMaxListeners(0);
|
|
132
|
+
this.connection = connection;
|
|
133
|
+
this.sessionId = sessionId;
|
|
134
|
+
this._rawSend = rawSend;
|
|
135
|
+
this.on = super.on;
|
|
136
|
+
this.off = super.removeListener;
|
|
137
|
+
this.addListener = super.addListener;
|
|
138
|
+
this.removeListener = super.removeListener;
|
|
139
|
+
this.once = super.once;
|
|
140
|
+
}
|
|
141
|
+
addFrameBrowsingContext(context) {
|
|
142
|
+
this._browsingContexts.add(context);
|
|
143
|
+
this.connection._browsingContextToSession.set(context, this);
|
|
144
|
+
}
|
|
145
|
+
removeFrameBrowsingContext(context) {
|
|
146
|
+
this._browsingContexts.delete(context);
|
|
147
|
+
this.connection._browsingContextToSession.delete(context);
|
|
148
|
+
}
|
|
149
|
+
async send(method, params) {
|
|
150
|
+
if (this._crashed || this._disposed || this.connection._browserDisconnectedLogs)
|
|
151
|
+
throw new import_protocolError.ProtocolError(this._crashed ? "crashed" : "closed", void 0, this.connection._browserDisconnectedLogs);
|
|
152
|
+
const id = this.connection.nextMessageId();
|
|
153
|
+
const messageObj = { id, method, params };
|
|
154
|
+
this._rawSend(messageObj);
|
|
155
|
+
return new Promise((resolve, reject) => {
|
|
156
|
+
this._callbacks.set(id, { resolve, reject, error: new import_protocolError.ProtocolError("error", method) });
|
|
157
|
+
});
|
|
158
|
+
}
|
|
159
|
+
sendMayFail(method, params) {
|
|
160
|
+
return this.send(method, params).catch((error) => import_debugLogger.debugLogger.log("error", error));
|
|
161
|
+
}
|
|
162
|
+
markAsCrashed() {
|
|
163
|
+
this._crashed = true;
|
|
164
|
+
}
|
|
165
|
+
isDisposed() {
|
|
166
|
+
return this._disposed;
|
|
167
|
+
}
|
|
168
|
+
dispose() {
|
|
169
|
+
this._disposed = true;
|
|
170
|
+
this.connection._browsingContextToSession.delete(this.sessionId);
|
|
171
|
+
for (const context of this._browsingContexts)
|
|
172
|
+
this.connection._browsingContextToSession.delete(context);
|
|
173
|
+
this._browsingContexts.clear();
|
|
174
|
+
for (const callback of this._callbacks.values()) {
|
|
175
|
+
callback.error.type = this._crashed ? "crashed" : "closed";
|
|
176
|
+
callback.error.logs = this.connection._browserDisconnectedLogs;
|
|
177
|
+
callback.reject(callback.error);
|
|
178
|
+
}
|
|
179
|
+
this._callbacks.clear();
|
|
180
|
+
}
|
|
181
|
+
hasCallback(id) {
|
|
182
|
+
return this._callbacks.has(id);
|
|
183
|
+
}
|
|
184
|
+
dispatchMessage(message) {
|
|
185
|
+
const object = message;
|
|
186
|
+
if (object.id === kBrowserCloseMessageId || object.id === kShutdownSessionNewMessageId)
|
|
187
|
+
return;
|
|
188
|
+
if (object.id && this._callbacks.has(object.id)) {
|
|
189
|
+
const callback = this._callbacks.get(object.id);
|
|
190
|
+
this._callbacks.delete(object.id);
|
|
191
|
+
if (object.type === "error") {
|
|
192
|
+
callback.error.setMessage(object.error + "\nMessage: " + object.message);
|
|
193
|
+
callback.reject(callback.error);
|
|
194
|
+
} else if (object.type === "success") {
|
|
195
|
+
callback.resolve(object.result);
|
|
196
|
+
} else {
|
|
197
|
+
callback.error.setMessage("Internal error, unexpected response type: " + JSON.stringify(object));
|
|
198
|
+
callback.reject(callback.error);
|
|
199
|
+
}
|
|
200
|
+
} else if (object.id) {
|
|
201
|
+
} else {
|
|
202
|
+
Promise.resolve().then(() => this.emit(object.method, object.params));
|
|
203
|
+
}
|
|
204
|
+
}
|
|
205
|
+
}
|
|
206
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
207
|
+
0 && (module.exports = {
|
|
208
|
+
BidiConnection,
|
|
209
|
+
BidiSession,
|
|
210
|
+
kBrowserCloseMessageId,
|
|
211
|
+
kShutdownSessionNewMessageId
|
|
212
|
+
});
|
|
@@ -0,0 +1,221 @@
|
|
|
1
|
+
"use strict";
|
|
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 bidiExecutionContext_exports = {};
|
|
30
|
+
__export(bidiExecutionContext_exports, {
|
|
31
|
+
BidiExecutionContext: () => BidiExecutionContext,
|
|
32
|
+
createHandle: () => createHandle
|
|
33
|
+
});
|
|
34
|
+
module.exports = __toCommonJS(bidiExecutionContext_exports);
|
|
35
|
+
var import_utils = require("../../utils");
|
|
36
|
+
var import_utilityScriptSerializers = require("../../utils/isomorphic/utilityScriptSerializers");
|
|
37
|
+
var js = __toESM(require("../javascript"));
|
|
38
|
+
var dom = __toESM(require("../dom"));
|
|
39
|
+
var import_bidiDeserializer = require("./third_party/bidiDeserializer");
|
|
40
|
+
var bidi = __toESM(require("./third_party/bidiProtocol"));
|
|
41
|
+
var import_bidiSerializer = require("./third_party/bidiSerializer");
|
|
42
|
+
class BidiExecutionContext {
|
|
43
|
+
constructor(session, realmInfo) {
|
|
44
|
+
this._session = session;
|
|
45
|
+
if (realmInfo.type === "window") {
|
|
46
|
+
this._target = {
|
|
47
|
+
context: realmInfo.context,
|
|
48
|
+
sandbox: realmInfo.sandbox
|
|
49
|
+
};
|
|
50
|
+
} else {
|
|
51
|
+
this._target = {
|
|
52
|
+
realm: realmInfo.realm
|
|
53
|
+
};
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
async rawEvaluateJSON(expression) {
|
|
57
|
+
const response = await this._session.send("script.evaluate", {
|
|
58
|
+
expression,
|
|
59
|
+
target: this._target,
|
|
60
|
+
serializationOptions: {
|
|
61
|
+
maxObjectDepth: 10,
|
|
62
|
+
maxDomDepth: 10
|
|
63
|
+
},
|
|
64
|
+
awaitPromise: true,
|
|
65
|
+
userActivation: true
|
|
66
|
+
});
|
|
67
|
+
if (response.type === "success")
|
|
68
|
+
return import_bidiDeserializer.BidiDeserializer.deserialize(response.result);
|
|
69
|
+
if (response.type === "exception")
|
|
70
|
+
throw new js.JavaScriptErrorInEvaluate(response.exceptionDetails.text);
|
|
71
|
+
throw new js.JavaScriptErrorInEvaluate("Unexpected response type: " + JSON.stringify(response));
|
|
72
|
+
}
|
|
73
|
+
async rawEvaluateHandle(context, expression) {
|
|
74
|
+
const response = await this._session.send("script.evaluate", {
|
|
75
|
+
expression,
|
|
76
|
+
target: this._target,
|
|
77
|
+
resultOwnership: bidi.Script.ResultOwnership.Root,
|
|
78
|
+
// Necessary for the handle to be returned.
|
|
79
|
+
serializationOptions: { maxObjectDepth: 0, maxDomDepth: 0 },
|
|
80
|
+
awaitPromise: true,
|
|
81
|
+
userActivation: true
|
|
82
|
+
});
|
|
83
|
+
if (response.type === "success") {
|
|
84
|
+
if ("handle" in response.result)
|
|
85
|
+
return createHandle(context, response.result);
|
|
86
|
+
throw new js.JavaScriptErrorInEvaluate("Cannot get handle: " + JSON.stringify(response.result));
|
|
87
|
+
}
|
|
88
|
+
if (response.type === "exception")
|
|
89
|
+
throw new js.JavaScriptErrorInEvaluate(response.exceptionDetails.text);
|
|
90
|
+
throw new js.JavaScriptErrorInEvaluate("Unexpected response type: " + JSON.stringify(response));
|
|
91
|
+
}
|
|
92
|
+
async evaluateWithArguments(functionDeclaration, returnByValue, utilityScript, values, handles) {
|
|
93
|
+
const response = await this._session.send("script.callFunction", {
|
|
94
|
+
functionDeclaration,
|
|
95
|
+
target: this._target,
|
|
96
|
+
arguments: [
|
|
97
|
+
{ handle: utilityScript._objectId },
|
|
98
|
+
...values.map(import_bidiSerializer.BidiSerializer.serialize),
|
|
99
|
+
...handles.map((handle) => ({ handle: handle._objectId }))
|
|
100
|
+
],
|
|
101
|
+
resultOwnership: returnByValue ? void 0 : bidi.Script.ResultOwnership.Root,
|
|
102
|
+
// Necessary for the handle to be returned.
|
|
103
|
+
serializationOptions: returnByValue ? {} : { maxObjectDepth: 0, maxDomDepth: 0 },
|
|
104
|
+
awaitPromise: true,
|
|
105
|
+
userActivation: true
|
|
106
|
+
});
|
|
107
|
+
if (response.type === "exception")
|
|
108
|
+
throw new js.JavaScriptErrorInEvaluate(response.exceptionDetails.text);
|
|
109
|
+
if (response.type === "success") {
|
|
110
|
+
if (returnByValue)
|
|
111
|
+
return (0, import_utilityScriptSerializers.parseEvaluationResultValue)(import_bidiDeserializer.BidiDeserializer.deserialize(response.result));
|
|
112
|
+
return createHandle(utilityScript._context, response.result);
|
|
113
|
+
}
|
|
114
|
+
throw new js.JavaScriptErrorInEvaluate("Unexpected response type: " + JSON.stringify(response));
|
|
115
|
+
}
|
|
116
|
+
async getProperties(handle) {
|
|
117
|
+
const names = await handle.evaluate((object) => {
|
|
118
|
+
const names2 = [];
|
|
119
|
+
const descriptors = Object.getOwnPropertyDescriptors(object);
|
|
120
|
+
for (const name in descriptors) {
|
|
121
|
+
if (descriptors[name]?.enumerable)
|
|
122
|
+
names2.push(name);
|
|
123
|
+
}
|
|
124
|
+
return names2;
|
|
125
|
+
});
|
|
126
|
+
const values = await Promise.all(names.map((name) => handle.evaluateHandle((object, name2) => object[name2], name)));
|
|
127
|
+
const map = /* @__PURE__ */ new Map();
|
|
128
|
+
for (let i = 0; i < names.length; i++)
|
|
129
|
+
map.set(names[i], values[i]);
|
|
130
|
+
return map;
|
|
131
|
+
}
|
|
132
|
+
async releaseHandle(handle) {
|
|
133
|
+
if (!handle._objectId)
|
|
134
|
+
return;
|
|
135
|
+
await this._session.send("script.disown", {
|
|
136
|
+
target: this._target,
|
|
137
|
+
handles: [handle._objectId]
|
|
138
|
+
});
|
|
139
|
+
}
|
|
140
|
+
async nodeIdForElementHandle(handle) {
|
|
141
|
+
const shared = await this._remoteValueForReference({ handle: handle._objectId });
|
|
142
|
+
if (!("sharedId" in shared))
|
|
143
|
+
throw new Error("Element is not a node");
|
|
144
|
+
return {
|
|
145
|
+
sharedId: shared.sharedId
|
|
146
|
+
};
|
|
147
|
+
}
|
|
148
|
+
async remoteObjectForNodeId(context, nodeId) {
|
|
149
|
+
const result = await this._remoteValueForReference(nodeId, true);
|
|
150
|
+
if (!("handle" in result))
|
|
151
|
+
throw new Error("Can't get remote object for nodeId");
|
|
152
|
+
return createHandle(context, result);
|
|
153
|
+
}
|
|
154
|
+
async contentFrameIdForFrame(handle) {
|
|
155
|
+
const contentWindow = await this._rawCallFunction("e => e.contentWindow", { handle: handle._objectId });
|
|
156
|
+
if (contentWindow?.type === "window")
|
|
157
|
+
return contentWindow.value.context;
|
|
158
|
+
return null;
|
|
159
|
+
}
|
|
160
|
+
async frameIdForWindowHandle(handle) {
|
|
161
|
+
if (!handle._objectId)
|
|
162
|
+
throw new Error("JSHandle is not a DOM node handle");
|
|
163
|
+
const contentWindow = await this._remoteValueForReference({ handle: handle._objectId });
|
|
164
|
+
if (contentWindow.type === "window")
|
|
165
|
+
return contentWindow.value.context;
|
|
166
|
+
return null;
|
|
167
|
+
}
|
|
168
|
+
async _remoteValueForReference(reference, createHandle2) {
|
|
169
|
+
return await this._rawCallFunction("e => e", reference, createHandle2);
|
|
170
|
+
}
|
|
171
|
+
async _rawCallFunction(functionDeclaration, arg, createHandle2) {
|
|
172
|
+
const response = await this._session.send("script.callFunction", {
|
|
173
|
+
functionDeclaration,
|
|
174
|
+
target: this._target,
|
|
175
|
+
arguments: [arg],
|
|
176
|
+
// "Root" is necessary for the handle to be returned.
|
|
177
|
+
resultOwnership: createHandle2 ? bidi.Script.ResultOwnership.Root : bidi.Script.ResultOwnership.None,
|
|
178
|
+
serializationOptions: { maxObjectDepth: 0, maxDomDepth: 0 },
|
|
179
|
+
awaitPromise: true,
|
|
180
|
+
userActivation: true
|
|
181
|
+
});
|
|
182
|
+
if (response.type === "exception")
|
|
183
|
+
throw new js.JavaScriptErrorInEvaluate(response.exceptionDetails.text);
|
|
184
|
+
if (response.type === "success")
|
|
185
|
+
return response.result;
|
|
186
|
+
throw new js.JavaScriptErrorInEvaluate("Unexpected response type: " + JSON.stringify(response));
|
|
187
|
+
}
|
|
188
|
+
}
|
|
189
|
+
function renderPreview(remoteObject) {
|
|
190
|
+
if (remoteObject.type === "undefined")
|
|
191
|
+
return "undefined";
|
|
192
|
+
if (remoteObject.type === "null")
|
|
193
|
+
return "null";
|
|
194
|
+
if ("value" in remoteObject)
|
|
195
|
+
return String(remoteObject.value);
|
|
196
|
+
return `<${remoteObject.type}>`;
|
|
197
|
+
}
|
|
198
|
+
function remoteObjectValue(remoteObject) {
|
|
199
|
+
if (remoteObject.type === "undefined")
|
|
200
|
+
return void 0;
|
|
201
|
+
if (remoteObject.type === "null")
|
|
202
|
+
return null;
|
|
203
|
+
if (remoteObject.type === "number" && typeof remoteObject.value === "string")
|
|
204
|
+
return js.parseUnserializableValue(remoteObject.value);
|
|
205
|
+
if ("value" in remoteObject)
|
|
206
|
+
return remoteObject.value;
|
|
207
|
+
return void 0;
|
|
208
|
+
}
|
|
209
|
+
function createHandle(context, remoteObject) {
|
|
210
|
+
if (remoteObject.type === "node") {
|
|
211
|
+
(0, import_utils.assert)(context instanceof dom.FrameExecutionContext);
|
|
212
|
+
return new dom.ElementHandle(context, remoteObject.handle);
|
|
213
|
+
}
|
|
214
|
+
const objectId = "handle" in remoteObject ? remoteObject.handle : void 0;
|
|
215
|
+
return new js.JSHandle(context, remoteObject.type, renderPreview(remoteObject), objectId, remoteObjectValue(remoteObject));
|
|
216
|
+
}
|
|
217
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
218
|
+
0 && (module.exports = {
|
|
219
|
+
BidiExecutionContext,
|
|
220
|
+
createHandle
|
|
221
|
+
});
|