Apidog tests MCP
Adds possibility to work with testing management via MCP
apidog-tests-mcp
MCP (Model Context Protocol) server for managing Apidog test cases, scenarios, suites, and test data. Gives AI assistants full read/write access to Apidog's test management features.
This project is not an official Apidog integration.
Features
- Test Cases -- Create, read, update, delete, and bulk-create test cases for API endpoints
- Test Scenarios -- Build multi-step test flows chaining multiple API calls
- Test Suites -- Organize tests into runnable suites for CI/CD
- Test Data -- Manage data-driven test iterations with CSV-formatted data
- Folders -- Organize scenarios and suites into nested folder structures
- Read-only tools -- List environments, endpoints, categories, tags, runners, and coverage statistics
Documentation
docs/PRACTICAL-USAGE.md-- proven patterns for creating stable test cases/scenarios/suitesSECURITY.md-- vulnerability reporting and secure usage guidelinesCONTRIBUTING.md-- contribution workflowCHANGELOG.md-- release notes
Installation
npm install -g @acabala/apidog-tests-mcp
Or use directly with npx:
npx @acabala/apidog-tests-mcp
Configuration
The server requires these environment variables:
| Variable | Required | Description |
|---|---|---|
APIDOG_ACCESS_TOKEN | Yes | Your Apidog access token |
APIDOG_PROJECT_ID | Yes | The Apidog project ID |
APIDOG_BRANCH_ID | Yes | The branch ID to work with |
APIDOG_DEVICE_ID | Yes | Device identifier for API requests |
APIDOG_BASE_URL | No | Override the API base URL (default: https://api.apidog.com/api/v1) |
MCP Client Configuration
Add to your MCP client config (e.g. Claude Desktop claude_desktop_config.json):
{
"mcpServers": {
"apidog-tests": {
"command": "npx",
"args": ["@acabala/apidog-tests-mcp"],
"env": {
"APIDOG_ACCESS_TOKEN": "your-token",
"APIDOG_PROJECT_ID": "your-project-id",
"APIDOG_BRANCH_ID": "your-branch-id",
"APIDOG_DEVICE_ID": "your-device-id"
}
}
}
}
Recommended Token Practices
- Use a dedicated token for automation.
- Scope access to the minimum required Apidog project(s).
- Rotate tokens regularly.
- Keep MCP client config files local/private.
Available Tools
Read-only
| Tool | Description |
|---|---|
list_environments | List all environments with base URLs |
list_api_endpoints | List API endpoint tree (filterable by module and name) |
list_test_case_categories | List test case categories |
list_test_case_tags | List available tags |
list_runners | List self-hosted test runners |
get_endpoint_statistics | Get test coverage statistics |
Test Cases
| Tool | Description |
|---|---|
list_test_cases | List all test cases (filterable by endpoint) |
get_test_case | Get full test case details |
create_test_case | Create a test case for an endpoint |
create_test_cases_bulk | Create multiple test cases at once |
update_test_case | Update a test case (GET-then-merge) |
delete_test_case | Delete a test case |
Test Scenarios
| Tool | Description |
|---|---|
list_test_scenarios | List scenarios with folder structure |
get_test_scenario_steps | Get steps for a scenario |
create_test_scenario | Create a multi-step test scenario |
update_test_scenario_steps | Set/replace scenario steps |
delete_test_scenario | Delete a scenario |
Test Suites
| Tool | Description |
|---|---|
list_test_suites | List suites with folder structure |
get_test_suite | Get full suite details |
create_test_suite | Create a test suite |
update_test_suite_items | Set suite items (static/dynamic groups) |
delete_test_suite | Delete a suite |
Test Data
| Tool | Description |
|---|---|
list_test_data | List test data records for a test case |
get_test_data | Get test data with CSV rows and columns |
create_test_data | Create test data for a test case |
update_test_data | Update test data (GET-then-merge) |
delete_test_data | Delete a test data record |
Folders
| Tool | Description |
|---|---|
create_scenario_folder | Create a scenario folder |
delete_scenario_folder | Delete a scenario folder |
create_suite_folder | Create a suite folder |
Development
# Install dependencies
npm install
# Run in development mode
npm run start:dev
# Type check
npm run typecheck
# Format
npm run format
# Run tests
npm test
# Run tests with coverage
npm run test:coverage
# Build for production
npm run build
Security
- Use a dedicated automation token with minimal required permissions.
- Never commit
APIDOG_ACCESS_TOKENor environment-specific IDs. - Keep local MCP client config files private.
- See
SECURITY.mdfor reporting and response policy.
Release and Versioning
This repository uses Changesets and a GitHub Actions release workflow:
- Add a changeset for user-visible changes:
npm run changeset - Release automation creates/updates a version PR on
main - Merged release PR publishes to npm with provenance
Open Source Guidelines
- Contribution guide:
CONTRIBUTING.md - Code of conduct:
CODE_OF_CONDUCT.md - Changelog:
CHANGELOG.md
Practical Tips
- Always include
pathandparameters.pathwhen creating route-parameterized test cases. - For update operations, prefer this server's merge-style tools over raw full-replace payloads.
- Use
customScriptpost-processors for assertions to avoid runner issues with declarative assertions. - See
docs/PRACTICAL-USAGE.mdfor complete examples.
Project Structure
src/
index.ts Entry point, registers tools and starts MCP server
client.ts ApidogClient HTTP wrapper with auth headers
types.ts Shared TypeScript interfaces and MCP result helpers
errors.ts Custom error classes (ApidogApiError, ApidogConfigError)
schemas.ts Shared Zod schemas for request parameters
tools/
read.ts Read-only tools (environments, endpoints, categories, etc.)
test-cases.ts Test case CRUD tools
test-scenarios.ts Test scenario CRUD tools
test-suites.ts Test suite CRUD tools
test-data.ts Test data CRUD tools
folders.ts Folder management tools
License
Related Servers
Scout Monitoring MCP
sponsorPut performance and error data directly in the hands of your AI assistant.
Alpha Vantage MCP Server
sponsorAccess financial market data: realtime & historical stock, ETF, options, forex, crypto, commodities, fundamentals, technical indicators, & more
Jenkins API MCP Server
A server for managing Jenkins jobs through its REST API, including operations like building, configuration, and information retrieval.
MCP-ABI
Interact with Ethereum-compatible smart contracts using their ABI.
Starknet MCP
An MCP server providing access to various Starknet RPC methods.
MCP Server Boilerplate
A TypeScript boilerplate for building MCP servers with streamable HTTP and OAuth proxy support.
Remote MCP Server (Authless)
An example of a remote MCP server without authentication, deployable on Cloudflare Workers or runnable locally.
Chess FEN MCP Server
Validate and visualize chess positions using FEN notation.
Composer Package README MCP Server
Fetches comprehensive information about Composer packages from Packagist, including READMEs, metadata, and search functionality.
IdeaJarvis
IdeaJarvis is an idea workspace for product builders. Use AI to structure brainstorming into detailed PRDs, conduct comprehensive market research, build prototypes, and gather real community feedback—turning "what if" into "ready to launch.
BaseCreative MCP
A template for deploying a remote MCP server on Cloudflare Workers without authentication.
Gemini CLI RAG MCP
A RAG-based Q&A server using a vector store built from Gemini CLI documentation.