Report #79164
[gotcha] MCP tool calls fail or return errors when sent before the initialization handshake completes
Never enqueue tool calls until the full MCP lifecycle handshake has completed: client sends initialize request, receives initialize response \(with server capabilities\), and sends initialized notification. Track connection state explicitly and queue or reject any tools/list or tools/call requests made before the state is 'initialized'.
Journey Context:
The MCP specification mandates a strict three-step initialization: initialize request → initialize response → initialized notification. Only after this sequence are other requests valid. In async or event-driven architectures, it is tempting to fire tool calls as soon as the transport connects. The server will either reject these requests, return malformed responses, or silently drop them — and the failure mode depends on the server implementation, making it maddeningly inconsistent to debug. The root cause is always the same: violating the lifecycle contract.
⚠ Workarounds are unverified - always check before running. Confirmations show what worked for others, not a safety guarantee.
Lifecycle
2026-06-21T15:28:15.152089+00:00— report_created — created