- Demo is deployed and accessible at
/demos/a2ui-fixed-schemaon the dashboard host - Agent backend is healthy;
OPENAI_API_KEYis set on Railway;LANGGRAPH_DEPLOYMENT_URLpoints at a LangGraph deployment exposing thea2ui_fixedgraph (registered as agent namea2ui-fixed-schema— seesrc/app/api/copilotkit-a2ui-fixed-schema/route.ts) - Note: the demo source contains no
data-testidattributes. Checks below rely on verbatim visible text, DOM structure, and the JSON schema atsrc/agents/a2ui_schemas/flight_schema.json
- Navigate to
/demos/a2ui-fixed-schema; verify the page renders within 3s and a singleCopilotChatpane is centered (max-width ~896px, rounded-2xl, full-height) - Verify the chat is wired to
runtimeUrl="/api/copilotkit-a2ui-fixed-schema"andagent="a2ui-fixed-schema"(DevTools → Network: sending a message hits that endpoint) - Verify the single suggestion pill is visible with verbatim title "Find SFO → JFK" (message body: "Find me a flight from SFO to JFK on United for $289.")
- Send "Hello" and verify an assistant text response appears within 10s (no flight card for plain text)
- DevTools → Network: after the first successful
display_flightcall, verify the response stream contains ana2ui_operationscontainer withcatalogId: "copilotkit://flight-fixed-catalog"(matchesCATALOG_IDinsrc/agents/a2ui_fixed.pyandsrc/app/demos/a2ui-fixed-schema/a2ui/catalog.ts) - Verify the same container carries the full
FLIGHT_SCHEMAcomponent tree (12 nodes fromsrc/agents/a2ui_schemas/flight_schema.json:root,content,title,route,from,arrow,to,meta,airline,price,bookButton,bookButtonLabel)
- Click the "Find SFO → JFK" suggestion; within 20s verify a single flight card renders in-transcript assembled per
flight_schema.json:- outer
Cardwith aColumnof children in this order: title row, route row, meta row, book button Titlenode renders the literal text "Flight Details" (1.15rem / 600 weight, color#010507)routerow showsAirport"SFO" →Arrow(→, color#AFAFB7) →Airport"JFK" (both monospaced, 1.5rem, 600 weight, 0.05em letter-spacing)metarow showsAirlineBadge"UNITED" (uppercase pill, lilac#BEC2FFborder, 0.08em tracking) on the left andPriceTag"$289" (monospaced, color#189370, 1.1rem / 600 weight) on the rightButtonrenders full-width with label "Book flight" (black#010507background, white text, 12px radius)
- outer
- Verify all four data-model fields resolved correctly (origin=
SFO, destination=JFK, airline=United, price=$289) — each is a{ path: "/..." }binding in the schema and must reach the DOM as a plain string via theGenericBinder(no literal{path}leak and no React error #31)
- Verify the "Book flight" button is rendered with the schema-declared label and is clickable, but the click is a no-op: the agent is not invoked, no schema swap occurs, and the button does not transition to a "Booked" state. Schema-swap-on-action will be wired up once the Python SDK exposes
action_handlers=ona2ui.render(see comment insrc/agents/a2ui_fixed.py).
- Send "Find me a flight from LAX to ORD on Delta for $412."; within 20s verify the card updates in place with origin=
LAX, destination=ORD, airline=DELTA, price=$412(same schema, new data model — proves the fixed-schema pattern: schema once, data streams)
- Send an empty message; verify it is a no-op (no user bubble, no assistant response)
- Send "What is the capital of France?"; verify the agent replies in plain text without invoking
display_flight(no flight card rendered, noa2ui_operationsin the response) - DevTools → Console: walk through all flows above; verify no uncaught errors and specifically no React error #31 ("objects are not valid as a React child, found: object with keys {path}") — the
DynStringunion ina2ui/definitions.tsis what prevents this, so a single occurrence is a regression
- Chat loads within 3s; plain-text response within 10s; flight card renders within 20s of the search prompt
display_flightis called exactly once per search prompt; result contains ana2ui_operationscontainer withcatalogId: "copilotkit://flight-fixed-catalog"and the full 12-node flight schema- All custom renderers in
a2ui/renderers.tsx(Card,Title,Airport,Arrow,AirlineBadge,PriceTag,Button) render at least once per search-flights run - Clicking "Book flight" is a no-op (inert presentation button — see comment in
src/agents/a2ui_fixed.py) - No UI layout breaks, no
{path}leak into the DOM, no uncaught console errors