Skip to main content

MCP server exposing the Backtest360 engine API as tools for AI agents

Project description

backtest360-mcp

MCP server exposing the Backtest360 engine API as tools for AI agents.

Connect any MCP-capable AI client and drive real backtests conversationally: discover indicators, build and validate strategies, run backtests, and read the results — all against the deterministic Backtest360 engine. The server contains no AI and computes no numbers of its own; it is a thin, faithful adapter over the engine HTTP API. Your engine API key and its plan govern everything (permissions, rate limits, data access).

Status: pre-release (v0.1.x). Local stdio transport. Remote (HTTP) deployment is planned.

Install

pip install backtest360-mcp        # or, from a clone: pip install -e .

Requires Python 3.10+ and a Backtest360 API key — create one at backtest360.com.

Configuration

Everything is environment-driven:

Variable Required Default Purpose
BACKTEST360_API_KEY yes Engine API key, sent as X-API-Key
BACKTEST360_ENGINE_URL no https://api.backtest360.com Engine base URL
BACKTEST360_MCP_TIMEOUT no 300 Per-request timeout (seconds)
BACKTEST360_MCP_MAX_OUTPUT_BYTES no 100000 Hard cap on a single tool result

Connect an MCP client

Add the server to your MCP client's configuration (the common mcpServers shape):

{
  "mcpServers": {
    "backtest360": {
      "command": "backtest360-mcp",
      "env": {
        "BACKTEST360_API_KEY": "b360_..."
      }
    }
  }
}

Prefer not to put the key in a config file? Point command at a small wrapper script that exports the key from your secrets manager and then runs backtest360-mcp. A minimal example config is in examples/mcp.json.

Tools

Tool What it does
engine_info Engine version, API contract, health
get_catalog Reference catalogs: operators, execution modes, stop types, sizing methods, bar frequencies, metric sections
list_indicators Indicator discovery; per-indicator parameter schemas
get_strategy_schema JSON Schema for strategy documents
validate_strategy Validate a strategy without running it — returns structured, locatable errors
run_backtest Run a historical backtest
get_latest_signal Evaluate the most recent bar only (no P&L)
compare_backtests Run several strategies on the same data, side by side
compute_stats Compute the metric set from an externally produced returns series
search_tickers / list_tickers Asset discovery for server-side data fetch
get_data_range Available history and bar-count estimate for a symbol

The cheap static catalogs are also published as MCP resources (backtest360://catalog/{name}, backtest360://schema/strategy) for clients that support resource attachment.

Response shaping

A full backtest result is megabytes; an agent's context is not. run_backtest and compare_backtests take response_detail:

  • summary (default) — headline metrics, warnings, counts, equity endpoints
  • stats — every metric the plan allows
  • full — plus series (downsampled, endpoints preserved) and trades (paginated)

include=["trades", "equity_curve", "monthly_returns", "yearly_returns"] adds specific blocks at the lighter levels. Results exceeding the output cap are reduced further and explicitly marked truncated_by_mcp — never silently cut. Shaping only ever selects and thins what the engine returned; no value is computed or altered.

Error semantics

Designed for agents:

  • Fixable by changing the request → returned as a normal result: failed validations arrive as {"valid": false, "errors": [...]} with machine codes and document locations; engine rejections arrive as {"accepted": false, "error": ...} with a hint.
  • Not fixable that way → a tool error with explicit guidance: rate limits carry the Retry-After value; engine-busy says retry with backoff; a compute timeout says do not retry and reduce scope instead; permission problems name the missing capability. Engine request ids are included for support.

Development

pip install -e ".[dev]"
pytest                  # unit suite against a mock engine — no network

License

MIT — see LICENSE.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

backtest360_mcp-0.1.0.tar.gz (19.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

backtest360_mcp-0.1.0-py3-none-any.whl (25.8 kB view details)

Uploaded Python 3

File details

Details for the file backtest360_mcp-0.1.0.tar.gz.

File metadata

  • Download URL: backtest360_mcp-0.1.0.tar.gz
  • Upload date:
  • Size: 19.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for backtest360_mcp-0.1.0.tar.gz
Algorithm Hash digest
SHA256 f322091c61e05b500a1c42f5b675889b7251c4ba5908f322c6909cf8531664a4
MD5 5cc5ad140da394946345b56c57a27c2e
BLAKE2b-256 5dd338722d5e980c983bfea33c96e7524cb21567f2169151c2b7d8631c8f3874

See more details on using hashes here.

Provenance

The following attestation bundles were made for backtest360_mcp-0.1.0.tar.gz:

Publisher: release.yml on Backtest360/backtest360-mcp

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file backtest360_mcp-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: backtest360_mcp-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 25.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for backtest360_mcp-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 94621bba5a44ffd57574527f4930ecbbe5e435802e7bd30eecebace29da9fd06
MD5 1c3c34648967248167483a4dc7b4e183
BLAKE2b-256 95a82bc9dde6a5db893eea473efabf6ea9a6639d43acbe648afdaacc9a211a0f

See more details on using hashes here.

Provenance

The following attestation bundles were made for backtest360_mcp-0.1.0-py3-none-any.whl:

Publisher: release.yml on Backtest360/backtest360-mcp

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page