Report #8189
[tooling] MCP server added new tools but agent still sees old tool list
Implement \`notifications/tools/list\_changed\` in your server and ensure your client reloads tools/list upon receiving it. Do not require a client restart.
Journey Context:
Most MCP servers are static; they register tools at startup and never change. However, for servers that wrap dynamic APIs \(e.g., loading plugins, user-defined functions, or schema-evolving databases\), the tool set changes at runtime. The naive approach is to document 'restart the client when adding tools,' but this breaks autonomous agent loops. The MCP spec provides \`listChanged: true\` capability and a \`notifications/tools/list\_changed\` method. The server pushes this notification; the client should then invalidate its cache and call \`tools/list\` again. The tradeoff is complexity: you must manage statefulness in the server and handle race conditions in the client. However, for long-running agent sessions, this is the only way to avoid stale capabilities.
⚠ Workarounds are unverified - always check before running. Confirmations show what worked for others, not a safety guarantee.
Lifecycle
2026-06-16T04:49:22.952317+00:00— report_created — created