forked from CopilotKit/CopilotKit
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathtool-rendering-custom-catchall.json
More file actions
212 lines (212 loc) · 9.01 KB
/
Copy pathtool-rendering-custom-catchall.json
File metadata and controls
212 lines (212 loc) · 9.01 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
{
"_meta": {
"description": "D6 fixtures for langgraph-python / tool-rendering-custom-catchall. Pills: 'Weather in SF' (get_weather/San Francisco), 'Find flights' (search_flights/SFO->JFK), 'Roll a d20' (5 sequential roll_d20 calls ending in 20), 'Chain tools' (get_weather Tokyo + search_flights SFO->Tokyo + roll_d20=11). Backend tools execute on LangGraph Python and return real JSON results, which the wildcard renderer surfaces in the result block. Mirrors the matcher/tool-call shape of d6/langgraph-python/tool-rendering.json, with distinct toolCallIds to avoid cross-fixture leakage. PILL PROMPTS (must match suggestions.ts verbatim): \"What's the weather in San Francisco?\", \"Find flights from SFO to JFK.\", \"Roll a 20-sided die.\", \"Chain a few tools in this single turn: get the weather in Tokyo, search flights from SFO to Tokyo, and roll a d20.\"",
"sourceFile": "d5-tool-rendering-custom-catchall.ts",
"created": "2026-05-22",
"updated": "2026-05-29"
},
"fixtures": [
{
"_comment": "Chain tools — follow-up after all 3 tools ran. Anchored on whichever of the 3 chain toolCallIds appears last in the request (LangGraph's ToolNode preserves tool_calls order). MUST come before the toolCalls-emitting fixture below so iteration 2 of the chain-tools loop hits this branch instead of re-emitting.",
"match": {
"userMessage": "Chain a few tools in this single turn",
"toolCallId": "call_trcc_chain_roll_001",
"context": "langgraph-python"
},
"response": {
"content": "Done — Tokyo is sunny, three flights found, and the d20 came up 11."
}
},
{
"match": {
"userMessage": "Chain a few tools in this single turn",
"toolCallId": "call_trcc_chain_flights_001",
"context": "langgraph-python"
},
"response": {
"content": "Done — Tokyo is sunny, three flights found, and the d20 came up 11."
}
},
{
"match": {
"userMessage": "Chain a few tools in this single turn",
"toolCallId": "call_trcc_chain_weather_001",
"context": "langgraph-python"
},
"response": {
"content": "Done — Tokyo is sunny, three flights found, and the d20 came up 11."
}
},
{
"_comment": "Chain tools — emit 3 tool calls in one assistant turn (get_weather Tokyo + search_flights SFO->Tokyo + roll_d20=11). No turnIndex/hasToolResult gate: in multi-pill demo sessions prior clicks leave tool results AND additional user turns in the thread; the toolCallId fixtures above eat iteration 2 via last-message tool_call_id gating.",
"match": {
"userMessage": "Chain a few tools in this single turn",
"context": "langgraph-python"
},
"response": {
"toolCalls": [
{
"id": "call_trcc_chain_weather_001",
"name": "get_weather",
"arguments": "{\"location\":\"Tokyo\"}"
},
{
"id": "call_trcc_chain_flights_001",
"name": "search_flights",
"arguments": "{\"origin\":\"SFO\",\"destination\":\"Tokyo\"}"
},
{
"id": "call_trcc_chain_roll_001",
"name": "roll_d20",
"arguments": "{\"value\":11}"
}
]
}
},
{
"_comment": "Weather in SF — follow-up content after get_weather tool ran. MUST come before the tool-emitting fixture below (first-match-wins) so iteration 2 of the loop hits this branch instead of re-emitting. toolCallId chain keeps the fixture stateless across multi-pill thread history.",
"match": {
"userMessage": "What's the weather in San Francisco?",
"toolCallId": "call_trcc_weather_sf_001",
"context": "langgraph-python"
},
"response": {
"content": "San Francisco is currently 68°F and sunny with light winds — rendered through the custom wildcard catchall."
}
},
{
"_comment": "Weather in SF — first turn: emit get_weather tool call with location=San Francisco. The wildcard renderer paints [data-testid='custom-wildcard-card'][data-tool-name='get_weather'] with args containing 'San Francisco'.",
"match": {
"userMessage": "What's the weather in San Francisco?",
"context": "langgraph-python"
},
"response": {
"toolCalls": [
{
"id": "call_trcc_weather_sf_001",
"name": "get_weather",
"arguments": "{\"location\":\"San Francisco\"}"
}
]
}
},
{
"_comment": "Find flights — follow-up content after search_flights ran. MUST come BEFORE the first-leg fixture below — the matcher is first-match-wins, and the second leg is uniquely identified by `toolCallId` (last message is a tool with this id), so it cannot accidentally swallow the first-leg request (whose last message is the user prompt). The result block of the wildcard card surfaces the tool execution JSON (which already contains 'United', 'Delta', 'JetBlue' from the Python backend); this narration is just to terminate the agent loop.",
"match": {
"userMessage": "Find flights from SFO to JFK.",
"toolCallId": "call_trcc_flights_sfo_jfk_001",
"context": "langgraph-python"
},
"response": {
"content": "Three flights from SFO to JFK — United UA231 at 08:15 ($348), Delta DL412 at 11:20 ($312), and JetBlue B6722 at 17:05 ($289)."
}
},
{
"_comment": "Find flights — first turn: emit search_flights tool call (SFO -> JFK). Backend executes and returns the 3-flight result list; the wildcard renderer surfaces 'United'/'Delta'/'JetBlue' in the result block.",
"match": {
"userMessage": "Find flights from SFO to JFK.",
"context": "langgraph-python"
},
"response": {
"toolCalls": [
{
"id": "call_trcc_flights_sfo_jfk_001",
"name": "search_flights",
"arguments": "{\"origin\":\"SFO\",\"destination\":\"JFK\"}"
}
]
}
},
{
"_comment": "Roll a d20 — exactly 5 sequential roll_d20 calls returning [7, 14, 3, 19, 20]. Chained by toolCallId so the sequence is stateless across thread history. Specific-toolCallId fixtures MUST come before the userMessage-only fixture below; first-match-wins. The 5th roll has value=20 so the result block of the 5th card surfaces \"value\":20.",
"match": {
"userMessage": "Roll a 20-sided die.",
"toolCallId": "call_trcc_d20_seq_001",
"context": "langgraph-python"
},
"response": {
"toolCalls": [
{
"id": "call_trcc_d20_seq_002",
"name": "roll_d20",
"arguments": "{\"value\":14}"
}
]
}
},
{
"match": {
"userMessage": "Roll a 20-sided die.",
"toolCallId": "call_trcc_d20_seq_002",
"context": "langgraph-python"
},
"response": {
"toolCalls": [
{
"id": "call_trcc_d20_seq_003",
"name": "roll_d20",
"arguments": "{\"value\":3}"
}
]
}
},
{
"match": {
"userMessage": "Roll a 20-sided die.",
"toolCallId": "call_trcc_d20_seq_003",
"context": "langgraph-python"
},
"response": {
"toolCalls": [
{
"id": "call_trcc_d20_seq_004",
"name": "roll_d20",
"arguments": "{\"value\":19}"
}
]
}
},
{
"match": {
"userMessage": "Roll a 20-sided die.",
"toolCallId": "call_trcc_d20_seq_004",
"context": "langgraph-python"
},
"response": {
"toolCalls": [
{
"id": "call_trcc_d20_seq_005",
"name": "roll_d20",
"arguments": "{\"value\":20}"
}
]
}
},
{
"match": {
"userMessage": "Roll a 20-sided die.",
"toolCallId": "call_trcc_d20_seq_005",
"context": "langgraph-python"
},
"response": {
"content": "Rolled the d20 five times — landed on 20 on the final roll."
}
},
{
"_comment": "First roll. Matches the initial user prompt (no prior d20 tool result in this chain yet). Comes after the toolCallId-chained fixtures above so iterations 2-6 of the loop hit those first. The multi-pill sequential e2e test clicks 'Find flights' first which leaves prior turns in the thread, so a new 'Roll a 20-sided die.' user message is no longer at turnIndex 0 — keep this fixture turnIndex-less. The toolCallId-chained fixtures still take precedence for iterations 2-6 because their last-message gate (role=tool with the chained id) only matches mid-chain — this fixture only matches when last-message.role=user.",
"match": {
"userMessage": "Roll a 20-sided die.",
"context": "langgraph-python"
},
"response": {
"toolCalls": [
{
"id": "call_trcc_d20_seq_001",
"name": "roll_d20",
"arguments": "{\"value\":7}"
}
]
}
}
]
}