Prompt Lab MCP Server

Prompt Lab MCP Server

Enables prompt optimization loops and regression test suites for Claude Code, with a companion web UI for real-time visualization of scores and prompt revisions.

Category
Visit Server

README

Prompt Lab MCP Server

Prompt optimization loops and regression test suites for Claude Code, with a companion web UI.

The agent runs inside your Claude Code session and owns all LLM work — scoring responses, proposing improved prompts, applying suggestions. The server holds workspace state and keeps the agent and the Prompt Lab UI in sync.


Quick start

Copy mcp-connect.json from this repo into your project as .mcp.json:

{
  "mcpServers": {
    "prompt-lab": {
      "type": "http",
      "url": "https://prompt-lab-mcp.up.railway.app/mcp"
    }
  }
}

Claude Code connects automatically on next start. Verify with /mcp.


Example session

# 1. Open a workspace — agent shares the UI URL
start_web_app()
→ "Open https://prompt-lab-mcp.vercel.app?s=abc123 to follow along."

# 2. Register an API key
register_api_key(workspaceId, "sk-ant-...")

# 3. Set a system prompt and a test case
set_system_prompt(workspaceId, "You are a concise customer support agent...")
add_test_cases(workspaceId, [{
  query: "How do I reset my password?",
  targetAnswer: "Click 'Forgot password' on the login page and follow the email link."
}])

# 4. Run the optimization loop
loop_optimization(workspaceId, threshold=85)
→ Iteration 1 — score 58: response too long, no mention of email link
→ Iteration 2 — score 74: better, but missing the exact step
→ Iteration 3 — score 91: SUCCESS — prompt updated to require step-by-step answers

The UI shows each iteration's score, the agent's reasoning, and the revised system prompt in real time.


How it works

Prompt Lab UI (Vercel)
  ↕  HTTP
Prompt Lab MCP Server (Railway)
  ↕  MCP
Claude Code (your machine)

MCP tools

Setup

Tool Description
start_web_app(workspaceId?) Creates a workspace and returns the Prompt Lab UI URL.
register_api_key(workspaceId, apiKey, provider?) Registers an API key for test runs. Provider is auto-detected from the key prefix.
list_models(workspaceId) Lists available models based on registered keys.
set_test_model(workspaceId, model) Sets the model for test runs. Syncs to the UI model selector.
delete_session(workspaceId) Deletes a workspace and all its state. Irreversible.

Templates

Templates are global and appear in the UI dropdowns as soon as they are pushed.

Tool Description
save_template(name, testCases) Saves a test suite template. Appears in the UI "Load test suite…" dropdown.
save_system_prompt_template(name, content) Saves a system prompt template. Appears in the UI "Load template…" dropdown.

Workspace state

Tool Description
get_workspace_state(workspaceId) Reads the full workspace: system prompt, test cases, results, suggestions, model.
set_system_prompt(workspaceId, systemPrompt) Sets the system prompt without incrementing the iteration counter.
add_test_cases(workspaceId, testCases, replace?) Adds test cases. replace=true overwrites all existing ones.
post_test_result(workspaceId, testCaseId, response, score, reasoning, model) Stores one scored test result.
post_prompt_suggestion(workspaceId, prompt, reasoning, expectedGain?) Queues a revised prompt for review in the UI.
apply_suggestion(workspaceId, suggestionId) Applies a pending suggestion and increments the iteration counter.
get_regression_status(workspaceId, threshold?) Pass/fail summary across all test cases for the current system prompt.

Optimization

Requires a workspace with at least one test case.

Tool Description
start_optimization_session(workspaceId, threshold?, maxIterations?) Single pass — scores test cases, posts one suggestion, then waits for user review in the UI.
loop_optimization(workspaceId, threshold?, maxIterations?) Automated loop — iterates until all scores meet the threshold or max iterations is reached.

Regression

Tool Description
run_regression_testsuite(workspaceId, threshold?) Single pass — scores all test cases, no prompt changes.
loop_regression(workspaceId, threshold?) Automated loop — repeats until every individual score meets the threshold. A high average that masks one failing case is not a pass.

Archive

Tool Description
pull_ui_history(workspaceId) Fetches all session summaries and regression runs pushed by the UI.

Self-hosting

Deploy to Railway and set these environment variables:

Variable Description
UPSTASH_REDIS_REST_URL Upstash Redis URL for persistence
UPSTASH_REDIS_REST_TOKEN Upstash Redis token
OVERHANG_PROMPT_LAB_URL URL of your Prompt Lab UI deployment
npm install
npm run dev    # starts on :3000

MCP endpoint: http://localhost:3000/mcp


License

MIT — see LICENSE.

© 2026 Jurek Föllmer

Recommended Servers

playwright-mcp

playwright-mcp

A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.

Official
Featured
TypeScript
Magic Component Platform (MCP)

Magic Component Platform (MCP)

An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

Audiense Insights MCP Server

Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

graphlit-mcp-server

The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.

Official
Featured
TypeScript
Kagi MCP Server

Kagi MCP Server

An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

Exa Search

A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured