Skip to main content

MCP server for best-of-Agent-Harnesses: harness recommendations, search, and head-to-head decision guides over a hand-curated, weekly-rescored list of 110 agent harnesses

Project description

agent-harnesses MCP server

The best-of-Agent-Harnesses list as an MCP server, so agents can recommend harnesses instead of you reading 101 table rows.

Single file, stdio transport, no clone needed — it fetches harnesses.json from this repo at startup (or reads it locally from a checkout). Requires uv.

Install

Claude Code:

claude mcp add agent-harnesses -- uv run https://raw.githubusercontent.com/RyanAlberts/best-of-Agent-Harnesses/main/mcp/server.py

Any other MCP client (Cursor, Codex, Gemini CLI, ...):

{
  "mcpServers": {
    "agent-harnesses": {
      "command": "uv",
      "args": ["run", "https://raw.githubusercontent.com/RyanAlberts/best-of-Agent-Harnesses/main/mcp/server.py"]
    }
  }
}

Tools

Tool What it does
pick_harness(use_case, max_complexity?, min_autonomy?, min_recovery?, open_source_only?, limit?) Ranked recommendations for a use case, seeded by the list's hand-curated use-case index. max_complexity caps adoption surface (super simplecomplex); min_autonomy requires a designed autonomy regime (step-gatedheadless); min_recovery requires a failure-recovery tier (nonedurable).
search_harnesses(query, limit?) Keyword search across names, descriptions, tags, and categories.
get_harness(github_id) Full record for one project.
list_comparisons() The head-to-head decision guides (OpenClaw vs Hermes, terminal coding agents, …) with summaries.
get_comparison(slug) Full markdown of one guide — architecture trade-offs, field reports, billing reality. Always current: served from the repo's main.
list_categories() The 10 categories, use-case intents, and the complexity/autonomy/recovery scales.

Example: "pick_harness('sandboxed code execution for generated code', max_complexity='slightly complex', open_source_only=True)" → E2B, smolagents, Daytona... each with stars, tier, license signal, and a one-line reason.

Data is regenerated by scripts/generate.py; star counts carry a stars_captured date, and the comparisons index is rebuilt from comparisons/*.md on every refresh — the server always serves current main.

Distribution

The server is packaged as agent-harnesses-mcp (this directory's pyproject.toml) and registered in the official MCP registry as io.github.ryanalberts/agent-harnesses (server.json at the repo root). Once a release is published, package-manager installs work everywhere:

# any MCP client, via PyPI
uvx agent-harnesses-mcp
# Claude Code
claude mcp add agent-harnesses -- uvx agent-harnesses-mcp

Until then (and forever, as the zero-install path), the raw-URL one-liner at the top of this README works from any machine with uv.

Publishing (maintainer runbook)

Releases are automated by .github/workflows/publish-mcp.yml on a mcp-v* tag: it builds the wheel, publishes to PyPI via trusted publishing, and publishes server.json to the official MCP registry via GitHub OIDC.

One-time setup, then never again:

  1. On pypi.org: create the project name agent-harnesses-mcp → Settings → Publishing → add a trusted publisher: owner RyanAlberts, repo best-of-Agent-Harnesses, workflow publish-mcp.yml. No API tokens.
  2. Nothing for the MCP registry — GitHub OIDC from this repo authorizes the io.github.ryanalberts/* namespace automatically.

Per release: bump the version in mcp/pyproject.toml and server.json (the workflow fails loudly on mismatch), then git tag mcp-v<version> && git push origin mcp-v<version>.

Also indexed via smithery.yaml (submit the repo once at smithery.ai); other directories (Glama, PulseMCP, mcpservers.org) crawl the official registry.

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

agent_harnesses_mcp-0.1.0.tar.gz (5.9 kB view details)

Uploaded Source

Built Distribution

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

agent_harnesses_mcp-0.1.0-py3-none-any.whl (6.4 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for agent_harnesses_mcp-0.1.0.tar.gz
Algorithm Hash digest
SHA256 4c627ab7b105c62aa1746ffae78b9e5b1eb9e9a45424ac29da8d23b8eb70c610
MD5 9ace59cee154e3228a724803ccbb27cb
BLAKE2b-256 a92923635f36cbcfbbd5cf67cc7387aebeb109a67f35d977f737c0c9796d87c0

See more details on using hashes here.

Provenance

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

Publisher: publish-mcp.yml on RyanAlberts/best-of-Agent-Harnesses

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

File details

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

File metadata

File hashes

Hashes for agent_harnesses_mcp-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 a37cbb17344b313f515200251855705c36e832ea2e3bb7b228449e087b9448d2
MD5 9986e85470e129e57e53ab7808d1e505
BLAKE2b-256 032c519f0ae82b7922e84831ca8b5e861c439b34eb33ee0d35a205a2708ddfd8

See more details on using hashes here.

Provenance

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

Publisher: publish-mcp.yml on RyanAlberts/best-of-Agent-Harnesses

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