neurodev-mcp
Enables automated generation of test suites based on AST analysis and execution of tests with detailed coverage reporting and performance metrics.
Provides comprehensive static analysis, security scanning, type checking, and automated PEP8 formatting for Python source code.
๐ง NeuroDev MCP Server
Intelligent Code Analysis, Test Generation & Execution
A powerful Model Context Protocol (MCP) server that supercharges your Python development workflow with AI-powered code review, intelligent test generation, and comprehensive test execution.
Features โข Installation โข Quick Start โข Tools โข Examples
โจ Features
๐ Code Review
6 Powerful Analyzers
pylint- Code quality & PEP8flake8- Style enforcementmypy- Type checkingbandit- Security scanningradon- Complexity metricsAST- Custom inspections
Real-time issue detection
Security vulnerability scanning
Complexity & maintainability scores
๐งช Test Generation
Intelligent AST Analysis
Auto-generate pytest tests
Happy path coverage
Edge case handling
Exception testing
Type validation tests
Supports functions & classes
Type-hint aware
โถ๏ธ Test Execution
Comprehensive Testing
Isolated environment
Coverage reporting
Line-by-line analysis
Timeout protection
Detailed pass/fail results
Performance metrics
๐จ Code Formatting
Auto-formatting
black- Opinionated styleautopep8- PEP8 compliance
Configurable line length
Consistent code style
One-command formatting
๐ฆ Installation
Quick Install
```bash
# Clone the repository
git clone https://github.com/ravikant1918/neurodev-mcp.git
cd neurodev-mcp
# Create virtual environment (recommended)
python -m venv .venv
source .venv/bin/activate # On Windows: .venv\\Scripts\\activate
# Install the package
pip install -e .
\`\`\`
### **Verify Installation**
\`\`\`bash
# Run tests (should show 15/15 passing)
python test_installation.py
# Test the server
python -m neurodev_mcp.server
\`\`\`
<details>
<summary><b>๐ Project Structure</b> (click to expand)</summary>
\`\`\`
neurodev-mcp/
โโ neurodev_mcp/ # ๐ฆ Main package
โ โโ __init__.py # Package exports
โ โโ server.py # MCP server entry point
โ โโ analyzers/ # ๐ Code analysis
โ โ โโ __init__.py
โ โ โโ code_analyzer.py # Multi-tool static analysis
โ โโ generators/ # ๐งช Test generation
โ โ โโ __init__.py
โ โ โโ test_generator.py # AST-based test creation
โ โโ executors/ # โถ๏ธ Test execution
โ โโ __init__.py
โ โโ test_executor.py # Test running & formatting
โโ pyproject.toml # Project configuration
โโ README.md # This file
โโ test_installation.py # Installation validator
โโ examples.py # Usage examples
โโ requirements.txt # Dependencies๐ Quick Start
Step 1: Configure Your MCP Client
Edit ~/Library/Application Support/Claude/claude_desktop_config.json:
{
"mcpServers": {
"neurodev-mcp": {
"command": "/absolute/path/to/neurodev-mcp/.venv/bin/python",
"args": ["-m", "neurodev_mcp.server"]
}
}
}๐ก Tip: Replace
/absolute/path/to/neurodev-mcpwith your actual path
Add to your MCP settings:
{
"neurodev-mcp": {
"command": "python",
"args": ["-m", "neurodev_mcp.server"]
}
}Run the server directly:
# Using the module
python -m neurodev_mcp.server
# Or as a command (if installed)
neurodev-mcpStep 2: Restart Your Client
Restart Claude Desktop or reload VSCode to load the server.
Step 3: Start Using! ๐
Try these commands with your AI assistant:
"Review this Python code for issues"
"Generate unit tests for this function"
"Run these tests with coverage"
"Format this code to PEP8 standards"
๐ Transport Options
NeuroDev MCP supports multiple transport protocols for different use cases:
STDIO (Default) - Local CLI
Perfect for local development with MCP clients like Claude Desktop or Cline:
# Default STDIO transport
neurodev-mcp
# Or explicitly specify STDIO
neurodev-mcp --transport stdioConfiguration (Claude Desktop):
{
"mcpServers": {
"neurodev-mcp": {
"command": "neurodev-mcp",
"args": ["--transport", "stdio"]
}
}
}SSE (Server-Sent Events) - Web Integration
For web-based integrations and HTTP streaming:
# Run with SSE on default port (8000)
neurodev-mcp --transport sse
# Custom host and port
neurodev-mcp --transport sse --host 0.0.0.0 --port 3000Endpoints:
SSE Stream:
http://localhost:8000/sseMessages:
http://localhost:8000/messages(POST)
Web Client Example:
const sse = new EventSource('http://localhost:8000/sse');
sse.onmessage = (event) => {
const data = JSON.parse(event.data);
console.log('Received:', data);
};
// Send message
fetch('http://localhost:8000/messages', {
method: 'POST',
headers: { 'Content-Type': 'application/json' },
body: JSON.stringify({
method: 'tools/call',
params: {
name: 'code_review',
arguments: { code: 'def test(): pass', analyzers: ['pylint'] }
}
})
});Transport Comparison
Transport | Use Case | Best For |
STDIO | Local CLI clients | Claude Desktop, Cline, local development |
SSE | Web integrations | Browser apps, webhooks, remote clients |
๐ ๏ธ Available Tools
1. code_review
๐ Comprehensive code analysis with multiple static analysis tools
Input:
{
"code": "def calculate(x):\n return x * 2",
"analyzers": ["pylint", "flake8", "mypy", "bandit", "radon", "ast"]
}Output:
Detailed issue reports from each analyzer
Security vulnerabilities
Complexity metrics
Code quality scores
Line-by-line suggestions
2. generate_tests
๐งช Intelligent pytest test generation using AST analysis
Input:
{
"code": "def add(a: int, b: int) -> int:\n return a + b",
"module_name": "calculator",
"save": false
}Output:
Complete pytest test suite
Multiple test cases (happy path, edge cases, exceptions)
Type validation tests
Ready-to-run test code
3. run_tests
โถ๏ธ Execute pytest tests with coverage reporting
Input:
{
"test_code": "def test_add():\n assert add(1, 2) == 3",
"source_code": "def add(a, b):\n return a + b",
"timeout": 30
}Output:
Pass/fail status
Coverage percentage
Line coverage details
Execution time
Detailed stdout/stderr
4. format_code
๐จ Auto-format Python code to PEP8 standards
Input:
{
"code": "def messy( x,y ):\n return x+y",
"line_length": 88
}Output:
Beautifully formatted code
PEP8 compliant
Consistent style
Change detection
๐ก Usage Examples
Example 1: Complete Code Review Workflow
You: "Review this code for issues and security problems"
[paste code]
AI: [Uses code_review tool]
โ Finds 3 style issues
โ Detects 1 security vulnerability
โ Suggests complexity improvements
You: "Fix those issues and show me the updated code"
AI: [Provides fixed code with explanations]Example 2: Test Generation & Execution
You: "Generate tests for this function and run them"
def divide(a: float, b: float) -> float:
if b == 0:
raise ValueError("Cannot divide by zero")
return a / b
AI: [Uses generate_tests tool]
โ Creates 5 test cases
โ Includes edge cases (zero, negative numbers)
โ Tests exception handling
[Uses run_tests tool]
โ 5/5 tests passing โ
โ 100% code coverage
โ All edge cases handledExample 3: Code Formatting
You: "Format this messy code"
def calculate( x,y,z ):
result=x+y+z
if result>10:
return True
return False
AI: [Uses format_code tool]
โ Applies black formatting
โ Returns clean, PEP8-compliant code
def calculate(x, y, z):
result = x + y + z
if result > 10:
return True
return False๐ Requirements
Package | Version | Purpose |
| โฅ0.9.0 | Model Context Protocol SDK |
| โฅ3.0.0 | Code quality analysis |
| โฅ7.0.0 | Style checking |
| โฅ1.7.0 | Static type checking |
| โฅ1.7.5 | Security scanning |
| โฅ6.0.1 | Complexity metrics |
| โฅ23.12.0 | Code formatting |
| โฅ2.0.4 | PEP8 formatting |
| โฅ7.4.3 | Testing framework |
| โฅ4.1.0 | Coverage reporting |
| โฅ2.2.0 | Test timeouts |
Python: 3.8 or higher
๐งช Development
Running Tests
# Run installation tests
python test_installation.py
# Run examples
python examples.py
# Run pytest (if you add tests)
pytestUsing as a Library
from neurodev_mcp import CodeAnalyzer, TestGenerator, TestExecutor
import asyncio
# Analyze code
code = "def hello(): print('world')"
result = asyncio.run(CodeAnalyzer.analyze_ast(code))
# Generate tests
tests = TestGenerator.generate_tests(code, "mymodule")
# Run tests
output = TestExecutor.run_tests(test_code, source_code)โ Troubleshooting
โ Check that the path in config is absolute
โ Ensure the Python executable path is correct
โ Restart Claude Desktop or VSCode completely
โ Check server logs for errors
# Reinstall the package
pip install -e .
# Verify installation
python -c "from neurodev_mcp import CodeAnalyzer; print('โ OK')"
# Run installation tests
python test_installation.pyโ Ensure Python 3.8+ is installed
โ Activate virtual environment:
source .venv/bin/activateโ Reinstall dependencies:
pip install -e .โ Run:
python test_installation.pyto diagnose
Some analyzers (pylint, mypy) can be slow on large files
Use specific analyzers:
"analyzers": ["flake8", "ast"]Increase timeout for large test suites
Consider caching results (future feature)
๐ค Contributing
Contributions are welcome! Here's how:
Fork the repository
Create a feature branch:
git checkout -b feature/amazing-featureMake your changes
Run tests:
python test_installation.pyCommit:
git commit -m 'Add amazing feature'Push:
git push origin feature/amazing-featureOpen a Pull Request
Future Enhancements
Additional analyzers (pydocstyle, vulture)
Result caching for performance
Configuration file support
Web dashboard
Multi-language support
CI/CD pipeline
๐ License
This project is licensed under the MIT License - see the LICENSE file for details.
๐ Acknowledgments
Built with the Model Context Protocol
Testing with pytest
Formatting with black
๐ Support
๐ Documentation: You're reading it!
๐ Issues: GitHub Issues
๐ฌ Discussions: GitHub Discussions
๐ง Email: team@neurodev.io
Ready to supercharge your Python development! ๐
Made with โค๏ธ by the NeuroDev Team
โญ Star on GitHub โข ๐ Report Bug โข โจ Request Feature
This server cannot be installed
Maintenance
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/ravikant1918/neurodev-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server