loading…
Search for a command to run...
loading…
Enables AI assistants to interact with TestOps 5.25 for managing projects, test runs, test plans, and test cases via MCP tools.
Enables AI assistants to interact with TestOps 5.25 for managing projects, test runs, test plans, and test cases via MCP tools.
Model Context Protocol server for TestOps 5.25
npm install @syn7xx/testops-mcp-server
Or use directly via npx:
npx @syn7xx/testops-mcp-server --url <testops-url> --token <api-token>
Short flags: -u / -t / -h (same as --url, --token, --help).
Environment variables: TESTOPS_URL, TESTOPS_TOKEN (used when flags are omitted).
npm run build
npm start -- --url <testops-url> --token <api-token>
Or with npx (if not installed globally):
npx @syn7xx/testops-mcp-server --url <testops-url> --token <api-token>
If TestOps is served with a self-signed certificate or HTTPS is intercepted by a corporate proxy and Node.js fails TLS validation, you can disable certificate verification for that Node process by setting:
export NODE_TLS_REJECT_UNAUTHORIZED=0
Then start the server as usual (npm start, npx, or your MCP command). In MCP configs that support server environment variables, set the same name next to TESTOPS_URL / TESTOPS_TOKEN (e.g. OpenCode environment, or your client’s env field).
Security: this disables TLS peer verification for all HTTPS calls from that process. Prefer installing the correct CA in the system trust store; use NODE_TLS_REJECT_UNAUTHORIZED=0 only when necessary and in a trusted environment.
Configs differ by product:
| Product | Typical config file | Root key | Notes |
|---|---|---|---|
| Cursor, Windsurf, Kilo Code, Zed | mcp.json (paths vary) |
mcpServers |
command + args |
| Visual Studio Code | .vscode/mcp.json or user MCP config |
servers |
Official docs — not mcpServers |
| Claude Desktop | claude_desktop_config.json |
mcpServers |
Same idea as Cursor |
| OpenCode | opencode.jsonc (project or user config) |
mcp |
type: "local", command as array, env under environment |
Do not commit real tokens; use env vars or local-only config.
These use top-level mcpServers, each entry has command (string) and args (array).
Cursor — ~/.cursor/mcp.json or project .cursor/mcp.json:
{
"mcpServers": {
"testops": {
"command": "npx",
"args": [
"-y",
"@syn7xx/testops-mcp-server",
"--url",
"https://your-testops.com",
"--token",
"your-token"
]
}
}
}
Windsurf — ~/.config/windsurf/mcp.json or project .windsurf/mcp.json (same structure).
Kilo Code — ~/.kilocode/mcp.json or project .kilocode/mcp.json (same structure).
Zed — ~/.config/zed/mcp.json (same structure).
VS Code stores MCP config in mcp.json with top-level servers, not mcpServers (see Add and manage MCP servers in VS Code and the MCP configuration reference).
Workspace file: .vscode/mcp.json, or run MCP: Open User Configuration for a global file.
{
"servers": {
"testops": {
"command": "npx",
"args": [
"-y",
"@syn7xx/testops-mcp-server",
"--url",
"https://your-testops.com",
"--token",
"your-token"
]
}
}
}
For sensitive values, prefer input variables or env files as described in the reference.
OpenCode does not use mcpServers. Define servers under mcp, set type: "local", pass the process as a command array (e.g. npx, -y, @syn7xx/testops-mcp-server, …), and optional env in environment (not env). See OpenCode MCP servers.
Example — opencode.jsonc in the project root or in the global OpenCode config:
{
"$schema": "https://opencode.ai/config.json",
"mcp": {
"testops": {
"type": "local",
"command": [
"npx",
"-y",
"@syn7xx/testops-mcp-server",
"--url",
"https://your-testops.com",
"--token",
"your-token"
],
"enabled": true
}
}
}
Using environment variables instead of flags:
{
"$schema": "https://opencode.ai/config.json",
"mcp": {
"testops": {
"type": "local",
"command": ["npx", "-y", "@syn7xx/testops-mcp-server"],
"environment": {
"TESTOPS_URL": "https://your-testops.com",
"TESTOPS_TOKEN": "your-token"
},
"enabled": true
}
}
}
macOS — ~/Library/Application Support/Claude/claude_desktop_config.json:
{
"mcpServers": {
"testops": {
"command": "npx",
"args": [
"@syn7xx/testops-mcp-server",
"--url",
"https://your-testops.com",
"--token",
"your-token"
]
}
}
}
On Windows, the config lives under %APPDATA%\Claude\ — see Anthropic’s Claude Desktop documentation for the exact path.
If you prefer a fixed binary path instead of npx:
npm install -g @syn7xx/testops-mcp-server
Then use "command": "testops-mcp-server" and "args": ["--url", "...", "--token", "..."] under mcpServers (Cursor, Claude, …) or servers (VS Code), or the command array in OpenCode.
| Tool | Description |
|---|---|
project_list |
List projects with pagination |
project_find_by_name |
Find project by exact or partial name match |
project_get_by_id |
Get project by ID |
| Tool | Description |
|---|---|
launch_create |
Create a launch directly |
launch_stop |
Close/stop a launch (end the run) |
launch_get_statistic |
Run summary: counts by status + progress ready |
launch_list_test_results |
Flat paginated test results for a launch (sort can be a string or array for multiple sort params) |
| Tool | Description |
|---|---|
testplan_get |
Get test plan by ID |
testplan_get_test_cases |
Get test cases from test plan with pagination |
testplan_run |
Start a launch from a test plan |
testplan_sync |
Sync test plan with source |
Routing is defined in each tool’s description in tools/list. For step actions and expected results as scenario JSON, use testcase_get_scenario or testcase_get_step (same behavior).
| Tool | Description |
|---|---|
testcase_get |
Get test case by ID |
testcase_get_detail |
Summary with flattened step strings and custom fields (not raw scenario JSON) |
testcase_get_scenario |
Scenario JSON: steps and expected results |
testcase_get_step |
Same as testcase_get_scenario (alias for LLM-friendly naming) |
testcase_update_step |
Update a step in scenario |
testcase_set_scenario |
Replace all steps in scenario |
testcase_get_custom_fields |
Get custom field values for a test case |
testcase_update_custom_fields |
Set custom field values on a test case |
testcase_search_by_aql |
Search test cases using AQL query |
testcase_list_in_tree |
List test cases in a project tree with pagination |
testcase_create |
Create a test case with optional steps, tags, custom fields, precondition/postcondition |
| Tool | Description |
|---|---|
project_get_custom_fields |
Get custom field definitions for a project with pagination ({ items, total, page, size }) |
project_get_custom_field_values |
Get available values for a custom field with pagination ({ items, total, page, size }) |
src/
├── shared/openapi/ # HTTP DTOs (common-dto, project-dto, test-plan-dto, test-case-dto, launch-dto, launch-test-result-dto)
├── shared/ # Utilities, API client, pagination
├── domain/
│ ├── test-case/ # Business logic (service, scenario, custom-fields, create)
│ └── ... # Other domains (project, launch, test-plan)
├── presentation/
│ ├── tool-utils.ts # handleResult helper for tools
│ ├── test-case/
│ │ └── tools/ # MCP tools (register, testcase-read, testcase-write, testcase-list, project-cf, schemas)
│ └── ... # Other presentations (project, launch, test-plan)
├── index.ts # Entry point
└── server.ts # MCP server configuration
MIT
Выполни в терминале:
claude mcp add testops-mcp-server -- npx Безопасность
Низкий рискАвтоматическая эвристика по публичным данным — не гарантия безопасности.