patchright-core 1.58.2 → 1.59.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/ThirdPartyNotices.txt +126 -650
- package/browsers.json +16 -14
- package/lib/bootstrap.js +77 -0
- package/lib/cli/browserActions.js +308 -0
- package/lib/cli/driver.js +3 -2
- package/lib/cli/installActions.js +171 -0
- package/lib/cli/program.js +47 -411
- package/lib/client/android.js +4 -4
- package/lib/client/api.js +3 -3
- package/lib/client/browser.js +8 -0
- package/lib/client/browserContext.js +22 -61
- package/lib/client/browserType.js +19 -51
- package/lib/client/cdpSession.js +6 -2
- package/lib/client/channelOwner.js +1 -1
- package/lib/client/clientHelper.js +2 -1
- package/lib/client/clock.js +0 -1
- package/lib/client/{webSocket.js → connect.js} +57 -7
- package/lib/client/connection.js +8 -4
- package/lib/client/consoleMessage.js +3 -0
- package/lib/client/debugger.js +57 -0
- package/lib/client/dialog.js +8 -1
- package/lib/client/disposable.js +76 -0
- package/lib/client/electron.js +1 -0
- package/lib/client/elementHandle.js +1 -4
- package/lib/client/events.js +3 -3
- package/lib/client/fetch.js +0 -1
- package/lib/client/frame.js +10 -23
- package/lib/client/harRouter.js +13 -1
- package/lib/client/jsHandle.js +4 -8
- package/lib/client/locator.js +13 -44
- package/lib/client/network.js +15 -16
- package/lib/client/page.js +41 -75
- package/lib/client/platform.js +0 -3
- package/lib/client/screencast.js +88 -0
- package/lib/client/selectors.js +3 -1
- package/lib/client/tracing.js +11 -5
- package/lib/client/video.js +13 -20
- package/lib/client/worker.js +6 -6
- package/lib/generated/bindingsControllerSource.js +1 -1
- package/lib/generated/clockSource.js +1 -1
- package/lib/generated/injectedScriptSource.js +1 -1
- package/lib/generated/pollingRecorderSource.js +1 -1
- package/lib/generated/storageScriptSource.js +1 -1
- package/lib/generated/utilityScriptSource.js +1 -1
- package/lib/mcpBundle.js +0 -6
- package/lib/mcpBundleImpl.js +91 -0
- package/lib/protocol/validator.js +224 -138
- package/lib/protocol/validatorPrimitives.js +1 -1
- package/lib/remote/playwrightConnection.js +10 -8
- package/lib/remote/playwrightPipeServer.js +100 -0
- package/lib/remote/playwrightServer.js +13 -8
- package/lib/remote/playwrightWebSocketServer.js +73 -0
- package/lib/remote/serverTransport.js +96 -0
- package/lib/server/android/android.js +2 -2
- package/lib/server/bidi/bidiBrowser.js +30 -8
- package/lib/server/bidi/bidiChromium.js +18 -5
- package/lib/server/bidi/bidiNetworkManager.js +39 -11
- package/lib/server/bidi/bidiPage.js +31 -15
- package/lib/server/bidi/third_party/firefoxPrefs.js +3 -1
- package/lib/server/browser.js +84 -21
- package/lib/server/browserContext.js +110 -58
- package/lib/server/browserType.js +14 -12
- package/lib/server/chromium/chromium.js +15 -12
- package/lib/server/chromium/chromiumSwitches.js +14 -2
- package/lib/server/chromium/crBrowser.js +20 -17
- package/lib/server/chromium/crCoverage.js +1 -13
- package/lib/server/chromium/crDevTools.js +1 -0
- package/lib/server/chromium/crNetworkManager.js +12 -267
- package/lib/server/chromium/crPage.js +67 -199
- package/lib/server/chromium/crServiceWorker.js +7 -14
- package/lib/server/clock.js +33 -41
- package/lib/server/console.js +5 -1
- package/lib/server/debugController.js +12 -6
- package/lib/server/debugger.js +40 -47
- package/lib/server/deviceDescriptorsSource.json +137 -137
- package/lib/server/dispatchers/browserContextDispatcher.js +29 -30
- package/lib/server/dispatchers/browserDispatcher.js +11 -5
- package/lib/server/dispatchers/browserTypeDispatcher.js +7 -0
- package/lib/server/dispatchers/cdpSessionDispatcher.js +4 -1
- package/lib/server/dispatchers/debuggerDispatcher.js +84 -0
- package/lib/server/dispatchers/dispatcher.js +1 -1
- package/lib/server/dispatchers/disposableDispatcher.js +39 -0
- package/lib/server/dispatchers/electronDispatcher.js +2 -1
- package/lib/server/dispatchers/frameDispatcher.js +6 -6
- package/lib/server/dispatchers/jsHandleDispatcher.js +2 -2
- package/lib/server/dispatchers/localUtilsDispatcher.js +37 -1
- package/lib/server/dispatchers/networkDispatchers.js +6 -5
- package/lib/server/dispatchers/pageDispatcher.js +101 -38
- package/lib/server/dispatchers/webSocketRouteDispatcher.js +4 -5
- package/lib/server/disposable.js +41 -0
- package/lib/server/dom.js +44 -26
- package/lib/server/download.js +3 -2
- package/lib/server/electron/electron.js +12 -7
- package/lib/server/firefox/ffBrowser.js +9 -19
- package/lib/server/firefox/ffInput.js +21 -5
- package/lib/server/firefox/ffNetworkManager.js +2 -2
- package/lib/server/firefox/ffPage.js +24 -27
- package/lib/server/frameSelectors.js +5 -172
- package/lib/server/frames.js +234 -687
- package/lib/server/har/harRecorder.js +2 -2
- package/lib/server/har/harTracer.js +5 -4
- package/lib/server/input.js +49 -4
- package/lib/server/instrumentation.js +5 -0
- package/lib/server/javascript.js +6 -26
- package/lib/server/launchApp.js +1 -3
- package/lib/server/localUtils.js +6 -6
- package/lib/server/network.js +9 -8
- package/lib/server/overlay.js +138 -0
- package/lib/server/page.js +157 -105
- package/lib/server/progress.js +6 -0
- package/lib/server/recorder/recorderApp.js +9 -8
- package/lib/server/recorder.js +76 -40
- package/lib/server/registry/index.js +55 -82
- package/lib/server/registry/nativeDeps.js +1 -0
- package/lib/server/screencast.js +90 -143
- package/lib/server/screenshotter.js +0 -6
- package/lib/server/trace/recorder/snapshotter.js +8 -17
- package/lib/server/trace/recorder/snapshotterInjected.js +82 -20
- package/lib/server/trace/recorder/tracing.js +87 -44
- package/lib/server/trace/viewer/traceViewer.js +3 -4
- package/lib/server/usKeyboardLayout.js +7 -0
- package/lib/server/utils/comparators.js +1 -1
- package/lib/server/utils/disposable.js +32 -0
- package/lib/server/utils/eventsHelper.js +3 -1
- package/lib/server/utils/fileUtils.js +16 -2
- package/lib/server/utils/happyEyeballs.js +15 -12
- package/lib/server/utils/hostPlatform.js +0 -15
- package/lib/server/utils/httpServer.js +5 -3
- package/lib/server/utils/network.js +2 -1
- package/lib/server/utils/nodePlatform.js +0 -6
- package/lib/server/utils/processLauncher.js +6 -5
- package/lib/server/utils/zipFile.js +2 -2
- package/lib/server/videoRecorder.js +82 -12
- package/lib/server/webkit/wkBrowser.js +1 -6
- package/lib/server/webkit/wkPage.js +27 -25
- package/lib/server/webkit/wkWorkers.js +2 -1
- package/lib/serverRegistry.js +156 -0
- 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/tools/mcp/extensionContextFactory.js +55 -0
- 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/{server/trace/viewer/traceParser.js → tools/trace/installSkill.js} +15 -39
- 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/formatUtils.js +64 -0
- package/lib/utils/isomorphic/jsonSchema.js +89 -0
- package/lib/utils/isomorphic/mimeType.js +7 -2
- package/lib/utils/isomorphic/protocolFormatter.js +2 -2
- package/lib/utils/isomorphic/protocolMetainfo.js +127 -106
- package/lib/utils/isomorphic/stringUtils.js +3 -3
- package/lib/utils/isomorphic/timeoutRunner.js +3 -3
- package/lib/utils/isomorphic/trace/snapshotRenderer.js +35 -42
- package/lib/utils/isomorphic/trace/traceLoader.js +15 -14
- package/lib/utils/isomorphic/trace/traceModel.js +3 -2
- package/lib/utils/isomorphic/trace/traceModernizer.js +1 -0
- package/lib/utils/isomorphic/urlMatch.js +54 -1
- package/lib/utils/isomorphic/utilityScriptSerializers.js +11 -0
- package/lib/utils.js +6 -2
- package/lib/utilsBundle.js +3 -21
- package/lib/utilsBundleImpl/index.js +132 -133
- 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 +2 -70
- package/lib/vite/htmlReport/report.css +1 -0
- package/lib/vite/htmlReport/report.js +72 -0
- package/lib/vite/recorder/assets/{codeMirrorModule-CFUTFUO7.js → codeMirrorModule-C8KMvO9L.js} +20 -20
- package/lib/vite/recorder/assets/index-CqAYX1I3.js +193 -0
- package/lib/vite/recorder/index.html +1 -1
- package/lib/vite/traceViewer/assets/{codeMirrorModule-BVA4h_ZY.js → codeMirrorModule-DS0FLvoc.js} +20 -20
- package/lib/vite/traceViewer/assets/defaultSettingsView-GTWI-W_B.js +262 -0
- package/lib/vite/traceViewer/defaultSettingsView.B4dS75f0.css +1 -0
- package/lib/vite/traceViewer/{index.BtyWtaE-.js → index.C5466mMT.js} +1 -1
- package/lib/vite/traceViewer/{index.BVu7tZDe.css → index.CzXZzn5A.css} +1 -1
- package/lib/vite/traceViewer/index.html +4 -4
- package/lib/vite/traceViewer/sw.bundle.js +4 -4
- package/lib/vite/traceViewer/uiMode.Vipi55dB.js +6 -0
- package/lib/vite/traceViewer/uiMode.html +3 -3
- package/lib/zipBundleImpl.js +2 -2
- package/lib/zodBundle.js +39 -0
- package/lib/zodBundleImpl.js +40 -0
- package/package.json +6 -1
- package/types/protocol.d.ts +947 -51
- package/types/types.d.ts +854 -74
- 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/server/pageBinding.js +0 -87
- package/lib/utils/isomorphic/oldUtilityScriptSerializers.js +0 -248
- package/lib/vite/recorder/assets/index-CVkBxsGf.js +0 -193
- package/lib/vite/traceViewer/assets/defaultSettingsView-CjfmcdOz.js +0 -266
- package/lib/vite/traceViewer/defaultSettingsView.7ch9cixO.css +0 -1
- package/lib/vite/traceViewer/uiMode.fyrXARf2.js +0 -5
- /package/lib/{server/utils → utils/isomorphic}/imageUtils.js +0 -0
- /package/lib/utils/isomorphic/{traceUtils.js → trace/traceUtils.js} +0 -0
|
@@ -23,6 +23,20 @@ __export(ffInput_exports, {
|
|
|
23
23
|
RawTouchscreenImpl: () => RawTouchscreenImpl
|
|
24
24
|
});
|
|
25
25
|
module.exports = __toCommonJS(ffInput_exports);
|
|
26
|
+
const kFirefoxKeyOverrides = /* @__PURE__ */ new Map([
|
|
27
|
+
["AudioVolumeMute", { code: "VolumeMute", keyCodeWithoutLocation: 181 }],
|
|
28
|
+
["AudioVolumeDown", { code: "VolumeDown", keyCodeWithoutLocation: 182 }],
|
|
29
|
+
["AudioVolumeUp", { code: "VolumeUp", keyCodeWithoutLocation: 183 }]
|
|
30
|
+
]);
|
|
31
|
+
function toFirefoxKeyDescription(description) {
|
|
32
|
+
const override = kFirefoxKeyOverrides.get(description.key);
|
|
33
|
+
if (!override)
|
|
34
|
+
return description;
|
|
35
|
+
return {
|
|
36
|
+
...description,
|
|
37
|
+
...override
|
|
38
|
+
};
|
|
39
|
+
}
|
|
26
40
|
function toModifiersMask(modifiers) {
|
|
27
41
|
let mask = 0;
|
|
28
42
|
if (modifiers.has("Alt"))
|
|
@@ -59,13 +73,14 @@ class RawKeyboardImpl {
|
|
|
59
73
|
this._client = client;
|
|
60
74
|
}
|
|
61
75
|
async keydown(progress, modifiers, keyName, description, autoRepeat) {
|
|
62
|
-
|
|
76
|
+
const keyDescription = toFirefoxKeyDescription(description);
|
|
77
|
+
let text = keyDescription.text;
|
|
63
78
|
if (text === "\r")
|
|
64
79
|
text = "";
|
|
65
|
-
const { code, key, location } =
|
|
80
|
+
const { code, key, location } = keyDescription;
|
|
66
81
|
await progress.race(this._client.send("Page.dispatchKeyEvent", {
|
|
67
82
|
type: "keydown",
|
|
68
|
-
keyCode:
|
|
83
|
+
keyCode: keyDescription.keyCodeWithoutLocation,
|
|
69
84
|
code,
|
|
70
85
|
key,
|
|
71
86
|
repeat: autoRepeat,
|
|
@@ -74,11 +89,12 @@ class RawKeyboardImpl {
|
|
|
74
89
|
}));
|
|
75
90
|
}
|
|
76
91
|
async keyup(progress, modifiers, keyName, description) {
|
|
77
|
-
const
|
|
92
|
+
const keyDescription = toFirefoxKeyDescription(description);
|
|
93
|
+
const { code, key, location } = keyDescription;
|
|
78
94
|
await progress.race(this._client.send("Page.dispatchKeyEvent", {
|
|
79
95
|
type: "keyup",
|
|
80
96
|
key,
|
|
81
|
-
keyCode:
|
|
97
|
+
keyCode: keyDescription.keyCodeWithoutLocation,
|
|
82
98
|
code,
|
|
83
99
|
location,
|
|
84
100
|
repeat: false
|
|
@@ -133,8 +133,7 @@ class FFNetworkManager {
|
|
|
133
133
|
this._requests.delete(request._id);
|
|
134
134
|
response._requestFinished(responseEndTime);
|
|
135
135
|
}
|
|
136
|
-
|
|
137
|
-
response._setHttpVersion(event.protocolVersion);
|
|
136
|
+
response._setHttpVersion(event.protocolVersion ?? null);
|
|
138
137
|
this._page.frameManager.reportRequestFinished(request.request, response);
|
|
139
138
|
}
|
|
140
139
|
_onRequestFailed(event) {
|
|
@@ -147,6 +146,7 @@ class FFNetworkManager {
|
|
|
147
146
|
response.setTransferSize(null);
|
|
148
147
|
response.setEncodedBodySize(null);
|
|
149
148
|
response._requestFinished(-1);
|
|
149
|
+
response._setHttpVersion(null);
|
|
150
150
|
}
|
|
151
151
|
request.request._setFailureText(event.errorCode);
|
|
152
152
|
this._page.frameManager.requestFailed(request.request, event.errorCode === "NS_BINDING_ABORTED");
|
|
@@ -43,7 +43,7 @@ var import_ffInput = require("./ffInput");
|
|
|
43
43
|
var import_ffNetworkManager = require("./ffNetworkManager");
|
|
44
44
|
var import_stackTrace = require("../../utils/isomorphic/stackTrace");
|
|
45
45
|
var import_errors = require("../errors");
|
|
46
|
-
var
|
|
46
|
+
var import_videoRecorder = require("../videoRecorder");
|
|
47
47
|
const UTILITY_WORLD_NAME = "__playwright_utility_world__";
|
|
48
48
|
class FFPage {
|
|
49
49
|
constructor(session, browserContext, opener) {
|
|
@@ -89,19 +89,14 @@ class FFPage {
|
|
|
89
89
|
import_eventsHelper.eventsHelper.addEventListener(this._session, "Page.webSocketFrameSent", this._onWebSocketFrameSent.bind(this)),
|
|
90
90
|
import_eventsHelper.eventsHelper.addEventListener(this._session, "Page.screencastFrame", this._onScreencastFrame.bind(this))
|
|
91
91
|
];
|
|
92
|
-
const
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
this._page.reportAsNew(this._opener?._page);
|
|
101
|
-
});
|
|
102
|
-
this.addInitScript(new import_page.InitScript(""), UTILITY_WORLD_NAME).catch((e) => this._markAsError(e));
|
|
103
|
-
}
|
|
104
|
-
async _markAsError(error) {
|
|
92
|
+
const promises = [];
|
|
93
|
+
if (!this._page.isStorageStatePage)
|
|
94
|
+
(0, import_videoRecorder.startAutomaticVideoRecording)(this._page);
|
|
95
|
+
promises.push(new Promise((f) => this._session.once("Page.ready", f)));
|
|
96
|
+
Promise.all(promises).then(() => this._reportAsNew(), (error) => this._reportAsNew(error));
|
|
97
|
+
this.addInitScript(new import_page.InitScript(this._page, ""), UTILITY_WORLD_NAME).catch((e) => this._reportAsNew(e));
|
|
98
|
+
}
|
|
99
|
+
_reportAsNew(error) {
|
|
105
100
|
if (this._reportedAsNew)
|
|
106
101
|
return;
|
|
107
102
|
this._reportedAsNew = true;
|
|
@@ -203,7 +198,8 @@ class FFPage {
|
|
|
203
198
|
const context = this._contextIdToContext.get(executionContextId);
|
|
204
199
|
if (!context)
|
|
205
200
|
return;
|
|
206
|
-
|
|
201
|
+
const timestamp = Date.now();
|
|
202
|
+
this._page.addConsoleMessage(null, type === "warn" ? "warning" : type, args.map((arg) => (0, import_ffExecutionContext.createHandle)(context, arg)), location, void 0, timestamp);
|
|
207
203
|
}
|
|
208
204
|
_onDialogOpened(params) {
|
|
209
205
|
this._page.browserContext.dialogManager.dialogDidOpen(new dialog.Dialog(
|
|
@@ -253,7 +249,7 @@ class FFPage {
|
|
|
253
249
|
workerSession.on("Runtime.console", (event2) => {
|
|
254
250
|
const { type, args, location } = event2;
|
|
255
251
|
const context = worker.existingExecutionContext;
|
|
256
|
-
this._page.addConsoleMessage(worker, type, args.map((arg) => (0, import_ffExecutionContext.createHandle)(context, arg)), location);
|
|
252
|
+
this._page.addConsoleMessage(worker, type, args.map((arg) => (0, import_ffExecutionContext.createHandle)(context, arg)), location, void 0, Date.now());
|
|
257
253
|
});
|
|
258
254
|
}
|
|
259
255
|
_onWorkerDestroyed(event) {
|
|
@@ -276,7 +272,7 @@ class FFPage {
|
|
|
276
272
|
this._page._didCrash();
|
|
277
273
|
}
|
|
278
274
|
didClose() {
|
|
279
|
-
this.
|
|
275
|
+
this._reportAsNew(new import_errors.TargetClosedError(this._page.closeReason()));
|
|
280
276
|
this._session.dispose();
|
|
281
277
|
import_eventsHelper.eventsHelper.removeEventListeners(this._eventListeners);
|
|
282
278
|
this._networkManager.dispose();
|
|
@@ -417,23 +413,22 @@ class FFPage {
|
|
|
417
413
|
throw e;
|
|
418
414
|
});
|
|
419
415
|
}
|
|
420
|
-
|
|
421
|
-
|
|
416
|
+
startScreencast(options) {
|
|
417
|
+
this._session.sendMayFail("Page.startScreencast", { width: options.width, height: options.height, quality: options.quality });
|
|
422
418
|
}
|
|
423
|
-
|
|
424
|
-
|
|
419
|
+
stopScreencast() {
|
|
420
|
+
this._session.sendMayFail("Page.stopScreencast");
|
|
425
421
|
}
|
|
426
422
|
_onScreencastFrame(event) {
|
|
427
|
-
this._page.screencast.throttleFrameAck(() => {
|
|
428
|
-
this._session.sendMayFail("Page.screencastFrameAck");
|
|
429
|
-
});
|
|
430
423
|
const buffer = Buffer.from(event.data, "base64");
|
|
431
|
-
this._page.
|
|
424
|
+
this._page.screencast.onScreencastFrame({
|
|
432
425
|
buffer,
|
|
433
426
|
frameSwapWallTime: event.timestamp * 1e3,
|
|
434
427
|
// timestamp is in seconds, we need to convert to milliseconds.
|
|
435
|
-
|
|
436
|
-
|
|
428
|
+
viewportWidth: event.deviceWidth,
|
|
429
|
+
viewportHeight: event.deviceHeight
|
|
430
|
+
}, () => {
|
|
431
|
+
this._session.sendMayFail("Page.screencastFrameAck");
|
|
437
432
|
});
|
|
438
433
|
}
|
|
439
434
|
rafCountForStablePosition() {
|
|
@@ -486,6 +481,8 @@ class FFPage {
|
|
|
486
481
|
shouldToggleStyleSheetToSyncAnimations() {
|
|
487
482
|
return false;
|
|
488
483
|
}
|
|
484
|
+
async setDockTile(image) {
|
|
485
|
+
}
|
|
489
486
|
}
|
|
490
487
|
function webSocketId(frameId, wsid) {
|
|
491
488
|
return `${frameId}---${wsid}`;
|
|
@@ -21,7 +21,6 @@ __export(frameSelectors_exports, {
|
|
|
21
21
|
FrameSelectors: () => FrameSelectors
|
|
22
22
|
});
|
|
23
23
|
module.exports = __toCommonJS(frameSelectors_exports);
|
|
24
|
-
var import_dom = require("./dom");
|
|
25
24
|
var import_utils = require("../utils");
|
|
26
25
|
var import_selectorParser = require("../utils/isomorphic/selectorParser");
|
|
27
26
|
class FrameSelectors {
|
|
@@ -46,8 +45,8 @@ class FrameSelectors {
|
|
|
46
45
|
}
|
|
47
46
|
return adoptIfNeeded(elementHandle, await resolved.frame._mainContext());
|
|
48
47
|
}
|
|
49
|
-
async queryArrayInMainWorld(selector, scope
|
|
50
|
-
const resolved = await this.resolveInjectedForSelector(selector, { mainWorld:
|
|
48
|
+
async queryArrayInMainWorld(selector, scope) {
|
|
49
|
+
const resolved = await this.resolveInjectedForSelector(selector, { mainWorld: true }, scope);
|
|
51
50
|
if (!resolved)
|
|
52
51
|
throw new Error(`Failed to find frame for selector "${selector}"`);
|
|
53
52
|
return await resolved.injected.evaluateHandle((injected, { info, scope: scope2 }) => {
|
|
@@ -124,29 +123,9 @@ class FrameSelectors {
|
|
|
124
123
|
throw injected.createStacklessError(`Selector "${selectorString}" resolved to ${injected.previewNode(element2)}, <iframe> was expected`);
|
|
125
124
|
return element2;
|
|
126
125
|
}, { info, scope: i === 0 ? scope : void 0, selectorString: (0, import_selectorParser.stringifySelector)(info.parsed) });
|
|
127
|
-
|
|
128
|
-
if (!element)
|
|
129
|
-
|
|
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
|
-
}
|
|
126
|
+
const element = handle.asElement();
|
|
127
|
+
if (!element)
|
|
128
|
+
return null;
|
|
150
129
|
const maybeFrame = await frame._page.delegate.getContentFrame(element);
|
|
151
130
|
element.dispose();
|
|
152
131
|
if (!maybeFrame)
|
|
@@ -164,155 +143,9 @@ class FrameSelectors {
|
|
|
164
143
|
if (!resolved)
|
|
165
144
|
return;
|
|
166
145
|
const context = await resolved.frame._context(options?.mainWorld ? "main" : resolved.info.world);
|
|
167
|
-
if (!context) throw new Error("Frame was detached");
|
|
168
146
|
const injected = await context.injectedScript();
|
|
169
147
|
return { injected, info: resolved.info, frame: resolved.frame, scope: resolved.scope };
|
|
170
148
|
}
|
|
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
|
-
for (const shadowChild of shadowRoot.children || []) {
|
|
308
|
-
const shadowChildIndex = (shadowRoot.children || []).indexOf(shadowChild);
|
|
309
|
-
const childIndex = this._findElementPositionInDomTree(element, shadowChild, documentScope, currentIndex + "." + shadowChildIndex.toString());
|
|
310
|
-
if (childIndex !== null) return childIndex;
|
|
311
|
-
}
|
|
312
|
-
}
|
|
313
|
-
}
|
|
314
|
-
return null;
|
|
315
|
-
}
|
|
316
149
|
}
|
|
317
150
|
async function adoptIfNeeded(handle, context) {
|
|
318
151
|
if (handle._context === context)
|