@copilotkit/runtime 1.57.3 → 1.58.0-canary.thread-id-propagation

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (346) hide show
  1. package/dist/lib/observability.d.cts +1 -1
  2. package/dist/lib/observability.d.cts.map +1 -1
  3. package/dist/lib/observability.d.mts +1 -1
  4. package/dist/lib/observability.d.mts.map +1 -1
  5. package/dist/lib/runtime/copilot-runtime.cjs +2 -0
  6. package/dist/lib/runtime/copilot-runtime.cjs.map +1 -1
  7. package/dist/lib/runtime/copilot-runtime.d.cts.map +1 -1
  8. package/dist/lib/runtime/copilot-runtime.d.mts.map +1 -1
  9. package/dist/lib/runtime/copilot-runtime.mjs +2 -0
  10. package/dist/lib/runtime/copilot-runtime.mjs.map +1 -1
  11. package/dist/package.cjs +5 -8
  12. package/dist/package.mjs +5 -8
  13. package/dist/v2/runtime/core/runtime.cjs +4 -1
  14. package/dist/v2/runtime/core/runtime.cjs.map +1 -1
  15. package/dist/v2/runtime/core/runtime.d.cts.map +1 -1
  16. package/dist/v2/runtime/core/runtime.d.mts.map +1 -1
  17. package/dist/v2/runtime/core/runtime.mjs +4 -1
  18. package/dist/v2/runtime/core/runtime.mjs.map +1 -1
  19. package/dist/v2/runtime/handlers/get-runtime-info.cjs +1 -1
  20. package/dist/v2/runtime/handlers/get-runtime-info.mjs +1 -1
  21. package/dist/v2/runtime/handlers/handle-connect.cjs +1 -1
  22. package/dist/v2/runtime/handlers/handle-connect.mjs +1 -1
  23. package/dist/v2/runtime/handlers/handle-run.cjs +1 -1
  24. package/dist/v2/runtime/handlers/handle-run.mjs +1 -1
  25. package/dist/v2/runtime/handlers/shared/agent-utils.cjs +1 -1
  26. package/dist/v2/runtime/handlers/shared/agent-utils.cjs.map +1 -1
  27. package/dist/v2/runtime/handlers/shared/agent-utils.mjs +1 -1
  28. package/dist/v2/runtime/handlers/shared/agent-utils.mjs.map +1 -1
  29. package/dist/v2/runtime/telemetry/telemetry-client.cjs +22 -6
  30. package/dist/v2/runtime/telemetry/telemetry-client.cjs.map +1 -1
  31. package/dist/v2/runtime/telemetry/telemetry-client.mjs +27 -11
  32. package/dist/v2/runtime/telemetry/telemetry-client.mjs.map +1 -1
  33. package/package.json +9 -19
  34. package/skills/runtime/SKILL.md +98 -0
  35. package/skills/runtime/references/agent-runners-custom.md +161 -0
  36. package/skills/runtime/references/agent-runners-in-memory.md +64 -0
  37. package/skills/runtime/references/agent-runners-sqlite.md +90 -0
  38. package/skills/runtime/references/agent-runners.md +304 -0
  39. package/skills/runtime/references/built-in-agent-factory-modes.md +232 -0
  40. package/skills/runtime/references/built-in-agent-helper-utilities.md +123 -0
  41. package/skills/runtime/references/built-in-agent-model-identifiers.md +59 -0
  42. package/skills/runtime/references/built-in-agent.md +523 -0
  43. package/skills/runtime/references/intelligence-mode.md +336 -0
  44. package/skills/runtime/references/middleware.md +376 -0
  45. package/skills/runtime/references/server-side-tools.md +414 -0
  46. package/skills/runtime/references/setup-endpoint.md +503 -0
  47. package/skills/runtime/references/transcription.md +287 -0
  48. package/skills/runtime/references/wiring-a2a.md +40 -0
  49. package/skills/runtime/references/wiring-adk.md +45 -0
  50. package/skills/runtime/references/wiring-ag2.md +41 -0
  51. package/skills/runtime/references/wiring-agno.md +39 -0
  52. package/skills/runtime/references/wiring-aws-strands.md +59 -0
  53. package/skills/runtime/references/wiring-crewai-crews.md +51 -0
  54. package/skills/runtime/references/wiring-crewai-flows.md +45 -0
  55. package/skills/runtime/references/wiring-external-agents.md +348 -0
  56. package/skills/runtime/references/wiring-langgraph.md +50 -0
  57. package/skills/runtime/references/wiring-llamaindex.md +39 -0
  58. package/skills/runtime/references/wiring-mastra.md +70 -0
  59. package/skills/runtime/references/wiring-mcp-apps-middleware.md +68 -0
  60. package/skills/runtime/references/wiring-ms-agent-framework.md +41 -0
  61. package/skills/runtime/references/wiring-pydantic-ai.md +45 -0
  62. package/CHANGELOG.md +0 -3624
  63. package/__snapshots__/schema/schema.graphql +0 -371
  64. package/dist/v2/runtime/telemetry/scarf-client.cjs +0 -32
  65. package/dist/v2/runtime/telemetry/scarf-client.cjs.map +0 -1
  66. package/dist/v2/runtime/telemetry/scarf-client.mjs +0 -32
  67. package/dist/v2/runtime/telemetry/scarf-client.mjs.map +0 -1
  68. package/scripts/generate-gql-schema.ts +0 -16
  69. package/src/agent/__tests__/agent-test-helpers.ts +0 -476
  70. package/src/agent/__tests__/agent.test.ts +0 -593
  71. package/src/agent/__tests__/ai-sdk-v6-compat.test.ts +0 -116
  72. package/src/agent/__tests__/basic-agent.test.ts +0 -1698
  73. package/src/agent/__tests__/capabilities.test.ts +0 -81
  74. package/src/agent/__tests__/config-tools-execution.test.ts +0 -516
  75. package/src/agent/__tests__/converter-aisdk.test.ts +0 -692
  76. package/src/agent/__tests__/converter-custom.test.ts +0 -319
  77. package/src/agent/__tests__/converter-tanstack-input.test.ts +0 -211
  78. package/src/agent/__tests__/converter-tanstack.test.ts +0 -594
  79. package/src/agent/__tests__/mcp-clients.test.ts +0 -246
  80. package/src/agent/__tests__/mcp-servers-integration.test.ts +0 -373
  81. package/src/agent/__tests__/multimodal-tanstack.test.ts +0 -284
  82. package/src/agent/__tests__/multimodal.test.ts +0 -176
  83. package/src/agent/__tests__/property-overrides.test.ts +0 -598
  84. package/src/agent/__tests__/provider-id-collision.test.ts +0 -195
  85. package/src/agent/__tests__/standard-schema-tools.test.ts +0 -313
  86. package/src/agent/__tests__/standard-schema-types.test.ts +0 -158
  87. package/src/agent/__tests__/state-tools.test.ts +0 -436
  88. package/src/agent/__tests__/test-helpers.ts +0 -197
  89. package/src/agent/__tests__/utils.test.ts +0 -536
  90. package/src/agent/__tests__/zod-regression.test.ts +0 -350
  91. package/src/agent/converters/aisdk.ts +0 -326
  92. package/src/agent/converters/index.ts +0 -7
  93. package/src/agent/converters/tanstack.ts +0 -451
  94. package/src/agent/index.ts +0 -1743
  95. package/src/agents/langgraph/__tests__/event-source.test.ts +0 -256
  96. package/src/agents/langgraph/event-source.ts +0 -365
  97. package/src/agents/langgraph/events.ts +0 -394
  98. package/src/graphql/inputs/action.input.ts +0 -16
  99. package/src/graphql/inputs/agent-session.input.ts +0 -13
  100. package/src/graphql/inputs/agent-state.input.ts +0 -13
  101. package/src/graphql/inputs/cloud-guardrails.input.ts +0 -16
  102. package/src/graphql/inputs/cloud.input.ts +0 -8
  103. package/src/graphql/inputs/context-property.input.ts +0 -10
  104. package/src/graphql/inputs/copilot-context.input.ts +0 -10
  105. package/src/graphql/inputs/custom-property.input.ts +0 -15
  106. package/src/graphql/inputs/extensions.input.ts +0 -21
  107. package/src/graphql/inputs/forwarded-parameters.input.ts +0 -22
  108. package/src/graphql/inputs/frontend.input.ts +0 -14
  109. package/src/graphql/inputs/generate-copilot-response.input.ts +0 -59
  110. package/src/graphql/inputs/load-agent-state.input.ts +0 -10
  111. package/src/graphql/inputs/message.input.ts +0 -110
  112. package/src/graphql/inputs/meta-event.input.ts +0 -18
  113. package/src/graphql/message-conversion/agui-to-gql.test.ts +0 -1384
  114. package/src/graphql/message-conversion/agui-to-gql.ts +0 -384
  115. package/src/graphql/message-conversion/gql-to-agui.test.ts +0 -1653
  116. package/src/graphql/message-conversion/gql-to-agui.ts +0 -297
  117. package/src/graphql/message-conversion/index.ts +0 -2
  118. package/src/graphql/message-conversion/roundtrip-conversion.test.ts +0 -561
  119. package/src/graphql/resolvers/__tests__/resolve-message-id.test.ts +0 -25
  120. package/src/graphql/resolvers/copilot.resolver.ts +0 -785
  121. package/src/graphql/resolvers/resolve-message-id.ts +0 -14
  122. package/src/graphql/resolvers/state.resolver.ts +0 -30
  123. package/src/graphql/types/agents-response.type.ts +0 -19
  124. package/src/graphql/types/base/index.ts +0 -10
  125. package/src/graphql/types/converted/index.ts +0 -183
  126. package/src/graphql/types/copilot-response.type.ts +0 -141
  127. package/src/graphql/types/enums.ts +0 -38
  128. package/src/graphql/types/extensions-response.type.ts +0 -23
  129. package/src/graphql/types/guardrails-result.type.ts +0 -20
  130. package/src/graphql/types/load-agent-state-response.type.ts +0 -17
  131. package/src/graphql/types/message-status.type.ts +0 -48
  132. package/src/graphql/types/meta-events.type.ts +0 -78
  133. package/src/graphql/types/response-status.type.ts +0 -77
  134. package/src/index.ts +0 -3
  135. package/src/langgraph.ts +0 -1
  136. package/src/lib/__tests__/telemetry-disclosure.test.ts +0 -55
  137. package/src/lib/cloud/index.ts +0 -4
  138. package/src/lib/error-messages.ts +0 -211
  139. package/src/lib/index.ts +0 -52
  140. package/src/lib/integrations/index.ts +0 -6
  141. package/src/lib/integrations/nest/index.ts +0 -21
  142. package/src/lib/integrations/nextjs/app-router.ts +0 -47
  143. package/src/lib/integrations/nextjs/pages-router.ts +0 -45
  144. package/src/lib/integrations/node-express/index.ts +0 -21
  145. package/src/lib/integrations/node-http/__tests__/request-duck-type.test.ts +0 -66
  146. package/src/lib/integrations/node-http/index.ts +0 -187
  147. package/src/lib/integrations/node-http/request-handler.ts +0 -128
  148. package/src/lib/integrations/shared.ts +0 -112
  149. package/src/lib/logger.ts +0 -31
  150. package/src/lib/observability.ts +0 -167
  151. package/src/lib/runtime/__tests__/copilot-runtime-error.test.ts +0 -183
  152. package/src/lib/runtime/__tests__/handle-service-adapter.test.ts +0 -108
  153. package/src/lib/runtime/__tests__/mcp-tools-utils.test.ts +0 -499
  154. package/src/lib/runtime/__tests__/on-after-request.test.ts +0 -122
  155. package/src/lib/runtime/__tests__/retry-utils.test.ts +0 -137
  156. package/src/lib/runtime/__tests__/v1-agent-factory.test.ts +0 -109
  157. package/src/lib/runtime/agent-integrations/langgraph/__tests__/dispatch-event-filtering.test.ts +0 -345
  158. package/src/lib/runtime/agent-integrations/langgraph/__tests__/run-message-filtering.test.ts +0 -156
  159. package/src/lib/runtime/agent-integrations/langgraph/agent.ts +0 -263
  160. package/src/lib/runtime/agent-integrations/langgraph/consts.ts +0 -37
  161. package/src/lib/runtime/agent-integrations/langgraph/index.ts +0 -2
  162. package/src/lib/runtime/copilot-runtime.ts +0 -863
  163. package/src/lib/runtime/mcp-tools-utils.ts +0 -313
  164. package/src/lib/runtime/retry-utils.ts +0 -141
  165. package/src/lib/runtime/telemetry-agent-runner.ts +0 -151
  166. package/src/lib/runtime/types.ts +0 -48
  167. package/src/lib/runtime/utils.ts +0 -93
  168. package/src/lib/streaming.ts +0 -220
  169. package/src/lib/telemetry-client.ts +0 -66
  170. package/src/lib/telemetry-disclosure.ts +0 -53
  171. package/src/service-adapters/anthropic/anthropic-adapter.ts +0 -532
  172. package/src/service-adapters/anthropic/utils.ts +0 -219
  173. package/src/service-adapters/bedrock/bedrock-adapter.ts +0 -73
  174. package/src/service-adapters/conversion.test.ts +0 -56
  175. package/src/service-adapters/conversion.ts +0 -69
  176. package/src/service-adapters/empty/empty-adapter.ts +0 -38
  177. package/src/service-adapters/events.ts +0 -337
  178. package/src/service-adapters/experimental/ollama/ollama-adapter.ts +0 -84
  179. package/src/service-adapters/google/google-genai-adapter.test.ts +0 -151
  180. package/src/service-adapters/google/google-genai-adapter.ts +0 -95
  181. package/src/service-adapters/groq/groq-adapter.ts +0 -229
  182. package/src/service-adapters/index.ts +0 -18
  183. package/src/service-adapters/langchain/langchain-adapter.ts +0 -113
  184. package/src/service-adapters/langchain/langserve.ts +0 -88
  185. package/src/service-adapters/langchain/types.ts +0 -20
  186. package/src/service-adapters/langchain/utils.ts +0 -330
  187. package/src/service-adapters/openai/__tests__/openai-v5-compat.test.ts +0 -177
  188. package/src/service-adapters/openai/openai-adapter.ts +0 -324
  189. package/src/service-adapters/openai/openai-assistant-adapter.ts +0 -385
  190. package/src/service-adapters/openai/utils.ts +0 -305
  191. package/src/service-adapters/service-adapter.ts +0 -50
  192. package/src/service-adapters/shared/error-utils.ts +0 -64
  193. package/src/service-adapters/shared/index.ts +0 -2
  194. package/src/service-adapters/shared/sdk-client-utils.ts +0 -19
  195. package/src/service-adapters/unify/unify-adapter.ts +0 -165
  196. package/src/utils/failed-response-status-reasons.ts +0 -70
  197. package/src/utils/index.ts +0 -1
  198. package/src/v2/express.ts +0 -1
  199. package/src/v2/hono.ts +0 -1
  200. package/src/v2/index.ts +0 -5
  201. package/src/v2/node.ts +0 -1
  202. package/src/v2/runtime/__tests__/agents-factory.test.ts +0 -136
  203. package/src/v2/runtime/__tests__/backward-compat.test.ts +0 -261
  204. package/src/v2/runtime/__tests__/code-review-fixes.test.ts +0 -500
  205. package/src/v2/runtime/__tests__/cors-credentials.test.ts +0 -320
  206. package/src/v2/runtime/__tests__/debug-sse-response.test.ts +0 -302
  207. package/src/v2/runtime/__tests__/express-adapter.test.ts +0 -188
  208. package/src/v2/runtime/__tests__/express-body-order.test.ts +0 -76
  209. package/src/v2/runtime/__tests__/express-fetch-bridge.test.ts +0 -344
  210. package/src/v2/runtime/__tests__/express-single-sse.test.ts +0 -122
  211. package/src/v2/runtime/__tests__/express-single-telemetry.integration.test.ts +0 -65
  212. package/src/v2/runtime/__tests__/express-telemetry.integration.test.ts +0 -101
  213. package/src/v2/runtime/__tests__/fetch-cors.test.ts +0 -205
  214. package/src/v2/runtime/__tests__/fetch-handler-validation.test.ts +0 -440
  215. package/src/v2/runtime/__tests__/fetch-handler.test.ts +0 -456
  216. package/src/v2/runtime/__tests__/fetch-router.test.ts +0 -276
  217. package/src/v2/runtime/__tests__/get-runtime-info.test.ts +0 -335
  218. package/src/v2/runtime/__tests__/handle-connect.test.ts +0 -585
  219. package/src/v2/runtime/__tests__/handle-run.test.ts +0 -1388
  220. package/src/v2/runtime/__tests__/handle-threads.test.ts +0 -930
  221. package/src/v2/runtime/__tests__/handle-transcribe.test.ts +0 -301
  222. package/src/v2/runtime/__tests__/header-utils.test.ts +0 -88
  223. package/src/v2/runtime/__tests__/hono-adapter.test.ts +0 -150
  224. package/src/v2/runtime/__tests__/hono-single-telemetry.integration.test.ts +0 -46
  225. package/src/v2/runtime/__tests__/hono-telemetry.integration.test.ts +0 -99
  226. package/src/v2/runtime/__tests__/hooks-edge-cases.test.ts +0 -457
  227. package/src/v2/runtime/__tests__/hooks.test.ts +0 -557
  228. package/src/v2/runtime/__tests__/in-process-agent-runner-messages.test.ts +0 -230
  229. package/src/v2/runtime/__tests__/in-process-agent-runner.test.ts +0 -1030
  230. package/src/v2/runtime/__tests__/integration/bun/bun-servers.integration.test.ts +0 -27
  231. package/src/v2/runtime/__tests__/integration/bun/elysia-multi.ts +0 -32
  232. package/src/v2/runtime/__tests__/integration/bun/elysia-single.ts +0 -33
  233. package/src/v2/runtime/__tests__/integration/bun/hono-bun-multi.ts +0 -25
  234. package/src/v2/runtime/__tests__/integration/bun/hono-bun-single.ts +0 -32
  235. package/src/v2/runtime/__tests__/integration/helpers/create-test-runtime.ts +0 -15
  236. package/src/v2/runtime/__tests__/integration/helpers/sse-reader.ts +0 -45
  237. package/src/v2/runtime/__tests__/integration/helpers/test-agent.ts +0 -58
  238. package/src/v2/runtime/__tests__/integration/node-servers.integration.test.ts +0 -58
  239. package/src/v2/runtime/__tests__/integration/servers/express-multi.ts +0 -35
  240. package/src/v2/runtime/__tests__/integration/servers/express-single.ts +0 -36
  241. package/src/v2/runtime/__tests__/integration/servers/fetch-direct.ts +0 -39
  242. package/src/v2/runtime/__tests__/integration/servers/hono-multi.ts +0 -30
  243. package/src/v2/runtime/__tests__/integration/servers/hono-single.ts +0 -37
  244. package/src/v2/runtime/__tests__/integration/servers/node-multi.ts +0 -45
  245. package/src/v2/runtime/__tests__/integration/servers/node-single.ts +0 -46
  246. package/src/v2/runtime/__tests__/integration/servers/types.ts +0 -18
  247. package/src/v2/runtime/__tests__/integration/suites/debug-events.suite.ts +0 -253
  248. package/src/v2/runtime/__tests__/integration/suites/multi-endpoint.suite.ts +0 -358
  249. package/src/v2/runtime/__tests__/integration/suites/single-endpoint.suite.ts +0 -363
  250. package/src/v2/runtime/__tests__/intelligence-run-telemetry.test.ts +0 -194
  251. package/src/v2/runtime/__tests__/mcp-apps-middleware-integration.test.ts +0 -275
  252. package/src/v2/runtime/__tests__/middleware-express.test.ts +0 -208
  253. package/src/v2/runtime/__tests__/middleware-single-express.test.ts +0 -213
  254. package/src/v2/runtime/__tests__/middleware-single.test.ts +0 -225
  255. package/src/v2/runtime/__tests__/middleware-sse-parser.test.ts +0 -237
  256. package/src/v2/runtime/__tests__/middleware.test.ts +0 -250
  257. package/src/v2/runtime/__tests__/node-fetch-handler.test.ts +0 -157
  258. package/src/v2/runtime/__tests__/open-generative-ui-middleware.e2e.test.ts +0 -728
  259. package/src/v2/runtime/__tests__/router-edge-cases.test.ts +0 -217
  260. package/src/v2/runtime/__tests__/routing-express.test.ts +0 -174
  261. package/src/v2/runtime/__tests__/routing-single-express.test.ts +0 -168
  262. package/src/v2/runtime/__tests__/routing-single.test.ts +0 -193
  263. package/src/v2/runtime/__tests__/routing.test.ts +0 -257
  264. package/src/v2/runtime/__tests__/runtime.test.ts +0 -234
  265. package/src/v2/runtime/__tests__/sse-response-telemetry.test.ts +0 -108
  266. package/src/v2/runtime/__tests__/telemetry.test.ts +0 -167
  267. package/src/v2/runtime/__tests__/thread-names.test.ts +0 -188
  268. package/src/v2/runtime/core/__tests__/debug-event-bus.test.ts +0 -156
  269. package/src/v2/runtime/core/debug-event-bus.ts +0 -45
  270. package/src/v2/runtime/core/fetch-cors.ts +0 -136
  271. package/src/v2/runtime/core/fetch-handler.ts +0 -492
  272. package/src/v2/runtime/core/fetch-router.ts +0 -203
  273. package/src/v2/runtime/core/hooks.ts +0 -160
  274. package/src/v2/runtime/core/middleware-sse-parser.ts +0 -210
  275. package/src/v2/runtime/core/middleware.ts +0 -115
  276. package/src/v2/runtime/core/runtime.ts +0 -432
  277. package/src/v2/runtime/endpoints/express-fetch-bridge.ts +0 -137
  278. package/src/v2/runtime/endpoints/express-single.ts +0 -54
  279. package/src/v2/runtime/endpoints/express.ts +0 -179
  280. package/src/v2/runtime/endpoints/hono-single.ts +0 -60
  281. package/src/v2/runtime/endpoints/hono.ts +0 -89
  282. package/src/v2/runtime/endpoints/index.ts +0 -4
  283. package/src/v2/runtime/endpoints/node-fetch-handler.ts +0 -48
  284. package/src/v2/runtime/endpoints/node.ts +0 -28
  285. package/src/v2/runtime/endpoints/single-route-helpers.ts +0 -125
  286. package/src/v2/runtime/express.ts +0 -2
  287. package/src/v2/runtime/handlers/__tests__/handle-debug-events.test.ts +0 -176
  288. package/src/v2/runtime/handlers/get-runtime-info.ts +0 -101
  289. package/src/v2/runtime/handlers/handle-connect.ts +0 -80
  290. package/src/v2/runtime/handlers/handle-debug-events.ts +0 -52
  291. package/src/v2/runtime/handlers/handle-run.ts +0 -111
  292. package/src/v2/runtime/handlers/handle-stop.ts +0 -77
  293. package/src/v2/runtime/handlers/handle-threads.ts +0 -11
  294. package/src/v2/runtime/handlers/handle-transcribe.ts +0 -269
  295. package/src/v2/runtime/handlers/header-utils.ts +0 -24
  296. package/src/v2/runtime/handlers/intelligence/connect.ts +0 -102
  297. package/src/v2/runtime/handlers/intelligence/run.ts +0 -351
  298. package/src/v2/runtime/handlers/intelligence/thread-names.ts +0 -246
  299. package/src/v2/runtime/handlers/intelligence/threads.ts +0 -420
  300. package/src/v2/runtime/handlers/shared/agent-utils.ts +0 -154
  301. package/src/v2/runtime/handlers/shared/intelligence-utils.ts +0 -41
  302. package/src/v2/runtime/handlers/shared/json-response.ts +0 -9
  303. package/src/v2/runtime/handlers/shared/resolve-intelligence-user.ts +0 -28
  304. package/src/v2/runtime/handlers/shared/sse-response.ts +0 -215
  305. package/src/v2/runtime/handlers/sse/__tests__/sse-connect-agent-id.test.ts +0 -71
  306. package/src/v2/runtime/handlers/sse/connect.ts +0 -30
  307. package/src/v2/runtime/handlers/sse/run.ts +0 -40
  308. package/src/v2/runtime/hono.ts +0 -2
  309. package/src/v2/runtime/index.ts +0 -51
  310. package/src/v2/runtime/intelligence-platform/__tests__/client.test.ts +0 -601
  311. package/src/v2/runtime/intelligence-platform/__tests__/intelligence-mcp-helper.test.ts +0 -246
  312. package/src/v2/runtime/intelligence-platform/client.ts +0 -818
  313. package/src/v2/runtime/intelligence-platform/index.ts +0 -10
  314. package/src/v2/runtime/node.ts +0 -6
  315. package/src/v2/runtime/open-generative-ui-middleware.ts +0 -373
  316. package/src/v2/runtime/runner/__tests__/finalize-events.test.ts +0 -109
  317. package/src/v2/runtime/runner/__tests__/in-memory-runner.e2e.test.ts +0 -775
  318. package/src/v2/runtime/runner/__tests__/in-memory-runner.test.ts +0 -777
  319. package/src/v2/runtime/runner/__tests__/intelligence-runner.test.ts +0 -1039
  320. package/src/v2/runtime/runner/agent-runner.ts +0 -35
  321. package/src/v2/runtime/runner/in-memory.ts +0 -467
  322. package/src/v2/runtime/runner/index.ts +0 -4
  323. package/src/v2/runtime/runner/intelligence.ts +0 -498
  324. package/src/v2/runtime/telemetry/__tests__/instance-created.test.ts +0 -96
  325. package/src/v2/runtime/telemetry/events.ts +0 -35
  326. package/src/v2/runtime/telemetry/index.ts +0 -7
  327. package/src/v2/runtime/telemetry/instance-created.ts +0 -44
  328. package/src/v2/runtime/telemetry/scarf-client.ts +0 -39
  329. package/src/v2/runtime/telemetry/telemetry-client.ts +0 -70
  330. package/src/v2/runtime/transcription-service/transcription-service.ts +0 -11
  331. package/tests/global.d.ts +0 -1
  332. package/tests/service-adapters/anthropic/allowlist-approach.test.ts +0 -259
  333. package/tests/service-adapters/anthropic/anthropic-adapter-language-model.test.ts +0 -101
  334. package/tests/service-adapters/anthropic/anthropic-adapter.test.ts +0 -645
  335. package/tests/service-adapters/anthropic/utils-token-trimming.test.ts +0 -301
  336. package/tests/service-adapters/groq/groq-adapter-language-model.test.ts +0 -102
  337. package/tests/service-adapters/openai/allowlist-approach.test.ts +0 -294
  338. package/tests/service-adapters/openai/openai-adapter-language-model.test.ts +0 -122
  339. package/tests/service-adapters/openai/openai-adapter.test.ts +0 -291
  340. package/tests/service-adapters/shared/sdk-client-utils.test.ts +0 -36
  341. package/tests/setup.vitest.ts +0 -8
  342. package/tests/tsconfig.json +0 -10
  343. package/tsconfig.json +0 -20
  344. package/tsdown.config.ts +0 -45
  345. package/typedoc.json +0 -4
  346. package/vitest.config.mjs +0 -13
@@ -1,692 +0,0 @@
1
- import { describe, it, expect } from "vitest";
2
- import { EventType } from "@ag-ui/client";
3
- import {
4
- createAgent,
5
- createDefaultInput,
6
- collectEvents,
7
- collectEventsIncludingErrors,
8
- expectLifecycleWrapped,
9
- expectEventSequence,
10
- eventField,
11
- textStart,
12
- textDelta,
13
- toolCallStreamingStart,
14
- toolCallDelta,
15
- toolCall,
16
- toolResult,
17
- reasoningStart,
18
- reasoningDelta,
19
- reasoningEnd,
20
- finish,
21
- } from "./agent-test-helpers";
22
-
23
- // ---------------------------------------------------------------------------
24
- // Basic Event Emission
25
- // ---------------------------------------------------------------------------
26
-
27
- describe("AI SDK Converter", () => {
28
- describe("Basic Event Emission", () => {
29
- it("text delta emits TEXT_MESSAGE_CHUNK with correct role, messageId, and delta", async () => {
30
- const agent = createAgent("aisdk", [textDelta("Hello"), finish()]);
31
- const input = createDefaultInput();
32
- const events = await collectEvents(agent.run(input));
33
-
34
- expectLifecycleWrapped(events);
35
-
36
- const textChunks = events.filter(
37
- (e) => e.type === EventType.TEXT_MESSAGE_CHUNK,
38
- );
39
- expect(textChunks).toHaveLength(1);
40
-
41
- expect(eventField<string>(textChunks[0], "role")).toBe("assistant");
42
- expect(eventField<string>(textChunks[0], "delta")).toBe("Hello");
43
- expect(eventField<string>(textChunks[0], "messageId")).toBeDefined();
44
- expect(typeof eventField<string>(textChunks[0], "messageId")).toBe(
45
- "string",
46
- );
47
- });
48
-
49
- it("text-start with provider id uses that id as messageId", async () => {
50
- const agent = createAgent("aisdk", [
51
- textStart("custom-msg-id"),
52
- textDelta("Hi"),
53
- finish(),
54
- ]);
55
- const input = createDefaultInput();
56
- const events = await collectEvents(agent.run(input));
57
-
58
- const chunk = events.find(
59
- (e) => e.type === EventType.TEXT_MESSAGE_CHUNK,
60
- )!;
61
- expect(eventField<string>(chunk, "messageId")).toBe("custom-msg-id");
62
- });
63
-
64
- it('text-start with "0" generates a unique messageId (not "0")', async () => {
65
- const agent = createAgent("aisdk", [
66
- textStart("0"),
67
- textDelta("Hi"),
68
- finish(),
69
- ]);
70
- const input = createDefaultInput();
71
- const events = await collectEvents(agent.run(input));
72
-
73
- const chunk = events.find(
74
- (e) => e.type === EventType.TEXT_MESSAGE_CHUNK,
75
- )!;
76
- expect(eventField<string>(chunk, "messageId")).not.toBe("0");
77
- expect(eventField<string>(chunk, "messageId")).toBeDefined();
78
- expect(eventField<string>(chunk, "messageId").length).toBeGreaterThan(0);
79
- });
80
-
81
- it("multiple text deltas share the same messageId", async () => {
82
- const agent = createAgent("aisdk", [
83
- textDelta("Hello "),
84
- textDelta("world"),
85
- finish(),
86
- ]);
87
- const input = createDefaultInput();
88
- const events = await collectEvents(agent.run(input));
89
-
90
- const textChunks = events.filter(
91
- (e) => e.type === EventType.TEXT_MESSAGE_CHUNK,
92
- );
93
- expect(textChunks).toHaveLength(2);
94
- expect(eventField<string>(textChunks[0], "messageId")).toBe(
95
- eventField<string>(textChunks[1], "messageId"),
96
- );
97
- });
98
-
99
- it("empty stream (only finish) emits only RUN_STARTED + RUN_FINISHED", async () => {
100
- const agent = createAgent("aisdk", [finish()]);
101
- const input = createDefaultInput();
102
- const events = await collectEvents(agent.run(input));
103
-
104
- expectEventSequence(events, [
105
- EventType.RUN_STARTED,
106
- EventType.RUN_FINISHED,
107
- ]);
108
- });
109
- });
110
-
111
- // ---------------------------------------------------------------------------
112
- // Tool Call Events
113
- // ---------------------------------------------------------------------------
114
-
115
- describe("Tool Call Events", () => {
116
- it("streamed tool call emits correct START/ARGS/END/RESULT events", async () => {
117
- const agent = createAgent("aisdk", [
118
- toolCallStreamingStart("tc-1", "myTool"),
119
- toolCallDelta("tc-1", '{"key":'),
120
- toolCallDelta("tc-1", '"value"}'),
121
- toolCall("tc-1", "myTool"),
122
- toolResult("tc-1", "myTool", { result: "ok" }),
123
- finish(),
124
- ]);
125
- const input = createDefaultInput();
126
- const events = await collectEvents(agent.run(input));
127
-
128
- expectLifecycleWrapped(events);
129
-
130
- // Check the sequence of tool events
131
- const toolEvents = events.filter(
132
- (e) =>
133
- e.type === EventType.TOOL_CALL_START ||
134
- e.type === EventType.TOOL_CALL_ARGS ||
135
- e.type === EventType.TOOL_CALL_END ||
136
- e.type === EventType.TOOL_CALL_RESULT,
137
- );
138
-
139
- expectEventSequence(toolEvents, [
140
- EventType.TOOL_CALL_START,
141
- EventType.TOOL_CALL_ARGS,
142
- EventType.TOOL_CALL_ARGS,
143
- EventType.TOOL_CALL_END,
144
- EventType.TOOL_CALL_RESULT,
145
- ]);
146
-
147
- // Verify TOOL_CALL_START details
148
- expect(eventField<string>(toolEvents[0], "toolCallId")).toBe("tc-1");
149
- expect(eventField<string>(toolEvents[0], "toolCallName")).toBe("myTool");
150
-
151
- // Verify TOOL_CALL_ARGS deltas
152
- const argsEvts = toolEvents.filter(
153
- (e) => e.type === EventType.TOOL_CALL_ARGS,
154
- );
155
- expect(eventField<string>(argsEvts[0], "delta")).toBe('{"key":');
156
- expect(eventField<string>(argsEvts[1], "delta")).toBe('"value"}');
157
-
158
- // Verify TOOL_CALL_END
159
- expect(eventField<string>(toolEvents[2 + 1], "toolCallId")).toBe("tc-1");
160
-
161
- // Verify TOOL_CALL_RESULT
162
- expect(eventField<string>(toolEvents[4], "toolCallId")).toBe("tc-1");
163
- expect(JSON.parse(eventField<string>(toolEvents[4], "content"))).toEqual({
164
- result: "ok",
165
- });
166
- });
167
-
168
- it("non-streamed tool call (tool-call with input, no prior tool-input-start) emits START + ARGS + END", async () => {
169
- const agent = createAgent("aisdk", [
170
- toolCall("tc-2", "directTool", { foo: "bar" }),
171
- finish(),
172
- ]);
173
- const input = createDefaultInput();
174
- const events = await collectEvents(agent.run(input));
175
-
176
- expectLifecycleWrapped(events);
177
-
178
- const toolEvents = events.filter(
179
- (e) =>
180
- e.type === EventType.TOOL_CALL_START ||
181
- e.type === EventType.TOOL_CALL_ARGS ||
182
- e.type === EventType.TOOL_CALL_END,
183
- );
184
-
185
- expectEventSequence(toolEvents, [
186
- EventType.TOOL_CALL_START,
187
- EventType.TOOL_CALL_ARGS,
188
- EventType.TOOL_CALL_END,
189
- ]);
190
-
191
- expect(eventField<string>(toolEvents[0], "toolCallId")).toBe("tc-2");
192
- expect(eventField<string>(toolEvents[0], "toolCallName")).toBe(
193
- "directTool",
194
- );
195
-
196
- expect(JSON.parse(eventField<string>(toolEvents[1], "delta"))).toEqual({
197
- foo: "bar",
198
- });
199
- });
200
-
201
- it("no duplicate START after tool-input-start followed by tool-call", async () => {
202
- const agent = createAgent("aisdk", [
203
- toolCallStreamingStart("tc-3", "myTool"),
204
- toolCallDelta("tc-3", "{}"),
205
- toolCall("tc-3", "myTool"),
206
- finish(),
207
- ]);
208
- const input = createDefaultInput();
209
- const events = await collectEvents(agent.run(input));
210
-
211
- const startEvents = events.filter(
212
- (e) =>
213
- e.type === EventType.TOOL_CALL_START &&
214
- eventField<string>(e, "toolCallId") === "tc-3",
215
- );
216
- expect(startEvents).toHaveLength(1);
217
- });
218
-
219
- it("multiple concurrent tool calls have events correctly paired by toolCallId", async () => {
220
- const agent = createAgent("aisdk", [
221
- toolCallStreamingStart("tc-a", "toolA"),
222
- toolCallStreamingStart("tc-b", "toolB"),
223
- toolCallDelta("tc-a", '{"a":1}'),
224
- toolCallDelta("tc-b", '{"b":2}'),
225
- toolCall("tc-a", "toolA"),
226
- toolCall("tc-b", "toolB"),
227
- toolResult("tc-a", "toolA", "resultA"),
228
- toolResult("tc-b", "toolB", "resultB"),
229
- finish(),
230
- ]);
231
- const input = createDefaultInput();
232
- const events = await collectEvents(agent.run(input));
233
-
234
- expectLifecycleWrapped(events);
235
-
236
- // Verify each tool call has its own START
237
- const startsA = events.filter(
238
- (e) =>
239
- e.type === EventType.TOOL_CALL_START &&
240
- eventField<string>(e, "toolCallId") === "tc-a",
241
- );
242
- const startsB = events.filter(
243
- (e) =>
244
- e.type === EventType.TOOL_CALL_START &&
245
- eventField<string>(e, "toolCallId") === "tc-b",
246
- );
247
- expect(startsA).toHaveLength(1);
248
- expect(startsB).toHaveLength(1);
249
-
250
- // Verify args are correctly paired
251
- const argsA = events.filter(
252
- (e) =>
253
- e.type === EventType.TOOL_CALL_ARGS &&
254
- eventField<string>(e, "toolCallId") === "tc-a",
255
- );
256
- const argsB = events.filter(
257
- (e) =>
258
- e.type === EventType.TOOL_CALL_ARGS &&
259
- eventField<string>(e, "toolCallId") === "tc-b",
260
- );
261
- expect(eventField<string>(argsA[0], "delta")).toBe('{"a":1}');
262
- expect(eventField<string>(argsB[0], "delta")).toBe('{"b":2}');
263
-
264
- // Verify results are correctly paired
265
- const resultsA = events.filter(
266
- (e) =>
267
- e.type === EventType.TOOL_CALL_RESULT &&
268
- eventField<string>(e, "toolCallId") === "tc-a",
269
- );
270
- const resultsB = events.filter(
271
- (e) =>
272
- e.type === EventType.TOOL_CALL_RESULT &&
273
- eventField<string>(e, "toolCallId") === "tc-b",
274
- );
275
- expect(JSON.parse(eventField<string>(resultsA[0], "content"))).toBe(
276
- "resultA",
277
- );
278
- expect(JSON.parse(eventField<string>(resultsB[0], "content"))).toBe(
279
- "resultB",
280
- );
281
- });
282
- });
283
-
284
- // ---------------------------------------------------------------------------
285
- // Reasoning Events
286
- // ---------------------------------------------------------------------------
287
-
288
- describe("Reasoning Events", () => {
289
- it("full reasoning lifecycle emits correct REASONING_START/MESSAGE_START/CONTENT/MESSAGE_END/END events", async () => {
290
- const agent = createAgent("aisdk", [
291
- reasoningStart("r-1"),
292
- reasoningDelta("thinking..."),
293
- reasoningEnd(),
294
- textDelta("Answer"),
295
- finish(),
296
- ]);
297
- const input = createDefaultInput();
298
- const events = await collectEvents(agent.run(input));
299
-
300
- expectLifecycleWrapped(events);
301
-
302
- const reasoningEvents = events.filter(
303
- (e) =>
304
- e.type === EventType.REASONING_START ||
305
- e.type === EventType.REASONING_MESSAGE_START ||
306
- e.type === EventType.REASONING_MESSAGE_CONTENT ||
307
- e.type === EventType.REASONING_MESSAGE_END ||
308
- e.type === EventType.REASONING_END,
309
- );
310
-
311
- expectEventSequence(reasoningEvents, [
312
- EventType.REASONING_START,
313
- EventType.REASONING_MESSAGE_START,
314
- EventType.REASONING_MESSAGE_CONTENT,
315
- EventType.REASONING_MESSAGE_END,
316
- EventType.REASONING_END,
317
- ]);
318
-
319
- // Verify messageId consistency
320
- expect(eventField<string>(reasoningEvents[0], "messageId")).toBe("r-1");
321
- expect(eventField<string>(reasoningEvents[1], "messageId")).toBe("r-1");
322
- expect(eventField<string>(reasoningEvents[1], "role")).toBe("reasoning");
323
- expect(eventField<string>(reasoningEvents[2], "messageId")).toBe("r-1");
324
- expect(eventField<string>(reasoningEvents[2], "delta")).toBe(
325
- "thinking...",
326
- );
327
- expect(eventField<string>(reasoningEvents[3], "messageId")).toBe("r-1");
328
- expect(eventField<string>(reasoningEvents[4], "messageId")).toBe("r-1");
329
- });
330
-
331
- it("empty reasoning deltas are skipped", async () => {
332
- const agent = createAgent("aisdk", [
333
- reasoningStart(),
334
- reasoningDelta(""),
335
- reasoningDelta("actual content"),
336
- reasoningDelta(""),
337
- reasoningEnd(),
338
- finish(),
339
- ]);
340
- const input = createDefaultInput();
341
- const events = await collectEvents(agent.run(input));
342
-
343
- const contentEvents = events.filter(
344
- (e) => e.type === EventType.REASONING_MESSAGE_CONTENT,
345
- );
346
- expect(contentEvents).toHaveLength(1);
347
- expect(eventField<string>(contentEvents[0], "delta")).toBe(
348
- "actual content",
349
- );
350
- });
351
-
352
- it("auto-close reasoning before text-delta", async () => {
353
- // No explicit reasoning-end — the converter should auto-close
354
- const agent = createAgent("aisdk", [
355
- reasoningStart("r-auto"),
356
- reasoningDelta("thinking"),
357
- textDelta("Answer"),
358
- finish(),
359
- ]);
360
- const input = createDefaultInput();
361
- const events = await collectEvents(agent.run(input));
362
-
363
- expectLifecycleWrapped(events);
364
-
365
- // Reasoning should be closed before the text event
366
- const types = events.map((e) => e.type);
367
- const msgEndIdx = types.indexOf(EventType.REASONING_MESSAGE_END);
368
- const reasoningEndIdx = types.indexOf(EventType.REASONING_END);
369
- const textIdx = types.indexOf(EventType.TEXT_MESSAGE_CHUNK);
370
-
371
- expect(msgEndIdx).toBeGreaterThan(-1);
372
- expect(reasoningEndIdx).toBeGreaterThan(-1);
373
- expect(textIdx).toBeGreaterThan(reasoningEndIdx);
374
- });
375
-
376
- it("auto-close reasoning before tool-input-start", async () => {
377
- const agent = createAgent("aisdk", [
378
- reasoningStart(),
379
- reasoningDelta("thinking about tools"),
380
- toolCallStreamingStart("tc-r", "someTool"),
381
- toolCallDelta("tc-r", "{}"),
382
- toolCall("tc-r", "someTool"),
383
- finish(),
384
- ]);
385
- const input = createDefaultInput();
386
- const events = await collectEvents(agent.run(input));
387
-
388
- expectLifecycleWrapped(events);
389
-
390
- const types = events.map((e) => e.type);
391
- const reasoningEndIdx = types.indexOf(EventType.REASONING_END);
392
- const toolStartIdx = types.indexOf(EventType.TOOL_CALL_START);
393
-
394
- expect(reasoningEndIdx).toBeGreaterThan(-1);
395
- expect(toolStartIdx).toBeGreaterThan(reasoningEndIdx);
396
- });
397
-
398
- it("auto-close reasoning before finish", async () => {
399
- const agent = createAgent("aisdk", [
400
- reasoningStart(),
401
- reasoningDelta("deep thought"),
402
- finish(),
403
- ]);
404
- const input = createDefaultInput();
405
- const events = await collectEvents(agent.run(input));
406
-
407
- expectLifecycleWrapped(events);
408
-
409
- // Should contain reasoning close events
410
- const types = events.map((e) => e.type);
411
- expect(types).toContain(EventType.REASONING_MESSAGE_END);
412
- expect(types).toContain(EventType.REASONING_END);
413
-
414
- // They should appear before RUN_FINISHED
415
- const reasoningEndIdx = types.indexOf(EventType.REASONING_END);
416
- const runFinishedIdx = types.indexOf(EventType.RUN_FINISHED);
417
- expect(reasoningEndIdx).toBeLessThan(runFinishedIdx);
418
- });
419
- });
420
-
421
- // ---------------------------------------------------------------------------
422
- // State Management Tool Results
423
- // ---------------------------------------------------------------------------
424
-
425
- describe("State Management Tool Results", () => {
426
- it("AGUISendStateSnapshot tool result emits STATE_SNAPSHOT event", async () => {
427
- const agent = createAgent("aisdk", [
428
- toolCallStreamingStart("tc-state", "AGUISendStateSnapshot"),
429
- toolCallDelta("tc-state", '{"snapshot":{"count":1}}'),
430
- toolCall("tc-state", "AGUISendStateSnapshot"),
431
- toolResult("tc-state", "AGUISendStateSnapshot", {
432
- snapshot: { count: 1 },
433
- }),
434
- finish(),
435
- ]);
436
- const input = createDefaultInput();
437
- const events = await collectEvents(agent.run(input));
438
-
439
- const stateSnapshots = events.filter(
440
- (e) => e.type === EventType.STATE_SNAPSHOT,
441
- );
442
- expect(stateSnapshots).toHaveLength(1);
443
- expect(eventField(stateSnapshots[0], "snapshot")).toEqual({ count: 1 });
444
- });
445
-
446
- it("AGUISendStateDelta tool result emits STATE_DELTA event", async () => {
447
- const delta = [{ op: "replace", path: "/count", value: 2 }];
448
- const agent = createAgent("aisdk", [
449
- toolCallStreamingStart("tc-delta", "AGUISendStateDelta"),
450
- toolCallDelta("tc-delta", JSON.stringify({ delta })),
451
- toolCall("tc-delta", "AGUISendStateDelta"),
452
- toolResult("tc-delta", "AGUISendStateDelta", { delta }),
453
- finish(),
454
- ]);
455
- const input = createDefaultInput();
456
- const events = await collectEvents(agent.run(input));
457
-
458
- const stateDeltas = events.filter(
459
- (e) => e.type === EventType.STATE_DELTA,
460
- );
461
- expect(stateDeltas).toHaveLength(1);
462
- expect(eventField(stateDeltas[0], "delta")).toEqual(delta);
463
- });
464
-
465
- it("state tool result also emits TOOL_CALL_RESULT event", async () => {
466
- const agent = createAgent("aisdk", [
467
- toolCallStreamingStart("tc-state2", "AGUISendStateSnapshot"),
468
- toolCallDelta("tc-state2", "{}"),
469
- toolCall("tc-state2", "AGUISendStateSnapshot"),
470
- toolResult("tc-state2", "AGUISendStateSnapshot", {
471
- snapshot: { x: 1 },
472
- }),
473
- finish(),
474
- ]);
475
- const input = createDefaultInput();
476
- const events = await collectEvents(agent.run(input));
477
-
478
- const toolResults = events.filter(
479
- (e) => e.type === EventType.TOOL_CALL_RESULT,
480
- );
481
- expect(toolResults).toHaveLength(1);
482
- expect(eventField<string>(toolResults[0], "toolCallId")).toBe(
483
- "tc-state2",
484
- );
485
- });
486
-
487
- it("does not emit STATE_SNAPSHOT when snapshot field is undefined", async () => {
488
- const agent = createAgent("aisdk", [
489
- toolCallStreamingStart("tc-no-snap", "AGUISendStateSnapshot"),
490
- toolCallDelta("tc-no-snap", "{}"),
491
- toolCall("tc-no-snap", "AGUISendStateSnapshot"),
492
- toolResult("tc-no-snap", "AGUISendStateSnapshot", {
493
- success: true,
494
- }),
495
- finish(),
496
- ]);
497
- const input = createDefaultInput();
498
- const events = await collectEvents(agent.run(input));
499
-
500
- const stateSnapshots = events.filter(
501
- (e) => e.type === EventType.STATE_SNAPSHOT,
502
- );
503
- expect(stateSnapshots).toHaveLength(0);
504
-
505
- // Should still emit the TOOL_CALL_RESULT
506
- const toolResults = events.filter(
507
- (e) => e.type === EventType.TOOL_CALL_RESULT,
508
- );
509
- expect(toolResults).toHaveLength(1);
510
- });
511
-
512
- it("does not emit STATE_DELTA when delta field is undefined", async () => {
513
- const agent = createAgent("aisdk", [
514
- toolCallStreamingStart("tc-no-delta", "AGUISendStateDelta"),
515
- toolCallDelta("tc-no-delta", "{}"),
516
- toolCall("tc-no-delta", "AGUISendStateDelta"),
517
- toolResult("tc-no-delta", "AGUISendStateDelta", {
518
- success: true,
519
- }),
520
- finish(),
521
- ]);
522
- const input = createDefaultInput();
523
- const events = await collectEvents(agent.run(input));
524
-
525
- const stateDeltas = events.filter(
526
- (e) => e.type === EventType.STATE_DELTA,
527
- );
528
- expect(stateDeltas).toHaveLength(0);
529
- });
530
- });
531
-
532
- // ---------------------------------------------------------------------------
533
- // Tool Result Property Compatibility
534
- // ---------------------------------------------------------------------------
535
-
536
- describe("Tool Result Property Compatibility", () => {
537
- it("reads tool result from 'result' property when 'output' is absent", async () => {
538
- // Simulate older AI SDK that uses "result" instead of "output"
539
- const agent = createAgent("aisdk", [
540
- toolCall("tc-compat", "myTool"),
541
- {
542
- type: "tool-result",
543
- toolCallId: "tc-compat",
544
- toolName: "myTool",
545
- result: { data: "from-result-prop" },
546
- },
547
- finish(),
548
- ]);
549
- const input = createDefaultInput();
550
- const events = await collectEvents(agent.run(input));
551
-
552
- const resultEvents = events.filter(
553
- (e) => e.type === EventType.TOOL_CALL_RESULT,
554
- );
555
- expect(resultEvents).toHaveLength(1);
556
- expect(
557
- JSON.parse(eventField<string>(resultEvents[0], "content")),
558
- ).toEqual({ data: "from-result-prop" });
559
- });
560
-
561
- it("prefers 'output' over 'result' when both are present", async () => {
562
- const agent = createAgent("aisdk", [
563
- toolCall("tc-both", "myTool"),
564
- {
565
- type: "tool-result",
566
- toolCallId: "tc-both",
567
- toolName: "myTool",
568
- output: { source: "output" },
569
- result: { source: "result" },
570
- },
571
- finish(),
572
- ]);
573
- const input = createDefaultInput();
574
- const events = await collectEvents(agent.run(input));
575
-
576
- const resultEvents = events.filter(
577
- (e) => e.type === EventType.TOOL_CALL_RESULT,
578
- );
579
- expect(
580
- JSON.parse(eventField<string>(resultEvents[0], "content")),
581
- ).toEqual({ source: "output" });
582
- });
583
- });
584
-
585
- // ---------------------------------------------------------------------------
586
- // Error Event Handling
587
- // ---------------------------------------------------------------------------
588
-
589
- describe("Error Event Handling", () => {
590
- it("wraps undefined error in a descriptive Error", async () => {
591
- const agent = createAgent("aisdk", [
592
- textDelta("before error"),
593
- { type: "error" }, // no .error property
594
- ]);
595
- const input = createDefaultInput();
596
-
597
- const { events, errored } = await collectEventsIncludingErrors(
598
- agent.run(input),
599
- );
600
-
601
- expect(errored).toBe(true);
602
- const errorEvents = events.filter((e) => e.type === EventType.RUN_ERROR);
603
- expect(errorEvents).toHaveLength(1);
604
- // Should contain a useful message, not just "undefined"
605
- expect(eventField<string>(errorEvents[0], "message")).not.toBe(
606
- "undefined",
607
- );
608
- expect(
609
- eventField<string>(errorEvents[0], "message").length,
610
- ).toBeGreaterThan(5);
611
- });
612
-
613
- it("preserves Error instances from error event", async () => {
614
- const agent = createAgent("aisdk", [
615
- { type: "error", error: new Error("rate limit exceeded") },
616
- ]);
617
- const input = createDefaultInput();
618
-
619
- const { events, errored } = await collectEventsIncludingErrors(
620
- agent.run(input),
621
- );
622
-
623
- expect(errored).toBe(true);
624
- const errorEvents = events.filter((e) => e.type === EventType.RUN_ERROR);
625
- expect(eventField<string>(errorEvents[0], "message")).toBe(
626
- "rate limit exceeded",
627
- );
628
- });
629
-
630
- it("handles string error from error event", async () => {
631
- const agent = createAgent("aisdk", [
632
- { type: "error", message: "auth failed" },
633
- ]);
634
- const input = createDefaultInput();
635
-
636
- const { events, errored } = await collectEventsIncludingErrors(
637
- agent.run(input),
638
- );
639
-
640
- expect(errored).toBe(true);
641
- const errorEvents = events.filter((e) => e.type === EventType.RUN_ERROR);
642
- expect(eventField<string>(errorEvents[0], "message")).toBe("auth failed");
643
- });
644
- });
645
-
646
- // ---------------------------------------------------------------------------
647
- // Edge Cases
648
- // ---------------------------------------------------------------------------
649
-
650
- describe("Edge Cases", () => {
651
- it("unknown event types are silently ignored", async () => {
652
- const agent = createAgent("aisdk", [
653
- { type: "some-unknown-event", data: "hello" },
654
- textDelta("text after unknown"),
655
- { type: "another-mystery-event" },
656
- finish(),
657
- ]);
658
- const input = createDefaultInput();
659
- const events = await collectEvents(agent.run(input));
660
-
661
- expectLifecycleWrapped(events);
662
-
663
- // Should still have the text chunk
664
- const textChunks = events.filter(
665
- (e) => e.type === EventType.TEXT_MESSAGE_CHUNK,
666
- );
667
- expect(textChunks).toHaveLength(1);
668
-
669
- // No events for unknown types — only RUN_STARTED, TEXT_MESSAGE_CHUNK, RUN_FINISHED
670
- expectEventSequence(events, [
671
- EventType.RUN_STARTED,
672
- EventType.TEXT_MESSAGE_CHUNK,
673
- EventType.RUN_FINISHED,
674
- ]);
675
- });
676
-
677
- it("large text deltas (100k chars) are passed through", async () => {
678
- const largeText = "x".repeat(100_000);
679
- const agent = createAgent("aisdk", [textDelta(largeText), finish()]);
680
- const input = createDefaultInput();
681
- const events = await collectEvents(agent.run(input));
682
-
683
- expectLifecycleWrapped(events);
684
-
685
- const chunk = events.find(
686
- (e) => e.type === EventType.TEXT_MESSAGE_CHUNK,
687
- )!;
688
- expect(eventField<string>(chunk, "delta")).toBe(largeText);
689
- expect(eventField<string>(chunk, "delta").length).toBe(100_000);
690
- });
691
- });
692
- });