Testing Platform — MCP server
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@Testing Platform — MCP serverShow me open high-priority issues in Panda Eats."
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
Testing Platform — MCP server
A small Model Context Protocol server that gives Claude Code read+write access to the Testing Platform's issues. Lets you say things like:
"Go to the Panda Eats project and check the critical new issues."
"Show me everything in In Review reported by tanya."
"Create a high-priority bug in Panda Eats titled 'Login throws 500'."
"Move issue 35 back to In Progress and post a comment that it's being reworked."
Runs on your machine, talks to the production HTTP API
(https://testing.r-ruiz.com/api) using a long-lived API token tied to your
developer account.
Setup
Mint an access token in the app. Sign in as a developer → click the key icon in the header (next to the bell) → Generate token. The token is shown exactly once — copy it before closing the modal.
Build the package.
cd mcp npm install npm run buildRegister with Claude Code (user scope — available in every session on this machine).
claude mcp add \ -e TP_API_BASE=https://testing.r-ruiz.com/api \ -e TP_API_TOKEN=<paste-token> \ -s user testing-platform \ -- node "<absolute path to mcp/dist/index.js>"The
-sflag must come after the-eenv vars so the variadic env parser terminates cleanly.--separates the server name from the launch command.Verify:
claude mcp list # should show ✓ Connected next to testing-platform claude mcp get testing-platform # shows full config + scopeThen in any Claude Code session: "list my testing-platform projects" — the server resolves and returns them.
Alternative: project scope. If you'd rather pin the server to this repo only (e.g. to share with a teammate who clones it), commit a
.mcp.jsonat the repo root pointing at./mcp/dist/index.js. Don't do both — Claude Code warns about scope conflicts and picks the project one..env(optional fallback). If you also run the server outside Claude Code (e.g.node dist/index.jsdirectly), copy.env.exampleto.envand paste the token there. Not needed when-eis set in the registration.
Related MCP server: GitLab MCP
Tools
All tools take the configured developer token's privileges — i.e., the same access you have as the user that minted the token in the app.
Tool | What it does |
| Every project the token's user can see. |
| Resolve a name (e.g. "panda eats") to its project. Returns an error listing candidates when ambiguous. |
| Filter the active board or the archive. |
| Full detail including attachments + comment count. |
| Comments on an issue, oldest first. |
| New issue, lands in the New column. |
| Post a comment. Visible immediately to anyone on the board. |
| Patch fields. Note: |
No delete_issue — that lives in the app's UI, on purpose.
Giving an outside developer access to ONE board
You don't have to hand someone a developer-level token (which reaches every board you can see) to let them work a single project. Mint a board-developer token scoped to just that board and give them only that — they never get the keys, the whitelist, or any other board.
In the app, open the project's Tokens button (developer-only).
Pick Access → Full board access, give it a label that names the source (e.g.
Acme Dev (Cursor)), and Generate. Copy thetp_…value — shown once.Hand that token to the developer. They register it in their own Claude Code / VS Code session exactly like the setup above, but with your value:
claude mcp add -e TP_API_BASE=https://testing.r-ruiz.com/api \ -e TP_API_TOKEN=tp_… -s user testing-platform \ -- node "<path to mcp/dist/index.js>"
What that token can do, on that one board only: list/read issues, create issues, comment, and move/update cards (including the same in-review close bypass the MCP service account has). What it can't: see or touch any other board, the whitelist, project settings, members, secrets, or mint more tokens — all of that stays developer-only.
Provenance. Everything the token does shows up on the board under its label as a distinct, non-human source (it files and acts as a service identity named after the label), so it's always clear an action came from that outside session and not from you. Revoke any time from the same Tokens modal — the credential and its board access die immediately.
Notes
Rotation. Lost or leaked? Open the same modal in the app and regenerate; the previous token stops working immediately. Update
mcp/.envwith the new one and restart Claude Code.Revoke. The same modal has a Revoke button that clears the token entirely. Any MCP request afterwards returns 401.
Token scope. A user token (minted from the header key icon) grants the same access as that user in-app — for a developer, every visible project. To confine a session to a single board, use a board-developer token instead (see "Giving an outside developer access to ONE board" above). Neither is yet scoped to individual operations within a board.
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/naft3r-101/testing-platform-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server