MCP Server Demo in python
Simple implementation of a Model Communication Protocol (MCP) server using Python over the network using sse transport
Perteghella
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()functionsubtract()functionget_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
stdiotransport. To expose it over the network, ensure you configure it to usessetransport. - The server runs on
localhostand listens on port8000using uvicorn.
Feel free to contribute or open issues if you encounter any problems!
Recommended Servers
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.
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.
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.
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.
@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.
Linear MCP Server
Enables interaction with Linear's API for managing issues, teams, and projects programmatically through the Model Context Protocol.
mermaid-mcp-server
A Model Context Protocol (MCP) server that converts Mermaid diagrams to PNG images.
Jira-Context-MCP
MCP server to provide Jira Tickets information to AI coding agents like Cursor
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.
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.