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,445 @@
1
+ "use strict";
2
+ var __create = Object.create;
3
+ var __defProp = Object.defineProperty;
4
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
+ var __getOwnPropNames = Object.getOwnPropertyNames;
6
+ var __getProtoOf = Object.getPrototypeOf;
7
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
8
+ var __export = (target, all) => {
9
+ for (var name in all)
10
+ __defProp(target, name, { get: all[name], enumerable: true });
11
+ };
12
+ var __copyProps = (to, from, except, desc) => {
13
+ if (from && typeof from === "object" || typeof from === "function") {
14
+ for (let key of __getOwnPropNames(from))
15
+ if (!__hasOwnProp.call(to, key) && key !== except)
16
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
17
+ }
18
+ return to;
19
+ };
20
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
21
+ // If the importer is in node compatibility mode or this is not an ESM
22
+ // file that has been converted to a CommonJS file using a Babel-
23
+ // compatible transform (i.e. "__esModule" has not been set), then set
24
+ // "default" to the CommonJS "module.exports" for node compatibility.
25
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
26
+ mod
27
+ ));
28
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
29
+ var tab_exports = {};
30
+ __export(tab_exports, {
31
+ Tab: () => Tab,
32
+ renderModalStates: () => renderModalStates,
33
+ shouldIncludeMessage: () => shouldIncludeMessage
34
+ });
35
+ module.exports = __toCommonJS(tab_exports);
36
+ var import_url = __toESM(require("url"));
37
+ var import_events = require("events");
38
+ var import_locatorGenerators = require("../../utils/isomorphic/locatorGenerators");
39
+ var import_locatorParser = require("../../utils/isomorphic/locatorParser");
40
+ var import_manualPromise = require("../../utils/isomorphic/manualPromise");
41
+ var import_utilsBundle = require("../../utilsBundle");
42
+ var import_eventsHelper = require("../../server/utils/eventsHelper");
43
+ var import_disposable = require("../../server/utils/disposable");
44
+ var import_utils = require("./utils");
45
+ var import_logFile = require("./logFile");
46
+ var import_dialogs = require("./dialogs");
47
+ var import_files = require("./files");
48
+ const TabEvents = {
49
+ modalState: "modalState"
50
+ };
51
+ class Tab extends import_events.EventEmitter {
52
+ constructor(context, page, onPageClose) {
53
+ super();
54
+ this._lastHeader = { title: "about:blank", url: "about:blank", current: false, console: { total: 0, warnings: 0, errors: 0 } };
55
+ this._downloads = [];
56
+ this._requests = [];
57
+ this._modalStates = [];
58
+ this._recentEventEntries = [];
59
+ this.context = context;
60
+ this.page = page;
61
+ this._onPageClose = onPageClose;
62
+ const p = page;
63
+ this._disposables = [
64
+ import_eventsHelper.eventsHelper.addEventListener(p, "console", (event) => this._handleConsoleMessage(messageToConsoleMessage(event))),
65
+ import_eventsHelper.eventsHelper.addEventListener(p, "pageerror", (error) => this._handleConsoleMessage(pageErrorToConsoleMessage(error))),
66
+ import_eventsHelper.eventsHelper.addEventListener(p, "request", (request) => this._handleRequest(request)),
67
+ import_eventsHelper.eventsHelper.addEventListener(p, "response", (response) => this._handleResponse(response)),
68
+ import_eventsHelper.eventsHelper.addEventListener(p, "requestfailed", (request) => this._handleRequestFailed(request)),
69
+ import_eventsHelper.eventsHelper.addEventListener(p, "close", () => this._onClose()),
70
+ import_eventsHelper.eventsHelper.addEventListener(p, "filechooser", (chooser) => {
71
+ this.setModalState({
72
+ type: "fileChooser",
73
+ description: "File chooser",
74
+ fileChooser: chooser,
75
+ clearedBy: { tool: import_files.uploadFile.schema.name, skill: "upload" }
76
+ });
77
+ }),
78
+ import_eventsHelper.eventsHelper.addEventListener(p, "dialog", (dialog) => this._dialogShown(dialog)),
79
+ import_eventsHelper.eventsHelper.addEventListener(p, "download", (download) => {
80
+ void this._downloadStarted(download);
81
+ })
82
+ ];
83
+ page[tabSymbol] = this;
84
+ const wallTime = Date.now();
85
+ this._consoleLog = new import_logFile.LogFile(this.context, wallTime, "console", "Console");
86
+ this._initializedPromise = this._initialize();
87
+ this.actionTimeoutOptions = { timeout: context.config.timeouts?.action };
88
+ this.navigationTimeoutOptions = { timeout: context.config.timeouts?.navigation };
89
+ this.expectTimeoutOptions = { timeout: context.config.timeouts?.expect };
90
+ }
91
+ async dispose() {
92
+ await (0, import_disposable.disposeAll)(this._disposables);
93
+ this._consoleLog.stop();
94
+ }
95
+ static forPage(page) {
96
+ return page[tabSymbol];
97
+ }
98
+ static async collectConsoleMessages(page) {
99
+ const result = [];
100
+ const messages = await page.consoleMessages().catch(() => []);
101
+ for (const message of messages)
102
+ result.push(messageToConsoleMessage(message));
103
+ const errors = await page.pageErrors().catch(() => []);
104
+ for (const error of errors)
105
+ result.push(pageErrorToConsoleMessage(error));
106
+ return result;
107
+ }
108
+ async _initialize() {
109
+ for (const message of await Tab.collectConsoleMessages(this.page))
110
+ this._handleConsoleMessage(message);
111
+ const requests = await this.page.requests().catch(() => []);
112
+ for (const request of requests.filter((r) => r.existingResponse() || r.failure()))
113
+ this._requests.push(request);
114
+ for (const initPage of this.context.config.browser?.initPage || []) {
115
+ try {
116
+ const { default: func } = await import(import_url.default.pathToFileURL(initPage).href);
117
+ await func({ page: this.page });
118
+ } catch (e) {
119
+ (0, import_utilsBundle.debug)("pw:tools:error")(e);
120
+ }
121
+ }
122
+ }
123
+ modalStates() {
124
+ return this._modalStates;
125
+ }
126
+ setModalState(modalState) {
127
+ this._modalStates.push(modalState);
128
+ this.emit(TabEvents.modalState, modalState);
129
+ }
130
+ clearModalState(modalState) {
131
+ this._modalStates = this._modalStates.filter((state) => state !== modalState);
132
+ }
133
+ _dialogShown(dialog) {
134
+ this.setModalState({
135
+ type: "dialog",
136
+ description: `"${dialog.type()}" dialog with message "${dialog.message()}"`,
137
+ dialog,
138
+ clearedBy: { tool: import_dialogs.handleDialog.schema.name, skill: "dialog-accept or dialog-dismiss" }
139
+ });
140
+ }
141
+ async _downloadStarted(download) {
142
+ const outputFile = await this.context.outputFile({ suggestedFilename: sanitizeForFilePath(download.suggestedFilename()), prefix: "download", ext: "bin" }, { origin: "code" });
143
+ const entry = {
144
+ download,
145
+ finished: false,
146
+ outputFile
147
+ };
148
+ this._downloads.push(entry);
149
+ this._addLogEntry({ type: "download-start", wallTime: Date.now(), download: entry });
150
+ await download.saveAs(entry.outputFile);
151
+ entry.finished = true;
152
+ this._addLogEntry({ type: "download-finish", wallTime: Date.now(), download: entry });
153
+ }
154
+ _clearCollectedArtifacts() {
155
+ this._downloads.length = 0;
156
+ this._requests.length = 0;
157
+ this._recentEventEntries.length = 0;
158
+ this._resetLogs();
159
+ }
160
+ _resetLogs() {
161
+ const wallTime = Date.now();
162
+ this._consoleLog.stop();
163
+ this._consoleLog = new import_logFile.LogFile(this.context, wallTime, "console", "Console");
164
+ }
165
+ _handleRequest(request) {
166
+ this._requests.push(request);
167
+ const wallTime = request.timing().startTime || Date.now();
168
+ this._addLogEntry({ type: "request", wallTime, request });
169
+ }
170
+ _handleResponse(response) {
171
+ const timing = response.request().timing();
172
+ const wallTime = timing.responseStart + timing.startTime;
173
+ this._addLogEntry({ type: "request", wallTime, request: response.request() });
174
+ }
175
+ _handleRequestFailed(request) {
176
+ this._requests.push(request);
177
+ const timing = request.timing();
178
+ const wallTime = timing.responseEnd + timing.startTime;
179
+ this._addLogEntry({ type: "request", wallTime, request });
180
+ }
181
+ _handleConsoleMessage(message) {
182
+ const wallTime = message.timestamp;
183
+ this._addLogEntry({ type: "console", wallTime, message });
184
+ if (shouldIncludeMessage(this.context.config.console?.level, message.type))
185
+ this._consoleLog.appendLine(wallTime, message.toString());
186
+ }
187
+ _addLogEntry(entry) {
188
+ this._recentEventEntries.push(entry);
189
+ }
190
+ _onClose() {
191
+ this._clearCollectedArtifacts();
192
+ this._onPageClose(this);
193
+ }
194
+ async headerSnapshot() {
195
+ let title;
196
+ await this._raceAgainstModalStates(async () => {
197
+ title = await this.page.title();
198
+ });
199
+ const newHeader = {
200
+ title: title ?? "",
201
+ url: this.page.url(),
202
+ current: this.isCurrentTab(),
203
+ console: await this.consoleMessageCount()
204
+ };
205
+ if (!tabHeaderEquals(this._lastHeader, newHeader)) {
206
+ this._lastHeader = newHeader;
207
+ return { ...this._lastHeader, changed: true };
208
+ }
209
+ return { ...this._lastHeader, changed: false };
210
+ }
211
+ isCurrentTab() {
212
+ return this === this.context.currentTab();
213
+ }
214
+ async waitForLoadState(state, options) {
215
+ await this._initializedPromise;
216
+ await this.page.waitForLoadState(state, options).catch((e) => (0, import_utilsBundle.debug)("pw:tools:error")(e));
217
+ }
218
+ async navigate(url2) {
219
+ await this._initializedPromise;
220
+ this._clearCollectedArtifacts();
221
+ const { promise: downloadEvent, abort: abortDownloadEvent } = (0, import_utils.eventWaiter)(this.page, "download", 3e3);
222
+ try {
223
+ await this.page.goto(url2, { waitUntil: "domcontentloaded", ...this.navigationTimeoutOptions });
224
+ abortDownloadEvent();
225
+ } catch (_e) {
226
+ const e = _e;
227
+ const mightBeDownload = e.message.includes("net::ERR_ABORTED") || e.message.includes("Download is starting");
228
+ if (!mightBeDownload)
229
+ throw e;
230
+ const download = await downloadEvent;
231
+ if (!download)
232
+ throw e;
233
+ await new Promise((resolve) => setTimeout(resolve, 500));
234
+ return;
235
+ }
236
+ await this.waitForLoadState("load", { timeout: 5e3 });
237
+ }
238
+ async consoleMessageCount() {
239
+ await this._initializedPromise;
240
+ const messages = await this.page.consoleMessages({ filter: "since-navigation" });
241
+ const pageErrors = await this.page.pageErrors({ filter: "since-navigation" });
242
+ let errors = pageErrors.length;
243
+ let warnings = 0;
244
+ for (const message of messages) {
245
+ if (message.type() === "error")
246
+ errors++;
247
+ else if (message.type() === "warning")
248
+ warnings++;
249
+ }
250
+ return { total: messages.length + pageErrors.length, errors, warnings };
251
+ }
252
+ async consoleMessages(level, all) {
253
+ await this._initializedPromise;
254
+ const result = [];
255
+ const messages = await this.page.consoleMessages({ filter: all ? "all" : "since-navigation" });
256
+ for (const message of messages) {
257
+ const cm = messageToConsoleMessage(message);
258
+ if (shouldIncludeMessage(level, cm.type))
259
+ result.push(cm);
260
+ }
261
+ if (shouldIncludeMessage(level, "error")) {
262
+ const errors = await this.page.pageErrors({ filter: all ? "all" : "since-navigation" });
263
+ for (const error of errors)
264
+ result.push(pageErrorToConsoleMessage(error));
265
+ }
266
+ return result;
267
+ }
268
+ async clearConsoleMessages() {
269
+ await this._initializedPromise;
270
+ await Promise.all([
271
+ this.page.clearConsoleMessages(),
272
+ this.page.clearPageErrors()
273
+ ]);
274
+ }
275
+ async requests() {
276
+ await this._initializedPromise;
277
+ return this._requests;
278
+ }
279
+ async clearRequests() {
280
+ await this._initializedPromise;
281
+ this._requests.length = 0;
282
+ }
283
+ async captureSnapshot(selector, depth, relativeTo) {
284
+ await this._initializedPromise;
285
+ let tabSnapshot;
286
+ const modalStates = await this._raceAgainstModalStates(async () => {
287
+ const ariaSnapshot = selector ? await this.page.locator(selector).ariaSnapshot({ mode: "ai", depth }) : await this.page.ariaSnapshot({ mode: "ai", depth });
288
+ tabSnapshot = {
289
+ ariaSnapshot,
290
+ modalStates: [],
291
+ events: []
292
+ };
293
+ });
294
+ if (tabSnapshot) {
295
+ tabSnapshot.consoleLink = await this._consoleLog.take(relativeTo);
296
+ tabSnapshot.events = this._recentEventEntries;
297
+ this._recentEventEntries = [];
298
+ }
299
+ return tabSnapshot ?? {
300
+ ariaSnapshot: "",
301
+ modalStates,
302
+ events: []
303
+ };
304
+ }
305
+ _javaScriptBlocked() {
306
+ return this._modalStates.some((state) => state.type === "dialog");
307
+ }
308
+ async _raceAgainstModalStates(action) {
309
+ if (this.modalStates().length)
310
+ return this.modalStates();
311
+ const promise = new import_manualPromise.ManualPromise();
312
+ const listener = (modalState) => promise.resolve([modalState]);
313
+ this.once(TabEvents.modalState, listener);
314
+ return await Promise.race([
315
+ action().then(() => {
316
+ this.off(TabEvents.modalState, listener);
317
+ return [];
318
+ }),
319
+ promise
320
+ ]);
321
+ }
322
+ async waitForCompletion(callback) {
323
+ await this._initializedPromise;
324
+ await this._raceAgainstModalStates(() => (0, import_utils.waitForCompletion)(this, callback));
325
+ }
326
+ async refLocator(params) {
327
+ await this._initializedPromise;
328
+ return (await this.refLocators([params]))[0];
329
+ }
330
+ async refLocators(params) {
331
+ await this._initializedPromise;
332
+ return Promise.all(params.map(async (param) => {
333
+ if (param.selector) {
334
+ const selector = (0, import_locatorParser.locatorOrSelectorAsSelector)("javascript", param.selector, this.context.config.testIdAttribute || "data-testid");
335
+ const handle = await this.page.$(selector);
336
+ if (!handle)
337
+ throw new Error(`"${param.selector}" does not match any elements.`);
338
+ handle.dispose().catch(() => {
339
+ });
340
+ return { locator: this.page.locator(selector), resolved: (0, import_locatorGenerators.asLocator)("javascript", selector) };
341
+ } else {
342
+ try {
343
+ let locator = this.page.locator(`aria-ref=${param.ref}`);
344
+ if (param.element)
345
+ locator = locator.describe(param.element);
346
+ const resolved = await locator.normalize();
347
+ return { locator, resolved: resolved.toString() };
348
+ } catch (e) {
349
+ throw new Error(`Ref ${param.ref} not found in the current page snapshot. Try capturing new snapshot.`);
350
+ }
351
+ }
352
+ }));
353
+ }
354
+ async waitForTimeout(time) {
355
+ if (this._javaScriptBlocked()) {
356
+ await new Promise((f) => setTimeout(f, time));
357
+ return;
358
+ }
359
+ await this.page.evaluate(() => new Promise((f) => setTimeout(f, 1e3))).catch(() => {
360
+ });
361
+ }
362
+ }
363
+ function messageToConsoleMessage(message) {
364
+ return {
365
+ type: message.type(),
366
+ timestamp: message.timestamp(),
367
+ text: message.text(),
368
+ toString: () => `[${message.type().toUpperCase()}] ${message.text()} @ ${message.location().url}:${message.location().lineNumber}`
369
+ };
370
+ }
371
+ function pageErrorToConsoleMessage(errorOrValue) {
372
+ if (errorOrValue instanceof Error) {
373
+ return {
374
+ type: "error",
375
+ timestamp: Date.now(),
376
+ text: errorOrValue.message,
377
+ toString: () => errorOrValue.stack || errorOrValue.message
378
+ };
379
+ }
380
+ return {
381
+ type: "error",
382
+ timestamp: Date.now(),
383
+ text: String(errorOrValue),
384
+ toString: () => String(errorOrValue)
385
+ };
386
+ }
387
+ function renderModalStates(config, modalStates) {
388
+ const result = [];
389
+ if (modalStates.length === 0)
390
+ result.push("- There is no modal state present");
391
+ for (const state of modalStates)
392
+ result.push(`- [${state.description}]: can be handled by ${config.skillMode ? state.clearedBy.skill : state.clearedBy.tool}`);
393
+ return result;
394
+ }
395
+ const consoleMessageLevels = ["error", "warning", "info", "debug"];
396
+ function shouldIncludeMessage(thresholdLevel, type) {
397
+ const messageLevel = consoleLevelForMessageType(type);
398
+ return consoleMessageLevels.indexOf(messageLevel) <= consoleMessageLevels.indexOf(thresholdLevel || "info");
399
+ }
400
+ function consoleLevelForMessageType(type) {
401
+ switch (type) {
402
+ case "assert":
403
+ case "error":
404
+ return "error";
405
+ case "warning":
406
+ return "warning";
407
+ case "count":
408
+ case "dir":
409
+ case "dirxml":
410
+ case "info":
411
+ case "log":
412
+ case "table":
413
+ case "time":
414
+ case "timeEnd":
415
+ return "info";
416
+ case "clear":
417
+ case "debug":
418
+ case "endGroup":
419
+ case "profile":
420
+ case "profileEnd":
421
+ case "startGroup":
422
+ case "startGroupCollapsed":
423
+ case "trace":
424
+ return "debug";
425
+ default:
426
+ return "info";
427
+ }
428
+ }
429
+ const tabSymbol = Symbol("tabSymbol");
430
+ function sanitizeForFilePath(s) {
431
+ const sanitize = (s2) => s2.replace(/[\x00-\x2C\x2E-\x2F\x3A-\x40\x5B-\x60\x7B-\x7F]+/g, "-");
432
+ const separator = s.lastIndexOf(".");
433
+ if (separator === -1)
434
+ return sanitize(s);
435
+ return sanitize(s.substring(0, separator)) + "." + sanitize(s.substring(separator + 1));
436
+ }
437
+ function tabHeaderEquals(a, b) {
438
+ return a.title === b.title && a.url === b.url && a.current === b.current && a.console.errors === b.console.errors && a.console.warnings === b.console.warnings && a.console.total === b.console.total;
439
+ }
440
+ // Annotate the CommonJS export names for ESM import in node:
441
+ 0 && (module.exports = {
442
+ Tab,
443
+ renderModalStates,
444
+ shouldIncludeMessage
445
+ });
@@ -0,0 +1,67 @@
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 tabs_exports = {};
20
+ __export(tabs_exports, {
21
+ default: () => tabs_default
22
+ });
23
+ module.exports = __toCommonJS(tabs_exports);
24
+ var import_zodBundle = require("../../zodBundle");
25
+ var import_tool = require("./tool");
26
+ var import_response = require("./response");
27
+ const browserTabs = (0, import_tool.defineTool)({
28
+ capability: "core-tabs",
29
+ schema: {
30
+ name: "browser_tabs",
31
+ title: "Manage tabs",
32
+ description: "List, create, close, or select a browser tab.",
33
+ inputSchema: import_zodBundle.z.object({
34
+ action: import_zodBundle.z.enum(["list", "new", "close", "select"]).describe("Operation to perform"),
35
+ index: import_zodBundle.z.number().optional().describe("Tab index, used for close/select. If omitted for close, current tab is closed.")
36
+ }),
37
+ type: "action"
38
+ },
39
+ handle: async (context, params, response) => {
40
+ switch (params.action) {
41
+ case "list": {
42
+ await context.ensureTab();
43
+ break;
44
+ }
45
+ case "new": {
46
+ await context.newTab();
47
+ break;
48
+ }
49
+ case "close": {
50
+ await context.closeTab(params.index);
51
+ break;
52
+ }
53
+ case "select": {
54
+ if (params.index === void 0)
55
+ throw new Error("Tab index is required");
56
+ await context.selectTab(params.index);
57
+ break;
58
+ }
59
+ }
60
+ const tabHeaders = await Promise.all(context.tabs().map((tab) => tab.headerSnapshot()));
61
+ const result = (0, import_response.renderTabsMarkdown)(tabHeaders);
62
+ response.addTextResult(result.join("\n"));
63
+ }
64
+ });
65
+ var tabs_default = [
66
+ browserTabs
67
+ ];
@@ -0,0 +1,47 @@
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 tool_exports = {};
20
+ __export(tool_exports, {
21
+ defineTabTool: () => defineTabTool,
22
+ defineTool: () => defineTool
23
+ });
24
+ module.exports = __toCommonJS(tool_exports);
25
+ function defineTool(tool) {
26
+ return tool;
27
+ }
28
+ function defineTabTool(tool) {
29
+ return {
30
+ ...tool,
31
+ handle: async (context, params, response) => {
32
+ const tab = await context.ensureTab();
33
+ const modalStates = tab.modalStates().map((state) => state.type);
34
+ if (tool.clearsModalState && !modalStates.includes(tool.clearsModalState))
35
+ response.addError(`Error: The tool "${tool.schema.name}" can only be used when there is related modal state present.`);
36
+ else if (!tool.clearsModalState && modalStates.length)
37
+ response.addError(`Error: Tool "${tool.schema.name}" does not handle the modal state.`);
38
+ else
39
+ return tool.handle(tab, params, response);
40
+ }
41
+ };
42
+ }
43
+ // Annotate the CommonJS export names for ESM import in node:
44
+ 0 && (module.exports = {
45
+ defineTabTool,
46
+ defineTool
47
+ });
@@ -0,0 +1,102 @@
1
+ "use strict";
2
+ var __create = Object.create;
3
+ var __defProp = Object.defineProperty;
4
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
+ var __getOwnPropNames = Object.getOwnPropertyNames;
6
+ var __getProtoOf = Object.getPrototypeOf;
7
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
8
+ var __export = (target, all) => {
9
+ for (var name in all)
10
+ __defProp(target, name, { get: all[name], enumerable: true });
11
+ };
12
+ var __copyProps = (to, from, except, desc) => {
13
+ if (from && typeof from === "object" || typeof from === "function") {
14
+ for (let key of __getOwnPropNames(from))
15
+ if (!__hasOwnProp.call(to, key) && key !== except)
16
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
17
+ }
18
+ return to;
19
+ };
20
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
21
+ // If the importer is in node compatibility mode or this is not an ESM
22
+ // file that has been converted to a CommonJS file using a Babel-
23
+ // compatible transform (i.e. "__esModule" has not been set), then set
24
+ // "default" to the CommonJS "module.exports" for node compatibility.
25
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
26
+ mod
27
+ ));
28
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
29
+ var tools_exports = {};
30
+ __export(tools_exports, {
31
+ browserTools: () => browserTools,
32
+ filteredTools: () => filteredTools
33
+ });
34
+ module.exports = __toCommonJS(tools_exports);
35
+ var import_zodBundle = require("../../zodBundle");
36
+ var import_common = __toESM(require("./common"));
37
+ var import_config = __toESM(require("./config"));
38
+ var import_console = __toESM(require("./console"));
39
+ var import_cookies = __toESM(require("./cookies"));
40
+ var import_devtools = __toESM(require("./devtools"));
41
+ var import_dialogs = __toESM(require("./dialogs"));
42
+ var import_evaluate = __toESM(require("./evaluate"));
43
+ var import_files = __toESM(require("./files"));
44
+ var import_form = __toESM(require("./form"));
45
+ var import_keyboard = __toESM(require("./keyboard"));
46
+ var import_mouse = __toESM(require("./mouse"));
47
+ var import_navigate = __toESM(require("./navigate"));
48
+ var import_network = __toESM(require("./network"));
49
+ var import_pdf = __toESM(require("./pdf"));
50
+ var import_route = __toESM(require("./route"));
51
+ var import_runCode = __toESM(require("./runCode"));
52
+ var import_snapshot = __toESM(require("./snapshot"));
53
+ var import_screenshot = __toESM(require("./screenshot"));
54
+ var import_storage = __toESM(require("./storage"));
55
+ var import_tabs = __toESM(require("./tabs"));
56
+ var import_tracing = __toESM(require("./tracing"));
57
+ var import_verify = __toESM(require("./verify"));
58
+ var import_video = __toESM(require("./video"));
59
+ var import_wait = __toESM(require("./wait"));
60
+ var import_webstorage = __toESM(require("./webstorage"));
61
+ const browserTools = [
62
+ ...import_common.default,
63
+ ...import_config.default,
64
+ ...import_console.default,
65
+ ...import_cookies.default,
66
+ ...import_devtools.default,
67
+ ...import_dialogs.default,
68
+ ...import_evaluate.default,
69
+ ...import_files.default,
70
+ ...import_form.default,
71
+ ...import_keyboard.default,
72
+ ...import_mouse.default,
73
+ ...import_navigate.default,
74
+ ...import_network.default,
75
+ ...import_pdf.default,
76
+ ...import_route.default,
77
+ ...import_runCode.default,
78
+ ...import_screenshot.default,
79
+ ...import_snapshot.default,
80
+ ...import_storage.default,
81
+ ...import_tabs.default,
82
+ ...import_tracing.default,
83
+ ...import_verify.default,
84
+ ...import_video.default,
85
+ ...import_wait.default,
86
+ ...import_webstorage.default
87
+ ];
88
+ function filteredTools(config2) {
89
+ return browserTools.filter((tool) => tool.capability.startsWith("core") || config2.capabilities?.includes(tool.capability)).filter((tool) => !tool.skillOnly).map((tool) => ({
90
+ ...tool,
91
+ schema: {
92
+ ...tool.schema,
93
+ // Note: we first ensure that "selector" property is present, so that we can omit() it without an error.
94
+ inputSchema: tool.schema.inputSchema.extend({ selector: import_zodBundle.z.string(), startSelector: import_zodBundle.z.string(), endSelector: import_zodBundle.z.string() }).omit({ selector: true, startSelector: true, endSelector: true })
95
+ }
96
+ }));
97
+ }
98
+ // Annotate the CommonJS export names for ESM import in node:
99
+ 0 && (module.exports = {
100
+ browserTools,
101
+ filteredTools
102
+ });