patchright-bun-core 1.58.2 → 1.59.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (272) 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 +18 -37
  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/{webSocket.js → connect.js} +57 -7
  16. package/lib/client/connection.js +8 -4
  17. package/lib/client/consoleMessage.js +3 -0
  18. package/lib/client/debugger.js +57 -0
  19. package/lib/client/dialog.js +8 -1
  20. package/lib/client/disposable.js +76 -0
  21. package/lib/client/electron.js +1 -0
  22. package/lib/client/elementHandle.js +1 -4
  23. package/lib/client/events.js +3 -3
  24. package/lib/client/fetch.js +0 -1
  25. package/lib/client/frame.js +0 -5
  26. package/lib/client/harRouter.js +13 -1
  27. package/lib/client/jsHandle.js +0 -4
  28. package/lib/client/locator.js +5 -7
  29. package/lib/client/network.js +14 -11
  30. package/lib/client/page.js +34 -48
  31. package/lib/client/platform.js +0 -3
  32. package/lib/client/screencast.js +88 -0
  33. package/lib/client/selectors.js +3 -1
  34. package/lib/client/tracing.js +11 -4
  35. package/lib/client/video.js +13 -20
  36. package/lib/generated/bindingsControllerSource.js +1 -1
  37. package/lib/generated/clockSource.js +1 -1
  38. package/lib/generated/injectedScriptSource.js +1 -1
  39. package/lib/generated/pollingRecorderSource.js +1 -1
  40. package/lib/generated/storageScriptSource.js +1 -1
  41. package/lib/generated/utilityScriptSource.js +1 -1
  42. package/lib/mcpBundle.js +0 -6
  43. package/lib/mcpBundleImpl.js +91 -0
  44. package/lib/protocol/validator.js +216 -118
  45. package/lib/protocol/validatorPrimitives.js +1 -1
  46. package/lib/remote/playwrightConnection.js +10 -8
  47. package/lib/remote/playwrightPipeServer.js +100 -0
  48. package/lib/remote/playwrightServer.js +13 -8
  49. package/lib/remote/playwrightWebSocketServer.js +73 -0
  50. package/lib/remote/serverTransport.js +96 -0
  51. package/lib/server/android/android.js +2 -2
  52. package/lib/server/bidi/bidiBrowser.js +30 -8
  53. package/lib/server/bidi/bidiChromium.js +18 -5
  54. package/lib/server/bidi/bidiNetworkManager.js +39 -11
  55. package/lib/server/bidi/bidiPage.js +31 -15
  56. package/lib/server/bidi/third_party/firefoxPrefs.js +3 -1
  57. package/lib/server/browser.js +84 -21
  58. package/lib/server/browserContext.js +97 -58
  59. package/lib/server/browserType.js +14 -12
  60. package/lib/server/chromium/chromium.js +15 -13
  61. package/lib/server/chromium/crBrowser.js +18 -10
  62. package/lib/server/chromium/crNetworkManager.js +4 -4
  63. package/lib/server/chromium/crPage.js +26 -64
  64. package/lib/server/chromium/crServiceWorker.js +5 -4
  65. package/lib/server/clock.js +33 -33
  66. package/lib/server/console.js +5 -1
  67. package/lib/server/debugController.js +12 -6
  68. package/lib/server/debugger.js +40 -47
  69. package/lib/server/deviceDescriptorsSource.json +137 -137
  70. package/lib/server/dispatchers/browserContextDispatcher.js +27 -30
  71. package/lib/server/dispatchers/browserDispatcher.js +11 -5
  72. package/lib/server/dispatchers/browserTypeDispatcher.js +7 -0
  73. package/lib/server/dispatchers/cdpSessionDispatcher.js +4 -1
  74. package/lib/server/dispatchers/debuggerDispatcher.js +84 -0
  75. package/lib/server/dispatchers/dispatcher.js +1 -1
  76. package/lib/server/dispatchers/disposableDispatcher.js +39 -0
  77. package/lib/server/dispatchers/electronDispatcher.js +2 -1
  78. package/lib/server/dispatchers/frameDispatcher.js +3 -3
  79. package/lib/server/dispatchers/localUtilsDispatcher.js +37 -1
  80. package/lib/server/dispatchers/networkDispatchers.js +6 -5
  81. package/lib/server/dispatchers/pageDispatcher.js +101 -38
  82. package/lib/server/dispatchers/webSocketRouteDispatcher.js +4 -5
  83. package/lib/server/disposable.js +41 -0
  84. package/lib/server/dom.js +44 -26
  85. package/lib/server/download.js +3 -2
  86. package/lib/server/electron/electron.js +12 -7
  87. package/lib/server/firefox/ffBrowser.js +9 -19
  88. package/lib/server/firefox/ffInput.js +21 -5
  89. package/lib/server/firefox/ffNetworkManager.js +2 -2
  90. package/lib/server/firefox/ffPage.js +24 -27
  91. package/lib/server/frames.js +40 -11
  92. package/lib/server/har/harRecorder.js +2 -2
  93. package/lib/server/har/harTracer.js +5 -4
  94. package/lib/server/input.js +49 -4
  95. package/lib/server/instrumentation.js +5 -0
  96. package/lib/server/launchApp.js +0 -1
  97. package/lib/server/localUtils.js +6 -6
  98. package/lib/server/network.js +9 -8
  99. package/lib/server/overlay.js +138 -0
  100. package/lib/server/page.js +111 -51
  101. package/lib/server/progress.js +6 -0
  102. package/lib/server/recorder/recorderApp.js +9 -8
  103. package/lib/server/recorder.js +76 -40
  104. package/lib/server/registry/index.js +54 -81
  105. package/lib/server/registry/nativeDeps.js +1 -0
  106. package/lib/server/screencast.js +90 -143
  107. package/lib/server/trace/recorder/snapshotter.js +2 -2
  108. package/lib/server/trace/recorder/tracing.js +87 -36
  109. package/lib/server/trace/viewer/traceViewer.js +3 -4
  110. package/lib/server/usKeyboardLayout.js +7 -0
  111. package/lib/server/utils/comparators.js +1 -1
  112. package/lib/server/utils/disposable.js +32 -0
  113. package/lib/server/utils/eventsHelper.js +3 -1
  114. package/lib/server/utils/fileUtils.js +16 -2
  115. package/lib/server/utils/happyEyeballs.js +15 -12
  116. package/lib/server/utils/hostPlatform.js +0 -15
  117. package/lib/server/utils/httpServer.js +5 -3
  118. package/lib/server/utils/network.js +2 -1
  119. package/lib/server/utils/nodePlatform.js +0 -6
  120. package/lib/server/utils/processLauncher.js +8 -6
  121. package/lib/server/utils/zipFile.js +2 -2
  122. package/lib/server/videoRecorder.js +82 -12
  123. package/lib/server/webkit/wkBrowser.js +1 -6
  124. package/lib/server/webkit/wkPage.js +27 -25
  125. package/lib/server/webkit/wkWorkers.js +2 -1
  126. package/lib/serverRegistry.js +156 -0
  127. package/lib/tools/backend/browserBackend.js +79 -0
  128. package/lib/tools/backend/common.js +63 -0
  129. package/lib/tools/backend/config.js +41 -0
  130. package/lib/tools/backend/console.js +66 -0
  131. package/lib/tools/backend/context.js +296 -0
  132. package/lib/tools/backend/cookies.js +152 -0
  133. package/lib/tools/backend/devtools.js +69 -0
  134. package/lib/tools/backend/dialogs.js +59 -0
  135. package/lib/tools/backend/evaluate.js +64 -0
  136. package/lib/tools/backend/files.js +60 -0
  137. package/lib/tools/backend/form.js +64 -0
  138. package/lib/tools/backend/keyboard.js +155 -0
  139. package/lib/tools/backend/logFile.js +95 -0
  140. package/lib/tools/backend/mouse.js +168 -0
  141. package/lib/tools/backend/navigate.js +106 -0
  142. package/lib/tools/backend/network.js +135 -0
  143. package/lib/tools/backend/pdf.js +48 -0
  144. package/lib/tools/backend/response.js +305 -0
  145. package/lib/tools/backend/route.js +140 -0
  146. package/lib/tools/backend/runCode.js +77 -0
  147. package/lib/tools/backend/screenshot.js +88 -0
  148. package/lib/tools/backend/sessionLog.js +74 -0
  149. package/lib/tools/backend/snapshot.js +208 -0
  150. package/lib/tools/backend/storage.js +68 -0
  151. package/lib/tools/backend/tab.js +445 -0
  152. package/lib/tools/backend/tabs.js +67 -0
  153. package/lib/tools/backend/tool.js +47 -0
  154. package/lib/tools/backend/tools.js +102 -0
  155. package/lib/tools/backend/tracing.js +78 -0
  156. package/lib/tools/backend/utils.js +83 -0
  157. package/lib/tools/backend/verify.js +151 -0
  158. package/lib/tools/backend/video.js +98 -0
  159. package/lib/tools/backend/wait.js +63 -0
  160. package/lib/tools/backend/webstorage.js +223 -0
  161. package/lib/tools/cli-client/cli.js +6 -0
  162. package/lib/tools/cli-client/help.json +399 -0
  163. package/lib/tools/cli-client/minimist.js +128 -0
  164. package/lib/tools/cli-client/program.js +350 -0
  165. package/lib/tools/cli-client/registry.js +176 -0
  166. package/lib/tools/cli-client/session.js +289 -0
  167. package/lib/tools/cli-client/skill/SKILL.md +328 -0
  168. package/lib/tools/cli-client/skill/references/element-attributes.md +23 -0
  169. package/lib/tools/cli-client/skill/references/playwright-tests.md +39 -0
  170. package/lib/tools/cli-client/skill/references/request-mocking.md +87 -0
  171. package/lib/tools/cli-client/skill/references/running-code.md +231 -0
  172. package/lib/tools/cli-client/skill/references/session-management.md +169 -0
  173. package/lib/tools/cli-client/skill/references/storage-state.md +275 -0
  174. package/lib/tools/cli-client/skill/references/test-generation.md +88 -0
  175. package/lib/tools/cli-client/skill/references/tracing.md +139 -0
  176. package/lib/tools/cli-client/skill/references/video-recording.md +143 -0
  177. package/lib/tools/cli-daemon/command.js +73 -0
  178. package/lib/tools/cli-daemon/commands.js +956 -0
  179. package/lib/tools/cli-daemon/daemon.js +157 -0
  180. package/lib/tools/cli-daemon/helpGenerator.js +177 -0
  181. package/lib/tools/cli-daemon/program.js +129 -0
  182. package/lib/tools/dashboard/appIcon.png +0 -0
  183. package/lib/tools/dashboard/dashboardApp.js +284 -0
  184. package/lib/tools/dashboard/dashboardController.js +296 -0
  185. package/lib/tools/exports.js +60 -0
  186. package/lib/tools/mcp/browserFactory.js +233 -0
  187. package/lib/tools/mcp/cdpRelay.js +352 -0
  188. package/lib/tools/mcp/cli-stub.js +7 -0
  189. package/lib/tools/mcp/config.d.js +16 -0
  190. package/lib/tools/mcp/config.js +446 -0
  191. package/lib/tools/mcp/configIni.js +189 -0
  192. package/lib/tools/mcp/extensionContextFactory.js +55 -0
  193. package/lib/tools/mcp/index.js +62 -0
  194. package/lib/tools/mcp/log.js +35 -0
  195. package/lib/tools/mcp/program.js +107 -0
  196. package/lib/tools/mcp/protocol.js +28 -0
  197. package/lib/tools/mcp/watchdog.js +44 -0
  198. package/lib/tools/trace/SKILL.md +171 -0
  199. package/lib/{server/trace/viewer/traceParser.js → tools/trace/installSkill.js} +15 -39
  200. package/lib/tools/trace/traceActions.js +142 -0
  201. package/lib/tools/trace/traceAttachments.js +69 -0
  202. package/lib/tools/trace/traceCli.js +87 -0
  203. package/lib/tools/trace/traceConsole.js +97 -0
  204. package/lib/tools/trace/traceErrors.js +55 -0
  205. package/lib/tools/trace/traceOpen.js +69 -0
  206. package/lib/tools/trace/traceParser.js +96 -0
  207. package/lib/tools/trace/traceRequests.js +182 -0
  208. package/lib/tools/trace/traceScreenshot.js +68 -0
  209. package/lib/tools/trace/traceSnapshot.js +149 -0
  210. package/lib/tools/trace/traceUtils.js +153 -0
  211. package/lib/tools/utils/connect.js +32 -0
  212. package/lib/tools/utils/mcp/http.js +152 -0
  213. package/lib/tools/utils/mcp/server.js +230 -0
  214. package/lib/tools/utils/mcp/tool.js +47 -0
  215. package/lib/tools/utils/socketConnection.js +108 -0
  216. package/lib/utils/isomorphic/formatUtils.js +64 -0
  217. package/lib/utils/isomorphic/jsonSchema.js +89 -0
  218. package/lib/utils/isomorphic/mimeType.js +7 -2
  219. package/lib/utils/isomorphic/protocolFormatter.js +2 -2
  220. package/lib/utils/isomorphic/protocolMetainfo.js +127 -106
  221. package/lib/utils/isomorphic/stringUtils.js +3 -3
  222. package/lib/utils/isomorphic/timeoutRunner.js +3 -3
  223. package/lib/utils/isomorphic/trace/snapshotRenderer.js +35 -42
  224. package/lib/utils/isomorphic/trace/traceLoader.js +15 -14
  225. package/lib/utils/isomorphic/trace/traceModel.js +3 -2
  226. package/lib/utils/isomorphic/trace/traceModernizer.js +1 -0
  227. package/lib/utils/isomorphic/urlMatch.js +54 -1
  228. package/lib/utils/isomorphic/utilityScriptSerializers.js +11 -0
  229. package/lib/utils.js +6 -2
  230. package/lib/utilsBundle.js +3 -21
  231. package/lib/utilsBundleImpl/index.js +132 -133
  232. package/lib/vite/dashboard/assets/index-BAOybkp8.js +50 -0
  233. package/lib/vite/dashboard/assets/index-CZAYOG76.css +1 -0
  234. package/lib/vite/dashboard/index.html +28 -0
  235. package/lib/vite/htmlReport/index.html +2 -70
  236. package/lib/vite/htmlReport/report.css +1 -0
  237. package/lib/vite/htmlReport/report.js +72 -0
  238. package/lib/vite/recorder/assets/{codeMirrorModule-DadYNm1I.js → codeMirrorModule-C8KMvO9L.js} +20 -20
  239. package/lib/vite/recorder/assets/index-CqAYX1I3.js +193 -0
  240. package/lib/vite/recorder/index.html +1 -1
  241. package/lib/vite/traceViewer/assets/{codeMirrorModule-a5XoALAZ.js → codeMirrorModule-DS0FLvoc.js} +20 -20
  242. package/lib/vite/traceViewer/assets/defaultSettingsView-GTWI-W_B.js +262 -0
  243. package/lib/vite/traceViewer/defaultSettingsView.B4dS75f0.css +1 -0
  244. package/lib/vite/traceViewer/{index.BVu7tZDe.css → index.CzXZzn5A.css} +1 -1
  245. package/lib/vite/traceViewer/{index.BDwrLSGN.js → index.Dtstcb7U.js} +1 -1
  246. package/lib/vite/traceViewer/index.html +4 -4
  247. package/lib/vite/traceViewer/sw.bundle.js +4 -4
  248. package/lib/vite/traceViewer/uiMode.Vipi55dB.js +6 -0
  249. package/lib/vite/traceViewer/uiMode.html +3 -3
  250. package/lib/zipBundleImpl.js +2 -2
  251. package/lib/zodBundle.js +39 -0
  252. package/lib/zodBundleImpl.js +40 -0
  253. package/package.json +6 -1
  254. package/types/protocol.d.ts +947 -51
  255. package/types/types.d.ts +854 -74
  256. package/lib/client/pageAgent.js +0 -64
  257. package/lib/mcpBundleImpl/index.js +0 -147
  258. package/lib/server/agent/actionRunner.js +0 -335
  259. package/lib/server/agent/actions.js +0 -128
  260. package/lib/server/agent/codegen.js +0 -111
  261. package/lib/server/agent/context.js +0 -150
  262. package/lib/server/agent/expectTools.js +0 -156
  263. package/lib/server/agent/pageAgent.js +0 -204
  264. package/lib/server/agent/performTools.js +0 -262
  265. package/lib/server/agent/tool.js +0 -109
  266. package/lib/server/dispatchers/pageAgentDispatcher.js +0 -96
  267. package/lib/vite/recorder/assets/index-BhTWtUlo.js +0 -193
  268. package/lib/vite/traceViewer/assets/defaultSettingsView-CJSZINFr.js +0 -266
  269. package/lib/vite/traceViewer/defaultSettingsView.7ch9cixO.css +0 -1
  270. package/lib/vite/traceViewer/uiMode.CQJ9SCIQ.js +0 -5
  271. /package/lib/{server/utils → utils/isomorphic}/imageUtils.js +0 -0
  272. /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
+ ];