Skip to main content
Glama

测试运行器 MCP

模型上下文协议 (MCP) 服务器,用于运行和解析来自多个测试框架的测试结果。该服务器提供统一的接口来执行测试并处理其输出,支持:

  • Bats(Bash 自动测试系统)

  • Pytest(Python测试框架)

  • Flutter 测试

  • Jest(JavaScript 测试框架)

  • Go 测试

  • 防锈测试(货物测试)

  • 通用(用于任意命令执行)

安装

npm install test-runner-mcp

Related MCP server: JMeter MCP Server

先决条件

需要针对各自的测试类型安装以下测试框架:

用法

配置

将测试运行器添加到您的 MCP 设置中(例如,在claude_desktop_config.jsoncline_mcp_settings.json中):

{ "mcpServers": { "test-runner": { "command": "node", "args": ["/path/to/test-runner-mcp/build/index.js"], "env": { "NODE_PATH": "/path/to/test-runner-mcp/node_modules", // Flutter-specific environment (required for Flutter tests) "FLUTTER_ROOT": "/opt/homebrew/Caskroom/flutter/3.27.2/flutter", "PUB_CACHE": "/Users/username/.pub-cache", "PATH": "/opt/homebrew/Caskroom/flutter/3.27.2/flutter/bin:/usr/local/bin:/usr/bin:/bin" } } } }

注意:对于 Flutter 测试,请确保替换:

  • /opt/homebrew/Caskroom/flutter/3.27.2/flutter替换为你的实际 Flutter 安装路径

  • /Users/username/.pub-cache替换为你的实际 pub 缓存路径

  • 更新 PATH 以包含系统的实际路径

您可以通过运行以下命令找到这些值:

# Get Flutter root flutter --version # Get pub cache path echo $PUB_CACHE # or default to $HOME/.pub-cache # Get Flutter binary path which flutter

运行测试

使用具有以下参数的run_tests工具:

{ "command": "test command to execute", "workingDir": "working directory for test execution", "framework": "bats|pytest|flutter|jest|go|rust|generic", "outputDir": "directory for test results", "timeout": "test execution timeout in milliseconds (default: 300000)", "env": "optional environment variables", "securityOptions": "optional security options for command execution" }

每个框架的示例:

// Bats { "command": "bats test/*.bats", "workingDir": "/path/to/project", "framework": "bats", "outputDir": "test_reports" } // Pytest { "command": "pytest test_file.py -v", "workingDir": "/path/to/project", "framework": "pytest", "outputDir": "test_reports" } // Flutter { "command": "flutter test test/widget_test.dart", "workingDir": "/path/to/project", "framework": "flutter", "outputDir": "test_reports", "FLUTTER_ROOT": "/opt/homebrew/Caskroom/flutter/3.27.2/flutter", "PUB_CACHE": "/Users/username/.pub-cache", "PATH": "/opt/homebrew/Caskroom/flutter/3.27.2/flutter/bin:/usr/local/bin:/usr/bin:/bin" } // Jest { "command": "jest test/*.test.js", "workingDir": "/path/to/project", "framework": "jest", "outputDir": "test_reports" } // Go { "command": "go test ./...", "workingDir": "/path/to/project", "framework": "go", "outputDir": "test_reports" } // Rust { "command": "cargo test", "workingDir": "/path/to/project", "framework": "rust", "outputDir": "test_reports" } // Generic (for arbitrary commands, CI/CD tools, etc.) { "command": "act -j build", "workingDir": "/path/to/project", "framework": "generic", "outputDir": "test_reports" } // Generic with security overrides { "command": "sudo docker-compose -f docker-compose.test.yml up", "workingDir": "/path/to/project", "framework": "generic", "outputDir": "test_reports", "securityOptions": { "allowSudo": true } }

安全功能

测试运行器包含内置的安全功能,以防止执行潜在的有害命令,特别是对于generic框架:

  1. 命令验证

    • 默认阻止sudosu

    • 防止危险命令,如rm -rf /

    • 阻止在安全位置之外进行文件系统写入操作

  2. 环境变量清理

    • 过滤掉潜在的危险环境变量

    • 防止覆盖关键系统变量

    • 确保安全路径处理

  3. 可配置的安全性

    • 必要时通过securityOptions覆盖安全限制

    • 对安全功能的细粒度控制

    • 标准测试使用的默认安全设置

您可以配置的安全选项:

{ "securityOptions": { "allowSudo": false, // Allow sudo commands "allowSu": false, // Allow su commands "allowShellExpansion": true, // Allow shell expansion like $() or backticks "allowPipeToFile": false // Allow pipe to file operations (> or >>) } }

Flutter 测试支持

测试运行器包括对 Flutter 测试的增强支持:

  1. 环境设置

    • 自动 Flutter 环境配置

    • PATH 和 PUB_CACHE 设置

    • Flutter 安装验证

  2. 错误处理

    • 堆栈跟踪收集

    • 断言错误处理

    • 异常捕获

    • 测试失败检测

  3. 输出处理

    • 完成测试输出捕获

    • 堆栈跟踪保存

    • 详细的错误报告

    • 原始输出保存

Rust 测试支持

测试运行器为 Rust 的cargo test提供了特定的支持:

  1. 环境设置

    • 自动设置 RUST_BACKTRACE=1 以获得更好的错误消息

  2. 输出解析

    • 解析单个测试结果

    • 捕获失败测试的详细错误消息

    • 识别被忽略的测试

    • 提取摘要信息

通用测试支持

对于 CI/CD 管道、通过act执行的 GitHub Actions 或任何其他命令执行,通用框架提供:

  1. 自动输出分析

    • 尝试将输出分割成逻辑块

    • 标识节标题

    • 检测通过/失败指标

    • 即使对于未知格式也能提供合理的输出结构

  2. 灵活集成

    • 可与任意 shell 命令配合使用

    • 无特定格式要求

    • 非常适合与act 、Docker 和自定义脚本等工具集成

  3. 安全功能

    • 命令验证以防止有害操作

    • 必要时可配置为允许特定的提升权限

输出格式

测试运行器生成结构化输出,同时保留完整的测试输出:

interface TestResult { name: string; passed: boolean; output: string[]; rawOutput?: string; // Complete unprocessed output } interface TestSummary { total: number; passed: number; failed: number; duration?: number; } interface ParsedResults { framework: string; tests: TestResult[]; summary: TestSummary; rawOutput: string; // Complete command output }

结果保存在指定的输出目录中:

  • test_output.log :原始测试输出

  • test_errors.log :错误消息(如果有)

  • test_results.json :结构化测试结果

  • summary.txt :人类可读的摘要

发展

设置

  1. 克隆存储库

  2. 安装依赖项:

    npm install
  3. 构建项目:

    npm run build

运行测试

npm test

该测试套件包括所有受支持框架的测试,并验证成功和失败的测试场景。

持续集成/持续交付

该项目使用 GitHub Actions 进行持续集成:

  • 在 Node.js 18.x 和 20.x 上进行自动化测试

  • 测试结果已上传为工件

  • Dependabot 配置为自动依赖项更新

贡献

  1. 分叉存储库

  2. 创建你的功能分支

  3. 提交你的更改

  4. 推送到分支

  5. 创建拉取请求

执照

该项目根据 MIT 许可证获得许可 - 有关详细信息,请参阅LICENSE文件。

One-click Deploy
A
security – no known vulnerabilities
A
license - permissive license
A
quality - confirmed to work

Latest Blog Posts

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/privsim/mcp-test-runner'

If you have feedback or need assistance with the MCP directory API, please join our Discord server