MCP HubMCP Hub
willccbb

mcp-client-server

by: willccbb

An MCP Server that's also an MCP Client. Useful for letting Claude develop and test MCPs without needing to reset the application.

115created 10/03/2025
Visit
Claude
testing

📌Overview

Purpose: The MCP Test Client is designed to facilitate the testing of MCP servers during their development by acting both as a testing server and client.

Overview: The MCP Test Client functions as a middleware component, registered with Claude to provide essential testing tools for MCP servers. This dual role enables developers to test their servers in development environments without needing to register them with Claude upfront.

Key Features:

  • Deploy MCP Servers: Allows users to deploy server instances to test environments easily.

  • Custom Tool Invocation: Enables calling specific tools on deployed servers with customizable arguments for tailored testing.

  • Automated Test Suites: Facilitates running predefined test suites to ensure server functionality and reliability.

  • Server Log Access: Provides access to server logs for debugging and monitoring purposes and insights.

  • Pre-Registration Testing: Supports testing servers before they are formally registered with Claude, streamlining the development process.


MCP Test Client

An MCP middleware acting 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.

This architecture allows testing 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 corresponds to 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. Available 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

Supported 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