@wingman-ai/gateway 0.5.2 → 0.5.4

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 (311) hide show
  1. package/dist/agent/config/agentConfig.cjs +4 -0
  2. package/dist/agent/config/agentConfig.d.ts +12 -0
  3. package/dist/agent/config/agentConfig.js +4 -0
  4. package/dist/agent/config/toolRegistry.cjs +75 -1
  5. package/dist/agent/config/toolRegistry.d.ts +3 -0
  6. package/dist/agent/config/toolRegistry.js +75 -1
  7. package/dist/agent/middleware/large-tool-results.cjs +207 -0
  8. package/dist/agent/middleware/large-tool-results.d.ts +16 -0
  9. package/dist/agent/middleware/large-tool-results.js +173 -0
  10. package/dist/agent/tools/browser_control.cjs +9 -1231
  11. package/dist/agent/tools/browser_control.d.ts +126 -234
  12. package/dist/agent/tools/browser_control.js +7 -1226
  13. package/dist/agent/tools/browser_runtime.cjs +1189 -0
  14. package/dist/agent/tools/browser_runtime.d.ts +560 -0
  15. package/dist/agent/tools/browser_runtime.js +1122 -0
  16. package/dist/agent/tools/browser_session.cjs +153 -0
  17. package/dist/agent/tools/browser_session.d.ts +741 -0
  18. package/dist/agent/tools/browser_session.js +110 -0
  19. package/dist/agent/tools/browser_session_manager.cjs +202 -0
  20. package/dist/agent/tools/browser_session_manager.d.ts +64 -0
  21. package/dist/agent/tools/browser_session_manager.js +165 -0
  22. package/dist/cli/commands/init.cjs +5 -1
  23. package/dist/cli/commands/init.js +5 -1
  24. package/dist/cli/config/loader.cjs +0 -5
  25. package/dist/cli/config/loader.js +0 -5
  26. package/dist/cli/config/schema.cjs +3 -7
  27. package/dist/cli/config/schema.d.ts +6 -6
  28. package/dist/cli/config/schema.js +3 -7
  29. package/dist/cli/core/agentInvoker.cjs +86 -22
  30. package/dist/cli/core/agentInvoker.d.ts +10 -3
  31. package/dist/cli/core/agentInvoker.js +86 -25
  32. package/dist/cli/core/outputManager.cjs +7 -2
  33. package/dist/cli/core/outputManager.d.ts +2 -2
  34. package/dist/cli/core/outputManager.js +7 -2
  35. package/dist/cli/types.d.ts +2 -1
  36. package/dist/webui/assets/index-XrEnkZiq.css +11 -0
  37. package/dist/webui/assets/index-mDs6HbKM.js +215 -0
  38. package/dist/webui/index.html +2 -2
  39. package/package.json +10 -10
  40. package/templates/agents/README.md +2 -1
  41. package/templates/agents/coding/agent.md +6 -13
  42. package/templates/agents/coding-v2/agent.md +6 -1
  43. package/templates/agents/game-dev/agent.md +8 -2
  44. package/templates/agents/game-dev/game-designer.md +4 -0
  45. package/templates/agents/game-dev/scene-engineer.md +4 -0
  46. package/templates/agents/main/agent.md +5 -0
  47. package/templates/agents/researcher/agent.md +11 -0
  48. package/templates/agents/stock-trader/agent.md +4 -0
  49. package/dist/agent/tests/agentConfig.test.cjs +0 -224
  50. package/dist/agent/tests/agentConfig.test.d.ts +0 -1
  51. package/dist/agent/tests/agentConfig.test.js +0 -218
  52. package/dist/agent/tests/agentLoader.test.cjs +0 -335
  53. package/dist/agent/tests/agentLoader.test.d.ts +0 -1
  54. package/dist/agent/tests/agentLoader.test.js +0 -329
  55. package/dist/agent/tests/backgroundTerminal.test.cjs +0 -70
  56. package/dist/agent/tests/backgroundTerminal.test.d.ts +0 -1
  57. package/dist/agent/tests/backgroundTerminal.test.js +0 -64
  58. package/dist/agent/tests/browserControlHelpers.test.cjs +0 -35
  59. package/dist/agent/tests/browserControlHelpers.test.d.ts +0 -1
  60. package/dist/agent/tests/browserControlHelpers.test.js +0 -29
  61. package/dist/agent/tests/browserControlTool.test.cjs +0 -2117
  62. package/dist/agent/tests/browserControlTool.test.d.ts +0 -1
  63. package/dist/agent/tests/browserControlTool.test.js +0 -2111
  64. package/dist/agent/tests/commandExecuteTool.test.cjs +0 -29
  65. package/dist/agent/tests/commandExecuteTool.test.d.ts +0 -1
  66. package/dist/agent/tests/commandExecuteTool.test.js +0 -23
  67. package/dist/agent/tests/internet_search.test.cjs +0 -107
  68. package/dist/agent/tests/internet_search.test.d.ts +0 -1
  69. package/dist/agent/tests/internet_search.test.js +0 -101
  70. package/dist/agent/tests/mcpClientManager.test.cjs +0 -290
  71. package/dist/agent/tests/mcpClientManager.test.d.ts +0 -1
  72. package/dist/agent/tests/mcpClientManager.test.js +0 -284
  73. package/dist/agent/tests/mcpResourceTools.test.cjs +0 -101
  74. package/dist/agent/tests/mcpResourceTools.test.d.ts +0 -1
  75. package/dist/agent/tests/mcpResourceTools.test.js +0 -95
  76. package/dist/agent/tests/modelFactory.test.cjs +0 -190
  77. package/dist/agent/tests/modelFactory.test.d.ts +0 -1
  78. package/dist/agent/tests/modelFactory.test.js +0 -184
  79. package/dist/agent/tests/terminalSessionManager.test.cjs +0 -121
  80. package/dist/agent/tests/terminalSessionManager.test.d.ts +0 -1
  81. package/dist/agent/tests/terminalSessionManager.test.js +0 -115
  82. package/dist/agent/tests/test-agent-loader.cjs +0 -33
  83. package/dist/agent/tests/test-agent-loader.d.ts +0 -1
  84. package/dist/agent/tests/test-agent-loader.js +0 -27
  85. package/dist/agent/tests/test-subagent-loading.cjs +0 -99
  86. package/dist/agent/tests/test-subagent-loading.d.ts +0 -1
  87. package/dist/agent/tests/test-subagent-loading.js +0 -93
  88. package/dist/agent/tests/toolRegistry.test.cjs +0 -147
  89. package/dist/agent/tests/toolRegistry.test.d.ts +0 -1
  90. package/dist/agent/tests/toolRegistry.test.js +0 -141
  91. package/dist/agent/tests/uiRegistryTools.test.cjs +0 -114
  92. package/dist/agent/tests/uiRegistryTools.test.d.ts +0 -1
  93. package/dist/agent/tests/uiRegistryTools.test.js +0 -105
  94. package/dist/agent/tests/xaiImageModel.test.cjs +0 -194
  95. package/dist/agent/tests/xaiImageModel.test.d.ts +0 -1
  96. package/dist/agent/tests/xaiImageModel.test.js +0 -188
  97. package/dist/tests/additionalMessageMiddleware.test.cjs +0 -216
  98. package/dist/tests/additionalMessageMiddleware.test.d.ts +0 -1
  99. package/dist/tests/additionalMessageMiddleware.test.js +0 -188
  100. package/dist/tests/agent-config-voice.test.cjs +0 -25
  101. package/dist/tests/agent-config-voice.test.d.ts +0 -1
  102. package/dist/tests/agent-config-voice.test.js +0 -19
  103. package/dist/tests/agentInvokerAttachments.test.cjs +0 -190
  104. package/dist/tests/agentInvokerAttachments.test.d.ts +0 -1
  105. package/dist/tests/agentInvokerAttachments.test.js +0 -184
  106. package/dist/tests/agentInvokerSummarization.test.cjs +0 -613
  107. package/dist/tests/agentInvokerSummarization.test.d.ts +0 -1
  108. package/dist/tests/agentInvokerSummarization.test.js +0 -607
  109. package/dist/tests/agentInvokerTokenUsage.test.cjs +0 -124
  110. package/dist/tests/agentInvokerTokenUsage.test.d.ts +0 -1
  111. package/dist/tests/agentInvokerTokenUsage.test.js +0 -118
  112. package/dist/tests/agentInvokerWorkdir.test.cjs +0 -150
  113. package/dist/tests/agentInvokerWorkdir.test.d.ts +0 -1
  114. package/dist/tests/agentInvokerWorkdir.test.js +0 -122
  115. package/dist/tests/agents-api.test.cjs +0 -324
  116. package/dist/tests/agents-api.test.d.ts +0 -1
  117. package/dist/tests/agents-api.test.js +0 -318
  118. package/dist/tests/attachments-utils.test.cjs +0 -46
  119. package/dist/tests/attachments-utils.test.d.ts +0 -1
  120. package/dist/tests/attachments-utils.test.js +0 -40
  121. package/dist/tests/browser-command.test.cjs +0 -264
  122. package/dist/tests/browser-command.test.d.ts +0 -1
  123. package/dist/tests/browser-command.test.js +0 -258
  124. package/dist/tests/browser-relay-server.test.cjs +0 -20
  125. package/dist/tests/browser-relay-server.test.d.ts +0 -1
  126. package/dist/tests/browser-relay-server.test.js +0 -14
  127. package/dist/tests/bunSqliteAdapter.test.cjs +0 -265
  128. package/dist/tests/bunSqliteAdapter.test.d.ts +0 -1
  129. package/dist/tests/bunSqliteAdapter.test.js +0 -259
  130. package/dist/tests/candleRange.test.cjs +0 -48
  131. package/dist/tests/candleRange.test.d.ts +0 -1
  132. package/dist/tests/candleRange.test.js +0 -42
  133. package/dist/tests/cli-config-loader.test.cjs +0 -532
  134. package/dist/tests/cli-config-loader.test.d.ts +0 -1
  135. package/dist/tests/cli-config-loader.test.js +0 -526
  136. package/dist/tests/cli-config-warnings.test.cjs +0 -94
  137. package/dist/tests/cli-config-warnings.test.d.ts +0 -1
  138. package/dist/tests/cli-config-warnings.test.js +0 -88
  139. package/dist/tests/cli-init.test.cjs +0 -225
  140. package/dist/tests/cli-init.test.d.ts +0 -1
  141. package/dist/tests/cli-init.test.js +0 -219
  142. package/dist/tests/cli-workspace-root.test.cjs +0 -114
  143. package/dist/tests/cli-workspace-root.test.d.ts +0 -1
  144. package/dist/tests/cli-workspace-root.test.js +0 -108
  145. package/dist/tests/codex-credentials-precedence.test.cjs +0 -94
  146. package/dist/tests/codex-credentials-precedence.test.d.ts +0 -1
  147. package/dist/tests/codex-credentials-precedence.test.js +0 -88
  148. package/dist/tests/codex-provider.test.cjs +0 -383
  149. package/dist/tests/codex-provider.test.d.ts +0 -1
  150. package/dist/tests/codex-provider.test.js +0 -377
  151. package/dist/tests/config-json-schema.test.cjs +0 -37
  152. package/dist/tests/config-json-schema.test.d.ts +0 -1
  153. package/dist/tests/config-json-schema.test.js +0 -31
  154. package/dist/tests/discord-adapter.test.cjs +0 -89
  155. package/dist/tests/discord-adapter.test.d.ts +0 -1
  156. package/dist/tests/discord-adapter.test.js +0 -83
  157. package/dist/tests/falRuntime.test.cjs +0 -78
  158. package/dist/tests/falRuntime.test.d.ts +0 -1
  159. package/dist/tests/falRuntime.test.js +0 -72
  160. package/dist/tests/falSummary.test.cjs +0 -51
  161. package/dist/tests/falSummary.test.d.ts +0 -1
  162. package/dist/tests/falSummary.test.js +0 -45
  163. package/dist/tests/fs-api.test.cjs +0 -138
  164. package/dist/tests/fs-api.test.d.ts +0 -1
  165. package/dist/tests/fs-api.test.js +0 -132
  166. package/dist/tests/gateway-command-workspace.test.cjs +0 -150
  167. package/dist/tests/gateway-command-workspace.test.d.ts +0 -1
  168. package/dist/tests/gateway-command-workspace.test.js +0 -144
  169. package/dist/tests/gateway-http-security.test.cjs +0 -318
  170. package/dist/tests/gateway-http-security.test.d.ts +0 -1
  171. package/dist/tests/gateway-http-security.test.js +0 -312
  172. package/dist/tests/gateway-node-mode.test.cjs +0 -174
  173. package/dist/tests/gateway-node-mode.test.d.ts +0 -1
  174. package/dist/tests/gateway-node-mode.test.js +0 -168
  175. package/dist/tests/gateway-origin-policy.test.cjs +0 -82
  176. package/dist/tests/gateway-origin-policy.test.d.ts +0 -1
  177. package/dist/tests/gateway-origin-policy.test.js +0 -76
  178. package/dist/tests/gateway-request-execution-overrides.test.cjs +0 -42
  179. package/dist/tests/gateway-request-execution-overrides.test.d.ts +0 -1
  180. package/dist/tests/gateway-request-execution-overrides.test.js +0 -36
  181. package/dist/tests/gateway.test.cjs +0 -700
  182. package/dist/tests/gateway.test.d.ts +0 -1
  183. package/dist/tests/gateway.test.js +0 -694
  184. package/dist/tests/hooks-matcher.test.cjs +0 -309
  185. package/dist/tests/hooks-matcher.test.d.ts +0 -1
  186. package/dist/tests/hooks-matcher.test.js +0 -303
  187. package/dist/tests/hooks-merger.test.cjs +0 -528
  188. package/dist/tests/hooks-merger.test.d.ts +0 -1
  189. package/dist/tests/hooks-merger.test.js +0 -522
  190. package/dist/tests/imagePersistence.test.cjs +0 -169
  191. package/dist/tests/imagePersistence.test.d.ts +0 -1
  192. package/dist/tests/imagePersistence.test.js +0 -163
  193. package/dist/tests/integration/agent-invocation.integration.test.cjs +0 -264
  194. package/dist/tests/integration/agent-invocation.integration.test.d.ts +0 -1
  195. package/dist/tests/integration/agent-invocation.integration.test.js +0 -258
  196. package/dist/tests/integration/finnhub-candles.integration.test.cjs +0 -98
  197. package/dist/tests/integration/finnhub-candles.integration.test.d.ts +0 -1
  198. package/dist/tests/integration/finnhub-candles.integration.test.js +0 -92
  199. package/dist/tests/integration/summarization-e2e.integration.test.cjs +0 -127
  200. package/dist/tests/integration/summarization-e2e.integration.test.d.ts +0 -1
  201. package/dist/tests/integration/summarization-e2e.integration.test.js +0 -121
  202. package/dist/tests/logger.test.cjs +0 -353
  203. package/dist/tests/logger.test.d.ts +0 -1
  204. package/dist/tests/logger.test.js +0 -347
  205. package/dist/tests/mediaCompatibilityMiddleware.test.cjs +0 -106
  206. package/dist/tests/mediaCompatibilityMiddleware.test.d.ts +0 -1
  207. package/dist/tests/mediaCompatibilityMiddleware.test.js +0 -100
  208. package/dist/tests/node-tools.test.cjs +0 -77
  209. package/dist/tests/node-tools.test.d.ts +0 -1
  210. package/dist/tests/node-tools.test.js +0 -71
  211. package/dist/tests/nodes-api.test.cjs +0 -86
  212. package/dist/tests/nodes-api.test.d.ts +0 -1
  213. package/dist/tests/nodes-api.test.js +0 -80
  214. package/dist/tests/outputManagerContextSummarized.test.cjs +0 -43
  215. package/dist/tests/outputManagerContextSummarized.test.d.ts +0 -1
  216. package/dist/tests/outputManagerContextSummarized.test.js +0 -37
  217. package/dist/tests/provider-command-codex.test.cjs +0 -57
  218. package/dist/tests/provider-command-codex.test.d.ts +0 -1
  219. package/dist/tests/provider-command-codex.test.js +0 -51
  220. package/dist/tests/routines-api.test.cjs +0 -107
  221. package/dist/tests/routines-api.test.d.ts +0 -1
  222. package/dist/tests/routines-api.test.js +0 -101
  223. package/dist/tests/run-terminal-bench-official-script.test.cjs +0 -61
  224. package/dist/tests/run-terminal-bench-official-script.test.d.ts +0 -1
  225. package/dist/tests/run-terminal-bench-official-script.test.js +0 -55
  226. package/dist/tests/sessionManager-uionly.test.cjs +0 -50
  227. package/dist/tests/sessionManager-uionly.test.d.ts +0 -1
  228. package/dist/tests/sessionManager-uionly.test.js +0 -44
  229. package/dist/tests/sessionMessageAttachments.test.cjs +0 -197
  230. package/dist/tests/sessionMessageAttachments.test.d.ts +0 -1
  231. package/dist/tests/sessionMessageAttachments.test.js +0 -191
  232. package/dist/tests/sessionMessageRole.test.cjs +0 -44
  233. package/dist/tests/sessionMessageRole.test.d.ts +0 -1
  234. package/dist/tests/sessionMessageRole.test.js +0 -38
  235. package/dist/tests/sessionStateMessages.test.cjs +0 -236
  236. package/dist/tests/sessionStateMessages.test.d.ts +0 -1
  237. package/dist/tests/sessionStateMessages.test.js +0 -230
  238. package/dist/tests/sessions-api.test.cjs +0 -250
  239. package/dist/tests/sessions-api.test.d.ts +0 -1
  240. package/dist/tests/sessions-api.test.js +0 -244
  241. package/dist/tests/skill-activation.test.cjs +0 -86
  242. package/dist/tests/skill-activation.test.d.ts +0 -1
  243. package/dist/tests/skill-activation.test.js +0 -80
  244. package/dist/tests/skill-metadata.test.cjs +0 -119
  245. package/dist/tests/skill-metadata.test.d.ts +0 -1
  246. package/dist/tests/skill-metadata.test.js +0 -113
  247. package/dist/tests/skill-repository.test.cjs +0 -469
  248. package/dist/tests/skill-repository.test.d.ts +0 -1
  249. package/dist/tests/skill-repository.test.js +0 -463
  250. package/dist/tests/skill-security-scanner.test.cjs +0 -126
  251. package/dist/tests/skill-security-scanner.test.d.ts +0 -1
  252. package/dist/tests/skill-security-scanner.test.js +0 -120
  253. package/dist/tests/sms-api.test.cjs +0 -183
  254. package/dist/tests/sms-api.test.d.ts +0 -1
  255. package/dist/tests/sms-api.test.js +0 -177
  256. package/dist/tests/sms-commands.test.cjs +0 -90
  257. package/dist/tests/sms-commands.test.d.ts +0 -1
  258. package/dist/tests/sms-commands.test.js +0 -84
  259. package/dist/tests/sms-policy-store.test.cjs +0 -69
  260. package/dist/tests/sms-policy-store.test.d.ts +0 -1
  261. package/dist/tests/sms-policy-store.test.js +0 -63
  262. package/dist/tests/teams-adapter.test.cjs +0 -58
  263. package/dist/tests/teams-adapter.test.d.ts +0 -1
  264. package/dist/tests/teams-adapter.test.js +0 -52
  265. package/dist/tests/technicalIndicators.test.cjs +0 -82
  266. package/dist/tests/technicalIndicators.test.d.ts +0 -1
  267. package/dist/tests/technicalIndicators.test.js +0 -76
  268. package/dist/tests/terminal-bench-adapters-helpers.test.cjs +0 -64
  269. package/dist/tests/terminal-bench-adapters-helpers.test.d.ts +0 -1
  270. package/dist/tests/terminal-bench-adapters-helpers.test.js +0 -58
  271. package/dist/tests/terminal-bench-cleanup.test.cjs +0 -93
  272. package/dist/tests/terminal-bench-cleanup.test.d.ts +0 -1
  273. package/dist/tests/terminal-bench-cleanup.test.js +0 -87
  274. package/dist/tests/terminal-bench-config.test.cjs +0 -62
  275. package/dist/tests/terminal-bench-config.test.d.ts +0 -1
  276. package/dist/tests/terminal-bench-config.test.js +0 -56
  277. package/dist/tests/terminal-bench-official.test.cjs +0 -194
  278. package/dist/tests/terminal-bench-official.test.d.ts +0 -1
  279. package/dist/tests/terminal-bench-official.test.js +0 -188
  280. package/dist/tests/terminal-bench-runner.test.cjs +0 -82
  281. package/dist/tests/terminal-bench-runner.test.d.ts +0 -1
  282. package/dist/tests/terminal-bench-runner.test.js +0 -76
  283. package/dist/tests/terminal-bench-scoring.test.cjs +0 -128
  284. package/dist/tests/terminal-bench-scoring.test.d.ts +0 -1
  285. package/dist/tests/terminal-bench-scoring.test.js +0 -122
  286. package/dist/tests/terminalProbe.test.cjs +0 -45
  287. package/dist/tests/terminalProbe.test.d.ts +0 -1
  288. package/dist/tests/terminalProbe.test.js +0 -39
  289. package/dist/tests/terminalProbeAuth.test.cjs +0 -85
  290. package/dist/tests/terminalProbeAuth.test.d.ts +0 -1
  291. package/dist/tests/terminalProbeAuth.test.js +0 -79
  292. package/dist/tests/toolDisplayHelpers.test.cjs +0 -46
  293. package/dist/tests/toolDisplayHelpers.test.d.ts +0 -1
  294. package/dist/tests/toolDisplayHelpers.test.js +0 -40
  295. package/dist/tests/uv.test.cjs +0 -47
  296. package/dist/tests/uv.test.d.ts +0 -1
  297. package/dist/tests/uv.test.js +0 -41
  298. package/dist/tests/voice-config.test.cjs +0 -35
  299. package/dist/tests/voice-config.test.d.ts +0 -1
  300. package/dist/tests/voice-config.test.js +0 -29
  301. package/dist/tests/websocket-transport.test.cjs +0 -31
  302. package/dist/tests/websocket-transport.test.d.ts +0 -1
  303. package/dist/tests/websocket-transport.test.js +0 -25
  304. package/dist/tests/yahooCandles.test.cjs +0 -111
  305. package/dist/tests/yahooCandles.test.d.ts +0 -1
  306. package/dist/tests/yahooCandles.test.js +0 -105
  307. package/dist/tools/finance/optionsAnalytics.test.cjs +0 -128
  308. package/dist/tools/finance/optionsAnalytics.test.d.ts +0 -1
  309. package/dist/tools/finance/optionsAnalytics.test.js +0 -122
  310. package/dist/webui/assets/index-D07GBGp0.js +0 -215
  311. package/dist/webui/assets/index-DV8IYeOw.css +0 -11
@@ -1,607 +0,0 @@
1
- import { createDeepAgent } from "deepagents";
2
- import { describe, expect, it, vi } from "vitest";
3
- import { validateConfig } from "../cli/config/schema.js";
4
- import { chunkBelongsToSummarizationMiddleware, chunkHasAssistantText, chunkHasBuiltInSummarizationSignal, chunkSignalsActiveSummarization, configureDeepAgentSummarizationMiddleware, detectContextSummarizationTransition, detectStreamErrorMessage, detectToolEventContext, emitCompletionAndContinuePostProcessing, isRootLangGraphTerminalEvent, recompileDeepAgentWithMiddlewareOverrides, resolveHumanInTheLoopSettings, resolveModelRetryMiddlewareSettings, resolveSummarizationMiddlewareSettings, resolveToolRetryMiddlewareSettings, selectStreamingFallbackText, trackRootLangGraphRunId } from "../cli/core/agentInvoker.js";
5
- const parseConfig = (input)=>{
6
- const result = validateConfig(input);
7
- if (!result.success || !result.data) throw new Error(result.error || "Expected config validation to succeed");
8
- return result.data;
9
- };
10
- describe("resolveSummarizationMiddlewareSettings", ()=>{
11
- it("returns default summarization settings from config defaults", ()=>{
12
- const config = parseConfig({});
13
- expect(resolveSummarizationMiddlewareSettings(config)).toEqual({
14
- maxTokensBeforeSummary: 12000,
15
- messagesToKeep: 8
16
- });
17
- });
18
- it("returns null when summarization is disabled", ()=>{
19
- const config = parseConfig({
20
- summarization: {
21
- enabled: false
22
- }
23
- });
24
- expect(resolveSummarizationMiddlewareSettings(config)).toBeNull();
25
- });
26
- it("returns custom summarization settings when configured", ()=>{
27
- const config = parseConfig({
28
- summarization: {
29
- enabled: true,
30
- maxTokensBeforeSummary: 20000,
31
- messagesToKeep: 10
32
- }
33
- });
34
- expect(resolveSummarizationMiddlewareSettings(config)).toEqual({
35
- maxTokensBeforeSummary: 20000,
36
- messagesToKeep: 10
37
- });
38
- });
39
- });
40
- describe("configureDeepAgentSummarizationMiddleware", ()=>{
41
- it("replaces built-in summarization middleware with configured settings", ()=>{
42
- const agent = {
43
- options: {
44
- middleware: [
45
- {
46
- name: "todoListMiddleware"
47
- },
48
- {
49
- name: "SummarizationMiddleware",
50
- marker: "old"
51
- }
52
- ]
53
- }
54
- };
55
- configureDeepAgentSummarizationMiddleware(agent, {
56
- maxTokensBeforeSummary: 9000,
57
- messagesToKeep: 5
58
- }, "openai:gpt-4o-mini");
59
- expect(agent.options.middleware).toHaveLength(2);
60
- expect(agent.options.middleware[1]?.name).toBe("SummarizationMiddleware");
61
- expect(agent.options.middleware[1]?.marker).toBeUndefined();
62
- });
63
- it("removes built-in summarization middleware when disabled", ()=>{
64
- const agent = {
65
- options: {
66
- middleware: [
67
- {
68
- name: "todoListMiddleware"
69
- },
70
- {
71
- name: "SummarizationMiddleware"
72
- },
73
- {
74
- name: "patchToolCallsMiddleware"
75
- }
76
- ]
77
- }
78
- };
79
- configureDeepAgentSummarizationMiddleware(agent, null);
80
- expect(agent.options.middleware.map((m)=>m.name)).toEqual([
81
- "todoListMiddleware",
82
- "patchToolCallsMiddleware"
83
- ]);
84
- });
85
- it("requires recompilation for runtime middleware overrides to take effect", ()=>{
86
- const deepAgent = createDeepAgent({
87
- model: "claude-sonnet-4-5-20250929",
88
- tools: [],
89
- systemPrompt: "test"
90
- });
91
- configureDeepAgentSummarizationMiddleware(deepAgent, {
92
- maxTokensBeforeSummary: 9000,
93
- messagesToKeep: 5
94
- }, "claude-sonnet-4-5-20250929");
95
- expect(Object.keys(deepAgent.graph?.nodes || {})).not.toContain("SummarizationMiddleware.before_model");
96
- const rebuilt = recompileDeepAgentWithMiddlewareOverrides(deepAgent);
97
- expect(Object.keys(rebuilt.graph?.nodes || {})).toContain("SummarizationMiddleware.before_model");
98
- });
99
- });
100
- describe("detectContextSummarizationTransition", ()=>{
101
- it("detects a large context drop after crossing the summarization threshold", ()=>{
102
- expect(detectContextSummarizationTransition({
103
- thresholdTokens: 12000,
104
- peakInputTokens: 11000,
105
- currentInputTokens: 5200
106
- })).toBe(true);
107
- });
108
- it("does not detect summarization before context was near threshold", ()=>{
109
- expect(detectContextSummarizationTransition({
110
- thresholdTokens: 12000,
111
- peakInputTokens: 8200,
112
- currentInputTokens: 4200
113
- })).toBe(false);
114
- });
115
- it("does not detect summarization when context has not dropped enough", ()=>{
116
- expect(detectContextSummarizationTransition({
117
- thresholdTokens: 12000,
118
- peakInputTokens: 11200,
119
- currentInputTokens: 9400
120
- })).toBe(false);
121
- });
122
- });
123
- describe("chunkHasBuiltInSummarizationSignal", ()=>{
124
- it("detects native summarization middleware output events", ()=>{
125
- expect(chunkHasBuiltInSummarizationSignal({
126
- event: "on_chain_end",
127
- name: "SummarizationMiddleware.before_model",
128
- data: {
129
- output: {
130
- messages: [
131
- {
132
- content: "summary",
133
- additional_kwargs: {
134
- lc_source: "summarization"
135
- }
136
- }
137
- ]
138
- }
139
- }
140
- })).toBe(true);
141
- });
142
- it("ignores summarization middleware end events without summary message payload", ()=>{
143
- expect(chunkHasBuiltInSummarizationSignal({
144
- event: "on_chain_end",
145
- name: "SummarizationMiddleware.before_model",
146
- data: {
147
- output: {
148
- messages: [
149
- {
150
- content: "unchanged"
151
- }
152
- ]
153
- }
154
- }
155
- })).toBe(false);
156
- });
157
- it("ignores non-summarization middleware events", ()=>{
158
- expect(chunkHasBuiltInSummarizationSignal({
159
- event: "on_chain_end",
160
- name: "model_request",
161
- data: {
162
- output: {
163
- messages: [
164
- {
165
- content: "summary",
166
- additional_kwargs: {
167
- lc_source: "summarization"
168
- }
169
- }
170
- ]
171
- }
172
- }
173
- })).toBe(false);
174
- });
175
- });
176
- describe("chunkBelongsToSummarizationMiddleware", ()=>{
177
- it("detects summarization chunks by explicit run name", ()=>{
178
- expect(chunkBelongsToSummarizationMiddleware({
179
- event: "on_chat_model_stream",
180
- name: "SummarizationMiddleware.before_model"
181
- })).toBe(true);
182
- });
183
- it("detects summarization chunks by langgraph node metadata", ()=>{
184
- expect(chunkBelongsToSummarizationMiddleware({
185
- event: "on_chat_model_stream",
186
- metadata: {
187
- langgraph_node: "SummarizationMiddleware.before_model"
188
- }
189
- })).toBe(true);
190
- });
191
- it("ignores non-summarization chunks", ()=>{
192
- expect(chunkBelongsToSummarizationMiddleware({
193
- event: "on_chat_model_stream",
194
- name: "chat_model",
195
- metadata: {
196
- langgraph_node: "main"
197
- }
198
- })).toBe(false);
199
- });
200
- });
201
- describe("chunkSignalsActiveSummarization", ()=>{
202
- it("ignores non-model summarization lifecycle events", ()=>{
203
- expect(chunkSignalsActiveSummarization({
204
- event: "on_chain_start",
205
- name: "SummarizationMiddleware.before_model"
206
- })).toBe(false);
207
- });
208
- it("detects summarization model stream events", ()=>{
209
- expect(chunkSignalsActiveSummarization({
210
- event: "on_chat_model_start",
211
- name: "SummarizationMiddleware.before_model"
212
- })).toBe(true);
213
- });
214
- it("ignores model events outside summarization middleware", ()=>{
215
- expect(chunkSignalsActiveSummarization({
216
- event: "on_chat_model_start",
217
- name: "chat_model",
218
- metadata: {
219
- langgraph_node: "main"
220
- }
221
- })).toBe(false);
222
- });
223
- });
224
- describe("resolveModelRetryMiddlewareSettings", ()=>{
225
- it("returns default retry settings when config defaults are used", ()=>{
226
- const config = parseConfig({});
227
- expect(resolveModelRetryMiddlewareSettings(config)).toEqual({
228
- maxRetries: 2,
229
- backoffFactor: 2,
230
- initialDelayMs: 1000,
231
- maxDelayMs: 60000,
232
- jitter: true,
233
- onFailure: "continue"
234
- });
235
- });
236
- it("returns configured retry settings when enabled", ()=>{
237
- const config = parseConfig({
238
- modelRetry: {
239
- enabled: true,
240
- maxRetries: 3,
241
- backoffFactor: 1.5,
242
- initialDelayMs: 250,
243
- maxDelayMs: 5000,
244
- jitter: false,
245
- onFailure: "error"
246
- }
247
- });
248
- expect(resolveModelRetryMiddlewareSettings(config)).toEqual({
249
- maxRetries: 3,
250
- backoffFactor: 1.5,
251
- initialDelayMs: 250,
252
- maxDelayMs: 5000,
253
- jitter: false,
254
- onFailure: "error"
255
- });
256
- });
257
- });
258
- describe("resolveToolRetryMiddlewareSettings", ()=>{
259
- it("returns null by default", ()=>{
260
- const config = parseConfig({});
261
- expect(resolveToolRetryMiddlewareSettings(config)).toBeNull();
262
- });
263
- it("returns configured retry settings and tool filter when enabled", ()=>{
264
- const config = parseConfig({
265
- toolRetry: {
266
- enabled: true,
267
- maxRetries: 4,
268
- backoffFactor: 2,
269
- initialDelayMs: 500,
270
- maxDelayMs: 10000,
271
- jitter: true,
272
- onFailure: "continue",
273
- tools: [
274
- "internet_search",
275
- "web_crawler"
276
- ]
277
- }
278
- });
279
- expect(resolveToolRetryMiddlewareSettings(config)).toEqual({
280
- maxRetries: 4,
281
- backoffFactor: 2,
282
- initialDelayMs: 500,
283
- maxDelayMs: 10000,
284
- jitter: true,
285
- onFailure: "continue",
286
- tools: [
287
- "internet_search",
288
- "web_crawler"
289
- ]
290
- });
291
- });
292
- });
293
- describe("resolveHumanInTheLoopSettings", ()=>{
294
- it("returns null by default", ()=>{
295
- const config = parseConfig({});
296
- expect(resolveHumanInTheLoopSettings(config)).toBeNull();
297
- });
298
- it("returns null when enabled but no tool policy is defined", ()=>{
299
- const config = parseConfig({
300
- humanInTheLoop: {
301
- enabled: true,
302
- interruptOn: {}
303
- }
304
- });
305
- expect(resolveHumanInTheLoopSettings(config)).toBeNull();
306
- });
307
- it("returns interrupt map when enabled with tool policies", ()=>{
308
- const config = parseConfig({
309
- humanInTheLoop: {
310
- enabled: true,
311
- interruptOn: {
312
- command_execute: {
313
- allowedDecisions: [
314
- "approve",
315
- "reject"
316
- ],
317
- description: "Command execution requires approval"
318
- },
319
- internet_search: false
320
- }
321
- }
322
- });
323
- expect(resolveHumanInTheLoopSettings(config)).toEqual({
324
- interruptOn: {
325
- command_execute: {
326
- allowedDecisions: [
327
- "approve",
328
- "reject"
329
- ],
330
- description: "Command execution requires approval"
331
- },
332
- internet_search: false
333
- }
334
- });
335
- });
336
- });
337
- describe("detectToolEventContext", ()=>{
338
- it("extracts tool context for tool start events", ()=>{
339
- const detected = detectToolEventContext({
340
- event: "on_tool_start",
341
- name: "glob"
342
- });
343
- expect(detected).toEqual({
344
- event: "on_tool_start",
345
- toolName: "glob"
346
- });
347
- });
348
- it("extracts tool context for tool error events", ()=>{
349
- const detected = detectToolEventContext({
350
- event: "on_tool_error",
351
- name: "grep"
352
- });
353
- expect(detected).toEqual({
354
- event: "on_tool_error",
355
- toolName: "grep"
356
- });
357
- });
358
- it("returns null for non-tool events", ()=>{
359
- const detected = detectToolEventContext({
360
- event: "on_chat_model_stream",
361
- data: {
362
- chunk: {
363
- text: "hello"
364
- }
365
- }
366
- });
367
- expect(detected).toBeNull();
368
- });
369
- });
370
- describe("chunkHasAssistantText", ()=>{
371
- it("detects text in on_chat_model_stream chunks", ()=>{
372
- expect(chunkHasAssistantText({
373
- event: "on_chat_model_stream",
374
- data: {
375
- chunk: {
376
- content: [
377
- {
378
- type: "text",
379
- text: "hello"
380
- }
381
- ]
382
- }
383
- }
384
- })).toBe(true);
385
- });
386
- it("detects text in on_llm_stream chunks", ()=>{
387
- expect(chunkHasAssistantText({
388
- event: "on_llm_stream",
389
- data: {
390
- chunk: {
391
- text: "delta"
392
- }
393
- }
394
- })).toBe(true);
395
- });
396
- it("returns false when chunk has no assistant text", ()=>{
397
- expect(chunkHasAssistantText({
398
- event: "on_tool_start",
399
- name: "glob"
400
- })).toBe(false);
401
- });
402
- });
403
- describe("selectStreamingFallbackText", ()=>{
404
- it("returns assistant text introduced during the current invocation", ()=>{
405
- const selected = selectStreamingFallbackText([
406
- {
407
- role: "assistant",
408
- content: "stale message"
409
- }
410
- ], [
411
- {
412
- role: "assistant",
413
- content: "stale message"
414
- },
415
- {
416
- role: "assistant",
417
- content: "fresh fallback"
418
- }
419
- ]);
420
- expect(selected).toBe("fresh fallback");
421
- });
422
- it("returns undefined when no new assistant text is introduced", ()=>{
423
- const selected = selectStreamingFallbackText([
424
- {
425
- role: "assistant",
426
- content: "existing response"
427
- }
428
- ], [
429
- {
430
- role: "user",
431
- content: "not assistant"
432
- },
433
- {
434
- role: "assistant",
435
- content: "existing response"
436
- }
437
- ]);
438
- expect(selected).toBeUndefined();
439
- });
440
- it("handles repeated assistant messages by count", ()=>{
441
- const selected = selectStreamingFallbackText([
442
- {
443
- role: "assistant",
444
- content: "repeat"
445
- }
446
- ], [
447
- {
448
- role: "assistant",
449
- content: "repeat"
450
- },
451
- {
452
- role: "assistant",
453
- content: "repeat"
454
- }
455
- ]);
456
- expect(selected).toBe("repeat");
457
- });
458
- });
459
- describe("detectStreamErrorMessage", ()=>{
460
- it("extracts non-tool stream error messages", ()=>{
461
- const detected = detectStreamErrorMessage({
462
- event: "on_chat_model_error",
463
- data: {
464
- error: {
465
- message: "Model call failed after retries"
466
- }
467
- }
468
- });
469
- expect(detected).toBe("Model call failed after retries");
470
- });
471
- it("ignores tool errors and non-error events", ()=>{
472
- expect(detectStreamErrorMessage({
473
- event: "on_tool_error",
474
- data: {
475
- error: "tool failed"
476
- }
477
- })).toBeUndefined();
478
- expect(detectStreamErrorMessage({
479
- event: "on_chat_model_stream",
480
- data: {
481
- chunk: {
482
- text: "hello"
483
- }
484
- }
485
- })).toBeUndefined();
486
- });
487
- });
488
- describe("LangGraph lifecycle termination", ()=>{
489
- it("tracks root LangGraph run id from parentless on_chain_start", ()=>{
490
- const rootRunId = trackRootLangGraphRunId(void 0, {
491
- event: "on_chain_start",
492
- name: "LangGraph",
493
- run_id: "root-run",
494
- parent_ids: []
495
- });
496
- expect(rootRunId).toBe("root-run");
497
- });
498
- it("ignores non-root or non-LangGraph start events", ()=>{
499
- const nestedRunId = trackRootLangGraphRunId(void 0, {
500
- event: "on_chain_start",
501
- name: "LangGraph",
502
- run_id: "child-run",
503
- parent_ids: [
504
- "root-run"
505
- ]
506
- });
507
- expect(nestedRunId).toBeUndefined();
508
- const otherChainRunId = trackRootLangGraphRunId(void 0, {
509
- event: "on_chain_start",
510
- name: "CustomChain",
511
- run_id: "other-run",
512
- parent_ids: []
513
- });
514
- expect(otherChainRunId).toBeUndefined();
515
- });
516
- it("detects terminal root LangGraph on_chain_end by run id", ()=>{
517
- expect(isRootLangGraphTerminalEvent({
518
- event: "on_chain_end",
519
- name: "LangGraph",
520
- run_id: "root-run",
521
- parent_ids: []
522
- }, "root-run")).toBe(true);
523
- });
524
- it("does not treat nested, mismatched, or non-LangGraph chain end as terminal", ()=>{
525
- expect(isRootLangGraphTerminalEvent({
526
- event: "on_chain_end",
527
- name: "LangGraph",
528
- run_id: "child-run",
529
- parent_ids: [
530
- "root-run"
531
- ]
532
- }, "root-run")).toBe(false);
533
- expect(isRootLangGraphTerminalEvent({
534
- event: "on_chain_end",
535
- name: "LangGraph",
536
- run_id: "other-run",
537
- parent_ids: []
538
- }, "root-run")).toBe(false);
539
- expect(isRootLangGraphTerminalEvent({
540
- event: "on_chain_end",
541
- name: "CustomChain",
542
- run_id: "root-run",
543
- parent_ids: []
544
- }, "root-run")).toBe(false);
545
- });
546
- it("treats root LangGraph on_chain_end as terminal even without tracked run id", ()=>{
547
- expect(isRootLangGraphTerminalEvent({
548
- event: "on_chain_end",
549
- name: "LangGraph",
550
- run_id: "root-run",
551
- parent_ids: []
552
- }, void 0)).toBe(true);
553
- });
554
- it("treats root LangGraph on_chain_end as terminal when run id is missing", ()=>{
555
- expect(isRootLangGraphTerminalEvent({
556
- event: "on_chain_end",
557
- name: "LangGraph",
558
- parent_ids: []
559
- }, "root-run")).toBe(true);
560
- });
561
- });
562
- describe("emitCompletionAndContinuePostProcessing", ()=>{
563
- it("emits completion before post-processing resolves", ()=>{
564
- const callOrder = [];
565
- let resolvePostProcess;
566
- const postProcess = ()=>new Promise((resolve)=>{
567
- callOrder.push("post-process-start");
568
- resolvePostProcess = resolve;
569
- });
570
- emitCompletionAndContinuePostProcessing({
571
- outputManager: {
572
- emitAgentComplete: ()=>{
573
- callOrder.push("emit-complete");
574
- }
575
- },
576
- result: {
577
- ok: true
578
- },
579
- postProcess
580
- });
581
- expect(callOrder).toEqual([
582
- "emit-complete",
583
- "post-process-start"
584
- ]);
585
- resolvePostProcess?.();
586
- });
587
- it("logs and swallows post-processing failures", async ()=>{
588
- const debug = vi.fn();
589
- emitCompletionAndContinuePostProcessing({
590
- outputManager: {
591
- emitAgentComplete: vi.fn()
592
- },
593
- result: {
594
- ok: true
595
- },
596
- postProcess: async ()=>{
597
- throw new Error("materialization failed");
598
- },
599
- logger: {
600
- debug
601
- }
602
- });
603
- await Promise.resolve();
604
- await Promise.resolve();
605
- expect(debug).toHaveBeenCalledWith("Failed post-completion processing for streamed agent response", expect.any(Error));
606
- });
607
- });