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.
Files changed (285) hide show
  1. package/ThirdPartyNotices.txt +126 -650
  2. package/browsers.json +16 -14
  3. package/lib/bootstrap.js +77 -0
  4. package/lib/cli/browserActions.js +308 -0
  5. package/lib/cli/driver.js +3 -2
  6. package/lib/cli/installActions.js +171 -0
  7. package/lib/cli/program.js +47 -411
  8. package/lib/client/android.js +4 -4
  9. package/lib/client/api.js +3 -3
  10. package/lib/client/browser.js +8 -0
  11. package/lib/client/browserContext.js +22 -61
  12. package/lib/client/browserType.js +19 -51
  13. package/lib/client/cdpSession.js +6 -2
  14. package/lib/client/channelOwner.js +1 -1
  15. package/lib/client/clientHelper.js +2 -1
  16. package/lib/client/clock.js +0 -1
  17. package/lib/client/{webSocket.js → connect.js} +57 -7
  18. package/lib/client/connection.js +8 -4
  19. package/lib/client/consoleMessage.js +3 -0
  20. package/lib/client/debugger.js +57 -0
  21. package/lib/client/dialog.js +8 -1
  22. package/lib/client/disposable.js +76 -0
  23. package/lib/client/electron.js +1 -0
  24. package/lib/client/elementHandle.js +1 -4
  25. package/lib/client/events.js +3 -3
  26. package/lib/client/fetch.js +0 -1
  27. package/lib/client/frame.js +10 -23
  28. package/lib/client/harRouter.js +13 -1
  29. package/lib/client/jsHandle.js +4 -8
  30. package/lib/client/locator.js +13 -44
  31. package/lib/client/network.js +15 -16
  32. package/lib/client/page.js +41 -75
  33. package/lib/client/platform.js +0 -3
  34. package/lib/client/screencast.js +88 -0
  35. package/lib/client/selectors.js +3 -1
  36. package/lib/client/tracing.js +11 -5
  37. package/lib/client/video.js +13 -20
  38. package/lib/client/worker.js +6 -6
  39. package/lib/generated/bindingsControllerSource.js +1 -1
  40. package/lib/generated/clockSource.js +1 -1
  41. package/lib/generated/injectedScriptSource.js +1 -1
  42. package/lib/generated/pollingRecorderSource.js +1 -1
  43. package/lib/generated/storageScriptSource.js +1 -1
  44. package/lib/generated/utilityScriptSource.js +1 -1
  45. package/lib/mcpBundle.js +0 -6
  46. package/lib/mcpBundleImpl.js +91 -0
  47. package/lib/protocol/validator.js +224 -138
  48. package/lib/protocol/validatorPrimitives.js +1 -1
  49. package/lib/remote/playwrightConnection.js +10 -8
  50. package/lib/remote/playwrightPipeServer.js +100 -0
  51. package/lib/remote/playwrightServer.js +13 -8
  52. package/lib/remote/playwrightWebSocketServer.js +73 -0
  53. package/lib/remote/serverTransport.js +96 -0
  54. package/lib/server/android/android.js +2 -2
  55. package/lib/server/bidi/bidiBrowser.js +30 -8
  56. package/lib/server/bidi/bidiChromium.js +18 -5
  57. package/lib/server/bidi/bidiNetworkManager.js +39 -11
  58. package/lib/server/bidi/bidiPage.js +31 -15
  59. package/lib/server/bidi/third_party/firefoxPrefs.js +3 -1
  60. package/lib/server/browser.js +84 -21
  61. package/lib/server/browserContext.js +110 -58
  62. package/lib/server/browserType.js +14 -12
  63. package/lib/server/chromium/chromium.js +15 -12
  64. package/lib/server/chromium/chromiumSwitches.js +14 -2
  65. package/lib/server/chromium/crBrowser.js +20 -17
  66. package/lib/server/chromium/crCoverage.js +1 -13
  67. package/lib/server/chromium/crDevTools.js +1 -0
  68. package/lib/server/chromium/crNetworkManager.js +12 -267
  69. package/lib/server/chromium/crPage.js +67 -199
  70. package/lib/server/chromium/crServiceWorker.js +7 -14
  71. package/lib/server/clock.js +33 -41
  72. package/lib/server/console.js +5 -1
  73. package/lib/server/debugController.js +12 -6
  74. package/lib/server/debugger.js +40 -47
  75. package/lib/server/deviceDescriptorsSource.json +137 -137
  76. package/lib/server/dispatchers/browserContextDispatcher.js +29 -30
  77. package/lib/server/dispatchers/browserDispatcher.js +11 -5
  78. package/lib/server/dispatchers/browserTypeDispatcher.js +7 -0
  79. package/lib/server/dispatchers/cdpSessionDispatcher.js +4 -1
  80. package/lib/server/dispatchers/debuggerDispatcher.js +84 -0
  81. package/lib/server/dispatchers/dispatcher.js +1 -1
  82. package/lib/server/dispatchers/disposableDispatcher.js +39 -0
  83. package/lib/server/dispatchers/electronDispatcher.js +2 -1
  84. package/lib/server/dispatchers/frameDispatcher.js +6 -6
  85. package/lib/server/dispatchers/jsHandleDispatcher.js +2 -2
  86. package/lib/server/dispatchers/localUtilsDispatcher.js +37 -1
  87. package/lib/server/dispatchers/networkDispatchers.js +6 -5
  88. package/lib/server/dispatchers/pageDispatcher.js +101 -38
  89. package/lib/server/dispatchers/webSocketRouteDispatcher.js +4 -5
  90. package/lib/server/disposable.js +41 -0
  91. package/lib/server/dom.js +44 -26
  92. package/lib/server/download.js +3 -2
  93. package/lib/server/electron/electron.js +12 -7
  94. package/lib/server/firefox/ffBrowser.js +9 -19
  95. package/lib/server/firefox/ffInput.js +21 -5
  96. package/lib/server/firefox/ffNetworkManager.js +2 -2
  97. package/lib/server/firefox/ffPage.js +24 -27
  98. package/lib/server/frameSelectors.js +5 -172
  99. package/lib/server/frames.js +234 -687
  100. package/lib/server/har/harRecorder.js +2 -2
  101. package/lib/server/har/harTracer.js +5 -4
  102. package/lib/server/input.js +49 -4
  103. package/lib/server/instrumentation.js +5 -0
  104. package/lib/server/javascript.js +6 -26
  105. package/lib/server/launchApp.js +1 -3
  106. package/lib/server/localUtils.js +6 -6
  107. package/lib/server/network.js +9 -8
  108. package/lib/server/overlay.js +138 -0
  109. package/lib/server/page.js +157 -105
  110. package/lib/server/progress.js +6 -0
  111. package/lib/server/recorder/recorderApp.js +9 -8
  112. package/lib/server/recorder.js +76 -40
  113. package/lib/server/registry/index.js +55 -82
  114. package/lib/server/registry/nativeDeps.js +1 -0
  115. package/lib/server/screencast.js +90 -143
  116. package/lib/server/screenshotter.js +0 -6
  117. package/lib/server/trace/recorder/snapshotter.js +8 -17
  118. package/lib/server/trace/recorder/snapshotterInjected.js +82 -20
  119. package/lib/server/trace/recorder/tracing.js +87 -44
  120. package/lib/server/trace/viewer/traceViewer.js +3 -4
  121. package/lib/server/usKeyboardLayout.js +7 -0
  122. package/lib/server/utils/comparators.js +1 -1
  123. package/lib/server/utils/disposable.js +32 -0
  124. package/lib/server/utils/eventsHelper.js +3 -1
  125. package/lib/server/utils/fileUtils.js +16 -2
  126. package/lib/server/utils/happyEyeballs.js +15 -12
  127. package/lib/server/utils/hostPlatform.js +0 -15
  128. package/lib/server/utils/httpServer.js +5 -3
  129. package/lib/server/utils/network.js +2 -1
  130. package/lib/server/utils/nodePlatform.js +0 -6
  131. package/lib/server/utils/processLauncher.js +6 -5
  132. package/lib/server/utils/zipFile.js +2 -2
  133. package/lib/server/videoRecorder.js +82 -12
  134. package/lib/server/webkit/wkBrowser.js +1 -6
  135. package/lib/server/webkit/wkPage.js +27 -25
  136. package/lib/server/webkit/wkWorkers.js +2 -1
  137. package/lib/serverRegistry.js +156 -0
  138. package/lib/tools/backend/browserBackend.js +79 -0
  139. package/lib/tools/backend/common.js +63 -0
  140. package/lib/tools/backend/config.js +41 -0
  141. package/lib/tools/backend/console.js +66 -0
  142. package/lib/tools/backend/context.js +296 -0
  143. package/lib/tools/backend/cookies.js +152 -0
  144. package/lib/tools/backend/devtools.js +69 -0
  145. package/lib/tools/backend/dialogs.js +59 -0
  146. package/lib/tools/backend/evaluate.js +64 -0
  147. package/lib/tools/backend/files.js +60 -0
  148. package/lib/tools/backend/form.js +64 -0
  149. package/lib/tools/backend/keyboard.js +155 -0
  150. package/lib/tools/backend/logFile.js +95 -0
  151. package/lib/tools/backend/mouse.js +168 -0
  152. package/lib/tools/backend/navigate.js +106 -0
  153. package/lib/tools/backend/network.js +135 -0
  154. package/lib/tools/backend/pdf.js +48 -0
  155. package/lib/tools/backend/response.js +305 -0
  156. package/lib/tools/backend/route.js +140 -0
  157. package/lib/tools/backend/runCode.js +77 -0
  158. package/lib/tools/backend/screenshot.js +88 -0
  159. package/lib/tools/backend/sessionLog.js +74 -0
  160. package/lib/tools/backend/snapshot.js +208 -0
  161. package/lib/tools/backend/storage.js +68 -0
  162. package/lib/tools/backend/tab.js +445 -0
  163. package/lib/tools/backend/tabs.js +67 -0
  164. package/lib/tools/backend/tool.js +47 -0
  165. package/lib/tools/backend/tools.js +102 -0
  166. package/lib/tools/backend/tracing.js +78 -0
  167. package/lib/tools/backend/utils.js +83 -0
  168. package/lib/tools/backend/verify.js +151 -0
  169. package/lib/tools/backend/video.js +98 -0
  170. package/lib/tools/backend/wait.js +63 -0
  171. package/lib/tools/backend/webstorage.js +223 -0
  172. package/lib/tools/cli-client/cli.js +6 -0
  173. package/lib/tools/cli-client/help.json +399 -0
  174. package/lib/tools/cli-client/minimist.js +128 -0
  175. package/lib/tools/cli-client/program.js +350 -0
  176. package/lib/tools/cli-client/registry.js +176 -0
  177. package/lib/tools/cli-client/session.js +289 -0
  178. package/lib/tools/cli-client/skill/SKILL.md +328 -0
  179. package/lib/tools/cli-client/skill/references/element-attributes.md +23 -0
  180. package/lib/tools/cli-client/skill/references/playwright-tests.md +39 -0
  181. package/lib/tools/cli-client/skill/references/request-mocking.md +87 -0
  182. package/lib/tools/cli-client/skill/references/running-code.md +231 -0
  183. package/lib/tools/cli-client/skill/references/session-management.md +169 -0
  184. package/lib/tools/cli-client/skill/references/storage-state.md +275 -0
  185. package/lib/tools/cli-client/skill/references/test-generation.md +88 -0
  186. package/lib/tools/cli-client/skill/references/tracing.md +139 -0
  187. package/lib/tools/cli-client/skill/references/video-recording.md +143 -0
  188. package/lib/tools/cli-daemon/command.js +73 -0
  189. package/lib/tools/cli-daemon/commands.js +956 -0
  190. package/lib/tools/cli-daemon/daemon.js +157 -0
  191. package/lib/tools/cli-daemon/helpGenerator.js +177 -0
  192. package/lib/tools/cli-daemon/program.js +129 -0
  193. package/lib/tools/dashboard/appIcon.png +0 -0
  194. package/lib/tools/dashboard/dashboardApp.js +284 -0
  195. package/lib/tools/dashboard/dashboardController.js +296 -0
  196. package/lib/tools/exports.js +60 -0
  197. package/lib/tools/mcp/browserFactory.js +233 -0
  198. package/lib/tools/mcp/cdpRelay.js +352 -0
  199. package/lib/tools/mcp/cli-stub.js +7 -0
  200. package/lib/tools/mcp/config.d.js +16 -0
  201. package/lib/tools/mcp/config.js +446 -0
  202. package/lib/tools/mcp/configIni.js +189 -0
  203. package/lib/tools/mcp/extensionContextFactory.js +55 -0
  204. package/lib/tools/mcp/index.js +62 -0
  205. package/lib/tools/mcp/log.js +35 -0
  206. package/lib/tools/mcp/program.js +107 -0
  207. package/lib/tools/mcp/protocol.js +28 -0
  208. package/lib/tools/mcp/watchdog.js +44 -0
  209. package/lib/tools/trace/SKILL.md +171 -0
  210. package/lib/{server/trace/viewer/traceParser.js → tools/trace/installSkill.js} +15 -39
  211. package/lib/tools/trace/traceActions.js +142 -0
  212. package/lib/tools/trace/traceAttachments.js +69 -0
  213. package/lib/tools/trace/traceCli.js +87 -0
  214. package/lib/tools/trace/traceConsole.js +97 -0
  215. package/lib/tools/trace/traceErrors.js +55 -0
  216. package/lib/tools/trace/traceOpen.js +69 -0
  217. package/lib/tools/trace/traceParser.js +96 -0
  218. package/lib/tools/trace/traceRequests.js +182 -0
  219. package/lib/tools/trace/traceScreenshot.js +68 -0
  220. package/lib/tools/trace/traceSnapshot.js +149 -0
  221. package/lib/tools/trace/traceUtils.js +153 -0
  222. package/lib/tools/utils/connect.js +32 -0
  223. package/lib/tools/utils/mcp/http.js +152 -0
  224. package/lib/tools/utils/mcp/server.js +230 -0
  225. package/lib/tools/utils/mcp/tool.js +47 -0
  226. package/lib/tools/utils/socketConnection.js +108 -0
  227. package/lib/utils/isomorphic/formatUtils.js +64 -0
  228. package/lib/utils/isomorphic/jsonSchema.js +89 -0
  229. package/lib/utils/isomorphic/mimeType.js +7 -2
  230. package/lib/utils/isomorphic/protocolFormatter.js +2 -2
  231. package/lib/utils/isomorphic/protocolMetainfo.js +127 -106
  232. package/lib/utils/isomorphic/stringUtils.js +3 -3
  233. package/lib/utils/isomorphic/timeoutRunner.js +3 -3
  234. package/lib/utils/isomorphic/trace/snapshotRenderer.js +35 -42
  235. package/lib/utils/isomorphic/trace/traceLoader.js +15 -14
  236. package/lib/utils/isomorphic/trace/traceModel.js +3 -2
  237. package/lib/utils/isomorphic/trace/traceModernizer.js +1 -0
  238. package/lib/utils/isomorphic/urlMatch.js +54 -1
  239. package/lib/utils/isomorphic/utilityScriptSerializers.js +11 -0
  240. package/lib/utils.js +6 -2
  241. package/lib/utilsBundle.js +3 -21
  242. package/lib/utilsBundleImpl/index.js +132 -133
  243. package/lib/vite/dashboard/assets/index-BAOybkp8.js +50 -0
  244. package/lib/vite/dashboard/assets/index-CZAYOG76.css +1 -0
  245. package/lib/vite/dashboard/index.html +28 -0
  246. package/lib/vite/htmlReport/index.html +2 -70
  247. package/lib/vite/htmlReport/report.css +1 -0
  248. package/lib/vite/htmlReport/report.js +72 -0
  249. package/lib/vite/recorder/assets/{codeMirrorModule-CFUTFUO7.js → codeMirrorModule-C8KMvO9L.js} +20 -20
  250. package/lib/vite/recorder/assets/index-CqAYX1I3.js +193 -0
  251. package/lib/vite/recorder/index.html +1 -1
  252. package/lib/vite/traceViewer/assets/{codeMirrorModule-BVA4h_ZY.js → codeMirrorModule-DS0FLvoc.js} +20 -20
  253. package/lib/vite/traceViewer/assets/defaultSettingsView-GTWI-W_B.js +262 -0
  254. package/lib/vite/traceViewer/defaultSettingsView.B4dS75f0.css +1 -0
  255. package/lib/vite/traceViewer/{index.BtyWtaE-.js → index.C5466mMT.js} +1 -1
  256. package/lib/vite/traceViewer/{index.BVu7tZDe.css → index.CzXZzn5A.css} +1 -1
  257. package/lib/vite/traceViewer/index.html +4 -4
  258. package/lib/vite/traceViewer/sw.bundle.js +4 -4
  259. package/lib/vite/traceViewer/uiMode.Vipi55dB.js +6 -0
  260. package/lib/vite/traceViewer/uiMode.html +3 -3
  261. package/lib/zipBundleImpl.js +2 -2
  262. package/lib/zodBundle.js +39 -0
  263. package/lib/zodBundleImpl.js +40 -0
  264. package/package.json +6 -1
  265. package/types/protocol.d.ts +947 -51
  266. package/types/types.d.ts +854 -74
  267. package/lib/client/pageAgent.js +0 -64
  268. package/lib/mcpBundleImpl/index.js +0 -147
  269. package/lib/server/agent/actionRunner.js +0 -335
  270. package/lib/server/agent/actions.js +0 -128
  271. package/lib/server/agent/codegen.js +0 -111
  272. package/lib/server/agent/context.js +0 -150
  273. package/lib/server/agent/expectTools.js +0 -156
  274. package/lib/server/agent/pageAgent.js +0 -204
  275. package/lib/server/agent/performTools.js +0 -262
  276. package/lib/server/agent/tool.js +0 -109
  277. package/lib/server/dispatchers/pageAgentDispatcher.js +0 -96
  278. package/lib/server/pageBinding.js +0 -87
  279. package/lib/utils/isomorphic/oldUtilityScriptSerializers.js +0 -248
  280. package/lib/vite/recorder/assets/index-CVkBxsGf.js +0 -193
  281. package/lib/vite/traceViewer/assets/defaultSettingsView-CjfmcdOz.js +0 -266
  282. package/lib/vite/traceViewer/defaultSettingsView.7ch9cixO.css +0 -1
  283. package/lib/vite/traceViewer/uiMode.fyrXARf2.js +0 -5
  284. /package/lib/{server/utils → utils/isomorphic}/imageUtils.js +0 -0
  285. /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
- let text = description.text;
76
+ const keyDescription = toFirefoxKeyDescription(description);
77
+ let text = keyDescription.text;
63
78
  if (text === "\r")
64
79
  text = "";
65
- const { code, key, location } = description;
80
+ const { code, key, location } = keyDescription;
66
81
  await progress.race(this._client.send("Page.dispatchKeyEvent", {
67
82
  type: "keydown",
68
- keyCode: description.keyCodeWithoutLocation,
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 { code, key, location } = description;
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: description.keyCodeWithoutLocation,
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
- if (event.protocolVersion)
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 import_debugLogger = require("../utils/debugLogger");
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 screencast = this._page.screencast;
93
- const videoOptions = screencast.launchVideoRecorder();
94
- if (videoOptions)
95
- screencast.startVideoRecording(videoOptions).catch((e) => import_debugLogger.debugLogger.log("error", e));
96
- this._session.once("Page.ready", () => {
97
- if (this._reportedAsNew)
98
- return;
99
- this._reportedAsNew = true;
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
- this._page.addConsoleMessage(null, type === "warn" ? "warning" : type, args.map((arg) => (0, import_ffExecutionContext.createHandle)(context, arg)), location);
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._markAsError(new import_errors.TargetClosedError(this._page.closeReason()));
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
- async startScreencast(options) {
421
- await this._session.send("Page.startScreencast", options);
416
+ startScreencast(options) {
417
+ this._session.sendMayFail("Page.startScreencast", { width: options.width, height: options.height, quality: options.quality });
422
418
  }
423
- async stopScreencast() {
424
- await this._session.sendMayFail("Page.stopScreencast");
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.emit(import_page2.Page.Events.ScreencastFrame, {
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
- width: event.deviceWidth,
436
- height: event.deviceHeight
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, isolatedContext) {
50
- const resolved = await this.resolveInjectedForSelector(selector, { mainWorld: !isolatedContext }, scope);
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
- 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
- }
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)