patchright-bun 1.58.0 → 1.58.2

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 (180) hide show
  1. package/README.md +225 -225
  2. package/ThirdPartyNotices.txt +5041 -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 +348 -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 +282 -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 +132 -132
  29. package/lib/common/suiteUtils.js +140 -140
  30. package/lib/common/test.js +321 -321
  31. package/lib/common/testLoader.js +101 -101
  32. package/lib/common/testType.js +298 -298
  33. package/lib/common/validators.js +68 -68
  34. package/lib/fsWatcher.js +67 -67
  35. package/lib/index.js +726 -726
  36. package/lib/internalsForTest.js +42 -42
  37. package/lib/isomorphic/events.js +77 -77
  38. package/lib/isomorphic/folders.js +30 -30
  39. package/lib/isomorphic/stringInternPool.js +69 -69
  40. package/lib/isomorphic/teleReceiver.js +521 -521
  41. package/lib/isomorphic/teleSuiteUpdater.js +157 -157
  42. package/lib/isomorphic/testServerConnection.js +225 -225
  43. package/lib/isomorphic/testServerInterface.js +16 -16
  44. package/lib/isomorphic/testTree.js +329 -329
  45. package/lib/isomorphic/types.d.js +16 -16
  46. package/lib/loader/loaderMain.js +59 -59
  47. package/lib/matchers/expect.js +311 -311
  48. package/lib/matchers/matcherHint.js +44 -44
  49. package/lib/matchers/matchers.js +383 -383
  50. package/lib/matchers/toBeTruthy.js +75 -75
  51. package/lib/matchers/toEqual.js +100 -100
  52. package/lib/matchers/toHaveURL.js +101 -101
  53. package/lib/matchers/toMatchAriaSnapshot.js +159 -159
  54. package/lib/matchers/toMatchSnapshot.js +342 -342
  55. package/lib/matchers/toMatchText.js +99 -99
  56. package/lib/mcp/browser/browserContextFactory.js +329 -329
  57. package/lib/mcp/browser/browserServerBackend.js +84 -84
  58. package/lib/mcp/browser/config.js +421 -421
  59. package/lib/mcp/browser/context.js +244 -244
  60. package/lib/mcp/browser/response.js +278 -278
  61. package/lib/mcp/browser/sessionLog.js +75 -75
  62. package/lib/mcp/browser/tab.js +343 -343
  63. package/lib/mcp/browser/tools/common.js +65 -65
  64. package/lib/mcp/browser/tools/console.js +46 -46
  65. package/lib/mcp/browser/tools/dialogs.js +60 -60
  66. package/lib/mcp/browser/tools/evaluate.js +61 -61
  67. package/lib/mcp/browser/tools/files.js +58 -58
  68. package/lib/mcp/browser/tools/form.js +63 -63
  69. package/lib/mcp/browser/tools/install.js +72 -72
  70. package/lib/mcp/browser/tools/keyboard.js +107 -107
  71. package/lib/mcp/browser/tools/mouse.js +107 -107
  72. package/lib/mcp/browser/tools/navigate.js +71 -71
  73. package/lib/mcp/browser/tools/network.js +63 -63
  74. package/lib/mcp/browser/tools/open.js +57 -57
  75. package/lib/mcp/browser/tools/pdf.js +49 -49
  76. package/lib/mcp/browser/tools/runCode.js +78 -78
  77. package/lib/mcp/browser/tools/screenshot.js +93 -93
  78. package/lib/mcp/browser/tools/snapshot.js +173 -173
  79. package/lib/mcp/browser/tools/tabs.js +67 -67
  80. package/lib/mcp/browser/tools/tool.js +47 -47
  81. package/lib/mcp/browser/tools/tracing.js +74 -74
  82. package/lib/mcp/browser/tools/utils.js +94 -94
  83. package/lib/mcp/browser/tools/verify.js +143 -143
  84. package/lib/mcp/browser/tools/wait.js +63 -63
  85. package/lib/mcp/browser/tools.js +84 -84
  86. package/lib/mcp/browser/watchdog.js +44 -44
  87. package/lib/mcp/config.d.js +16 -16
  88. package/lib/mcp/extension/cdpRelay.js +351 -351
  89. package/lib/mcp/extension/extensionContextFactory.js +76 -76
  90. package/lib/mcp/extension/protocol.js +28 -28
  91. package/lib/mcp/index.js +61 -61
  92. package/lib/mcp/log.js +35 -35
  93. package/lib/mcp/program.js +111 -111
  94. package/lib/mcp/sdk/exports.js +28 -28
  95. package/lib/mcp/sdk/http.js +152 -152
  96. package/lib/mcp/sdk/inProcessTransport.js +71 -71
  97. package/lib/mcp/sdk/server.js +223 -223
  98. package/lib/mcp/sdk/tool.js +47 -47
  99. package/lib/mcp/terminal/cli.js +296 -296
  100. package/lib/mcp/terminal/command.js +56 -56
  101. package/lib/mcp/terminal/commands.js +333 -333
  102. package/lib/mcp/terminal/daemon.js +129 -129
  103. package/lib/mcp/terminal/help.json +31 -31
  104. package/lib/mcp/terminal/helpGenerator.js +88 -88
  105. package/lib/mcp/terminal/socketConnection.js +80 -80
  106. package/lib/mcp/test/browserBackend.js +98 -98
  107. package/lib/mcp/test/generatorTools.js +122 -122
  108. package/lib/mcp/test/plannerTools.js +145 -145
  109. package/lib/mcp/test/seed.js +82 -82
  110. package/lib/mcp/test/streams.js +44 -44
  111. package/lib/mcp/test/testBackend.js +99 -99
  112. package/lib/mcp/test/testContext.js +285 -285
  113. package/lib/mcp/test/testTool.js +30 -30
  114. package/lib/mcp/test/testTools.js +108 -108
  115. package/lib/plugins/gitCommitInfoPlugin.js +198 -198
  116. package/lib/plugins/index.js +28 -28
  117. package/lib/plugins/webServerPlugin.js +237 -237
  118. package/lib/program.js +417 -417
  119. package/lib/reporters/base.js +634 -634
  120. package/lib/reporters/blob.js +138 -138
  121. package/lib/reporters/dot.js +99 -99
  122. package/lib/reporters/empty.js +32 -32
  123. package/lib/reporters/github.js +128 -128
  124. package/lib/reporters/html.js +633 -633
  125. package/lib/reporters/internalReporter.js +138 -138
  126. package/lib/reporters/json.js +254 -254
  127. package/lib/reporters/junit.js +232 -232
  128. package/lib/reporters/line.js +131 -131
  129. package/lib/reporters/list.js +253 -253
  130. package/lib/reporters/listModeReporter.js +69 -69
  131. package/lib/reporters/markdown.js +144 -144
  132. package/lib/reporters/merge.js +558 -558
  133. package/lib/reporters/multiplexer.js +112 -112
  134. package/lib/reporters/reporterV2.js +102 -102
  135. package/lib/reporters/teleEmitter.js +317 -317
  136. package/lib/reporters/versions/blobV1.js +16 -16
  137. package/lib/runner/dispatcher.js +530 -530
  138. package/lib/runner/failureTracker.js +72 -72
  139. package/lib/runner/lastRun.js +77 -77
  140. package/lib/runner/loadUtils.js +334 -334
  141. package/lib/runner/loaderHost.js +89 -89
  142. package/lib/runner/processHost.js +180 -180
  143. package/lib/runner/projectUtils.js +241 -241
  144. package/lib/runner/rebase.js +189 -189
  145. package/lib/runner/reporters.js +138 -138
  146. package/lib/runner/sigIntWatcher.js +96 -96
  147. package/lib/runner/storage.js +91 -91
  148. package/lib/runner/taskRunner.js +127 -127
  149. package/lib/runner/tasks.js +410 -410
  150. package/lib/runner/testGroups.js +125 -125
  151. package/lib/runner/testRunner.js +398 -398
  152. package/lib/runner/testServer.js +269 -269
  153. package/lib/runner/uiModeReporter.js +30 -30
  154. package/lib/runner/vcs.js +72 -72
  155. package/lib/runner/watchMode.js +396 -396
  156. package/lib/runner/workerHost.js +104 -104
  157. package/lib/third_party/pirates.js +62 -62
  158. package/lib/third_party/tsconfig-loader.js +103 -103
  159. package/lib/transform/babelBundle.js +46 -46
  160. package/lib/transform/babelBundleImpl.js +461 -461
  161. package/lib/transform/compilationCache.js +274 -274
  162. package/lib/transform/esmLoader.js +103 -103
  163. package/lib/transform/md.js +221 -221
  164. package/lib/transform/portTransport.js +67 -67
  165. package/lib/transform/transform.js +303 -303
  166. package/lib/util.js +400 -400
  167. package/lib/utilsBundle.js +50 -50
  168. package/lib/utilsBundleImpl.js +103 -103
  169. package/lib/worker/fixtureRunner.js +262 -262
  170. package/lib/worker/testInfo.js +536 -536
  171. package/lib/worker/testTracing.js +345 -345
  172. package/lib/worker/timeoutManager.js +174 -174
  173. package/lib/worker/util.js +31 -31
  174. package/lib/worker/workerMain.js +530 -530
  175. package/package.json +2 -2
  176. package/test.d.ts +18 -18
  177. package/test.js +24 -24
  178. package/test.mjs +34 -34
  179. package/types/test.d.ts +10251 -10251
  180. package/types/testReporter.d.ts +822 -822
@@ -1,80 +1,80 @@
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 socketConnection_exports = {};
20
- __export(socketConnection_exports, {
21
- SocketConnection: () => SocketConnection
22
- });
23
- module.exports = __toCommonJS(socketConnection_exports);
24
- var import_utilsBundle = require("patchright-core/lib/utilsBundle");
25
- const daemonDebug = (0, import_utilsBundle.debug)("pw:daemon");
26
- class SocketConnection {
27
- constructor(socket) {
28
- this._pendingBuffers = [];
29
- this._socket = socket;
30
- socket.on("data", (buffer) => this._onData(buffer));
31
- socket.on("close", () => {
32
- this.onclose?.();
33
- });
34
- socket.on("error", (e) => daemonDebug(`error: ${e.message}`));
35
- }
36
- async send(message) {
37
- await new Promise((resolve, reject) => {
38
- this._socket.write(`${JSON.stringify(message)}
39
- `, (error) => {
40
- if (error)
41
- reject(error);
42
- else
43
- resolve(void 0);
44
- });
45
- });
46
- }
47
- close() {
48
- this._socket.destroy();
49
- }
50
- _onData(buffer) {
51
- let end = buffer.indexOf("\n");
52
- if (end === -1) {
53
- this._pendingBuffers.push(buffer);
54
- return;
55
- }
56
- this._pendingBuffers.push(buffer.slice(0, end));
57
- const message = Buffer.concat(this._pendingBuffers).toString();
58
- this._dispatchMessage(message);
59
- let start = end + 1;
60
- end = buffer.indexOf("\n", start);
61
- while (end !== -1) {
62
- const message2 = buffer.toString(void 0, start, end);
63
- this._dispatchMessage(message2);
64
- start = end + 1;
65
- end = buffer.indexOf("\n", start);
66
- }
67
- this._pendingBuffers = [buffer.slice(start)];
68
- }
69
- _dispatchMessage(message) {
70
- try {
71
- this.onmessage?.(JSON.parse(message));
72
- } catch (e) {
73
- daemonDebug("failed to dispatch message", e);
74
- }
75
- }
76
- }
77
- // Annotate the CommonJS export names for ESM import in node:
78
- 0 && (module.exports = {
79
- SocketConnection
80
- });
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 socketConnection_exports = {};
20
+ __export(socketConnection_exports, {
21
+ SocketConnection: () => SocketConnection
22
+ });
23
+ module.exports = __toCommonJS(socketConnection_exports);
24
+ var import_utilsBundle = require("patchright-bun-core/lib/utilsBundle");
25
+ const daemonDebug = (0, import_utilsBundle.debug)("pw:daemon");
26
+ class SocketConnection {
27
+ constructor(socket) {
28
+ this._pendingBuffers = [];
29
+ this._socket = socket;
30
+ socket.on("data", (buffer) => this._onData(buffer));
31
+ socket.on("close", () => {
32
+ this.onclose?.();
33
+ });
34
+ socket.on("error", (e) => daemonDebug(`error: ${e.message}`));
35
+ }
36
+ async send(message) {
37
+ await new Promise((resolve, reject) => {
38
+ this._socket.write(`${JSON.stringify(message)}
39
+ `, (error) => {
40
+ if (error)
41
+ reject(error);
42
+ else
43
+ resolve(void 0);
44
+ });
45
+ });
46
+ }
47
+ close() {
48
+ this._socket.destroy();
49
+ }
50
+ _onData(buffer) {
51
+ let end = buffer.indexOf("\n");
52
+ if (end === -1) {
53
+ this._pendingBuffers.push(buffer);
54
+ return;
55
+ }
56
+ this._pendingBuffers.push(buffer.slice(0, end));
57
+ const message = Buffer.concat(this._pendingBuffers).toString();
58
+ this._dispatchMessage(message);
59
+ let start = end + 1;
60
+ end = buffer.indexOf("\n", start);
61
+ while (end !== -1) {
62
+ const message2 = buffer.toString(void 0, start, end);
63
+ this._dispatchMessage(message2);
64
+ start = end + 1;
65
+ end = buffer.indexOf("\n", start);
66
+ }
67
+ this._pendingBuffers = [buffer.slice(start)];
68
+ }
69
+ _dispatchMessage(message) {
70
+ try {
71
+ this.onmessage?.(JSON.parse(message));
72
+ } catch (e) {
73
+ daemonDebug("failed to dispatch message", e);
74
+ }
75
+ }
76
+ }
77
+ // Annotate the CommonJS export names for ESM import in node:
78
+ 0 && (module.exports = {
79
+ SocketConnection
80
+ });
@@ -1,98 +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 browserBackend_exports = {};
20
- __export(browserBackend_exports, {
21
- createCustomMessageHandler: () => createCustomMessageHandler
22
- });
23
- module.exports = __toCommonJS(browserBackend_exports);
24
- var import_config = require("../browser/config");
25
- var import_browserServerBackend = require("../browser/browserServerBackend");
26
- var import_tab = require("../browser/tab");
27
- var import_util = require("../../util");
28
- var import_browserContextFactory = require("../browser/browserContextFactory");
29
- function createCustomMessageHandler(testInfo, context) {
30
- let backend;
31
- return async (data) => {
32
- if (data.initialize) {
33
- if (backend)
34
- throw new Error("MCP backend is already initialized");
35
- backend = new import_browserServerBackend.BrowserServerBackend({ ...import_config.defaultConfig, capabilities: ["testing"] }, (0, import_browserContextFactory.identityBrowserContextFactory)(context));
36
- await backend.initialize(data.initialize.clientInfo);
37
- const pausedMessage = await generatePausedMessage(testInfo, context);
38
- return { initialize: { pausedMessage } };
39
- }
40
- if (data.listTools) {
41
- if (!backend)
42
- throw new Error("MCP backend is not initialized");
43
- return { listTools: await backend.listTools() };
44
- }
45
- if (data.callTool) {
46
- if (!backend)
47
- throw new Error("MCP backend is not initialized");
48
- return { callTool: await backend.callTool(data.callTool.name, data.callTool.arguments) };
49
- }
50
- if (data.close) {
51
- backend?.serverClosed();
52
- backend = void 0;
53
- return { close: {} };
54
- }
55
- throw new Error("Unknown MCP request");
56
- };
57
- }
58
- async function generatePausedMessage(testInfo, context) {
59
- const lines = [];
60
- if (testInfo.errors.length) {
61
- lines.push(`### Paused on error:`);
62
- for (const error of testInfo.errors)
63
- lines.push((0, import_util.stripAnsiEscapes)(error.message || ""));
64
- } else {
65
- lines.push(`### Paused at end of test. ready for interaction`);
66
- }
67
- for (let i = 0; i < context.pages().length; i++) {
68
- const page = context.pages()[i];
69
- const stateSuffix = context.pages().length > 1 ? i + 1 + " of " + context.pages().length : "state";
70
- lines.push(
71
- "",
72
- `### Page ${stateSuffix}`,
73
- `- Page URL: ${page.url()}`,
74
- `- Page Title: ${await page.title()}`.trim()
75
- );
76
- let console = testInfo.errors.length ? await import_tab.Tab.collectConsoleMessages(page) : [];
77
- console = console.filter((msg) => msg.type === "error");
78
- if (console.length) {
79
- lines.push("- Console Messages:");
80
- for (const message of console)
81
- lines.push(` - ${message.toString()}`);
82
- }
83
- lines.push(
84
- `- Page Snapshot:`,
85
- "```yaml",
86
- (await page._snapshotForAI()).full,
87
- "```"
88
- );
89
- }
90
- lines.push("");
91
- if (testInfo.errors.length)
92
- lines.push(`### Task`, `Try recovering from the error prior to continuing`);
93
- return lines.join("\n");
94
- }
95
- // Annotate the CommonJS export names for ESM import in node:
96
- 0 && (module.exports = {
97
- createCustomMessageHandler
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 browserBackend_exports = {};
20
+ __export(browserBackend_exports, {
21
+ createCustomMessageHandler: () => createCustomMessageHandler
22
+ });
23
+ module.exports = __toCommonJS(browserBackend_exports);
24
+ var import_config = require("../browser/config");
25
+ var import_browserServerBackend = require("../browser/browserServerBackend");
26
+ var import_tab = require("../browser/tab");
27
+ var import_util = require("../../util");
28
+ var import_browserContextFactory = require("../browser/browserContextFactory");
29
+ function createCustomMessageHandler(testInfo, context) {
30
+ let backend;
31
+ return async (data) => {
32
+ if (data.initialize) {
33
+ if (backend)
34
+ throw new Error("MCP backend is already initialized");
35
+ backend = new import_browserServerBackend.BrowserServerBackend({ ...import_config.defaultConfig, capabilities: ["testing"] }, (0, import_browserContextFactory.identityBrowserContextFactory)(context));
36
+ await backend.initialize(data.initialize.clientInfo);
37
+ const pausedMessage = await generatePausedMessage(testInfo, context);
38
+ return { initialize: { pausedMessage } };
39
+ }
40
+ if (data.listTools) {
41
+ if (!backend)
42
+ throw new Error("MCP backend is not initialized");
43
+ return { listTools: await backend.listTools() };
44
+ }
45
+ if (data.callTool) {
46
+ if (!backend)
47
+ throw new Error("MCP backend is not initialized");
48
+ return { callTool: await backend.callTool(data.callTool.name, data.callTool.arguments) };
49
+ }
50
+ if (data.close) {
51
+ backend?.serverClosed();
52
+ backend = void 0;
53
+ return { close: {} };
54
+ }
55
+ throw new Error("Unknown MCP request");
56
+ };
57
+ }
58
+ async function generatePausedMessage(testInfo, context) {
59
+ const lines = [];
60
+ if (testInfo.errors.length) {
61
+ lines.push(`### Paused on error:`);
62
+ for (const error of testInfo.errors)
63
+ lines.push((0, import_util.stripAnsiEscapes)(error.message || ""));
64
+ } else {
65
+ lines.push(`### Paused at end of test. ready for interaction`);
66
+ }
67
+ for (let i = 0; i < context.pages().length; i++) {
68
+ const page = context.pages()[i];
69
+ const stateSuffix = context.pages().length > 1 ? i + 1 + " of " + context.pages().length : "state";
70
+ lines.push(
71
+ "",
72
+ `### Page ${stateSuffix}`,
73
+ `- Page URL: ${page.url()}`,
74
+ `- Page Title: ${await page.title()}`.trim()
75
+ );
76
+ let console = testInfo.errors.length ? await import_tab.Tab.collectConsoleMessages(page) : [];
77
+ console = console.filter((msg) => msg.type === "error");
78
+ if (console.length) {
79
+ lines.push("- Console Messages:");
80
+ for (const message of console)
81
+ lines.push(` - ${message.toString()}`);
82
+ }
83
+ lines.push(
84
+ `- Page Snapshot:`,
85
+ "```yaml",
86
+ (await page._snapshotForAI()).full,
87
+ "```"
88
+ );
89
+ }
90
+ lines.push("");
91
+ if (testInfo.errors.length)
92
+ lines.push(`### Task`, `Try recovering from the error prior to continuing`);
93
+ return lines.join("\n");
94
+ }
95
+ // Annotate the CommonJS export names for ESM import in node:
96
+ 0 && (module.exports = {
97
+ createCustomMessageHandler
98
+ });
@@ -1,122 +1,122 @@
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 generatorTools_exports = {};
30
- __export(generatorTools_exports, {
31
- generatorReadLog: () => generatorReadLog,
32
- generatorWriteTest: () => generatorWriteTest,
33
- setupPage: () => setupPage
34
- });
35
- module.exports = __toCommonJS(generatorTools_exports);
36
- var import_fs = __toESM(require("fs"));
37
- var import_path = __toESM(require("path"));
38
- var import_mcpBundle = require("patchright-core/lib/mcpBundle");
39
- var import_testTool = require("./testTool");
40
- var import_testContext = require("./testContext");
41
- const setupPage = (0, import_testTool.defineTestTool)({
42
- schema: {
43
- name: "generator_setup_page",
44
- title: "Setup generator page",
45
- description: "Setup the page for test.",
46
- inputSchema: import_mcpBundle.z.object({
47
- plan: import_mcpBundle.z.string().describe("The plan for the test. This should be the actual test plan with all the steps."),
48
- project: import_mcpBundle.z.string().optional().describe('Project to use for setup. For example: "chromium", if no project is provided uses the first project in the config.'),
49
- seedFile: import_mcpBundle.z.string().optional().describe('A seed file contains a single test that is used to setup the page for testing, for example: "tests/seed.spec.ts". If no seed file is provided, a default seed file is created.')
50
- }),
51
- type: "readOnly"
52
- },
53
- handle: async (context, params) => {
54
- const seed = await context.getOrCreateSeedFile(params.seedFile, params.project);
55
- context.generatorJournal = new import_testContext.GeneratorJournal(context.rootPath, params.plan, seed);
56
- const { output, status } = await context.runSeedTest(seed.file, seed.projectName);
57
- return { content: [{ type: "text", text: output }], isError: status !== "paused" };
58
- }
59
- });
60
- const generatorReadLog = (0, import_testTool.defineTestTool)({
61
- schema: {
62
- name: "generator_read_log",
63
- title: "Retrieve test log",
64
- description: "Retrieve the performed test log",
65
- inputSchema: import_mcpBundle.z.object({}),
66
- type: "readOnly"
67
- },
68
- handle: async (context) => {
69
- if (!context.generatorJournal)
70
- throw new Error(`Please setup page using "${setupPage.schema.name}" first.`);
71
- const result = context.generatorJournal.journal();
72
- return { content: [{
73
- type: "text",
74
- text: result
75
- }] };
76
- }
77
- });
78
- const generatorWriteTest = (0, import_testTool.defineTestTool)({
79
- schema: {
80
- name: "generator_write_test",
81
- title: "Write test",
82
- description: "Write the generated test to the test file",
83
- inputSchema: import_mcpBundle.z.object({
84
- fileName: import_mcpBundle.z.string().describe("The file to write the test to"),
85
- code: import_mcpBundle.z.string().describe("The generated test code")
86
- }),
87
- type: "readOnly"
88
- },
89
- handle: async (context, params) => {
90
- if (!context.generatorJournal)
91
- throw new Error(`Please setup page using "${setupPage.schema.name}" first.`);
92
- const testRunner = context.existingTestRunner();
93
- if (!testRunner)
94
- throw new Error("No test runner found, please setup page and perform actions first.");
95
- const config = await testRunner.loadConfig();
96
- const dirs = [];
97
- for (const project of config.projects) {
98
- const testDir = import_path.default.relative(context.rootPath, project.project.testDir).replace(/\\/g, "/");
99
- const fileName = params.fileName.replace(/\\/g, "/");
100
- if (fileName.startsWith(testDir)) {
101
- const resolvedFile = import_path.default.resolve(context.rootPath, fileName);
102
- await import_fs.default.promises.mkdir(import_path.default.dirname(resolvedFile), { recursive: true });
103
- await import_fs.default.promises.writeFile(resolvedFile, params.code);
104
- return {
105
- content: [{
106
- type: "text",
107
- text: `### Result
108
- Test written to ${params.fileName}`
109
- }]
110
- };
111
- }
112
- dirs.push(testDir);
113
- }
114
- throw new Error(`Test file did not match any of the test dirs: ${dirs.join(", ")}`);
115
- }
116
- });
117
- // Annotate the CommonJS export names for ESM import in node:
118
- 0 && (module.exports = {
119
- generatorReadLog,
120
- generatorWriteTest,
121
- setupPage
122
- });
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 generatorTools_exports = {};
30
+ __export(generatorTools_exports, {
31
+ generatorReadLog: () => generatorReadLog,
32
+ generatorWriteTest: () => generatorWriteTest,
33
+ setupPage: () => setupPage
34
+ });
35
+ module.exports = __toCommonJS(generatorTools_exports);
36
+ var import_fs = __toESM(require("fs"));
37
+ var import_path = __toESM(require("path"));
38
+ var import_mcpBundle = require("patchright-bun-core/lib/mcpBundle");
39
+ var import_testTool = require("./testTool");
40
+ var import_testContext = require("./testContext");
41
+ const setupPage = (0, import_testTool.defineTestTool)({
42
+ schema: {
43
+ name: "generator_setup_page",
44
+ title: "Setup generator page",
45
+ description: "Setup the page for test.",
46
+ inputSchema: import_mcpBundle.z.object({
47
+ plan: import_mcpBundle.z.string().describe("The plan for the test. This should be the actual test plan with all the steps."),
48
+ project: import_mcpBundle.z.string().optional().describe('Project to use for setup. For example: "chromium", if no project is provided uses the first project in the config.'),
49
+ seedFile: import_mcpBundle.z.string().optional().describe('A seed file contains a single test that is used to setup the page for testing, for example: "tests/seed.spec.ts". If no seed file is provided, a default seed file is created.')
50
+ }),
51
+ type: "readOnly"
52
+ },
53
+ handle: async (context, params) => {
54
+ const seed = await context.getOrCreateSeedFile(params.seedFile, params.project);
55
+ context.generatorJournal = new import_testContext.GeneratorJournal(context.rootPath, params.plan, seed);
56
+ const { output, status } = await context.runSeedTest(seed.file, seed.projectName);
57
+ return { content: [{ type: "text", text: output }], isError: status !== "paused" };
58
+ }
59
+ });
60
+ const generatorReadLog = (0, import_testTool.defineTestTool)({
61
+ schema: {
62
+ name: "generator_read_log",
63
+ title: "Retrieve test log",
64
+ description: "Retrieve the performed test log",
65
+ inputSchema: import_mcpBundle.z.object({}),
66
+ type: "readOnly"
67
+ },
68
+ handle: async (context) => {
69
+ if (!context.generatorJournal)
70
+ throw new Error(`Please setup page using "${setupPage.schema.name}" first.`);
71
+ const result = context.generatorJournal.journal();
72
+ return { content: [{
73
+ type: "text",
74
+ text: result
75
+ }] };
76
+ }
77
+ });
78
+ const generatorWriteTest = (0, import_testTool.defineTestTool)({
79
+ schema: {
80
+ name: "generator_write_test",
81
+ title: "Write test",
82
+ description: "Write the generated test to the test file",
83
+ inputSchema: import_mcpBundle.z.object({
84
+ fileName: import_mcpBundle.z.string().describe("The file to write the test to"),
85
+ code: import_mcpBundle.z.string().describe("The generated test code")
86
+ }),
87
+ type: "readOnly"
88
+ },
89
+ handle: async (context, params) => {
90
+ if (!context.generatorJournal)
91
+ throw new Error(`Please setup page using "${setupPage.schema.name}" first.`);
92
+ const testRunner = context.existingTestRunner();
93
+ if (!testRunner)
94
+ throw new Error("No test runner found, please setup page and perform actions first.");
95
+ const config = await testRunner.loadConfig();
96
+ const dirs = [];
97
+ for (const project of config.projects) {
98
+ const testDir = import_path.default.relative(context.rootPath, project.project.testDir).replace(/\\/g, "/");
99
+ const fileName = params.fileName.replace(/\\/g, "/");
100
+ if (fileName.startsWith(testDir)) {
101
+ const resolvedFile = import_path.default.resolve(context.rootPath, fileName);
102
+ await import_fs.default.promises.mkdir(import_path.default.dirname(resolvedFile), { recursive: true });
103
+ await import_fs.default.promises.writeFile(resolvedFile, params.code);
104
+ return {
105
+ content: [{
106
+ type: "text",
107
+ text: `### Result
108
+ Test written to ${params.fileName}`
109
+ }]
110
+ };
111
+ }
112
+ dirs.push(testDir);
113
+ }
114
+ throw new Error(`Test file did not match any of the test dirs: ${dirs.join(", ")}`);
115
+ }
116
+ });
117
+ // Annotate the CommonJS export names for ESM import in node:
118
+ 0 && (module.exports = {
119
+ generatorReadLog,
120
+ generatorWriteTest,
121
+ setupPage
122
+ });