@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,193 +0,0 @@
1
- import { describe, it, expect } from "vitest";
2
- import type { AbstractAgent } from "@ag-ui/client";
3
-
4
- import { createCopilotEndpointSingleRoute } from "../endpoints";
5
- import { CopilotRuntime } from "../core/runtime";
6
-
7
- describe("CopilotEndpointSingleRoute routing", () => {
8
- const createMockRuntime = () => {
9
- const createMockAgent = () => {
10
- const agent: unknown = {
11
- execute: async () => ({ events: [] }),
12
- };
13
- (agent as { clone: () => unknown }).clone = () => createMockAgent();
14
- return agent as AbstractAgent;
15
- };
16
-
17
- return new CopilotRuntime({
18
- agents: {
19
- default: createMockAgent(),
20
- myAgent: createMockAgent(),
21
- agent123: createMockAgent(),
22
- "my-agent": createMockAgent(),
23
- my_agent: createMockAgent(),
24
- testAgent: createMockAgent(),
25
- test: createMockAgent(),
26
- "test%20agent": createMockAgent(),
27
- "test agent": createMockAgent(),
28
- },
29
- });
30
- };
31
-
32
- const callEndpoint = async (body: Record<string, unknown>) => {
33
- const runtime = createMockRuntime();
34
- const endpoint = createCopilotEndpointSingleRoute({
35
- runtime,
36
- basePath: "/rpc",
37
- });
38
- const request = new Request("https://example.com/rpc", {
39
- method: "POST",
40
- headers: { "content-type": "application/json" },
41
- body: JSON.stringify(body),
42
- });
43
-
44
- return endpoint.fetch(request);
45
- };
46
-
47
- describe("agent/run method", () => {
48
- it("accepts simple agent names", async () => {
49
- const response = await callEndpoint({
50
- method: "agent/run",
51
- params: { agentId: "myAgent" },
52
- body: {},
53
- });
54
-
55
- expect(response.status).not.toBe(404);
56
- });
57
-
58
- it("accepts hyphenated agent names", async () => {
59
- const response = await callEndpoint({
60
- method: "agent/run",
61
- params: { agentId: "my-agent" },
62
- body: {},
63
- });
64
-
65
- expect(response.status).not.toBe(404);
66
- });
67
-
68
- it("accepts underscored agent names", async () => {
69
- const response = await callEndpoint({
70
- method: "agent/run",
71
- params: { agentId: "my_agent" },
72
- body: {},
73
- });
74
-
75
- expect(response.status).not.toBe(404);
76
- });
77
-
78
- it("returns 400 when agentId missing", async () => {
79
- const response = await callEndpoint({
80
- method: "agent/run",
81
- body: {},
82
- });
83
-
84
- expect(response.status).toBe(400);
85
- });
86
- });
87
-
88
- describe("agent/connect method", () => {
89
- it("accepts standard agent id", async () => {
90
- const response = await callEndpoint({
91
- method: "agent/connect",
92
- params: { agentId: "agent123" },
93
- body: {},
94
- });
95
-
96
- expect(response.status).not.toBe(404);
97
- });
98
- });
99
-
100
- describe("agent/stop method", () => {
101
- it("requires threadId", async () => {
102
- const response = await callEndpoint({
103
- method: "agent/stop",
104
- params: { agentId: "agent123" },
105
- });
106
-
107
- expect(response.status).toBe(400);
108
- });
109
-
110
- it("returns response when params provided", async () => {
111
- const response = await callEndpoint({
112
- method: "agent/stop",
113
- params: { agentId: "agent123", threadId: "thread-1" },
114
- });
115
-
116
- expect(response.status).not.toBe(404);
117
- });
118
- });
119
-
120
- describe("info method", () => {
121
- it("returns runtime info for base path", async () => {
122
- const response = await callEndpoint({ method: "info" });
123
-
124
- expect(response.status).toBe(200);
125
- const body = await response.json();
126
- expect(body).toHaveProperty("version");
127
- });
128
-
129
- it("handles query parameters", async () => {
130
- const runtime = createMockRuntime();
131
- const endpoint = createCopilotEndpointSingleRoute({
132
- runtime,
133
- basePath: "/rpc",
134
- });
135
- const request = new Request("https://example.com/rpc?foo=bar", {
136
- method: "POST",
137
- headers: { "content-type": "application/json" },
138
- body: JSON.stringify({ method: "info" }),
139
- });
140
-
141
- const response = await endpoint.fetch(request);
142
- expect(response.status).toBe(200);
143
- });
144
- });
145
-
146
- describe("transcribe method", () => {
147
- it("returns non-404 even without multipart body", async () => {
148
- const response = await callEndpoint({ method: "transcribe" });
149
-
150
- expect(response.status).not.toBe(404);
151
- });
152
- });
153
-
154
- describe("invalid inputs", () => {
155
- it("returns 415 for non-JSON content", async () => {
156
- const runtime = createMockRuntime();
157
- const endpoint = createCopilotEndpointSingleRoute({
158
- runtime,
159
- basePath: "/rpc",
160
- });
161
- const request = new Request("https://example.com/rpc", {
162
- method: "POST",
163
- headers: { "content-type": "text/plain" },
164
- body: "method=info",
165
- });
166
-
167
- const response = await endpoint.fetch(request);
168
- expect(response.status).toBe(415);
169
- });
170
-
171
- it("returns 400 for unsupported method", async () => {
172
- const response = await callEndpoint({ method: "unknown" });
173
-
174
- expect(response.status).toBe(400);
175
- });
176
-
177
- it("returns 404 for unmatched path", async () => {
178
- const runtime = createMockRuntime();
179
- const endpoint = createCopilotEndpointSingleRoute({
180
- runtime,
181
- basePath: "/rpc",
182
- });
183
- const request = new Request("https://example.com/other", {
184
- method: "POST",
185
- headers: { "content-type": "application/json" },
186
- body: JSON.stringify({ method: "info" }),
187
- });
188
-
189
- const response = await endpoint.fetch(request);
190
- expect(response.status).toBe(404);
191
- });
192
- });
193
- });
@@ -1,257 +0,0 @@
1
- import { createCopilotEndpoint } from "../endpoints";
2
- import { CopilotRuntime } from "../core/runtime";
3
- import { describe, it, expect } from "vitest";
4
- import type { AbstractAgent } from "@ag-ui/client";
5
-
6
- describe("CopilotEndpoint routing", () => {
7
- // Helper function to create a Request object with a given URL
8
- const createRequest = (url: string, method: string = "GET"): Request => {
9
- return new Request(url, { method });
10
- };
11
-
12
- // Create a mock runtime with a basic agent
13
- const createMockRuntime = () => {
14
- const createMockAgent = () => {
15
- const agent: unknown = {
16
- execute: async () => ({ events: [] }),
17
- };
18
- (agent as { clone: () => unknown }).clone = () => createMockAgent();
19
- return agent as AbstractAgent;
20
- };
21
-
22
- return new CopilotRuntime({
23
- agents: {
24
- default: createMockAgent(),
25
- myAgent: createMockAgent(),
26
- agent123: createMockAgent(),
27
- "my-agent": createMockAgent(),
28
- my_agent: createMockAgent(),
29
- testAgent: createMockAgent(),
30
- test: createMockAgent(),
31
- "test%20agent": createMockAgent(),
32
- "test agent": createMockAgent(),
33
- },
34
- });
35
- };
36
-
37
- // Helper to test routing
38
- const testRoute = async (
39
- url: string,
40
- method: string = "GET",
41
- body?: unknown,
42
- ) => {
43
- const runtime = createMockRuntime();
44
- const endpoint = createCopilotEndpoint({ runtime, basePath: "/" });
45
- const requestInit: RequestInit = { method };
46
- if (body) {
47
- requestInit.body = JSON.stringify(body);
48
- requestInit.headers = { "Content-Type": "application/json" };
49
- }
50
- const request = createRequest(url, method);
51
- const response = await endpoint.fetch(request);
52
- return response;
53
- };
54
-
55
- describe("RunAgent route pattern", () => {
56
- it("should match agent run URL with simple agent name", async () => {
57
- const response = await testRoute(
58
- "https://example.com/agent/myAgent/run",
59
- "POST",
60
- {
61
- agentId: "myAgent",
62
- },
63
- );
64
-
65
- // Should not be 404
66
- expect(response.status).not.toBe(404);
67
- });
68
-
69
- it("should match agent run URL with alphanumeric agent name", async () => {
70
- const response = await testRoute(
71
- "https://example.com/agent/agent123/run",
72
- "POST",
73
- {
74
- agentId: "agent123",
75
- },
76
- );
77
-
78
- expect(response.status).not.toBe(404);
79
- });
80
-
81
- it("should match agent run URL with hyphenated agent name", async () => {
82
- const response = await testRoute(
83
- "https://example.com/agent/my-agent/run",
84
- "POST",
85
- {
86
- agentId: "my-agent",
87
- },
88
- );
89
-
90
- expect(response.status).not.toBe(404);
91
- });
92
-
93
- it("should match agent run URL with underscored agent name", async () => {
94
- const response = await testRoute(
95
- "https://example.com/agent/my_agent/run",
96
- "POST",
97
- {
98
- agentId: "my_agent",
99
- },
100
- );
101
-
102
- expect(response.status).not.toBe(404);
103
- });
104
-
105
- it("should not match agent run URL with empty agent name", async () => {
106
- const response = await testRoute(
107
- "https://example.com/agent//run",
108
- "POST",
109
- );
110
-
111
- expect(response.status).toBe(404);
112
- const body = await response.json();
113
- expect(body).toEqual({ error: "Not found" });
114
- });
115
-
116
- it("should not match partial agent run URL", async () => {
117
- const response = await testRoute(
118
- "https://example.com/agent/myAgent",
119
- "POST",
120
- );
121
-
122
- expect(response.status).toBe(404);
123
- });
124
-
125
- it("should not match agent run URL with extra path segments", async () => {
126
- const response = await testRoute(
127
- "https://example.com/agent/myAgent/run/extra",
128
- "POST",
129
- );
130
-
131
- expect(response.status).toBe(404);
132
- });
133
- });
134
-
135
- describe("GetRuntimeInfo route pattern (/info endpoint)", () => {
136
- it("should match simple info URL", async () => {
137
- const response = await testRoute("https://example.com/info");
138
-
139
- expect(response.status).toBe(200);
140
- const body = await response.json();
141
- expect(body).toHaveProperty("version");
142
- });
143
-
144
- it("should match info URL with query parameters", async () => {
145
- const response = await testRoute("https://example.com/info?param=value");
146
-
147
- expect(response.status).toBe(200);
148
- });
149
-
150
- it("should not match non-info URLs", async () => {
151
- const response = await testRoute("https://example.com/agents");
152
-
153
- expect(response.status).toBe(404);
154
- });
155
- });
156
-
157
- describe("Transcribe route pattern (/transcribe endpoint)", () => {
158
- it("should match simple transcribe URL", async () => {
159
- // Transcribe expects POST method and audio data
160
- const response = await testRoute(
161
- "https://example.com/transcribe",
162
- "POST",
163
- {},
164
- );
165
-
166
- // It might return an error since we're not providing audio, but it shouldn't be 404
167
- expect(response.status).not.toBe(404);
168
- });
169
-
170
- it("should match transcribe URL with query parameters", async () => {
171
- const response = await testRoute(
172
- "https://example.com/transcribe?format=json",
173
- "POST",
174
- {},
175
- );
176
-
177
- expect(response.status).not.toBe(404);
178
- });
179
-
180
- it("should not match transcribe URLs with extra path segments", async () => {
181
- const response = await testRoute(
182
- "https://example.com/transcribe/extra",
183
- "POST",
184
- );
185
-
186
- expect(response.status).toBe(404);
187
- });
188
- });
189
-
190
- describe("Unmatched routes (404 behavior)", () => {
191
- it("should return 404 for root path", async () => {
192
- const response = await testRoute("https://example.com/");
193
-
194
- expect(response.status).toBe(404);
195
- const body = await response.json();
196
- expect(body).toEqual({ error: "Not found" });
197
- });
198
-
199
- it("should return 404 for unknown paths", async () => {
200
- const response = await testRoute("https://example.com/unknown/path");
201
-
202
- expect(response.status).toBe(404);
203
- });
204
-
205
- it("should return 404 for malformed agent paths", async () => {
206
- const response = await testRoute("https://example.com/agent/run", "POST");
207
-
208
- expect(response.status).toBe(404);
209
- });
210
-
211
- it("should return 404 for agents path", async () => {
212
- const response = await testRoute("https://example.com/agents");
213
-
214
- expect(response.status).toBe(404);
215
- });
216
- });
217
-
218
- describe("Edge cases", () => {
219
- it("should handle URLs with different domains", async () => {
220
- const response = await testRoute(
221
- "http://localhost:3000/agent/test/run",
222
- "POST",
223
- {
224
- agentId: "test",
225
- },
226
- );
227
-
228
- expect(response.status).not.toBe(404);
229
- });
230
-
231
- it("should handle URLs with ports for info endpoint", async () => {
232
- const response = await testRoute("https://api.example.com:8080/info");
233
-
234
- expect(response.status).toBe(200);
235
- });
236
-
237
- it("should handle URLs with ports for transcribe endpoint", async () => {
238
- const response = await testRoute(
239
- "https://api.example.com:8080/transcribe",
240
- "POST",
241
- {},
242
- );
243
-
244
- expect(response.status).not.toBe(404);
245
- });
246
-
247
- it("should handle URLs with special characters in agent names", async () => {
248
- const response = await testRoute(
249
- "https://example.com/agent/test%20agent/run",
250
- "POST",
251
- { agentId: "test%20agent" },
252
- );
253
-
254
- expect(response.status).not.toBe(404);
255
- });
256
- });
257
- });
@@ -1,234 +0,0 @@
1
- import { describe, expect, it, vi } from "vitest";
2
-
3
- import {
4
- CopilotIntelligenceRuntime,
5
- CopilotRuntime,
6
- CopilotSseRuntime,
7
- } from "../core/runtime";
8
- import type { CopilotKitIntelligence } from "../intelligence-platform";
9
- import { InMemoryAgentRunner } from "../runner/in-memory";
10
- import { IntelligenceAgentRunner } from "../runner/intelligence";
11
-
12
- describe("runtime construction", () => {
13
- const agents = {};
14
- const identifyUser = vi
15
- .fn()
16
- .mockResolvedValue({ id: "user-1", name: "User One" });
17
- const createMockIntelligence = (): CopilotKitIntelligence =>
18
- ({
19
- ɵgetRunnerWsUrl: vi.fn().mockReturnValue("ws://runner.example"),
20
- ɵgetRunnerAuthToken: vi.fn().mockReturnValue("token-123"),
21
- ɵgetClientWsUrl: vi.fn().mockReturnValue("ws://client.example"),
22
- }) as unknown as CopilotKitIntelligence;
23
-
24
- it("builds an SSE runtime by default", () => {
25
- const runtime = new CopilotSseRuntime({ agents });
26
-
27
- expect(runtime.mode).toBe("sse");
28
-
29
- expect(runtime.runner).toBeInstanceOf(InMemoryAgentRunner);
30
- expect(runtime.intelligence).toBeUndefined();
31
- });
32
-
33
- it("builds an Intelligence runtime with an Intelligence runner", () => {
34
- const sdk = createMockIntelligence();
35
-
36
- const runtime = new CopilotIntelligenceRuntime({
37
- agents,
38
- intelligence: sdk,
39
- identifyUser,
40
- });
41
-
42
- expect(runtime.mode).toBe("intelligence");
43
-
44
- expect(runtime.intelligence).toBe(sdk);
45
- expect(runtime.runner).toBeInstanceOf(IntelligenceAgentRunner);
46
- expect(runtime.generateThreadNames).toBe(true);
47
- expect(runtime.identifyUser).toBe(identifyUser);
48
- expect(sdk.ɵgetRunnerWsUrl).toHaveBeenCalledTimes(1);
49
- expect(sdk.ɵgetRunnerAuthToken).toHaveBeenCalledTimes(1);
50
- });
51
-
52
- it("preserves an explicit generateThreadNames=false option in Intelligence mode", () => {
53
- const sdk = createMockIntelligence();
54
-
55
- const runtime = new CopilotIntelligenceRuntime({
56
- agents,
57
- intelligence: sdk,
58
- identifyUser,
59
- generateThreadNames: false,
60
- });
61
-
62
- expect(runtime.generateThreadNames).toBe(false);
63
- });
64
-
65
- it("keeps CopilotRuntime as an SSE shim when no CopilotKitIntelligence is provided", () => {
66
- const runtime = new CopilotRuntime({ agents });
67
-
68
- expect(runtime.mode).toBe("sse");
69
-
70
- expect(runtime.runner).toBeInstanceOf(InMemoryAgentRunner);
71
- expect(runtime.intelligence).toBeUndefined();
72
- });
73
-
74
- it("keeps CopilotRuntime as an Intelligence shim when CopilotKitIntelligence is provided", () => {
75
- const sdk = createMockIntelligence();
76
-
77
- const runtime = new CopilotRuntime({
78
- agents,
79
- intelligence: sdk,
80
- identifyUser,
81
- });
82
-
83
- expect(runtime.mode).toBe("intelligence");
84
-
85
- expect(runtime.intelligence).toBe(sdk);
86
- expect(runtime.runner).toBeInstanceOf(IntelligenceAgentRunner);
87
- expect(
88
- (runtime as CopilotRuntime & { generateThreadNames?: boolean })
89
- .generateThreadNames,
90
- ).toBe(true);
91
- expect(
92
- (
93
- runtime as CopilotRuntime & {
94
- identifyUser?: typeof identifyUser;
95
- }
96
- ).identifyUser,
97
- ).toBe(identifyUser);
98
- });
99
-
100
- it("forwards generateThreadNames=false through the CopilotRuntime intelligence shim", () => {
101
- const sdk = createMockIntelligence();
102
-
103
- const runtime = new CopilotRuntime({
104
- agents,
105
- intelligence: sdk,
106
- identifyUser,
107
- generateThreadNames: false,
108
- });
109
-
110
- expect(runtime.mode).toBe("intelligence");
111
- expect(
112
- (runtime as CopilotRuntime & { generateThreadNames?: boolean })
113
- .generateThreadNames,
114
- ).toBe(false);
115
- });
116
-
117
- it("exposes identifyUser as undefined for SSE runtimes", () => {
118
- const runtime = new CopilotRuntime({ agents });
119
-
120
- expect(
121
- (runtime as CopilotRuntime & { identifyUser?: typeof identifyUser })
122
- .identifyUser,
123
- ).toBeUndefined();
124
- });
125
-
126
- it("defaults lockTtlSeconds to 20 and lockHeartbeatIntervalSeconds to 15", () => {
127
- const sdk = createMockIntelligence();
128
-
129
- const runtime = new CopilotIntelligenceRuntime({
130
- agents,
131
- intelligence: sdk,
132
- identifyUser,
133
- });
134
-
135
- expect(runtime.lockTtlSeconds).toBe(20);
136
- expect(runtime.lockHeartbeatIntervalSeconds).toBe(15);
137
- });
138
-
139
- it("clamps lockTtlSeconds to a maximum of 3600 (1 hour)", () => {
140
- const sdk = createMockIntelligence();
141
-
142
- const runtime = new CopilotIntelligenceRuntime({
143
- agents,
144
- intelligence: sdk,
145
- identifyUser,
146
- lockTtlSeconds: 7200,
147
- });
148
-
149
- expect(runtime.lockTtlSeconds).toBe(3600);
150
- });
151
-
152
- it("clamps lockHeartbeatIntervalSeconds to a maximum of 3000 (50 minutes)", () => {
153
- const sdk = createMockIntelligence();
154
-
155
- const runtime = new CopilotIntelligenceRuntime({
156
- agents,
157
- intelligence: sdk,
158
- identifyUser,
159
- lockHeartbeatIntervalSeconds: 5000,
160
- });
161
-
162
- expect(runtime.lockHeartbeatIntervalSeconds).toBe(3000);
163
- });
164
-
165
- it("uses provided values when they are within allowed range", () => {
166
- const sdk = createMockIntelligence();
167
-
168
- const runtime = new CopilotIntelligenceRuntime({
169
- agents,
170
- intelligence: sdk,
171
- identifyUser,
172
- lockTtlSeconds: 30,
173
- });
174
-
175
- expect(runtime.lockTtlSeconds).toBe(30);
176
- expect(runtime.lockHeartbeatIntervalSeconds).toBe(15);
177
- });
178
-
179
- it("stores lock config on CopilotIntelligenceRuntime", () => {
180
- const sdk = createMockIntelligence();
181
-
182
- const runtime = new CopilotIntelligenceRuntime({
183
- agents,
184
- intelligence: sdk,
185
- identifyUser,
186
- lockTtlSeconds: 30,
187
- lockKeyPrefix: "custom",
188
- lockHeartbeatIntervalSeconds: 10,
189
- });
190
-
191
- expect(runtime.lockTtlSeconds).toBe(30);
192
- expect(runtime.lockKeyPrefix).toBe("custom");
193
- expect(runtime.lockHeartbeatIntervalSeconds).toBe(10);
194
- });
195
-
196
- it("forwards lock config through the CopilotRuntime intelligence shim", () => {
197
- const sdk = createMockIntelligence();
198
-
199
- const runtime = new CopilotRuntime({
200
- agents,
201
- intelligence: sdk,
202
- identifyUser,
203
- lockTtlSeconds: 60,
204
- lockKeyPrefix: "agent",
205
- lockHeartbeatIntervalSeconds: 20,
206
- });
207
-
208
- expect(
209
- (runtime as CopilotRuntime & { lockTtlSeconds?: number }).lockTtlSeconds,
210
- ).toBe(60);
211
- expect(
212
- (runtime as CopilotRuntime & { lockKeyPrefix?: string }).lockKeyPrefix,
213
- ).toBe("agent");
214
- expect(
215
- (runtime as CopilotRuntime & { lockHeartbeatIntervalSeconds?: number })
216
- .lockHeartbeatIntervalSeconds,
217
- ).toBe(20);
218
- });
219
-
220
- it("exposes lock config as undefined for SSE runtimes", () => {
221
- const runtime = new CopilotRuntime({ agents });
222
-
223
- expect(
224
- (runtime as CopilotRuntime & { lockTtlSeconds?: number }).lockTtlSeconds,
225
- ).toBeUndefined();
226
- expect(
227
- (runtime as CopilotRuntime & { lockKeyPrefix?: string }).lockKeyPrefix,
228
- ).toBeUndefined();
229
- expect(
230
- (runtime as CopilotRuntime & { lockHeartbeatIntervalSeconds?: number })
231
- .lockHeartbeatIntervalSeconds,
232
- ).toBeUndefined();
233
- });
234
- });