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
@@ -0,0 +1,78 @@
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 tracing_exports = {};
20
+ __export(tracing_exports, {
21
+ default: () => tracing_default
22
+ });
23
+ module.exports = __toCommonJS(tracing_exports);
24
+ var import_zodBundle = require("../../zodBundle");
25
+ var import_tool = require("./tool");
26
+ const tracingStart = (0, import_tool.defineTool)({
27
+ capability: "devtools",
28
+ schema: {
29
+ name: "browser_start_tracing",
30
+ title: "Start tracing",
31
+ description: "Start trace recording",
32
+ inputSchema: import_zodBundle.z.object({}),
33
+ type: "readOnly"
34
+ },
35
+ handle: async (context, params, response) => {
36
+ const browserContext = await context.ensureBrowserContext();
37
+ const tracesDir = await context.outputFile({ prefix: "", suggestedFilename: `traces`, ext: "" }, { origin: "code" });
38
+ const name = "trace-" + Date.now();
39
+ await browserContext.tracing.start({
40
+ name,
41
+ screenshots: true,
42
+ snapshots: true,
43
+ live: true
44
+ });
45
+ response.addTextResult(`Trace recording started`);
46
+ response.addFileLink("Action log", `${tracesDir}/${name}.trace`);
47
+ response.addFileLink("Network log", `${tracesDir}/${name}.network`);
48
+ response.addFileLink("Resources", `${tracesDir}/resources`);
49
+ browserContext.tracing[traceLegendSymbol] = { tracesDir, name };
50
+ }
51
+ });
52
+ const tracingStop = (0, import_tool.defineTool)({
53
+ capability: "devtools",
54
+ schema: {
55
+ name: "browser_stop_tracing",
56
+ title: "Stop tracing",
57
+ description: "Stop trace recording",
58
+ inputSchema: import_zodBundle.z.object({}),
59
+ type: "readOnly"
60
+ },
61
+ handle: async (context, params, response) => {
62
+ const browserContext = await context.ensureBrowserContext();
63
+ await browserContext.tracing.stop();
64
+ const traceLegend = browserContext.tracing[traceLegendSymbol];
65
+ if (!traceLegend)
66
+ throw new Error("Tracing is not started");
67
+ delete browserContext.tracing[traceLegendSymbol];
68
+ response.addTextResult(`Trace recording stopped.`);
69
+ response.addFileLink("Trace", `${traceLegend.tracesDir}/${traceLegend.name}.trace`);
70
+ response.addFileLink("Network log", `${traceLegend.tracesDir}/${traceLegend.name}.network`);
71
+ response.addFileLink("Resources", `${traceLegend.tracesDir}/resources`);
72
+ }
73
+ });
74
+ var tracing_default = [
75
+ tracingStart,
76
+ tracingStop
77
+ ];
78
+ const traceLegendSymbol = Symbol("tracesDir");
@@ -0,0 +1,83 @@
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 utils_exports = {};
20
+ __export(utils_exports, {
21
+ eventWaiter: () => eventWaiter,
22
+ waitForCompletion: () => waitForCompletion
23
+ });
24
+ module.exports = __toCommonJS(utils_exports);
25
+ async function waitForCompletion(tab, callback) {
26
+ const requests = [];
27
+ const requestListener = (request) => requests.push(request);
28
+ const disposeListeners = () => {
29
+ tab.page.off("request", requestListener);
30
+ };
31
+ tab.page.on("request", requestListener);
32
+ let result;
33
+ try {
34
+ result = await callback();
35
+ await tab.waitForTimeout(500);
36
+ } finally {
37
+ disposeListeners();
38
+ }
39
+ const requestedNavigation = requests.some((request) => request.isNavigationRequest());
40
+ if (requestedNavigation) {
41
+ await tab.page.mainFrame().waitForLoadState("load", { timeout: 1e4 }).catch(() => {
42
+ });
43
+ return result;
44
+ }
45
+ const promises = [];
46
+ for (const request of requests) {
47
+ if (["document", "stylesheet", "script", "xhr", "fetch"].includes(request.resourceType()))
48
+ promises.push(request.response().then((r) => r?.finished()).catch(() => {
49
+ }));
50
+ else
51
+ promises.push(request.response().catch(() => {
52
+ }));
53
+ }
54
+ const timeout = new Promise((resolve) => setTimeout(resolve, 5e3));
55
+ await Promise.race([Promise.all(promises), timeout]);
56
+ if (requests.length)
57
+ await tab.waitForTimeout(500);
58
+ return result;
59
+ }
60
+ function eventWaiter(page, event, timeout) {
61
+ const disposables = [];
62
+ const eventPromise = new Promise((resolve, reject) => {
63
+ page.on(event, resolve);
64
+ disposables.push(() => page.off(event, resolve));
65
+ });
66
+ let abort;
67
+ const abortPromise = new Promise((resolve, reject) => {
68
+ abort = () => resolve(void 0);
69
+ });
70
+ const timeoutPromise = new Promise((f) => {
71
+ const timeoutId = setTimeout(() => f(void 0), timeout);
72
+ disposables.push(() => clearTimeout(timeoutId));
73
+ });
74
+ return {
75
+ promise: Promise.race([eventPromise, abortPromise, timeoutPromise]).finally(() => disposables.forEach((dispose) => dispose())),
76
+ abort
77
+ };
78
+ }
79
+ // Annotate the CommonJS export names for ESM import in node:
80
+ 0 && (module.exports = {
81
+ eventWaiter,
82
+ waitForCompletion
83
+ });
@@ -0,0 +1,151 @@
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 verify_exports = {};
20
+ __export(verify_exports, {
21
+ default: () => verify_default
22
+ });
23
+ module.exports = __toCommonJS(verify_exports);
24
+ var import_zodBundle = require("../../zodBundle");
25
+ var import_stringUtils = require("../../utils/isomorphic/stringUtils");
26
+ var import_tool = require("./tool");
27
+ const verifyElement = (0, import_tool.defineTabTool)({
28
+ capability: "testing",
29
+ schema: {
30
+ name: "browser_verify_element_visible",
31
+ title: "Verify element visible",
32
+ description: "Verify element is visible on the page",
33
+ inputSchema: import_zodBundle.z.object({
34
+ role: import_zodBundle.z.string().describe('ROLE of the element. Can be found in the snapshot like this: `- {ROLE} "Accessible Name":`'),
35
+ accessibleName: import_zodBundle.z.string().describe('ACCESSIBLE_NAME of the element. Can be found in the snapshot like this: `- role "{ACCESSIBLE_NAME}"`')
36
+ }),
37
+ type: "assertion"
38
+ },
39
+ handle: async (tab, params, response) => {
40
+ for (const frame of tab.page.frames()) {
41
+ const locator = frame.getByRole(params.role, { name: params.accessibleName });
42
+ if (await locator.count() > 0) {
43
+ const resolved = await locator.normalize();
44
+ response.addCode(`await expect(page.${resolved}).toBeVisible();`);
45
+ response.addTextResult("Done");
46
+ return;
47
+ }
48
+ }
49
+ response.addError(`Element with role "${params.role}" and accessible name "${params.accessibleName}" not found`);
50
+ }
51
+ });
52
+ const verifyText = (0, import_tool.defineTabTool)({
53
+ capability: "testing",
54
+ schema: {
55
+ name: "browser_verify_text_visible",
56
+ title: "Verify text visible",
57
+ description: `Verify text is visible on the page. Prefer ${verifyElement.schema.name} if possible.`,
58
+ inputSchema: import_zodBundle.z.object({
59
+ text: import_zodBundle.z.string().describe('TEXT to verify. Can be found in the snapshot like this: `- role "Accessible Name": {TEXT}` or like this: `- text: {TEXT}`')
60
+ }),
61
+ type: "assertion"
62
+ },
63
+ handle: async (tab, params, response) => {
64
+ for (const frame of tab.page.frames()) {
65
+ const locator = frame.getByText(params.text).filter({ visible: true });
66
+ if (await locator.count() > 0) {
67
+ const resolved = await locator.normalize();
68
+ response.addCode(`await expect(page.${resolved}).toBeVisible();`);
69
+ response.addTextResult("Done");
70
+ return;
71
+ }
72
+ }
73
+ response.addError("Text not found");
74
+ }
75
+ });
76
+ const verifyList = (0, import_tool.defineTabTool)({
77
+ capability: "testing",
78
+ schema: {
79
+ name: "browser_verify_list_visible",
80
+ title: "Verify list visible",
81
+ description: "Verify list is visible on the page",
82
+ inputSchema: import_zodBundle.z.object({
83
+ element: import_zodBundle.z.string().describe("Human-readable list description"),
84
+ ref: import_zodBundle.z.string().describe("Exact target element reference that points to the list"),
85
+ selector: import_zodBundle.z.string().optional().describe('CSS or role selector for the target list, when "ref" is not available.'),
86
+ items: import_zodBundle.z.array(import_zodBundle.z.string()).describe("Items to verify")
87
+ }),
88
+ type: "assertion"
89
+ },
90
+ handle: async (tab, params, response) => {
91
+ const { locator } = await tab.refLocator({ ref: params.ref, selector: params.selector, element: params.element });
92
+ const itemTexts = [];
93
+ for (const item of params.items) {
94
+ const itemLocator = locator.getByText(item);
95
+ if (await itemLocator.count() === 0) {
96
+ response.addError(`Item "${item}" not found`);
97
+ return;
98
+ }
99
+ itemTexts.push(await itemLocator.textContent(tab.expectTimeoutOptions));
100
+ }
101
+ const ariaSnapshot = `\`
102
+ - list:
103
+ ${itemTexts.map((t) => ` - listitem: ${(0, import_stringUtils.escapeWithQuotes)(t, '"')}`).join("\n")}
104
+ \``;
105
+ response.addCode(`await expect(page.locator('body')).toMatchAriaSnapshot(${ariaSnapshot});`);
106
+ response.addTextResult("Done");
107
+ }
108
+ });
109
+ const verifyValue = (0, import_tool.defineTabTool)({
110
+ capability: "testing",
111
+ schema: {
112
+ name: "browser_verify_value",
113
+ title: "Verify value",
114
+ description: "Verify element value",
115
+ inputSchema: import_zodBundle.z.object({
116
+ type: import_zodBundle.z.enum(["textbox", "checkbox", "radio", "combobox", "slider"]).describe("Type of the element"),
117
+ element: import_zodBundle.z.string().describe("Human-readable element description"),
118
+ ref: import_zodBundle.z.string().describe("Exact target element reference from the page snapshot"),
119
+ selector: import_zodBundle.z.string().optional().describe('CSS or role selector for the target element, when "ref" is not available'),
120
+ value: import_zodBundle.z.string().describe('Value to verify. For checkbox, use "true" or "false".')
121
+ }),
122
+ type: "assertion"
123
+ },
124
+ handle: async (tab, params, response) => {
125
+ const { locator, resolved } = await tab.refLocator({ ref: params.ref, selector: params.selector, element: params.element });
126
+ const locatorSource = `page.${resolved}`;
127
+ if (params.type === "textbox" || params.type === "slider" || params.type === "combobox") {
128
+ const value = await locator.inputValue(tab.expectTimeoutOptions);
129
+ if (value !== params.value) {
130
+ response.addError(`Expected value "${params.value}", but got "${value}"`);
131
+ return;
132
+ }
133
+ response.addCode(`await expect(${locatorSource}).toHaveValue(${(0, import_stringUtils.escapeWithQuotes)(params.value)});`);
134
+ } else if (params.type === "checkbox" || params.type === "radio") {
135
+ const value = await locator.isChecked(tab.expectTimeoutOptions);
136
+ if (value !== (params.value === "true")) {
137
+ response.addError(`Expected value "${params.value}", but got "${value}"`);
138
+ return;
139
+ }
140
+ const matcher = value ? "toBeChecked" : "not.toBeChecked";
141
+ response.addCode(`await expect(${locatorSource}).${matcher}();`);
142
+ }
143
+ response.addTextResult("Done");
144
+ }
145
+ });
146
+ var verify_default = [
147
+ verifyElement,
148
+ verifyText,
149
+ verifyList,
150
+ verifyValue
151
+ ];
@@ -0,0 +1,98 @@
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 video_exports = {};
20
+ __export(video_exports, {
21
+ default: () => video_default
22
+ });
23
+ module.exports = __toCommonJS(video_exports);
24
+ var import_zodBundle = require("../../zodBundle");
25
+ var import_tool = require("./tool");
26
+ const videoStart = (0, import_tool.defineTool)({
27
+ capability: "devtools",
28
+ schema: {
29
+ name: "browser_start_video",
30
+ title: "Start video",
31
+ description: "Start video recording",
32
+ inputSchema: import_zodBundle.z.object({
33
+ filename: import_zodBundle.z.string().optional().describe("Filename to save the video."),
34
+ size: import_zodBundle.z.object({
35
+ width: import_zodBundle.z.number().describe("Video width"),
36
+ height: import_zodBundle.z.number().describe("Video height")
37
+ }).optional().describe("Video size")
38
+ }),
39
+ type: "readOnly"
40
+ },
41
+ handle: async (context, params, response) => {
42
+ const resolvedFile = await response.resolveClientFile({ prefix: "video", ext: "webm", suggestedFilename: params.filename }, "Video");
43
+ await context.startVideoRecording(resolvedFile.fileName, { size: params.size });
44
+ response.addTextResult("Video recording started.");
45
+ }
46
+ });
47
+ const videoStop = (0, import_tool.defineTool)({
48
+ capability: "devtools",
49
+ schema: {
50
+ name: "browser_stop_video",
51
+ title: "Stop video",
52
+ description: "Stop video recording",
53
+ inputSchema: import_zodBundle.z.object({}),
54
+ type: "readOnly"
55
+ },
56
+ handle: async (context, params, response) => {
57
+ const fileNames = await context.stopVideoRecording();
58
+ if (!fileNames.length) {
59
+ response.addTextResult("No videos were recorded.");
60
+ return;
61
+ }
62
+ for (const fileName of fileNames) {
63
+ const resolvedFile = await response.resolveClientFile({
64
+ prefix: "video",
65
+ ext: "webm",
66
+ suggestedFilename: fileName
67
+ }, "Video");
68
+ await response.addFileResult(resolvedFile, null);
69
+ }
70
+ }
71
+ });
72
+ const videoChapter = (0, import_tool.defineTool)({
73
+ capability: "devtools",
74
+ schema: {
75
+ name: "browser_video_chapter",
76
+ title: "Video chapter",
77
+ description: "Add a chapter marker to the video recording. Shows a full-screen chapter card with blurred backdrop.",
78
+ inputSchema: import_zodBundle.z.object({
79
+ title: import_zodBundle.z.string().describe("Chapter title"),
80
+ description: import_zodBundle.z.string().optional().describe("Chapter description"),
81
+ duration: import_zodBundle.z.number().optional().describe("Duration in milliseconds to show the chapter card")
82
+ }),
83
+ type: "readOnly"
84
+ },
85
+ handle: async (context, params, response) => {
86
+ const tab = context.currentTabOrDie();
87
+ await tab.page.screencast.showChapter(params.title, {
88
+ description: params.description,
89
+ duration: params.duration
90
+ });
91
+ response.addTextResult(`Chapter '${params.title}' added.`);
92
+ }
93
+ });
94
+ var video_default = [
95
+ videoStart,
96
+ videoStop,
97
+ videoChapter
98
+ ];
@@ -0,0 +1,63 @@
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 wait_exports = {};
20
+ __export(wait_exports, {
21
+ default: () => wait_default
22
+ });
23
+ module.exports = __toCommonJS(wait_exports);
24
+ var import_zodBundle = require("../../zodBundle");
25
+ var import_tool = require("./tool");
26
+ const wait = (0, import_tool.defineTool)({
27
+ capability: "core",
28
+ schema: {
29
+ name: "browser_wait_for",
30
+ title: "Wait for",
31
+ description: "Wait for text to appear or disappear or a specified time to pass",
32
+ inputSchema: import_zodBundle.z.object({
33
+ time: import_zodBundle.z.number().optional().describe("The time to wait in seconds"),
34
+ text: import_zodBundle.z.string().optional().describe("The text to wait for"),
35
+ textGone: import_zodBundle.z.string().optional().describe("The text to wait for to disappear")
36
+ }),
37
+ type: "assertion"
38
+ },
39
+ handle: async (context, params, response) => {
40
+ if (!params.text && !params.textGone && !params.time)
41
+ throw new Error("Either time, text or textGone must be provided");
42
+ if (params.time) {
43
+ response.addCode(`await new Promise(f => setTimeout(f, ${params.time} * 1000));`);
44
+ await new Promise((f) => setTimeout(f, Math.min(3e4, params.time * 1e3)));
45
+ }
46
+ const tab = context.currentTabOrDie();
47
+ const locator = params.text ? tab.page.getByText(params.text).first() : void 0;
48
+ const goneLocator = params.textGone ? tab.page.getByText(params.textGone).first() : void 0;
49
+ if (goneLocator) {
50
+ response.addCode(`await page.getByText(${JSON.stringify(params.textGone)}).first().waitFor({ state: 'hidden' });`);
51
+ await goneLocator.waitFor({ state: "hidden" });
52
+ }
53
+ if (locator) {
54
+ response.addCode(`await page.getByText(${JSON.stringify(params.text)}).first().waitFor({ state: 'visible' });`);
55
+ await locator.waitFor({ state: "visible" });
56
+ }
57
+ response.addTextResult(`Waited for ${params.text || params.textGone || params.time}`);
58
+ response.setIncludeSnapshot();
59
+ }
60
+ });
61
+ var wait_default = [
62
+ wait
63
+ ];