@machina.ai/cell-cli-core 1.41.1-rc2 → 1.45.1-rc2

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 (834) hide show
  1. package/dist/docs/AFTER_MERGE_PROMPT.md +1 -1
  2. package/dist/docs/changelogs/index.md +63 -0
  3. package/dist/docs/changelogs/latest.md +200 -244
  4. package/dist/docs/changelogs/preview.md +198 -385
  5. package/dist/docs/cli/auto-memory.md +61 -40
  6. package/dist/docs/cli/cli-reference.md +2 -1
  7. package/dist/docs/cli/creating-skills.md +165 -38
  8. package/dist/docs/cli/custom-commands.md +1 -0
  9. package/dist/docs/cli/gemini-md.md +0 -3
  10. package/dist/docs/cli/model-routing.md +3 -3
  11. package/dist/docs/cli/plan-mode.md +2 -2
  12. package/dist/docs/cli/settings.md +20 -19
  13. package/dist/docs/cli/skills-best-practices.md +78 -0
  14. package/dist/docs/cli/skills.md +98 -176
  15. package/dist/docs/cli/tutorials/memory-management.md +3 -3
  16. package/dist/docs/cli/tutorials/session-management.md +13 -0
  17. package/dist/docs/cli/tutorials/skills-getting-started.md +140 -92
  18. package/dist/docs/cli/using-agent-skills.md +90 -0
  19. package/dist/docs/core/gemma-setup.md +83 -0
  20. package/dist/docs/core/index.md +3 -2
  21. package/dist/docs/core/local-model-routing.md +14 -7
  22. package/dist/docs/extensions/reference.md +16 -0
  23. package/dist/docs/extensions/releasing.md +58 -24
  24. package/dist/docs/extensions/writing-extensions.md +7 -0
  25. package/dist/docs/get-started/installation.mdx +2 -2
  26. package/dist/docs/model-routing-spec.md +683 -0
  27. package/dist/docs/reference/commands.md +14 -7
  28. package/dist/docs/reference/configuration.md +264 -88
  29. package/dist/docs/reference/keyboard-shortcuts.md +24 -1
  30. package/dist/docs/reference/policy-engine.md +14 -3
  31. package/dist/docs/reference/tools.md +48 -1
  32. package/dist/docs/releases.md +2 -2
  33. package/dist/docs/sidebar.json +24 -2
  34. package/dist/docs/tools/activate-skill.md +1 -1
  35. package/dist/docs/tools/mcp-server.md +24 -3
  36. package/dist/docs/tools/memory.md +10 -13
  37. package/dist/docs/tools/shell.md +17 -0
  38. package/dist/package.json +18 -18
  39. package/dist/src/agent/content-utils.js +6 -1
  40. package/dist/src/agent/content-utils.js.map +1 -1
  41. package/dist/src/agent/content-utils.test.js +5 -1
  42. package/dist/src/agent/content-utils.test.js.map +1 -1
  43. package/dist/src/agent/event-translator.js +8 -7
  44. package/dist/src/agent/event-translator.js.map +1 -1
  45. package/dist/src/agent/event-translator.test.js +2 -2
  46. package/dist/src/agent/event-translator.test.js.map +1 -1
  47. package/dist/src/agent/legacy-agent-session.js +5 -1
  48. package/dist/src/agent/legacy-agent-session.js.map +1 -1
  49. package/dist/src/agent/legacy-agent-session.test.js +11 -3
  50. package/dist/src/agent/legacy-agent-session.test.js.map +1 -1
  51. package/dist/src/agent/tool-display-utils.d.ts +3 -2
  52. package/dist/src/agent/tool-display-utils.js +3 -2
  53. package/dist/src/agent/tool-display-utils.js.map +1 -1
  54. package/dist/src/agent/types.d.ts +33 -3
  55. package/dist/src/agents/a2aUtils.d.ts +1 -1
  56. package/dist/src/agents/a2aUtils.js +5 -4
  57. package/dist/src/agents/a2aUtils.js.map +1 -1
  58. package/dist/src/agents/a2aUtils.test.js +18 -0
  59. package/dist/src/agents/a2aUtils.test.js.map +1 -1
  60. package/dist/src/agents/agent-tool.d.ts +3 -1
  61. package/dist/src/agents/agent-tool.js +19 -3
  62. package/dist/src/agents/agent-tool.js.map +1 -1
  63. package/dist/src/agents/agent-tool.test.js +76 -0
  64. package/dist/src/agents/agent-tool.test.js.map +1 -1
  65. package/dist/src/agents/agentLoader.d.ts +127 -22
  66. package/dist/src/agents/agentLoader.js +20 -0
  67. package/dist/src/agents/agentLoader.js.map +1 -1
  68. package/dist/src/agents/agentLoader.test.js +60 -0
  69. package/dist/src/agents/agentLoader.test.js.map +1 -1
  70. package/dist/src/agents/auth-provider/types.d.ts +5 -0
  71. package/dist/src/agents/browser/browserAgentInvocation.js +24 -19
  72. package/dist/src/agents/browser/browserAgentInvocation.js.map +1 -1
  73. package/dist/src/agents/browser/snapshotSuperseder.js +11 -8
  74. package/dist/src/agents/browser/snapshotSuperseder.js.map +1 -1
  75. package/dist/src/agents/browser/snapshotSuperseder.test.js +6 -1
  76. package/dist/src/agents/browser/snapshotSuperseder.test.js.map +1 -1
  77. package/dist/src/agents/generalist-agent.js +8 -1
  78. package/dist/src/agents/generalist-agent.js.map +1 -1
  79. package/dist/src/agents/generalist-agent.test.js +24 -0
  80. package/dist/src/agents/generalist-agent.test.js.map +1 -1
  81. package/dist/src/agents/local-executor.d.ts +1 -0
  82. package/dist/src/agents/local-executor.js +76 -45
  83. package/dist/src/agents/local-executor.js.map +1 -1
  84. package/dist/src/agents/local-executor.test.js +199 -27
  85. package/dist/src/agents/local-executor.test.js.map +1 -1
  86. package/dist/src/agents/local-invocation.d.ts +1 -1
  87. package/dist/src/agents/local-invocation.js +47 -48
  88. package/dist/src/agents/local-invocation.js.map +1 -1
  89. package/dist/src/agents/local-invocation.test.js +13 -15
  90. package/dist/src/agents/local-invocation.test.js.map +1 -1
  91. package/dist/src/agents/local-session-invocation.d.ts +51 -0
  92. package/dist/src/agents/local-session-invocation.js +320 -0
  93. package/dist/src/agents/local-session-invocation.js.map +1 -0
  94. package/dist/src/agents/local-session-invocation.test.js +512 -0
  95. package/dist/src/agents/local-session-invocation.test.js.map +1 -0
  96. package/dist/src/agents/local-subagent-protocol.d.ts +18 -0
  97. package/dist/src/agents/local-subagent-protocol.js +357 -0
  98. package/dist/src/agents/local-subagent-protocol.js.map +1 -0
  99. package/dist/src/agents/local-subagent-protocol.test.js +676 -0
  100. package/dist/src/agents/local-subagent-protocol.test.js.map +1 -0
  101. package/dist/src/agents/registry.d.ts +8 -4
  102. package/dist/src/agents/registry.js +112 -47
  103. package/dist/src/agents/registry.js.map +1 -1
  104. package/dist/src/agents/registry.test.js +9 -20
  105. package/dist/src/agents/registry.test.js.map +1 -1
  106. package/dist/src/agents/remote-invocation.js +6 -6
  107. package/dist/src/agents/remote-invocation.js.map +1 -1
  108. package/dist/src/agents/remote-invocation.test.js +23 -12
  109. package/dist/src/agents/remote-invocation.test.js.map +1 -1
  110. package/dist/src/agents/remote-session-invocation.d.ts +48 -0
  111. package/dist/src/agents/remote-session-invocation.js +193 -0
  112. package/dist/src/agents/remote-session-invocation.js.map +1 -0
  113. package/dist/src/agents/remote-session-invocation.test.d.ts +6 -0
  114. package/dist/src/agents/remote-session-invocation.test.js +405 -0
  115. package/dist/src/agents/remote-session-invocation.test.js.map +1 -0
  116. package/dist/src/agents/remote-subagent-protocol.d.ts +42 -0
  117. package/dist/src/agents/remote-subagent-protocol.js +348 -0
  118. package/dist/src/agents/remote-subagent-protocol.js.map +1 -0
  119. package/dist/src/agents/remote-subagent-protocol.test.d.ts +6 -0
  120. package/dist/src/agents/remote-subagent-protocol.test.js +652 -0
  121. package/dist/src/agents/remote-subagent-protocol.test.js.map +1 -0
  122. package/dist/src/agents/skill-extraction-agent.d.ts +8 -1
  123. package/dist/src/agents/skill-extraction-agent.js +171 -21
  124. package/dist/src/agents/skill-extraction-agent.js.map +1 -1
  125. package/dist/src/agents/skill-extraction-agent.test.js +66 -2
  126. package/dist/src/agents/skill-extraction-agent.test.js.map +1 -1
  127. package/dist/src/agents/types.d.ts +38 -2
  128. package/dist/src/agents/types.js +7 -0
  129. package/dist/src/agents/types.js.map +1 -1
  130. package/dist/src/availability/autoRoutingFallback.integration.test.d.ts +6 -0
  131. package/dist/src/availability/autoRoutingFallback.integration.test.js +288 -0
  132. package/dist/src/availability/autoRoutingFallback.integration.test.js.map +1 -0
  133. package/dist/src/availability/fallbackIntegration.test.js +29 -0
  134. package/dist/src/availability/fallbackIntegration.test.js.map +1 -1
  135. package/dist/src/availability/modelAvailabilityService.d.ts +6 -6
  136. package/dist/src/availability/modelAvailabilityService.js +16 -8
  137. package/dist/src/availability/modelAvailabilityService.js.map +1 -1
  138. package/dist/src/availability/modelAvailabilityService.test.js +39 -0
  139. package/dist/src/availability/modelAvailabilityService.test.js.map +1 -1
  140. package/dist/src/availability/modelPolicy.d.ts +1 -0
  141. package/dist/src/availability/policyCatalog.d.ts +2 -0
  142. package/dist/src/availability/policyCatalog.js +38 -9
  143. package/dist/src/availability/policyCatalog.js.map +1 -1
  144. package/dist/src/availability/policyCatalog.test.js +5 -4
  145. package/dist/src/availability/policyCatalog.test.js.map +1 -1
  146. package/dist/src/availability/policyHelpers.js +42 -27
  147. package/dist/src/availability/policyHelpers.js.map +1 -1
  148. package/dist/src/availability/policyHelpers.test.js +47 -7
  149. package/dist/src/availability/policyHelpers.test.js.map +1 -1
  150. package/dist/src/availability/testUtils.js +1 -1
  151. package/dist/src/availability/testUtils.js.map +1 -1
  152. package/dist/src/code_assist/admin/admin_controls.js +3 -1
  153. package/dist/src/code_assist/admin/admin_controls.js.map +1 -1
  154. package/dist/src/code_assist/experiments/flagNames.d.ts +1 -1
  155. package/dist/src/code_assist/experiments/flagNames.js +1 -1
  156. package/dist/src/code_assist/experiments/flagNames.js.map +1 -1
  157. package/dist/src/code_assist/oauth-credential-storage.js +12 -3
  158. package/dist/src/code_assist/oauth-credential-storage.js.map +1 -1
  159. package/dist/src/code_assist/oauth-credential-storage.test.js +29 -2
  160. package/dist/src/code_assist/oauth-credential-storage.test.js.map +1 -1
  161. package/dist/src/code_assist/oauth2.js +12 -3
  162. package/dist/src/code_assist/oauth2.js.map +1 -1
  163. package/dist/src/code_assist/oauth2.test.js +38 -0
  164. package/dist/src/code_assist/oauth2.test.js.map +1 -1
  165. package/dist/src/code_assist/setup.d.ts +3 -0
  166. package/dist/src/code_assist/setup.js +9 -0
  167. package/dist/src/code_assist/setup.js.map +1 -1
  168. package/dist/src/code_assist/setup.test.js +10 -1
  169. package/dist/src/code_assist/setup.test.js.map +1 -1
  170. package/dist/src/commands/memory.d.ts +83 -2
  171. package/dist/src/commands/memory.js +479 -28
  172. package/dist/src/commands/memory.js.map +1 -1
  173. package/dist/src/commands/memory.test.js +414 -58
  174. package/dist/src/commands/memory.test.js.map +1 -1
  175. package/dist/src/config/config.d.ts +61 -37
  176. package/dist/src/config/config.js +294 -101
  177. package/dist/src/config/config.js.map +1 -1
  178. package/dist/src/config/config.test.js +365 -113
  179. package/dist/src/config/config.test.js.map +1 -1
  180. package/dist/src/config/defaultModelConfigs.js +185 -61
  181. package/dist/src/config/defaultModelConfigs.js.map +1 -1
  182. package/dist/src/config/flashFallback.test.js +31 -0
  183. package/dist/src/config/flashFallback.test.js.map +1 -1
  184. package/dist/src/config/models.d.ts +20 -10
  185. package/dist/src/config/models.js +105 -34
  186. package/dist/src/config/models.js.map +1 -1
  187. package/dist/src/config/models.test.js +204 -47
  188. package/dist/src/config/models.test.js.map +1 -1
  189. package/dist/src/config/projectRegistry.d.ts +1 -0
  190. package/dist/src/config/projectRegistry.js +14 -3
  191. package/dist/src/config/projectRegistry.js.map +1 -1
  192. package/dist/src/config/projectRegistry.test.js +43 -0
  193. package/dist/src/config/projectRegistry.test.js.map +1 -1
  194. package/dist/src/config/scoped-config.d.ts +22 -0
  195. package/dist/src/config/scoped-config.js +32 -0
  196. package/dist/src/config/scoped-config.js.map +1 -1
  197. package/dist/src/config/storage.d.ts +0 -1
  198. package/dist/src/config/storage.js +0 -3
  199. package/dist/src/config/storage.js.map +1 -1
  200. package/dist/src/confirmation-bus/message-bus.d.ts +3 -1
  201. package/dist/src/confirmation-bus/message-bus.js +14 -5
  202. package/dist/src/confirmation-bus/message-bus.js.map +1 -1
  203. package/dist/src/confirmation-bus/message-bus.test.js +34 -0
  204. package/dist/src/confirmation-bus/message-bus.test.js.map +1 -1
  205. package/dist/src/context/chatCompressionService.js +7 -5
  206. package/dist/src/context/chatCompressionService.js.map +1 -1
  207. package/dist/src/context/chatCompressionService.test.js +1 -1
  208. package/dist/src/context/chatCompressionService.test.js.map +1 -1
  209. package/dist/src/context/config/configLoader.js +4 -1
  210. package/dist/src/context/config/configLoader.js.map +1 -1
  211. package/dist/src/context/config/profiles.d.ts +10 -0
  212. package/dist/src/context/config/profiles.js +98 -3
  213. package/dist/src/context/config/profiles.js.map +1 -1
  214. package/dist/src/context/config/schema.d.ts +4 -0
  215. package/dist/src/context/config/schema.js +4 -0
  216. package/dist/src/context/config/schema.js.map +1 -1
  217. package/dist/src/context/config/types.d.ts +13 -1
  218. package/dist/src/context/contextCompressionService.test.js +7 -3
  219. package/dist/src/context/contextCompressionService.test.js.map +1 -1
  220. package/dist/src/context/contextManager.barrier.test.js +39 -16
  221. package/dist/src/context/contextManager.barrier.test.js.map +1 -1
  222. package/dist/src/context/contextManager.d.ts +25 -28
  223. package/dist/src/context/contextManager.hotstart.test.d.ts +6 -0
  224. package/dist/src/context/contextManager.hotstart.test.js +65 -0
  225. package/dist/src/context/contextManager.hotstart.test.js.map +1 -0
  226. package/dist/src/context/contextManager.incremental.test.d.ts +6 -0
  227. package/dist/src/context/contextManager.incremental.test.js +101 -0
  228. package/dist/src/context/contextManager.incremental.test.js.map +1 -0
  229. package/dist/src/context/contextManager.js +276 -79
  230. package/dist/src/context/contextManager.js.map +1 -1
  231. package/dist/src/context/contextManager.test.d.ts +6 -0
  232. package/dist/src/context/contextManager.test.js +142 -0
  233. package/dist/src/context/contextManager.test.js.map +1 -0
  234. package/dist/src/context/eventBus.d.ts +13 -0
  235. package/dist/src/context/eventBus.js +12 -0
  236. package/dist/src/context/eventBus.js.map +1 -1
  237. package/dist/src/context/graph/behaviorRegistry.d.ts +4 -12
  238. package/dist/src/context/graph/behaviorRegistry.js.map +1 -1
  239. package/dist/src/context/graph/builtinBehaviors.d.ts +6 -1
  240. package/dist/src/context/graph/builtinBehaviors.js +23 -108
  241. package/dist/src/context/graph/builtinBehaviors.js.map +1 -1
  242. package/dist/src/context/graph/fromGraph.d.ts +8 -3
  243. package/dist/src/context/graph/fromGraph.js +46 -30
  244. package/dist/src/context/graph/fromGraph.js.map +1 -1
  245. package/dist/src/context/graph/fromGraph.test.d.ts +6 -0
  246. package/dist/src/context/graph/fromGraph.test.js +186 -0
  247. package/dist/src/context/graph/fromGraph.test.js.map +1 -0
  248. package/dist/src/context/graph/mapper.d.ts +8 -10
  249. package/dist/src/context/graph/mapper.js +11 -19
  250. package/dist/src/context/graph/mapper.js.map +1 -1
  251. package/dist/src/context/graph/mapper.test.d.ts +6 -0
  252. package/dist/src/context/graph/mapper.test.js +101 -0
  253. package/dist/src/context/graph/mapper.test.js.map +1 -0
  254. package/dist/src/context/graph/nodeIdService.d.ts +17 -0
  255. package/dist/src/context/graph/nodeIdService.js +24 -0
  256. package/dist/src/context/graph/nodeIdService.js.map +1 -0
  257. package/dist/src/context/graph/render.d.ts +24 -5
  258. package/dist/src/context/graph/render.js +129 -34
  259. package/dist/src/context/graph/render.js.map +1 -1
  260. package/dist/src/context/graph/render.test.d.ts +6 -0
  261. package/dist/src/context/graph/render.test.js +280 -0
  262. package/dist/src/context/graph/render.test.js.map +1 -0
  263. package/dist/src/context/graph/toGraph.d.ts +16 -14
  264. package/dist/src/context/graph/toGraph.js +180 -202
  265. package/dist/src/context/graph/toGraph.js.map +1 -1
  266. package/dist/src/context/graph/toGraph.test.d.ts +6 -0
  267. package/dist/src/context/graph/toGraph.test.js +116 -0
  268. package/dist/src/context/graph/toGraph.test.js.map +1 -0
  269. package/dist/src/context/graph/types.d.ts +36 -73
  270. package/dist/src/context/graph/types.js +23 -14
  271. package/dist/src/context/graph/types.js.map +1 -1
  272. package/dist/src/context/initializer.js +26 -5
  273. package/dist/src/context/initializer.js.map +1 -1
  274. package/dist/src/context/pipeline/contextWorkingBuffer.d.ts +5 -8
  275. package/dist/src/context/pipeline/contextWorkingBuffer.js +105 -35
  276. package/dist/src/context/pipeline/contextWorkingBuffer.js.map +1 -1
  277. package/dist/src/context/pipeline/contextWorkingBuffer.test.js +81 -13
  278. package/dist/src/context/pipeline/contextWorkingBuffer.test.js.map +1 -1
  279. package/dist/src/context/pipeline/environment.d.ts +4 -0
  280. package/dist/src/context/pipeline/environmentImpl.d.ts +6 -5
  281. package/dist/src/context/pipeline/environmentImpl.js +7 -9
  282. package/dist/src/context/pipeline/environmentImpl.js.map +1 -1
  283. package/dist/src/context/pipeline/environmentImpl.test.js +5 -1
  284. package/dist/src/context/pipeline/environmentImpl.test.js.map +1 -1
  285. package/dist/src/context/pipeline/orchestrator.d.ts +20 -6
  286. package/dist/src/context/pipeline/orchestrator.js +97 -80
  287. package/dist/src/context/pipeline/orchestrator.js.map +1 -1
  288. package/dist/src/context/pipeline/orchestrator.test.js +33 -36
  289. package/dist/src/context/pipeline/orchestrator.test.js.map +1 -1
  290. package/dist/src/context/pipeline.d.ts +0 -1
  291. package/dist/src/context/processors/blobDegradationProcessor.js +43 -84
  292. package/dist/src/context/processors/blobDegradationProcessor.js.map +1 -1
  293. package/dist/src/context/processors/blobDegradationProcessor.test.js +33 -37
  294. package/dist/src/context/processors/blobDegradationProcessor.test.js.map +1 -1
  295. package/dist/src/context/processors/nodeDistillationProcessor.js +58 -80
  296. package/dist/src/context/processors/nodeDistillationProcessor.js.map +1 -1
  297. package/dist/src/context/processors/nodeDistillationProcessor.test.js +21 -15
  298. package/dist/src/context/processors/nodeDistillationProcessor.test.js.map +1 -1
  299. package/dist/src/context/processors/nodeTruncationProcessor.js +16 -60
  300. package/dist/src/context/processors/nodeTruncationProcessor.js.map +1 -1
  301. package/dist/src/context/processors/nodeTruncationProcessor.test.js +16 -19
  302. package/dist/src/context/processors/nodeTruncationProcessor.test.js.map +1 -1
  303. package/dist/src/context/processors/rollingSummaryProcessor.js +12 -25
  304. package/dist/src/context/processors/rollingSummaryProcessor.js.map +1 -1
  305. package/dist/src/context/processors/rollingSummaryProcessor.test.js +10 -9
  306. package/dist/src/context/processors/rollingSummaryProcessor.test.js.map +1 -1
  307. package/dist/src/context/processors/stateSnapshotAsyncProcessor.d.ts +7 -0
  308. package/dist/src/context/processors/stateSnapshotAsyncProcessor.js +37 -19
  309. package/dist/src/context/processors/stateSnapshotAsyncProcessor.js.map +1 -1
  310. package/dist/src/context/processors/stateSnapshotAsyncProcessor.test.js +35 -10
  311. package/dist/src/context/processors/stateSnapshotAsyncProcessor.test.js.map +1 -1
  312. package/dist/src/context/processors/stateSnapshotProcessor.d.ts +2 -0
  313. package/dist/src/context/processors/stateSnapshotProcessor.js +53 -21
  314. package/dist/src/context/processors/stateSnapshotProcessor.js.map +1 -1
  315. package/dist/src/context/processors/stateSnapshotProcessor.test.js +52 -12
  316. package/dist/src/context/processors/stateSnapshotProcessor.test.js.map +1 -1
  317. package/dist/src/context/processors/toolMaskingProcessor.js +96 -117
  318. package/dist/src/context/processors/toolMaskingProcessor.js.map +1 -1
  319. package/dist/src/context/processors/toolMaskingProcessor.test.js +50 -17
  320. package/dist/src/context/processors/toolMaskingProcessor.test.js.map +1 -1
  321. package/dist/src/context/system-tests/hysteresis.test.d.ts +6 -0
  322. package/dist/src/context/system-tests/hysteresis.test.js +100 -0
  323. package/dist/src/context/system-tests/hysteresis.test.js.map +1 -0
  324. package/dist/src/context/system-tests/lifecycle.golden.test.js +107 -72
  325. package/dist/src/context/system-tests/lifecycle.golden.test.js.map +1 -1
  326. package/dist/src/context/system-tests/powerUserLifecycle.test.d.ts +6 -0
  327. package/dist/src/context/system-tests/powerUserLifecycle.test.js +91 -0
  328. package/dist/src/context/system-tests/powerUserLifecycle.test.js.map +1 -0
  329. package/dist/src/context/system-tests/simulationHarness.d.ts +2 -5
  330. package/dist/src/context/system-tests/simulationHarness.js +34 -35
  331. package/dist/src/context/system-tests/simulationHarness.js.map +1 -1
  332. package/dist/src/context/testing/contextTestUtils.d.ts +5 -3
  333. package/dist/src/context/testing/contextTestUtils.js +74 -53
  334. package/dist/src/context/testing/contextTestUtils.js.map +1 -1
  335. package/dist/src/context/testing/testProfile.js +1 -0
  336. package/dist/src/context/testing/testProfile.js.map +1 -1
  337. package/dist/src/context/toolOutputMaskingService.js +1 -2
  338. package/dist/src/context/toolOutputMaskingService.js.map +1 -1
  339. package/dist/src/context/toolOutputMaskingService.test.js +5 -20
  340. package/dist/src/context/toolOutputMaskingService.test.js.map +1 -1
  341. package/dist/src/context/utils/adaptiveTokenCalculator.d.ts +70 -0
  342. package/dist/src/context/utils/adaptiveTokenCalculator.js +138 -0
  343. package/dist/src/context/utils/adaptiveTokenCalculator.js.map +1 -0
  344. package/dist/src/context/utils/adaptiveTokenCalculator.test.d.ts +6 -0
  345. package/dist/src/context/utils/adaptiveTokenCalculator.test.js +129 -0
  346. package/dist/src/context/utils/adaptiveTokenCalculator.test.js.map +1 -0
  347. package/dist/src/context/utils/contextTokenCalculator.d.ts +63 -2
  348. package/dist/src/context/utils/contextTokenCalculator.js +80 -5
  349. package/dist/src/context/utils/contextTokenCalculator.js.map +1 -1
  350. package/dist/src/context/utils/contextTokenCalculator.test.d.ts +6 -0
  351. package/dist/src/context/utils/contextTokenCalculator.test.js +54 -0
  352. package/dist/src/context/utils/contextTokenCalculator.test.js.map +1 -0
  353. package/dist/src/context/utils/formatNodesForLlm.d.ts +21 -0
  354. package/dist/src/context/utils/formatNodesForLlm.js +69 -0
  355. package/dist/src/context/utils/formatNodesForLlm.js.map +1 -0
  356. package/dist/src/context/utils/formatNodesForLlm.test.d.ts +6 -0
  357. package/dist/src/context/utils/formatNodesForLlm.test.js +110 -0
  358. package/dist/src/context/utils/formatNodesForLlm.test.js.map +1 -0
  359. package/dist/src/context/utils/invariantChecker.d.ts +11 -0
  360. package/dist/src/context/utils/invariantChecker.js +36 -0
  361. package/dist/src/context/utils/invariantChecker.js.map +1 -0
  362. package/dist/src/context/utils/snapshotGenerator.d.ts +43 -1
  363. package/dist/src/context/utils/snapshotGenerator.js +332 -33
  364. package/dist/src/context/utils/snapshotGenerator.js.map +1 -1
  365. package/dist/src/context/utils/snapshotGenerator.test.d.ts +6 -0
  366. package/dist/src/context/utils/snapshotGenerator.test.js +362 -0
  367. package/dist/src/context/utils/snapshotGenerator.test.js.map +1 -0
  368. package/dist/src/context/utils/tokenCalibration.d.ts +9 -0
  369. package/dist/src/context/utils/tokenCalibration.js +30 -0
  370. package/dist/src/context/utils/tokenCalibration.js.map +1 -0
  371. package/dist/src/core/agentChatHistory.d.ts +29 -14
  372. package/dist/src/core/agentChatHistory.js +27 -27
  373. package/dist/src/core/agentChatHistory.js.map +1 -1
  374. package/dist/src/core/baseLlmClient.d.ts +8 -0
  375. package/dist/src/core/baseLlmClient.js +23 -3
  376. package/dist/src/core/baseLlmClient.js.map +1 -1
  377. package/dist/src/core/baseLlmClient.test.js +27 -23
  378. package/dist/src/core/baseLlmClient.test.js.map +1 -1
  379. package/dist/src/core/client.d.ts +7 -5
  380. package/dist/src/core/client.js +65 -40
  381. package/dist/src/core/client.js.map +1 -1
  382. package/dist/src/core/client.test.js +35 -131
  383. package/dist/src/core/client.test.js.map +1 -1
  384. package/dist/src/core/contentGenerator.js +46 -21
  385. package/dist/src/core/contentGenerator.js.map +1 -1
  386. package/dist/src/core/contentGenerator.test.js +191 -13
  387. package/dist/src/core/contentGenerator.test.js.map +1 -1
  388. package/dist/src/core/fakeContentGenerator.d.ts +15 -3
  389. package/dist/src/core/fakeContentGenerator.js +29 -9
  390. package/dist/src/core/fakeContentGenerator.js.map +1 -1
  391. package/dist/src/core/geminiChat.d.ts +18 -7
  392. package/dist/src/core/geminiChat.js +312 -54
  393. package/dist/src/core/geminiChat.js.map +1 -1
  394. package/dist/src/core/geminiChat.test.js +448 -54
  395. package/dist/src/core/geminiChat.test.js.map +1 -1
  396. package/dist/src/core/geminiChat_network_retry.test.js +39 -0
  397. package/dist/src/core/geminiChat_network_retry.test.js.map +1 -1
  398. package/dist/src/core/localLiteRtLmClient.js +6 -2
  399. package/dist/src/core/localLiteRtLmClient.js.map +1 -1
  400. package/dist/src/core/prompts.test.js +12 -7
  401. package/dist/src/core/prompts.test.js.map +1 -1
  402. package/dist/src/core/turn.d.ts +7 -2
  403. package/dist/src/core/turn.js +61 -4
  404. package/dist/src/core/turn.js.map +1 -1
  405. package/dist/src/core/turn.test.js +19 -10
  406. package/dist/src/core/turn.test.js.map +1 -1
  407. package/dist/src/fallback/handler.js +16 -6
  408. package/dist/src/fallback/handler.js.map +1 -1
  409. package/dist/src/fallback/handler.test.js +8 -2
  410. package/dist/src/fallback/handler.test.js.map +1 -1
  411. package/dist/src/generated/git-commit.d.ts +2 -2
  412. package/dist/src/generated/git-commit.js +2 -2
  413. package/dist/src/hooks/hookEventHandler.js +3 -2
  414. package/dist/src/hooks/hookEventHandler.js.map +1 -1
  415. package/dist/src/hooks/hookEventHandler.test.js +80 -0
  416. package/dist/src/hooks/hookEventHandler.test.js.map +1 -1
  417. package/dist/src/hooks/hookRunner.test.js +3 -3
  418. package/dist/src/hooks/hookRunner.test.js.map +1 -1
  419. package/dist/src/hooks/hookTranslator.js +95 -5
  420. package/dist/src/hooks/hookTranslator.js.map +1 -1
  421. package/dist/src/hooks/hookTranslator.test.js +171 -0
  422. package/dist/src/hooks/hookTranslator.test.js.map +1 -1
  423. package/dist/src/ide/ide-client.js +5 -3
  424. package/dist/src/ide/ide-client.js.map +1 -1
  425. package/dist/src/ide/ide-connection-utils.js +12 -10
  426. package/dist/src/ide/ide-connection-utils.js.map +1 -1
  427. package/dist/src/ide/ide-connection-utils.test.js +25 -2
  428. package/dist/src/ide/ide-connection-utils.test.js.map +1 -1
  429. package/dist/src/ide/types.d.ts +16 -16
  430. package/dist/src/index.d.ts +5 -2
  431. package/dist/src/index.js +5 -3
  432. package/dist/src/index.js.map +1 -1
  433. package/dist/src/mcp/oauth-provider.d.ts +8 -0
  434. package/dist/src/mcp/oauth-provider.js +41 -0
  435. package/dist/src/mcp/oauth-provider.js.map +1 -1
  436. package/dist/src/mcp/oauth-token-storage.js +7 -1
  437. package/dist/src/mcp/oauth-token-storage.js.map +1 -1
  438. package/dist/src/mcp/oauth-token-storage.test.js +55 -0
  439. package/dist/src/mcp/oauth-token-storage.test.js.map +1 -1
  440. package/dist/src/mcp/stored-token-provider.d.ts +27 -0
  441. package/dist/src/mcp/stored-token-provider.js +76 -0
  442. package/dist/src/mcp/stored-token-provider.js.map +1 -0
  443. package/dist/src/mcp/token-storage/keychain-token-storage.js +2 -2
  444. package/dist/src/mcp/token-storage/keychain-token-storage.js.map +1 -1
  445. package/dist/src/mcp/token-storage/keychain-token-storage.test.js +14 -1
  446. package/dist/src/mcp/token-storage/keychain-token-storage.test.js.map +1 -1
  447. package/dist/src/output/json-formatter.d.ts +1 -1
  448. package/dist/src/output/json-formatter.js +4 -1
  449. package/dist/src/output/json-formatter.js.map +1 -1
  450. package/dist/src/output/json-formatter.test.js +7 -0
  451. package/dist/src/output/json-formatter.test.js.map +1 -1
  452. package/dist/src/output/types.d.ts +1 -0
  453. package/dist/src/output/types.js.map +1 -1
  454. package/dist/src/policy/config.js +25 -0
  455. package/dist/src/policy/config.js.map +1 -1
  456. package/dist/src/policy/config.test.js +80 -0
  457. package/dist/src/policy/config.test.js.map +1 -1
  458. package/dist/src/policy/core-tools-mapping.test.js +9 -1
  459. package/dist/src/policy/core-tools-mapping.test.js.map +1 -1
  460. package/dist/src/policy/policies/plan.toml +1 -1
  461. package/dist/src/policy/policies/write.toml +0 -7
  462. package/dist/src/policy/policy-engine.test.js +0 -8
  463. package/dist/src/policy/policy-engine.test.js.map +1 -1
  464. package/dist/src/policy/sandboxPolicyManager.d.ts +20 -20
  465. package/dist/src/policy/stable-stringify.js +10 -6
  466. package/dist/src/policy/stable-stringify.js.map +1 -1
  467. package/dist/src/policy/stable-stringify.test.js +157 -0
  468. package/dist/src/policy/stable-stringify.test.js.map +1 -0
  469. package/dist/src/policy/types.d.ts +1 -0
  470. package/dist/src/policy/types.js.map +1 -1
  471. package/dist/src/prompts/promptProvider.js +8 -9
  472. package/dist/src/prompts/promptProvider.js.map +1 -1
  473. package/dist/src/prompts/promptProvider.test.js +3 -1
  474. package/dist/src/prompts/promptProvider.test.js.map +1 -1
  475. package/dist/src/prompts/snippets-memory.test.d.ts +6 -0
  476. package/dist/src/prompts/{snippets-memory-v2.test.js → snippets-memory.test.js} +5 -23
  477. package/dist/src/prompts/snippets-memory.test.js.map +1 -0
  478. package/dist/src/prompts/snippets.d.ts +6 -11
  479. package/dist/src/prompts/snippets.js +28 -30
  480. package/dist/src/prompts/snippets.js.map +1 -1
  481. package/dist/src/prompts/snippets.legacy.d.ts +0 -1
  482. package/dist/src/prompts/snippets.legacy.js +8 -15
  483. package/dist/src/prompts/snippets.legacy.js.map +1 -1
  484. package/dist/src/routing/strategies/approvalModeStrategy.js +5 -3
  485. package/dist/src/routing/strategies/approvalModeStrategy.js.map +1 -1
  486. package/dist/src/routing/strategies/approvalModeStrategy.test.js +9 -0
  487. package/dist/src/routing/strategies/approvalModeStrategy.test.js.map +1 -1
  488. package/dist/src/routing/strategies/classifierStrategy.js +18 -4
  489. package/dist/src/routing/strategies/classifierStrategy.js.map +1 -1
  490. package/dist/src/routing/strategies/classifierStrategy.test.js +77 -1
  491. package/dist/src/routing/strategies/classifierStrategy.test.js.map +1 -1
  492. package/dist/src/routing/strategies/defaultStrategy.js +1 -1
  493. package/dist/src/routing/strategies/defaultStrategy.js.map +1 -1
  494. package/dist/src/routing/strategies/fallbackStrategy.js +1 -1
  495. package/dist/src/routing/strategies/fallbackStrategy.js.map +1 -1
  496. package/dist/src/routing/strategies/gemmaClassifierStrategy.js +7 -1
  497. package/dist/src/routing/strategies/gemmaClassifierStrategy.js.map +1 -1
  498. package/dist/src/routing/strategies/gemmaClassifierStrategy.test.js +15 -1
  499. package/dist/src/routing/strategies/gemmaClassifierStrategy.test.js.map +1 -1
  500. package/dist/src/routing/strategies/numericalClassifierStrategy.d.ts +1 -0
  501. package/dist/src/routing/strategies/numericalClassifierStrategy.js +32 -5
  502. package/dist/src/routing/strategies/numericalClassifierStrategy.js.map +1 -1
  503. package/dist/src/routing/strategies/numericalClassifierStrategy.test.js +247 -25
  504. package/dist/src/routing/strategies/numericalClassifierStrategy.test.js.map +1 -1
  505. package/dist/src/routing/strategies/overrideStrategy.js +1 -1
  506. package/dist/src/routing/strategies/overrideStrategy.js.map +1 -1
  507. package/dist/src/sandbox/utils/commandSafety.js +22 -2
  508. package/dist/src/sandbox/utils/commandSafety.js.map +1 -1
  509. package/dist/src/sandbox/utils/commandSafety.test.d.ts +6 -0
  510. package/dist/src/sandbox/utils/commandSafety.test.js +85 -0
  511. package/dist/src/sandbox/utils/commandSafety.test.js.map +1 -0
  512. package/dist/src/scheduler/confirmation.test.js +29 -0
  513. package/dist/src/scheduler/confirmation.test.js.map +1 -1
  514. package/dist/src/scheduler/scheduler.js +15 -0
  515. package/dist/src/scheduler/scheduler.js.map +1 -1
  516. package/dist/src/scheduler/scheduler.test.js +1 -1
  517. package/dist/src/scheduler/scheduler.test.js.map +1 -1
  518. package/dist/src/scheduler/scheduler_parallel.test.js +37 -0
  519. package/dist/src/scheduler/scheduler_parallel.test.js.map +1 -1
  520. package/dist/src/scheduler/state-manager.js +5 -1
  521. package/dist/src/scheduler/state-manager.js.map +1 -1
  522. package/dist/src/scheduler/tool-executor.js +7 -4
  523. package/dist/src/scheduler/tool-executor.js.map +1 -1
  524. package/dist/src/scheduler/types.d.ts +5 -1
  525. package/dist/src/scheduler/types.js.map +1 -1
  526. package/dist/src/services/chatRecordingService.d.ts +14 -7
  527. package/dist/src/services/chatRecordingService.js +157 -133
  528. package/dist/src/services/chatRecordingService.js.map +1 -1
  529. package/dist/src/services/chatRecordingService.test.js +189 -52
  530. package/dist/src/services/chatRecordingService.test.js.map +1 -1
  531. package/dist/src/services/fileDiscoveryService.js +2 -1
  532. package/dist/src/services/fileDiscoveryService.js.map +1 -1
  533. package/dist/src/services/fileDiscoveryService.test.js +36 -0
  534. package/dist/src/services/fileDiscoveryService.test.js.map +1 -1
  535. package/dist/src/services/gitService.js +43 -4
  536. package/dist/src/services/gitService.js.map +1 -1
  537. package/dist/src/services/gitService.test.js +105 -1
  538. package/dist/src/services/gitService.test.js.map +1 -1
  539. package/dist/src/services/keychainService.js +14 -5
  540. package/dist/src/services/keychainService.js.map +1 -1
  541. package/dist/src/services/memoryPatchUtils.d.ts +93 -0
  542. package/dist/src/services/memoryPatchUtils.js +310 -2
  543. package/dist/src/services/memoryPatchUtils.js.map +1 -1
  544. package/dist/src/services/memoryService.d.ts +2 -0
  545. package/dist/src/services/memoryService.js +214 -9
  546. package/dist/src/services/memoryService.js.map +1 -1
  547. package/dist/src/services/memoryService.test.js +133 -0
  548. package/dist/src/services/memoryService.test.js.map +1 -1
  549. package/dist/src/services/modelConfigService.d.ts +3 -0
  550. package/dist/src/services/modelConfigService.js +22 -13
  551. package/dist/src/services/modelConfigService.js.map +1 -1
  552. package/dist/src/services/modelConfigService.test.js +73 -0
  553. package/dist/src/services/modelConfigService.test.js.map +1 -1
  554. package/dist/src/services/shellExecutionService.js +88 -41
  555. package/dist/src/services/shellExecutionService.js.map +1 -1
  556. package/dist/src/services/shellExecutionService.test.js +22 -9
  557. package/dist/src/services/shellExecutionService.test.js.map +1 -1
  558. package/dist/src/services/shellExecutionService.windows.integration.test.d.ts +6 -0
  559. package/dist/src/services/shellExecutionService.windows.integration.test.js +63 -0
  560. package/dist/src/services/shellExecutionService.windows.integration.test.js.map +1 -0
  561. package/dist/src/services/test-data/resolved-aliases-retry.golden.json +85 -7
  562. package/dist/src/services/test-data/resolved-aliases.golden.json +85 -7
  563. package/dist/src/services/trackerTypes.d.ts +4 -4
  564. package/dist/src/skills/skillManager.d.ts +4 -0
  565. package/dist/src/skills/skillManager.js +6 -0
  566. package/dist/src/skills/skillManager.js.map +1 -1
  567. package/dist/src/skills/skillManager.test.js +10 -0
  568. package/dist/src/skills/skillManager.test.js.map +1 -1
  569. package/dist/src/telemetry/file-exporters.d.ts +4 -1
  570. package/dist/src/telemetry/file-exporters.js +21 -3
  571. package/dist/src/telemetry/file-exporters.js.map +1 -1
  572. package/dist/src/telemetry/file-exporters.test.js +32 -2
  573. package/dist/src/telemetry/file-exporters.test.js.map +1 -1
  574. package/dist/src/telemetry/gcp-exporters.d.ts +3 -0
  575. package/dist/src/telemetry/gcp-exporters.js +72 -5
  576. package/dist/src/telemetry/gcp-exporters.js.map +1 -1
  577. package/dist/src/telemetry/gcp-exporters.test.js +52 -0
  578. package/dist/src/telemetry/gcp-exporters.test.js.map +1 -1
  579. package/dist/src/telemetry/heap-snapshot.d.ts +12 -0
  580. package/dist/src/telemetry/heap-snapshot.js +35 -0
  581. package/dist/src/telemetry/heap-snapshot.js.map +1 -0
  582. package/dist/src/telemetry/heap-snapshot.test.d.ts +6 -0
  583. package/dist/src/telemetry/heap-snapshot.test.js +38 -0
  584. package/dist/src/telemetry/heap-snapshot.test.js.map +1 -0
  585. package/dist/src/telemetry/index.d.ts +1 -0
  586. package/dist/src/telemetry/index.js +1 -0
  587. package/dist/src/telemetry/index.js.map +1 -1
  588. package/dist/src/telemetry/loggers.test.js +1 -0
  589. package/dist/src/telemetry/loggers.test.js.map +1 -1
  590. package/dist/src/telemetry/memory-monitor.d.ts +5 -0
  591. package/dist/src/telemetry/memory-monitor.js +8 -0
  592. package/dist/src/telemetry/memory-monitor.js.map +1 -1
  593. package/dist/src/telemetry/metrics.js +13 -2
  594. package/dist/src/telemetry/metrics.js.map +1 -1
  595. package/dist/src/telemetry/metrics.test.js +61 -1
  596. package/dist/src/telemetry/metrics.test.js.map +1 -1
  597. package/dist/src/test-utils/config.js +10 -1
  598. package/dist/src/test-utils/config.js.map +1 -1
  599. package/dist/src/tools/ask-user.js +25 -1
  600. package/dist/src/tools/ask-user.js.map +1 -1
  601. package/dist/src/tools/ask-user.test.js +46 -1
  602. package/dist/src/tools/ask-user.test.js.map +1 -1
  603. package/dist/src/tools/definitions/base-declarations.d.ts +0 -3
  604. package/dist/src/tools/definitions/base-declarations.js +0 -4
  605. package/dist/src/tools/definitions/base-declarations.js.map +1 -1
  606. package/dist/src/tools/definitions/coreTools.d.ts +1 -2
  607. package/dist/src/tools/definitions/coreTools.js +2 -8
  608. package/dist/src/tools/definitions/coreTools.js.map +1 -1
  609. package/dist/src/tools/definitions/coreToolsModelSnapshots.test.js +1 -2
  610. package/dist/src/tools/definitions/coreToolsModelSnapshots.test.js.map +1 -1
  611. package/dist/src/tools/definitions/model-family-sets/default-legacy.js +7 -31
  612. package/dist/src/tools/definitions/model-family-sets/default-legacy.js.map +1 -1
  613. package/dist/src/tools/definitions/model-family-sets/gemini-3.js +9 -26
  614. package/dist/src/tools/definitions/model-family-sets/gemini-3.js.map +1 -1
  615. package/dist/src/tools/definitions/types.d.ts +0 -1
  616. package/dist/src/tools/edit.js +27 -5
  617. package/dist/src/tools/edit.js.map +1 -1
  618. package/dist/src/tools/edit.test.js +37 -0
  619. package/dist/src/tools/edit.test.js.map +1 -1
  620. package/dist/src/tools/grep.js +14 -2
  621. package/dist/src/tools/grep.js.map +1 -1
  622. package/dist/src/tools/grep.test.js +17 -0
  623. package/dist/src/tools/grep.test.js.map +1 -1
  624. package/dist/src/tools/jit-context.d.ts +1 -1
  625. package/dist/src/tools/jit-context.js +1 -4
  626. package/dist/src/tools/jit-context.js.map +1 -1
  627. package/dist/src/tools/jit-context.test.js +1 -13
  628. package/dist/src/tools/jit-context.test.js.map +1 -1
  629. package/dist/src/tools/ls.js +5 -0
  630. package/dist/src/tools/ls.js.map +1 -1
  631. package/dist/src/tools/mcp-client-manager.js +2 -1
  632. package/dist/src/tools/mcp-client-manager.js.map +1 -1
  633. package/dist/src/tools/mcp-client-manager.test.js +29 -0
  634. package/dist/src/tools/mcp-client-manager.test.js.map +1 -1
  635. package/dist/src/tools/mcp-client.js +89 -50
  636. package/dist/src/tools/mcp-client.js.map +1 -1
  637. package/dist/src/tools/mcp-client.test.js +353 -59
  638. package/dist/src/tools/mcp-client.test.js.map +1 -1
  639. package/dist/src/tools/{xcode-mcp-fix-transport.d.ts → mcp-compliance-transport.d.ts} +6 -6
  640. package/dist/src/tools/{xcode-mcp-fix-transport.js → mcp-compliance-transport.js} +6 -6
  641. package/dist/src/tools/mcp-compliance-transport.js.map +1 -0
  642. package/dist/src/tools/mcp-compliance-transport.test.d.ts +6 -0
  643. package/dist/src/tools/mcp-compliance-transport.test.js +162 -0
  644. package/dist/src/tools/mcp-compliance-transport.test.js.map +1 -0
  645. package/dist/src/tools/memoryTool.d.ts +9 -31
  646. package/dist/src/tools/memoryTool.js +47 -262
  647. package/dist/src/tools/memoryTool.js.map +1 -1
  648. package/dist/src/tools/memoryTool.test.js +41 -312
  649. package/dist/src/tools/memoryTool.test.js.map +1 -1
  650. package/dist/src/tools/read-file.js +11 -6
  651. package/dist/src/tools/read-file.js.map +1 -1
  652. package/dist/src/tools/read-file.test.js +20 -8
  653. package/dist/src/tools/read-file.test.js.map +1 -1
  654. package/dist/src/tools/read-many-files.js +2 -2
  655. package/dist/src/tools/read-many-files.js.map +1 -1
  656. package/dist/src/tools/ripGrep.d.ts +3 -7
  657. package/dist/src/tools/ripGrep.js +57 -35
  658. package/dist/src/tools/ripGrep.js.map +1 -1
  659. package/dist/src/tools/ripGrep.test.js +197 -276
  660. package/dist/src/tools/ripGrep.test.js.map +1 -1
  661. package/dist/src/tools/shell.d.ts +5 -3
  662. package/dist/src/tools/shell.js +130 -36
  663. package/dist/src/tools/shell.js.map +1 -1
  664. package/dist/src/tools/shell.test.js +186 -14
  665. package/dist/src/tools/shell.test.js.map +1 -1
  666. package/dist/src/tools/shell_proactive.test.js +1 -0
  667. package/dist/src/tools/shell_proactive.test.js.map +1 -1
  668. package/dist/src/tools/tool-names.d.ts +3 -3
  669. package/dist/src/tools/tool-names.js +4 -5
  670. package/dist/src/tools/tool-names.js.map +1 -1
  671. package/dist/src/tools/tool-registry.js +1 -1
  672. package/dist/src/tools/tool-registry.js.map +1 -1
  673. package/dist/src/tools/tools.d.ts +6 -0
  674. package/dist/src/tools/tools.js.map +1 -1
  675. package/dist/src/tools/topicTool.js +5 -0
  676. package/dist/src/tools/topicTool.js.map +1 -1
  677. package/dist/src/tools/write-file.js +13 -0
  678. package/dist/src/tools/write-file.js.map +1 -1
  679. package/dist/src/tools/write-file.test.js +8 -0
  680. package/dist/src/tools/write-file.test.js.map +1 -1
  681. package/dist/src/utils/atCommandUtils.d.ts +35 -0
  682. package/dist/src/utils/atCommandUtils.js +163 -0
  683. package/dist/src/utils/atCommandUtils.js.map +1 -0
  684. package/dist/src/utils/atCommandUtils.test.d.ts +6 -0
  685. package/dist/src/utils/atCommandUtils.test.js +292 -0
  686. package/dist/src/utils/atCommandUtils.test.js.map +1 -0
  687. package/dist/src/utils/channel.d.ts +8 -0
  688. package/dist/src/utils/channel.js +21 -10
  689. package/dist/src/utils/channel.js.map +1 -1
  690. package/dist/src/utils/cryptoUtils.d.ts +11 -0
  691. package/dist/src/utils/cryptoUtils.js +19 -0
  692. package/dist/src/utils/cryptoUtils.js.map +1 -0
  693. package/dist/src/utils/cryptoUtils.test.d.ts +6 -0
  694. package/dist/src/utils/cryptoUtils.test.js +31 -0
  695. package/dist/src/utils/cryptoUtils.test.js.map +1 -0
  696. package/dist/src/utils/editor.d.ts +29 -3
  697. package/dist/src/utils/editor.js +94 -3
  698. package/dist/src/utils/editor.js.map +1 -1
  699. package/dist/src/utils/editor.test.js +176 -2
  700. package/dist/src/utils/editor.test.js.map +1 -1
  701. package/dist/src/utils/environmentContext.d.ts +2 -1
  702. package/dist/src/utils/environmentContext.js +15 -8
  703. package/dist/src/utils/environmentContext.js.map +1 -1
  704. package/dist/src/utils/environmentContext.test.js +4 -14
  705. package/dist/src/utils/environmentContext.test.js.map +1 -1
  706. package/dist/src/utils/errors.js +3 -8
  707. package/dist/src/utils/errors.js.map +1 -1
  708. package/dist/src/utils/events.d.ts +26 -1
  709. package/dist/src/utils/events.js +21 -2
  710. package/dist/src/utils/events.js.map +1 -1
  711. package/dist/src/utils/events.test.js +39 -0
  712. package/dist/src/utils/events.test.js.map +1 -1
  713. package/dist/src/utils/extensionLoader.js +2 -2
  714. package/dist/src/utils/extensionLoader.js.map +1 -1
  715. package/dist/src/utils/extensionLoader.test.js +22 -15
  716. package/dist/src/utils/extensionLoader.test.js.map +1 -1
  717. package/dist/src/utils/fetch.d.ts +3 -3
  718. package/dist/src/utils/fetch.js +44 -20
  719. package/dist/src/utils/fetch.js.map +1 -1
  720. package/dist/src/utils/fetch.test.js +93 -17
  721. package/dist/src/utils/fetch.test.js.map +1 -1
  722. package/dist/src/utils/fileUtils.js +4 -1
  723. package/dist/src/utils/fileUtils.js.map +1 -1
  724. package/dist/src/utils/filesearch/fileSearch.js +20 -9
  725. package/dist/src/utils/filesearch/fileSearch.js.map +1 -1
  726. package/dist/src/utils/filesearch/ignore.js +4 -1
  727. package/dist/src/utils/filesearch/ignore.js.map +1 -1
  728. package/dist/src/utils/generateContentResponseUtilities.d.ts +1 -0
  729. package/dist/src/utils/generateContentResponseUtilities.js +37 -7
  730. package/dist/src/utils/generateContentResponseUtilities.js.map +1 -1
  731. package/dist/src/utils/generateContentResponseUtilities.test.js +33 -0
  732. package/dist/src/utils/generateContentResponseUtilities.test.js.map +1 -1
  733. package/dist/src/utils/gitUtils.d.ts +5 -0
  734. package/dist/src/utils/gitUtils.js +11 -0
  735. package/dist/src/utils/gitUtils.js.map +1 -1
  736. package/dist/src/utils/historyHardening.d.ts +37 -0
  737. package/dist/src/utils/historyHardening.js +332 -0
  738. package/dist/src/utils/historyHardening.js.map +1 -0
  739. package/dist/src/utils/historyHardening.test.d.ts +6 -0
  740. package/dist/src/utils/historyHardening.test.js +317 -0
  741. package/dist/src/utils/historyHardening.test.js.map +1 -0
  742. package/dist/src/utils/ignoreFileParser.js +1 -1
  743. package/dist/src/utils/ignoreFileParser.js.map +1 -1
  744. package/dist/src/utils/ignorePatterns.js +2 -0
  745. package/dist/src/utils/ignorePatterns.js.map +1 -1
  746. package/dist/src/utils/ignorePatterns.test.js +1 -0
  747. package/dist/src/utils/ignorePatterns.test.js.map +1 -1
  748. package/dist/src/utils/memoryDiscovery.d.ts +0 -20
  749. package/dist/src/utils/memoryDiscovery.js +57 -220
  750. package/dist/src/utils/memoryDiscovery.js.map +1 -1
  751. package/dist/src/utils/memoryDiscovery.test.js +112 -403
  752. package/dist/src/utils/memoryDiscovery.test.js.map +1 -1
  753. package/dist/src/utils/modelUtils.d.ts +14 -0
  754. package/dist/src/utils/modelUtils.js +17 -0
  755. package/dist/src/utils/modelUtils.js.map +1 -0
  756. package/dist/src/utils/modelUtils.test.d.ts +6 -0
  757. package/dist/src/utils/modelUtils.test.js +23 -0
  758. package/dist/src/utils/modelUtils.test.js.map +1 -0
  759. package/dist/src/utils/partUtils.d.ts +26 -1
  760. package/dist/src/utils/partUtils.js +37 -0
  761. package/dist/src/utils/partUtils.js.map +1 -1
  762. package/dist/src/utils/path-validator.d.ts +17 -0
  763. package/dist/src/utils/path-validator.js +76 -0
  764. package/dist/src/utils/path-validator.js.map +1 -0
  765. package/dist/src/utils/path-validator.test.d.ts +6 -0
  766. package/dist/src/utils/path-validator.test.js +91 -0
  767. package/dist/src/utils/path-validator.test.js.map +1 -0
  768. package/dist/src/utils/pathReader.js +12 -0
  769. package/dist/src/utils/pathReader.js.map +1 -1
  770. package/dist/src/utils/pathReader.test.js +95 -0
  771. package/dist/src/utils/pathReader.test.js.map +1 -1
  772. package/dist/src/utils/paths.d.ts +19 -1
  773. package/dist/src/utils/paths.js +74 -9
  774. package/dist/src/utils/paths.js.map +1 -1
  775. package/dist/src/utils/paths.test.js +111 -1
  776. package/dist/src/utils/paths.test.js.map +1 -1
  777. package/dist/src/utils/quotaErrorDetection.js +23 -12
  778. package/dist/src/utils/quotaErrorDetection.js.map +1 -1
  779. package/dist/src/utils/ragLogger.d.ts +32 -0
  780. package/dist/src/utils/ragLogger.js +56 -0
  781. package/dist/src/utils/ragLogger.js.map +1 -0
  782. package/dist/src/utils/ragLogger.test.d.ts +6 -0
  783. package/dist/src/utils/ragLogger.test.js +97 -0
  784. package/dist/src/utils/ragLogger.test.js.map +1 -0
  785. package/dist/src/utils/retry.js +8 -3
  786. package/dist/src/utils/retry.js.map +1 -1
  787. package/dist/src/utils/retry.test.js +17 -0
  788. package/dist/src/utils/retry.test.js.map +1 -1
  789. package/dist/src/utils/safeJsonStringify.js +0 -2
  790. package/dist/src/utils/safeJsonStringify.js.map +1 -1
  791. package/dist/src/utils/sessionOperations.d.ts +26 -0
  792. package/dist/src/utils/sessionOperations.js +177 -8
  793. package/dist/src/utils/sessionOperations.js.map +1 -1
  794. package/dist/src/utils/sessionUtils.d.ts +11 -5
  795. package/dist/src/utils/sessionUtils.js +139 -68
  796. package/dist/src/utils/sessionUtils.js.map +1 -1
  797. package/dist/src/utils/sessionUtils.test.js +31 -5
  798. package/dist/src/utils/sessionUtils.test.js.map +1 -1
  799. package/dist/src/utils/shell-utils.d.ts +9 -1
  800. package/dist/src/utils/shell-utils.js +51 -20
  801. package/dist/src/utils/shell-utils.js.map +1 -1
  802. package/dist/src/utils/shell-utils.test.js +87 -46
  803. package/dist/src/utils/shell-utils.test.js.map +1 -1
  804. package/dist/src/utils/textUtils.d.ts +12 -2
  805. package/dist/src/utils/textUtils.js +30 -3
  806. package/dist/src/utils/textUtils.js.map +1 -1
  807. package/dist/src/utils/textUtils.test.js +96 -1
  808. package/dist/src/utils/textUtils.test.js.map +1 -1
  809. package/dist/src/utils/tokenCalculation.d.ts +3 -2
  810. package/dist/src/utils/tokenCalculation.js +9 -5
  811. package/dist/src/utils/tokenCalculation.js.map +1 -1
  812. package/dist/src/utils/tokenCalculation.test.js +15 -0
  813. package/dist/src/utils/tokenCalculation.test.js.map +1 -1
  814. package/dist/tsconfig.tsbuildinfo +1 -1
  815. package/package.json +18 -18
  816. package/dist/src/context/historyObserver.d.ts +0 -28
  817. package/dist/src/context/historyObserver.js +0 -63
  818. package/dist/src/context/historyObserver.js.map +0 -1
  819. package/dist/src/policy/memory-manager-policy.test.js +0 -80
  820. package/dist/src/policy/memory-manager-policy.test.js.map +0 -1
  821. package/dist/src/policy/policies/memory-manager.toml +0 -20
  822. package/dist/src/prompts/snippets-memory-v2.test.js.map +0 -1
  823. package/dist/src/tools/xcode-mcp-fix-transport.js.map +0 -1
  824. package/dist/src/tools/xcode-mcp-fix-transport.test.d.ts +0 -1
  825. package/dist/src/tools/xcode-mcp-fix-transport.test.js +0 -98
  826. package/dist/src/tools/xcode-mcp-fix-transport.test.js.map +0 -1
  827. package/dist/src/utils/systemEncoding.d.ts +0 -40
  828. package/dist/src/utils/systemEncoding.js +0 -150
  829. package/dist/src/utils/systemEncoding.js.map +0 -1
  830. package/dist/src/utils/systemEncoding.test.js +0 -369
  831. package/dist/src/utils/systemEncoding.test.js.map +0 -1
  832. /package/dist/src/{policy/memory-manager-policy.test.d.ts → agents/local-session-invocation.test.d.ts} +0 -0
  833. /package/dist/src/{prompts/snippets-memory-v2.test.d.ts → agents/local-subagent-protocol.test.d.ts} +0 -0
  834. /package/dist/src/{utils/systemEncoding.test.d.ts → policy/stable-stringify.test.d.ts} +0 -0
@@ -0,0 +1,676 @@
1
+ /**
2
+ * @license
3
+ * Copyright 2026 Google LLC
4
+ * SPDX-License-Identifier: Apache-2.0
5
+ */
6
+ import { describe, it, expect, vi, beforeEach, afterEach } from 'vitest';
7
+ import { LocalSubagentSession } from './local-subagent-protocol.js';
8
+ import { LocalAgentExecutor } from './local-executor.js';
9
+ import { AgentTerminateMode, } from './types.js';
10
+ import { makeFakeConfig } from '../test-utils/config.js';
11
+ import { createMockMessageBus } from '../test-utils/mock-message-bus.js';
12
+ vi.mock('./local-executor.js');
13
+ const MockLocalAgentExecutor = vi.mocked(LocalAgentExecutor);
14
+ // Captures the onActivity callback passed to LocalAgentExecutor.create().
15
+ // Set via create.mockImplementation in beforeEach to avoid mock.calls index fragility.
16
+ let capturedOnActivity;
17
+ const testDefinition = {
18
+ kind: 'local',
19
+ name: 'TestProtocolAgent',
20
+ description: 'A test agent for protocol tests.',
21
+ inputConfig: {
22
+ inputSchema: {
23
+ type: 'object',
24
+ properties: {
25
+ task: { type: 'string' },
26
+ priority: { type: 'number' },
27
+ },
28
+ },
29
+ },
30
+ modelConfig: { model: 'test', generateContentConfig: {} },
31
+ runConfig: { maxTimeMinutes: 1 },
32
+ promptConfig: { systemPrompt: 'test' },
33
+ };
34
+ const GOAL_OUTPUT = {
35
+ result: 'Analysis complete.',
36
+ terminate_reason: AgentTerminateMode.GOAL,
37
+ };
38
+ describe('LocalSubagentSession (protocol)', () => {
39
+ let mockContext;
40
+ let mockMessageBus;
41
+ let mockExecutorInstance;
42
+ beforeEach(() => {
43
+ vi.clearAllMocks();
44
+ capturedOnActivity = undefined;
45
+ mockContext = makeFakeConfig();
46
+ mockMessageBus = createMockMessageBus();
47
+ mockExecutorInstance = {
48
+ run: vi.fn().mockResolvedValue(GOAL_OUTPUT),
49
+ definition: testDefinition,
50
+ };
51
+ // Use mockImplementation (not mockResolvedValue) so we can capture onActivity.
52
+ MockLocalAgentExecutor.create.mockImplementation(
53
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
54
+ async (_def, _ctx, onActivity) => {
55
+ capturedOnActivity = onActivity;
56
+ return mockExecutorInstance;
57
+ });
58
+ });
59
+ afterEach(() => {
60
+ vi.restoreAllMocks();
61
+ });
62
+ // ---------------------------------------------------------------------------
63
+ // Lifecycle events
64
+ // ---------------------------------------------------------------------------
65
+ describe('lifecycle events', () => {
66
+ it('emits agent_start then agent_end(completed) for a GOAL run', async () => {
67
+ const session = new LocalSubagentSession(testDefinition, mockContext, mockMessageBus);
68
+ const events = [];
69
+ session.subscribe((e) => events.push(e));
70
+ await session.send({
71
+ message: { content: [{ type: 'text', text: 'query' }] },
72
+ });
73
+ await session.getResult();
74
+ expect(events[0].type).toBe('agent_start');
75
+ expect(events[events.length - 1].type).toBe('agent_end');
76
+ const endEvent = events[events.length - 1];
77
+ if (endEvent.type === 'agent_end') {
78
+ expect(endEvent.reason).toBe('completed');
79
+ }
80
+ });
81
+ it('emits agent_start exactly once even if ensureAgentStart called twice internally', async () => {
82
+ const session = new LocalSubagentSession(testDefinition, mockContext, mockMessageBus);
83
+ const events = [];
84
+ session.subscribe((e) => events.push(e));
85
+ await session.send({
86
+ message: { content: [{ type: 'text', text: 'query' }] },
87
+ });
88
+ await session.getResult();
89
+ const startEvents = events.filter((e) => e.type === 'agent_start');
90
+ expect(startEvents).toHaveLength(1);
91
+ });
92
+ it('emits agent_end exactly once on error path', async () => {
93
+ const session = new LocalSubagentSession(testDefinition, mockContext, mockMessageBus);
94
+ mockExecutorInstance.run.mockRejectedValue(new Error('executor failed'));
95
+ const events = [];
96
+ session.subscribe((e) => events.push(e));
97
+ await session.send({
98
+ message: { content: [{ type: 'text', text: 'query' }] },
99
+ });
100
+ await expect(session.getResult()).rejects.toThrow('executor failed');
101
+ const endEvents = events.filter((e) => e.type === 'agent_end');
102
+ expect(endEvents).toHaveLength(1);
103
+ });
104
+ it('all events share the same streamId', async () => {
105
+ const session = new LocalSubagentSession(testDefinition, mockContext, mockMessageBus);
106
+ const events = [];
107
+ session.subscribe((e) => events.push(e));
108
+ await session.send({
109
+ message: { content: [{ type: 'text', text: 'query' }] },
110
+ });
111
+ await session.getResult();
112
+ const streamIds = new Set(events.map((e) => e.streamId));
113
+ expect(streamIds.size).toBe(1);
114
+ });
115
+ });
116
+ // ---------------------------------------------------------------------------
117
+ // Config buffering (update + message pattern)
118
+ // ---------------------------------------------------------------------------
119
+ describe('config buffering', () => {
120
+ it('merges buffered config with message query', async () => {
121
+ const session = new LocalSubagentSession(testDefinition, mockContext, mockMessageBus);
122
+ await session.send({
123
+ update: { config: { task: 'analyze', priority: 5 } },
124
+ });
125
+ await session.send({
126
+ message: { content: [{ type: 'text', text: 'my query' }] },
127
+ });
128
+ await session.getResult();
129
+ expect(mockExecutorInstance.run).toHaveBeenCalledWith({ task: 'analyze', priority: 5, query: 'my query' }, expect.any(AbortSignal));
130
+ });
131
+ it('omits query key when message text is empty', async () => {
132
+ const session = new LocalSubagentSession(testDefinition, mockContext, mockMessageBus);
133
+ await session.send({ update: { config: { task: 'no-query-task' } } });
134
+ await session.send({
135
+ message: { content: [{ type: 'text', text: '' }] },
136
+ });
137
+ await session.getResult();
138
+ const callArgs = mockExecutorInstance.run.mock.calls[0][0];
139
+ expect(callArgs).not.toHaveProperty('query');
140
+ expect(callArgs).toEqual({ task: 'no-query-task' });
141
+ });
142
+ it('sends only query when no prior update', async () => {
143
+ const session = new LocalSubagentSession(testDefinition, mockContext, mockMessageBus);
144
+ await session.send({
145
+ message: { content: [{ type: 'text', text: 'just a query' }] },
146
+ });
147
+ await session.getResult();
148
+ expect(mockExecutorInstance.run).toHaveBeenCalledWith({ query: 'just a query' }, expect.any(AbortSignal));
149
+ });
150
+ it('multiple update calls are merged', async () => {
151
+ const session = new LocalSubagentSession(testDefinition, mockContext, mockMessageBus);
152
+ await session.send({ update: { config: { field1: 'a' } } });
153
+ await session.send({ update: { config: { field2: 'b' } } });
154
+ await session.send({
155
+ message: { content: [{ type: 'text', text: 'q' }] },
156
+ });
157
+ await session.getResult();
158
+ expect(mockExecutorInstance.run).toHaveBeenCalledWith({ field1: 'a', field2: 'b', query: 'q' }, expect.any(AbortSignal));
159
+ });
160
+ it('update returns streamId: null; message returns a streamId', async () => {
161
+ const session = new LocalSubagentSession(testDefinition, mockContext, mockMessageBus);
162
+ const updateResult = await session.send({ update: { config: {} } });
163
+ expect(updateResult.streamId).toBeNull();
164
+ const messageResult = await session.send({
165
+ message: { content: [{ type: 'text', text: 'q' }] },
166
+ });
167
+ expect(messageResult.streamId).not.toBeNull();
168
+ expect(typeof messageResult.streamId).toBe('string');
169
+ // Await completion to prevent dangling execution affecting subsequent tests
170
+ await session.getResult();
171
+ });
172
+ });
173
+ // ---------------------------------------------------------------------------
174
+ // Activity translation
175
+ // ---------------------------------------------------------------------------
176
+ describe('activity translation', () => {
177
+ function makeSession() {
178
+ const activityEvents = [];
179
+ const session = new LocalSubagentSession(testDefinition, mockContext, mockMessageBus);
180
+ return { session, activityEvents };
181
+ }
182
+ async function runWithActivities(session, activities) {
183
+ mockExecutorInstance.run.mockImplementation(async () => {
184
+ // capturedOnActivity is set by the create.mockImplementation in beforeEach
185
+ // and updated whenever create() is called. By the time run() is called,
186
+ // capturedOnActivity holds the onActivity closure for the most-recently
187
+ // created executor — which is the one associated with this session.
188
+ for (const act of activities) {
189
+ capturedOnActivity?.(act);
190
+ }
191
+ return GOAL_OUTPUT;
192
+ });
193
+ const events = [];
194
+ session.subscribe((e) => events.push(e));
195
+ await session.send({
196
+ message: { content: [{ type: 'text', text: 'q' }] },
197
+ });
198
+ await session.getResult();
199
+ return events;
200
+ }
201
+ it('THOUGHT_CHUNK → message event with thought content', async () => {
202
+ const { session } = makeSession();
203
+ const events = await runWithActivities(session, [
204
+ {
205
+ isSubagentActivityEvent: true,
206
+ agentName: 'TestProtocolAgent',
207
+ type: 'THOUGHT_CHUNK',
208
+ data: { text: 'I am thinking...' },
209
+ },
210
+ ]);
211
+ const msgEvent = events.find((e) => e.type === 'message');
212
+ expect(msgEvent).toBeDefined();
213
+ if (msgEvent?.type === 'message') {
214
+ expect(msgEvent.role).toBe('agent');
215
+ expect(msgEvent.content).toContainEqual({
216
+ type: 'thought',
217
+ thought: 'I am thinking...',
218
+ });
219
+ }
220
+ });
221
+ it('TOOL_CALL_START → tool_request event', async () => {
222
+ const { session } = makeSession();
223
+ const events = await runWithActivities(session, [
224
+ {
225
+ isSubagentActivityEvent: true,
226
+ agentName: 'TestProtocolAgent',
227
+ type: 'TOOL_CALL_START',
228
+ data: { callId: 'call-123', name: 'read_file', args: { path: '/a' } },
229
+ },
230
+ ]);
231
+ const reqEvent = events.find((e) => e.type === 'tool_request');
232
+ expect(reqEvent).toBeDefined();
233
+ if (reqEvent?.type === 'tool_request') {
234
+ expect(reqEvent.requestId).toBe('call-123');
235
+ expect(reqEvent.name).toBe('read_file');
236
+ expect(reqEvent.args).toEqual({ path: '/a' });
237
+ }
238
+ });
239
+ it('TOOL_CALL_END → tool_response event', async () => {
240
+ const { session } = makeSession();
241
+ const events = await runWithActivities(session, [
242
+ {
243
+ isSubagentActivityEvent: true,
244
+ agentName: 'TestProtocolAgent',
245
+ type: 'TOOL_CALL_END',
246
+ data: { id: 'call-123', name: 'read_file', output: 'file contents' },
247
+ },
248
+ ]);
249
+ const respEvent = events.find((e) => e.type === 'tool_response');
250
+ expect(respEvent).toBeDefined();
251
+ if (respEvent?.type === 'tool_response') {
252
+ expect(respEvent.requestId).toBe('call-123');
253
+ expect(respEvent.name).toBe('read_file');
254
+ expect(respEvent.content).toContainEqual({
255
+ type: 'text',
256
+ text: 'file contents',
257
+ });
258
+ }
259
+ });
260
+ it('ERROR activity → error event with INTERNAL status, fatal: false', async () => {
261
+ const { session } = makeSession();
262
+ const events = await runWithActivities(session, [
263
+ {
264
+ isSubagentActivityEvent: true,
265
+ agentName: 'TestProtocolAgent',
266
+ type: 'ERROR',
267
+ data: { error: 'something went wrong' },
268
+ },
269
+ ]);
270
+ const errEvent = events.find((e) => e.type === 'error');
271
+ expect(errEvent).toBeDefined();
272
+ if (errEvent?.type === 'error') {
273
+ expect(errEvent.status).toBe('INTERNAL');
274
+ expect(errEvent.message).toBe('something went wrong');
275
+ expect(errEvent.fatal).toBe(false);
276
+ }
277
+ });
278
+ it('unknown activity type → no events emitted', async () => {
279
+ const { session } = makeSession();
280
+ const events = await runWithActivities(session, [
281
+ {
282
+ isSubagentActivityEvent: true,
283
+ agentName: 'TestProtocolAgent',
284
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
285
+ type: 'UNKNOWN_TYPE',
286
+ data: {},
287
+ },
288
+ ]);
289
+ // Only agent_start and agent_end should be present
290
+ const nonLifecycle = events.filter((e) => e.type !== 'agent_start' && e.type !== 'agent_end');
291
+ expect(nonLifecycle).toHaveLength(0);
292
+ });
293
+ it('TOOL_CALL_START with non-object args defaults to {}', async () => {
294
+ const { session } = makeSession();
295
+ const events = await runWithActivities(session, [
296
+ {
297
+ isSubagentActivityEvent: true,
298
+ agentName: 'TestProtocolAgent',
299
+ type: 'TOOL_CALL_START',
300
+ data: { callId: 'x', name: 'tool', args: null },
301
+ },
302
+ ]);
303
+ const reqEvent = events.find((e) => e.type === 'tool_request');
304
+ if (reqEvent?.type === 'tool_request') {
305
+ expect(reqEvent.args).toEqual({});
306
+ }
307
+ });
308
+ });
309
+ // ---------------------------------------------------------------------------
310
+ // getResult() promise
311
+ // ---------------------------------------------------------------------------
312
+ describe('getResult()', () => {
313
+ it('resolves with OutputObject on GOAL termination', async () => {
314
+ const session = new LocalSubagentSession(testDefinition, mockContext, mockMessageBus);
315
+ await session.send({
316
+ message: { content: [{ type: 'text', text: 'q' }] },
317
+ });
318
+ const output = await session.getResult();
319
+ expect(output.result).toBe('Analysis complete.');
320
+ expect(output.terminate_reason).toBe(AgentTerminateMode.GOAL);
321
+ });
322
+ it('rejects when executor throws', async () => {
323
+ const session = new LocalSubagentSession(testDefinition, mockContext, mockMessageBus);
324
+ mockExecutorInstance.run.mockRejectedValue(new Error('executor error'));
325
+ await session.send({
326
+ message: { content: [{ type: 'text', text: 'q' }] },
327
+ });
328
+ await expect(session.getResult()).rejects.toThrow('executor error');
329
+ });
330
+ });
331
+ // ---------------------------------------------------------------------------
332
+ // rawActivityCallback
333
+ // ---------------------------------------------------------------------------
334
+ describe('rawActivityCallback', () => {
335
+ it('receives raw SubagentActivityEvent before AgentEvent translation', async () => {
336
+ const rawActivities = [];
337
+ const session = new LocalSubagentSession(testDefinition, mockContext, mockMessageBus, (activity) => rawActivities.push(activity));
338
+ const thoughtActivity = {
339
+ isSubagentActivityEvent: true,
340
+ agentName: 'TestProtocolAgent',
341
+ type: 'THOUGHT_CHUNK',
342
+ data: { text: 'raw thought' },
343
+ };
344
+ mockExecutorInstance.run.mockImplementation(async () => {
345
+ const onActivity = MockLocalAgentExecutor.create.mock.calls[0]?.[2];
346
+ onActivity?.(thoughtActivity);
347
+ return GOAL_OUTPUT;
348
+ });
349
+ await session.send({
350
+ message: { content: [{ type: 'text', text: 'q' }] },
351
+ });
352
+ await session.getResult();
353
+ expect(rawActivities).toHaveLength(1);
354
+ expect(rawActivities[0]).toBe(thoughtActivity);
355
+ });
356
+ it('is called before AgentEvent translation (raw arrives first)', async () => {
357
+ const callOrder = [];
358
+ const session = new LocalSubagentSession(testDefinition, mockContext, mockMessageBus, () => callOrder.push('raw'));
359
+ session.subscribe((e) => {
360
+ if (e.type === 'message')
361
+ callOrder.push('translated');
362
+ });
363
+ mockExecutorInstance.run.mockImplementation(async () => {
364
+ const onActivity = MockLocalAgentExecutor.create.mock.calls[0]?.[2];
365
+ onActivity?.({
366
+ isSubagentActivityEvent: true,
367
+ agentName: 'TestProtocolAgent',
368
+ type: 'THOUGHT_CHUNK',
369
+ data: { text: 'thought' },
370
+ });
371
+ return GOAL_OUTPUT;
372
+ });
373
+ await session.send({
374
+ message: { content: [{ type: 'text', text: 'q' }] },
375
+ });
376
+ await session.getResult();
377
+ expect(callOrder).toEqual(['raw', 'translated']);
378
+ });
379
+ it('is optional — no callback causes no error', async () => {
380
+ const session = new LocalSubagentSession(testDefinition, mockContext, mockMessageBus);
381
+ await session.send({
382
+ message: { content: [{ type: 'text', text: 'q' }] },
383
+ });
384
+ await expect(session.getResult()).resolves.toBeDefined();
385
+ });
386
+ });
387
+ // ---------------------------------------------------------------------------
388
+ // Subscription
389
+ // ---------------------------------------------------------------------------
390
+ describe('subscription', () => {
391
+ it('unsubscribe stops event delivery', async () => {
392
+ const session = new LocalSubagentSession(testDefinition, mockContext, mockMessageBus);
393
+ const received = [];
394
+ const unsub = session.subscribe((e) => received.push(e));
395
+ unsub();
396
+ await session.send({
397
+ message: { content: [{ type: 'text', text: 'q' }] },
398
+ });
399
+ await session.getResult();
400
+ expect(received).toHaveLength(0);
401
+ });
402
+ it('multiple subscribers all receive events', async () => {
403
+ const session = new LocalSubagentSession(testDefinition, mockContext, mockMessageBus);
404
+ const received1 = [];
405
+ const received2 = [];
406
+ session.subscribe((e) => received1.push(e));
407
+ session.subscribe((e) => received2.push(e));
408
+ await session.send({
409
+ message: { content: [{ type: 'text', text: 'q' }] },
410
+ });
411
+ await session.getResult();
412
+ expect(received1.length).toBeGreaterThan(0);
413
+ expect(received1).toEqual(received2);
414
+ });
415
+ it('events array accumulates all emitted events', async () => {
416
+ const session = new LocalSubagentSession(testDefinition, mockContext, mockMessageBus);
417
+ await session.send({
418
+ message: { content: [{ type: 'text', text: 'q' }] },
419
+ });
420
+ await session.getResult();
421
+ expect(session.events.length).toBeGreaterThanOrEqual(2); // at least agent_start + agent_end
422
+ expect(session.events[0].type).toBe('agent_start');
423
+ });
424
+ });
425
+ // ---------------------------------------------------------------------------
426
+ // Terminate mode mapping
427
+ // ---------------------------------------------------------------------------
428
+ describe('terminate mode → StreamEndReason mapping', () => {
429
+ const cases = [
430
+ [AgentTerminateMode.GOAL, 'completed'],
431
+ [AgentTerminateMode.TIMEOUT, 'max_time'],
432
+ [AgentTerminateMode.MAX_TURNS, 'max_turns'],
433
+ [AgentTerminateMode.ABORTED, 'aborted'],
434
+ [AgentTerminateMode.ERROR, 'failed'],
435
+ [AgentTerminateMode.ERROR_NO_COMPLETE_TASK_CALL, 'failed'],
436
+ ];
437
+ for (const [terminateMode, expectedReason] of cases) {
438
+ it(`${terminateMode} → agent_end(reason:'${expectedReason}')`, async () => {
439
+ mockExecutorInstance.run.mockResolvedValue({
440
+ result: 'done',
441
+ terminate_reason: terminateMode,
442
+ });
443
+ const session = new LocalSubagentSession(testDefinition, mockContext, mockMessageBus);
444
+ const events = [];
445
+ session.subscribe((e) => events.push(e));
446
+ await session.send({
447
+ message: { content: [{ type: 'text', text: 'q' }] },
448
+ });
449
+ await session.getResult().catch(() => {
450
+ // ABORTED results in rejection — catch to let test complete
451
+ });
452
+ const endEvent = events.find((e) => e.type === 'agent_end');
453
+ expect(endEvent).toBeDefined();
454
+ if (endEvent?.type === 'agent_end') {
455
+ expect(endEvent.reason).toBe(expectedReason);
456
+ }
457
+ });
458
+ }
459
+ });
460
+ // ---------------------------------------------------------------------------
461
+ // Abort
462
+ // ---------------------------------------------------------------------------
463
+ describe('abort()', () => {
464
+ it('abort() causes agent_end(reason:aborted)', async () => {
465
+ // Make run() wait until aborted
466
+ let abortSignal;
467
+ mockExecutorInstance.run.mockImplementation((_params, signal) => {
468
+ abortSignal = signal;
469
+ return new Promise((_resolve, reject) => {
470
+ signal.addEventListener('abort', () => {
471
+ const err = new Error('AbortError');
472
+ err.name = 'AbortError';
473
+ reject(err);
474
+ });
475
+ });
476
+ });
477
+ const session = new LocalSubagentSession(testDefinition, mockContext, mockMessageBus);
478
+ const events = [];
479
+ session.subscribe((e) => events.push(e));
480
+ void session.send({
481
+ message: { content: [{ type: 'text', text: 'q' }] },
482
+ });
483
+ // Wait for executor to be created and run started
484
+ await vi.waitFor(() => {
485
+ expect(abortSignal).toBeDefined();
486
+ });
487
+ await session.abort();
488
+ const result = await session.getResult();
489
+ expect(result.result).toBe('');
490
+ expect(result.terminate_reason).toBe('ABORTED');
491
+ const endEvent = events.find((e) => e.type === 'agent_end');
492
+ expect(endEvent).toBeDefined();
493
+ if (endEvent?.type === 'agent_end') {
494
+ expect(endEvent.reason).toBe('aborted');
495
+ }
496
+ });
497
+ });
498
+ // ---------------------------------------------------------------------------
499
+ // Full event sequence
500
+ // ---------------------------------------------------------------------------
501
+ describe('full event sequence', () => {
502
+ it('emits agent_start → message(thought) → tool_request → tool_response → agent_end in order', async () => {
503
+ const session = new LocalSubagentSession(testDefinition, mockContext, mockMessageBus);
504
+ mockExecutorInstance.run.mockImplementation(async () => {
505
+ const onActivity = MockLocalAgentExecutor.create.mock.calls[0]?.[2];
506
+ onActivity?.({
507
+ isSubagentActivityEvent: true,
508
+ agentName: 'TestProtocolAgent',
509
+ type: 'THOUGHT_CHUNK',
510
+ data: { text: 'thinking' },
511
+ });
512
+ onActivity?.({
513
+ isSubagentActivityEvent: true,
514
+ agentName: 'TestProtocolAgent',
515
+ type: 'TOOL_CALL_START',
516
+ data: { callId: 'c1', name: 'tool', args: {} },
517
+ });
518
+ onActivity?.({
519
+ isSubagentActivityEvent: true,
520
+ agentName: 'TestProtocolAgent',
521
+ type: 'TOOL_CALL_END',
522
+ data: { id: 'c1', name: 'tool', output: 'result' },
523
+ });
524
+ return GOAL_OUTPUT;
525
+ });
526
+ const events = [];
527
+ session.subscribe((e) => events.push(e));
528
+ await session.send({
529
+ message: { content: [{ type: 'text', text: 'go' }] },
530
+ });
531
+ await session.getResult();
532
+ const types = events.map((e) => e.type);
533
+ expect(types).toEqual([
534
+ 'agent_start',
535
+ 'message',
536
+ 'tool_request',
537
+ 'tool_response',
538
+ 'agent_end',
539
+ ]);
540
+ });
541
+ });
542
+ // ---------------------------------------------------------------------------
543
+ // Concurrent send() guard
544
+ // ---------------------------------------------------------------------------
545
+ describe('concurrent send() guard', () => {
546
+ it('calling send() while a stream is active throws', async () => {
547
+ let abortSignal;
548
+ mockExecutorInstance.run.mockImplementation((_params, signal) => {
549
+ abortSignal = signal;
550
+ return new Promise((_resolve, reject) => {
551
+ // Reject when aborted so getResult() can settle during cleanup
552
+ signal.addEventListener('abort', () => {
553
+ const err = new Error('AbortError');
554
+ err.name = 'AbortError';
555
+ reject(err);
556
+ });
557
+ });
558
+ });
559
+ const session = new LocalSubagentSession(testDefinition, mockContext, mockMessageBus);
560
+ void session.send({
561
+ message: { content: [{ type: 'text', text: 'first' }] },
562
+ });
563
+ // Wait for execution to start
564
+ await vi.waitFor(() => {
565
+ expect(abortSignal).toBeDefined();
566
+ });
567
+ // Second send() while first stream is active must throw
568
+ await expect(session.send({
569
+ message: { content: [{ type: 'text', text: 'second' }] },
570
+ })).rejects.toThrow('cannot be called while a stream is active');
571
+ // Clean up: abort to unblock the hanging executor
572
+ await session.abort();
573
+ await session.getResult().catch(() => { });
574
+ });
575
+ });
576
+ // ---------------------------------------------------------------------------
577
+ // Multi-send support
578
+ // ---------------------------------------------------------------------------
579
+ describe('multi-send', () => {
580
+ it('supports sequential sends after stream completion', async () => {
581
+ const session = new LocalSubagentSession(testDefinition, mockContext, mockMessageBus);
582
+ // First send
583
+ const result1 = await session.send({
584
+ message: { content: [{ type: 'text', text: 'first' }] },
585
+ });
586
+ expect(result1.streamId).not.toBeNull();
587
+ const output1 = await session.getResult();
588
+ expect(output1.result).toBe('Analysis complete.');
589
+ // Second send — should work, not throw
590
+ const secondOutput = {
591
+ result: 'Second analysis.',
592
+ terminate_reason: AgentTerminateMode.GOAL,
593
+ };
594
+ mockExecutorInstance.run.mockResolvedValue(secondOutput);
595
+ const result2 = await session.send({
596
+ message: { content: [{ type: 'text', text: 'second' }] },
597
+ });
598
+ expect(result2.streamId).not.toBeNull();
599
+ expect(result2.streamId).not.toBe(result1.streamId);
600
+ const output2 = await session.getResult();
601
+ expect(output2.result).toBe('Second analysis.');
602
+ });
603
+ it('getResult() returns the latest stream result', async () => {
604
+ const session = new LocalSubagentSession(testDefinition, mockContext, mockMessageBus);
605
+ // First send
606
+ await session.send({
607
+ message: { content: [{ type: 'text', text: 'first' }] },
608
+ });
609
+ const result1 = await session.getResult();
610
+ // Second send with different output
611
+ const secondOutput = {
612
+ result: 'Different result.',
613
+ terminate_reason: AgentTerminateMode.GOAL,
614
+ };
615
+ mockExecutorInstance.run.mockResolvedValue(secondOutput);
616
+ await session.send({
617
+ message: { content: [{ type: 'text', text: 'second' }] },
618
+ });
619
+ const result2 = await session.getResult();
620
+ expect(result1.result).toBe('Analysis complete.');
621
+ expect(result2.result).toBe('Different result.');
622
+ });
623
+ it('buffered config does not bleed across sends', async () => {
624
+ const session = new LocalSubagentSession(testDefinition, mockContext, mockMessageBus);
625
+ // Buffer config, then send first message
626
+ await session.send({ update: { config: { temperature: 0.5 } } });
627
+ await session.send({
628
+ message: { content: [{ type: 'text', text: 'first' }] },
629
+ });
630
+ await session.getResult();
631
+ // The executor.run params include the buffered config
632
+ const firstRunParams = mockExecutorInstance.run.mock.calls[0]?.[0];
633
+ expect(firstRunParams).toHaveProperty('temperature', 0.5);
634
+ expect(firstRunParams).toHaveProperty('query', 'first');
635
+ // Second send without buffered config — temperature should be gone
636
+ mockExecutorInstance.run.mockResolvedValue(GOAL_OUTPUT);
637
+ await session.send({
638
+ message: { content: [{ type: 'text', text: 'second' }] },
639
+ });
640
+ await session.getResult();
641
+ const secondRunParams = mockExecutorInstance.run.mock.calls[1]?.[0];
642
+ expect(secondRunParams).not.toHaveProperty('temperature');
643
+ expect(secondRunParams).toHaveProperty('query', 'second');
644
+ });
645
+ it('getResult() rejects when called before any send', async () => {
646
+ const session = new LocalSubagentSession(testDefinition, mockContext, mockMessageBus);
647
+ await expect(session.getResult()).rejects.toThrow('No active or completed stream');
648
+ });
649
+ it('emits fresh agent_start/agent_end per stream', async () => {
650
+ const session = new LocalSubagentSession(testDefinition, mockContext, mockMessageBus);
651
+ const events = [];
652
+ session.subscribe((e) => events.push(e));
653
+ // First send
654
+ await session.send({
655
+ message: { content: [{ type: 'text', text: 'first' }] },
656
+ });
657
+ await session.getResult();
658
+ const firstStreamEvents = events.length;
659
+ expect(events[0]?.type).toBe('agent_start');
660
+ expect(events[firstStreamEvents - 1]?.type).toBe('agent_end');
661
+ // Second send
662
+ mockExecutorInstance.run.mockResolvedValue(GOAL_OUTPUT);
663
+ await session.send({
664
+ message: { content: [{ type: 'text', text: 'second' }] },
665
+ });
666
+ await session.getResult();
667
+ // Should have a second agent_start/agent_end pair
668
+ const secondStreamStart = events[firstStreamEvents];
669
+ const lastEvent = events[events.length - 1];
670
+ expect(secondStreamStart?.type).toBe('agent_start');
671
+ expect(lastEvent?.type).toBe('agent_end');
672
+ expect(secondStreamStart?.streamId).not.toBe(events[0]?.streamId);
673
+ });
674
+ });
675
+ });
676
+ //# sourceMappingURL=local-subagent-protocol.test.js.map