MCP Server Demo in python

MCP Server Demo in python

Simple implementation of a Model Communication Protocol (MCP) server using Python over the network using sse transport

Perteghella

Developer Tools
Visit Server

README

MCP Server Demo in python

This repository contains a simple implementation of a Model Communication Protocol (MCP) server using Python. The server is designed to demonstrate the basic functionality of an MCP server and can be used for testing and development purposes.

The server uses uvicorn by default, running on port 8000. To expose the server over the network, use the sse transport.


Setup Instructions

1. Create and Activate a Virtual Environment

Run the following commands to set up your Python environment:

python3 -m venv .venv
source .venv/bin/activate
pip install -r requirements.txt

Starting the Server

To start the server, run:

python3 server.py

Verify the Server is Running

You can verify that the server is running on port 8000 using the following commands:

  • Check active connections:

    netstat -n | grep 8000
    
  • Check processes using the port:

    lsof -i :8000
    
  • Test the server with curl:

    curl http://0.0.0.0:8000/sse
    

Running Tests

The project includes a comprehensive test suite using pytest. To run the tests:

# Install test dependencies
pip install -r requirements.txt

# Run tests with verbose output
pytest -v

# Run tests with coverage report
pytest --cov=.

Test Coverage

The test suite includes:

  • Basic functionality tests for addition and subtraction
  • Input validation and type checking
  • Edge cases with large numbers
  • API endpoint testing for greetings

All tests are located in test_server.py and cover:

  • add() function
  • subtract() function
  • get_greeting() function
  • Type error handling
  • Edge cases handling

Tools Using the Server

To integrate this server with tools like Cursor or Claude, use the following mcp.json configuration file:

{
  "mcpServers": {
    "demo-server": {
      "transport": "sse",
      "url": "http://localhost:8000/sse"
    }
  }
}

Notes

  • By default, the server uses stdio transport. To expose it over the network, ensure you configure it to use sse transport.
  • The server runs on localhost and listens on port 8000 using uvicorn.

Feel free to contribute or open issues if you encounter any problems!

Recommended Servers

playwright-mcp

playwright-mcp

A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.

Official
Featured
TypeScript
Magic Component Platform (MCP)

Magic Component Platform (MCP)

An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.

Official
Featured
Local
TypeScript
MCP Package Docs Server

MCP Package Docs Server

Facilitates LLMs to efficiently access and fetch structured documentation for packages in Go, Python, and NPM, enhancing software development with multi-language support and performance optimization.

Featured
Local
TypeScript
Claude Code MCP

Claude Code MCP

An implementation of Claude Code as a Model Context Protocol server that enables using Claude's software engineering capabilities (code generation, editing, reviewing, and file operations) through the standardized MCP interface.

Featured
Local
JavaScript
@kazuph/mcp-taskmanager

@kazuph/mcp-taskmanager

Model Context Protocol server for Task Management. This allows Claude Desktop (or any MCP client) to manage and execute tasks in a queue-based system.

Featured
Local
JavaScript
Linear MCP Server

Linear MCP Server

Enables interaction with Linear's API for managing issues, teams, and projects programmatically through the Model Context Protocol.

Featured
JavaScript
mermaid-mcp-server

mermaid-mcp-server

A Model Context Protocol (MCP) server that converts Mermaid diagrams to PNG images.

Featured
JavaScript
Jira-Context-MCP

Jira-Context-MCP

MCP server to provide Jira Tickets information to AI coding agents like Cursor

Featured
TypeScript
Linear MCP Server

Linear MCP Server

A Model Context Protocol server that integrates with Linear's issue tracking system, allowing LLMs to create, update, search, and comment on Linear issues through natural language interactions.

Featured
JavaScript
Sequential Thinking MCP Server

Sequential Thinking MCP Server

This server facilitates structured problem-solving by breaking down complex issues into sequential steps, supporting revisions, and enabling multiple solution paths through full MCP integration.

Featured
Python