@stablyai/internal-playwright 0.1.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.
- package/LICENSE +202 -0
- package/NOTICE +5 -0
- package/README.md +168 -0
- package/ThirdPartyNotices.txt +6277 -0
- package/cli.js +19 -0
- package/index.d.ts +17 -0
- package/index.js +17 -0
- package/index.mjs +18 -0
- package/jsx-runtime.js +42 -0
- package/jsx-runtime.mjs +21 -0
- package/lib/agents/generateAgents.js +265 -0
- package/lib/agents/generator.md +102 -0
- package/lib/agents/healer.md +78 -0
- package/lib/agents/planner.md +135 -0
- package/lib/cli.js +274 -0
- package/lib/common/config.js +274 -0
- package/lib/common/config.js.map +7 -0
- package/lib/common/configLoader.js +377 -0
- package/lib/common/configLoader.js.map +7 -0
- package/lib/common/esmLoaderHost.js +102 -0
- package/lib/common/esmLoaderHost.js.map +7 -0
- package/lib/common/expectBundle.js +52 -0
- package/lib/common/expectBundle.js.map +7 -0
- package/lib/common/expectBundleImpl.js +389 -0
- package/lib/common/expectBundleImpl.js.map +7 -0
- package/lib/common/fixtures.js +302 -0
- package/lib/common/fixtures.js.map +7 -0
- package/lib/common/globals.js +58 -0
- package/lib/common/globals.js.map +7 -0
- package/lib/common/ipc.js +60 -0
- package/lib/common/ipc.js.map +7 -0
- package/lib/common/poolBuilder.js +85 -0
- package/lib/common/poolBuilder.js.map +7 -0
- package/lib/common/process.js +104 -0
- package/lib/common/process.js.map +7 -0
- package/lib/common/suiteUtils.js +140 -0
- package/lib/common/suiteUtils.js.map +7 -0
- package/lib/common/test.js +321 -0
- package/lib/common/test.js.map +7 -0
- package/lib/common/testLoader.js +100 -0
- package/lib/common/testLoader.js.map +7 -0
- package/lib/common/testType.js +310 -0
- package/lib/common/testType.js.map +7 -0
- package/lib/fsWatcher.js +67 -0
- package/lib/fsWatcher.js.map +7 -0
- package/lib/index.js +696 -0
- package/lib/index.js.map +7 -0
- package/lib/internalsForTest.js +42 -0
- package/lib/internalsForTest.js.map +7 -0
- package/lib/isomorphic/events.js +77 -0
- package/lib/isomorphic/events.js.map +7 -0
- package/lib/isomorphic/folders.js +30 -0
- package/lib/isomorphic/folders.js.map +7 -0
- package/lib/isomorphic/stringInternPool.js +69 -0
- package/lib/isomorphic/stringInternPool.js.map +7 -0
- package/lib/isomorphic/teleReceiver.js +507 -0
- package/lib/isomorphic/teleReceiver.js.map +7 -0
- package/lib/isomorphic/teleSuiteUpdater.js +137 -0
- package/lib/isomorphic/teleSuiteUpdater.js.map +7 -0
- package/lib/isomorphic/testServerConnection.js +211 -0
- package/lib/isomorphic/testServerConnection.js.map +7 -0
- package/lib/isomorphic/testServerInterface.js +16 -0
- package/lib/isomorphic/testServerInterface.js.map +7 -0
- package/lib/isomorphic/testTree.js +334 -0
- package/lib/isomorphic/testTree.js.map +7 -0
- package/lib/isomorphic/types.d.js +16 -0
- package/lib/isomorphic/types.d.js.map +7 -0
- package/lib/loader/loaderMain.js +59 -0
- package/lib/loader/loaderMain.js.map +7 -0
- package/lib/matchers/expect.js +325 -0
- package/lib/matchers/expect.js.map +7 -0
- package/lib/matchers/matcherHint.js +87 -0
- package/lib/matchers/matcherHint.js.map +7 -0
- package/lib/matchers/matchers.js +366 -0
- package/lib/matchers/matchers.js.map +7 -0
- package/lib/matchers/toBeTruthy.js +73 -0
- package/lib/matchers/toBeTruthy.js.map +7 -0
- package/lib/matchers/toEqual.js +99 -0
- package/lib/matchers/toEqual.js.map +7 -0
- package/lib/matchers/toHaveURL.js +102 -0
- package/lib/matchers/toHaveURL.js.map +7 -0
- package/lib/matchers/toMatchAriaSnapshot.js +159 -0
- package/lib/matchers/toMatchAriaSnapshot.js.map +7 -0
- package/lib/matchers/toMatchSnapshot.js +359 -0
- package/lib/matchers/toMatchSnapshot.js.map +7 -0
- package/lib/matchers/toMatchText.js +99 -0
- package/lib/matchers/toMatchText.js.map +7 -0
- package/lib/mcp/browser/actions.d.js +16 -0
- package/lib/mcp/browser/backend.js +93 -0
- package/lib/mcp/browser/backend.js.map +7 -0
- package/lib/mcp/browser/browserContextFactory.js +296 -0
- package/lib/mcp/browser/browserServerBackend.js +76 -0
- package/lib/mcp/browser/codegen.js +66 -0
- package/lib/mcp/browser/config.js +385 -0
- package/lib/mcp/browser/context.js +287 -0
- package/lib/mcp/browser/response.js +228 -0
- package/lib/mcp/browser/sessionLog.js +160 -0
- package/lib/mcp/browser/tab.js +277 -0
- package/lib/mcp/browser/tool.js +30 -0
- package/lib/mcp/browser/tool.js.map +7 -0
- package/lib/mcp/browser/tools/common.js +63 -0
- package/lib/mcp/browser/tools/console.js +44 -0
- package/lib/mcp/browser/tools/dialogs.js +60 -0
- package/lib/mcp/browser/tools/evaluate.js +70 -0
- package/lib/mcp/browser/tools/files.js +58 -0
- package/lib/mcp/browser/tools/form.js +74 -0
- package/lib/mcp/browser/tools/install.js +69 -0
- package/lib/mcp/browser/tools/keyboard.js +85 -0
- package/lib/mcp/browser/tools/mouse.js +107 -0
- package/lib/mcp/browser/tools/navigate.js +62 -0
- package/lib/mcp/browser/tools/network.js +54 -0
- package/lib/mcp/browser/tools/pdf.js +59 -0
- package/lib/mcp/browser/tools/screenshot.js +88 -0
- package/lib/mcp/browser/tools/snapshot.js +182 -0
- package/lib/mcp/browser/tools/tabs.js +67 -0
- package/lib/mcp/browser/tools/tool.js +49 -0
- package/lib/mcp/browser/tools/tracing.js +74 -0
- package/lib/mcp/browser/tools/utils.js +100 -0
- package/lib/mcp/browser/tools/verify.js +154 -0
- package/lib/mcp/browser/tools/wait.js +63 -0
- package/lib/mcp/browser/tools.js +80 -0
- package/lib/mcp/browser/tools.js.map +7 -0
- package/lib/mcp/browser/watchdog.js +44 -0
- package/lib/mcp/config.d.js +16 -0
- package/lib/mcp/extension/cdpRelay.js +351 -0
- package/lib/mcp/extension/extensionContextFactory.js +75 -0
- package/lib/mcp/extension/protocol.js +28 -0
- package/lib/mcp/index.js +61 -0
- package/lib/mcp/log.js +35 -0
- package/lib/mcp/program.js +96 -0
- package/lib/mcp/sdk/bundle.js +81 -0
- package/lib/mcp/sdk/bundle.js.map +7 -0
- package/lib/mcp/sdk/call.js +49 -0
- package/lib/mcp/sdk/call.js.map +7 -0
- package/lib/mcp/sdk/exports.js +32 -0
- package/lib/mcp/sdk/exports.js.map +7 -0
- package/lib/mcp/sdk/http.js +187 -0
- package/lib/mcp/sdk/http.js.map +7 -0
- package/lib/mcp/sdk/inProcessTransport.js +71 -0
- package/lib/mcp/sdk/inProcessTransport.js.map +7 -0
- package/lib/mcp/sdk/mdb.js +206 -0
- package/lib/mcp/sdk/mdb.js.map +7 -0
- package/lib/mcp/sdk/proxyBackend.js +128 -0
- package/lib/mcp/sdk/proxyBackend.js.map +7 -0
- package/lib/mcp/sdk/server.js +189 -0
- package/lib/mcp/sdk/server.js.map +7 -0
- package/lib/mcp/sdk/tool.js +51 -0
- package/lib/mcp/sdk/tool.js.map +7 -0
- package/lib/mcp/test/backend.js +67 -0
- package/lib/mcp/test/backend.js.map +7 -0
- package/lib/mcp/test/browserBackend.js +98 -0
- package/lib/mcp/test/context.js +48 -0
- package/lib/mcp/test/context.js.map +7 -0
- package/lib/mcp/test/generatorTools.js +122 -0
- package/lib/mcp/test/plannerTools.js +46 -0
- package/lib/mcp/test/seed.js +72 -0
- package/lib/mcp/test/streams.js +39 -0
- package/lib/mcp/test/streams.js.map +7 -0
- package/lib/mcp/test/testBackend.js +97 -0
- package/lib/mcp/test/testContext.js +176 -0
- package/lib/mcp/test/testTool.js +30 -0
- package/lib/mcp/test/testTools.js +115 -0
- package/lib/mcp/test/tool.js +30 -0
- package/lib/mcp/test/tool.js.map +7 -0
- package/lib/mcp/test/tools.js +150 -0
- package/lib/mcp/test/tools.js.map +7 -0
- package/lib/mcp/vscode/host.js +187 -0
- package/lib/mcp/vscode/main.js +77 -0
- package/lib/mcpBundleImpl.js +41 -0
- package/lib/mcpBundleImpl.js.map +7 -0
- package/lib/plugins/gitCommitInfoPlugin.js +198 -0
- package/lib/plugins/gitCommitInfoPlugin.js.map +7 -0
- package/lib/plugins/index.js +28 -0
- package/lib/plugins/index.js.map +7 -0
- package/lib/plugins/webServerPlugin.js +209 -0
- package/lib/plugins/webServerPlugin.js.map +7 -0
- package/lib/program.js +412 -0
- package/lib/program.js.map +7 -0
- package/lib/reporters/base.js +609 -0
- package/lib/reporters/base.js.map +7 -0
- package/lib/reporters/blob.js +135 -0
- package/lib/reporters/blob.js.map +7 -0
- package/lib/reporters/dot.js +82 -0
- package/lib/reporters/dot.js.map +7 -0
- package/lib/reporters/empty.js +32 -0
- package/lib/reporters/empty.js.map +7 -0
- package/lib/reporters/github.js +128 -0
- package/lib/reporters/github.js.map +7 -0
- package/lib/reporters/html.js +644 -0
- package/lib/reporters/html.js.map +7 -0
- package/lib/reporters/internalReporter.js +130 -0
- package/lib/reporters/internalReporter.js.map +7 -0
- package/lib/reporters/json.js +254 -0
- package/lib/reporters/json.js.map +7 -0
- package/lib/reporters/junit.js +230 -0
- package/lib/reporters/junit.js.map +7 -0
- package/lib/reporters/line.js +113 -0
- package/lib/reporters/line.js.map +7 -0
- package/lib/reporters/list.js +235 -0
- package/lib/reporters/list.js.map +7 -0
- package/lib/reporters/listModeReporter.js +69 -0
- package/lib/reporters/listModeReporter.js.map +7 -0
- package/lib/reporters/markdown.js +144 -0
- package/lib/reporters/markdown.js.map +7 -0
- package/lib/reporters/merge.js +535 -0
- package/lib/reporters/merge.js.map +7 -0
- package/lib/reporters/multiplexer.js +104 -0
- package/lib/reporters/multiplexer.js.map +7 -0
- package/lib/reporters/reporterV2.js +102 -0
- package/lib/reporters/reporterV2.js.map +7 -0
- package/lib/reporters/teleEmitter.js +297 -0
- package/lib/reporters/teleEmitter.js.map +7 -0
- package/lib/reporters/versions/blobV1.js +16 -0
- package/lib/reporters/versions/blobV1.js.map +7 -0
- package/lib/runner/dispatcher.js +491 -0
- package/lib/runner/dispatcher.js.map +7 -0
- package/lib/runner/failureTracker.js +72 -0
- package/lib/runner/failureTracker.js.map +7 -0
- package/lib/runner/lastRun.js +77 -0
- package/lib/runner/lastRun.js.map +7 -0
- package/lib/runner/loadUtils.js +333 -0
- package/lib/runner/loadUtils.js.map +7 -0
- package/lib/runner/loaderHost.js +89 -0
- package/lib/runner/loaderHost.js.map +7 -0
- package/lib/runner/processHost.js +161 -0
- package/lib/runner/processHost.js.map +7 -0
- package/lib/runner/projectUtils.js +241 -0
- package/lib/runner/projectUtils.js.map +7 -0
- package/lib/runner/rebase.js +189 -0
- package/lib/runner/rebase.js.map +7 -0
- package/lib/runner/reporters.js +137 -0
- package/lib/runner/reporters.js.map +7 -0
- package/lib/runner/runner.js +173 -0
- package/lib/runner/sigIntWatcher.js +96 -0
- package/lib/runner/sigIntWatcher.js.map +7 -0
- package/lib/runner/taskRunner.js +127 -0
- package/lib/runner/taskRunner.js.map +7 -0
- package/lib/runner/tasks.js +410 -0
- package/lib/runner/tasks.js.map +7 -0
- package/lib/runner/testGroups.js +117 -0
- package/lib/runner/testGroups.js.map +7 -0
- package/lib/runner/testRunner.js +390 -0
- package/lib/runner/testRunner.js.map +7 -0
- package/lib/runner/testServer.js +264 -0
- package/lib/runner/testServer.js.map +7 -0
- package/lib/runner/uiMode.js +271 -0
- package/lib/runner/uiModeReporter.js +30 -0
- package/lib/runner/uiModeReporter.js.map +7 -0
- package/lib/runner/vcs.js +72 -0
- package/lib/runner/vcs.js.map +7 -0
- package/lib/runner/watchMode.js +395 -0
- package/lib/runner/watchMode.js.map +7 -0
- package/lib/runner/workerHost.js +95 -0
- package/lib/runner/workerHost.js.map +7 -0
- package/lib/store.js +98 -0
- package/lib/third_party/pirates.js +62 -0
- package/lib/third_party/pirates.js.map +7 -0
- package/lib/third_party/tsconfig-loader.js +103 -0
- package/lib/third_party/tsconfig-loader.js.map +7 -0
- package/lib/transform/babelBundle.js +43 -0
- package/lib/transform/babelBundle.js.map +7 -0
- package/lib/transform/babelBundleImpl.js +461 -0
- package/lib/transform/babelBundleImpl.js.map +7 -0
- package/lib/transform/compilationCache.js +272 -0
- package/lib/transform/compilationCache.js.map +7 -0
- package/lib/transform/esmLoader.js +104 -0
- package/lib/transform/esmLoader.js.map +7 -0
- package/lib/transform/esmUtils.js +32 -0
- package/lib/transform/portTransport.js +67 -0
- package/lib/transform/portTransport.js.map +7 -0
- package/lib/transform/transform.js +293 -0
- package/lib/transform/transform.js.map +7 -0
- package/lib/util.js +403 -0
- package/lib/util.js.map +7 -0
- package/lib/utilsBundle.js +43 -0
- package/lib/utilsBundle.js.map +7 -0
- package/lib/utilsBundleImpl.js +100 -0
- package/lib/utilsBundleImpl.js.map +7 -0
- package/lib/worker/fixtureRunner.js +258 -0
- package/lib/worker/fixtureRunner.js.map +7 -0
- package/lib/worker/stepContext.js +34 -0
- package/lib/worker/testInfo.js +508 -0
- package/lib/worker/testInfo.js.map +7 -0
- package/lib/worker/testTracing.js +344 -0
- package/lib/worker/testTracing.js.map +7 -0
- package/lib/worker/timeoutManager.js +174 -0
- package/lib/worker/timeoutManager.js.map +7 -0
- package/lib/worker/util.js +31 -0
- package/lib/worker/util.js.map +7 -0
- package/lib/worker/workerMain.js +520 -0
- package/lib/worker/workerMain.js.map +7 -0
- package/package.json +74 -0
- package/test.d.ts +18 -0
- package/test.js +24 -0
- package/test.mjs +33 -0
- package/types/test.d.ts +10217 -0
- package/types/testReporter.d.ts +816 -0
@@ -0,0 +1,67 @@
|
|
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 backend_exports = {};
|
30
|
+
__export(backend_exports, {
|
31
|
+
TestServerBackend: () => TestServerBackend
|
32
|
+
});
|
33
|
+
module.exports = __toCommonJS(backend_exports);
|
34
|
+
var mcp = __toESM(require("../sdk/exports.js"));
|
35
|
+
var import_context = require("./context");
|
36
|
+
var import_tools = require("./tools.js");
|
37
|
+
var import_tools2 = require("../browser/tools");
|
38
|
+
class TestServerBackend {
|
39
|
+
constructor(resolvedLocation, options) {
|
40
|
+
this.name = "Playwright";
|
41
|
+
this.version = "0.0.1";
|
42
|
+
this._tools = [import_tools.listTests, import_tools.runTests, import_tools.debugTest];
|
43
|
+
this._context = new import_context.Context(resolvedLocation, options);
|
44
|
+
}
|
45
|
+
async listTools() {
|
46
|
+
return [
|
47
|
+
...this._tools.map((tool) => mcp.toMcpTool(tool.schema)),
|
48
|
+
mcp.toMcpTool(import_tools2.snapshot.schema),
|
49
|
+
mcp.toMcpTool(import_tools2.pickLocator.schema),
|
50
|
+
mcp.toMcpTool(import_tools2.evaluate.schema)
|
51
|
+
];
|
52
|
+
}
|
53
|
+
async callTool(name, args) {
|
54
|
+
const tool = this._tools.find((tool2) => tool2.schema.name === name);
|
55
|
+
if (!tool)
|
56
|
+
throw new Error(`Tool not found: ${name}. Available tools: ${this._tools.map((tool2) => tool2.schema.name).join(", ")}`);
|
57
|
+
const parsedArguments = tool.schema.inputSchema.parse(args || {});
|
58
|
+
return await tool.handle(this._context, parsedArguments);
|
59
|
+
}
|
60
|
+
serverClosed() {
|
61
|
+
void this._context.close();
|
62
|
+
}
|
63
|
+
}
|
64
|
+
// Annotate the CommonJS export names for ESM import in node:
|
65
|
+
0 && (module.exports = {
|
66
|
+
TestServerBackend
|
67
|
+
});
|
@@ -0,0 +1,7 @@
|
|
1
|
+
{
|
2
|
+
"version": 3,
|
3
|
+
"sources": ["../../../src/mcp/test/backend.ts"],
|
4
|
+
"sourcesContent": ["/**\n * Copyright (c) Microsoft Corporation.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport * as mcp from '../sdk/exports.js';\nimport { Context } from './context';\nimport { listTests, runTests, debugTest } from './tools.js';\nimport { snapshot, pickLocator, evaluate } from '../browser/tools';\n\nimport type { ConfigLocation } from '../../common/config';\nimport type { Tool } from './tool';\n\n\nexport class TestServerBackend implements mcp.ServerBackend {\n readonly name = 'Playwright';\n readonly version = '0.0.1';\n private _tools: Tool<any>[] = [listTests, runTests, debugTest];\n private _context: Context;\n\n constructor(resolvedLocation: ConfigLocation, options?: { muteConsole?: boolean }) {\n this._context = new Context(resolvedLocation, options);\n }\n\n async listTools(): Promise<mcp.Tool[]> {\n return [\n ...this._tools.map(tool => mcp.toMcpTool(tool.schema)),\n mcp.toMcpTool(snapshot.schema),\n mcp.toMcpTool(pickLocator.schema),\n mcp.toMcpTool(evaluate.schema),\n ];\n }\n\n async callTool(name: string, args: mcp.CallToolRequest['params']['arguments']): Promise<mcp.CallToolResult> {\n const tool = this._tools.find(tool => tool.schema.name === name);\n if (!tool)\n throw new Error(`Tool not found: ${name}. Available tools: ${this._tools.map(tool => tool.schema.name).join(', ')}`);\n const parsedArguments = tool.schema.inputSchema.parse(args || {});\n return await tool.handle(this._context!, parsedArguments);\n }\n\n serverClosed() {\n void this._context!.close();\n }\n}\n"],
|
5
|
+
"mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAgBA,UAAqB;AACrB,qBAAwB;AACxB,mBAA+C;AAC/C,IAAAA,gBAAgD;AAMzC,MAAM,kBAA+C;AAAA,EAM1D,YAAY,kBAAkC,SAAqC;AALnF,SAAS,OAAO;AAChB,SAAS,UAAU;AACnB,SAAQ,SAAsB,CAAC,wBAAW,uBAAU,sBAAS;AAI3D,SAAK,WAAW,IAAI,uBAAQ,kBAAkB,OAAO;AAAA,EACvD;AAAA,EAEA,MAAM,YAAiC;AACrC,WAAO;AAAA,MACL,GAAG,KAAK,OAAO,IAAI,UAAQ,IAAI,UAAU,KAAK,MAAM,CAAC;AAAA,MACrD,IAAI,UAAU,uBAAS,MAAM;AAAA,MAC7B,IAAI,UAAU,0BAAY,MAAM;AAAA,MAChC,IAAI,UAAU,uBAAS,MAAM;AAAA,IAC/B;AAAA,EACF;AAAA,EAEA,MAAM,SAAS,MAAc,MAA+E;AAC1G,UAAM,OAAO,KAAK,OAAO,KAAK,CAAAC,UAAQA,MAAK,OAAO,SAAS,IAAI;AAC/D,QAAI,CAAC;AACH,YAAM,IAAI,MAAM,mBAAmB,IAAI,sBAAsB,KAAK,OAAO,IAAI,CAAAA,UAAQA,MAAK,OAAO,IAAI,EAAE,KAAK,IAAI,CAAC,EAAE;AACrH,UAAM,kBAAkB,KAAK,OAAO,YAAY,MAAM,QAAQ,CAAC,CAAC;AAChE,WAAO,MAAM,KAAK,OAAO,KAAK,UAAW,eAAe;AAAA,EAC1D;AAAA,EAEA,eAAe;AACb,SAAK,KAAK,SAAU,MAAM;AAAA,EAC5B;AACF;",
|
6
|
+
"names": ["import_tools", "tool"]
|
7
|
+
}
|
@@ -0,0 +1,98 @@
|
|
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 browserBackend_exports = {};
|
30
|
+
__export(browserBackend_exports, {
|
31
|
+
runBrowserBackendAtEnd: () => runBrowserBackendAtEnd
|
32
|
+
});
|
33
|
+
module.exports = __toCommonJS(browserBackend_exports);
|
34
|
+
var mcp = __toESM(require("../sdk/exports"));
|
35
|
+
var import_globals = require("../../common/globals");
|
36
|
+
var import_util = require("../../util");
|
37
|
+
var import_config = require("../browser/config");
|
38
|
+
var import_browserServerBackend = require("../browser/browserServerBackend");
|
39
|
+
var import_tab = require("../browser/tab");
|
40
|
+
async function runBrowserBackendAtEnd(context, errorMessage) {
|
41
|
+
const testInfo = (0, import_globals.currentTestInfo)();
|
42
|
+
if (!testInfo)
|
43
|
+
return;
|
44
|
+
const shouldPause = errorMessage ? testInfo?._pauseOnError() : testInfo?._pauseAtEnd();
|
45
|
+
if (!shouldPause)
|
46
|
+
return;
|
47
|
+
const lines = [];
|
48
|
+
if (errorMessage)
|
49
|
+
lines.push(`### Paused on error:`, (0, import_util.stripAnsiEscapes)(errorMessage));
|
50
|
+
else
|
51
|
+
lines.push(`### Paused at end of test. ready for interaction`);
|
52
|
+
for (let i = 0; i < context.pages().length; i++) {
|
53
|
+
const page = context.pages()[i];
|
54
|
+
const stateSuffix = context.pages().length > 1 ? i + 1 + " of " + context.pages().length : "state";
|
55
|
+
lines.push(
|
56
|
+
"",
|
57
|
+
`### Page ${stateSuffix}`,
|
58
|
+
`- Page URL: ${page.url()}`,
|
59
|
+
`- Page Title: ${await page.title()}`.trim()
|
60
|
+
);
|
61
|
+
let console = errorMessage ? await import_tab.Tab.collectConsoleMessages(page) : [];
|
62
|
+
console = console.filter((msg) => !msg.type || msg.type === "error");
|
63
|
+
if (console.length) {
|
64
|
+
lines.push("- Console Messages:");
|
65
|
+
for (const message of console)
|
66
|
+
lines.push(` - ${message.toString()}`);
|
67
|
+
}
|
68
|
+
lines.push(
|
69
|
+
`- Page Snapshot:`,
|
70
|
+
"```yaml",
|
71
|
+
await page._snapshotForAI(),
|
72
|
+
"```"
|
73
|
+
);
|
74
|
+
}
|
75
|
+
lines.push("");
|
76
|
+
if (errorMessage)
|
77
|
+
lines.push(`### Task`, `Try recovering from the error prior to continuing`);
|
78
|
+
const config = {
|
79
|
+
...import_config.defaultConfig,
|
80
|
+
capabilities: ["testing"]
|
81
|
+
};
|
82
|
+
await mcp.runOnPauseBackendLoop(new import_browserServerBackend.BrowserServerBackend(config, identityFactory(context)), lines.join("\n"));
|
83
|
+
}
|
84
|
+
function identityFactory(browserContext) {
|
85
|
+
return {
|
86
|
+
createContext: async (clientInfo, abortSignal, toolName) => {
|
87
|
+
return {
|
88
|
+
browserContext,
|
89
|
+
close: async () => {
|
90
|
+
}
|
91
|
+
};
|
92
|
+
}
|
93
|
+
};
|
94
|
+
}
|
95
|
+
// Annotate the CommonJS export names for ESM import in node:
|
96
|
+
0 && (module.exports = {
|
97
|
+
runBrowserBackendAtEnd
|
98
|
+
});
|
@@ -0,0 +1,48 @@
|
|
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 context_exports = {};
|
20
|
+
__export(context_exports, {
|
21
|
+
Context: () => Context
|
22
|
+
});
|
23
|
+
module.exports = __toCommonJS(context_exports);
|
24
|
+
var import_testRunner = require("../../runner/testRunner");
|
25
|
+
class Context {
|
26
|
+
constructor(configLocation, options) {
|
27
|
+
this.configLocation = configLocation;
|
28
|
+
this.options = options;
|
29
|
+
}
|
30
|
+
async createTestRunner() {
|
31
|
+
if (this._testRunner)
|
32
|
+
await this._testRunner.stopTests();
|
33
|
+
const testRunner = new import_testRunner.TestRunner(this.configLocation, {});
|
34
|
+
await testRunner.initialize({});
|
35
|
+
this._testRunner = testRunner;
|
36
|
+
testRunner.on(import_testRunner.TestRunnerEvent.TestFilesChanged, (testFiles) => {
|
37
|
+
this._testRunner?.emit(import_testRunner.TestRunnerEvent.TestFilesChanged, testFiles);
|
38
|
+
});
|
39
|
+
this._testRunner = testRunner;
|
40
|
+
return testRunner;
|
41
|
+
}
|
42
|
+
async close() {
|
43
|
+
}
|
44
|
+
}
|
45
|
+
// Annotate the CommonJS export names for ESM import in node:
|
46
|
+
0 && (module.exports = {
|
47
|
+
Context
|
48
|
+
});
|
@@ -0,0 +1,7 @@
|
|
1
|
+
{
|
2
|
+
"version": 3,
|
3
|
+
"sources": ["../../../src/mcp/test/context.ts"],
|
4
|
+
"sourcesContent": ["/**\n * Copyright (c) Microsoft Corporation.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { TestRunner, TestRunnerEvent } from '../../runner/testRunner';\n\nimport type { ConfigLocation } from '../../common/config';\n\nexport class Context {\n private _testRunner: TestRunner | undefined;\n readonly configLocation: ConfigLocation;\n readonly options?: { muteConsole?: boolean };\n\n constructor(configLocation: ConfigLocation, options?: { muteConsole?: boolean }) {\n this.configLocation = configLocation;\n this.options = options;\n }\n\n async createTestRunner(): Promise<TestRunner> {\n if (this._testRunner)\n await this._testRunner.stopTests();\n const testRunner = new TestRunner(this.configLocation, {});\n await testRunner.initialize({});\n this._testRunner = testRunner;\n testRunner.on(TestRunnerEvent.TestFilesChanged, testFiles => {\n this._testRunner?.emit(TestRunnerEvent.TestFilesChanged, testFiles);\n });\n this._testRunner = testRunner;\n return testRunner;\n }\n\n async close() {\n }\n}\n"],
|
5
|
+
"mappings": ";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAgBA,wBAA4C;AAIrC,MAAM,QAAQ;AAAA,EAKnB,YAAY,gBAAgC,SAAqC;AAC/E,SAAK,iBAAiB;AACtB,SAAK,UAAU;AAAA,EACjB;AAAA,EAEA,MAAM,mBAAwC;AAC5C,QAAI,KAAK;AACP,YAAM,KAAK,YAAY,UAAU;AACnC,UAAM,aAAa,IAAI,6BAAW,KAAK,gBAAgB,CAAC,CAAC;AACzD,UAAM,WAAW,WAAW,CAAC,CAAC;AAC9B,SAAK,cAAc;AACnB,eAAW,GAAG,kCAAgB,kBAAkB,eAAa;AAC3D,WAAK,aAAa,KAAK,kCAAgB,kBAAkB,SAAS;AAAA,IACpE,CAAC;AACD,SAAK,cAAc;AACnB,WAAO;AAAA,EACT;AAAA,EAEA,MAAM,QAAQ;AAAA,EACd;AACF;",
|
6
|
+
"names": []
|
7
|
+
}
|
@@ -0,0 +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_bundle = require("../sdk/bundle");
|
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_bundle.z.object({
|
47
|
+
plan: import_bundle.z.string().describe("The plan for the test. This should be the actual test plan with all the steps."),
|
48
|
+
project: import_bundle.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_bundle.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, progress) => {
|
54
|
+
const seed = await context.getOrCreateSeedFile(params.seedFile, params.project);
|
55
|
+
context.generatorJournal = new import_testContext.GeneratorJournal(context.rootPath, params.plan, seed);
|
56
|
+
await context.runSeedTest(seed.file, seed.projectName, progress);
|
57
|
+
return { content: [] };
|
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_bundle.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_bundle.z.object({
|
84
|
+
fileName: import_bundle.z.string().describe("The file to write the test to"),
|
85
|
+
code: import_bundle.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
|
+
});
|
@@ -0,0 +1,46 @@
|
|
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 plannerTools_exports = {};
|
20
|
+
__export(plannerTools_exports, {
|
21
|
+
setupPage: () => setupPage
|
22
|
+
});
|
23
|
+
module.exports = __toCommonJS(plannerTools_exports);
|
24
|
+
var import_bundle = require("../sdk/bundle");
|
25
|
+
var import_testTool = require("./testTool");
|
26
|
+
const setupPage = (0, import_testTool.defineTestTool)({
|
27
|
+
schema: {
|
28
|
+
name: "planner_setup_page",
|
29
|
+
title: "Setup planner page",
|
30
|
+
description: "Setup the page for test planning",
|
31
|
+
inputSchema: import_bundle.z.object({
|
32
|
+
project: import_bundle.z.string().optional().describe('Project to use for setup. For example: "chromium", if no project is provided uses the first project in the config.'),
|
33
|
+
seedFile: import_bundle.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.')
|
34
|
+
}),
|
35
|
+
type: "readOnly"
|
36
|
+
},
|
37
|
+
handle: async (context, params, progress) => {
|
38
|
+
const seed = await context.getOrCreateSeedFile(params.seedFile, params.project);
|
39
|
+
await context.runSeedTest(seed.file, seed.projectName, progress);
|
40
|
+
return { content: [] };
|
41
|
+
}
|
42
|
+
});
|
43
|
+
// Annotate the CommonJS export names for ESM import in node:
|
44
|
+
0 && (module.exports = {
|
45
|
+
setupPage
|
46
|
+
});
|
@@ -0,0 +1,72 @@
|
|
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 seed_exports = {};
|
30
|
+
__export(seed_exports, {
|
31
|
+
ensureSeedTest: () => ensureSeedTest,
|
32
|
+
seedProject: () => seedProject
|
33
|
+
});
|
34
|
+
module.exports = __toCommonJS(seed_exports);
|
35
|
+
var import_fs = __toESM(require("fs"));
|
36
|
+
var import_path = __toESM(require("path"));
|
37
|
+
var import_utils = require("playwright-core/lib/utils");
|
38
|
+
var import_projectUtils = require("../../runner/projectUtils");
|
39
|
+
function seedProject(config, projectName) {
|
40
|
+
if (!projectName)
|
41
|
+
return (0, import_projectUtils.findTopLevelProjects)(config)[0];
|
42
|
+
const project = config.projects.find((p) => p.project.name === projectName);
|
43
|
+
if (!project)
|
44
|
+
throw new Error(`Project ${projectName} not found`);
|
45
|
+
return project;
|
46
|
+
}
|
47
|
+
async function ensureSeedTest(project, logNew) {
|
48
|
+
const files = await (0, import_projectUtils.collectFilesForProject)(project);
|
49
|
+
const seed = files.find((file) => import_path.default.basename(file).includes("seed"));
|
50
|
+
if (seed)
|
51
|
+
return seed;
|
52
|
+
const testDir = project.project.testDir;
|
53
|
+
const seedFile = import_path.default.resolve(testDir, "seed.spec.ts");
|
54
|
+
if (logNew) {
|
55
|
+
console.log(`Writing file: ${import_path.default.relative(process.cwd(), seedFile)}`);
|
56
|
+
}
|
57
|
+
await (0, import_utils.mkdirIfNeeded)(seedFile);
|
58
|
+
await import_fs.default.promises.writeFile(seedFile, `import { test, expect } from '@playwright/test';
|
59
|
+
|
60
|
+
test.describe('Test group', () => {
|
61
|
+
test('seed', async ({ page }) => {
|
62
|
+
// generate code here.
|
63
|
+
});
|
64
|
+
});
|
65
|
+
`);
|
66
|
+
return seedFile;
|
67
|
+
}
|
68
|
+
// Annotate the CommonJS export names for ESM import in node:
|
69
|
+
0 && (module.exports = {
|
70
|
+
ensureSeedTest,
|
71
|
+
seedProject
|
72
|
+
});
|
@@ -0,0 +1,39 @@
|
|
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 streams_exports = {};
|
20
|
+
__export(streams_exports, {
|
21
|
+
StringWriteStream: () => StringWriteStream
|
22
|
+
});
|
23
|
+
module.exports = __toCommonJS(streams_exports);
|
24
|
+
var import_stream = require("stream");
|
25
|
+
class StringWriteStream extends import_stream.Writable {
|
26
|
+
constructor(progress) {
|
27
|
+
super();
|
28
|
+
this._progress = progress;
|
29
|
+
}
|
30
|
+
_write(chunk, encoding, callback) {
|
31
|
+
const text = chunk.toString();
|
32
|
+
this._progress({ message: text.endsWith("\n") ? text.slice(0, -1) : text });
|
33
|
+
callback();
|
34
|
+
}
|
35
|
+
}
|
36
|
+
// Annotate the CommonJS export names for ESM import in node:
|
37
|
+
0 && (module.exports = {
|
38
|
+
StringWriteStream
|
39
|
+
});
|
@@ -0,0 +1,7 @@
|
|
1
|
+
{
|
2
|
+
"version": 3,
|
3
|
+
"sources": ["../../../src/mcp/test/streams.ts"],
|
4
|
+
"sourcesContent": ["/**\n * Copyright (c) Microsoft Corporation.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { Writable } from 'stream';\n\nexport class StringWriteStream extends Writable {\n private _chunks: string[] = [];\n\n override _write(chunk: any, encoding: any, callback: any) {\n this._chunks.push(chunk.toString());\n callback();\n }\n\n content() {\n return this._chunks.join('');\n }\n}\n"],
|
5
|
+
"mappings": ";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAgBA,oBAAyB;AAElB,MAAM,0BAA0B,uBAAS;AAAA,EAAzC;AAAA;AACL,SAAQ,UAAoB,CAAC;AAAA;AAAA,EAEpB,OAAO,OAAY,UAAe,UAAe;AACxD,SAAK,QAAQ,KAAK,MAAM,SAAS,CAAC;AAClC,aAAS;AAAA,EACX;AAAA,EAEA,UAAU;AACR,WAAO,KAAK,QAAQ,KAAK,EAAE;AAAA,EAC7B;AACF;",
|
6
|
+
"names": []
|
7
|
+
}
|
@@ -0,0 +1,97 @@
|
|
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 testBackend_exports = {};
|
30
|
+
__export(testBackend_exports, {
|
31
|
+
TestServerBackend: () => TestServerBackend
|
32
|
+
});
|
33
|
+
module.exports = __toCommonJS(testBackend_exports);
|
34
|
+
var mcp = __toESM(require("../sdk/exports"));
|
35
|
+
var import_testContext = require("./testContext");
|
36
|
+
var testTools = __toESM(require("./testTools.js"));
|
37
|
+
var generatorTools = __toESM(require("./generatorTools.js"));
|
38
|
+
var plannerTools = __toESM(require("./plannerTools.js"));
|
39
|
+
var import_tools = require("../browser/tools");
|
40
|
+
var import_configLoader = require("../../common/configLoader");
|
41
|
+
var import_response = require("../browser/response");
|
42
|
+
class TestServerBackend {
|
43
|
+
constructor(configOption, options) {
|
44
|
+
this.name = "Playwright";
|
45
|
+
this.version = "0.0.1";
|
46
|
+
this._tools = [
|
47
|
+
plannerTools.setupPage,
|
48
|
+
generatorTools.setupPage,
|
49
|
+
generatorTools.generatorReadLog,
|
50
|
+
generatorTools.generatorWriteTest,
|
51
|
+
testTools.listTests,
|
52
|
+
testTools.runTests,
|
53
|
+
testTools.debugTest
|
54
|
+
];
|
55
|
+
this._context = new import_testContext.TestContext(options);
|
56
|
+
this._configOption = configOption;
|
57
|
+
}
|
58
|
+
async initialize(server, clientInfo) {
|
59
|
+
const rootPath = mcp.firstRootPath(clientInfo);
|
60
|
+
if (this._configOption) {
|
61
|
+
this._context.initialize(rootPath, (0, import_configLoader.resolveConfigLocation)(this._configOption));
|
62
|
+
return;
|
63
|
+
}
|
64
|
+
if (rootPath) {
|
65
|
+
this._context.initialize(rootPath, (0, import_configLoader.resolveConfigLocation)(rootPath));
|
66
|
+
return;
|
67
|
+
}
|
68
|
+
this._context.initialize(rootPath, (0, import_configLoader.resolveConfigLocation)(void 0));
|
69
|
+
}
|
70
|
+
async listTools() {
|
71
|
+
return [
|
72
|
+
...this._tools.map((tool) => mcp.toMcpTool(tool.schema)),
|
73
|
+
...import_tools.browserTools.map((tool) => mcp.toMcpTool(tool.schema, { addIntent: true }))
|
74
|
+
];
|
75
|
+
}
|
76
|
+
async afterCallTool(name, args, result) {
|
77
|
+
if (!import_tools.browserTools.find((tool) => tool.schema.name === name))
|
78
|
+
return;
|
79
|
+
const response = (0, import_response.parseResponse)(result);
|
80
|
+
if (response && !response.isError && response.code && typeof args?.["intent"] === "string")
|
81
|
+
this._context.generatorJournal?.logStep(args["intent"], response.code);
|
82
|
+
}
|
83
|
+
async callTool(name, args, progress) {
|
84
|
+
const tool = this._tools.find((tool2) => tool2.schema.name === name);
|
85
|
+
if (!tool)
|
86
|
+
throw new Error(`Tool not found: ${name}. Available tools: ${this._tools.map((tool2) => tool2.schema.name).join(", ")}`);
|
87
|
+
const parsedArguments = tool.schema.inputSchema.parse(args || {});
|
88
|
+
return await tool.handle(this._context, parsedArguments, progress);
|
89
|
+
}
|
90
|
+
serverClosed() {
|
91
|
+
void this._context.close();
|
92
|
+
}
|
93
|
+
}
|
94
|
+
// Annotate the CommonJS export names for ESM import in node:
|
95
|
+
0 && (module.exports = {
|
96
|
+
TestServerBackend
|
97
|
+
});
|