MCP server wrapping golden-dataset-studio for version-controlled golden dataset management and RAG evaluation
Project description
golden-dataset-mcp
An MCP server wrapping golden-dataset-studio — version-controlled golden dataset management and semantic evaluation for RAG/LLM pipelines.
This is a thin protocol layer over the existing golden_dataset library (DatasetStore, Evaluator). It does not reimplement any logic — it exposes the library's existing Python API as MCP tools so an agent (Claude Desktop, Claude Code, or any MCP client) can manage golden datasets conversationally.
No LLM API key required. Evaluation uses TF-IDF cosine similarity (scikit-learn), not an LLM call.
Why a separate package from golden-dataset-studio?
golden-dataset-studio is a CLI tool — designed for a human typing golden add, golden commit, etc. in a terminal. golden-dataset-mcp exposes the same underlying operations as MCP tools so an LLM agent can drive them programmatically, e.g. as part of an automated RAG evaluation pipeline. Keeping them as separate PyPI packages means CLI users aren't forced to pull in fastmcp as a dependency, and MCP users get a clean, protocol-focused package.
Tools
| Tool | What it does |
|---|---|
init_dataset |
Initialise a new dataset at a given path |
add_entry |
Add a question/answer pair to the working tree |
update_entry |
Edit fields of an existing working-tree entry |
delete_entry |
Remove an entry from the working tree |
list_entries |
List working-tree or committed-version entries |
commit_version |
Snapshot the working tree as a new immutable version |
diff_versions |
Show entries added/removed/changed between two versions |
evaluate_answers |
Score actual answers against a version via TF-IDF cosine similarity |
dataset_status |
Show current version, working tree size, and version history |
Design: every tool takes an explicit dataset_path
Unlike the CLI (which operates on the current working directory), every tool here requires an explicit dataset_path parameter. This keeps the server fully stateless between calls — no hidden "current dataset" session state to lose track of, and safe for one server instance to manage multiple datasets or serve multiple concurrent clients.
Installation
pip install golden-dataset-mcp
This pulls in golden-dataset-studio automatically as a dependency.
Usage with Claude Desktop / Claude Code
{
"mcpServers": {
"golden-dataset": {
"command": "golden-dataset-mcp"
}
}
}
No environment variables needed — no API key, no config.
Example flow
1. init_dataset(dataset_path="./my-rag-eval", name="support-bot-eval")
2. add_entry(dataset_path="./my-rag-eval", question="...", answer="...")
[repeat for each golden Q&A pair]
3. commit_version(dataset_path="./my-rag-eval", description="initial 50 questions")
4. [run your RAG pipeline, collect actual answers]
5. evaluate_answers(dataset_path="./my-rag-eval", actual_answers=[...])
-> avg_semantic_similarity, per-entry scores, pass/fail
As your RAG pipeline changes over time, commit_version again after edits and use diff_versions to see exactly what changed in your golden set between releases.
Relationship to the underlying library
golden-dataset-studio |
golden-dataset-mcp |
|
|---|---|---|
| Interface | CLI (golden ...) |
MCP tools |
| Driven by | A human typing commands | An LLM agent / MCP client |
| Path handling | Current working directory | Explicit dataset_path per call |
| Dependency direction | — | Depends on golden-dataset-studio |
If you want the human-driven CLI, use golden-dataset-studio directly. If you want an agent to drive it, use this package.
Development
git clone https://github.com/nipun-sharma/golden-dataset-mcp
cd golden-dataset-mcp
pip install -e ".[dev]" --break-system-packages
pytest -v
Validate the MCP-facing contract:
npx @modelcontextprotocol/inspector golden-dataset-mcp
Limitations
evaluate_answersuses TF-IDF cosine similarity, which captures lexical overlap better than deep semantic meaning. For embedding-based or RAGAS-style metrics, call the underlying library'sEvaluator.ragas_evaluate()directly (requirespip install ragas datasets— not exposed as an MCP tool in this version).- Very short or stop-word-only answers will raise an error. scikit-learn's TF-IDF vectorizer raises
ValueError: empty vocabularyon inputs like a bare"4"or"the a an". Avoid single-token golden answers, or expectevaluate_answersto fail on them. - All state is filesystem-backed JSON/JSONL under
<dataset_path>/.golden_dataset/; this server does no remote storage or syncing. golden-dataset-studio(as of 0.1.1) usesscikit-learnat runtime but does not declare it in its own dependencies — this package pinsscikit-learnexplicitly soevaluate_answersworks correctly out of the box regardless of upstream's declared requirements.
License
MIT
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 golden_dataset_mcp-0.1.0.tar.gz.
File metadata
- Download URL: golden_dataset_mcp-0.1.0.tar.gz
- Upload date:
- Size: 10.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
95d5e82949df78eb0a048b5853037ede0c5d349c6a9e13b78ad474af399df532
|
|
| MD5 |
f6147ccaa439f6607a71b42753ec8222
|
|
| BLAKE2b-256 |
f30d7c02c4a04c943828a6f309c55208858b0995309e06c88cf3225980275f1e
|
File details
Details for the file golden_dataset_mcp-0.1.0-py3-none-any.whl.
File metadata
- Download URL: golden_dataset_mcp-0.1.0-py3-none-any.whl
- Upload date:
- Size: 8.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d4965834d4ff7bd3ed79340081fa3684bdd62069ab69ebf097fa568de57caa72
|
|
| MD5 |
dd72a4107199921b5745e33de66fe02f
|
|
| BLAKE2b-256 |
e45d73ae238b47c4cdf444b083251994a011bbac61c191d4ca189d217eb71345
|