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 simple → complex); min_autonomy requires a designed autonomy regime (step-gated → headless); min_recovery requires a failure-recovery tier (none → durable). |
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:
- On pypi.org: create the project name
agent-harnesses-mcp→ Settings → Publishing → add a trusted publisher: ownerRyanAlberts, repobest-of-Agent-Harnesses, workflowpublish-mcp.yml. No API tokens. - 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
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
4c627ab7b105c62aa1746ffae78b9e5b1eb9e9a45424ac29da8d23b8eb70c610
|
|
| MD5 |
9ace59cee154e3228a724803ccbb27cb
|
|
| BLAKE2b-256 |
a92923635f36cbcfbbd5cf67cc7387aebeb109a67f35d977f737c0c9796d87c0
|
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
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
agent_harnesses_mcp-0.1.0.tar.gz -
Subject digest:
4c627ab7b105c62aa1746ffae78b9e5b1eb9e9a45424ac29da8d23b8eb70c610 - Sigstore transparency entry: 1805173008
- Sigstore integration time:
-
Permalink:
RyanAlberts/best-of-Agent-Harnesses@0ebeea88aecde27dbba070797912baf38684159c -
Branch / Tag:
refs/tags/mcp-v0.1.0 - Owner: https://github.com/RyanAlberts
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-mcp.yml@0ebeea88aecde27dbba070797912baf38684159c -
Trigger Event:
push
-
Statement type:
File details
Details for the file agent_harnesses_mcp-0.1.0-py3-none-any.whl.
File metadata
- Download URL: agent_harnesses_mcp-0.1.0-py3-none-any.whl
- Upload date:
- Size: 6.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a37cbb17344b313f515200251855705c36e832ea2e3bb7b228449e087b9448d2
|
|
| MD5 |
9986e85470e129e57e53ab7808d1e505
|
|
| BLAKE2b-256 |
032c519f0ae82b7922e84831ca8b5e861c439b34eb33ee0d35a205a2708ddfd8
|
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
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
agent_harnesses_mcp-0.1.0-py3-none-any.whl -
Subject digest:
a37cbb17344b313f515200251855705c36e832ea2e3bb7b228449e087b9448d2 - Sigstore transparency entry: 1805173014
- Sigstore integration time:
-
Permalink:
RyanAlberts/best-of-Agent-Harnesses@0ebeea88aecde27dbba070797912baf38684159c -
Branch / Tag:
refs/tags/mcp-v0.1.0 - Owner: https://github.com/RyanAlberts
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-mcp.yml@0ebeea88aecde27dbba070797912baf38684159c -
Trigger Event:
push
-
Statement type: