
mcp-client-server
An MCP Server that's also an MCP Client. Useful for letting Claude develop and test MCPs without needing to reset the application.
3 years
Works with Finder
2
Github Watches
7
Github Forks
115
Github Stars
MCP Test Client
An MCP middleware that acts as both a server (to Claude) and a client (to servers under test) for testing MCP servers during development.
Architecture
The MCP Test Client has a dual role:
- It's a server registered with Claude that exposes tools for testing
- It's a client that connects to and tests other MCP servers
┌─────────────┐ ┌───────────────────┐ ┌────────────────┐
│ │ Tools │ │ Client │ │
│ Claude │─────────>│ MCP Test Client │─────────>│ Server Under │
│ │ │ │ │ Test │
└─────────────┘ └───────────────────┘ └────────────────┘
This architecture lets you test MCP servers without registering them directly with Claude.
Features
- Deploy MCP servers to test environments
- Call individual tools with custom arguments
- Run automated test suites
- View server logs
- Test servers before formal registration with Claude
Implementation
The MCP Test Client is implemented with:
- Process Management: Spawns and manages MCP server processes
- MCP SDK Client: Uses the official MCP SDK to communicate with servers
- Custom Transport: Implements a custom transport for stdio communication
- Test Execution: Runs tests and validates responses
- CLI Interface: Provides an interactive testing interface
The current implementation is Phase 1 of the design plan, with future enhancements planned for Phases 2 and 3.
Installation
# Install dependencies
npm install
# Build the TypeScript project
npm run build
Usage
As an MCP Server
The MCP Test Client is registered with Claude via the claude-mcp-local
script. You can use the following tools:
- Deploy a server:
mcp__mcp-test__mcp_test_deploy_server({
name: "my-server",
source_path: "/path/to/server",
env_vars: {
"API_KEY": "${API_KEY}"
}
})
- Call a tool on a deployed server:
mcp__mcp-test__mcp_test_call_tool({
server_name: "my-server",
tool_name: "tool_name",
arguments: {
// Tool-specific arguments
}
})
- Run tests against a server:
mcp__mcp-test__mcp_test_run_tests({
server_name: "my-server"
})
- View server logs:
mcp__mcp-test__mcp_test_get_logs({
server_name: "my-server",
lines: 100
})
- List deployed servers:
mcp__mcp-test__mcp_test_list_servers({})
- Stop a server:
mcp__mcp-test__mcp_test_stop_server({
server_name: "my-server"
})
As a CLI Tool
Run the CLI interface for testing:
# Use npm script
npm run test
# Or run directly
node dist/test-runner.js
This provides an interactive menu for deploying, testing, and managing MCP servers.
Development Workflow
The MCP Test Client supports this workflow:
- Develop an MCP server in the playground directory
- Deploy it to the test environment with MCP Test Client
- Test functionality, call individual tools, and debug issues
- Fix and iterate until the server works correctly
- Migrate the server to mcp-servers/ when ready
- Register with Claude through claude-mcp-local
Future Enhancements
Planned enhancements include:
- Phase 2: Docker-based container management, comprehensive test suites
- Phase 3: Migration tools, more advanced test validation
See notes/mcp_test_client_design.md
for the complete design document.
相关推荐
I find academic articles and books for research and literature reviews.
Confidential guide on numerology and astrology, based of GG33 Public information
Converts Figma frames into front-end code for various mobile frameworks.
Embark on a thrilling diplomatic quest across a galaxy on the brink of war. Navigate complex politics and alien cultures to forge peace and avert catastrophe in this immersive interstellar adventure.
Advanced software engineer GPT that excels through nailing the basics.
Delivers concise Python code and interprets non-English comments
💬 MaxKB is a ready-to-use AI chatbot that integrates Retrieval-Augmented Generation (RAG) pipelines, supports robust workflows, and provides advanced MCP tool-use capabilities.
Micropython I2C-based manipulation of the MCP series GPIO expander, derived from Adafruit_MCP230xx
MCP server to provide Figma layout information to AI coding agents like Cursor
The all-in-one Desktop & Docker AI application with built-in RAG, AI agents, No-code agent builder, MCP compatibility, and more.
Python code to use the MCP3008 analog to digital converter with a Raspberry Pi or BeagleBone black.
Put an end to hallucinations! GitMCP is a free, open-source, remote MCP server for any GitHub project
Reviews

user_2U0KZqnG
I have been using mcp-client-server by willccbb, and I'm thoroughly impressed. This client-server application is robust, user-friendly, and well-documented. The seamless interaction between client and server components enhances productivity, and the support provided by the community is outstanding. I highly recommend checking it out at https://github.com/willccbb/mcp-client-server. Great work, willccbb!