patchright-bun 1.58.1 → 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 (183) hide show
  1. package/README.md +225 -225
  2. package/ThirdPartyNotices.txt +3918 -5041
  3. package/cli.js +19 -19
  4. package/index.d.ts +17 -17
  5. package/index.js +17 -17
  6. package/index.mjs +18 -18
  7. package/jsx-runtime.js +42 -42
  8. package/jsx-runtime.mjs +21 -21
  9. package/lib/agents/agentParser.js +89 -89
  10. package/lib/agents/copilot-setup-steps.yml +34 -34
  11. package/lib/agents/generateAgents.js +346 -348
  12. package/lib/agents/playwright-test-coverage.prompt.md +31 -31
  13. package/lib/agents/playwright-test-generate.prompt.md +8 -8
  14. package/lib/agents/playwright-test-generator.agent.md +88 -88
  15. package/lib/agents/playwright-test-heal.prompt.md +6 -6
  16. package/lib/agents/playwright-test-healer.agent.md +55 -55
  17. package/lib/agents/playwright-test-plan.prompt.md +9 -9
  18. package/lib/agents/playwright-test-planner.agent.md +73 -73
  19. package/lib/common/config.js +281 -282
  20. package/lib/common/configLoader.js +344 -344
  21. package/lib/common/esmLoaderHost.js +104 -104
  22. package/lib/common/expectBundle.js +28 -28
  23. package/lib/common/expectBundleImpl.js +407 -407
  24. package/lib/common/fixtures.js +302 -302
  25. package/lib/common/globals.js +58 -58
  26. package/lib/common/ipc.js +60 -60
  27. package/lib/common/poolBuilder.js +85 -85
  28. package/lib/common/process.js +133 -132
  29. package/lib/common/suiteUtils.js +140 -140
  30. package/lib/common/test.js +330 -321
  31. package/lib/common/testLoader.js +101 -101
  32. package/lib/common/testType.js +301 -298
  33. package/lib/common/validators.js +68 -68
  34. package/lib/errorContext.js +121 -0
  35. package/lib/fsWatcher.js +67 -67
  36. package/lib/index.js +764 -726
  37. package/lib/internalsForTest.js +42 -42
  38. package/lib/isomorphic/events.js +77 -77
  39. package/lib/isomorphic/folders.js +30 -30
  40. package/lib/isomorphic/stringInternPool.js +69 -69
  41. package/lib/isomorphic/teleReceiver.js +538 -521
  42. package/lib/isomorphic/teleSuiteUpdater.js +157 -157
  43. package/lib/isomorphic/testServerConnection.js +223 -225
  44. package/lib/isomorphic/testServerInterface.js +16 -16
  45. package/lib/isomorphic/testTree.js +329 -329
  46. package/lib/isomorphic/types.d.js +16 -16
  47. package/lib/loader/loaderMain.js +59 -59
  48. package/lib/matchers/expect.js +311 -311
  49. package/lib/matchers/matcherHint.js +44 -44
  50. package/lib/matchers/matchers.js +385 -383
  51. package/lib/matchers/toBeTruthy.js +75 -75
  52. package/lib/matchers/toEqual.js +100 -100
  53. package/lib/matchers/toHaveURL.js +101 -101
  54. package/lib/matchers/toMatchAriaSnapshot.js +163 -159
  55. package/lib/matchers/toMatchSnapshot.js +349 -342
  56. package/lib/matchers/toMatchText.js +99 -99
  57. package/lib/mcp/test/browserBackend.js +121 -98
  58. package/lib/mcp/test/generatorTools.js +122 -122
  59. package/lib/mcp/test/plannerTools.js +145 -145
  60. package/lib/mcp/test/seed.js +82 -82
  61. package/lib/mcp/test/streams.js +44 -44
  62. package/lib/mcp/test/testBackend.js +99 -99
  63. package/lib/mcp/test/testContext.js +283 -285
  64. package/lib/mcp/test/testTool.js +30 -30
  65. package/lib/mcp/test/testTools.js +108 -108
  66. package/lib/plugins/gitCommitInfoPlugin.js +198 -198
  67. package/lib/plugins/index.js +28 -28
  68. package/lib/plugins/webServerPlugin.js +238 -237
  69. package/lib/program.js +239 -417
  70. package/lib/reportActions.js +80 -0
  71. package/lib/reporters/base.js +633 -634
  72. package/lib/reporters/blob.js +138 -138
  73. package/lib/reporters/dot.js +99 -99
  74. package/lib/reporters/empty.js +32 -32
  75. package/lib/reporters/github.js +127 -128
  76. package/lib/reporters/html.js +666 -633
  77. package/lib/reporters/internalReporter.js +138 -138
  78. package/lib/reporters/json.js +254 -254
  79. package/lib/reporters/junit.js +321 -232
  80. package/lib/reporters/line.js +131 -131
  81. package/lib/reporters/list.js +252 -253
  82. package/lib/reporters/listModeReporter.js +69 -69
  83. package/lib/reporters/markdown.js +144 -144
  84. package/lib/reporters/merge.js +579 -558
  85. package/lib/reporters/multiplexer.js +116 -112
  86. package/lib/reporters/reporterV2.js +102 -102
  87. package/lib/reporters/teleEmitter.js +319 -317
  88. package/lib/reporters/versions/blobV1.js +16 -16
  89. package/lib/runner/dispatcher.js +522 -530
  90. package/lib/runner/failureTracker.js +72 -72
  91. package/lib/runner/lastRun.js +77 -77
  92. package/lib/runner/loadUtils.js +340 -334
  93. package/lib/runner/loaderHost.js +89 -89
  94. package/lib/runner/processHost.js +180 -180
  95. package/lib/runner/projectUtils.js +241 -241
  96. package/lib/runner/rebase.js +189 -189
  97. package/lib/runner/reporters.js +143 -138
  98. package/lib/runner/sigIntWatcher.js +96 -96
  99. package/lib/runner/taskRunner.js +127 -127
  100. package/lib/runner/tasks.js +413 -410
  101. package/lib/runner/testGroups.js +125 -125
  102. package/lib/runner/testRunner.js +398 -398
  103. package/lib/runner/testServer.js +269 -269
  104. package/lib/runner/uiModeReporter.js +30 -30
  105. package/lib/runner/vcs.js +72 -72
  106. package/lib/runner/watchMode.js +396 -396
  107. package/lib/runner/workerHost.js +101 -104
  108. package/lib/testActions.js +220 -0
  109. package/lib/third_party/pirates.js +62 -62
  110. package/lib/third_party/tsconfig-loader.js +103 -103
  111. package/lib/transform/babelBundle.js +43 -46
  112. package/lib/transform/babelBundleImpl.js +461 -461
  113. package/lib/transform/compilationCache.js +272 -274
  114. package/lib/transform/esmLoader.js +105 -103
  115. package/lib/transform/portTransport.js +67 -67
  116. package/lib/transform/transform.js +296 -303
  117. package/lib/util.js +400 -400
  118. package/lib/utilsBundle.js +43 -50
  119. package/lib/utilsBundleImpl.js +100 -103
  120. package/lib/worker/fixtureRunner.js +262 -262
  121. package/lib/worker/testInfo.js +532 -536
  122. package/lib/worker/testTracing.js +351 -345
  123. package/lib/worker/timeoutManager.js +185 -174
  124. package/lib/worker/util.js +31 -31
  125. package/lib/worker/workerMain.js +533 -530
  126. package/package.json +2 -6
  127. package/test.d.ts +18 -18
  128. package/test.js +24 -24
  129. package/test.mjs +34 -34
  130. package/types/test.d.ts +10322 -10251
  131. package/types/testReporter.d.ts +822 -822
  132. package/lib/mcp/browser/browserContextFactory.js +0 -329
  133. package/lib/mcp/browser/browserServerBackend.js +0 -84
  134. package/lib/mcp/browser/config.js +0 -421
  135. package/lib/mcp/browser/context.js +0 -244
  136. package/lib/mcp/browser/response.js +0 -278
  137. package/lib/mcp/browser/sessionLog.js +0 -75
  138. package/lib/mcp/browser/tab.js +0 -343
  139. package/lib/mcp/browser/tools/common.js +0 -65
  140. package/lib/mcp/browser/tools/console.js +0 -46
  141. package/lib/mcp/browser/tools/dialogs.js +0 -60
  142. package/lib/mcp/browser/tools/evaluate.js +0 -61
  143. package/lib/mcp/browser/tools/files.js +0 -58
  144. package/lib/mcp/browser/tools/form.js +0 -63
  145. package/lib/mcp/browser/tools/install.js +0 -72
  146. package/lib/mcp/browser/tools/keyboard.js +0 -107
  147. package/lib/mcp/browser/tools/mouse.js +0 -107
  148. package/lib/mcp/browser/tools/navigate.js +0 -71
  149. package/lib/mcp/browser/tools/network.js +0 -63
  150. package/lib/mcp/browser/tools/open.js +0 -57
  151. package/lib/mcp/browser/tools/pdf.js +0 -49
  152. package/lib/mcp/browser/tools/runCode.js +0 -78
  153. package/lib/mcp/browser/tools/screenshot.js +0 -93
  154. package/lib/mcp/browser/tools/snapshot.js +0 -173
  155. package/lib/mcp/browser/tools/tabs.js +0 -67
  156. package/lib/mcp/browser/tools/tool.js +0 -47
  157. package/lib/mcp/browser/tools/tracing.js +0 -74
  158. package/lib/mcp/browser/tools/utils.js +0 -94
  159. package/lib/mcp/browser/tools/verify.js +0 -143
  160. package/lib/mcp/browser/tools/wait.js +0 -63
  161. package/lib/mcp/browser/tools.js +0 -84
  162. package/lib/mcp/browser/watchdog.js +0 -44
  163. package/lib/mcp/config.d.js +0 -16
  164. package/lib/mcp/extension/cdpRelay.js +0 -351
  165. package/lib/mcp/extension/extensionContextFactory.js +0 -76
  166. package/lib/mcp/extension/protocol.js +0 -28
  167. package/lib/mcp/index.js +0 -61
  168. package/lib/mcp/log.js +0 -35
  169. package/lib/mcp/program.js +0 -111
  170. package/lib/mcp/sdk/exports.js +0 -28
  171. package/lib/mcp/sdk/http.js +0 -152
  172. package/lib/mcp/sdk/inProcessTransport.js +0 -71
  173. package/lib/mcp/sdk/server.js +0 -223
  174. package/lib/mcp/sdk/tool.js +0 -47
  175. package/lib/mcp/terminal/cli.js +0 -296
  176. package/lib/mcp/terminal/command.js +0 -56
  177. package/lib/mcp/terminal/commands.js +0 -333
  178. package/lib/mcp/terminal/daemon.js +0 -129
  179. package/lib/mcp/terminal/help.json +0 -32
  180. package/lib/mcp/terminal/helpGenerator.js +0 -88
  181. package/lib/mcp/terminal/socketConnection.js +0 -80
  182. package/lib/runner/storage.js +0 -91
  183. package/lib/transform/md.js +0 -221
@@ -1,296 +0,0 @@
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 __copyProps = (to, from, except, desc) => {
9
- if (from && typeof from === "object" || typeof from === "function") {
10
- for (let key of __getOwnPropNames(from))
11
- if (!__hasOwnProp.call(to, key) && key !== except)
12
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
13
- }
14
- return to;
15
- };
16
- var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
17
- // If the importer is in node compatibility mode or this is not an ESM
18
- // file that has been converted to a CommonJS file using a Babel-
19
- // compatible transform (i.e. "__esModule" has not been set), then set
20
- // "default" to the CommonJS "module.exports" for node compatibility.
21
- isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
22
- mod
23
- ));
24
- var import_child_process = require("child_process");
25
- var import_crypto = __toESM(require("crypto"));
26
- var import_fs = __toESM(require("fs"));
27
- var import_net = __toESM(require("net"));
28
- var import_os = __toESM(require("os"));
29
- var import_path = __toESM(require("path"));
30
- var import_utilsBundle = require("patchright-core/lib/utilsBundle");
31
- var import_socketConnection = require("./socketConnection");
32
- const debugCli = (0, import_utilsBundle.debug)("pw:cli");
33
- const packageJSON = require("../../../package.json");
34
- async function runCliCommand(sessionName, args) {
35
- const session = await connectToDaemon(sessionName);
36
- const result = await session.runCliCommand(args);
37
- console.log(result);
38
- session.dispose();
39
- }
40
- async function socketExists(socketPath) {
41
- try {
42
- const stat = await import_fs.default.promises.stat(socketPath);
43
- if (stat?.isSocket())
44
- return true;
45
- } catch (e) {
46
- }
47
- return false;
48
- }
49
- class SocketSession {
50
- constructor(connection) {
51
- this._nextMessageId = 1;
52
- this._callbacks = /* @__PURE__ */ new Map();
53
- this._connection = connection;
54
- this._connection.onmessage = (message) => this._onMessage(message);
55
- this._connection.onclose = () => this.dispose();
56
- }
57
- async callTool(name, args) {
58
- return this._send(name, args);
59
- }
60
- async runCliCommand(args) {
61
- return await this._send("runCliCommand", { args });
62
- }
63
- async _send(method, params = {}) {
64
- const messageId = this._nextMessageId++;
65
- const message = {
66
- id: messageId,
67
- method,
68
- params
69
- };
70
- await this._connection.send(message);
71
- return new Promise((resolve, reject) => {
72
- this._callbacks.set(messageId, { resolve, reject });
73
- });
74
- }
75
- dispose() {
76
- for (const callback of this._callbacks.values())
77
- callback.reject(new Error("Disposed"));
78
- this._callbacks.clear();
79
- this._connection.close();
80
- }
81
- _onMessage(object) {
82
- if (object.id && this._callbacks.has(object.id)) {
83
- const callback = this._callbacks.get(object.id);
84
- this._callbacks.delete(object.id);
85
- if (object.error)
86
- callback.reject(new Error(object.error));
87
- else
88
- callback.resolve(object.result);
89
- } else if (object.id) {
90
- throw new Error(`Unexpected message id: ${object.id}`);
91
- } else {
92
- throw new Error(`Unexpected message without id: ${JSON.stringify(object)}`);
93
- }
94
- }
95
- }
96
- function localCacheDir() {
97
- if (process.platform === "linux")
98
- return process.env.XDG_CACHE_HOME || import_path.default.join(import_os.default.homedir(), ".cache");
99
- if (process.platform === "darwin")
100
- return import_path.default.join(import_os.default.homedir(), "Library", "Caches");
101
- if (process.platform === "win32")
102
- return process.env.LOCALAPPDATA || import_path.default.join(import_os.default.homedir(), "AppData", "Local");
103
- throw new Error("Unsupported platform: " + process.platform);
104
- }
105
- function playwrightCacheDir() {
106
- return import_path.default.join(localCacheDir(), "ms-playwright");
107
- }
108
- function calculateSha1(buffer) {
109
- const hash = import_crypto.default.createHash("sha1");
110
- hash.update(buffer);
111
- return hash.digest("hex");
112
- }
113
- function socketDirHash() {
114
- return calculateSha1(__dirname);
115
- }
116
- function daemonSocketDir() {
117
- return import_path.default.resolve(playwrightCacheDir(), "daemon", socketDirHash());
118
- }
119
- function daemonSocketPath(sessionName) {
120
- const socketName = `${sessionName}.sock`;
121
- if (import_os.default.platform() === "win32")
122
- return `\\\\.\\pipe\\${socketDirHash()}-${socketName}`;
123
- return import_path.default.resolve(daemonSocketDir(), socketName);
124
- }
125
- async function connectToDaemon(sessionName) {
126
- const socketPath = daemonSocketPath(sessionName);
127
- debugCli(`Connecting to daemon at ${socketPath}`);
128
- if (await socketExists(socketPath)) {
129
- debugCli(`Socket file exists, attempting to connect...`);
130
- try {
131
- return await connectToSocket(socketPath);
132
- } catch (e) {
133
- if (import_os.default.platform() !== "win32")
134
- await import_fs.default.promises.unlink(socketPath).catch(() => {
135
- });
136
- }
137
- }
138
- const cliPath = import_path.default.join(__dirname, "../../../cli.js");
139
- debugCli(`Will launch daemon process: ${cliPath}`);
140
- const userDataDir = import_path.default.resolve(daemonSocketDir(), `${sessionName}-user-data`);
141
- const child = (0, import_child_process.spawn)(process.execPath, [cliPath, "run-mcp-server", `--daemon=${socketPath}`, `--user-data-dir=${userDataDir}`], {
142
- detached: true,
143
- stdio: "ignore",
144
- cwd: process.cwd()
145
- // Will be used as root.
146
- });
147
- child.unref();
148
- const maxRetries = 50;
149
- const retryDelay = 100;
150
- for (let i = 0; i < maxRetries; i++) {
151
- await new Promise((resolve) => setTimeout(resolve, 100));
152
- try {
153
- return await connectToSocket(socketPath);
154
- } catch (e) {
155
- if (e.code !== "ENOENT")
156
- throw e;
157
- debugCli(`Retrying to connect to daemon at ${socketPath} (${i + 1}/${maxRetries})`);
158
- }
159
- }
160
- throw new Error(`Failed to connect to daemon at ${socketPath} after ${maxRetries * retryDelay}ms`);
161
- }
162
- async function connectToSocket(socketPath) {
163
- const socket = await new Promise((resolve, reject) => {
164
- const socket2 = import_net.default.createConnection(socketPath, () => {
165
- debugCli(`Connected to daemon at ${socketPath}`);
166
- resolve(socket2);
167
- });
168
- socket2.on("error", reject);
169
- });
170
- return new SocketSession(new import_socketConnection.SocketConnection(socket));
171
- }
172
- function currentSessionPath() {
173
- return import_path.default.resolve(daemonSocketDir(), "current-session");
174
- }
175
- async function getCurrentSession() {
176
- try {
177
- const session = await import_fs.default.promises.readFile(currentSessionPath(), "utf-8");
178
- return session.trim() || "default";
179
- } catch {
180
- return "default";
181
- }
182
- }
183
- async function setCurrentSession(sessionName) {
184
- await import_fs.default.promises.mkdir(daemonSocketDir(), { recursive: true });
185
- await import_fs.default.promises.writeFile(currentSessionPath(), sessionName);
186
- }
187
- async function canConnectToSocket(socketPath) {
188
- return new Promise((resolve) => {
189
- const socket = import_net.default.createConnection(socketPath, () => {
190
- socket.destroy();
191
- resolve(true);
192
- });
193
- socket.on("error", () => {
194
- resolve(false);
195
- });
196
- });
197
- }
198
- async function listSessions() {
199
- const dir = daemonSocketDir();
200
- try {
201
- const files = await import_fs.default.promises.readdir(dir);
202
- const sessions = [];
203
- for (const file of files) {
204
- if (file.endsWith("-user-data")) {
205
- const sessionName = file.slice(0, -"-user-data".length);
206
- const socketPath = daemonSocketPath(sessionName);
207
- const live = await canConnectToSocket(socketPath);
208
- sessions.push({ name: sessionName, live });
209
- }
210
- }
211
- return sessions;
212
- } catch {
213
- return [];
214
- }
215
- }
216
- function resolveSessionName(args) {
217
- if (args.session)
218
- return args.session;
219
- if (process.env.PLAYWRIGHT_CLI_SESSION)
220
- return process.env.PLAYWRIGHT_CLI_SESSION;
221
- return "default";
222
- }
223
- async function handleSessionCommand(args) {
224
- const subcommand = args._[1];
225
- if (!subcommand) {
226
- const current = await getCurrentSession();
227
- console.log(current);
228
- return;
229
- }
230
- if (subcommand === "list") {
231
- const sessions = await listSessions();
232
- const current = await getCurrentSession();
233
- console.log("Sessions:");
234
- for (const session of sessions) {
235
- const marker = session.name === current ? "->" : " ";
236
- const liveMarker = session.live ? " (live)" : "";
237
- console.log(`${marker} ${session.name}${liveMarker}`);
238
- }
239
- if (sessions.length === 0)
240
- console.log(" (no sessions)");
241
- return;
242
- }
243
- if (subcommand === "set") {
244
- const sessionName = args._[2];
245
- if (!sessionName) {
246
- console.error("Usage: playwright-cli session set <session-name>");
247
- process.exit(1);
248
- }
249
- await setCurrentSession(sessionName);
250
- console.log(`Current session set to: ${sessionName}`);
251
- return;
252
- }
253
- console.error(`Unknown session subcommand: ${subcommand}`);
254
- process.exit(1);
255
- }
256
- async function main() {
257
- const argv = process.argv.slice(2);
258
- const args = require("minimist")(argv);
259
- const help = require("./help.json");
260
- const commandName = args._[0];
261
- if (args.version || args.v) {
262
- console.log(packageJSON.version);
263
- process.exit(0);
264
- }
265
- if (commandName === "session") {
266
- await handleSessionCommand(args);
267
- return;
268
- }
269
- const command = help.commands[commandName];
270
- if (args.help || args.h) {
271
- if (command) {
272
- console.log(command);
273
- } else {
274
- console.log("playwright-cli - run playwright mcp commands from terminal\n");
275
- console.log(help.global);
276
- }
277
- process.exit(0);
278
- }
279
- if (!command) {
280
- console.error(`Unknown command: ${commandName}
281
- `);
282
- console.log(help.global);
283
- process.exit(1);
284
- }
285
- let sessionName = resolveSessionName(args);
286
- if (sessionName === "default" && !args.session && !process.env.PLAYWRIGHT_CLI_SESSION)
287
- sessionName = await getCurrentSession();
288
- runCliCommand(sessionName, args).catch((e) => {
289
- console.error(e.message);
290
- process.exit(1);
291
- });
292
- }
293
- main().catch((e) => {
294
- console.error(e.message);
295
- process.exit(1);
296
- });
@@ -1,56 +0,0 @@
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 command_exports = {};
20
- __export(command_exports, {
21
- declareCommand: () => declareCommand,
22
- parseCommand: () => parseCommand
23
- });
24
- module.exports = __toCommonJS(command_exports);
25
- function declareCommand(command) {
26
- return command;
27
- }
28
- function parseCommand(command, args) {
29
- const shape = command.args ? command.args.shape : {};
30
- const argv = args["_"];
31
- const options = command.options?.parse({ ...args, _: void 0 }) ?? {};
32
- const argsObject = {};
33
- let i = 0;
34
- for (const name of Object.keys(shape))
35
- argsObject[name] = argv[++i];
36
- let parsedArgsObject = {};
37
- try {
38
- parsedArgsObject = command.args?.parse(argsObject) ?? {};
39
- } catch (e) {
40
- throw new Error(formatZodError(e));
41
- }
42
- const toolName = typeof command.toolName === "function" ? command.toolName(parsedArgsObject, options) : command.toolName;
43
- const toolParams = command.toolParams(parsedArgsObject, options);
44
- return { toolName, toolParams };
45
- }
46
- function formatZodError(error) {
47
- const issue = error.issues[0];
48
- if (issue.code === "invalid_type")
49
- return `${issue.message} in <${issue.path.join(".")}>`;
50
- return error.issues.map((i) => i.message).join("\n");
51
- }
52
- // Annotate the CommonJS export names for ESM import in node:
53
- 0 && (module.exports = {
54
- declareCommand,
55
- parseCommand
56
- });
@@ -1,333 +0,0 @@
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 commands_exports = {};
20
- __export(commands_exports, {
21
- commands: () => commands
22
- });
23
- module.exports = __toCommonJS(commands_exports);
24
- var import_mcpBundle = require("patchright-core/lib/mcpBundle");
25
- var import_command = require("./command");
26
- const click = (0, import_command.declareCommand)({
27
- name: "click",
28
- description: "Perform click on a web page",
29
- args: import_mcpBundle.z.object({
30
- ref: import_mcpBundle.z.string().describe("Exact target element reference from the page snapshot")
31
- }),
32
- options: import_mcpBundle.z.object({
33
- button: import_mcpBundle.z.string().optional().describe("Button to click, defaults to left"),
34
- modifiers: import_mcpBundle.z.array(import_mcpBundle.z.string()).optional().describe("Modifier keys to press")
35
- }),
36
- toolName: "browser_click",
37
- toolParams: ({ ref }, { button, modifiers }) => ({ ref, button, modifiers })
38
- });
39
- const doubleClick = (0, import_command.declareCommand)({
40
- name: "dblclick",
41
- description: "Perform double click on a web page",
42
- args: import_mcpBundle.z.object({
43
- ref: import_mcpBundle.z.string().describe("Exact target element reference from the page snapshot")
44
- }),
45
- options: import_mcpBundle.z.object({
46
- button: import_mcpBundle.z.string().optional().describe("Button to click, defaults to left"),
47
- modifiers: import_mcpBundle.z.array(import_mcpBundle.z.string()).optional().describe("Modifier keys to press")
48
- }),
49
- toolName: "browser_click",
50
- toolParams: ({ ref }, { button, modifiers }) => ({ ref, button, modifiers, doubleClick: true })
51
- });
52
- const close = (0, import_command.declareCommand)({
53
- name: "close",
54
- description: "Close the page",
55
- args: import_mcpBundle.z.object({}),
56
- toolName: "browser_close",
57
- toolParams: () => ({})
58
- });
59
- const consoleMessages = (0, import_command.declareCommand)({
60
- name: "console",
61
- description: "Returns all console messages",
62
- args: import_mcpBundle.z.object({
63
- level: import_mcpBundle.z.string().optional().describe('Level of the console messages to return. Each level includes the messages of more severe levels. Defaults to "info".')
64
- }),
65
- toolName: "browser_console_messages",
66
- toolParams: ({ level }) => ({ level })
67
- });
68
- const drag = (0, import_command.declareCommand)({
69
- name: "drag",
70
- description: "Perform drag and drop between two elements",
71
- args: import_mcpBundle.z.object({
72
- startRef: import_mcpBundle.z.string().describe("Exact source element reference from the page snapshot"),
73
- endRef: import_mcpBundle.z.string().describe("Exact target element reference from the page snapshot")
74
- }),
75
- options: import_mcpBundle.z.object({
76
- headed: import_mcpBundle.z.boolean().default(false).describe("Run browser in headed mode")
77
- }),
78
- toolName: "browser_drag",
79
- toolParams: ({ startRef, endRef }) => ({ startRef, endRef })
80
- });
81
- const evaluate = (0, import_command.declareCommand)({
82
- name: "evaluate",
83
- description: "Evaluate JavaScript expression on page or element",
84
- args: import_mcpBundle.z.object({
85
- function: import_mcpBundle.z.string().describe("() => { /* code */ } or (element) => { /* code */ } when element is provided"),
86
- ref: import_mcpBundle.z.string().optional().describe("Exact target element reference from the page snapshot")
87
- }),
88
- toolName: "browser_evaluate",
89
- toolParams: ({ function: fn, ref }) => ({ function: fn, ref })
90
- });
91
- const fileUpload = (0, import_command.declareCommand)({
92
- name: "upload-file",
93
- description: "Upload one or multiple files",
94
- args: import_mcpBundle.z.object({}),
95
- options: import_mcpBundle.z.object({
96
- paths: import_mcpBundle.z.array(import_mcpBundle.z.string()).optional().describe("The absolute paths to the files to upload. Can be single file or multiple files. If omitted, file chooser is cancelled.")
97
- }),
98
- toolName: "browser_file_upload",
99
- toolParams: (_, { paths }) => ({ paths })
100
- });
101
- const handleDialog = (0, import_command.declareCommand)({
102
- name: "handle-dialog",
103
- description: "Handle a dialog",
104
- args: import_mcpBundle.z.object({
105
- accept: import_mcpBundle.z.boolean().describe("Whether to accept the dialog."),
106
- promptText: import_mcpBundle.z.string().optional().describe("The text of the prompt in case of a prompt dialog.")
107
- }),
108
- toolName: "browser_handle_dialog",
109
- toolParams: ({ accept, promptText }) => ({ accept, promptText })
110
- });
111
- const hover = (0, import_command.declareCommand)({
112
- name: "hover",
113
- description: "Hover over element on page",
114
- args: import_mcpBundle.z.object({
115
- ref: import_mcpBundle.z.string().describe("Exact target element reference from the page snapshot")
116
- }),
117
- toolName: "browser_hover",
118
- toolParams: ({ ref }) => ({ ref })
119
- });
120
- const open = (0, import_command.declareCommand)({
121
- name: "open",
122
- description: "Open URL",
123
- args: import_mcpBundle.z.object({
124
- url: import_mcpBundle.z.string().describe("The URL to navigate to")
125
- }),
126
- options: import_mcpBundle.z.object({
127
- headed: import_mcpBundle.z.boolean().default(false).describe("Run browser in headed mode")
128
- }),
129
- toolName: "browser_open",
130
- toolParams: ({ url }, { headed }) => ({ url, headed })
131
- });
132
- const navigateBack = (0, import_command.declareCommand)({
133
- name: "go-back",
134
- description: "Go back to the previous page",
135
- args: import_mcpBundle.z.object({}),
136
- toolName: "browser_navigate_back",
137
- toolParams: () => ({})
138
- });
139
- const networkRequests = (0, import_command.declareCommand)({
140
- name: "network-requests",
141
- description: "Returns all network requests since loading the page",
142
- args: import_mcpBundle.z.object({}),
143
- options: import_mcpBundle.z.object({
144
- includeStatic: import_mcpBundle.z.boolean().optional().describe("Whether to include successful static resources like images, fonts, scripts, etc. Defaults to false.")
145
- }),
146
- toolName: "browser_network_requests",
147
- toolParams: (_, { includeStatic }) => ({ includeStatic })
148
- });
149
- const pressKey = (0, import_command.declareCommand)({
150
- name: "press",
151
- description: "Press a key on the keyboard",
152
- args: import_mcpBundle.z.object({
153
- key: import_mcpBundle.z.string().describe("Name of the key to press or a character to generate, such as `ArrowLeft` or `a`")
154
- }),
155
- toolName: "browser_press_key",
156
- toolParams: ({ key }) => ({ key })
157
- });
158
- const resize = (0, import_command.declareCommand)({
159
- name: "resize",
160
- description: "Resize the browser window",
161
- args: import_mcpBundle.z.object({
162
- width: import_mcpBundle.z.number().describe("Width of the browser window"),
163
- height: import_mcpBundle.z.number().describe("Height of the browser window")
164
- }),
165
- toolName: "browser_resize",
166
- toolParams: ({ width, height }) => ({ width, height })
167
- });
168
- const runCode = (0, import_command.declareCommand)({
169
- name: "run-code",
170
- description: "Run Playwright code snippet",
171
- args: import_mcpBundle.z.object({
172
- code: import_mcpBundle.z.string().describe("A JavaScript function containing Playwright code to execute. It will be invoked with a single argument, page, which you can use for any page interaction.")
173
- }),
174
- toolName: "browser_run_code",
175
- toolParams: ({ code }) => ({ code })
176
- });
177
- const selectOption = (0, import_command.declareCommand)({
178
- name: "select-option",
179
- description: "Select an option in a dropdown",
180
- args: import_mcpBundle.z.object({
181
- ref: import_mcpBundle.z.string().describe("Exact target element reference from the page snapshot"),
182
- values: import_mcpBundle.z.array(import_mcpBundle.z.string()).describe("Array of values to select in the dropdown. This can be a single value or multiple values.")
183
- }),
184
- toolName: "browser_select_option",
185
- toolParams: ({ ref, values }) => ({ ref, values })
186
- });
187
- const snapshot = (0, import_command.declareCommand)({
188
- name: "snapshot",
189
- description: "Capture accessibility snapshot of the current page, this is better than screenshot",
190
- args: import_mcpBundle.z.object({}),
191
- options: import_mcpBundle.z.object({
192
- filename: import_mcpBundle.z.string().optional().describe("Save snapshot to markdown file instead of returning it in the response.")
193
- }),
194
- toolName: "browser_snapshot",
195
- toolParams: (_, { filename }) => ({ filename })
196
- });
197
- const screenshot = (0, import_command.declareCommand)({
198
- name: "screenshot",
199
- description: "Take a screenshot of the current page. You can't perform actions based on the screenshot, use browser_snapshot for actions.",
200
- args: import_mcpBundle.z.object({
201
- ref: import_mcpBundle.z.string().optional().describe("Exact target element reference from the page snapshot.")
202
- }),
203
- options: import_mcpBundle.z.object({
204
- filename: import_mcpBundle.z.string().optional().describe("File name to save the screenshot to. Defaults to `page-{timestamp}.{png|jpeg}` if not specified."),
205
- fullPage: import_mcpBundle.z.boolean().optional().describe("When true, takes a screenshot of the full scrollable page, instead of the currently visible viewport.")
206
- }),
207
- toolName: "browser_take_screenshot",
208
- toolParams: ({ ref }, { filename, fullPage }) => ({ filename, ref, fullPage })
209
- });
210
- const type = (0, import_command.declareCommand)({
211
- name: "type",
212
- description: "Type text into editable element",
213
- args: import_mcpBundle.z.object({
214
- text: import_mcpBundle.z.string().describe("Text to type into the element")
215
- }),
216
- options: import_mcpBundle.z.object({
217
- submit: import_mcpBundle.z.boolean().optional().describe("Whether to submit entered text (press Enter after)")
218
- }),
219
- toolName: "browser_press_sequentially",
220
- toolParams: ({ text }, { submit }) => ({ text, submit })
221
- });
222
- const waitFor = (0, import_command.declareCommand)({
223
- name: "wait-for",
224
- description: "Wait for text to appear or disappear or a specified time to pass",
225
- args: import_mcpBundle.z.object({}),
226
- options: import_mcpBundle.z.object({
227
- time: import_mcpBundle.z.number().optional().describe("The time to wait in seconds"),
228
- text: import_mcpBundle.z.string().optional().describe("The text to wait for"),
229
- textGone: import_mcpBundle.z.string().optional().describe("The text to wait for to disappear")
230
- }),
231
- toolName: "browser_wait_for",
232
- toolParams: (_, { time, text, textGone }) => ({ time, text, textGone })
233
- });
234
- const tab = (0, import_command.declareCommand)({
235
- name: "tab",
236
- description: "Close a browser tab",
237
- args: import_mcpBundle.z.object({
238
- action: import_mcpBundle.z.string().describe(`Action to perform on tabs, 'list' | 'new' | 'close' | 'select'`),
239
- index: import_mcpBundle.z.number().optional().describe("Tab index. If omitted, current tab is closed.")
240
- }),
241
- toolName: "browser_tabs",
242
- toolParams: ({ action, index }) => ({ action, index })
243
- });
244
- const mouseClickXy = (0, import_command.declareCommand)({
245
- name: "mouse-click-xy",
246
- description: "Click left mouse button at a given position",
247
- args: import_mcpBundle.z.object({
248
- x: import_mcpBundle.z.number().describe("X coordinate"),
249
- y: import_mcpBundle.z.number().describe("Y coordinate")
250
- }),
251
- toolName: "browser_mouse_click_xy",
252
- toolParams: ({ x, y }) => ({ x, y })
253
- });
254
- const mouseDragXy = (0, import_command.declareCommand)({
255
- name: "mouse-drag-xy",
256
- description: "Drag left mouse button to a given position",
257
- args: import_mcpBundle.z.object({
258
- startX: import_mcpBundle.z.number().describe("Start X coordinate"),
259
- startY: import_mcpBundle.z.number().describe("Start Y coordinate"),
260
- endX: import_mcpBundle.z.number().describe("End X coordinate"),
261
- endY: import_mcpBundle.z.number().describe("End Y coordinate")
262
- }),
263
- toolName: "browser_mouse_drag_xy",
264
- toolParams: ({ startX, startY, endX, endY }) => ({ startX, startY, endX, endY })
265
- });
266
- const mouseMoveXy = (0, import_command.declareCommand)({
267
- name: "mouse-move-xy",
268
- description: "Move mouse to a given position",
269
- args: import_mcpBundle.z.object({
270
- x: import_mcpBundle.z.number().describe("X coordinate"),
271
- y: import_mcpBundle.z.number().describe("Y coordinate")
272
- }),
273
- toolName: "browser_mouse_move_xy",
274
- toolParams: ({ x, y }) => ({ x, y })
275
- });
276
- const pdfSave = (0, import_command.declareCommand)({
277
- name: "pdf-save",
278
- description: "Save page as PDF",
279
- args: import_mcpBundle.z.object({}),
280
- options: import_mcpBundle.z.object({
281
- filename: import_mcpBundle.z.string().optional().describe("File name to save the pdf to. Defaults to `page-{timestamp}.pdf` if not specified.")
282
- }),
283
- toolName: "browser_pdf_save",
284
- toolParams: (_, { filename }) => ({ filename })
285
- });
286
- const startTracing = (0, import_command.declareCommand)({
287
- name: "start-tracing",
288
- description: "Start trace recording",
289
- args: import_mcpBundle.z.object({}),
290
- toolName: "browser_start_tracing",
291
- toolParams: () => ({})
292
- });
293
- const stopTracing = (0, import_command.declareCommand)({
294
- name: "stop-tracing",
295
- description: "Stop trace recording",
296
- args: import_mcpBundle.z.object({}),
297
- toolName: "browser_stop_tracing",
298
- toolParams: () => ({})
299
- });
300
- const commandsArray = [
301
- click,
302
- close,
303
- doubleClick,
304
- consoleMessages,
305
- drag,
306
- evaluate,
307
- fileUpload,
308
- handleDialog,
309
- hover,
310
- open,
311
- navigateBack,
312
- networkRequests,
313
- pressKey,
314
- resize,
315
- runCode,
316
- selectOption,
317
- snapshot,
318
- screenshot,
319
- type,
320
- waitFor,
321
- tab,
322
- mouseClickXy,
323
- mouseDragXy,
324
- mouseMoveXy,
325
- pdfSave,
326
- startTracing,
327
- stopTracing
328
- ];
329
- const commands = Object.fromEntries(commandsArray.map((cmd) => [cmd.name, cmd]));
330
- // Annotate the CommonJS export names for ESM import in node:
331
- 0 && (module.exports = {
332
- commands
333
- });