UNPKG

@smartbear/mcp

Version:

MCP server for interacting SmartBear Products

244 lines (211 loc) 10.7 kB
<div align="center"> <a href="https://www.smartbear.com"> <picture> <source media="(prefers-color-scheme: dark)" srcset="https://assets.smartbear.com/m/79b99a7ff9c81a9a/original/SmartBear-Logo_Dark-Mode.svg"> <img alt="SmartBear logo" src="https://assets.smartbear.com/m/105001cc5db1e0bf/original/SmartBear-Logo_Light-Mode.svg"> </picture> </a> <h1>SmartBear MCP server</h1> <!-- Badges --> <div> <a href="https://github.com/SmartBear/smartbear-mcp/actions/workflows/test.yml"><img src="https://github.com/SmartBear/smartbear-mcp/actions/workflows/test.yml/badge.svg?branch=main" alt="Test Status"></a> <a href="https://smartbear.github.io/smartbear-mcp/"><img src="https://img.shields.io/badge/coverage-dynamic-brightgreen" alt="Coverage"></a> <a href="https://www.npmjs.com/package/@smartbear/mcp"><img src="https://img.shields.io/npm/v/@smartbear/mcp" alt="npm version"></a> <a href="https://modelcontextprotocol.io"><img src="https://img.shields.io/badge/MCP-Compatible-blue" alt="MCP Compatible"></a> <a href="https://developer.smartbear.com/smartbear-mcp"><img src="https://img.shields.io/badge/documentation-latest-blue.svg" alt="Documentation"></a> </div> </div> <br /> A Model Context Protocol (MCP) server which provides AI assistants with seamless access to SmartBear's suite of testing and monitoring tools, including [BugSnag](https://www.bugsnag.com/), [Reflect](https://reflect.run), [Swagger](https://www.smartbear.com/api-hub), [PactFlow](https://pactflow.io/), [Pact Broker](https://docs.pact.io/), [QMetry](https://www.qmetry.com/), [Zephyr](https://smartbear.com/test-management/zephyr/) and [Collaborator](https://smartbear.com/product/collaborator/). ## What is MCP? The [Model Context Protocol (MCP)](https://modelcontextprotocol.io/introduction) is an open standard that enables AI assistants to securely connect to external data sources and tools. This server exposes SmartBear's APIs through natural language interfaces, allowing you to query your testing data, analyze performance metrics, and manage test automation directly from your AI workflow. ## Supported Tools See individual guides for suggested prompts and supported tools and resources: - [BugSnag](https://developer.smartbear.com/smartbear-mcp/docs/bugsnag-integration) - Comprehensive error monitoring and debugging capabilities - [Test Hub](https://developer.smartbear.com/smartbear-mcp/docs/test-hub-integration) - Test management and execution capabilities - **Swagger** - [Portal](https://developer.smartbear.com/smartbear-mcp/docs/swagger-portal-integration) - Portal and product management capabilities - [Studio](https://developer.smartbear.com/smartbear-mcp/docs/swagger-studio-integration) - API and Domain management capabilities, including AI-powered API generation from prompts and automatic standardization - [Contract Testing (PactFlow)](https://developer.smartbear.com/pactflow/default/getting-started) - Contract testing capabilities - [QMetry](https://developer.smartbear.com/smartbear-mcp/docs/qmetry-integration) - QMetry Test Management capabilities - [Zephyr](https://developer.smartbear.com/smartbear-mcp/docs/zephyr-integration) - Zephyr Test Management capabilities - [Collaborator](https://developer.smartbear.com/smartbear-mcp/docs/collaborator-integration) - Review and Remote System Configuration management capabilities ## Prerequisites - Node.js 20+ and npm - Access to SmartBear products (BugSnag, Reflect, Swagger, QMetry, or Zephyr) - Valid API tokens for the products you want to integrate ## Installation The MCP server is distributed as an npm package [`@smartbear/mcp`](https://www.npmjs.com/package/@smartbear/mcp), making it easy to integrate into your development workflow. The server is started with the API key or auth token that you use with your SmartBear product(s). They are optional and can be removed from your configuration if you aren't using the product. For BugSnag, if you provide a project API key it will narrow down all searches to a single project in your BugSnag dashboard. Leave this field blank if you wish to interact across multiple projects at a time. ### VS Code with Copilot For the quickest setup, use the "MCP: Add server…" command in the Command Palette to add the `@smartbear/mcp` npm package. <details> <summary><strong>📋 Manual installation</strong></summary> Alternatively, you can use `npx` (or globally install) the `@smartbear/mcp` package to run the server and add the following to your `.vscode/mcp.json` file: ```json { "servers": { "smartbear": { "type": "stdio", "command": "npx", "args": [ "-y", "@smartbear/mcp@latest" ], "env": { "BUGSNAG_AUTH_TOKEN": "${input:bugsnag_auth_token}", "BUGSNAG_PROJECT_API_KEY": "${input:bugsnag_project_api_key}", "REFLECT_API_TOKEN": "${input:reflect_api_token}", "SWAGGER_API_KEY": "${input:swagger_api_key}", "PACT_BROKER_BASE_URL": "${input:pact_broker_base_url}", "PACT_BROKER_TOKEN": "${input:pact_broker_token}", "PACT_BROKER_USERNAME": "${input:pact_broker_username}", "PACT_BROKER_PASSWORD": "${input:pact_broker_password}", "QMETRY_API_KEY": "${input:qmetry_api_key}", "QMETRY_BASE_URL": "${input:qmetry_base_url}", "ZEPHYR_API_TOKEN": "${input:zephyr_api_token}", "ZEPHYR_BASE_URL": "${input:zephyr_base_url}", "COLLAB_BASE_URL": "${input:collab_base_url}", "COLLAB_USERNAME": "${input:collab_username}", "COLLAB_LOGIN_TICKET": "${input:collab_login_ticket}" } } }, "inputs": [ { "id": "bugsnag_auth_token", "type": "promptString", "description": "BugSnag Auth Token - leave blank to disable BugSnag tools", "password": true }, { "id": "bugsnag_project_api_key", "type": "promptString", "description": "BugSnag Project API Key - for single project interactions", "password": false }, { "id": "reflect_api_token", "type": "promptString", "description": "Reflect API Token - leave blank to disable Reflect tools", "password": true }, { "id": "swagger_api_key", "type": "promptString", "description": "Swagger API Key - leave blank to disable Swagger tools", "password": true }, { "id": "pact_broker_base_url", "type": "promptString", "description": "PactFlow or Pact Broker base url - leave blank to disable the tools", "password": true }, { "id": "pact_broker_token", "type": "promptString", "description": "PactFlow Authentication Token", "password": true }, { "id": "pact_broker_username", "type": "promptString", "description": "Pact Broker Username", "password": true }, { "id": "pact_broker_password", "type": "promptString", "description": "Pact Broker Password", "password": true }, { "id": "qmetry_api_key", "type": "promptString", "description": "QMetry Open API Key", "password": true }, { "id": "qmetry_base_url", "type": "promptString", "description": "By default, connects to https://testmanagement.qmetry.com. Change to a custom QMetry server URL or a region-specific endpoint if needed.", "password": false }, { "id": "zephyr_api_token", "type": "promptString", "description": "Zephyr API token - leave blank to disable Zephyr tools", "password": true }, { "id": "zephyr_base_url", "type": "promptString", "description": "Zephyr API base URL. By default, connects to https://api.zephyrscale.smartbear.com/v2. Change to region-specific endpoint if needed.", "password": false }, { "id": "collab_base_url", "type": "promptString", "description": "Collab base url", "password": true }, { "id": "collab_username", "type": "promptString", "description": "Collab username", "password": true }, { "id": "collab_login_ticket", "type": "promptString", "description": "Collab login ticket", "password": true } ] } ``` </details> ### Claude Desktop Add the following configuration to your `claude_desktop_config.json` to launch the MCP server via `npx`: ```json { "mcpServers": { "smartbear": { "command": "npx", "args": [ "-y", "@smartbear/mcp@latest" ], "env": { "BUGSNAG_AUTH_TOKEN": "your_personal_auth_token", "BUGSNAG_PROJECT_API_KEY": "your_project_api_key", "REFLECT_API_TOKEN": "your_reflect_token", "SWAGGER_API_KEY": "your_swagger_key", "PACT_BROKER_BASE_URL": "your_pactflow_or_pactbroker_base_url", "PACT_BROKER_TOKEN": "your_pactflow_token", "PACT_BROKER_USERNAME": "your_pact_broker_username", "PACT_BROKER_PASSWORD": "your_pact_broker_password", "QMETRY_API_KEY": "your_qmetry_api_key", "QMETRY_BASE_URL": "https://testmanagement.qmetry.com", "ZEPHYR_API_TOKEN": "your_zephyr_api_token", "ZEPHYR_BASE_URL": "https://api.zephyrscale.smartbear.com/v2", "COLLAB_BASE_URL": "your collab base url", "COLLAB_USERNAME": "your collab user name", "COLLAB_LOGIN_TICKET": "your collab login ticket" } } } } ``` ## Documentation For detailed introduction, examples, and advanced configuration visit our 📖 [Full Documentation](https://developer.smartbear.com/smartbear-mcp) ## Local Development For developers who want to contribute to the SmartBear MCP server, please see the [CONTRIBUTING.md](CONTRIBUTING.md) guide. ## License This MCP server is licensed under the MIT License. This means you are free to use, modify, and distribute the software, subject to the terms and conditions of the MIT License. For more details, please see the [LICENSE](LICENSE.txt) file in the project repository. ## Support * [Search open and closed issues](https://github.com/SmartBear/smartbear-mcp/issues?utf8=✓&q=is%3Aissue) for similar problems * [Report a bug or request a feature](https://github.com/SmartBear/smartbear-mcp/issues/new) --- **SmartBear MCP Server** - Bringing the power of SmartBear's testing and monitoring ecosystem to your AI-powered development workflow.