X

qa-mcp

Information

VibeShift Web 测试器 该项目提供了一个由 AI 驱动的代理,旨在简化网页测试工作流程,特别是对于使用像 GitHub Copilot、Cursor、Roo Code 等 AI 编码助手的开发者。它通过 MCP(机器命令协议) 直接集成到这些助手中,允许您使用自然语言提示来自动化测试录制、执行和发现。 问题: 在使用 AI 助手生成代码后手动测试网页应用程序既耗时又容易出错。此外,AI 驱动的代码更改可能会无意中在之前正常工作的功能中引入回归。 解决方案: 该工具通过使您的 AI 编码助手能够: 录制新的测试流程: 用自然语言描述用户旅程,代理将在 AI 指导下与浏览器(使用 Playwright)交互以生成可重现的测试脚本(JSON 格式)。 执行现有测试: 运行先前记录的测试脚本来进行回归测试,确保新代码更改没有破坏现有的功能。 发现潜在的测试步骤: 爬取网站,分析页面的视觉效果和 DOM 结构,并让大型语言模型 (LLM) 建议不同页面的相关测试步骤。 这创建了一个更紧密的反馈循环,自动化了测试过程,使得 AI 助手(以及开发者)可以快速识别并修复问题或回归。 演示(点击播放视频) 特性 MCP 集成: 无缝集成 Cursor/Windsurf/GitHub Copilot/Roo Code AI 辅助测试录制: 从自然语言描述生成基于 Playwright 的测试脚本(自动模式下)。 确定性测试执行: 使用 Playwright 可靠地运行已记录的 JSON 测试文件。 AI 驱动的测试发现: 爬取网站,并利用任何 LLM(符合 openai 格式)为发现的页面建议测试步骤。 回归测试: 轻松运行现有测试套件以捕获回归。 自动化反馈循环: 执行结果(包括失败情况、截图、控制台日志)被返回,直接向 AI 助手提供反馈。 自我修复: 如果代码发生变化,现有测试会自我修复。无需手动更新。 UI 测试: 支持 Playwright 不直接支持的 UI 测试。例如,“检查文本是否在 div 中溢出”。 视觉回归测试: 使用传统的 pixelmatch 和视觉 LLM 方法。 工作原理 +-------------+ +-----------------+ +---------------------+ +-----------------+ +---------+ | 用户 | ----> | AI 编码代理 | ----> | MCP 服务器 | ----> | Web 测试代理 | ----> | 浏览器 | | (开发者) | | (如 Copilot) | | (mcp_server.py) | | (agent/executor)| | (Playwright)| +-------------+ +-----------------+ +---------------------+ +-----------------+ +---------+ ^ | | | |--------------------------------------------------+----------------------------+---------------------+ [测试结果 / 反馈] 用户: 向其 AI 编码助手发出指令(例如,“为登录流程录制一个测试”,“运行回归测试 test_login.json”)。 AI 编码代理: 识别意图并通过 MCP 调用 MCP 服务器 提供的相应工具。 MCP 服务器: 将请求路由到相应的函数 (record_test_flow, run_regression_test, discover_test_flows, list_recorded_tests)。 Web 测试代理:* 录制: WebAgent(在自动模式下)与LLM交互以规划步骤,通过BrowserController(Playwright)控制浏览器,处理HTML/视觉信息,并将生成的测试步骤保存到output/目录下的JSON文件中。 执行: TestExecutor加载指定的JSON测试文件,使用BrowserController根据记录的步骤与浏览器进行交互,并捕获结果、截图和控制台日志。 发现: CrawlerAgent使用BrowserController和LLMClient来爬取页面并建议测试步骤。 浏览器: Playwright驱动实际的浏览器交互。 反馈: 结果(成功/失败、文件路径、错误消息、发现的步骤)通过MCP服务器返回给AI编码助手,然后由其呈现给用户。 开始使用 前提条件 Python 3.10+ 访问任何LLM(在我的测试中,gemini 2.0 flash免费版效果最佳) 安装了MCP (pip install mcp[cli]) 安装了Playwright浏览器 (playwright install) 安装 克隆仓库: bash git clone cd 创建虚拟环境(推荐): bash python -m venv venv source venv/bin/activate # Linux/macOS venvScriptsactivate # Windows 安装依赖: bash pip install -r requirements.txt 安装Playwright浏览器: bash playwright install --with-deps # 安装浏览器及其操作系统依赖 配置 将项目根目录中的.env.example重命名为.env文件。 添加您的LLM API密钥及其他必要信息: dotenv .env LLM_API_KEY="YOUR_LLM_API_KEY" 将YOUR_LLM_API_KEY替换为您的实际密钥。 添加MCP服务器 将以下内容添加到您的MCP配置中: json \{ "mcpServers": \{ "Web-QA":\{ "command": "uv", "args": ["--directory","path/to/cloned_repo", "run", "mcp_server.py"] \} \} \} 在与您的AI编码助手交互时,请保持此服务器运行。 使用方法 通过支持MCP的AI编码助手使用自然语言与代理进行交互。 示例: 录制测试: "录制一个测试:访问https://practicetestautomation.com/practice-test-login/,在用户名字段输入student,在密码字段输入Password123,点击提交按钮,并验证文本Congratulations student是否可见。" (代理将自动执行这些操作并将test_....json文件保存到output/目录中) 执行测试: "运行回归测试output/test_practice_test_login_20231105_103000.json" (代理将执行指定文件中的步骤,并报告PASS/FAIL状态以及错误和详细信息。) 发现测试步骤: "从https://practicetestautomation.com/practice/开始发现潜在的测试步骤。" (代理将爬取站点,分析页面,并为每个页面返回建议的测试步骤。) 列出已录制的测试: "列出可用的已录制网页测试。" (代理将返回output/目录中找到的.json文件列表。) 输出: 已录制的测试: 作为JSON文件保存在output/目录中(有关格式,请参阅test_schema.md)。 执行结果: 作为总结运行情况的JSON对象返回(状态、错误、证据路径)。完整的结果也保存到output/execution_result_....json。 发现结果: 作为包含发现的URL和建议步骤的JSON对象返回。完整的结果保存到output/discovery_results_....json。 灵感来源* Browser Use: DOM 上下文树的生成大量借鉴了他们的工作,并进行了修改以适应静态/动态/视觉元素。特别感谢他们对开源社区的贡献。 贡献 欢迎贡献!请参阅 CONTRIBUTING.md 了解如何开始、报告问题以及提交拉取请求的详细信息。 许可证 本项目根据 APACHE-2.0 许可证发布。

Prompts

Reviews

Tags

Write Your Review

Detailed Ratings

ALL
Correctness
Helpfulness
Interesting
Upload Pictures and Videos

Name
Size
Type
Download
Last Modified
  • Community

Add Discussion

Upload Pictures and Videos