@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,593 +0,0 @@
1
- import { describe, it, expect } from "vitest";
2
- import { EventType, type BaseEvent } from "@ag-ui/client";
3
- import {
4
- BuiltInAgent,
5
- type AgentFactoryContext,
6
- type BuiltInAgentFactoryConfig,
7
- createDefaultInput,
8
- createAgent,
9
- createThrowingAgent,
10
- createMidStreamErrorAgent,
11
- collectEvents,
12
- collectEventsIncludingErrors,
13
- expectLifecycleWrapped,
14
- eventField,
15
- textDelta,
16
- finish,
17
- tanstackTextChunk,
18
- type AgentType,
19
- type MockStreamEvent,
20
- } from "./agent-test-helpers";
21
-
22
- // ---------------------------------------------------------------------------
23
- // Local helpers for parameterized tests
24
- // ---------------------------------------------------------------------------
25
-
26
- const allTypes: AgentType[] = ["aisdk", "tanstack", "custom"];
27
-
28
- function minimalStreamData(
29
- type: AgentType,
30
- ): MockStreamEvent[] | Record<string, unknown>[] | BaseEvent[] {
31
- switch (type) {
32
- case "aisdk":
33
- return [textDelta("hi"), finish()];
34
- case "tanstack":
35
- return [tanstackTextChunk("hi")];
36
- case "custom":
37
- return [
38
- {
39
- type: EventType.TEXT_MESSAGE_CHUNK,
40
- role: "assistant",
41
- delta: "hi",
42
- } as BaseEvent,
43
- ];
44
- }
45
- }
46
-
47
- function emptyStreamData(
48
- type: AgentType,
49
- ): MockStreamEvent[] | Record<string, unknown>[] | BaseEvent[] {
50
- switch (type) {
51
- case "aisdk":
52
- return [finish()];
53
- case "tanstack":
54
- return [];
55
- case "custom":
56
- return [];
57
- }
58
- }
59
-
60
- // ---------------------------------------------------------------------------
61
- // Parameterized test suites
62
- // ---------------------------------------------------------------------------
63
-
64
- describe.each(allTypes)("Agent [%s]", (type) => {
65
- // -------------------------------------------------------------------------
66
- // Lifecycle
67
- // -------------------------------------------------------------------------
68
- describe("lifecycle", () => {
69
- it("emits RUN_STARTED as the first event with correct threadId/runId", async () => {
70
- const agent = createAgent(type, minimalStreamData(type));
71
- const input = createDefaultInput({ threadId: "t1", runId: "r1" });
72
- const events = await collectEvents(agent.run(input));
73
-
74
- expect(events.length).toBeGreaterThanOrEqual(2);
75
- const first = events[0];
76
- expect(first.type).toBe(EventType.RUN_STARTED);
77
- expect(eventField<string>(first, "threadId")).toBe("t1");
78
- expect(eventField<string>(first, "runId")).toBe("r1");
79
- });
80
-
81
- it("emits RUN_FINISHED as the last event with correct threadId/runId", async () => {
82
- const agent = createAgent(type, minimalStreamData(type));
83
- const input = createDefaultInput({ threadId: "t2", runId: "r2" });
84
- const events = await collectEvents(agent.run(input));
85
-
86
- const last = events[events.length - 1];
87
- expect(last.type).toBe(EventType.RUN_FINISHED);
88
- expect(eventField<string>(last, "threadId")).toBe("t2");
89
- expect(eventField<string>(last, "runId")).toBe("r2");
90
- });
91
-
92
- it("emits RUN_FINISHED for an empty stream", async () => {
93
- const agent = createAgent(type, emptyStreamData(type));
94
- const input = createDefaultInput();
95
- const events = await collectEvents(agent.run(input));
96
-
97
- expect(events.length).toBeGreaterThanOrEqual(2);
98
- expect(events[0].type).toBe(EventType.RUN_STARTED);
99
- expect(events[events.length - 1].type).toBe(EventType.RUN_FINISHED);
100
- });
101
-
102
- it("wraps content with lifecycle events", async () => {
103
- const agent = createAgent(type, minimalStreamData(type));
104
- const input = createDefaultInput({ threadId: "wrap-t", runId: "wrap-r" });
105
- const events = await collectEvents(agent.run(input));
106
-
107
- expectLifecycleWrapped(events, "wrap-t", "wrap-r");
108
-
109
- // There should be content events between the lifecycle bookends
110
- const contentEvents = events.slice(1, -1);
111
- expect(contentEvents.length).toBeGreaterThan(0);
112
- for (const e of contentEvents) {
113
- expect(e.type).not.toBe(EventType.RUN_STARTED);
114
- expect(e.type).not.toBe(EventType.RUN_FINISHED);
115
- }
116
- });
117
- });
118
-
119
- // -------------------------------------------------------------------------
120
- // RUN_ERROR
121
- // -------------------------------------------------------------------------
122
- describe("RUN_ERROR", () => {
123
- it("emits RUN_ERROR when factory throws", async () => {
124
- const agent = createThrowingAgent(type, "factory-boom");
125
- const input = createDefaultInput();
126
- const { events, errored } = await collectEventsIncludingErrors(
127
- agent.run(input),
128
- );
129
-
130
- expect(errored).toBe(true);
131
- const errorEvents = events.filter((e) => e.type === EventType.RUN_ERROR);
132
- expect(errorEvents.length).toBe(1);
133
- expect(eventField<string>(errorEvents[0], "message")).toBe(
134
- "factory-boom",
135
- );
136
- });
137
-
138
- it("emits RUN_ERROR when stream throws mid-iteration", async () => {
139
- const agent = createMidStreamErrorAgent(type, "mid-stream-boom");
140
- const input = createDefaultInput();
141
- const { events, errored } = await collectEventsIncludingErrors(
142
- agent.run(input),
143
- );
144
-
145
- expect(errored).toBe(true);
146
- const errorEvents = events.filter((e) => e.type === EventType.RUN_ERROR);
147
- expect(errorEvents.length).toBe(1);
148
- expect(eventField<string>(errorEvents[0], "message")).toBe(
149
- "mid-stream-boom",
150
- );
151
- });
152
-
153
- it("does not emit RUN_FINISHED after RUN_ERROR", async () => {
154
- const agent = createThrowingAgent(type, "no-finish");
155
- const input = createDefaultInput();
156
- const { events } = await collectEventsIncludingErrors(agent.run(input));
157
-
158
- const errorIdx = events.findIndex((e) => e.type === EventType.RUN_ERROR);
159
- expect(errorIdx).toBeGreaterThanOrEqual(0);
160
-
161
- const eventsAfterError = events.slice(errorIdx + 1);
162
- const finishAfterError = eventsAfterError.filter(
163
- (e) => e.type === EventType.RUN_FINISHED,
164
- );
165
- expect(finishAfterError.length).toBe(0);
166
- });
167
- });
168
-
169
- // -------------------------------------------------------------------------
170
- // Abort
171
- // -------------------------------------------------------------------------
172
- describe("abort", () => {
173
- it("completes without error after abortRun()", async () => {
174
- // Use a signal to synchronize: abort after the first chunk is emitted
175
- let emittedFirstChunk: () => void;
176
- const firstChunkEmitted = new Promise<void>(
177
- (r) => (emittedFirstChunk = r),
178
- );
179
-
180
- let config: BuiltInAgentFactoryConfig;
181
- switch (type) {
182
- case "aisdk":
183
- config = {
184
- type: "aisdk",
185
- factory: ({ abortSignal }: AgentFactoryContext) => ({
186
- fullStream: (async function* () {
187
- yield { type: "text-delta", text: "tick" };
188
- emittedFirstChunk();
189
- // Wait for abort — use a promise that resolves on abort
190
- await new Promise<void>((r) => {
191
- if (abortSignal.aborted) return r();
192
- abortSignal.addEventListener("abort", () => r(), {
193
- once: true,
194
- });
195
- });
196
- })(),
197
- }),
198
- };
199
- break;
200
- case "tanstack":
201
- config = {
202
- type: "tanstack",
203
- factory: ({ abortSignal }: AgentFactoryContext) => ({
204
- [Symbol.asyncIterator]: async function* () {
205
- yield { type: "TEXT_MESSAGE_CONTENT", delta: "tick" };
206
- emittedFirstChunk();
207
- await new Promise<void>((r) => {
208
- if (abortSignal.aborted) return r();
209
- abortSignal.addEventListener("abort", () => r(), {
210
- once: true,
211
- });
212
- });
213
- },
214
- }),
215
- };
216
- break;
217
- case "custom":
218
- config = {
219
- type: "custom",
220
- factory: ({ abortSignal }: AgentFactoryContext) => ({
221
- [Symbol.asyncIterator]: async function* () {
222
- yield {
223
- type: EventType.TEXT_MESSAGE_CHUNK,
224
- role: "assistant",
225
- delta: "tick",
226
- } as BaseEvent;
227
- emittedFirstChunk();
228
- await new Promise<void>((r) => {
229
- if (abortSignal.aborted) return r();
230
- abortSignal.addEventListener("abort", () => r(), {
231
- once: true,
232
- });
233
- });
234
- },
235
- }),
236
- };
237
- break;
238
- }
239
-
240
- const agent = new BuiltInAgent(config);
241
- const input = createDefaultInput();
242
-
243
- const completed = await new Promise<boolean>((resolve) => {
244
- agent.run(input).subscribe({
245
- next: () => {},
246
- error: () => resolve(false),
247
- complete: () => resolve(true),
248
- });
249
-
250
- // Wait for the first chunk to be emitted, then abort
251
- firstChunkEmitted.then(() => agent.abortRun());
252
- });
253
-
254
- expect(completed).toBe(true);
255
- });
256
- });
257
-
258
- // -------------------------------------------------------------------------
259
- // Factory Context
260
- // -------------------------------------------------------------------------
261
- describe("factory context", () => {
262
- it("receives correct input with threadId, runId, and forwardedProps", async () => {
263
- let capturedCtx: AgentFactoryContext | null = null;
264
-
265
- let config: BuiltInAgentFactoryConfig;
266
- switch (type) {
267
- case "aisdk":
268
- config = {
269
- type: "aisdk",
270
- factory: (ctx: AgentFactoryContext) => {
271
- capturedCtx = ctx;
272
- return {
273
- fullStream: (async function* () {
274
- yield { type: "finish", finishReason: "stop" };
275
- })(),
276
- };
277
- },
278
- };
279
- break;
280
- case "tanstack":
281
- config = {
282
- type: "tanstack",
283
- factory: (ctx: AgentFactoryContext) => {
284
- capturedCtx = ctx;
285
- return (async function* () {
286
- // empty stream
287
- })();
288
- },
289
- };
290
- break;
291
- case "custom":
292
- config = {
293
- type: "custom",
294
- factory: (ctx: AgentFactoryContext) => {
295
- capturedCtx = ctx;
296
- return (async function* () {
297
- // empty stream
298
- })();
299
- },
300
- };
301
- break;
302
- }
303
-
304
- const agent = new BuiltInAgent(config);
305
- const input = createDefaultInput({
306
- threadId: "ctx-thread",
307
- runId: "ctx-run",
308
- forwardedProps: { model: "gpt-4" },
309
- });
310
-
311
- await collectEvents(agent.run(input));
312
-
313
- expect(capturedCtx).not.toBeNull();
314
- expect(capturedCtx!.input.threadId).toBe("ctx-thread");
315
- expect(capturedCtx!.input.runId).toBe("ctx-run");
316
- expect(capturedCtx!.input.forwardedProps).toEqual({ model: "gpt-4" });
317
- });
318
-
319
- it("receives abortController and abortSignal", async () => {
320
- let capturedCtx: AgentFactoryContext | null = null;
321
-
322
- let config: BuiltInAgentFactoryConfig;
323
- switch (type) {
324
- case "aisdk":
325
- config = {
326
- type: "aisdk",
327
- factory: (ctx: AgentFactoryContext) => {
328
- capturedCtx = ctx;
329
- return {
330
- fullStream: (async function* () {
331
- yield { type: "finish", finishReason: "stop" };
332
- })(),
333
- };
334
- },
335
- };
336
- break;
337
- case "tanstack":
338
- config = {
339
- type: "tanstack",
340
- factory: (ctx: AgentFactoryContext) => {
341
- capturedCtx = ctx;
342
- return (async function* () {
343
- // empty
344
- })();
345
- },
346
- };
347
- break;
348
- case "custom":
349
- config = {
350
- type: "custom",
351
- factory: (ctx: AgentFactoryContext) => {
352
- capturedCtx = ctx;
353
- return (async function* () {
354
- // empty
355
- })();
356
- },
357
- };
358
- break;
359
- }
360
-
361
- const agent = new BuiltInAgent(config);
362
- const input = createDefaultInput();
363
- await collectEvents(agent.run(input));
364
-
365
- expect(capturedCtx!.abortController).toBeInstanceOf(AbortController);
366
- expect(capturedCtx!.abortSignal).toBe(
367
- capturedCtx!.abortController.signal,
368
- );
369
- });
370
- });
371
-
372
- // -------------------------------------------------------------------------
373
- // clone()
374
- // -------------------------------------------------------------------------
375
- describe("clone()", () => {
376
- it("returns a new Agent instance (not the same reference)", () => {
377
- const agent = createAgent(type, minimalStreamData(type));
378
- const cloned = agent.clone();
379
-
380
- expect(cloned).toBeInstanceOf(BuiltInAgent);
381
- expect(cloned).not.toBe(agent);
382
- });
383
-
384
- it("produces correct lifecycle events from a cloned agent", async () => {
385
- const agent = createAgent(type, minimalStreamData(type));
386
- const cloned = agent.clone();
387
- const input = createDefaultInput({
388
- threadId: "clone-t",
389
- runId: "clone-r",
390
- });
391
-
392
- const events = await collectEvents(cloned.run(input));
393
-
394
- expectLifecycleWrapped(events, "clone-t", "clone-r");
395
- });
396
- });
397
- });
398
-
399
- // ---------------------------------------------------------------------------
400
- // Type Discrimination (NOT parameterized)
401
- // ---------------------------------------------------------------------------
402
-
403
- describe("Agent type discrimination", () => {
404
- it('"aisdk" routes to AI SDK converter and produces text content', async () => {
405
- const agent = createAgent("aisdk", [
406
- textDelta("hello from aisdk"),
407
- finish(),
408
- ]);
409
- const input = createDefaultInput();
410
- const events = await collectEvents(agent.run(input));
411
-
412
- const textEvents = events.filter(
413
- (e) => e.type === EventType.TEXT_MESSAGE_CHUNK,
414
- );
415
- expect(textEvents.length).toBe(1);
416
- expect(eventField<string>(textEvents[0], "delta")).toBe("hello from aisdk");
417
- });
418
-
419
- it('"tanstack" routes to TanStack converter and produces text content', async () => {
420
- const agent = createAgent("tanstack", [
421
- tanstackTextChunk("hello from tanstack"),
422
- ]);
423
- const input = createDefaultInput();
424
- const events = await collectEvents(agent.run(input));
425
-
426
- const textEvents = events.filter(
427
- (e) => e.type === EventType.TEXT_MESSAGE_CHUNK,
428
- );
429
- expect(textEvents.length).toBe(1);
430
- expect(eventField<string>(textEvents[0], "delta")).toBe(
431
- "hello from tanstack",
432
- );
433
- });
434
-
435
- it('"custom" forwards events directly without conversion', async () => {
436
- const customEvent: BaseEvent = {
437
- type: EventType.TEXT_MESSAGE_CHUNK,
438
- role: "assistant",
439
- delta: "hello from custom",
440
- } as BaseEvent;
441
-
442
- const agent = createAgent("custom", [customEvent]);
443
- const input = createDefaultInput();
444
- const events = await collectEvents(agent.run(input));
445
-
446
- const textEvents = events.filter(
447
- (e) => e.type === EventType.TEXT_MESSAGE_CHUNK,
448
- );
449
- expect(textEvents.length).toBe(1);
450
- expect(eventField<string>(textEvents[0], "delta")).toBe(
451
- "hello from custom",
452
- );
453
- });
454
- });
455
-
456
- // ---------------------------------------------------------------------------
457
- // Async Factory (Promise-returning)
458
- // ---------------------------------------------------------------------------
459
-
460
- describe("Async factory (Promise-returning)", () => {
461
- it("aisdk: async factory resolves and streams correctly", async () => {
462
- const agent = new BuiltInAgent({
463
- type: "aisdk",
464
- factory: async () => {
465
- // Simulate async setup (e.g., fetching API key)
466
- await new Promise((r) => setTimeout(r, 5));
467
- return {
468
- fullStream: (async function* () {
469
- yield { type: "text-delta", text: "async-aisdk" };
470
- yield { type: "finish", finishReason: "stop" };
471
- })(),
472
- };
473
- },
474
- });
475
- const input = createDefaultInput();
476
- const events = await collectEvents(agent.run(input));
477
-
478
- expectLifecycleWrapped(events);
479
- const textEvents = events.filter(
480
- (e) => e.type === EventType.TEXT_MESSAGE_CHUNK,
481
- );
482
- expect(textEvents).toHaveLength(1);
483
- expect(eventField<string>(textEvents[0], "delta")).toBe("async-aisdk");
484
- });
485
-
486
- it("tanstack: async factory resolves and streams correctly", async () => {
487
- const agent = new BuiltInAgent({
488
- type: "tanstack",
489
- factory: async () => {
490
- await new Promise((r) => setTimeout(r, 5));
491
- return (async function* () {
492
- yield { type: "TEXT_MESSAGE_CONTENT", delta: "async-tanstack" };
493
- })();
494
- },
495
- });
496
- const input = createDefaultInput();
497
- const events = await collectEvents(agent.run(input));
498
-
499
- expectLifecycleWrapped(events);
500
- const textEvents = events.filter(
501
- (e) => e.type === EventType.TEXT_MESSAGE_CHUNK,
502
- );
503
- expect(textEvents).toHaveLength(1);
504
- expect(eventField<string>(textEvents[0], "delta")).toBe("async-tanstack");
505
- });
506
-
507
- it("custom: async factory resolves and streams correctly", async () => {
508
- const agent = new BuiltInAgent({
509
- type: "custom",
510
- factory: async () => {
511
- await new Promise((r) => setTimeout(r, 5));
512
- return (async function* () {
513
- yield {
514
- type: EventType.TEXT_MESSAGE_CHUNK,
515
- role: "assistant",
516
- delta: "async-custom",
517
- } as BaseEvent;
518
- })();
519
- },
520
- });
521
- const input = createDefaultInput();
522
- const events = await collectEvents(agent.run(input));
523
-
524
- expectLifecycleWrapped(events);
525
- const textEvents = events.filter(
526
- (e) => e.type === EventType.TEXT_MESSAGE_CHUNK,
527
- );
528
- expect(textEvents).toHaveLength(1);
529
- expect(eventField<string>(textEvents[0], "delta")).toBe("async-custom");
530
- });
531
- });
532
-
533
- // ---------------------------------------------------------------------------
534
- // RUN_ERROR includes threadId and runId
535
- // ---------------------------------------------------------------------------
536
-
537
- describe("RUN_ERROR correlation fields", () => {
538
- it("RUN_ERROR includes threadId and runId for run correlation", async () => {
539
- const agent = new BuiltInAgent({
540
- type: "aisdk",
541
- factory: () => {
542
- throw new Error("test-error");
543
- },
544
- });
545
- const input = createDefaultInput({
546
- threadId: "err-thread",
547
- runId: "err-run",
548
- });
549
- const { events, errored } = await collectEventsIncludingErrors(
550
- agent.run(input),
551
- );
552
-
553
- expect(errored).toBe(true);
554
- const errorEvents = events.filter((e) => e.type === EventType.RUN_ERROR);
555
- expect(errorEvents).toHaveLength(1);
556
- expect(eventField<string>(errorEvents[0], "threadId")).toBe("err-thread");
557
- expect(eventField<string>(errorEvents[0], "runId")).toBe("err-run");
558
- });
559
- });
560
-
561
- // ---------------------------------------------------------------------------
562
- // Concurrent run guard
563
- // ---------------------------------------------------------------------------
564
-
565
- describe("Concurrent run guard", () => {
566
- it("throws when run() is called while another run is in progress", async () => {
567
- let resolveFactory: () => void;
568
- const factoryBlocked = new Promise<void>((r) => (resolveFactory = r));
569
-
570
- const agent = new BuiltInAgent({
571
- type: "custom",
572
- factory: async function* ({ abortSignal }) {
573
- // Block until resolved externally
574
- await new Promise<void>((r) => {
575
- if (abortSignal.aborted) return r();
576
- abortSignal.addEventListener("abort", () => r(), { once: true });
577
- factoryBlocked.then(() => r());
578
- });
579
- },
580
- });
581
- const input = createDefaultInput();
582
-
583
- // Start first run — abortController is now set synchronously in run()
584
- const sub = agent.run(input).subscribe({ next: () => {} });
585
-
586
- // Second run should throw immediately (no timing dependency)
587
- expect(() => agent.run(input)).toThrow("Agent is already running");
588
-
589
- // Cleanup
590
- resolveFactory!();
591
- sub.unsubscribe();
592
- });
593
- });
@@ -1,116 +0,0 @@
1
- import { describe, it, expect, vi, beforeEach, afterEach } from "vitest";
2
- import { BuiltInAgent } from "../index";
3
- import { EventType, type RunAgentInput } from "@ag-ui/client";
4
- import { streamText } from "ai";
5
- import {
6
- mockStreamTextResponse,
7
- textDelta,
8
- finish,
9
- collectEvents,
10
- } from "./test-helpers";
11
-
12
- // Mock the ai module
13
- vi.mock("ai", () => ({
14
- streamText: vi.fn(),
15
- tool: vi.fn((config) => config),
16
- stepCountIs: vi.fn((count: number) => ({ type: "stepCount", count })),
17
- }));
18
-
19
- // Mock SDK providers (not used directly, but resolveModel imports them)
20
- vi.mock("@ai-sdk/openai", () => ({
21
- createOpenAI: vi.fn(() => (modelId: string) => ({
22
- specificationVersion: "v3",
23
- modelId,
24
- provider: "openai",
25
- })),
26
- }));
27
-
28
- vi.mock("@ai-sdk/anthropic", () => ({
29
- createAnthropic: vi.fn(() => (modelId: string) => ({
30
- specificationVersion: "v3",
31
- modelId,
32
- provider: "anthropic",
33
- })),
34
- }));
35
-
36
- vi.mock("@ai-sdk/google", () => ({
37
- createGoogleGenerativeAI: vi.fn(() => (modelId: string) => ({
38
- specificationVersion: "v3",
39
- modelId,
40
- provider: "google",
41
- })),
42
- }));
43
-
44
- describe("AI SDK v6 Compatibility", () => {
45
- const originalEnv = process.env;
46
-
47
- beforeEach(() => {
48
- vi.clearAllMocks();
49
- process.env = { ...originalEnv };
50
- process.env.OPENAI_API_KEY = "test-key";
51
- });
52
-
53
- afterEach(() => {
54
- process.env = originalEnv;
55
- });
56
-
57
- it("should accept a LanguageModelV3 instance (specificationVersion 'v3')", async () => {
58
- // Simulate what @ai-sdk/openai@^3 (AI SDK v6) returns:
59
- // a model object with specificationVersion: "v3"
60
- const v3Model = {
61
- specificationVersion: "v3" as const,
62
- modelId: "gpt-4o-mini",
63
- provider: "openai",
64
- supportedUrls: {},
65
- doGenerate: vi.fn(),
66
- doStream: vi.fn(),
67
- };
68
-
69
- // After upgrading to ai@^6, LanguageModel = string | LanguageModelV2 | LanguageModelV3.
70
- // No 'as any' cast needed — the type accepts V3 models natively.
71
- const agent = new BuiltInAgent({
72
- model: v3Model,
73
- });
74
-
75
- vi.mocked(streamText).mockReturnValue(
76
- mockStreamTextResponse([
77
- textDelta("Hello from V3 model"),
78
- finish(),
79
- ]) as any,
80
- );
81
-
82
- const input: RunAgentInput = {
83
- threadId: "thread-v3",
84
- runId: "run-v3",
85
- messages: [{ id: "1", role: "user", content: "Hi" }],
86
- tools: [],
87
- context: [],
88
- state: {},
89
- };
90
-
91
- const events = await collectEvents(agent["run"](input));
92
-
93
- // Verify the model was passed through to streamText
94
- const callArgs = vi.mocked(streamText).mock.calls[0][0];
95
- expect(callArgs.model).toBe(v3Model);
96
-
97
- // Verify normal event emission still works
98
- expect(events[0]).toMatchObject({
99
- type: EventType.RUN_STARTED,
100
- threadId: "thread-v3",
101
- runId: "run-v3",
102
- });
103
-
104
- const textEvents = events.filter(
105
- (e: any) => e.type === EventType.TEXT_MESSAGE_CHUNK,
106
- );
107
- expect(textEvents).toHaveLength(1);
108
- expect(textEvents[0]).toMatchObject({
109
- delta: "Hello from V3 model",
110
- });
111
-
112
- expect(events[events.length - 1]).toMatchObject({
113
- type: EventType.RUN_FINISHED,
114
- });
115
- });
116
- });