mcp-client-server

MCP.Pizza Chef: willccbb

The mcp-client-server is a unique MCP server that also functions as an MCP client, enabling developers to test and develop MCP servers without resetting the application. It acts as a middleware between Claude and MCP servers under test, exposing testing tools to Claude while connecting to other MCP servers. This setup facilitates deploying test environments, running automated test suites, calling tools with custom arguments, and viewing server logs, streamlining MCP server development and validation.

Use This MCP server To

Deploy MCP servers to isolated test environments Run automated test suites on MCP servers Invoke individual MCP server tools with custom parameters View and analyze logs from MCP servers under test Test MCP servers without direct registration to Claude Validate MCP server functionality during development Simulate client-server interactions for MCP servers Debug MCP servers with real-time feedback

README

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:

  1. Deploy a server:
mcp__mcp-test__mcp_test_deploy_server({
  name: "my-server",
  source_path: "/path/to/server",
  env_vars: {
    "API_KEY": "${API_KEY}"
  }
})
  1. 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
  }
})
  1. Run tests against a server:
mcp__mcp-test__mcp_test_run_tests({
  server_name: "my-server"
})
  1. View server logs:
mcp__mcp-test__mcp_test_get_logs({
  server_name: "my-server",
  lines: 100
})
  1. List deployed servers:
mcp__mcp-test__mcp_test_list_servers({})
  1. 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:

  1. Develop an MCP server in the playground directory
  2. Deploy it to the test environment with MCP Test Client
  3. Test functionality, call individual tools, and debug issues
  4. Fix and iterate until the server works correctly
  5. Migrate the server to mcp-servers/ when ready
  6. 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.

mcp-client-server FAQ

How does mcp-client-server act as both a server and a client?
It registers as a server with Claude to expose testing tools, while simultaneously acting as a client to connect and test other MCP servers.
Can I use mcp-client-server to automate testing of MCP servers?
Yes, it supports running automated test suites to validate MCP server behavior.
Does mcp-client-server require resetting the application to test new MCP servers?
No, it allows testing without resetting the application, streamlining development workflows.
How can I view logs from MCP servers under test?
The mcp-client-server provides log viewing capabilities for servers it tests, enabling easier debugging.
Is mcp-client-server limited to testing with Claude only?
While designed to register with Claude, it can test any MCP server by acting as a client to those servers.
Can I call individual tools on MCP servers with custom arguments?
Yes, it supports invoking specific tools with custom parameters for targeted testing.
What environments can I deploy MCP servers to using mcp-client-server?
You can deploy MCP servers to isolated test environments for safe and controlled testing.
How does mcp-client-server improve MCP server development?
By enabling seamless testing, automated suites, and log analysis without app resets, it accelerates development cycles.