@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,1030 +0,0 @@
1
- import { describe, it, expect, beforeEach } from "vitest";
2
- import { InMemoryAgentRunner } from "../runner/in-memory";
3
- import {
4
- AbstractAgent,
5
- BaseEvent,
6
- EventType,
7
- RunAgentInput,
8
- } from "@ag-ui/client";
9
- import { firstValueFrom } from "rxjs";
10
- import { toArray } from "rxjs/operators";
11
-
12
- const stripTerminalEvents = (events: BaseEvent[]) =>
13
- events.filter(
14
- (event) =>
15
- event.type !== EventType.RUN_FINISHED &&
16
- event.type !== EventType.RUN_ERROR,
17
- );
18
-
19
- // Mock agent implementations for testing
20
- class MockAgent extends AbstractAgent {
21
- private events: BaseEvent[];
22
- private delay: number;
23
-
24
- constructor(events: BaseEvent[] = [], delay: number = 0) {
25
- super();
26
- this.events = events;
27
- this.delay = delay;
28
- }
29
-
30
- async runAgent(
31
- input: RunAgentInput,
32
- options: { onEvent: (event: { event: BaseEvent }) => void },
33
- ): Promise<void> {
34
- for (const event of this.events) {
35
- if (this.delay > 0) {
36
- await new Promise((resolve) => setTimeout(resolve, this.delay));
37
- }
38
- options.onEvent({ event });
39
- }
40
- }
41
-
42
- clone(): AbstractAgent {
43
- return new MockAgent(this.events, this.delay);
44
- }
45
- }
46
-
47
- class DelayedEventAgent extends AbstractAgent {
48
- private eventCount: number;
49
- private eventDelay: number;
50
- private prefix: string;
51
-
52
- constructor(
53
- eventCount: number = 5,
54
- eventDelay: number = 10,
55
- prefix: string = "delayed",
56
- ) {
57
- super();
58
- this.eventCount = eventCount;
59
- this.eventDelay = eventDelay;
60
- this.prefix = prefix;
61
- }
62
-
63
- async runAgent(
64
- input: RunAgentInput,
65
- options: { onEvent: (event: { event: BaseEvent }) => void },
66
- ): Promise<void> {
67
- for (let i = 0; i < this.eventCount; i++) {
68
- await new Promise((resolve) => setTimeout(resolve, this.eventDelay));
69
- options.onEvent({
70
- event: {
71
- type: "message",
72
- id: `${this.prefix}-${i}`,
73
- timestamp: new Date().toISOString(),
74
- data: { index: i, prefix: this.prefix },
75
- } as BaseEvent,
76
- });
77
- }
78
- }
79
-
80
- clone(): AbstractAgent {
81
- return new DelayedEventAgent(this.eventCount, this.eventDelay, this.prefix);
82
- }
83
- }
84
-
85
- class ErrorThrowingAgent extends AbstractAgent {
86
- private throwAfterEvents: number;
87
- private errorMessage: string;
88
-
89
- constructor(
90
- throwAfterEvents: number = 2,
91
- errorMessage: string = "Test error",
92
- ) {
93
- super();
94
- this.throwAfterEvents = throwAfterEvents;
95
- this.errorMessage = errorMessage;
96
- }
97
-
98
- async runAgent(
99
- input: RunAgentInput,
100
- options: { onEvent: (event: { event: BaseEvent }) => void },
101
- ): Promise<void> {
102
- for (let i = 0; i < this.throwAfterEvents; i++) {
103
- options.onEvent({
104
- event: {
105
- type: "message",
106
- id: `error-agent-${i}`,
107
- timestamp: new Date().toISOString(),
108
- data: { index: i },
109
- } as BaseEvent,
110
- });
111
- }
112
- throw new Error(this.errorMessage);
113
- }
114
-
115
- clone(): AbstractAgent {
116
- return new ErrorThrowingAgent(this.throwAfterEvents, this.errorMessage);
117
- }
118
- }
119
-
120
- class StoppableAgent extends AbstractAgent {
121
- private shouldStop = false;
122
- private eventDelay: number;
123
-
124
- constructor(eventDelay = 5) {
125
- super();
126
- this.eventDelay = eventDelay;
127
- }
128
-
129
- async runAgent(
130
- input: RunAgentInput,
131
- options: { onEvent: (event: { event: BaseEvent }) => void },
132
- ): Promise<void> {
133
- this.shouldStop = false;
134
- let counter = 0;
135
-
136
- while (!this.shouldStop && counter < 10_000) {
137
- await new Promise((resolve) => setTimeout(resolve, this.eventDelay));
138
- const event: BaseEvent = {
139
- type: "message",
140
- id: `stoppable-${counter}`,
141
- timestamp: new Date().toISOString(),
142
- data: { counter },
143
- } as BaseEvent;
144
- options.onEvent({ event });
145
- counter += 1;
146
- }
147
- }
148
-
149
- abortRun(): void {
150
- this.shouldStop = true;
151
- }
152
-
153
- clone(): AbstractAgent {
154
- return new StoppableAgent(this.eventDelay);
155
- }
156
- }
157
-
158
- class OpenEventsAgent extends AbstractAgent {
159
- private shouldStop = false;
160
-
161
- async runAgent(
162
- input: RunAgentInput,
163
- options: { onEvent: (event: { event: BaseEvent }) => void },
164
- ): Promise<void> {
165
- this.shouldStop = false;
166
- const messageId = "open-message";
167
- const toolCallId = "open-tool";
168
-
169
- options.onEvent({
170
- event: {
171
- type: EventType.TEXT_MESSAGE_START,
172
- messageId,
173
- role: "assistant",
174
- } as BaseEvent,
175
- });
176
-
177
- options.onEvent({
178
- event: {
179
- type: EventType.TEXT_MESSAGE_CONTENT,
180
- messageId,
181
- delta: "Partial content",
182
- } as BaseEvent,
183
- });
184
-
185
- options.onEvent({
186
- event: {
187
- type: EventType.TOOL_CALL_START,
188
- toolCallId,
189
- toolCallName: "testTool",
190
- parentMessageId: messageId,
191
- } as BaseEvent,
192
- });
193
-
194
- while (!this.shouldStop) {
195
- await new Promise((resolve) => setTimeout(resolve, 5));
196
- }
197
- }
198
-
199
- abortRun(): void {
200
- this.shouldStop = true;
201
- }
202
-
203
- clone(): AbstractAgent {
204
- return new OpenEventsAgent();
205
- }
206
- }
207
-
208
- class MultiEventAgent extends AbstractAgent {
209
- private runId: string;
210
-
211
- constructor(runId: string) {
212
- super();
213
- this.runId = runId;
214
- }
215
-
216
- async runAgent(
217
- input: RunAgentInput,
218
- options: { onEvent: (event: { event: BaseEvent }) => void },
219
- ): Promise<void> {
220
- // Emit different types of events
221
- const eventTypes = ["start", "message", "tool_call", "tool_result", "end"];
222
-
223
- for (const eventType of eventTypes) {
224
- options.onEvent({
225
- event: {
226
- type: eventType,
227
- id: `${this.runId}-${eventType}`,
228
- timestamp: new Date().toISOString(),
229
- data: {
230
- runId: this.runId,
231
- eventType,
232
- metadata: { source: "MultiEventAgent" },
233
- },
234
- } as BaseEvent,
235
- });
236
- }
237
- }
238
-
239
- clone(): AbstractAgent {
240
- return new MultiEventAgent(this.runId);
241
- }
242
- }
243
-
244
- describe("InMemoryAgentRunner", () => {
245
- let runner: InMemoryAgentRunner;
246
-
247
- beforeEach(() => {
248
- runner = new InMemoryAgentRunner();
249
- });
250
-
251
- describe("Basic Functionality", () => {
252
- it("should run a single agent and collect all events", async () => {
253
- const threadId = "test-thread-1";
254
- const events: BaseEvent[] = [
255
- {
256
- type: "start",
257
- id: "1",
258
- timestamp: new Date().toISOString(),
259
- data: {},
260
- } as BaseEvent,
261
- {
262
- type: "message",
263
- id: "2",
264
- timestamp: new Date().toISOString(),
265
- data: { text: "Hello" },
266
- } as BaseEvent,
267
- {
268
- type: "end",
269
- id: "3",
270
- timestamp: new Date().toISOString(),
271
- data: {},
272
- } as BaseEvent,
273
- ];
274
-
275
- const agent = new MockAgent(events);
276
- const input: RunAgentInput = {
277
- messages: [],
278
- state: {},
279
- threadId,
280
- runId: "run-1",
281
- };
282
-
283
- const runObservable = runner.run({ threadId, agent, input });
284
- const collectedEvents = await firstValueFrom(
285
- runObservable.pipe(toArray()),
286
- );
287
-
288
- const agentEvents = stripTerminalEvents(collectedEvents);
289
- expect(agentEvents).toEqual(events);
290
- });
291
-
292
- it("should allow connecting after run completes and receive all past events", async () => {
293
- const threadId = "test-thread-3";
294
- const events: BaseEvent[] = [
295
- {
296
- type: "message",
297
- id: "past-1",
298
- timestamp: new Date().toISOString(),
299
- data: {},
300
- } as BaseEvent,
301
- {
302
- type: "message",
303
- id: "past-2",
304
- timestamp: new Date().toISOString(),
305
- data: {},
306
- } as BaseEvent,
307
- ];
308
-
309
- const agent = new MockAgent(events);
310
- const input: RunAgentInput = {
311
- messages: [],
312
- state: {},
313
- threadId,
314
- runId: "run-3",
315
- };
316
-
317
- // Run and wait for completion
318
- const runObservable = runner.run({ threadId, agent, input });
319
- await firstValueFrom(runObservable.pipe(toArray()));
320
-
321
- // Connect after completion
322
- const connectObservable = runner.connect({ threadId });
323
- const collectedEvents = await firstValueFrom(
324
- connectObservable.pipe(toArray()),
325
- );
326
-
327
- const storedAgentEvents = stripTerminalEvents(collectedEvents);
328
- expect(storedAgentEvents).toEqual(events);
329
- });
330
- });
331
-
332
- describe("Multiple Runs", () => {
333
- it("should accumulate events from multiple sequential runs on same thread", async () => {
334
- const threadId = "test-thread-multi-1";
335
-
336
- // First run
337
- const agent1 = new MultiEventAgent("run-1");
338
- const input1: RunAgentInput = {
339
- messages: [],
340
- state: {},
341
- threadId,
342
- runId: "run-1",
343
- };
344
-
345
- const run1 = runner.run({ threadId, agent: agent1, input: input1 });
346
- await firstValueFrom(run1.pipe(toArray()));
347
-
348
- // Second run
349
- const agent2 = new MultiEventAgent("run-2");
350
- const input2: RunAgentInput = {
351
- messages: [],
352
- state: {},
353
- threadId,
354
- runId: "run-2",
355
- };
356
-
357
- const run2 = runner.run({ threadId, agent: agent2, input: input2 });
358
- await firstValueFrom(run2.pipe(toArray()));
359
-
360
- // Third run
361
- const agent3 = new MultiEventAgent("run-3");
362
- const input3: RunAgentInput = {
363
- messages: [],
364
- state: {},
365
- threadId,
366
- runId: "run-3",
367
- };
368
-
369
- const run3 = runner.run({ threadId, agent: agent3, input: input3 });
370
- await firstValueFrom(run3.pipe(toArray()));
371
-
372
- // Connect and verify all events
373
- const connectObservable = runner.connect({ threadId });
374
- const allEvents = await firstValueFrom(connectObservable.pipe(toArray()));
375
-
376
- const agentEvents = stripTerminalEvents(allEvents);
377
- expect(agentEvents).toHaveLength(15); // 5 events per run × 3 runs
378
-
379
- // Verify events from all runs are present
380
- const run1Events = agentEvents.filter((e) => e.id?.startsWith("run-1"));
381
- const run2Events = agentEvents.filter((e) => e.id?.startsWith("run-2"));
382
- const run3Events = agentEvents.filter((e) => e.id?.startsWith("run-3"));
383
-
384
- expect(run1Events).toHaveLength(5);
385
- expect(run2Events).toHaveLength(5);
386
- expect(run3Events).toHaveLength(5);
387
-
388
- // Verify order preservation
389
- const runOrder = agentEvents.map(
390
- (e) => e.id?.split("-")[0] + "-" + e.id?.split("-")[1],
391
- );
392
- expect(runOrder.slice(0, 5).every((id) => id?.startsWith("run-1"))).toBe(
393
- true,
394
- );
395
- expect(runOrder.slice(5, 10).every((id) => id?.startsWith("run-2"))).toBe(
396
- true,
397
- );
398
- expect(
399
- runOrder.slice(10, 15).every((id) => id?.startsWith("run-3")),
400
- ).toBe(true);
401
- });
402
-
403
- it("should handle connect during multiple runs", async () => {
404
- const threadId = "test-thread-multi-2";
405
-
406
- // Start first run
407
- const agent1 = new DelayedEventAgent(5, 20, "first");
408
- const input1: RunAgentInput = {
409
- messages: [],
410
- state: {},
411
- threadId,
412
- runId: "run-1",
413
- };
414
-
415
- const run1Observable = runner.run({
416
- threadId,
417
- agent: agent1,
418
- input: input1,
419
- });
420
-
421
- // Wait a bit to ensure first run is in progress
422
- await new Promise((resolve) => setTimeout(resolve, 50));
423
-
424
- // Connect during first run
425
- const connectObservable = runner.connect({ threadId });
426
- const eventCollector = firstValueFrom(connectObservable.pipe(toArray()));
427
-
428
- // Wait for first run to complete
429
- await firstValueFrom(run1Observable.pipe(toArray()));
430
-
431
- // Collect all events from the connect during first run
432
- const allEvents = await eventCollector;
433
-
434
- // Connect only receives events from the first run since it completes
435
- const firstRunAgentEvents = stripTerminalEvents(allEvents);
436
- expect(firstRunAgentEvents).toHaveLength(5);
437
- const firstRunEvents = firstRunAgentEvents.filter((e) =>
438
- e.id?.startsWith("first"),
439
- );
440
-
441
- expect(firstRunEvents).toHaveLength(5);
442
-
443
- // Start second run
444
- const agent2 = new DelayedEventAgent(3, 10, "second");
445
- const input2: RunAgentInput = {
446
- messages: [],
447
- state: {},
448
- threadId,
449
- runId: "run-2",
450
- };
451
-
452
- const run2Observable = runner.run({
453
- threadId,
454
- agent: agent2,
455
- input: input2,
456
- });
457
- await firstValueFrom(run2Observable.pipe(toArray()));
458
-
459
- // Connect after both runs to verify all events are accumulated
460
- const allEventsAfter = await firstValueFrom(
461
- runner.connect({ threadId }).pipe(toArray()),
462
- );
463
- expect(stripTerminalEvents(allEventsAfter)).toHaveLength(8); // 5 from first + 3 from second
464
- });
465
-
466
- it("should preserve event order across different agent types", async () => {
467
- const threadId = "test-thread-multi-3";
468
-
469
- // Run different types of agents
470
- const agents = [
471
- new MockAgent([
472
- {
473
- type: "mock",
474
- id: "mock-1",
475
- timestamp: new Date().toISOString(),
476
- data: {},
477
- } as BaseEvent,
478
- {
479
- type: "mock",
480
- id: "mock-2",
481
- timestamp: new Date().toISOString(),
482
- data: {},
483
- } as BaseEvent,
484
- ]),
485
- new MultiEventAgent("multi"),
486
- new DelayedEventAgent(2, 0, "delayed"),
487
- ];
488
-
489
- for (let i = 0; i < agents.length; i++) {
490
- const input: RunAgentInput = {
491
- messages: [],
492
- state: {},
493
- threadId,
494
- runId: `run-${i}`,
495
- };
496
-
497
- const run = runner.run({ threadId, agent: agents[i], input });
498
- await firstValueFrom(run.pipe(toArray()));
499
- }
500
-
501
- // Verify all events are preserved
502
- const connectObservable = runner.connect({ threadId });
503
- const allEvents = await firstValueFrom(connectObservable.pipe(toArray()));
504
-
505
- const agentEvents = stripTerminalEvents(allEvents);
506
- expect(agentEvents).toHaveLength(9); // 2 + 5 + 2
507
-
508
- // Verify event groups are in order
509
- expect(agentEvents[0].id).toBe("mock-1");
510
- expect(agentEvents[1].id).toBe("mock-2");
511
- expect(agentEvents[2].id).toContain("multi");
512
- expect(agentEvents[7].id).toContain("delayed");
513
- });
514
- });
515
-
516
- describe("Concurrent Subscribers", () => {
517
- it("should provide same events to multiple concurrent connect calls", async () => {
518
- const threadId = "test-thread-concurrent-1";
519
- const agent = new MultiEventAgent("concurrent");
520
- const input: RunAgentInput = {
521
- messages: [],
522
- state: {},
523
- threadId,
524
- runId: "run-concurrent",
525
- };
526
-
527
- // Run agent
528
- const runObservable = runner.run({ threadId, agent, input });
529
- await firstValueFrom(runObservable.pipe(toArray()));
530
-
531
- // Multiple concurrent connects
532
- const connect1 = runner.connect({ threadId });
533
- const connect2 = runner.connect({ threadId });
534
- const connect3 = runner.connect({ threadId });
535
-
536
- const [events1, events2, events3] = await Promise.all([
537
- firstValueFrom(connect1.pipe(toArray())),
538
- firstValueFrom(connect2.pipe(toArray())),
539
- firstValueFrom(connect3.pipe(toArray())),
540
- ]);
541
-
542
- // All should receive same events including RUN_FINISHED
543
- const agentEvents1 = stripTerminalEvents(events1);
544
- const agentEvents2 = stripTerminalEvents(events2);
545
- const agentEvents3 = stripTerminalEvents(events3);
546
- expect(agentEvents1).toHaveLength(5);
547
- expect(agentEvents2).toHaveLength(5);
548
- expect(agentEvents3).toHaveLength(5);
549
- expect(events1).toEqual(events2);
550
- expect(events2).toEqual(events3);
551
- });
552
-
553
- it("should handle late subscribers during active run", async () => {
554
- const threadId = "test-thread-concurrent-2";
555
- const agent = new DelayedEventAgent(10, 20, "late-sub");
556
- const input: RunAgentInput = {
557
- messages: [],
558
- state: {},
559
- threadId,
560
- runId: "run-late",
561
- };
562
-
563
- // Start run
564
- runner.run({ threadId, agent, input });
565
-
566
- // Connect at different times during the run
567
- await new Promise((resolve) => setTimeout(resolve, 50)); // After ~2 events
568
- const connect1 = runner.connect({ threadId });
569
-
570
- await new Promise((resolve) => setTimeout(resolve, 60)); // After ~5 events
571
- const connect2 = runner.connect({ threadId });
572
-
573
- await new Promise((resolve) => setTimeout(resolve, 80)); // After ~9 events
574
- const connect3 = runner.connect({ threadId });
575
-
576
- const [events1, events2, events3] = await Promise.all([
577
- firstValueFrom(connect1.pipe(toArray())),
578
- firstValueFrom(connect2.pipe(toArray())),
579
- firstValueFrom(connect3.pipe(toArray())),
580
- ]);
581
-
582
- // All subscribers should eventually receive all events plus RUN_FINISHED
583
- const agentEvents1 = stripTerminalEvents(events1);
584
- const agentEvents2 = stripTerminalEvents(events2);
585
- const agentEvents3 = stripTerminalEvents(events3);
586
- expect(agentEvents1).toHaveLength(10);
587
- expect(agentEvents2).toHaveLength(10);
588
- expect(agentEvents3).toHaveLength(10);
589
-
590
- // Verify they all have the same events
591
- expect(events1.map((e) => e.id)).toEqual(events2.map((e) => e.id));
592
- expect(events2.map((e) => e.id)).toEqual(events3.map((e) => e.id));
593
- });
594
- });
595
-
596
- describe("Error Handling", () => {
597
- it("should throw error when thread is already running", async () => {
598
- const threadId = "test-thread-error-1";
599
- const agent = new DelayedEventAgent(5, 50, "blocking");
600
- const input: RunAgentInput = {
601
- messages: [],
602
- state: {},
603
- threadId,
604
- runId: "run-1",
605
- };
606
-
607
- // Start first run
608
- runner.run({ threadId, agent, input });
609
-
610
- // Try to start another run on same thread immediately
611
- expect(() => {
612
- runner.run({ threadId, agent, input });
613
- }).toThrow("Thread already running");
614
- });
615
-
616
- it("should handle agent errors gracefully", async () => {
617
- const threadId = "test-thread-error-2";
618
- const agent = new ErrorThrowingAgent(3, "Agent crashed!");
619
- const input: RunAgentInput = {
620
- messages: [],
621
- state: {},
622
- threadId,
623
- runId: "run-error-1",
624
- };
625
-
626
- const runObservable = runner.run({ threadId, agent, input });
627
- const events = await firstValueFrom(runObservable.pipe(toArray()));
628
-
629
- // Should still receive events emitted before error
630
- expect(events.at(-1)?.type).toBe(EventType.RUN_ERROR);
631
- const preErrorEvents = events.slice(0, -1);
632
- expect(preErrorEvents).toHaveLength(3);
633
- expect(preErrorEvents.every((e) => e.id?.startsWith("error-agent"))).toBe(
634
- true,
635
- );
636
-
637
- // Should be able to run again after error
638
- const agent2 = new MockAgent([
639
- {
640
- type: "recovery",
641
- id: "recovery-1",
642
- timestamp: new Date().toISOString(),
643
- data: {},
644
- } as BaseEvent,
645
- ]);
646
-
647
- const input2: RunAgentInput = {
648
- messages: [],
649
- state: {},
650
- threadId,
651
- runId: "run-error-2",
652
- };
653
-
654
- const run2 = runner.run({ threadId, agent: agent2, input: input2 });
655
- const events2 = await firstValueFrom(run2.pipe(toArray()));
656
-
657
- const recoveryEvents = stripTerminalEvents(events2);
658
- expect(recoveryEvents).toHaveLength(1); // Only events from current run
659
- expect(recoveryEvents[0].id).toBe("recovery-1");
660
-
661
- // Connect should have all events including from errored run
662
- const allEvents = await firstValueFrom(
663
- runner.connect({ threadId }).pipe(toArray()),
664
- );
665
- expect(
666
- allEvents.filter((event) => event.type === EventType.RUN_ERROR).length,
667
- ).toBeGreaterThanOrEqual(1);
668
- const storedAgentEvents = stripTerminalEvents(allEvents);
669
- expect(storedAgentEvents).toHaveLength(4); // 3 from error run + 1 from recovery
670
- });
671
-
672
- it("should properly set isRunning to false after agent error", async () => {
673
- const threadId = "test-thread-error-3";
674
- const agent = new ErrorThrowingAgent(1, "Quick fail");
675
- const input: RunAgentInput = {
676
- messages: [],
677
- state: {},
678
- threadId,
679
- runId: "run-fail",
680
- };
681
-
682
- // Run and wait for completion (even with error)
683
- const runObservable = runner.run({ threadId, agent, input });
684
- await firstValueFrom(runObservable.pipe(toArray()));
685
-
686
- // Verify thread is not running
687
- const isRunning = await runner.isRunning({ threadId });
688
- expect(isRunning).toBe(false);
689
-
690
- // Should be able to run again
691
- const agent2 = new MockAgent([
692
- {
693
- type: "test",
694
- id: "after-error",
695
- timestamp: new Date().toISOString(),
696
- data: {},
697
- } as BaseEvent,
698
- ]);
699
-
700
- const input2: RunAgentInput = {
701
- messages: [],
702
- state: {},
703
- threadId,
704
- runId: "run-fail-2",
705
- };
706
-
707
- expect(() => {
708
- runner.run({ threadId, agent: agent2, input: input2 });
709
- }).not.toThrow();
710
- });
711
- });
712
-
713
- describe("Edge Cases", () => {
714
- it("should return EMPTY observable when connecting to non-existent thread", async () => {
715
- const connectObservable = runner.connect({
716
- threadId: "non-existent-thread",
717
- });
718
-
719
- // EMPTY completes immediately with no values
720
- let completed = false;
721
- let eventCount = 0;
722
-
723
- await new Promise<void>((resolve) => {
724
- connectObservable.subscribe({
725
- next: () => eventCount++,
726
- complete: () => {
727
- completed = true;
728
- resolve();
729
- },
730
- });
731
- });
732
-
733
- expect(completed).toBe(true);
734
- expect(eventCount).toBe(0);
735
- });
736
-
737
- it("should handle very large number of events", async () => {
738
- const threadId = "test-thread-large";
739
- const eventCount = 1000;
740
- const events: BaseEvent[] = [];
741
-
742
- for (let i = 0; i < eventCount; i++) {
743
- events.push({
744
- type: "bulk",
745
- id: `bulk-${i}`,
746
- timestamp: new Date().toISOString(),
747
- data: { index: i, payload: "x".repeat(100) },
748
- } as BaseEvent);
749
- }
750
-
751
- const agent = new MockAgent(events);
752
- const input: RunAgentInput = {
753
- messages: [],
754
- state: {},
755
- threadId,
756
- runId: "run-large",
757
- };
758
-
759
- // Run with large event set
760
- const runObservable = runner.run({ threadId, agent, input });
761
- await firstValueFrom(runObservable.pipe(toArray()));
762
-
763
- // Connect and verify all events are preserved
764
- const connectObservable = runner.connect({ threadId });
765
- const collectedEvents = await firstValueFrom(
766
- connectObservable.pipe(toArray()),
767
- );
768
-
769
- const bulkEvents = stripTerminalEvents(collectedEvents);
770
- expect(bulkEvents).toHaveLength(eventCount);
771
- expect(bulkEvents[0].id).toBe("bulk-0");
772
- expect(bulkEvents[eventCount - 1].id).toBe(`bulk-${eventCount - 1}`);
773
- });
774
-
775
- it("should return false for isRunning on non-existent thread", async () => {
776
- const isRunning = await runner.isRunning({ threadId: "non-existent" });
777
- expect(isRunning).toBe(false);
778
- });
779
-
780
- it("should properly track isRunning state", async () => {
781
- const threadId = "test-thread-running";
782
- const agent = new DelayedEventAgent(5, 20, "running");
783
- const input: RunAgentInput = {
784
- messages: [],
785
- state: {},
786
- threadId,
787
- runId: "run-running",
788
- };
789
-
790
- // Check before run
791
- expect(await runner.isRunning({ threadId })).toBe(false);
792
-
793
- // Start run
794
- const runObservable = runner.run({ threadId, agent, input });
795
-
796
- // Check during run
797
- expect(await runner.isRunning({ threadId })).toBe(true);
798
-
799
- // Wait for completion
800
- await firstValueFrom(runObservable.pipe(toArray()));
801
-
802
- // Check after run
803
- expect(await runner.isRunning({ threadId })).toBe(false);
804
- });
805
-
806
- it("should return false when stopping a non-existent thread", async () => {
807
- await expect(runner.stop({ threadId: "missing-thread" })).resolves.toBe(
808
- false,
809
- );
810
- });
811
-
812
- it("should stop an active run and complete streams", async () => {
813
- const threadId = "test-thread-stop";
814
- const agent = new StoppableAgent(2);
815
- const input: RunAgentInput = {
816
- messages: [],
817
- state: {},
818
- threadId,
819
- runId: "run-stop",
820
- };
821
-
822
- const run$ = runner.run({ threadId, agent, input });
823
- const collected = firstValueFrom(run$.pipe(toArray()));
824
-
825
- // Allow the run loop to start and emit a couple of events
826
- await new Promise((resolve) => setTimeout(resolve, 20));
827
- expect(await runner.isRunning({ threadId })).toBe(true);
828
-
829
- const stopped = await runner.stop({ threadId });
830
- expect(stopped).toBe(true);
831
-
832
- const events = await collected;
833
- expect(events.length).toBeGreaterThan(0);
834
- expect(events[events.length - 1].type).toBe(EventType.RUN_FINISHED);
835
- expect(await runner.isRunning({ threadId })).toBe(false);
836
- });
837
-
838
- it("should close open text and tool events when stopping", async () => {
839
- const threadId = "test-thread-open-events";
840
- const agent = new OpenEventsAgent();
841
- const input: RunAgentInput = {
842
- messages: [],
843
- state: {},
844
- threadId,
845
- runId: "run-open",
846
- };
847
-
848
- const run$ = runner.run({ threadId, agent, input });
849
- const collected = firstValueFrom(run$.pipe(toArray()));
850
-
851
- await new Promise((resolve) => setTimeout(resolve, 20));
852
- await runner.stop({ threadId });
853
-
854
- const events = await collected;
855
- const endingTypes = events.slice(-4).map((event) => event.type);
856
- expect(endingTypes).toEqual([
857
- EventType.TEXT_MESSAGE_END,
858
- EventType.TOOL_CALL_END,
859
- EventType.TOOL_CALL_RESULT,
860
- EventType.RUN_FINISHED,
861
- ]);
862
- });
863
-
864
- it("should handle thread isolation correctly", async () => {
865
- const thread1 = "test-thread-iso-1";
866
- const thread2 = "test-thread-iso-2";
867
-
868
- const agent1 = new MockAgent([
869
- {
870
- type: "thread1",
871
- id: "t1-event",
872
- timestamp: new Date().toISOString(),
873
- data: {},
874
- } as BaseEvent,
875
- ]);
876
- const agent2 = new MockAgent([
877
- {
878
- type: "thread2",
879
- id: "t2-event",
880
- timestamp: new Date().toISOString(),
881
- data: {},
882
- } as BaseEvent,
883
- ]);
884
-
885
- // Run on different threads
886
- const run1 = runner.run({
887
- threadId: thread1,
888
- agent: agent1,
889
- input: { messages: [], state: {}, threadId: thread1, runId: "run-t1" },
890
- });
891
- const run2 = runner.run({
892
- threadId: thread2,
893
- agent: agent2,
894
- input: { messages: [], state: {}, threadId: thread2, runId: "run-t2" },
895
- });
896
-
897
- await Promise.all([
898
- firstValueFrom(run1.pipe(toArray())),
899
- firstValueFrom(run2.pipe(toArray())),
900
- ]);
901
-
902
- // Connect to each thread
903
- const events1 = await firstValueFrom(
904
- runner.connect({ threadId: thread1 }).pipe(toArray()),
905
- );
906
- const events2 = await firstValueFrom(
907
- runner.connect({ threadId: thread2 }).pipe(toArray()),
908
- );
909
-
910
- // Verify isolation
911
- const thread1Events = stripTerminalEvents(events1);
912
- const thread2Events = stripTerminalEvents(events2);
913
- expect(thread1Events).toHaveLength(1);
914
- expect(thread1Events[0].id).toBe("t1-event");
915
-
916
- expect(thread2Events).toHaveLength(1);
917
- expect(thread2Events[0].id).toBe("t2-event");
918
- });
919
- });
920
-
921
- describe("Complex Scenarios", () => {
922
- it("should handle rapid sequential runs with mixed event patterns", async () => {
923
- const threadId = "test-thread-complex-1";
924
- const runs = [
925
- {
926
- agent: new MockAgent([
927
- {
928
- type: "instant",
929
- id: "instant-1",
930
- timestamp: new Date().toISOString(),
931
- data: {},
932
- } as BaseEvent,
933
- ]),
934
- runId: "run-1",
935
- },
936
- { agent: new DelayedEventAgent(3, 5, "delayed"), runId: "run-2" },
937
- {
938
- agent: new MockAgent([
939
- {
940
- type: "instant",
941
- id: "instant-2",
942
- timestamp: new Date().toISOString(),
943
- data: {},
944
- } as BaseEvent,
945
- ]),
946
- runId: "run-3",
947
- },
948
- { agent: new MultiEventAgent("multi"), runId: "run-4" },
949
- { agent: new DelayedEventAgent(2, 10, "slow"), runId: "run-5" },
950
- ];
951
-
952
- for (const { agent, runId } of runs) {
953
- const input: RunAgentInput = {
954
- messages: [],
955
- state: {},
956
- threadId,
957
- runId,
958
- };
959
-
960
- const run = runner.run({ threadId, agent, input });
961
- await firstValueFrom(run.pipe(toArray()));
962
- }
963
-
964
- const allEvents = await firstValueFrom(
965
- runner.connect({ threadId }).pipe(toArray()),
966
- );
967
-
968
- const agentEvents = stripTerminalEvents(allEvents);
969
- expect(agentEvents).toHaveLength(12); // 1 + 3 + 1 + 5 + 2
970
-
971
- // Verify event ordering
972
- expect(agentEvents[0].id).toBe("instant-1");
973
- expect(agentEvents[1].id).toContain("delayed-0");
974
- expect(agentEvents[4].id).toBe("instant-2");
975
- expect(agentEvents[5].id).toContain("multi-start");
976
- expect(agentEvents[10].id).toContain("slow-0");
977
- });
978
-
979
- it("should handle subscriber that connects between runs", async () => {
980
- const threadId = "test-thread-complex-2";
981
-
982
- // First run
983
- const agent1 = new MultiEventAgent("first");
984
- const run1 = runner.run({
985
- threadId,
986
- agent: agent1,
987
- input: { messages: [], state: {}, threadId, runId: "run-1" },
988
- });
989
- await firstValueFrom(run1.pipe(toArray()));
990
-
991
- // Connect after first run - should only get first run events
992
- const midConnectObservable = runner.connect({ threadId });
993
- const midEvents = await firstValueFrom(
994
- midConnectObservable.pipe(toArray()),
995
- );
996
-
997
- const midAgentEvents = stripTerminalEvents(midEvents);
998
- expect(midAgentEvents).toHaveLength(5); // Only events from first run
999
- const firstRunEvents = midAgentEvents.filter((e) =>
1000
- e.id?.includes("first"),
1001
- );
1002
- expect(firstRunEvents).toHaveLength(5);
1003
-
1004
- // Second run
1005
- const agent2 = new MultiEventAgent("second");
1006
- const run2 = runner.run({
1007
- threadId,
1008
- agent: agent2,
1009
- input: { messages: [], state: {}, threadId, runId: "run-2" },
1010
- });
1011
- await firstValueFrom(run2.pipe(toArray()));
1012
-
1013
- // Connect after both runs to verify all events
1014
- const allEvents = await firstValueFrom(
1015
- runner.connect({ threadId }).pipe(toArray()),
1016
- );
1017
- const allAgentEvents = stripTerminalEvents(allEvents);
1018
- expect(allAgentEvents).toHaveLength(10); // Events from both runs
1019
-
1020
- const allFirstRunEvents = allAgentEvents.filter((e) =>
1021
- e.id?.includes("first"),
1022
- );
1023
- const allSecondRunEvents = allAgentEvents.filter((e) =>
1024
- e.id?.includes("second"),
1025
- );
1026
- expect(allFirstRunEvents).toHaveLength(5);
1027
- expect(allSecondRunEvents).toHaveLength(5);
1028
- });
1029
- });
1030
- });