An MCP (Model Context Protocol) server that provides a physics-aware combo generator for wizard-style inline skating, powered by the wzrdbrain Python package.
Unlike random trick generators, this server understands skating physics. It models moves as state transitions (direction, edge, stance, weight point), ensuring that the combinations it generates are actually executable and flow naturally.
- Python 3.13+
- uv for dependency management
- Node.js (optional, for MCP Inspector)
git clone https://github.com/your-username/wzrdbrain-mcp.git
cd wzrdbrain-mcp
uv syncOpen the configuration file for your operating system:
- macOS:
~/Library/Application Support/Claude/claude_desktop_config.json - Windows:
%APPDATA%\Claude\claude_desktop_config.json
Add the following, replacing <ABSOLUTE_PATH_TO_PROJECT> with the actual path:
{
"mcpServers": {
"wzrdbrain": {
"command": "uv",
"args": [
"--directory",
"<ABSOLUTE_PATH_TO_PROJECT>",
"run",
"mcp-server-wzrdbrain"
]
}
}
}Restart Claude Desktop. The wzrdbrain tools will appear via the hammer icon in your chat.
claude mcp add wzrdbrain -- uv --directory <ABSOLUTE_PATH_TO_PROJECT> run mcp-server-wzrdbrainAdd to .gemini/settings.json (project-level) or ~/.gemini/settings.json (user-level), replacing <ABSOLUTE_PATH_TO_PROJECT> with the actual path:
{
"mcpServers": {
"wzrdbrain": {
"command": "uv",
"args": [
"--directory",
"<ABSOLUTE_PATH_TO_PROJECT>",
"run",
"mcp-server-wzrdbrain"
]
}
}
}See the Gemini CLI MCP docs for additional options like timeout and env.
Test the tools locally before connecting to a client:
npx @modelcontextprotocol/inspector uv run mcp-server-wzrdbrainGenerates a physics-aware sequence of inline skating tricks.
| Parameter | Type | Default | Range |
|---|---|---|---|
num_tricks |
integer | 3 | 1–20 |
Each line shows the trick name and its entry/exit state (direction/edge/stance/point):
1. Front Soul Slide: front/outside/open/all → front/outside/open/all
2. Front Mizu Slide: front/inside/open/all → front/inside/open/all
3. Front Fast Slide: front/outside/open/all → front/outside/open/all
Returns the available trick categories as a sorted list. No parameters.
['base', 'manual', 'pivot', 'slide', 'swivel', 'transition', 'turn']
Lists all tricks in a given category. Case-insensitive.
| Parameter | Type | Required |
|---|---|---|
category |
string | yes |
Tricks in category:
- Back Predator (Open)
- Back Predator One
- Front Predator (Open)
- Front Predator One
Invalid categories return an error listing valid options:
Error: Invalid category. Valid categories are: base, manual, pivot, slide, swivel, transition, turn
A prompt template that instructs the LLM to generate a 4-trick combo and structure it into a 30-minute practice session:
- Warm-up (5 minutes)
- Trick Breakdown & Practice (15 minutes)
- Combo Execution (5 minutes)
- Cool-down (5 minutes)
| Message | Cause |
|---|---|
Error: num_tricks must be an integer. |
Passed a string, float, or non-integer type |
Error: num_tricks must be between 1 and 20. |
Value outside the allowed range |
Error: Invalid category. Valid categories are: ... |
Unrecognized category name |
Error generating combo: An internal error occurred... |
Unexpected exception from wzrdbrain |
uv sync --extra test# All tests
uv run pytest -v
# Single test
uv run pytest tests/test_server.py::TestGenerateSkatingComboHappy::test_default_three_tricks
# Coverage (target: 100%)
uv run pytest --cov=wzrdbrain_mcp --cov-report=term-missingsrc/wzrdbrain_mcp/server.py # All MCP tools, prompts, and the entry point
tests/test_server.py # Full test suite
pyproject.toml # Dependencies (pinned with ==) and pytest config
- FastMCP decorated functions are plain callables — tests call them directly without an MCP client.
wzrdbrainlibrary provides two touchpoints:wzrdbrain.generate_combo()for combo generation andMOVESdict for the trick catalog.- State transitions are modeled as
direction/edge/stance/point. - Input validation returns error strings, not exceptions. Maintain this pattern for new tools.
- Output sanitization validates the structure of
wzrdbrainresponses before formatting. - Logging goes to stderr only. User input is sanitized via
_sanitize_for_log()before logging to prevent log injection. - Dependencies are pinned with exact versions (
==) inpyproject.tomland locked viauv.lock.
- Add a
@mcp.tool()function inserver.py - Validate all inputs (type checks, range bounds) — return error strings for invalid input
- Sanitize outputs from
wzrdbrainbefore returning - Log user-supplied values through
_sanitize_for_log()only - Add tests in
tests/test_server.py— direct calls for happy paths,unittest.mock.patchfor error paths - Verify coverage stays at 100%:
uv run pytest --cov=wzrdbrain_mcp --cov-report=term-missing - Update this README with the new tool's documentation