- Demo is deployed and accessible
- Agent backend is healthy (check /api/health)
- Agent slug
tool-rendering-default-catchallis registered at/api/copilotkit
- Navigate to the
tool-rendering-default-catchalldemo page - Verify the chat interface loads in a centered full-height layout (max-width 4xl,
rounded-2xl) - Verify the chat input placeholder "Type a message" is visible
- Send a basic message (e.g. "Hi")
- Verify the agent responds with a text message
The frontend calls useDefaultRenderTool() with NO config — it registers CopilotKit's package-provided DefaultToolCallRenderer as the * wildcard. The frontend adds ZERO custom per-tool or custom wildcard renderers. Every tool call must paint via this one built-in card.
- Verify "Weather in SF" suggestion pill is visible
- Verify "Find flights" suggestion pill is visible
- Verify "Roll a d20" suggestion pill is visible
- Click a suggestion and verify it either populates the input or sends the message
- Click the "Weather in SF" suggestion (or type "What's the weather in San Francisco?")
- Verify a default tool-call card appears with the tool name
get_weathervisible - Verify a status pill transitions through
Runningand lands onDone - Expand the card's "Arguments" section and verify it shows
{ "location": "San Francisco" }(or similar) - Expand the card's "Result" section and verify it shows the mock payload with
city,temperature: 68,humidity: 55,wind_speed: 10,conditions: "Sunny" - Verify NO custom-branded card appears (no
data-testid="custom-catchall-card", nodata-testid="weather-card")
- Click the "Find flights" suggestion (or type "Find flights from SFO to JFK")
- Verify a tool-call card appears with tool name
search_flights - Verify the card has the identical visual style/structure as the
get_weathercard — same header layout, same status pill, same Arguments/Result sections - Verify the Result section contains three mock flights (United UA231, Delta DL412, JetBlue B6722)
- Click the "Roll a d20" suggestion (or type "Roll a 20-sided die")
- Verify a tool-call card for
roll_diceappears with the same default visual style - Verify the Result section shows
{ "sides": 20, "result": <1-20> }
- Type "How is AAPL doing?"
- Verify a
get_stock_pricetool-call card appears with the default built-in style - Verify the Result shows
ticker: "AAPL", aprice_usd, and achange_pct
- Ask "What's the weather in Tokyo?" — the system prompt instructs the agent to chain tools
- Verify at least TWO default tool-call cards render in succession (e.g.
get_weatherthensearch_flights) - Verify every card uses the identical default built-in UI — visually indistinguishable apart from the tool name and payload
- Send an empty message (should be handled gracefully)
- Verify no console errors during normal usage
- Verify no unhandled-promise warnings when a tool call streams
- Chat loads within 3 seconds
- Every tool invocation paints via the built-in
DefaultToolCallRenderercard (tool name + live status pill + Arguments + Result) - All four distinct tools (
get_weather,search_flights,get_stock_price,roll_dice) render via the SAME default card — zero visual variance beyond payload - No custom-branded renderer appears anywhere
- No UI errors or broken layouts