@terminai/core 0.21.0

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 (1980) hide show
  1. package/dist/.last_build +0 -0
  2. package/dist/docs/CONTRIBUTING.md +327 -0
  3. package/dist/docs/architecture.md +95 -0
  4. package/dist/docs/assets/connected_devtools.png +0 -0
  5. package/dist/docs/assets/gemini-screenshot.png +0 -0
  6. package/dist/docs/assets/release_patch.png +0 -0
  7. package/dist/docs/assets/termai-banner.png +0 -0
  8. package/dist/docs/assets/termai-demo.gif +0 -0
  9. package/dist/docs/assets/theme-ansi-light.png +0 -0
  10. package/dist/docs/assets/theme-ansi.png +0 -0
  11. package/dist/docs/assets/theme-atom-one.png +0 -0
  12. package/dist/docs/assets/theme-ayu-light.png +0 -0
  13. package/dist/docs/assets/theme-ayu.png +0 -0
  14. package/dist/docs/assets/theme-custom.png +0 -0
  15. package/dist/docs/assets/theme-default-light.png +0 -0
  16. package/dist/docs/assets/theme-default.png +0 -0
  17. package/dist/docs/assets/theme-dracula.png +0 -0
  18. package/dist/docs/assets/theme-github-light.png +0 -0
  19. package/dist/docs/assets/theme-github.png +0 -0
  20. package/dist/docs/assets/theme-google-light.png +0 -0
  21. package/dist/docs/assets/theme-xcode-light.png +0 -0
  22. package/dist/docs/changelogs/index.md +592 -0
  23. package/dist/docs/changelogs/latest.md +225 -0
  24. package/dist/docs/changelogs/preview.md +129 -0
  25. package/dist/docs/changelogs/releases.md +897 -0
  26. package/dist/docs/cli/authentication.md +3 -0
  27. package/dist/docs/cli/checkpointing.md +94 -0
  28. package/dist/docs/cli/commands.md +354 -0
  29. package/dist/docs/cli/configuration.md +784 -0
  30. package/dist/docs/cli/custom-commands.md +385 -0
  31. package/dist/docs/cli/enterprise.md +565 -0
  32. package/dist/docs/cli/gemini-ignore.md +74 -0
  33. package/dist/docs/cli/generation-settings.md +210 -0
  34. package/dist/docs/cli/headless.md +391 -0
  35. package/dist/docs/cli/index.md +66 -0
  36. package/dist/docs/cli/keyboard-shortcuts.md +143 -0
  37. package/dist/docs/cli/model-routing.md +37 -0
  38. package/dist/docs/cli/model.md +62 -0
  39. package/dist/docs/cli/sandbox.md +174 -0
  40. package/dist/docs/cli/session-management.md +161 -0
  41. package/dist/docs/cli/settings.md +112 -0
  42. package/dist/docs/cli/system-prompt.md +101 -0
  43. package/dist/docs/cli/telemetry.md +793 -0
  44. package/dist/docs/cli/terminaI-md.md +109 -0
  45. package/dist/docs/cli/themes.md +253 -0
  46. package/dist/docs/cli/token-caching.md +20 -0
  47. package/dist/docs/cli/trusted-folders.md +95 -0
  48. package/dist/docs/cli/tutorials.md +130 -0
  49. package/dist/docs/cli/uninstall.md +47 -0
  50. package/dist/docs/core/index.md +101 -0
  51. package/dist/docs/core/memport.md +244 -0
  52. package/dist/docs/core/policy-engine.md +267 -0
  53. package/dist/docs/core/tools-api.md +131 -0
  54. package/dist/docs/demos.md +74 -0
  55. package/dist/docs/examples/proxy-script.md +83 -0
  56. package/dist/docs/extensions/extension-releasing.md +183 -0
  57. package/dist/docs/extensions/getting-started-extensions.md +245 -0
  58. package/dist/docs/extensions/index.md +293 -0
  59. package/dist/docs/faq.md +154 -0
  60. package/dist/docs/get-started/authentication.md +321 -0
  61. package/dist/docs/get-started/configuration-v1.md +892 -0
  62. package/dist/docs/get-started/configuration.md +1647 -0
  63. package/dist/docs/get-started/deployment.md +143 -0
  64. package/dist/docs/get-started/examples.md +219 -0
  65. package/dist/docs/get-started/gemini-2.0-flash-exp.md +118 -0
  66. package/dist/docs/get-started/index.md +76 -0
  67. package/dist/docs/get-started/installation.md +141 -0
  68. package/dist/docs/handoff_professionalization.md +69 -0
  69. package/dist/docs/hooks/best-practices.md +806 -0
  70. package/dist/docs/hooks/index.md +665 -0
  71. package/dist/docs/hooks/reference.md +168 -0
  72. package/dist/docs/hooks/writing-hooks.md +1026 -0
  73. package/dist/docs/ide-integration/ide-companion-spec.md +267 -0
  74. package/dist/docs/ide-integration/index.md +201 -0
  75. package/dist/docs/index.md +170 -0
  76. package/dist/docs/integration-tests.md +52 -0
  77. package/dist/docs/issue-and-pr-automation.md +134 -0
  78. package/dist/docs/local-development.md +129 -0
  79. package/dist/docs/mermaid/context.mmd +103 -0
  80. package/dist/docs/mermaid/render-path.mmd +64 -0
  81. package/dist/docs/npm.md +62 -0
  82. package/dist/docs/quota-and-pricing.md +158 -0
  83. package/dist/docs/release-confidence.md +162 -0
  84. package/dist/docs/releases.md +540 -0
  85. package/dist/docs/security-posture.md +52 -0
  86. package/dist/docs/sidebar.json +329 -0
  87. package/dist/docs/termai-comparison.md +91 -0
  88. package/dist/docs/termai-examples.md +51 -0
  89. package/dist/docs/termai-operator-recipes.md +93 -0
  90. package/dist/docs/termai-process-manager.md +68 -0
  91. package/dist/docs/termai-quickstart.md +59 -0
  92. package/dist/docs/termai-system.md +64 -0
  93. package/dist/docs/tools/file-system.md +268 -0
  94. package/dist/docs/tools/index.md +105 -0
  95. package/dist/docs/tools/mcp-server.md +1045 -0
  96. package/dist/docs/tools/memory.md +54 -0
  97. package/dist/docs/tools/shell.md +260 -0
  98. package/dist/docs/tools/todos.md +57 -0
  99. package/dist/docs/tools/web-fetch.md +69 -0
  100. package/dist/docs/tools/web-search.md +50 -0
  101. package/dist/docs/tos-privacy.md +96 -0
  102. package/dist/docs/troubleshooting.md +162 -0
  103. package/dist/index.d.ts +24 -0
  104. package/dist/index.js +24 -0
  105. package/dist/index.js.map +1 -0
  106. package/dist/src/__mocks__/fs/promises.d.ts +12 -0
  107. package/dist/src/__mocks__/fs/promises.js +18 -0
  108. package/dist/src/__mocks__/fs/promises.js.map +1 -0
  109. package/dist/src/agents/codebase-investigator.d.ts +47 -0
  110. package/dist/src/agents/codebase-investigator.js +134 -0
  111. package/dist/src/agents/codebase-investigator.js.map +1 -0
  112. package/dist/src/agents/codebase-investigator.test.d.ts +7 -0
  113. package/dist/src/agents/codebase-investigator.test.js +36 -0
  114. package/dist/src/agents/codebase-investigator.test.js.map +1 -0
  115. package/dist/src/agents/delegate-to-agent-tool.d.ts +20 -0
  116. package/dist/src/agents/delegate-to-agent-tool.js +116 -0
  117. package/dist/src/agents/delegate-to-agent-tool.js.map +1 -0
  118. package/dist/src/agents/delegate-to-agent-tool.test.d.ts +7 -0
  119. package/dist/src/agents/delegate-to-agent-tool.test.js +136 -0
  120. package/dist/src/agents/delegate-to-agent-tool.test.js.map +1 -0
  121. package/dist/src/agents/introspection-agent.d.ts +24 -0
  122. package/dist/src/agents/introspection-agent.js +73 -0
  123. package/dist/src/agents/introspection-agent.js.map +1 -0
  124. package/dist/src/agents/introspection-agent.test.d.ts +7 -0
  125. package/dist/src/agents/introspection-agent.test.js +48 -0
  126. package/dist/src/agents/introspection-agent.test.js.map +1 -0
  127. package/dist/src/agents/local-executor.d.ts +109 -0
  128. package/dist/src/agents/local-executor.js +805 -0
  129. package/dist/src/agents/local-executor.js.map +1 -0
  130. package/dist/src/agents/local-executor.test.d.ts +7 -0
  131. package/dist/src/agents/local-executor.test.js +1381 -0
  132. package/dist/src/agents/local-executor.test.js.map +1 -0
  133. package/dist/src/agents/local-invocation.d.ts +46 -0
  134. package/dist/src/agents/local-invocation.js +102 -0
  135. package/dist/src/agents/local-invocation.js.map +1 -0
  136. package/dist/src/agents/local-invocation.test.d.ts +7 -0
  137. package/dist/src/agents/local-invocation.test.js +217 -0
  138. package/dist/src/agents/local-invocation.test.js.map +1 -0
  139. package/dist/src/agents/registry.d.ts +57 -0
  140. package/dist/src/agents/registry.js +210 -0
  141. package/dist/src/agents/registry.js.map +1 -0
  142. package/dist/src/agents/registry.test.d.ts +7 -0
  143. package/dist/src/agents/registry.test.js +334 -0
  144. package/dist/src/agents/registry.test.js.map +1 -0
  145. package/dist/src/agents/remote-invocation.d.ts +22 -0
  146. package/dist/src/agents/remote-invocation.js +32 -0
  147. package/dist/src/agents/remote-invocation.js.map +1 -0
  148. package/dist/src/agents/remote-invocation.test.d.ts +7 -0
  149. package/dist/src/agents/remote-invocation.test.js +36 -0
  150. package/dist/src/agents/remote-invocation.test.js.map +1 -0
  151. package/dist/src/agents/schema-utils.d.ts +40 -0
  152. package/dist/src/agents/schema-utils.js +58 -0
  153. package/dist/src/agents/schema-utils.js.map +1 -0
  154. package/dist/src/agents/schema-utils.test.d.ts +7 -0
  155. package/dist/src/agents/schema-utils.test.js +145 -0
  156. package/dist/src/agents/schema-utils.test.js.map +1 -0
  157. package/dist/src/agents/subagent-tool-wrapper.d.ts +39 -0
  158. package/dist/src/agents/subagent-tool-wrapper.js +53 -0
  159. package/dist/src/agents/subagent-tool-wrapper.js.map +1 -0
  160. package/dist/src/agents/subagent-tool-wrapper.test.d.ts +7 -0
  161. package/dist/src/agents/subagent-tool-wrapper.test.js +112 -0
  162. package/dist/src/agents/subagent-tool-wrapper.test.js.map +1 -0
  163. package/dist/src/agents/toml-loader.d.ts +66 -0
  164. package/dist/src/agents/toml-loader.js +177 -0
  165. package/dist/src/agents/toml-loader.js.map +1 -0
  166. package/dist/src/agents/toml-loader.test.d.ts +7 -0
  167. package/dist/src/agents/toml-loader.test.js +191 -0
  168. package/dist/src/agents/toml-loader.test.js.map +1 -0
  169. package/dist/src/agents/types.d.ts +155 -0
  170. package/dist/src/agents/types.js +20 -0
  171. package/dist/src/agents/types.js.map +1 -0
  172. package/dist/src/agents/utils.d.ts +16 -0
  173. package/dist/src/agents/utils.js +30 -0
  174. package/dist/src/agents/utils.js.map +1 -0
  175. package/dist/src/agents/utils.test.d.ts +7 -0
  176. package/dist/src/agents/utils.test.js +88 -0
  177. package/dist/src/agents/utils.test.js.map +1 -0
  178. package/dist/src/audit/export.d.ts +10 -0
  179. package/dist/src/audit/export.js +30 -0
  180. package/dist/src/audit/export.js.map +1 -0
  181. package/dist/src/audit/hashChain.d.ts +16 -0
  182. package/dist/src/audit/hashChain.js +43 -0
  183. package/dist/src/audit/hashChain.js.map +1 -0
  184. package/dist/src/audit/index.d.ts +16 -0
  185. package/dist/src/audit/index.js +15 -0
  186. package/dist/src/audit/index.js.map +1 -0
  187. package/dist/src/audit/ledger.d.ts +46 -0
  188. package/dist/src/audit/ledger.js +113 -0
  189. package/dist/src/audit/ledger.js.map +1 -0
  190. package/dist/src/audit/ledger.test.d.ts +7 -0
  191. package/dist/src/audit/ledger.test.js +68 -0
  192. package/dist/src/audit/ledger.test.js.map +1 -0
  193. package/dist/src/audit/redaction.d.ts +11 -0
  194. package/dist/src/audit/redaction.js +77 -0
  195. package/dist/src/audit/redaction.js.map +1 -0
  196. package/dist/src/audit/schema.d.ts +52 -0
  197. package/dist/src/audit/schema.js +8 -0
  198. package/dist/src/audit/schema.js.map +1 -0
  199. package/dist/src/auth/geminiAuthStatus.d.ts +17 -0
  200. package/dist/src/auth/geminiAuthStatus.js +96 -0
  201. package/dist/src/auth/geminiAuthStatus.js.map +1 -0
  202. package/dist/src/auth/geminiAuthStatus.test.d.ts +7 -0
  203. package/dist/src/auth/geminiAuthStatus.test.js +88 -0
  204. package/dist/src/auth/geminiAuthStatus.test.js.map +1 -0
  205. package/dist/src/auth/providerRegistry.d.ts +26 -0
  206. package/dist/src/auth/providerRegistry.js +76 -0
  207. package/dist/src/auth/providerRegistry.js.map +1 -0
  208. package/dist/src/auth/wizardSettings.d.ts +25 -0
  209. package/dist/src/auth/wizardSettings.js +70 -0
  210. package/dist/src/auth/wizardSettings.js.map +1 -0
  211. package/dist/src/auth/wizardSettings.test.d.ts +7 -0
  212. package/dist/src/auth/wizardSettings.test.js +63 -0
  213. package/dist/src/auth/wizardSettings.test.js.map +1 -0
  214. package/dist/src/auth/wizardState.d.ts +80 -0
  215. package/dist/src/auth/wizardState.js +142 -0
  216. package/dist/src/auth/wizardState.js.map +1 -0
  217. package/dist/src/auth/wizardState.test.d.ts +7 -0
  218. package/dist/src/auth/wizardState.test.js +220 -0
  219. package/dist/src/auth/wizardState.test.js.map +1 -0
  220. package/dist/src/availability/errorClassification.d.ts +8 -0
  221. package/dist/src/availability/errorClassification.js +21 -0
  222. package/dist/src/availability/errorClassification.js.map +1 -0
  223. package/dist/src/availability/modelAvailabilityService.d.ts +37 -0
  224. package/dist/src/availability/modelAvailabilityService.js +88 -0
  225. package/dist/src/availability/modelAvailabilityService.js.map +1 -0
  226. package/dist/src/availability/modelAvailabilityService.test.d.ts +7 -0
  227. package/dist/src/availability/modelAvailabilityService.test.js +141 -0
  228. package/dist/src/availability/modelAvailabilityService.test.js.map +1 -0
  229. package/dist/src/availability/modelPolicy.d.ts +50 -0
  230. package/dist/src/availability/modelPolicy.js +8 -0
  231. package/dist/src/availability/modelPolicy.js.map +1 -0
  232. package/dist/src/availability/policyCatalog.d.ts +24 -0
  233. package/dist/src/availability/policyCatalog.js +83 -0
  234. package/dist/src/availability/policyCatalog.js.map +1 -0
  235. package/dist/src/availability/policyCatalog.test.d.ts +7 -0
  236. package/dist/src/availability/policyCatalog.test.js +71 -0
  237. package/dist/src/availability/policyCatalog.test.js.map +1 -0
  238. package/dist/src/availability/policyHelpers.d.ts +53 -0
  239. package/dist/src/availability/policyHelpers.js +139 -0
  240. package/dist/src/availability/policyHelpers.js.map +1 -0
  241. package/dist/src/availability/policyHelpers.test.d.ts +7 -0
  242. package/dist/src/availability/policyHelpers.test.js +183 -0
  243. package/dist/src/availability/policyHelpers.test.js.map +1 -0
  244. package/dist/src/availability/testUtils.d.ts +11 -0
  245. package/dist/src/availability/testUtils.js +23 -0
  246. package/dist/src/availability/testUtils.js.map +1 -0
  247. package/dist/src/brain/__tests__/advisors.test.d.ts +7 -0
  248. package/dist/src/brain/__tests__/advisors.test.js +77 -0
  249. package/dist/src/brain/__tests__/advisors.test.js.map +1 -0
  250. package/dist/src/brain/__tests__/cognitiveArchitecture.test.d.ts +7 -0
  251. package/dist/src/brain/__tests__/cognitiveArchitecture.test.js +61 -0
  252. package/dist/src/brain/__tests__/cognitiveArchitecture.test.js.map +1 -0
  253. package/dist/src/brain/__tests__/confidenceHandler.test.d.ts +7 -0
  254. package/dist/src/brain/__tests__/confidenceHandler.test.js +29 -0
  255. package/dist/src/brain/__tests__/confidenceHandler.test.js.map +1 -0
  256. package/dist/src/brain/__tests__/environmentDetector.test.d.ts +7 -0
  257. package/dist/src/brain/__tests__/environmentDetector.test.js +73 -0
  258. package/dist/src/brain/__tests__/environmentDetector.test.js.map +1 -0
  259. package/dist/src/brain/__tests__/executionRouter.test.d.ts +7 -0
  260. package/dist/src/brain/__tests__/executionRouter.test.js +67 -0
  261. package/dist/src/brain/__tests__/executionRouter.test.js.map +1 -0
  262. package/dist/src/brain/__tests__/frameworkSelector.test.d.ts +7 -0
  263. package/dist/src/brain/__tests__/frameworkSelector.test.js +47 -0
  264. package/dist/src/brain/__tests__/frameworkSelector.test.js.map +1 -0
  265. package/dist/src/brain/__tests__/historyTracker.test.d.ts +7 -0
  266. package/dist/src/brain/__tests__/historyTracker.test.js +78 -0
  267. package/dist/src/brain/__tests__/historyTracker.test.js.map +1 -0
  268. package/dist/src/brain/__tests__/pacLoop.test.d.ts +7 -0
  269. package/dist/src/brain/__tests__/pacLoop.test.js +49 -0
  270. package/dist/src/brain/__tests__/pacLoop.test.js.map +1 -0
  271. package/dist/src/brain/__tests__/riskAssessor.test.d.ts +7 -0
  272. package/dist/src/brain/__tests__/riskAssessor.test.js +87 -0
  273. package/dist/src/brain/__tests__/riskAssessor.test.js.map +1 -0
  274. package/dist/src/brain/__tests__/taskDecomposer.test.d.ts +7 -0
  275. package/dist/src/brain/__tests__/taskDecomposer.test.js +86 -0
  276. package/dist/src/brain/__tests__/taskDecomposer.test.js.map +1 -0
  277. package/dist/src/brain/__tests__/thinkingOrchestrator.test.d.ts +7 -0
  278. package/dist/src/brain/__tests__/thinkingOrchestrator.test.js +77 -0
  279. package/dist/src/brain/__tests__/thinkingOrchestrator.test.js.map +1 -0
  280. package/dist/src/brain/advisors/codeGenerator.d.ts +18 -0
  281. package/dist/src/brain/advisors/codeGenerator.js +68 -0
  282. package/dist/src/brain/advisors/codeGenerator.js.map +1 -0
  283. package/dist/src/brain/advisors/depScanner.d.ts +18 -0
  284. package/dist/src/brain/advisors/depScanner.js +76 -0
  285. package/dist/src/brain/advisors/depScanner.js.map +1 -0
  286. package/dist/src/brain/advisors/enumerator.d.ts +18 -0
  287. package/dist/src/brain/advisors/enumerator.js +65 -0
  288. package/dist/src/brain/advisors/enumerator.js.map +1 -0
  289. package/dist/src/brain/advisors/fallbackChain.d.ts +18 -0
  290. package/dist/src/brain/advisors/fallbackChain.js +66 -0
  291. package/dist/src/brain/advisors/fallbackChain.js.map +1 -0
  292. package/dist/src/brain/advisors/patternMatcher.d.ts +18 -0
  293. package/dist/src/brain/advisors/patternMatcher.js +65 -0
  294. package/dist/src/brain/advisors/patternMatcher.js.map +1 -0
  295. package/dist/src/brain/advisors/types.d.ts +24 -0
  296. package/dist/src/brain/advisors/types.js +8 -0
  297. package/dist/src/brain/advisors/types.js.map +1 -0
  298. package/dist/src/brain/codeThinker.d.ts +24 -0
  299. package/dist/src/brain/codeThinker.js +56 -0
  300. package/dist/src/brain/codeThinker.js.map +1 -0
  301. package/dist/src/brain/confidenceHandler.d.ts +13 -0
  302. package/dist/src/brain/confidenceHandler.js +50 -0
  303. package/dist/src/brain/confidenceHandler.js.map +1 -0
  304. package/dist/src/brain/consensus.d.ts +29 -0
  305. package/dist/src/brain/consensus.js +103 -0
  306. package/dist/src/brain/consensus.js.map +1 -0
  307. package/dist/src/brain/environmentDetector.d.ts +9 -0
  308. package/dist/src/brain/environmentDetector.js +87 -0
  309. package/dist/src/brain/environmentDetector.js.map +1 -0
  310. package/dist/src/brain/executionRouter.d.ts +28 -0
  311. package/dist/src/brain/executionRouter.js +71 -0
  312. package/dist/src/brain/executionRouter.js.map +1 -0
  313. package/dist/src/brain/frameworkSelector.d.ts +34 -0
  314. package/dist/src/brain/frameworkSelector.js +155 -0
  315. package/dist/src/brain/frameworkSelector.js.map +1 -0
  316. package/dist/src/brain/historyTracker.d.ts +47 -0
  317. package/dist/src/brain/historyTracker.js +195 -0
  318. package/dist/src/brain/historyTracker.js.map +1 -0
  319. package/dist/src/brain/index.d.ts +29 -0
  320. package/dist/src/brain/index.js +31 -0
  321. package/dist/src/brain/index.js.map +1 -0
  322. package/dist/src/brain/modelAdapter.d.ts +26 -0
  323. package/dist/src/brain/modelAdapter.js +43 -0
  324. package/dist/src/brain/modelAdapter.js.map +1 -0
  325. package/dist/src/brain/pacLoop.d.ts +46 -0
  326. package/dist/src/brain/pacLoop.js +110 -0
  327. package/dist/src/brain/pacLoop.js.map +1 -0
  328. package/dist/src/brain/patterns.d.ts +13 -0
  329. package/dist/src/brain/patterns.js +82 -0
  330. package/dist/src/brain/patterns.js.map +1 -0
  331. package/dist/src/brain/prompts/riskAssessment.d.ts +7 -0
  332. package/dist/src/brain/prompts/riskAssessment.js +29 -0
  333. package/dist/src/brain/prompts/riskAssessment.js.map +1 -0
  334. package/dist/src/brain/reflectiveCritique.d.ts +28 -0
  335. package/dist/src/brain/reflectiveCritique.js +51 -0
  336. package/dist/src/brain/reflectiveCritique.js.map +1 -0
  337. package/dist/src/brain/riskAssessor.d.ts +41 -0
  338. package/dist/src/brain/riskAssessor.js +185 -0
  339. package/dist/src/brain/riskAssessor.js.map +1 -0
  340. package/dist/src/brain/sequentialThinking.d.ts +25 -0
  341. package/dist/src/brain/sequentialThinking.js +52 -0
  342. package/dist/src/brain/sequentialThinking.js.map +1 -0
  343. package/dist/src/brain/stepBackEvaluator.d.ts +30 -0
  344. package/dist/src/brain/stepBackEvaluator.js +35 -0
  345. package/dist/src/brain/stepBackEvaluator.js.map +1 -0
  346. package/dist/src/brain/systemSpec.d.ts +75 -0
  347. package/dist/src/brain/systemSpec.js +194 -0
  348. package/dist/src/brain/systemSpec.js.map +1 -0
  349. package/dist/src/brain/systemSpecPrompt.d.ts +13 -0
  350. package/dist/src/brain/systemSpecPrompt.js +51 -0
  351. package/dist/src/brain/systemSpecPrompt.js.map +1 -0
  352. package/dist/src/brain/taskDecomposer.d.ts +29 -0
  353. package/dist/src/brain/taskDecomposer.js +96 -0
  354. package/dist/src/brain/taskDecomposer.js.map +1 -0
  355. package/dist/src/brain/thinkingOrchestrator.d.ts +48 -0
  356. package/dist/src/brain/thinkingOrchestrator.js +151 -0
  357. package/dist/src/brain/thinkingOrchestrator.js.map +1 -0
  358. package/dist/src/code_assist/codeAssist.d.ts +13 -0
  359. package/dist/src/code_assist/codeAssist.js +32 -0
  360. package/dist/src/code_assist/codeAssist.js.map +1 -0
  361. package/dist/src/code_assist/codeAssist.test.d.ts +7 -0
  362. package/dist/src/code_assist/codeAssist.test.js +100 -0
  363. package/dist/src/code_assist/codeAssist.test.js.map +1 -0
  364. package/dist/src/code_assist/converter.d.ts +76 -0
  365. package/dist/src/code_assist/converter.js +162 -0
  366. package/dist/src/code_assist/converter.js.map +1 -0
  367. package/dist/src/code_assist/converter.test.d.ts +7 -0
  368. package/dist/src/code_assist/converter.test.js +392 -0
  369. package/dist/src/code_assist/converter.test.js.map +1 -0
  370. package/dist/src/code_assist/experiments/client_metadata.d.ts +13 -0
  371. package/dist/src/code_assist/experiments/client_metadata.js +52 -0
  372. package/dist/src/code_assist/experiments/client_metadata.js.map +1 -0
  373. package/dist/src/code_assist/experiments/client_metadata.test.d.ts +7 -0
  374. package/dist/src/code_assist/experiments/client_metadata.test.js +97 -0
  375. package/dist/src/code_assist/experiments/client_metadata.test.js.map +1 -0
  376. package/dist/src/code_assist/experiments/experiments.d.ts +18 -0
  377. package/dist/src/code_assist/experiments/experiments.js +37 -0
  378. package/dist/src/code_assist/experiments/experiments.js.map +1 -0
  379. package/dist/src/code_assist/experiments/experiments.test.d.ts +7 -0
  380. package/dist/src/code_assist/experiments/experiments.test.js +93 -0
  381. package/dist/src/code_assist/experiments/experiments.test.js.map +1 -0
  382. package/dist/src/code_assist/experiments/flagNames.d.ts +14 -0
  383. package/dist/src/code_assist/experiments/flagNames.js +14 -0
  384. package/dist/src/code_assist/experiments/flagNames.js.map +1 -0
  385. package/dist/src/code_assist/experiments/types.d.ts +36 -0
  386. package/dist/src/code_assist/experiments/types.js +8 -0
  387. package/dist/src/code_assist/experiments/types.js.map +1 -0
  388. package/dist/src/code_assist/oauth-credential-storage.d.ts +26 -0
  389. package/dist/src/code_assist/oauth-credential-storage.js +111 -0
  390. package/dist/src/code_assist/oauth-credential-storage.js.map +1 -0
  391. package/dist/src/code_assist/oauth-credential-storage.test.d.ts +7 -0
  392. package/dist/src/code_assist/oauth-credential-storage.test.js +199 -0
  393. package/dist/src/code_assist/oauth-credential-storage.test.js.map +1 -0
  394. package/dist/src/code_assist/oauth2.begin.test.d.ts +7 -0
  395. package/dist/src/code_assist/oauth2.begin.test.js +57 -0
  396. package/dist/src/code_assist/oauth2.begin.test.js.map +1 -0
  397. package/dist/src/code_assist/oauth2.d.ts +35 -0
  398. package/dist/src/code_assist/oauth2.js +568 -0
  399. package/dist/src/code_assist/oauth2.js.map +1 -0
  400. package/dist/src/code_assist/oauth2.test.d.ts +7 -0
  401. package/dist/src/code_assist/oauth2.test.js +1065 -0
  402. package/dist/src/code_assist/oauth2.test.js.map +1 -0
  403. package/dist/src/code_assist/server.d.ts +44 -0
  404. package/dist/src/code_assist/server.js +203 -0
  405. package/dist/src/code_assist/server.js.map +1 -0
  406. package/dist/src/code_assist/server.test.d.ts +7 -0
  407. package/dist/src/code_assist/server.test.js +432 -0
  408. package/dist/src/code_assist/server.test.js.map +1 -0
  409. package/dist/src/code_assist/setup.d.ts +21 -0
  410. package/dist/src/code_assist/setup.js +104 -0
  411. package/dist/src/code_assist/setup.js.map +1 -0
  412. package/dist/src/code_assist/setup.test.d.ts +7 -0
  413. package/dist/src/code_assist/setup.test.js +172 -0
  414. package/dist/src/code_assist/setup.test.js.map +1 -0
  415. package/dist/src/code_assist/telemetry.d.ts +15 -0
  416. package/dist/src/code_assist/telemetry.js +157 -0
  417. package/dist/src/code_assist/telemetry.js.map +1 -0
  418. package/dist/src/code_assist/telemetry.test.d.ts +7 -0
  419. package/dist/src/code_assist/telemetry.test.js +301 -0
  420. package/dist/src/code_assist/telemetry.test.js.map +1 -0
  421. package/dist/src/code_assist/types.d.ts +229 -0
  422. package/dist/src/code_assist/types.js +68 -0
  423. package/dist/src/code_assist/types.js.map +1 -0
  424. package/dist/src/commands/extensions.d.ts +8 -0
  425. package/dist/src/commands/extensions.js +10 -0
  426. package/dist/src/commands/extensions.js.map +1 -0
  427. package/dist/src/commands/extensions.test.d.ts +7 -0
  428. package/dist/src/commands/extensions.test.js +20 -0
  429. package/dist/src/commands/extensions.test.js.map +1 -0
  430. package/dist/src/commands/init.d.ts +8 -0
  431. package/dist/src/commands/init.js +54 -0
  432. package/dist/src/commands/init.js.map +1 -0
  433. package/dist/src/commands/init.test.d.ts +7 -0
  434. package/dist/src/commands/init.test.js +26 -0
  435. package/dist/src/commands/init.test.js.map +1 -0
  436. package/dist/src/commands/restore.d.ts +10 -0
  437. package/dist/src/commands/restore.js +47 -0
  438. package/dist/src/commands/restore.js.map +1 -0
  439. package/dist/src/commands/restore.test.d.ts +7 -0
  440. package/dist/src/commands/restore.test.js +138 -0
  441. package/dist/src/commands/restore.test.js.map +1 -0
  442. package/dist/src/commands/types.d.ts +42 -0
  443. package/dist/src/commands/types.js +8 -0
  444. package/dist/src/commands/types.js.map +1 -0
  445. package/dist/src/computer/ComputerSessionManager.d.ts +46 -0
  446. package/dist/src/computer/ComputerSessionManager.js +201 -0
  447. package/dist/src/computer/ComputerSessionManager.js.map +1 -0
  448. package/dist/src/computer/ComputerSessionManager.test.d.ts +7 -0
  449. package/dist/src/computer/ComputerSessionManager.test.js +98 -0
  450. package/dist/src/computer/ComputerSessionManager.test.js.map +1 -0
  451. package/dist/src/computer/PersistentShell.d.ts +27 -0
  452. package/dist/src/computer/PersistentShell.js +148 -0
  453. package/dist/src/computer/PersistentShell.js.map +1 -0
  454. package/dist/src/computer/PersistentShell.test.d.ts +7 -0
  455. package/dist/src/computer/PersistentShell.test.js +141 -0
  456. package/dist/src/computer/PersistentShell.test.js.map +1 -0
  457. package/dist/src/computer/index.d.ts +8 -0
  458. package/dist/src/computer/index.js +9 -0
  459. package/dist/src/computer/index.js.map +1 -0
  460. package/dist/src/computer/truncateOutput.d.ts +7 -0
  461. package/dist/src/computer/truncateOutput.js +20 -0
  462. package/dist/src/computer/truncateOutput.js.map +1 -0
  463. package/dist/src/config/brainAuthority.d.ts +11 -0
  464. package/dist/src/config/brainAuthority.js +27 -0
  465. package/dist/src/config/brainAuthority.js.map +1 -0
  466. package/dist/src/config/builder.d.ts +24 -0
  467. package/dist/src/config/builder.js +198 -0
  468. package/dist/src/config/builder.js.map +1 -0
  469. package/dist/src/config/config.d.ts +639 -0
  470. package/dist/src/config/config.js +1478 -0
  471. package/dist/src/config/config.js.map +1 -0
  472. package/dist/src/config/config.test.d.ts +7 -0
  473. package/dist/src/config/config.test.js +1579 -0
  474. package/dist/src/config/config.test.js.map +1 -0
  475. package/dist/src/config/constants.d.ts +12 -0
  476. package/dist/src/config/constants.js +17 -0
  477. package/dist/src/config/constants.js.map +1 -0
  478. package/dist/src/config/defaultModelConfigs.d.ts +8 -0
  479. package/dist/src/config/defaultModelConfigs.js +232 -0
  480. package/dist/src/config/defaultModelConfigs.js.map +1 -0
  481. package/dist/src/config/flashFallback.test.d.ts +7 -0
  482. package/dist/src/config/flashFallback.test.js +51 -0
  483. package/dist/src/config/flashFallback.test.js.map +1 -0
  484. package/dist/src/config/models.d.ts +69 -0
  485. package/dist/src/config/models.js +141 -0
  486. package/dist/src/config/models.js.map +1 -0
  487. package/dist/src/config/models.test.d.ts +7 -0
  488. package/dist/src/config/models.test.js +111 -0
  489. package/dist/src/config/models.test.js.map +1 -0
  490. package/dist/src/config/settings/comment-json.d.ts +10 -0
  491. package/dist/src/config/settings/comment-json.js +121 -0
  492. package/dist/src/config/settings/comment-json.js.map +1 -0
  493. package/dist/src/config/settings/constants.d.ts +8 -0
  494. package/dist/src/config/settings/constants.js +9 -0
  495. package/dist/src/config/settings/constants.js.map +1 -0
  496. package/dist/src/config/settings/env-vars.d.ts +13 -0
  497. package/dist/src/config/settings/env-vars.js +38 -0
  498. package/dist/src/config/settings/env-vars.js.map +1 -0
  499. package/dist/src/config/settings/loader.d.ts +52 -0
  500. package/dist/src/config/settings/loader.js +196 -0
  501. package/dist/src/config/settings/loader.js.map +1 -0
  502. package/dist/src/config/settings/loader.test.d.ts +7 -0
  503. package/dist/src/config/settings/loader.test.js +80 -0
  504. package/dist/src/config/settings/loader.test.js.map +1 -0
  505. package/dist/src/config/settings/migrate.d.ts +30 -0
  506. package/dist/src/config/settings/migrate.js +202 -0
  507. package/dist/src/config/settings/migrate.js.map +1 -0
  508. package/dist/src/config/settings/parity.test.d.ts +7 -0
  509. package/dist/src/config/settings/parity.test.js +147 -0
  510. package/dist/src/config/settings/parity.test.js.map +1 -0
  511. package/dist/src/config/settings/schema-types.d.ts +47 -0
  512. package/dist/src/config/settings/schema-types.js +14 -0
  513. package/dist/src/config/settings/schema-types.js.map +1 -0
  514. package/dist/src/config/settings/schema.d.ts +2126 -0
  515. package/dist/src/config/settings/schema.js +2345 -0
  516. package/dist/src/config/settings/schema.js.map +1 -0
  517. package/dist/src/config/settings/settings.test.d.ts +7 -0
  518. package/dist/src/config/settings/settings.test.js +90 -0
  519. package/dist/src/config/settings/settings.test.js.map +1 -0
  520. package/dist/src/config/settings/trust.d.ts +27 -0
  521. package/dist/src/config/settings/trust.js +175 -0
  522. package/dist/src/config/settings/trust.js.map +1 -0
  523. package/dist/src/config/settings/trust.test.d.ts +7 -0
  524. package/dist/src/config/settings/trust.test.js +63 -0
  525. package/dist/src/config/settings/trust.test.js.map +1 -0
  526. package/dist/src/config/settings/types.d.ts +134 -0
  527. package/dist/src/config/settings/types.js +30 -0
  528. package/dist/src/config/settings/types.js.map +1 -0
  529. package/dist/src/config/settings/utils.d.ts +19 -0
  530. package/dist/src/config/settings/utils.js +67 -0
  531. package/dist/src/config/settings/utils.js.map +1 -0
  532. package/dist/src/config/settings/validate.d.ts +24 -0
  533. package/dist/src/config/settings/validate.js +250 -0
  534. package/dist/src/config/settings/validate.js.map +1 -0
  535. package/dist/src/config/storage.d.ts +45 -0
  536. package/dist/src/config/storage.js +140 -0
  537. package/dist/src/config/storage.js.map +1 -0
  538. package/dist/src/config/storage.test.d.ts +7 -0
  539. package/dist/src/config/storage.test.js +57 -0
  540. package/dist/src/config/storage.test.js.map +1 -0
  541. package/dist/src/confirmation-bus/index.d.ts +8 -0
  542. package/dist/src/confirmation-bus/index.js +9 -0
  543. package/dist/src/confirmation-bus/index.js.map +1 -0
  544. package/dist/src/confirmation-bus/message-bus.d.ts +25 -0
  545. package/dist/src/confirmation-bus/message-bus.js +150 -0
  546. package/dist/src/confirmation-bus/message-bus.js.map +1 -0
  547. package/dist/src/confirmation-bus/message-bus.test.d.ts +7 -0
  548. package/dist/src/confirmation-bus/message-bus.test.js +171 -0
  549. package/dist/src/confirmation-bus/message-bus.test.js.map +1 -0
  550. package/dist/src/confirmation-bus/types.d.ts +77 -0
  551. package/dist/src/confirmation-bus/types.js +20 -0
  552. package/dist/src/confirmation-bus/types.js.map +1 -0
  553. package/dist/src/core/apiKeyCredentialStorage.d.ts +18 -0
  554. package/dist/src/core/apiKeyCredentialStorage.js +65 -0
  555. package/dist/src/core/apiKeyCredentialStorage.js.map +1 -0
  556. package/dist/src/core/apiKeyCredentialStorage.test.d.ts +7 -0
  557. package/dist/src/core/apiKeyCredentialStorage.test.js +72 -0
  558. package/dist/src/core/apiKeyCredentialStorage.test.js.map +1 -0
  559. package/dist/src/core/baseLlmClient.d.ts +75 -0
  560. package/dist/src/core/baseLlmClient.js +168 -0
  561. package/dist/src/core/baseLlmClient.js.map +1 -0
  562. package/dist/src/core/baseLlmClient.test.d.ts +7 -0
  563. package/dist/src/core/baseLlmClient.test.js +570 -0
  564. package/dist/src/core/baseLlmClient.test.js.map +1 -0
  565. package/dist/src/core/client.d.ts +54 -0
  566. package/dist/src/core/client.js +539 -0
  567. package/dist/src/core/client.js.map +1 -0
  568. package/dist/src/core/client.test.d.ts +7 -0
  569. package/dist/src/core/client.test.js +1919 -0
  570. package/dist/src/core/client.test.js.map +1 -0
  571. package/dist/src/core/clientHookTriggers.d.ts +37 -0
  572. package/dist/src/core/clientHookTriggers.js +77 -0
  573. package/dist/src/core/clientHookTriggers.js.map +1 -0
  574. package/dist/src/core/contentGenerator.d.ts +35 -0
  575. package/dist/src/core/contentGenerator.js +134 -0
  576. package/dist/src/core/contentGenerator.js.map +1 -0
  577. package/dist/src/core/contentGenerator.test.d.ts +7 -0
  578. package/dist/src/core/contentGenerator.test.js +435 -0
  579. package/dist/src/core/contentGenerator.test.js.map +1 -0
  580. package/dist/src/core/coreToolHookTriggers.d.ts +56 -0
  581. package/dist/src/core/coreToolHookTriggers.js +262 -0
  582. package/dist/src/core/coreToolHookTriggers.js.map +1 -0
  583. package/dist/src/core/coreToolScheduler.d.ts +145 -0
  584. package/dist/src/core/coreToolScheduler.js +1119 -0
  585. package/dist/src/core/coreToolScheduler.js.map +1 -0
  586. package/dist/src/core/coreToolScheduler.test.d.ts +7 -0
  587. package/dist/src/core/coreToolScheduler.test.js +1857 -0
  588. package/dist/src/core/coreToolScheduler.test.js.map +1 -0
  589. package/dist/src/core/fakeContentGenerator.d.ts +34 -0
  590. package/dist/src/core/fakeContentGenerator.js +59 -0
  591. package/dist/src/core/fakeContentGenerator.js.map +1 -0
  592. package/dist/src/core/fakeContentGenerator.test.d.ts +7 -0
  593. package/dist/src/core/fakeContentGenerator.test.js +128 -0
  594. package/dist/src/core/fakeContentGenerator.test.js.map +1 -0
  595. package/dist/src/core/geminiChat.d.ts +137 -0
  596. package/dist/src/core/geminiChat.js +663 -0
  597. package/dist/src/core/geminiChat.js.map +1 -0
  598. package/dist/src/core/geminiChat.test.d.ts +7 -0
  599. package/dist/src/core/geminiChat.test.js +1653 -0
  600. package/dist/src/core/geminiChat.test.js.map +1 -0
  601. package/dist/src/core/geminiChatHookTriggers.d.ts +65 -0
  602. package/dist/src/core/geminiChatHookTriggers.js +137 -0
  603. package/dist/src/core/geminiChatHookTriggers.js.map +1 -0
  604. package/dist/src/core/geminiChat_network_retry.test.d.ts +7 -0
  605. package/dist/src/core/geminiChat_network_retry.test.js +197 -0
  606. package/dist/src/core/geminiChat_network_retry.test.js.map +1 -0
  607. package/dist/src/core/geminiRequest.d.ts +14 -0
  608. package/dist/src/core/geminiRequest.js +12 -0
  609. package/dist/src/core/geminiRequest.js.map +1 -0
  610. package/dist/src/core/logger.d.ts +74 -0
  611. package/dist/src/core/logger.js +337 -0
  612. package/dist/src/core/logger.js.map +1 -0
  613. package/dist/src/core/logger.test.d.ts +7 -0
  614. package/dist/src/core/logger.test.js +537 -0
  615. package/dist/src/core/logger.test.js.map +1 -0
  616. package/dist/src/core/loggingContentGenerator.d.ts +27 -0
  617. package/dist/src/core/loggingContentGenerator.js +180 -0
  618. package/dist/src/core/loggingContentGenerator.js.map +1 -0
  619. package/dist/src/core/loggingContentGenerator.test.d.ts +7 -0
  620. package/dist/src/core/loggingContentGenerator.test.js +181 -0
  621. package/dist/src/core/loggingContentGenerator.test.js.map +1 -0
  622. package/dist/src/core/nonInteractiveToolExecutor.d.ts +12 -0
  623. package/dist/src/core/nonInteractiveToolExecutor.js +30 -0
  624. package/dist/src/core/nonInteractiveToolExecutor.js.map +1 -0
  625. package/dist/src/core/nonInteractiveToolExecutor.test.d.ts +7 -0
  626. package/dist/src/core/nonInteractiveToolExecutor.test.js +306 -0
  627. package/dist/src/core/nonInteractiveToolExecutor.test.js.map +1 -0
  628. package/dist/src/core/openaiContentGenerator.d.ts +28 -0
  629. package/dist/src/core/openaiContentGenerator.js +507 -0
  630. package/dist/src/core/openaiContentGenerator.js.map +1 -0
  631. package/dist/src/core/openaiContentGenerator.test.d.ts +7 -0
  632. package/dist/src/core/openaiContentGenerator.test.js +502 -0
  633. package/dist/src/core/openaiContentGenerator.test.js.map +1 -0
  634. package/dist/src/core/prompts.d.ts +19 -0
  635. package/dist/src/core/prompts.js +384 -0
  636. package/dist/src/core/prompts.js.map +1 -0
  637. package/dist/src/core/prompts.test.d.ts +7 -0
  638. package/dist/src/core/prompts.test.js +332 -0
  639. package/dist/src/core/prompts.test.js.map +1 -0
  640. package/dist/src/core/providerTypes.d.ts +37 -0
  641. package/dist/src/core/providerTypes.js +54 -0
  642. package/dist/src/core/providerTypes.js.map +1 -0
  643. package/dist/src/core/providerTypes.test.d.ts +7 -0
  644. package/dist/src/core/providerTypes.test.js +55 -0
  645. package/dist/src/core/providerTypes.test.js.map +1 -0
  646. package/dist/src/core/recordingContentGenerator.d.ts +19 -0
  647. package/dist/src/core/recordingContentGenerator.js +78 -0
  648. package/dist/src/core/recordingContentGenerator.js.map +1 -0
  649. package/dist/src/core/recordingContentGenerator.test.d.ts +7 -0
  650. package/dist/src/core/recordingContentGenerator.test.js +102 -0
  651. package/dist/src/core/recordingContentGenerator.test.js.map +1 -0
  652. package/dist/src/core/sessionHookTriggers.d.ts +29 -0
  653. package/dist/src/core/sessionHookTriggers.js +69 -0
  654. package/dist/src/core/sessionHookTriggers.js.map +1 -0
  655. package/dist/src/core/tokenLimits.d.ts +11 -0
  656. package/dist/src/core/tokenLimits.js +29 -0
  657. package/dist/src/core/tokenLimits.js.map +1 -0
  658. package/dist/src/core/tokenLimits.test.d.ts +7 -0
  659. package/dist/src/core/tokenLimits.test.js +27 -0
  660. package/dist/src/core/tokenLimits.test.js.map +1 -0
  661. package/dist/src/core/turn.d.ts +177 -0
  662. package/dist/src/core/turn.js +230 -0
  663. package/dist/src/core/turn.js.map +1 -0
  664. package/dist/src/core/turn.test.d.ts +7 -0
  665. package/dist/src/core/turn.test.js +650 -0
  666. package/dist/src/core/turn.test.js.map +1 -0
  667. package/dist/src/evaluation/index.d.ts +7 -0
  668. package/dist/src/evaluation/index.js +8 -0
  669. package/dist/src/evaluation/index.js.map +1 -0
  670. package/dist/src/evaluation/sessionEvaluator.d.ts +59 -0
  671. package/dist/src/evaluation/sessionEvaluator.js +222 -0
  672. package/dist/src/evaluation/sessionEvaluator.js.map +1 -0
  673. package/dist/src/fallback/handler.d.ts +8 -0
  674. package/dist/src/fallback/handler.js +117 -0
  675. package/dist/src/fallback/handler.js.map +1 -0
  676. package/dist/src/fallback/handler.test.d.ts +7 -0
  677. package/dist/src/fallback/handler.test.js +248 -0
  678. package/dist/src/fallback/handler.test.js.map +1 -0
  679. package/dist/src/fallback/types.d.ts +23 -0
  680. package/dist/src/fallback/types.js +8 -0
  681. package/dist/src/fallback/types.js.map +1 -0
  682. package/dist/src/generated/git-commit.d.ts +8 -0
  683. package/dist/src/generated/git-commit.js +11 -0
  684. package/dist/src/generated/git-commit.js.map +1 -0
  685. package/dist/src/gui/config.d.ts +19 -0
  686. package/dist/src/gui/config.js +53 -0
  687. package/dist/src/gui/config.js.map +1 -0
  688. package/dist/src/gui/drivers/__tests__/sidecarContract.test.d.ts +7 -0
  689. package/dist/src/gui/drivers/__tests__/sidecarContract.test.js +161 -0
  690. package/dist/src/gui/drivers/__tests__/sidecarContract.test.js.map +1 -0
  691. package/dist/src/gui/drivers/driverRegistry.d.ts +8 -0
  692. package/dist/src/gui/drivers/driverRegistry.js +31 -0
  693. package/dist/src/gui/drivers/driverRegistry.js.map +1 -0
  694. package/dist/src/gui/drivers/linuxAtspiDriver.d.ts +33 -0
  695. package/dist/src/gui/drivers/linuxAtspiDriver.js +200 -0
  696. package/dist/src/gui/drivers/linuxAtspiDriver.js.map +1 -0
  697. package/dist/src/gui/drivers/mockDriver.d.ts +25 -0
  698. package/dist/src/gui/drivers/mockDriver.js +123 -0
  699. package/dist/src/gui/drivers/mockDriver.js.map +1 -0
  700. package/dist/src/gui/drivers/noOpDriver.d.ts +31 -0
  701. package/dist/src/gui/drivers/noOpDriver.js +110 -0
  702. package/dist/src/gui/drivers/noOpDriver.js.map +1 -0
  703. package/dist/src/gui/drivers/types.d.ts +50 -0
  704. package/dist/src/gui/drivers/types.js +8 -0
  705. package/dist/src/gui/drivers/types.js.map +1 -0
  706. package/dist/src/gui/drivers/windowsUiaDriver.d.ts +32 -0
  707. package/dist/src/gui/drivers/windowsUiaDriver.js +134 -0
  708. package/dist/src/gui/drivers/windowsUiaDriver.js.map +1 -0
  709. package/dist/src/gui/protocol/__tests__/schema.test.d.ts +7 -0
  710. package/dist/src/gui/protocol/__tests__/schema.test.js +72 -0
  711. package/dist/src/gui/protocol/__tests__/schema.test.js.map +1 -0
  712. package/dist/src/gui/protocol/schemas.d.ts +960 -0
  713. package/dist/src/gui/protocol/schemas.js +252 -0
  714. package/dist/src/gui/protocol/schemas.js.map +1 -0
  715. package/dist/src/gui/protocol/types.d.ts +149 -0
  716. package/dist/src/gui/protocol/types.js +8 -0
  717. package/dist/src/gui/protocol/types.js.map +1 -0
  718. package/dist/src/gui/selectors/__tests__/selectors.test.d.ts +7 -0
  719. package/dist/src/gui/selectors/__tests__/selectors.test.js +125 -0
  720. package/dist/src/gui/selectors/__tests__/selectors.test.js.map +1 -0
  721. package/dist/src/gui/selectors/ast.d.ts +34 -0
  722. package/dist/src/gui/selectors/ast.js +8 -0
  723. package/dist/src/gui/selectors/ast.js.map +1 -0
  724. package/dist/src/gui/selectors/matcher.d.ts +19 -0
  725. package/dist/src/gui/selectors/matcher.js +118 -0
  726. package/dist/src/gui/selectors/matcher.js.map +1 -0
  727. package/dist/src/gui/selectors/parser.d.ts +26 -0
  728. package/dist/src/gui/selectors/parser.js +235 -0
  729. package/dist/src/gui/selectors/parser.js.map +1 -0
  730. package/dist/src/gui/selectors/resolve.d.ts +18 -0
  731. package/dist/src/gui/selectors/resolve.js +74 -0
  732. package/dist/src/gui/selectors/resolve.js.map +1 -0
  733. package/dist/src/gui/service/DesktopAutomationService.d.ts +46 -0
  734. package/dist/src/gui/service/DesktopAutomationService.js +689 -0
  735. package/dist/src/gui/service/DesktopAutomationService.js.map +1 -0
  736. package/dist/src/gui/service/__tests__/capabilities.test.d.ts +1 -0
  737. package/dist/src/gui/service/__tests__/capabilities.test.js +95 -0
  738. package/dist/src/gui/service/__tests__/capabilities.test.js.map +1 -0
  739. package/dist/src/gui/service/__tests__/diagnose.test.d.ts +1 -0
  740. package/dist/src/gui/service/__tests__/diagnose.test.js +91 -0
  741. package/dist/src/gui/service/__tests__/diagnose.test.js.map +1 -0
  742. package/dist/src/gui/service/__tests__/progressive.test.d.ts +1 -0
  743. package/dist/src/gui/service/__tests__/progressive.test.js +94 -0
  744. package/dist/src/gui/service/__tests__/progressive.test.js.map +1 -0
  745. package/dist/src/gui/service/__tests__/redaction.test.d.ts +1 -0
  746. package/dist/src/gui/service/__tests__/redaction.test.js +94 -0
  747. package/dist/src/gui/service/__tests__/redaction.test.js.map +1 -0
  748. package/dist/src/gui/service/__tests__/selectorError.test.d.ts +1 -0
  749. package/dist/src/gui/service/__tests__/selectorError.test.js +28 -0
  750. package/dist/src/gui/service/__tests__/selectorError.test.js.map +1 -0
  751. package/dist/src/gui/service/__tests__/wait.test.d.ts +1 -0
  752. package/dist/src/gui/service/__tests__/wait.test.js +84 -0
  753. package/dist/src/gui/service/__tests__/wait.test.js.map +1 -0
  754. package/dist/src/hooks/hookAggregator.d.ts +69 -0
  755. package/dist/src/hooks/hookAggregator.js +263 -0
  756. package/dist/src/hooks/hookAggregator.js.map +1 -0
  757. package/dist/src/hooks/hookAggregator.test.d.ts +7 -0
  758. package/dist/src/hooks/hookAggregator.test.js +388 -0
  759. package/dist/src/hooks/hookAggregator.test.js.map +1 -0
  760. package/dist/src/hooks/hookEventHandler.d.ts +110 -0
  761. package/dist/src/hooks/hookEventHandler.js +551 -0
  762. package/dist/src/hooks/hookEventHandler.js.map +1 -0
  763. package/dist/src/hooks/hookEventHandler.test.d.ts +7 -0
  764. package/dist/src/hooks/hookEventHandler.test.js +432 -0
  765. package/dist/src/hooks/hookEventHandler.test.js.map +1 -0
  766. package/dist/src/hooks/hookPlanner.d.ts +47 -0
  767. package/dist/src/hooks/hookPlanner.js +111 -0
  768. package/dist/src/hooks/hookPlanner.js.map +1 -0
  769. package/dist/src/hooks/hookPlanner.test.d.ts +7 -0
  770. package/dist/src/hooks/hookPlanner.test.js +317 -0
  771. package/dist/src/hooks/hookPlanner.test.js.map +1 -0
  772. package/dist/src/hooks/hookRegistry.d.ts +81 -0
  773. package/dist/src/hooks/hookRegistry.js +186 -0
  774. package/dist/src/hooks/hookRegistry.js.map +1 -0
  775. package/dist/src/hooks/hookRegistry.test.d.ts +7 -0
  776. package/dist/src/hooks/hookRegistry.test.js +410 -0
  777. package/dist/src/hooks/hookRegistry.test.js.map +1 -0
  778. package/dist/src/hooks/hookRunner.d.ts +43 -0
  779. package/dist/src/hooks/hookRunner.js +295 -0
  780. package/dist/src/hooks/hookRunner.js.map +1 -0
  781. package/dist/src/hooks/hookRunner.test.d.ts +7 -0
  782. package/dist/src/hooks/hookRunner.test.js +518 -0
  783. package/dist/src/hooks/hookRunner.test.js.map +1 -0
  784. package/dist/src/hooks/hookSystem.d.ts +41 -0
  785. package/dist/src/hooks/hookSystem.js +66 -0
  786. package/dist/src/hooks/hookSystem.js.map +1 -0
  787. package/dist/src/hooks/hookSystem.test.d.ts +7 -0
  788. package/dist/src/hooks/hookSystem.test.js +320 -0
  789. package/dist/src/hooks/hookSystem.test.js.map +1 -0
  790. package/dist/src/hooks/hookTranslator.d.ts +114 -0
  791. package/dist/src/hooks/hookTranslator.js +233 -0
  792. package/dist/src/hooks/hookTranslator.js.map +1 -0
  793. package/dist/src/hooks/hookTranslator.test.d.ts +7 -0
  794. package/dist/src/hooks/hookTranslator.test.js +193 -0
  795. package/dist/src/hooks/hookTranslator.test.js.map +1 -0
  796. package/dist/src/hooks/index.d.ts +18 -0
  797. package/dist/src/hooks/index.js +19 -0
  798. package/dist/src/hooks/index.js.map +1 -0
  799. package/dist/src/hooks/types.d.ts +386 -0
  800. package/dist/src/hooks/types.js +284 -0
  801. package/dist/src/hooks/types.js.map +1 -0
  802. package/dist/src/hooks/types.test.d.ts +7 -0
  803. package/dist/src/hooks/types.test.js +314 -0
  804. package/dist/src/hooks/types.test.js.map +1 -0
  805. package/dist/src/ide/constants.d.ts +10 -0
  806. package/dist/src/ide/constants.js +11 -0
  807. package/dist/src/ide/constants.js.map +1 -0
  808. package/dist/src/ide/detect-ide.d.ts +61 -0
  809. package/dist/src/ide/detect-ide.js +73 -0
  810. package/dist/src/ide/detect-ide.js.map +1 -0
  811. package/dist/src/ide/detect-ide.test.d.ts +7 -0
  812. package/dist/src/ide/detect-ide.test.js +140 -0
  813. package/dist/src/ide/detect-ide.test.js.map +1 -0
  814. package/dist/src/ide/ide-client.d.ts +113 -0
  815. package/dist/src/ide/ide-client.js +650 -0
  816. package/dist/src/ide/ide-client.js.map +1 -0
  817. package/dist/src/ide/ide-client.test.d.ts +7 -0
  818. package/dist/src/ide/ide-client.test.js +565 -0
  819. package/dist/src/ide/ide-client.test.js.map +1 -0
  820. package/dist/src/ide/ide-installer.d.ts +15 -0
  821. package/dist/src/ide/ide-installer.js +157 -0
  822. package/dist/src/ide/ide-installer.js.map +1 -0
  823. package/dist/src/ide/ide-installer.test.d.ts +7 -0
  824. package/dist/src/ide/ide-installer.test.js +185 -0
  825. package/dist/src/ide/ide-installer.test.js.map +1 -0
  826. package/dist/src/ide/ideContext.d.ts +45 -0
  827. package/dist/src/ide/ideContext.js +102 -0
  828. package/dist/src/ide/ideContext.js.map +1 -0
  829. package/dist/src/ide/ideContext.test.d.ts +7 -0
  830. package/dist/src/ide/ideContext.test.js +394 -0
  831. package/dist/src/ide/ideContext.test.js.map +1 -0
  832. package/dist/src/ide/process-utils.d.ts +22 -0
  833. package/dist/src/ide/process-utils.js +182 -0
  834. package/dist/src/ide/process-utils.js.map +1 -0
  835. package/dist/src/ide/process-utils.test.d.ts +7 -0
  836. package/dist/src/ide/process-utils.test.js +152 -0
  837. package/dist/src/ide/process-utils.test.js.map +1 -0
  838. package/dist/src/ide/types.d.ts +487 -0
  839. package/dist/src/ide/types.js +139 -0
  840. package/dist/src/ide/types.js.map +1 -0
  841. package/dist/src/index.d.ts +154 -0
  842. package/dist/src/index.js +172 -0
  843. package/dist/src/index.js.map +1 -0
  844. package/dist/src/index.test.d.ts +7 -0
  845. package/dist/src/index.test.js +13 -0
  846. package/dist/src/index.test.js.map +1 -0
  847. package/dist/src/mcp/auth-provider.d.ts +17 -0
  848. package/dist/src/mcp/auth-provider.js +8 -0
  849. package/dist/src/mcp/auth-provider.js.map +1 -0
  850. package/dist/src/mcp/google-auth-provider.d.ts +34 -0
  851. package/dist/src/mcp/google-auth-provider.js +119 -0
  852. package/dist/src/mcp/google-auth-provider.js.map +1 -0
  853. package/dist/src/mcp/google-auth-provider.test.d.ts +7 -0
  854. package/dist/src/mcp/google-auth-provider.test.js +168 -0
  855. package/dist/src/mcp/google-auth-provider.test.js.map +1 -0
  856. package/dist/src/mcp/oauth-provider.d.ts +154 -0
  857. package/dist/src/mcp/oauth-provider.js +703 -0
  858. package/dist/src/mcp/oauth-provider.js.map +1 -0
  859. package/dist/src/mcp/oauth-provider.test.d.ts +7 -0
  860. package/dist/src/mcp/oauth-provider.test.js +1218 -0
  861. package/dist/src/mcp/oauth-provider.test.js.map +1 -0
  862. package/dist/src/mcp/oauth-token-storage.d.ts +66 -0
  863. package/dist/src/mcp/oauth-token-storage.js +182 -0
  864. package/dist/src/mcp/oauth-token-storage.js.map +1 -0
  865. package/dist/src/mcp/oauth-token-storage.test.d.ts +7 -0
  866. package/dist/src/mcp/oauth-token-storage.test.js +306 -0
  867. package/dist/src/mcp/oauth-token-storage.test.js.map +1 -0
  868. package/dist/src/mcp/oauth-utils.d.ts +134 -0
  869. package/dist/src/mcp/oauth-utils.js +286 -0
  870. package/dist/src/mcp/oauth-utils.js.map +1 -0
  871. package/dist/src/mcp/oauth-utils.test.d.ts +7 -0
  872. package/dist/src/mcp/oauth-utils.test.js +285 -0
  873. package/dist/src/mcp/oauth-utils.test.js.map +1 -0
  874. package/dist/src/mcp/sa-impersonation-provider.d.ts +28 -0
  875. package/dist/src/mcp/sa-impersonation-provider.js +114 -0
  876. package/dist/src/mcp/sa-impersonation-provider.js.map +1 -0
  877. package/dist/src/mcp/sa-impersonation-provider.test.d.ts +7 -0
  878. package/dist/src/mcp/sa-impersonation-provider.test.js +118 -0
  879. package/dist/src/mcp/sa-impersonation-provider.test.js.map +1 -0
  880. package/dist/src/mcp/token-storage/base-token-storage.d.ts +20 -0
  881. package/dist/src/mcp/token-storage/base-token-storage.js +37 -0
  882. package/dist/src/mcp/token-storage/base-token-storage.js.map +1 -0
  883. package/dist/src/mcp/token-storage/base-token-storage.test.d.ts +7 -0
  884. package/dist/src/mcp/token-storage/base-token-storage.test.js +152 -0
  885. package/dist/src/mcp/token-storage/base-token-storage.test.js.map +1 -0
  886. package/dist/src/mcp/token-storage/file-token-storage.d.ts +25 -0
  887. package/dist/src/mcp/token-storage/file-token-storage.js +146 -0
  888. package/dist/src/mcp/token-storage/file-token-storage.js.map +1 -0
  889. package/dist/src/mcp/token-storage/file-token-storage.test.d.ts +7 -0
  890. package/dist/src/mcp/token-storage/file-token-storage.test.js +239 -0
  891. package/dist/src/mcp/token-storage/file-token-storage.test.js.map +1 -0
  892. package/dist/src/mcp/token-storage/hybrid-token-storage.d.ts +24 -0
  893. package/dist/src/mcp/token-storage/hybrid-token-storage.js +79 -0
  894. package/dist/src/mcp/token-storage/hybrid-token-storage.js.map +1 -0
  895. package/dist/src/mcp/token-storage/hybrid-token-storage.test.d.ts +7 -0
  896. package/dist/src/mcp/token-storage/hybrid-token-storage.test.js +194 -0
  897. package/dist/src/mcp/token-storage/hybrid-token-storage.test.js.map +1 -0
  898. package/dist/src/mcp/token-storage/index.d.ts +12 -0
  899. package/dist/src/mcp/token-storage/index.js +13 -0
  900. package/dist/src/mcp/token-storage/index.js.map +1 -0
  901. package/dist/src/mcp/token-storage/keychain-token-storage.d.ts +36 -0
  902. package/dist/src/mcp/token-storage/keychain-token-storage.js +247 -0
  903. package/dist/src/mcp/token-storage/keychain-token-storage.js.map +1 -0
  904. package/dist/src/mcp/token-storage/keychain-token-storage.test.d.ts +7 -0
  905. package/dist/src/mcp/token-storage/keychain-token-storage.test.js +306 -0
  906. package/dist/src/mcp/token-storage/keychain-token-storage.test.js.map +1 -0
  907. package/dist/src/mcp/token-storage/types.d.ts +45 -0
  908. package/dist/src/mcp/token-storage/types.js +12 -0
  909. package/dist/src/mcp/token-storage/types.js.map +1 -0
  910. package/dist/src/mocks/msw.d.ts +7 -0
  911. package/dist/src/mocks/msw.js +9 -0
  912. package/dist/src/mocks/msw.js.map +1 -0
  913. package/dist/src/output/json-formatter.d.ts +12 -0
  914. package/dist/src/output/json-formatter.js +34 -0
  915. package/dist/src/output/json-formatter.js.map +1 -0
  916. package/dist/src/output/json-formatter.test.d.ts +7 -0
  917. package/dist/src/output/json-formatter.test.js +295 -0
  918. package/dist/src/output/json-formatter.test.js.map +1 -0
  919. package/dist/src/output/stream-json-formatter.d.ts +33 -0
  920. package/dist/src/output/stream-json-formatter.js +59 -0
  921. package/dist/src/output/stream-json-formatter.js.map +1 -0
  922. package/dist/src/output/stream-json-formatter.test.d.ts +7 -0
  923. package/dist/src/output/stream-json-formatter.test.js +478 -0
  924. package/dist/src/output/stream-json-formatter.test.js.map +1 -0
  925. package/dist/src/output/types.d.ts +86 -0
  926. package/dist/src/output/types.js +23 -0
  927. package/dist/src/output/types.js.map +1 -0
  928. package/dist/src/policy/config.d.ts +34 -0
  929. package/dist/src/policy/config.js +334 -0
  930. package/dist/src/policy/config.js.map +1 -0
  931. package/dist/src/policy/config.test.d.ts +7 -0
  932. package/dist/src/policy/config.test.js +540 -0
  933. package/dist/src/policy/config.test.js.map +1 -0
  934. package/dist/src/policy/index.d.ts +10 -0
  935. package/dist/src/policy/index.js +11 -0
  936. package/dist/src/policy/index.js.map +1 -0
  937. package/dist/src/policy/persistence.test.d.ts +7 -0
  938. package/dist/src/policy/persistence.test.js +150 -0
  939. package/dist/src/policy/persistence.test.js.map +1 -0
  940. package/dist/src/policy/policies/agent.toml +31 -0
  941. package/dist/src/policy/policies/discovered.toml +8 -0
  942. package/dist/src/policy/policies/read-only.toml +96 -0
  943. package/dist/src/policy/policies/write.toml +110 -0
  944. package/dist/src/policy/policies/yolo.toml +31 -0
  945. package/dist/src/policy/policy-engine.d.ts +56 -0
  946. package/dist/src/policy/policy-engine.js +302 -0
  947. package/dist/src/policy/policy-engine.js.map +1 -0
  948. package/dist/src/policy/policy-engine.test.d.ts +7 -0
  949. package/dist/src/policy/policy-engine.test.js +1122 -0
  950. package/dist/src/policy/policy-engine.test.js.map +1 -0
  951. package/dist/src/policy/recipes/dns-debug.toml +28 -0
  952. package/dist/src/policy/recipes/docker-prune.toml +28 -0
  953. package/dist/src/policy/recipes/wifi-fix.toml +31 -0
  954. package/dist/src/policy/shell-safety.test.d.ts +7 -0
  955. package/dist/src/policy/shell-safety.test.js +75 -0
  956. package/dist/src/policy/shell-safety.test.js.map +1 -0
  957. package/dist/src/policy/stable-stringify.d.ts +59 -0
  958. package/dist/src/policy/stable-stringify.js +123 -0
  959. package/dist/src/policy/stable-stringify.js.map +1 -0
  960. package/dist/src/policy/toml-loader.d.ts +56 -0
  961. package/dist/src/policy/toml-loader.js +412 -0
  962. package/dist/src/policy/toml-loader.js.map +1 -0
  963. package/dist/src/policy/toml-loader.test.d.ts +7 -0
  964. package/dist/src/policy/toml-loader.test.js +377 -0
  965. package/dist/src/policy/toml-loader.test.js.map +1 -0
  966. package/dist/src/policy/types.d.ts +181 -0
  967. package/dist/src/policy/types.js +44 -0
  968. package/dist/src/policy/types.js.map +1 -0
  969. package/dist/src/prompts/mcp-prompts.d.ts +9 -0
  970. package/dist/src/prompts/mcp-prompts.js +14 -0
  971. package/dist/src/prompts/mcp-prompts.js.map +1 -0
  972. package/dist/src/prompts/mcp-prompts.test.d.ts +7 -0
  973. package/dist/src/prompts/mcp-prompts.test.js +40 -0
  974. package/dist/src/prompts/mcp-prompts.test.js.map +1 -0
  975. package/dist/src/prompts/prompt-registry.d.ts +35 -0
  976. package/dist/src/prompts/prompt-registry.js +65 -0
  977. package/dist/src/prompts/prompt-registry.js.map +1 -0
  978. package/dist/src/prompts/prompt-registry.test.d.ts +7 -0
  979. package/dist/src/prompts/prompt-registry.test.js +97 -0
  980. package/dist/src/prompts/prompt-registry.test.js.map +1 -0
  981. package/dist/src/recipes/builtins/index.d.ts +8 -0
  982. package/dist/src/recipes/builtins/index.js +115 -0
  983. package/dist/src/recipes/builtins/index.js.map +1 -0
  984. package/dist/src/recipes/executor.d.ts +23 -0
  985. package/dist/src/recipes/executor.js +86 -0
  986. package/dist/src/recipes/executor.js.map +1 -0
  987. package/dist/src/recipes/executor.test.d.ts +7 -0
  988. package/dist/src/recipes/executor.test.js +86 -0
  989. package/dist/src/recipes/executor.test.js.map +1 -0
  990. package/dist/src/recipes/index.d.ts +10 -0
  991. package/dist/src/recipes/index.js +11 -0
  992. package/dist/src/recipes/index.js.map +1 -0
  993. package/dist/src/recipes/loader.d.ts +27 -0
  994. package/dist/src/recipes/loader.js +187 -0
  995. package/dist/src/recipes/loader.js.map +1 -0
  996. package/dist/src/recipes/loader.test.d.ts +7 -0
  997. package/dist/src/recipes/loader.test.js +84 -0
  998. package/dist/src/recipes/loader.test.js.map +1 -0
  999. package/dist/src/recipes/schema.d.ts +43 -0
  1000. package/dist/src/recipes/schema.js +8 -0
  1001. package/dist/src/recipes/schema.js.map +1 -0
  1002. package/dist/src/resources/resource-registry.d.ts +31 -0
  1003. package/dist/src/resources/resource-registry.js +58 -0
  1004. package/dist/src/resources/resource-registry.js.map +1 -0
  1005. package/dist/src/resources/resource-registry.test.d.ts +7 -0
  1006. package/dist/src/resources/resource-registry.test.js +55 -0
  1007. package/dist/src/resources/resource-registry.test.js.map +1 -0
  1008. package/dist/src/routing/modelRouterService.d.ts +24 -0
  1009. package/dist/src/routing/modelRouterService.js +71 -0
  1010. package/dist/src/routing/modelRouterService.js.map +1 -0
  1011. package/dist/src/routing/modelRouterService.test.d.ts +7 -0
  1012. package/dist/src/routing/modelRouterService.test.js +99 -0
  1013. package/dist/src/routing/modelRouterService.test.js.map +1 -0
  1014. package/dist/src/routing/routingStrategy.d.ts +63 -0
  1015. package/dist/src/routing/routingStrategy.js +8 -0
  1016. package/dist/src/routing/routingStrategy.js.map +1 -0
  1017. package/dist/src/routing/strategies/classifierStrategy.d.ts +13 -0
  1018. package/dist/src/routing/strategies/classifierStrategy.js +156 -0
  1019. package/dist/src/routing/strategies/classifierStrategy.js.map +1 -0
  1020. package/dist/src/routing/strategies/classifierStrategy.test.d.ts +7 -0
  1021. package/dist/src/routing/strategies/classifierStrategy.test.js +198 -0
  1022. package/dist/src/routing/strategies/classifierStrategy.test.js.map +1 -0
  1023. package/dist/src/routing/strategies/compositeStrategy.d.ts +27 -0
  1024. package/dist/src/routing/strategies/compositeStrategy.js +69 -0
  1025. package/dist/src/routing/strategies/compositeStrategy.js.map +1 -0
  1026. package/dist/src/routing/strategies/compositeStrategy.test.d.ts +7 -0
  1027. package/dist/src/routing/strategies/compositeStrategy.test.js +124 -0
  1028. package/dist/src/routing/strategies/compositeStrategy.test.js.map +1 -0
  1029. package/dist/src/routing/strategies/defaultStrategy.d.ts +13 -0
  1030. package/dist/src/routing/strategies/defaultStrategy.js +21 -0
  1031. package/dist/src/routing/strategies/defaultStrategy.js.map +1 -0
  1032. package/dist/src/routing/strategies/defaultStrategy.test.d.ts +7 -0
  1033. package/dist/src/routing/strategies/defaultStrategy.test.js +27 -0
  1034. package/dist/src/routing/strategies/defaultStrategy.test.js.map +1 -0
  1035. package/dist/src/routing/strategies/fallbackStrategy.d.ts +13 -0
  1036. package/dist/src/routing/strategies/fallbackStrategy.js +34 -0
  1037. package/dist/src/routing/strategies/fallbackStrategy.js.map +1 -0
  1038. package/dist/src/routing/strategies/fallbackStrategy.test.d.ts +7 -0
  1039. package/dist/src/routing/strategies/fallbackStrategy.test.js +84 -0
  1040. package/dist/src/routing/strategies/fallbackStrategy.test.js.map +1 -0
  1041. package/dist/src/routing/strategies/overrideStrategy.d.ts +16 -0
  1042. package/dist/src/routing/strategies/overrideStrategy.js +30 -0
  1043. package/dist/src/routing/strategies/overrideStrategy.js.map +1 -0
  1044. package/dist/src/routing/strategies/overrideStrategy.test.d.ts +7 -0
  1045. package/dist/src/routing/strategies/overrideStrategy.test.js +46 -0
  1046. package/dist/src/routing/strategies/overrideStrategy.test.js.map +1 -0
  1047. package/dist/src/safety/approval-ladder/__tests__/buildShellActionProfile.test.d.ts +7 -0
  1048. package/dist/src/safety/approval-ladder/__tests__/buildShellActionProfile.test.js +203 -0
  1049. package/dist/src/safety/approval-ladder/__tests__/buildShellActionProfile.test.js.map +1 -0
  1050. package/dist/src/safety/approval-ladder/__tests__/buildToolActionProfile.test.d.ts +7 -0
  1051. package/dist/src/safety/approval-ladder/__tests__/buildToolActionProfile.test.js +81 -0
  1052. package/dist/src/safety/approval-ladder/__tests__/buildToolActionProfile.test.js.map +1 -0
  1053. package/dist/src/safety/approval-ladder/__tests__/computeMinimumReviewLevel.test.d.ts +7 -0
  1054. package/dist/src/safety/approval-ladder/__tests__/computeMinimumReviewLevel.test.js +252 -0
  1055. package/dist/src/safety/approval-ladder/__tests__/computeMinimumReviewLevel.test.js.map +1 -0
  1056. package/dist/src/safety/approval-ladder/buildShellActionProfile.d.ts +19 -0
  1057. package/dist/src/safety/approval-ladder/buildShellActionProfile.js +285 -0
  1058. package/dist/src/safety/approval-ladder/buildShellActionProfile.js.map +1 -0
  1059. package/dist/src/safety/approval-ladder/buildToolActionProfile.d.ts +16 -0
  1060. package/dist/src/safety/approval-ladder/buildToolActionProfile.js +255 -0
  1061. package/dist/src/safety/approval-ladder/buildToolActionProfile.js.map +1 -0
  1062. package/dist/src/safety/approval-ladder/classifyDomain.d.ts +9 -0
  1063. package/dist/src/safety/approval-ladder/classifyDomain.js +81 -0
  1064. package/dist/src/safety/approval-ladder/classifyDomain.js.map +1 -0
  1065. package/dist/src/safety/approval-ladder/classifyIntention.d.ts +16 -0
  1066. package/dist/src/safety/approval-ladder/classifyIntention.js +64 -0
  1067. package/dist/src/safety/approval-ladder/classifyIntention.js.map +1 -0
  1068. package/dist/src/safety/approval-ladder/classifyOutcome.d.ts +9 -0
  1069. package/dist/src/safety/approval-ladder/classifyOutcome.js +62 -0
  1070. package/dist/src/safety/approval-ladder/classifyOutcome.js.map +1 -0
  1071. package/dist/src/safety/approval-ladder/computeBalancedRisk.d.ts +8 -0
  1072. package/dist/src/safety/approval-ladder/computeBalancedRisk.js +49 -0
  1073. package/dist/src/safety/approval-ladder/computeBalancedRisk.js.map +1 -0
  1074. package/dist/src/safety/approval-ladder/computeMinimalRisk.d.ts +8 -0
  1075. package/dist/src/safety/approval-ladder/computeMinimalRisk.js +23 -0
  1076. package/dist/src/safety/approval-ladder/computeMinimalRisk.js.map +1 -0
  1077. package/dist/src/safety/approval-ladder/computeMinimumReviewLevel.d.ts +17 -0
  1078. package/dist/src/safety/approval-ladder/computeMinimumReviewLevel.js +124 -0
  1079. package/dist/src/safety/approval-ladder/computeMinimumReviewLevel.js.map +1 -0
  1080. package/dist/src/safety/approval-ladder/computeRisk.d.ts +8 -0
  1081. package/dist/src/safety/approval-ladder/computeRisk.js +29 -0
  1082. package/dist/src/safety/approval-ladder/computeRisk.js.map +1 -0
  1083. package/dist/src/safety/approval-ladder/computeStrictRisk.d.ts +8 -0
  1084. package/dist/src/safety/approval-ladder/computeStrictRisk.js +32 -0
  1085. package/dist/src/safety/approval-ladder/computeStrictRisk.js.map +1 -0
  1086. package/dist/src/safety/approval-ladder/safetyInvariants.d.ts +29 -0
  1087. package/dist/src/safety/approval-ladder/safetyInvariants.js +77 -0
  1088. package/dist/src/safety/approval-ladder/safetyInvariants.js.map +1 -0
  1089. package/dist/src/safety/approval-ladder/types.d.ts +81 -0
  1090. package/dist/src/safety/approval-ladder/types.js +8 -0
  1091. package/dist/src/safety/approval-ladder/types.js.map +1 -0
  1092. package/dist/src/safety/built-in.d.ts +30 -0
  1093. package/dist/src/safety/built-in.js +124 -0
  1094. package/dist/src/safety/built-in.js.map +1 -0
  1095. package/dist/src/safety/built-in.test.d.ts +7 -0
  1096. package/dist/src/safety/built-in.test.js +200 -0
  1097. package/dist/src/safety/built-in.test.js.map +1 -0
  1098. package/dist/src/safety/checker-runner.d.ts +49 -0
  1099. package/dist/src/safety/checker-runner.js +220 -0
  1100. package/dist/src/safety/checker-runner.js.map +1 -0
  1101. package/dist/src/safety/checker-runner.test.d.ts +7 -0
  1102. package/dist/src/safety/checker-runner.test.js +239 -0
  1103. package/dist/src/safety/checker-runner.test.js.map +1 -0
  1104. package/dist/src/safety/context-builder.d.ts +24 -0
  1105. package/dist/src/safety/context-builder.js +48 -0
  1106. package/dist/src/safety/context-builder.js.map +1 -0
  1107. package/dist/src/safety/context-builder.test.d.ts +7 -0
  1108. package/dist/src/safety/context-builder.test.js +50 -0
  1109. package/dist/src/safety/context-builder.test.js.map +1 -0
  1110. package/dist/src/safety/protocol.d.ts +89 -0
  1111. package/dist/src/safety/protocol.js +16 -0
  1112. package/dist/src/safety/protocol.js.map +1 -0
  1113. package/dist/src/safety/registry.d.ts +27 -0
  1114. package/dist/src/safety/registry.js +66 -0
  1115. package/dist/src/safety/registry.js.map +1 -0
  1116. package/dist/src/safety/registry.test.d.ts +7 -0
  1117. package/dist/src/safety/registry.test.js +32 -0
  1118. package/dist/src/safety/registry.test.js.map +1 -0
  1119. package/dist/src/safety/risk-classifier.d.ts +8 -0
  1120. package/dist/src/safety/risk-classifier.js +36 -0
  1121. package/dist/src/safety/risk-classifier.js.map +1 -0
  1122. package/dist/src/safety/risk-classifier.test.d.ts +7 -0
  1123. package/dist/src/safety/risk-classifier.test.js +28 -0
  1124. package/dist/src/safety/risk-classifier.test.js.map +1 -0
  1125. package/dist/src/services/chatCompressionService.d.ts +34 -0
  1126. package/dist/src/services/chatCompressionService.js +195 -0
  1127. package/dist/src/services/chatCompressionService.js.map +1 -0
  1128. package/dist/src/services/chatCompressionService.test.d.ts +7 -0
  1129. package/dist/src/services/chatCompressionService.test.js +215 -0
  1130. package/dist/src/services/chatCompressionService.test.js.map +1 -0
  1131. package/dist/src/services/chatRecordingService.d.ts +160 -0
  1132. package/dist/src/services/chatRecordingService.js +370 -0
  1133. package/dist/src/services/chatRecordingService.js.map +1 -0
  1134. package/dist/src/services/chatRecordingService.test.d.ts +7 -0
  1135. package/dist/src/services/chatRecordingService.test.js +333 -0
  1136. package/dist/src/services/chatRecordingService.test.js.map +1 -0
  1137. package/dist/src/services/contextManager.d.ts +30 -0
  1138. package/dist/src/services/contextManager.js +72 -0
  1139. package/dist/src/services/contextManager.js.map +1 -0
  1140. package/dist/src/services/contextManager.test.d.ts +7 -0
  1141. package/dist/src/services/contextManager.test.js +105 -0
  1142. package/dist/src/services/contextManager.test.js.map +1 -0
  1143. package/dist/src/services/fileDiscoveryService.d.ts +34 -0
  1144. package/dist/src/services/fileDiscoveryService.js +70 -0
  1145. package/dist/src/services/fileDiscoveryService.js.map +1 -0
  1146. package/dist/src/services/fileDiscoveryService.test.d.ts +7 -0
  1147. package/dist/src/services/fileDiscoveryService.test.js +224 -0
  1148. package/dist/src/services/fileDiscoveryService.test.js.map +1 -0
  1149. package/dist/src/services/fileSystemService.d.ts +32 -0
  1150. package/dist/src/services/fileSystemService.js +19 -0
  1151. package/dist/src/services/fileSystemService.js.map +1 -0
  1152. package/dist/src/services/fileSystemService.test.d.ts +7 -0
  1153. package/dist/src/services/fileSystemService.test.js +42 -0
  1154. package/dist/src/services/fileSystemService.test.js.map +1 -0
  1155. package/dist/src/services/gitService.d.ts +24 -0
  1156. package/dist/src/services/gitService.js +115 -0
  1157. package/dist/src/services/gitService.js.map +1 -0
  1158. package/dist/src/services/gitService.test.d.ts +7 -0
  1159. package/dist/src/services/gitService.test.js +241 -0
  1160. package/dist/src/services/gitService.test.js.map +1 -0
  1161. package/dist/src/services/loopDetectionService.d.ts +107 -0
  1162. package/dist/src/services/loopDetectionService.js +434 -0
  1163. package/dist/src/services/loopDetectionService.js.map +1 -0
  1164. package/dist/src/services/loopDetectionService.test.d.ts +7 -0
  1165. package/dist/src/services/loopDetectionService.test.js +802 -0
  1166. package/dist/src/services/loopDetectionService.test.js.map +1 -0
  1167. package/dist/src/services/modelConfig.golden.test.d.ts +7 -0
  1168. package/dist/src/services/modelConfig.golden.test.js +75 -0
  1169. package/dist/src/services/modelConfig.golden.test.js.map +1 -0
  1170. package/dist/src/services/modelConfig.integration.test.d.ts +7 -0
  1171. package/dist/src/services/modelConfig.integration.test.js +248 -0
  1172. package/dist/src/services/modelConfig.integration.test.js.map +1 -0
  1173. package/dist/src/services/modelConfigService.d.ts +53 -0
  1174. package/dist/src/services/modelConfigService.js +157 -0
  1175. package/dist/src/services/modelConfigService.js.map +1 -0
  1176. package/dist/src/services/modelConfigService.test.d.ts +7 -0
  1177. package/dist/src/services/modelConfigService.test.js +753 -0
  1178. package/dist/src/services/modelConfigService.test.js.map +1 -0
  1179. package/dist/src/services/modelConfigServiceTestUtils.d.ts +11 -0
  1180. package/dist/src/services/modelConfigServiceTestUtils.js +18 -0
  1181. package/dist/src/services/modelConfigServiceTestUtils.js.map +1 -0
  1182. package/dist/src/services/sessionSummaryService.d.ts +29 -0
  1183. package/dist/src/services/sessionSummaryService.js +132 -0
  1184. package/dist/src/services/sessionSummaryService.js.map +1 -0
  1185. package/dist/src/services/sessionSummaryService.test.d.ts +7 -0
  1186. package/dist/src/services/sessionSummaryService.test.js +786 -0
  1187. package/dist/src/services/sessionSummaryService.test.js.map +1 -0
  1188. package/dist/src/services/sessionSummaryUtils.d.ts +17 -0
  1189. package/dist/src/services/sessionSummaryUtils.js +130 -0
  1190. package/dist/src/services/sessionSummaryUtils.js.map +1 -0
  1191. package/dist/src/services/sessionSummaryUtils.test.d.ts +7 -0
  1192. package/dist/src/services/sessionSummaryUtils.test.js +138 -0
  1193. package/dist/src/services/sessionSummaryUtils.test.js.map +1 -0
  1194. package/dist/src/services/shellExecutionService.d.ts +122 -0
  1195. package/dist/src/services/shellExecutionService.js +759 -0
  1196. package/dist/src/services/shellExecutionService.js.map +1 -0
  1197. package/dist/src/services/shellExecutionService.test.d.ts +7 -0
  1198. package/dist/src/services/shellExecutionService.test.js +1040 -0
  1199. package/dist/src/services/shellExecutionService.test.js.map +1 -0
  1200. package/dist/src/services/test-data/resolved-aliases-retry.golden.json +238 -0
  1201. package/dist/src/services/test-data/resolved-aliases.golden.json +238 -0
  1202. package/dist/src/telemetry/activity-detector.d.ts +42 -0
  1203. package/dist/src/telemetry/activity-detector.js +62 -0
  1204. package/dist/src/telemetry/activity-detector.js.map +1 -0
  1205. package/dist/src/telemetry/activity-detector.test.d.ts +7 -0
  1206. package/dist/src/telemetry/activity-detector.test.js +137 -0
  1207. package/dist/src/telemetry/activity-detector.test.js.map +1 -0
  1208. package/dist/src/telemetry/activity-monitor.d.ts +117 -0
  1209. package/dist/src/telemetry/activity-monitor.js +210 -0
  1210. package/dist/src/telemetry/activity-monitor.js.map +1 -0
  1211. package/dist/src/telemetry/activity-monitor.test.d.ts +7 -0
  1212. package/dist/src/telemetry/activity-monitor.test.js +252 -0
  1213. package/dist/src/telemetry/activity-monitor.test.js.map +1 -0
  1214. package/dist/src/telemetry/activity-types.d.ts +20 -0
  1215. package/dist/src/telemetry/activity-types.js +22 -0
  1216. package/dist/src/telemetry/activity-types.js.map +1 -0
  1217. package/dist/src/telemetry/clearcut-logger/clearcut-logger.d.ts +159 -0
  1218. package/dist/src/telemetry/clearcut-logger/clearcut-logger.js +1210 -0
  1219. package/dist/src/telemetry/clearcut-logger/clearcut-logger.js.map +1 -0
  1220. package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.d.ts +20 -0
  1221. package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.js +835 -0
  1222. package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.js.map +1 -0
  1223. package/dist/src/telemetry/clearcut-logger/event-metadata-key.d.ts +140 -0
  1224. package/dist/src/telemetry/clearcut-logger/event-metadata-key.js +350 -0
  1225. package/dist/src/telemetry/clearcut-logger/event-metadata-key.js.map +1 -0
  1226. package/dist/src/telemetry/config.d.ts +32 -0
  1227. package/dist/src/telemetry/config.js +79 -0
  1228. package/dist/src/telemetry/config.js.map +1 -0
  1229. package/dist/src/telemetry/config.test.d.ts +7 -0
  1230. package/dist/src/telemetry/config.test.js +150 -0
  1231. package/dist/src/telemetry/config.test.js.map +1 -0
  1232. package/dist/src/telemetry/constants.d.ts +7 -0
  1233. package/dist/src/telemetry/constants.js +8 -0
  1234. package/dist/src/telemetry/constants.js.map +1 -0
  1235. package/dist/src/telemetry/file-exporters.d.ts +30 -0
  1236. package/dist/src/telemetry/file-exporters.js +63 -0
  1237. package/dist/src/telemetry/file-exporters.js.map +1 -0
  1238. package/dist/src/telemetry/gcp-exporters.d.ts +36 -0
  1239. package/dist/src/telemetry/gcp-exporters.js +121 -0
  1240. package/dist/src/telemetry/gcp-exporters.js.map +1 -0
  1241. package/dist/src/telemetry/gcp-exporters.test.d.ts +7 -0
  1242. package/dist/src/telemetry/gcp-exporters.test.js +319 -0
  1243. package/dist/src/telemetry/gcp-exporters.test.js.map +1 -0
  1244. package/dist/src/telemetry/high-water-mark-tracker.d.ts +44 -0
  1245. package/dist/src/telemetry/high-water-mark-tracker.js +89 -0
  1246. package/dist/src/telemetry/high-water-mark-tracker.js.map +1 -0
  1247. package/dist/src/telemetry/high-water-mark-tracker.test.d.ts +7 -0
  1248. package/dist/src/telemetry/high-water-mark-tracker.test.js +153 -0
  1249. package/dist/src/telemetry/high-water-mark-tracker.test.js.map +1 -0
  1250. package/dist/src/telemetry/index.d.ts +34 -0
  1251. package/dist/src/telemetry/index.js +45 -0
  1252. package/dist/src/telemetry/index.js.map +1 -0
  1253. package/dist/src/telemetry/integration.test.circular.d.ts +7 -0
  1254. package/dist/src/telemetry/integration.test.circular.js +55 -0
  1255. package/dist/src/telemetry/integration.test.circular.js.map +1 -0
  1256. package/dist/src/telemetry/loggers.d.ts +45 -0
  1257. package/dist/src/telemetry/loggers.js +499 -0
  1258. package/dist/src/telemetry/loggers.js.map +1 -0
  1259. package/dist/src/telemetry/loggers.test.circular.d.ts +7 -0
  1260. package/dist/src/telemetry/loggers.test.circular.js +107 -0
  1261. package/dist/src/telemetry/loggers.test.circular.js.map +1 -0
  1262. package/dist/src/telemetry/loggers.test.d.ts +7 -0
  1263. package/dist/src/telemetry/loggers.test.js +1578 -0
  1264. package/dist/src/telemetry/loggers.test.js.map +1 -0
  1265. package/dist/src/telemetry/memory-monitor.d.ts +150 -0
  1266. package/dist/src/telemetry/memory-monitor.js +336 -0
  1267. package/dist/src/telemetry/memory-monitor.js.map +1 -0
  1268. package/dist/src/telemetry/memory-monitor.test.d.ts +7 -0
  1269. package/dist/src/telemetry/memory-monitor.test.js +473 -0
  1270. package/dist/src/telemetry/memory-monitor.test.js.map +1 -0
  1271. package/dist/src/telemetry/metrics.d.ts +534 -0
  1272. package/dist/src/telemetry/metrics.js +842 -0
  1273. package/dist/src/telemetry/metrics.js.map +1 -0
  1274. package/dist/src/telemetry/metrics.test.d.ts +7 -0
  1275. package/dist/src/telemetry/metrics.test.js +1170 -0
  1276. package/dist/src/telemetry/metrics.test.js.map +1 -0
  1277. package/dist/src/telemetry/rate-limiter.d.ts +49 -0
  1278. package/dist/src/telemetry/rate-limiter.js +101 -0
  1279. package/dist/src/telemetry/rate-limiter.js.map +1 -0
  1280. package/dist/src/telemetry/rate-limiter.test.d.ts +7 -0
  1281. package/dist/src/telemetry/rate-limiter.test.js +208 -0
  1282. package/dist/src/telemetry/rate-limiter.test.js.map +1 -0
  1283. package/dist/src/telemetry/sanitize.d.ts +26 -0
  1284. package/dist/src/telemetry/sanitize.js +49 -0
  1285. package/dist/src/telemetry/sanitize.js.map +1 -0
  1286. package/dist/src/telemetry/sanitize.test.d.ts +7 -0
  1287. package/dist/src/telemetry/sanitize.test.js +280 -0
  1288. package/dist/src/telemetry/sanitize.test.js.map +1 -0
  1289. package/dist/src/telemetry/sdk.d.ts +17 -0
  1290. package/dist/src/telemetry/sdk.js +309 -0
  1291. package/dist/src/telemetry/sdk.js.map +1 -0
  1292. package/dist/src/telemetry/sdk.test.d.ts +7 -0
  1293. package/dist/src/telemetry/sdk.test.js +293 -0
  1294. package/dist/src/telemetry/sdk.test.js.map +1 -0
  1295. package/dist/src/telemetry/semantic.d.ts +83 -0
  1296. package/dist/src/telemetry/semantic.js +270 -0
  1297. package/dist/src/telemetry/semantic.js.map +1 -0
  1298. package/dist/src/telemetry/semantic.test.d.ts +7 -0
  1299. package/dist/src/telemetry/semantic.test.js +388 -0
  1300. package/dist/src/telemetry/semantic.test.js.map +1 -0
  1301. package/dist/src/telemetry/startupProfiler.d.ts +52 -0
  1302. package/dist/src/telemetry/startupProfiler.js +171 -0
  1303. package/dist/src/telemetry/startupProfiler.js.map +1 -0
  1304. package/dist/src/telemetry/startupProfiler.test.d.ts +7 -0
  1305. package/dist/src/telemetry/startupProfiler.test.js +276 -0
  1306. package/dist/src/telemetry/startupProfiler.test.js.map +1 -0
  1307. package/dist/src/telemetry/telemetry-utils.d.ts +7 -0
  1308. package/dist/src/telemetry/telemetry-utils.js +15 -0
  1309. package/dist/src/telemetry/telemetry-utils.js.map +1 -0
  1310. package/dist/src/telemetry/telemetry-utils.test.d.ts +7 -0
  1311. package/dist/src/telemetry/telemetry-utils.test.js +42 -0
  1312. package/dist/src/telemetry/telemetry-utils.test.js.map +1 -0
  1313. package/dist/src/telemetry/telemetry.test.d.ts +7 -0
  1314. package/dist/src/telemetry/telemetry.test.js +58 -0
  1315. package/dist/src/telemetry/telemetry.test.js.map +1 -0
  1316. package/dist/src/telemetry/telemetryAttributes.d.ts +9 -0
  1317. package/dist/src/telemetry/telemetryAttributes.js +20 -0
  1318. package/dist/src/telemetry/telemetryAttributes.js.map +1 -0
  1319. package/dist/src/telemetry/tool-call-decision.d.ts +14 -0
  1320. package/dist/src/telemetry/tool-call-decision.js +30 -0
  1321. package/dist/src/telemetry/tool-call-decision.js.map +1 -0
  1322. package/dist/src/telemetry/trace.d.ts +47 -0
  1323. package/dist/src/telemetry/trace.js +122 -0
  1324. package/dist/src/telemetry/trace.js.map +1 -0
  1325. package/dist/src/telemetry/types.d.ts +545 -0
  1326. package/dist/src/telemetry/types.js +1435 -0
  1327. package/dist/src/telemetry/types.js.map +1 -0
  1328. package/dist/src/telemetry/uiTelemetry.d.ts +77 -0
  1329. package/dist/src/telemetry/uiTelemetry.js +155 -0
  1330. package/dist/src/telemetry/uiTelemetry.js.map +1 -0
  1331. package/dist/src/telemetry/uiTelemetry.test.d.ts +7 -0
  1332. package/dist/src/telemetry/uiTelemetry.test.js +585 -0
  1333. package/dist/src/telemetry/uiTelemetry.test.js.map +1 -0
  1334. package/dist/src/test-utils/config.d.ts +18 -0
  1335. package/dist/src/test-utils/config.js +33 -0
  1336. package/dist/src/test-utils/config.js.map +1 -0
  1337. package/dist/src/test-utils/index.d.ts +7 -0
  1338. package/dist/src/test-utils/index.js +8 -0
  1339. package/dist/src/test-utils/index.js.map +1 -0
  1340. package/dist/src/test-utils/mock-message-bus.d.ts +61 -0
  1341. package/dist/src/test-utils/mock-message-bus.js +132 -0
  1342. package/dist/src/test-utils/mock-message-bus.js.map +1 -0
  1343. package/dist/src/test-utils/mock-tool.d.ts +67 -0
  1344. package/dist/src/test-utils/mock-tool.js +122 -0
  1345. package/dist/src/test-utils/mock-tool.js.map +1 -0
  1346. package/dist/src/test-utils/mockWorkspaceContext.d.ts +14 -0
  1347. package/dist/src/test-utils/mockWorkspaceContext.js +25 -0
  1348. package/dist/src/test-utils/mockWorkspaceContext.js.map +1 -0
  1349. package/dist/src/tools/__tests__/shell.pin.test.d.ts +7 -0
  1350. package/dist/src/tools/__tests__/shell.pin.test.js +177 -0
  1351. package/dist/src/tools/__tests__/shell.pin.test.js.map +1 -0
  1352. package/dist/src/tools/__tests__/shell.provenance.test.d.ts +7 -0
  1353. package/dist/src/tools/__tests__/shell.provenance.test.js +36 -0
  1354. package/dist/src/tools/__tests__/shell.provenance.test.js.map +1 -0
  1355. package/dist/src/tools/__tests__/ui-diagnose.test.d.ts +1 -0
  1356. package/dist/src/tools/__tests__/ui-diagnose.test.js +68 -0
  1357. package/dist/src/tools/__tests__/ui-diagnose.test.js.map +1 -0
  1358. package/dist/src/tools/__tests__/ui-health.test.d.ts +1 -0
  1359. package/dist/src/tools/__tests__/ui-health.test.js +108 -0
  1360. package/dist/src/tools/__tests__/ui-health.test.js.map +1 -0
  1361. package/dist/src/tools/__tests__/ui-tool-utils.test.d.ts +7 -0
  1362. package/dist/src/tools/__tests__/ui-tool-utils.test.js +45 -0
  1363. package/dist/src/tools/__tests__/ui-tool-utils.test.js.map +1 -0
  1364. package/dist/src/tools/agent-control.d.ts +33 -0
  1365. package/dist/src/tools/agent-control.js +238 -0
  1366. package/dist/src/tools/agent-control.js.map +1 -0
  1367. package/dist/src/tools/agent-control.test.d.ts +7 -0
  1368. package/dist/src/tools/agent-control.test.js +126 -0
  1369. package/dist/src/tools/agent-control.test.js.map +1 -0
  1370. package/dist/src/tools/base-tool-invocation.test.d.ts +7 -0
  1371. package/dist/src/tools/base-tool-invocation.test.js +86 -0
  1372. package/dist/src/tools/base-tool-invocation.test.js.map +1 -0
  1373. package/dist/src/tools/confirmation-policy.test.d.ts +7 -0
  1374. package/dist/src/tools/confirmation-policy.test.js +160 -0
  1375. package/dist/src/tools/confirmation-policy.test.js.map +1 -0
  1376. package/dist/src/tools/diffOptions.d.ts +10 -0
  1377. package/dist/src/tools/diffOptions.js +47 -0
  1378. package/dist/src/tools/diffOptions.js.map +1 -0
  1379. package/dist/src/tools/diffOptions.test.d.ts +7 -0
  1380. package/dist/src/tools/diffOptions.test.js +156 -0
  1381. package/dist/src/tools/diffOptions.test.js.map +1 -0
  1382. package/dist/src/tools/edit.d.ts +58 -0
  1383. package/dist/src/tools/edit.js +445 -0
  1384. package/dist/src/tools/edit.js.map +1 -0
  1385. package/dist/src/tools/edit.test.d.ts +7 -0
  1386. package/dist/src/tools/edit.test.js +960 -0
  1387. package/dist/src/tools/edit.test.js.map +1 -0
  1388. package/dist/src/tools/file-ops.d.ts +29 -0
  1389. package/dist/src/tools/file-ops.js +440 -0
  1390. package/dist/src/tools/file-ops.js.map +1 -0
  1391. package/dist/src/tools/file-ops.test.d.ts +7 -0
  1392. package/dist/src/tools/file-ops.test.js +150 -0
  1393. package/dist/src/tools/file-ops.test.js.map +1 -0
  1394. package/dist/src/tools/get-internal-docs.d.ts +28 -0
  1395. package/dist/src/tools/get-internal-docs.js +130 -0
  1396. package/dist/src/tools/get-internal-docs.js.map +1 -0
  1397. package/dist/src/tools/get-internal-docs.test.d.ts +7 -0
  1398. package/dist/src/tools/get-internal-docs.test.js +57 -0
  1399. package/dist/src/tools/get-internal-docs.test.js.map +1 -0
  1400. package/dist/src/tools/glob.d.ts +58 -0
  1401. package/dist/src/tools/glob.js +242 -0
  1402. package/dist/src/tools/glob.js.map +1 -0
  1403. package/dist/src/tools/glob.test.d.ts +7 -0
  1404. package/dist/src/tools/glob.test.js +434 -0
  1405. package/dist/src/tools/glob.test.js.map +1 -0
  1406. package/dist/src/tools/grep.d.ts +49 -0
  1407. package/dist/src/tools/grep.js +524 -0
  1408. package/dist/src/tools/grep.js.map +1 -0
  1409. package/dist/src/tools/grep.test.d.ts +7 -0
  1410. package/dist/src/tools/grep.test.js +299 -0
  1411. package/dist/src/tools/grep.test.js.map +1 -0
  1412. package/dist/src/tools/ls.d.ts +70 -0
  1413. package/dist/src/tools/ls.js +209 -0
  1414. package/dist/src/tools/ls.js.map +1 -0
  1415. package/dist/src/tools/ls.test.d.ts +7 -0
  1416. package/dist/src/tools/ls.test.js +242 -0
  1417. package/dist/src/tools/ls.test.js.map +1 -0
  1418. package/dist/src/tools/mcp-client-manager.d.ts +81 -0
  1419. package/dist/src/tools/mcp-client-manager.js +270 -0
  1420. package/dist/src/tools/mcp-client-manager.js.map +1 -0
  1421. package/dist/src/tools/mcp-client-manager.test.d.ts +7 -0
  1422. package/dist/src/tools/mcp-client-manager.test.js +194 -0
  1423. package/dist/src/tools/mcp-client-manager.test.js.map +1 -0
  1424. package/dist/src/tools/mcp-client.d.ts +234 -0
  1425. package/dist/src/tools/mcp-client.js +1276 -0
  1426. package/dist/src/tools/mcp-client.js.map +1 -0
  1427. package/dist/src/tools/mcp-client.test.d.ts +7 -0
  1428. package/dist/src/tools/mcp-client.test.js +1285 -0
  1429. package/dist/src/tools/mcp-client.test.js.map +1 -0
  1430. package/dist/src/tools/mcp-tool.d.ts +29 -0
  1431. package/dist/src/tools/mcp-tool.js +293 -0
  1432. package/dist/src/tools/mcp-tool.js.map +1 -0
  1433. package/dist/src/tools/mcp-tool.test.d.ts +7 -0
  1434. package/dist/src/tools/mcp-tool.test.js +653 -0
  1435. package/dist/src/tools/mcp-tool.test.js.map +1 -0
  1436. package/dist/src/tools/memoryTool.d.ts +43 -0
  1437. package/dist/src/tools/memoryTool.js +272 -0
  1438. package/dist/src/tools/memoryTool.js.map +1 -0
  1439. package/dist/src/tools/memoryTool.test.d.ts +7 -0
  1440. package/dist/src/tools/memoryTool.test.js +300 -0
  1441. package/dist/src/tools/memoryTool.test.js.map +1 -0
  1442. package/dist/src/tools/message-bus-integration.test.d.ts +7 -0
  1443. package/dist/src/tools/message-bus-integration.test.js +197 -0
  1444. package/dist/src/tools/message-bus-integration.test.js.map +1 -0
  1445. package/dist/src/tools/modifiable-tool.d.ts +37 -0
  1446. package/dist/src/tools/modifiable-tool.js +111 -0
  1447. package/dist/src/tools/modifiable-tool.js.map +1 -0
  1448. package/dist/src/tools/modifiable-tool.test.d.ts +7 -0
  1449. package/dist/src/tools/modifiable-tool.test.js +238 -0
  1450. package/dist/src/tools/modifiable-tool.test.js.map +1 -0
  1451. package/dist/src/tools/process-manager.d.ts +117 -0
  1452. package/dist/src/tools/process-manager.js +659 -0
  1453. package/dist/src/tools/process-manager.js.map +1 -0
  1454. package/dist/src/tools/process-manager.test.d.ts +7 -0
  1455. package/dist/src/tools/process-manager.test.js +161 -0
  1456. package/dist/src/tools/process-manager.test.js.map +1 -0
  1457. package/dist/src/tools/process-notifications.d.ts +19 -0
  1458. package/dist/src/tools/process-notifications.js +14 -0
  1459. package/dist/src/tools/process-notifications.js.map +1 -0
  1460. package/dist/src/tools/read-file.d.ts +37 -0
  1461. package/dist/src/tools/read-file.js +134 -0
  1462. package/dist/src/tools/read-file.js.map +1 -0
  1463. package/dist/src/tools/read-file.test.d.ts +7 -0
  1464. package/dist/src/tools/read-file.test.js +376 -0
  1465. package/dist/src/tools/read-file.test.js.map +1 -0
  1466. package/dist/src/tools/read-many-files.d.ts +55 -0
  1467. package/dist/src/tools/read-many-files.js +356 -0
  1468. package/dist/src/tools/read-many-files.js.map +1 -0
  1469. package/dist/src/tools/read-many-files.test.d.ts +7 -0
  1470. package/dist/src/tools/read-many-files.test.js +567 -0
  1471. package/dist/src/tools/read-many-files.test.js.map +1 -0
  1472. package/dist/src/tools/repl.d.ts +21 -0
  1473. package/dist/src/tools/repl.js +386 -0
  1474. package/dist/src/tools/repl.js.map +1 -0
  1475. package/dist/src/tools/repl.test.d.ts +7 -0
  1476. package/dist/src/tools/repl.test.js +287 -0
  1477. package/dist/src/tools/repl.test.js.map +1 -0
  1478. package/dist/src/tools/ripGrep.d.ts +74 -0
  1479. package/dist/src/tools/ripGrep.js +396 -0
  1480. package/dist/src/tools/ripGrep.js.map +1 -0
  1481. package/dist/src/tools/ripGrep.test.d.ts +7 -0
  1482. package/dist/src/tools/ripGrep.test.js +1306 -0
  1483. package/dist/src/tools/ripGrep.test.js.map +1 -0
  1484. package/dist/src/tools/shell.d.ts +44 -0
  1485. package/dist/src/tools/shell.js +649 -0
  1486. package/dist/src/tools/shell.js.map +1 -0
  1487. package/dist/src/tools/shell.test.d.ts +7 -0
  1488. package/dist/src/tools/shell.test.js +431 -0
  1489. package/dist/src/tools/shell.test.js.map +1 -0
  1490. package/dist/src/tools/smart-edit.d.ts +79 -0
  1491. package/dist/src/tools/smart-edit.js +739 -0
  1492. package/dist/src/tools/smart-edit.js.map +1 -0
  1493. package/dist/src/tools/smart-edit.test.d.ts +7 -0
  1494. package/dist/src/tools/smart-edit.test.js +597 -0
  1495. package/dist/src/tools/smart-edit.test.js.map +1 -0
  1496. package/dist/src/tools/tool-error.d.ts +66 -0
  1497. package/dist/src/tools/tool-error.js +87 -0
  1498. package/dist/src/tools/tool-error.js.map +1 -0
  1499. package/dist/src/tools/tool-names.d.ts +48 -0
  1500. package/dist/src/tools/tool-names.js +108 -0
  1501. package/dist/src/tools/tool-names.js.map +1 -0
  1502. package/dist/src/tools/tool-names.test.d.ts +7 -0
  1503. package/dist/src/tools/tool-names.test.js +44 -0
  1504. package/dist/src/tools/tool-names.test.js.map +1 -0
  1505. package/dist/src/tools/tool-registry.d.ts +99 -0
  1506. package/dist/src/tools/tool-registry.js +415 -0
  1507. package/dist/src/tools/tool-registry.js.map +1 -0
  1508. package/dist/src/tools/tool-registry.test.d.ts +7 -0
  1509. package/dist/src/tools/tool-registry.test.js +411 -0
  1510. package/dist/src/tools/tool-registry.test.js.map +1 -0
  1511. package/dist/src/tools/tools.d.ts +361 -0
  1512. package/dist/src/tools/tools.js +409 -0
  1513. package/dist/src/tools/tools.js.map +1 -0
  1514. package/dist/src/tools/tools.test.d.ts +7 -0
  1515. package/dist/src/tools/tools.test.js +206 -0
  1516. package/dist/src/tools/tools.test.js.map +1 -0
  1517. package/dist/src/tools/ui-assert.d.ts +16 -0
  1518. package/dist/src/tools/ui-assert.js +51 -0
  1519. package/dist/src/tools/ui-assert.js.map +1 -0
  1520. package/dist/src/tools/ui-capabilities.d.ts +17 -0
  1521. package/dist/src/tools/ui-capabilities.js +43 -0
  1522. package/dist/src/tools/ui-capabilities.js.map +1 -0
  1523. package/dist/src/tools/ui-click-xy.d.ts +16 -0
  1524. package/dist/src/tools/ui-click-xy.js +65 -0
  1525. package/dist/src/tools/ui-click-xy.js.map +1 -0
  1526. package/dist/src/tools/ui-click.d.ts +16 -0
  1527. package/dist/src/tools/ui-click.js +67 -0
  1528. package/dist/src/tools/ui-click.js.map +1 -0
  1529. package/dist/src/tools/ui-describe.d.ts +16 -0
  1530. package/dist/src/tools/ui-describe.js +129 -0
  1531. package/dist/src/tools/ui-describe.js.map +1 -0
  1532. package/dist/src/tools/ui-diagnose.d.ts +16 -0
  1533. package/dist/src/tools/ui-diagnose.js +87 -0
  1534. package/dist/src/tools/ui-diagnose.js.map +1 -0
  1535. package/dist/src/tools/ui-focus.d.ts +16 -0
  1536. package/dist/src/tools/ui-focus.js +61 -0
  1537. package/dist/src/tools/ui-focus.js.map +1 -0
  1538. package/dist/src/tools/ui-health.d.ts +17 -0
  1539. package/dist/src/tools/ui-health.js +84 -0
  1540. package/dist/src/tools/ui-health.js.map +1 -0
  1541. package/dist/src/tools/ui-key.d.ts +16 -0
  1542. package/dist/src/tools/ui-key.js +65 -0
  1543. package/dist/src/tools/ui-key.js.map +1 -0
  1544. package/dist/src/tools/ui-query.d.ts +16 -0
  1545. package/dist/src/tools/ui-query.js +48 -0
  1546. package/dist/src/tools/ui-query.js.map +1 -0
  1547. package/dist/src/tools/ui-scroll.d.ts +16 -0
  1548. package/dist/src/tools/ui-scroll.js +62 -0
  1549. package/dist/src/tools/ui-scroll.js.map +1 -0
  1550. package/dist/src/tools/ui-snapshot.d.ts +16 -0
  1551. package/dist/src/tools/ui-snapshot.js +69 -0
  1552. package/dist/src/tools/ui-snapshot.js.map +1 -0
  1553. package/dist/src/tools/ui-tool-base.d.ts +22 -0
  1554. package/dist/src/tools/ui-tool-base.js +27 -0
  1555. package/dist/src/tools/ui-tool-base.js.map +1 -0
  1556. package/dist/src/tools/ui-tool-utils.d.ts +21 -0
  1557. package/dist/src/tools/ui-tool-utils.js +126 -0
  1558. package/dist/src/tools/ui-tool-utils.js.map +1 -0
  1559. package/dist/src/tools/ui-type.d.ts +16 -0
  1560. package/dist/src/tools/ui-type.js +67 -0
  1561. package/dist/src/tools/ui-type.js.map +1 -0
  1562. package/dist/src/tools/ui-wait.d.ts +16 -0
  1563. package/dist/src/tools/ui-wait.js +51 -0
  1564. package/dist/src/tools/ui-wait.js.map +1 -0
  1565. package/dist/src/tools/web-fetch.d.ts +36 -0
  1566. package/dist/src/tools/web-fetch.js +316 -0
  1567. package/dist/src/tools/web-fetch.js.map +1 -0
  1568. package/dist/src/tools/web-fetch.test.d.ts +7 -0
  1569. package/dist/src/tools/web-fetch.test.js +477 -0
  1570. package/dist/src/tools/web-fetch.test.js.map +1 -0
  1571. package/dist/src/tools/web-search.d.ts +51 -0
  1572. package/dist/src/tools/web-search.js +142 -0
  1573. package/dist/src/tools/web-search.js.map +1 -0
  1574. package/dist/src/tools/web-search.test.d.ts +7 -0
  1575. package/dist/src/tools/web-search.test.js +242 -0
  1576. package/dist/src/tools/web-search.test.js.map +1 -0
  1577. package/dist/src/tools/write-file.d.ts +54 -0
  1578. package/dist/src/tools/write-file.js +332 -0
  1579. package/dist/src/tools/write-file.js.map +1 -0
  1580. package/dist/src/tools/write-file.test.d.ts +7 -0
  1581. package/dist/src/tools/write-file.test.js +623 -0
  1582. package/dist/src/tools/write-file.test.js.map +1 -0
  1583. package/dist/src/tools/write-todos.d.ts +51 -0
  1584. package/dist/src/tools/write-todos.js +194 -0
  1585. package/dist/src/tools/write-todos.js.map +1 -0
  1586. package/dist/src/tools/write-todos.test.d.ts +7 -0
  1587. package/dist/src/tools/write-todos.test.js +90 -0
  1588. package/dist/src/tools/write-todos.test.js.map +1 -0
  1589. package/dist/src/utils/LruCache.d.ts +14 -0
  1590. package/dist/src/utils/LruCache.js +39 -0
  1591. package/dist/src/utils/LruCache.js.map +1 -0
  1592. package/dist/src/utils/bfsFileSearch.d.ts +33 -0
  1593. package/dist/src/utils/bfsFileSearch.js +137 -0
  1594. package/dist/src/utils/bfsFileSearch.js.map +1 -0
  1595. package/dist/src/utils/bfsFileSearch.test.d.ts +7 -0
  1596. package/dist/src/utils/bfsFileSearch.test.js +228 -0
  1597. package/dist/src/utils/bfsFileSearch.test.js.map +1 -0
  1598. package/dist/src/utils/browser.d.ts +14 -0
  1599. package/dist/src/utils/browser.js +51 -0
  1600. package/dist/src/utils/browser.js.map +1 -0
  1601. package/dist/src/utils/channel.d.ts +20 -0
  1602. package/dist/src/utils/channel.js +50 -0
  1603. package/dist/src/utils/channel.js.map +1 -0
  1604. package/dist/src/utils/channel.test.d.ts +7 -0
  1605. package/dist/src/utils/channel.test.js +171 -0
  1606. package/dist/src/utils/channel.test.js.map +1 -0
  1607. package/dist/src/utils/checkpointUtils.d.ts +83 -0
  1608. package/dist/src/utils/checkpointUtils.js +118 -0
  1609. package/dist/src/utils/checkpointUtils.js.map +1 -0
  1610. package/dist/src/utils/checkpointUtils.test.d.ts +7 -0
  1611. package/dist/src/utils/checkpointUtils.test.js +230 -0
  1612. package/dist/src/utils/checkpointUtils.test.js.map +1 -0
  1613. package/dist/src/utils/customHeaderUtils.d.ts +10 -0
  1614. package/dist/src/utils/customHeaderUtils.js +35 -0
  1615. package/dist/src/utils/customHeaderUtils.js.map +1 -0
  1616. package/dist/src/utils/customHeaderUtils.test.d.ts +7 -0
  1617. package/dist/src/utils/customHeaderUtils.test.js +78 -0
  1618. package/dist/src/utils/customHeaderUtils.test.js.map +1 -0
  1619. package/dist/src/utils/debugLogger.d.ts +29 -0
  1620. package/dist/src/utils/debugLogger.js +61 -0
  1621. package/dist/src/utils/debugLogger.js.map +1 -0
  1622. package/dist/src/utils/debugLogger.test.d.ts +7 -0
  1623. package/dist/src/utils/debugLogger.test.js +70 -0
  1624. package/dist/src/utils/debugLogger.test.js.map +1 -0
  1625. package/dist/src/utils/deepMerge.d.ts +10 -0
  1626. package/dist/src/utils/deepMerge.js +64 -0
  1627. package/dist/src/utils/deepMerge.js.map +1 -0
  1628. package/dist/src/utils/delay.d.ts +17 -0
  1629. package/dist/src/utils/delay.js +44 -0
  1630. package/dist/src/utils/delay.js.map +1 -0
  1631. package/dist/src/utils/delay.test.d.ts +7 -0
  1632. package/dist/src/utils/delay.test.js +89 -0
  1633. package/dist/src/utils/delay.test.js.map +1 -0
  1634. package/dist/src/utils/editCorrector.d.ts +55 -0
  1635. package/dist/src/utils/editCorrector.js +574 -0
  1636. package/dist/src/utils/editCorrector.js.map +1 -0
  1637. package/dist/src/utils/editCorrector.test.d.ts +7 -0
  1638. package/dist/src/utils/editCorrector.test.js +534 -0
  1639. package/dist/src/utils/editCorrector.test.js.map +1 -0
  1640. package/dist/src/utils/editor.d.ts +39 -0
  1641. package/dist/src/utils/editor.js +197 -0
  1642. package/dist/src/utils/editor.js.map +1 -0
  1643. package/dist/src/utils/editor.test.d.ts +7 -0
  1644. package/dist/src/utils/editor.test.js +405 -0
  1645. package/dist/src/utils/editor.test.js.map +1 -0
  1646. package/dist/src/utils/envAliases.d.ts +11 -0
  1647. package/dist/src/utils/envAliases.js +33 -0
  1648. package/dist/src/utils/envAliases.js.map +1 -0
  1649. package/dist/src/utils/envAliases.test.d.ts +7 -0
  1650. package/dist/src/utils/envAliases.test.js +43 -0
  1651. package/dist/src/utils/envAliases.test.js.map +1 -0
  1652. package/dist/src/utils/envVarResolver.d.ts +15 -0
  1653. package/dist/src/utils/envVarResolver.js +68 -0
  1654. package/dist/src/utils/envVarResolver.js.map +1 -0
  1655. package/dist/src/utils/environmentContext.d.ts +24 -0
  1656. package/dist/src/utils/environmentContext.js +116 -0
  1657. package/dist/src/utils/environmentContext.js.map +1 -0
  1658. package/dist/src/utils/environmentContext.test.d.ts +7 -0
  1659. package/dist/src/utils/environmentContext.test.js +115 -0
  1660. package/dist/src/utils/environmentContext.test.js.map +1 -0
  1661. package/dist/src/utils/errorParsing.d.ts +9 -0
  1662. package/dist/src/utils/errorParsing.js +66 -0
  1663. package/dist/src/utils/errorParsing.js.map +1 -0
  1664. package/dist/src/utils/errorParsing.test.d.ts +7 -0
  1665. package/dist/src/utils/errorParsing.test.js +85 -0
  1666. package/dist/src/utils/errorParsing.test.js.map +1 -0
  1667. package/dist/src/utils/errorReporting.d.ts +15 -0
  1668. package/dist/src/utils/errorReporting.js +89 -0
  1669. package/dist/src/utils/errorReporting.js.map +1 -0
  1670. package/dist/src/utils/errorReporting.test.d.ts +7 -0
  1671. package/dist/src/utils/errorReporting.test.js +131 -0
  1672. package/dist/src/utils/errorReporting.test.js.map +1 -0
  1673. package/dist/src/utils/errors.d.ts +51 -0
  1674. package/dist/src/utils/errors.js +140 -0
  1675. package/dist/src/utils/errors.js.map +1 -0
  1676. package/dist/src/utils/errors.test.d.ts +7 -0
  1677. package/dist/src/utils/errors.test.js +156 -0
  1678. package/dist/src/utils/errors.test.js.map +1 -0
  1679. package/dist/src/utils/events.d.ts +107 -0
  1680. package/dist/src/utils/events.js +76 -0
  1681. package/dist/src/utils/events.js.map +1 -0
  1682. package/dist/src/utils/events.test.d.ts +7 -0
  1683. package/dist/src/utils/events.test.js +213 -0
  1684. package/dist/src/utils/events.test.js.map +1 -0
  1685. package/dist/src/utils/exitCodes.d.ts +13 -0
  1686. package/dist/src/utils/exitCodes.js +14 -0
  1687. package/dist/src/utils/exitCodes.js.map +1 -0
  1688. package/dist/src/utils/extensionLoader.d.ts +87 -0
  1689. package/dist/src/utils/extensionLoader.js +208 -0
  1690. package/dist/src/utils/extensionLoader.js.map +1 -0
  1691. package/dist/src/utils/extensionLoader.test.d.ts +7 -0
  1692. package/dist/src/utils/extensionLoader.test.js +166 -0
  1693. package/dist/src/utils/extensionLoader.test.js.map +1 -0
  1694. package/dist/src/utils/fetch.d.ts +13 -0
  1695. package/dist/src/utils/fetch.js +56 -0
  1696. package/dist/src/utils/fetch.js.map +1 -0
  1697. package/dist/src/utils/fileUtils.d.ts +74 -0
  1698. package/dist/src/utils/fileUtils.js +438 -0
  1699. package/dist/src/utils/fileUtils.js.map +1 -0
  1700. package/dist/src/utils/fileUtils.test.d.ts +7 -0
  1701. package/dist/src/utils/fileUtils.test.js +724 -0
  1702. package/dist/src/utils/fileUtils.test.js.map +1 -0
  1703. package/dist/src/utils/filesearch/crawlCache.d.ts +26 -0
  1704. package/dist/src/utils/filesearch/crawlCache.js +58 -0
  1705. package/dist/src/utils/filesearch/crawlCache.js.map +1 -0
  1706. package/dist/src/utils/filesearch/crawlCache.test.d.ts +7 -0
  1707. package/dist/src/utils/filesearch/crawlCache.test.js +104 -0
  1708. package/dist/src/utils/filesearch/crawlCache.test.js.map +1 -0
  1709. package/dist/src/utils/filesearch/crawler.d.ts +16 -0
  1710. package/dist/src/utils/filesearch/crawler.js +51 -0
  1711. package/dist/src/utils/filesearch/crawler.js.map +1 -0
  1712. package/dist/src/utils/filesearch/crawler.test.d.ts +7 -0
  1713. package/dist/src/utils/filesearch/crawler.test.js +469 -0
  1714. package/dist/src/utils/filesearch/crawler.test.js.map +1 -0
  1715. package/dist/src/utils/filesearch/fileSearch.d.ts +39 -0
  1716. package/dist/src/utils/filesearch/fileSearch.js +192 -0
  1717. package/dist/src/utils/filesearch/fileSearch.js.map +1 -0
  1718. package/dist/src/utils/filesearch/fileSearch.test.d.ts +7 -0
  1719. package/dist/src/utils/filesearch/fileSearch.test.js +643 -0
  1720. package/dist/src/utils/filesearch/fileSearch.test.js.map +1 -0
  1721. package/dist/src/utils/filesearch/ignore.d.ts +43 -0
  1722. package/dist/src/utils/filesearch/ignore.js +107 -0
  1723. package/dist/src/utils/filesearch/ignore.js.map +1 -0
  1724. package/dist/src/utils/filesearch/ignore.test.d.ts +7 -0
  1725. package/dist/src/utils/filesearch/ignore.test.js +145 -0
  1726. package/dist/src/utils/filesearch/ignore.test.js.map +1 -0
  1727. package/dist/src/utils/filesearch/result-cache.d.ts +34 -0
  1728. package/dist/src/utils/filesearch/result-cache.js +60 -0
  1729. package/dist/src/utils/filesearch/result-cache.js.map +1 -0
  1730. package/dist/src/utils/filesearch/result-cache.test.d.ts +7 -0
  1731. package/dist/src/utils/filesearch/result-cache.test.js +47 -0
  1732. package/dist/src/utils/filesearch/result-cache.test.js.map +1 -0
  1733. package/dist/src/utils/flashFallback.test.d.ts +7 -0
  1734. package/dist/src/utils/flashFallback.test.js +104 -0
  1735. package/dist/src/utils/flashFallback.test.js.map +1 -0
  1736. package/dist/src/utils/formatters.d.ts +8 -0
  1737. package/dist/src/utils/formatters.js +18 -0
  1738. package/dist/src/utils/formatters.js.map +1 -0
  1739. package/dist/src/utils/formatters.test.d.ts +7 -0
  1740. package/dist/src/utils/formatters.test.js +27 -0
  1741. package/dist/src/utils/formatters.test.js.map +1 -0
  1742. package/dist/src/utils/geminiIgnoreParser.d.ts +19 -0
  1743. package/dist/src/utils/geminiIgnoreParser.js +62 -0
  1744. package/dist/src/utils/geminiIgnoreParser.js.map +1 -0
  1745. package/dist/src/utils/geminiIgnoreParser.test.d.ts +7 -0
  1746. package/dist/src/utils/geminiIgnoreParser.test.js +51 -0
  1747. package/dist/src/utils/geminiIgnoreParser.test.js.map +1 -0
  1748. package/dist/src/utils/generateContentResponseUtilities.d.ts +15 -0
  1749. package/dist/src/utils/generateContentResponseUtilities.js +91 -0
  1750. package/dist/src/utils/generateContentResponseUtilities.js.map +1 -0
  1751. package/dist/src/utils/generateContentResponseUtilities.test.d.ts +7 -0
  1752. package/dist/src/utils/generateContentResponseUtilities.test.js +293 -0
  1753. package/dist/src/utils/generateContentResponseUtilities.test.js.map +1 -0
  1754. package/dist/src/utils/getFolderStructure.d.ts +32 -0
  1755. package/dist/src/utils/getFolderStructure.js +239 -0
  1756. package/dist/src/utils/getFolderStructure.js.map +1 -0
  1757. package/dist/src/utils/getFolderStructure.test.d.ts +7 -0
  1758. package/dist/src/utils/getFolderStructure.test.js +284 -0
  1759. package/dist/src/utils/getFolderStructure.test.js.map +1 -0
  1760. package/dist/src/utils/getPty.d.ts +20 -0
  1761. package/dist/src/utils/getPty.js +24 -0
  1762. package/dist/src/utils/getPty.js.map +1 -0
  1763. package/dist/src/utils/gitHelpers.d.ts +11 -0
  1764. package/dist/src/utils/gitHelpers.js +33 -0
  1765. package/dist/src/utils/gitHelpers.js.map +1 -0
  1766. package/dist/src/utils/gitIgnoreParser.d.ts +20 -0
  1767. package/dist/src/utils/gitIgnoreParser.js +171 -0
  1768. package/dist/src/utils/gitIgnoreParser.js.map +1 -0
  1769. package/dist/src/utils/gitIgnoreParser.test.d.ts +7 -0
  1770. package/dist/src/utils/gitIgnoreParser.test.js +244 -0
  1771. package/dist/src/utils/gitIgnoreParser.test.js.map +1 -0
  1772. package/dist/src/utils/gitUtils.d.ts +18 -0
  1773. package/dist/src/utils/gitUtils.js +62 -0
  1774. package/dist/src/utils/gitUtils.js.map +1 -0
  1775. package/dist/src/utils/googleErrors.d.ts +105 -0
  1776. package/dist/src/utils/googleErrors.js +166 -0
  1777. package/dist/src/utils/googleErrors.js.map +1 -0
  1778. package/dist/src/utils/googleErrors.test.d.ts +7 -0
  1779. package/dist/src/utils/googleErrors.test.js +310 -0
  1780. package/dist/src/utils/googleErrors.test.js.map +1 -0
  1781. package/dist/src/utils/googleQuotaErrors.d.ts +38 -0
  1782. package/dist/src/utils/googleQuotaErrors.js +181 -0
  1783. package/dist/src/utils/googleQuotaErrors.js.map +1 -0
  1784. package/dist/src/utils/googleQuotaErrors.test.d.ts +7 -0
  1785. package/dist/src/utils/googleQuotaErrors.test.js +404 -0
  1786. package/dist/src/utils/googleQuotaErrors.test.js.map +1 -0
  1787. package/dist/src/utils/httpErrors.d.ts +19 -0
  1788. package/dist/src/utils/httpErrors.js +37 -0
  1789. package/dist/src/utils/httpErrors.js.map +1 -0
  1790. package/dist/src/utils/ignorePatterns.d.ts +104 -0
  1791. package/dist/src/utils/ignorePatterns.js +221 -0
  1792. package/dist/src/utils/ignorePatterns.js.map +1 -0
  1793. package/dist/src/utils/ignorePatterns.test.d.ts +7 -0
  1794. package/dist/src/utils/ignorePatterns.test.js +247 -0
  1795. package/dist/src/utils/ignorePatterns.test.js.map +1 -0
  1796. package/dist/src/utils/installationManager.d.ts +17 -0
  1797. package/dist/src/utils/installationManager.js +52 -0
  1798. package/dist/src/utils/installationManager.js.map +1 -0
  1799. package/dist/src/utils/installationManager.test.d.ts +7 -0
  1800. package/dist/src/utils/installationManager.test.js +86 -0
  1801. package/dist/src/utils/installationManager.test.js.map +1 -0
  1802. package/dist/src/utils/language-detection.d.ts +7 -0
  1803. package/dist/src/utils/language-detection.js +102 -0
  1804. package/dist/src/utils/language-detection.js.map +1 -0
  1805. package/dist/src/utils/llm-edit-fixer.d.ts +27 -0
  1806. package/dist/src/utils/llm-edit-fixer.js +156 -0
  1807. package/dist/src/utils/llm-edit-fixer.js.map +1 -0
  1808. package/dist/src/utils/llm-edit-fixer.test.d.ts +7 -0
  1809. package/dist/src/utils/llm-edit-fixer.test.js +224 -0
  1810. package/dist/src/utils/llm-edit-fixer.test.js.map +1 -0
  1811. package/dist/src/utils/memoryDiscovery.d.ts +41 -0
  1812. package/dist/src/utils/memoryDiscovery.js +423 -0
  1813. package/dist/src/utils/memoryDiscovery.js.map +1 -0
  1814. package/dist/src/utils/memoryDiscovery.test.d.ts +7 -0
  1815. package/dist/src/utils/memoryDiscovery.test.js +534 -0
  1816. package/dist/src/utils/memoryDiscovery.test.js.map +1 -0
  1817. package/dist/src/utils/memoryImportProcessor.d.ts +43 -0
  1818. package/dist/src/utils/memoryImportProcessor.js +291 -0
  1819. package/dist/src/utils/memoryImportProcessor.js.map +1 -0
  1820. package/dist/src/utils/memoryImportProcessor.test.d.ts +7 -0
  1821. package/dist/src/utils/memoryImportProcessor.test.js +582 -0
  1822. package/dist/src/utils/memoryImportProcessor.test.js.map +1 -0
  1823. package/dist/src/utils/messageInspectors.d.ts +9 -0
  1824. package/dist/src/utils/messageInspectors.js +17 -0
  1825. package/dist/src/utils/messageInspectors.js.map +1 -0
  1826. package/dist/src/utils/nextSpeakerChecker.d.ts +13 -0
  1827. package/dist/src/utils/nextSpeakerChecker.js +98 -0
  1828. package/dist/src/utils/nextSpeakerChecker.js.map +1 -0
  1829. package/dist/src/utils/nextSpeakerChecker.test.d.ts +7 -0
  1830. package/dist/src/utils/nextSpeakerChecker.test.js +192 -0
  1831. package/dist/src/utils/nextSpeakerChecker.test.js.map +1 -0
  1832. package/dist/src/utils/package.d.ts +27 -0
  1833. package/dist/src/utils/package.js +29 -0
  1834. package/dist/src/utils/package.js.map +1 -0
  1835. package/dist/src/utils/partUtils.d.ts +36 -0
  1836. package/dist/src/utils/partUtils.js +134 -0
  1837. package/dist/src/utils/partUtils.js.map +1 -0
  1838. package/dist/src/utils/partUtils.test.d.ts +7 -0
  1839. package/dist/src/utils/partUtils.test.js +242 -0
  1840. package/dist/src/utils/partUtils.test.js.map +1 -0
  1841. package/dist/src/utils/pathCorrector.d.ts +26 -0
  1842. package/dist/src/utils/pathCorrector.js +44 -0
  1843. package/dist/src/utils/pathCorrector.js.map +1 -0
  1844. package/dist/src/utils/pathCorrector.test.d.ts +7 -0
  1845. package/dist/src/utils/pathCorrector.test.js +88 -0
  1846. package/dist/src/utils/pathCorrector.test.js.map +1 -0
  1847. package/dist/src/utils/pathReader.d.ts +18 -0
  1848. package/dist/src/utils/pathReader.js +93 -0
  1849. package/dist/src/utils/pathReader.js.map +1 -0
  1850. package/dist/src/utils/pathReader.test.d.ts +7 -0
  1851. package/dist/src/utils/pathReader.test.js +407 -0
  1852. package/dist/src/utils/pathReader.test.js.map +1 -0
  1853. package/dist/src/utils/paths.d.ts +75 -0
  1854. package/dist/src/utils/paths.js +311 -0
  1855. package/dist/src/utils/paths.js.map +1 -0
  1856. package/dist/src/utils/paths.test.d.ts +7 -0
  1857. package/dist/src/utils/paths.test.js +358 -0
  1858. package/dist/src/utils/paths.test.js.map +1 -0
  1859. package/dist/src/utils/promptIdContext.d.ts +8 -0
  1860. package/dist/src/utils/promptIdContext.js +9 -0
  1861. package/dist/src/utils/promptIdContext.js.map +1 -0
  1862. package/dist/src/utils/pythonDepsInstaller.d.ts +23 -0
  1863. package/dist/src/utils/pythonDepsInstaller.js +132 -0
  1864. package/dist/src/utils/pythonDepsInstaller.js.map +1 -0
  1865. package/dist/src/utils/quotaErrorDetection.d.ts +17 -0
  1866. package/dist/src/utils/quotaErrorDetection.js +20 -0
  1867. package/dist/src/utils/quotaErrorDetection.js.map +1 -0
  1868. package/dist/src/utils/retry.d.ts +37 -0
  1869. package/dist/src/utils/retry.js +233 -0
  1870. package/dist/src/utils/retry.js.map +1 -0
  1871. package/dist/src/utils/retry.test.d.ts +7 -0
  1872. package/dist/src/utils/retry.test.js +549 -0
  1873. package/dist/src/utils/retry.test.js.map +1 -0
  1874. package/dist/src/utils/safeJsonStringify.d.ts +14 -0
  1875. package/dist/src/utils/safeJsonStringify.js +50 -0
  1876. package/dist/src/utils/safeJsonStringify.js.map +1 -0
  1877. package/dist/src/utils/safeJsonStringify.test.d.ts +7 -0
  1878. package/dist/src/utils/safeJsonStringify.test.js +62 -0
  1879. package/dist/src/utils/safeJsonStringify.test.js.map +1 -0
  1880. package/dist/src/utils/schemaValidator.d.ts +16 -0
  1881. package/dist/src/utils/schemaValidator.js +49 -0
  1882. package/dist/src/utils/schemaValidator.js.map +1 -0
  1883. package/dist/src/utils/schemaValidator.test.d.ts +7 -0
  1884. package/dist/src/utils/schemaValidator.test.js +114 -0
  1885. package/dist/src/utils/schemaValidator.test.js.map +1 -0
  1886. package/dist/src/utils/secure-browser-launcher.d.ts +24 -0
  1887. package/dist/src/utils/secure-browser-launcher.js +166 -0
  1888. package/dist/src/utils/secure-browser-launcher.js.map +1 -0
  1889. package/dist/src/utils/secure-browser-launcher.test.d.ts +7 -0
  1890. package/dist/src/utils/secure-browser-launcher.test.js +150 -0
  1891. package/dist/src/utils/secure-browser-launcher.test.js.map +1 -0
  1892. package/dist/src/utils/session.d.ts +7 -0
  1893. package/dist/src/utils/session.js +9 -0
  1894. package/dist/src/utils/session.js.map +1 -0
  1895. package/dist/src/utils/shell-permissions.d.ts +53 -0
  1896. package/dist/src/utils/shell-permissions.js +189 -0
  1897. package/dist/src/utils/shell-permissions.js.map +1 -0
  1898. package/dist/src/utils/shell-permissions.test.d.ts +7 -0
  1899. package/dist/src/utils/shell-permissions.test.js +345 -0
  1900. package/dist/src/utils/shell-permissions.test.js.map +1 -0
  1901. package/dist/src/utils/shell-utils.d.ts +100 -0
  1902. package/dist/src/utils/shell-utils.js +789 -0
  1903. package/dist/src/utils/shell-utils.js.map +1 -0
  1904. package/dist/src/utils/shell-utils.test.d.ts +7 -0
  1905. package/dist/src/utils/shell-utils.test.js +233 -0
  1906. package/dist/src/utils/shell-utils.test.js.map +1 -0
  1907. package/dist/src/utils/stdio.d.ts +33 -0
  1908. package/dist/src/utils/stdio.js +86 -0
  1909. package/dist/src/utils/stdio.js.map +1 -0
  1910. package/dist/src/utils/stdio.test.d.ts +7 -0
  1911. package/dist/src/utils/stdio.test.js +48 -0
  1912. package/dist/src/utils/stdio.test.js.map +1 -0
  1913. package/dist/src/utils/summarizer.d.ts +28 -0
  1914. package/dist/src/utils/summarizer.js +51 -0
  1915. package/dist/src/utils/summarizer.js.map +1 -0
  1916. package/dist/src/utils/summarizer.test.d.ts +7 -0
  1917. package/dist/src/utils/summarizer.test.js +152 -0
  1918. package/dist/src/utils/summarizer.test.js.map +1 -0
  1919. package/dist/src/utils/systemEncoding.d.ts +41 -0
  1920. package/dist/src/utils/systemEncoding.js +151 -0
  1921. package/dist/src/utils/systemEncoding.js.map +1 -0
  1922. package/dist/src/utils/systemEncoding.test.d.ts +7 -0
  1923. package/dist/src/utils/systemEncoding.test.js +370 -0
  1924. package/dist/src/utils/systemEncoding.test.js.map +1 -0
  1925. package/dist/src/utils/terminal.d.ts +15 -0
  1926. package/dist/src/utils/terminal.js +39 -0
  1927. package/dist/src/utils/terminal.js.map +1 -0
  1928. package/dist/src/utils/terminalSerializer.d.ts +26 -0
  1929. package/dist/src/utils/terminalSerializer.js +433 -0
  1930. package/dist/src/utils/terminalSerializer.js.map +1 -0
  1931. package/dist/src/utils/terminalSerializer.test.d.ts +7 -0
  1932. package/dist/src/utils/terminalSerializer.test.js +194 -0
  1933. package/dist/src/utils/terminalSerializer.test.js.map +1 -0
  1934. package/dist/src/utils/testUtils.d.ts +30 -0
  1935. package/dist/src/utils/testUtils.js +71 -0
  1936. package/dist/src/utils/testUtils.js.map +1 -0
  1937. package/dist/src/utils/textUtils.d.ts +19 -0
  1938. package/dist/src/utils/textUtils.js +43 -0
  1939. package/dist/src/utils/textUtils.js.map +1 -0
  1940. package/dist/src/utils/textUtils.test.d.ts +7 -0
  1941. package/dist/src/utils/textUtils.test.js +60 -0
  1942. package/dist/src/utils/textUtils.test.js.map +1 -0
  1943. package/dist/src/utils/thoughtUtils.d.ts +22 -0
  1944. package/dist/src/utils/thoughtUtils.js +40 -0
  1945. package/dist/src/utils/thoughtUtils.js.map +1 -0
  1946. package/dist/src/utils/thoughtUtils.test.d.ts +7 -0
  1947. package/dist/src/utils/thoughtUtils.test.js +79 -0
  1948. package/dist/src/utils/thoughtUtils.test.js.map +1 -0
  1949. package/dist/src/utils/tokenCalculation.d.ts +20 -0
  1950. package/dist/src/utils/tokenCalculation.js +71 -0
  1951. package/dist/src/utils/tokenCalculation.js.map +1 -0
  1952. package/dist/src/utils/tokenCalculation.test.d.ts +7 -0
  1953. package/dist/src/utils/tokenCalculation.test.js +79 -0
  1954. package/dist/src/utils/tokenCalculation.test.js.map +1 -0
  1955. package/dist/src/utils/tool-utils.d.ts +20 -0
  1956. package/dist/src/utils/tool-utils.js +68 -0
  1957. package/dist/src/utils/tool-utils.js.map +1 -0
  1958. package/dist/src/utils/tool-utils.test.d.ts +7 -0
  1959. package/dist/src/utils/tool-utils.test.js +70 -0
  1960. package/dist/src/utils/tool-utils.test.js.map +1 -0
  1961. package/dist/src/utils/userAccountManager.d.ts +21 -0
  1962. package/dist/src/utils/userAccountManager.js +116 -0
  1963. package/dist/src/utils/userAccountManager.js.map +1 -0
  1964. package/dist/src/utils/userAccountManager.test.d.ts +7 -0
  1965. package/dist/src/utils/userAccountManager.test.js +226 -0
  1966. package/dist/src/utils/userAccountManager.test.js.map +1 -0
  1967. package/dist/src/utils/version.d.ts +7 -0
  1968. package/dist/src/utils/version.js +16 -0
  1969. package/dist/src/utils/version.js.map +1 -0
  1970. package/dist/src/utils/version.test.d.ts +7 -0
  1971. package/dist/src/utils/version.test.js +40 -0
  1972. package/dist/src/utils/version.test.js.map +1 -0
  1973. package/dist/src/utils/workspaceContext.d.ts +68 -0
  1974. package/dist/src/utils/workspaceContext.js +172 -0
  1975. package/dist/src/utils/workspaceContext.js.map +1 -0
  1976. package/dist/src/utils/workspaceContext.test.d.ts +7 -0
  1977. package/dist/src/utils/workspaceContext.test.js +320 -0
  1978. package/dist/src/utils/workspaceContext.test.js.map +1 -0
  1979. package/dist/tsconfig.tsbuildinfo +1 -0
  1980. package/package.json +94 -0
@@ -0,0 +1,1653 @@
1
+ /**
2
+ * @license
3
+ * Copyright 2025 Google LLC
4
+ * Portions Copyright 2025 TerminaI Authors
5
+ * SPDX-License-Identifier: Apache-2.0
6
+ */
7
+ import { describe, it, expect, vi, beforeEach, afterEach } from 'vitest';
8
+ import { ApiError, ThinkingLevel } from '@google/genai';
9
+ import { GeminiChat, InvalidStreamError, StreamEventType, SYNTHETIC_THOUGHT_SIGNATURE, } from './geminiChat.js';
10
+ import { setSimulate429 } from '../utils/testUtils.js';
11
+ import { DEFAULT_THINKING_MODE } from '../config/models.js';
12
+ import { AuthType } from './contentGenerator.js';
13
+ import { TerminalQuotaError } from '../utils/googleQuotaErrors.js';
14
+ import {} from '../utils/retry.js';
15
+ import { uiTelemetryService } from '../telemetry/uiTelemetry.js';
16
+ import { HookSystem } from '../hooks/hookSystem.js';
17
+ import { createMockMessageBus } from '../test-utils/mock-message-bus.js';
18
+ import { createAvailabilityServiceMock } from '../availability/testUtils.js';
19
+ import * as policyHelpers from '../availability/policyHelpers.js';
20
+ import { makeResolvedModelConfig } from '../services/modelConfigServiceTestUtils.js';
21
+ // Mock fs module to prevent actual file system operations during tests
22
+ const mockFileSystem = new Map();
23
+ vi.mock('node:fs', () => {
24
+ const fsModule = {
25
+ mkdirSync: vi.fn(),
26
+ writeFileSync: vi.fn((path, data) => {
27
+ mockFileSystem.set(path, data);
28
+ }),
29
+ readFileSync: vi.fn((path) => {
30
+ if (mockFileSystem.has(path)) {
31
+ return mockFileSystem.get(path);
32
+ }
33
+ throw Object.assign(new Error('ENOENT: no such file or directory'), {
34
+ code: 'ENOENT',
35
+ });
36
+ }),
37
+ existsSync: vi.fn((path) => mockFileSystem.has(path)),
38
+ createWriteStream: vi.fn(() => ({
39
+ write: vi.fn(),
40
+ on: vi.fn(),
41
+ })),
42
+ };
43
+ return {
44
+ default: fsModule,
45
+ ...fsModule,
46
+ };
47
+ });
48
+ const { mockHandleFallback } = vi.hoisted(() => ({
49
+ mockHandleFallback: vi.fn(),
50
+ }));
51
+ // Add mock for the retry utility
52
+ const { mockRetryWithBackoff } = vi.hoisted(() => ({
53
+ mockRetryWithBackoff: vi.fn(),
54
+ }));
55
+ vi.mock('../utils/retry.js', async (importOriginal) => {
56
+ const actual = await importOriginal();
57
+ return {
58
+ ...actual,
59
+ retryWithBackoff: mockRetryWithBackoff,
60
+ };
61
+ });
62
+ vi.mock('../fallback/handler.js', () => ({
63
+ handleFallback: mockHandleFallback,
64
+ }));
65
+ const { mockLogContentRetry, mockLogContentRetryFailure } = vi.hoisted(() => ({
66
+ mockLogContentRetry: vi.fn(),
67
+ mockLogContentRetryFailure: vi.fn(),
68
+ }));
69
+ vi.mock('../telemetry/loggers.js', () => ({
70
+ logContentRetry: mockLogContentRetry,
71
+ logContentRetryFailure: mockLogContentRetryFailure,
72
+ }));
73
+ vi.mock('../telemetry/uiTelemetry.js', () => ({
74
+ uiTelemetryService: {
75
+ setLastPromptTokenCount: vi.fn(),
76
+ },
77
+ }));
78
+ describe('GeminiChat', () => {
79
+ let mockContentGenerator;
80
+ let chat;
81
+ let mockConfig;
82
+ beforeEach(() => {
83
+ vi.clearAllMocks();
84
+ vi.mocked(uiTelemetryService.setLastPromptTokenCount).mockClear();
85
+ mockContentGenerator = {
86
+ generateContent: vi.fn(),
87
+ generateContentStream: vi.fn(),
88
+ countTokens: vi.fn(),
89
+ embedContent: vi.fn(),
90
+ batchEmbedContents: vi.fn(),
91
+ };
92
+ mockHandleFallback.mockClear();
93
+ // Default mock implementation for tests that don't care about retry logic
94
+ mockRetryWithBackoff.mockImplementation(async (apiCall, options) => {
95
+ const result = await apiCall();
96
+ const context = options?.getAvailabilityContext?.();
97
+ if (context) {
98
+ context.service.markHealthy(context.policy.model);
99
+ }
100
+ return result;
101
+ });
102
+ let currentModel = 'gemini-pro';
103
+ let currentActiveModel = 'gemini-pro';
104
+ mockConfig = {
105
+ getSessionId: () => 'test-session-id',
106
+ getTelemetryLogPromptsEnabled: () => true,
107
+ getUsageStatisticsEnabled: () => true,
108
+ getDebugMode: () => false,
109
+ getPreviewFeatures: () => false,
110
+ getContentGeneratorConfig: vi.fn().mockImplementation(() => ({
111
+ authType: 'oauth-personal',
112
+ model: currentModel,
113
+ })),
114
+ getModel: vi.fn().mockImplementation(() => currentModel),
115
+ setModel: vi.fn().mockImplementation((m) => {
116
+ currentModel = m;
117
+ // When model is explicitly set, active model usually resets or updates to it
118
+ currentActiveModel = m;
119
+ }),
120
+ getQuotaErrorOccurred: vi.fn().mockReturnValue(false),
121
+ setQuotaErrorOccurred: vi.fn(),
122
+ flashFallbackHandler: undefined,
123
+ getProjectRoot: vi.fn().mockReturnValue('/test/project/root'),
124
+ storage: {
125
+ getProjectTempDir: vi.fn().mockReturnValue('/test/temp'),
126
+ },
127
+ getToolRegistry: vi.fn().mockReturnValue({
128
+ getTool: vi.fn(),
129
+ }),
130
+ getContentGenerator: vi.fn().mockReturnValue(mockContentGenerator),
131
+ getRetryFetchErrors: vi.fn().mockReturnValue(false),
132
+ getUserTier: vi.fn().mockReturnValue(undefined),
133
+ modelConfigService: {
134
+ getResolvedConfig: vi.fn().mockImplementation((modelConfigKey) => {
135
+ const model = modelConfigKey.model ?? mockConfig.getModel();
136
+ const thinkingConfig = model.startsWith('gemini-3')
137
+ ? {
138
+ thinkingLevel: ThinkingLevel.HIGH,
139
+ }
140
+ : {
141
+ thinkingBudget: DEFAULT_THINKING_MODE,
142
+ };
143
+ return {
144
+ model,
145
+ generateContentConfig: {
146
+ temperature: modelConfigKey.isRetry ? 1 : 0,
147
+ thinkingConfig,
148
+ },
149
+ };
150
+ }),
151
+ },
152
+ isInteractive: vi.fn().mockReturnValue(false),
153
+ getEnableHooks: vi.fn().mockReturnValue(false),
154
+ getActiveModel: vi.fn().mockImplementation(() => currentActiveModel),
155
+ setActiveModel: vi
156
+ .fn()
157
+ .mockImplementation((m) => (currentActiveModel = m)),
158
+ getModelAvailabilityService: vi
159
+ .fn()
160
+ .mockReturnValue(createAvailabilityServiceMock()),
161
+ };
162
+ // Use proper MessageBus mocking for Phase 3 preparation
163
+ const mockMessageBus = createMockMessageBus();
164
+ mockConfig.getMessageBus = vi.fn().mockReturnValue(mockMessageBus);
165
+ // Disable 429 simulation for tests
166
+ setSimulate429(false);
167
+ // Reset history for each test by creating a new instance
168
+ chat = new GeminiChat(mockConfig);
169
+ mockConfig.getHookSystem = vi
170
+ .fn()
171
+ .mockReturnValue(new HookSystem(mockConfig));
172
+ });
173
+ afterEach(() => {
174
+ vi.restoreAllMocks();
175
+ vi.resetAllMocks();
176
+ });
177
+ describe('constructor', () => {
178
+ it('should initialize lastPromptTokenCount based on history size', () => {
179
+ const history = [
180
+ { role: 'user', parts: [{ text: 'Hello' }] },
181
+ { role: 'model', parts: [{ text: 'Hi there' }] },
182
+ ];
183
+ const chatWithHistory = new GeminiChat(mockConfig, '', [], history);
184
+ // 'Hello': 5 chars * 0.25 = 1.25
185
+ // 'Hi there': 8 chars * 0.25 = 2.0
186
+ // Total: 3.25 -> floor(3.25) = 3
187
+ expect(chatWithHistory.getLastPromptTokenCount()).toBe(3);
188
+ });
189
+ it('should initialize lastPromptTokenCount for empty history', () => {
190
+ const chatEmpty = new GeminiChat(mockConfig);
191
+ expect(chatEmpty.getLastPromptTokenCount()).toBe(0);
192
+ });
193
+ });
194
+ describe('sendMessageStream', () => {
195
+ it('should succeed if a tool call is followed by an empty part', async () => {
196
+ // 1. Mock a stream that contains a tool call, then an invalid (empty) part.
197
+ const streamWithToolCall = (async function* () {
198
+ yield {
199
+ candidates: [
200
+ {
201
+ content: {
202
+ role: 'model',
203
+ parts: [{ functionCall: { name: 'test_tool', args: {} } }],
204
+ },
205
+ },
206
+ ],
207
+ };
208
+ // This second chunk is invalid according to isValidResponse
209
+ yield {
210
+ candidates: [
211
+ {
212
+ content: {
213
+ role: 'model',
214
+ parts: [{ text: '' }],
215
+ },
216
+ },
217
+ ],
218
+ };
219
+ })();
220
+ vi.mocked(mockContentGenerator.generateContentStream).mockResolvedValue(streamWithToolCall);
221
+ // 2. Action & Assert: The stream processing should complete without throwing an error
222
+ // because the presence of a tool call makes the empty final chunk acceptable.
223
+ const stream = await chat.sendMessageStream({ model: 'test-model' }, 'test message', 'prompt-id-tool-call-empty-end', new AbortController().signal);
224
+ await expect((async () => {
225
+ for await (const _ of stream) {
226
+ /* consume stream */
227
+ }
228
+ })()).resolves.not.toThrow();
229
+ // 3. Verify history was recorded correctly
230
+ const history = chat.getHistory();
231
+ expect(history.length).toBe(2); // user turn + model turn
232
+ const modelTurn = history[1];
233
+ expect(modelTurn?.parts?.length).toBe(1); // The empty part is discarded
234
+ expect(modelTurn?.parts[0].functionCall).toBeDefined();
235
+ });
236
+ it('should fail if the stream ends with an empty part and has no finishReason', async () => {
237
+ // 1. Mock a stream that ends with an invalid part and has no finish reason.
238
+ const streamWithNoFinish = (async function* () {
239
+ yield {
240
+ candidates: [
241
+ {
242
+ content: {
243
+ role: 'model',
244
+ parts: [{ text: 'Initial content...' }],
245
+ },
246
+ },
247
+ ],
248
+ };
249
+ // This second chunk is invalid and has no finishReason, so it should fail.
250
+ yield {
251
+ candidates: [
252
+ {
253
+ content: {
254
+ role: 'model',
255
+ parts: [{ text: '' }],
256
+ },
257
+ },
258
+ ],
259
+ };
260
+ })();
261
+ vi.mocked(mockContentGenerator.generateContentStream).mockResolvedValue(streamWithNoFinish);
262
+ // 2. Action & Assert: The stream should fail because there's no finish reason.
263
+ const stream = await chat.sendMessageStream({ model: 'gemini-2.0-flash' }, 'test message', 'prompt-id-no-finish-empty-end', new AbortController().signal);
264
+ await expect((async () => {
265
+ for await (const _ of stream) {
266
+ /* consume stream */
267
+ }
268
+ })()).rejects.toThrow(InvalidStreamError);
269
+ });
270
+ it('should succeed if the stream ends with an invalid part but has a finishReason and contained a valid part', async () => {
271
+ // 1. Mock a stream that sends a valid chunk, then an invalid one, but has a finish reason.
272
+ const streamWithInvalidEnd = (async function* () {
273
+ yield {
274
+ candidates: [
275
+ {
276
+ content: {
277
+ role: 'model',
278
+ parts: [{ text: 'Initial valid content...' }],
279
+ },
280
+ },
281
+ ],
282
+ };
283
+ // This second chunk is invalid, but the response has a finishReason.
284
+ yield {
285
+ candidates: [
286
+ {
287
+ content: {
288
+ role: 'model',
289
+ parts: [{ text: '' }], // Invalid part
290
+ },
291
+ finishReason: 'STOP',
292
+ },
293
+ ],
294
+ };
295
+ })();
296
+ vi.mocked(mockContentGenerator.generateContentStream).mockResolvedValue(streamWithInvalidEnd);
297
+ // 2. Action & Assert: The stream should complete without throwing an error.
298
+ const stream = await chat.sendMessageStream({ model: 'test-model' }, 'test message', 'prompt-id-valid-then-invalid-end', new AbortController().signal);
299
+ await expect((async () => {
300
+ for await (const _ of stream) {
301
+ /* consume stream */
302
+ }
303
+ })()).resolves.not.toThrow();
304
+ // 3. Verify history was recorded correctly with only the valid part.
305
+ const history = chat.getHistory();
306
+ expect(history.length).toBe(2); // user turn + model turn
307
+ const modelTurn = history[1];
308
+ expect(modelTurn?.parts?.length).toBe(1);
309
+ expect(modelTurn?.parts[0].text).toBe('Initial valid content...');
310
+ });
311
+ it('should consolidate subsequent text chunks after receiving an empty text chunk', async () => {
312
+ // 1. Mock the API to return a stream where one chunk is just an empty text part.
313
+ const multiChunkStream = (async function* () {
314
+ yield {
315
+ candidates: [
316
+ { content: { role: 'model', parts: [{ text: 'Hello' }] } },
317
+ ],
318
+ };
319
+ // FIX: The original test used { text: '' }, which is invalid.
320
+ // A chunk can be empty but still valid. This chunk is now removed
321
+ // as the important part is consolidating what comes after.
322
+ yield {
323
+ candidates: [
324
+ {
325
+ content: { role: 'model', parts: [{ text: ' World!' }] },
326
+ finishReason: 'STOP',
327
+ },
328
+ ],
329
+ };
330
+ })();
331
+ vi.mocked(mockContentGenerator.generateContentStream).mockResolvedValue(multiChunkStream);
332
+ // 2. Action: Send a message and consume the stream.
333
+ const stream = await chat.sendMessageStream({ model: 'test-model' }, 'test message', 'prompt-id-empty-chunk-consolidation', new AbortController().signal);
334
+ for await (const _ of stream) {
335
+ // Consume the stream
336
+ }
337
+ // 3. Assert: Check that the final history was correctly consolidated.
338
+ const history = chat.getHistory();
339
+ expect(history.length).toBe(2);
340
+ const modelTurn = history[1];
341
+ expect(modelTurn?.parts?.length).toBe(1);
342
+ expect(modelTurn?.parts[0].text).toBe('Hello World!');
343
+ });
344
+ it('should consolidate adjacent text parts that arrive in separate stream chunks', async () => {
345
+ // 1. Mock the API to return a stream of multiple, adjacent text chunks.
346
+ const multiChunkStream = (async function* () {
347
+ yield {
348
+ candidates: [
349
+ { content: { role: 'model', parts: [{ text: 'This is the ' }] } },
350
+ ],
351
+ };
352
+ yield {
353
+ candidates: [
354
+ { content: { role: 'model', parts: [{ text: 'first part.' }] } },
355
+ ],
356
+ };
357
+ // This function call should break the consolidation.
358
+ yield {
359
+ candidates: [
360
+ {
361
+ content: {
362
+ role: 'model',
363
+ parts: [{ functionCall: { name: 'do_stuff', args: {} } }],
364
+ },
365
+ },
366
+ ],
367
+ };
368
+ yield {
369
+ candidates: [
370
+ {
371
+ content: {
372
+ role: 'model',
373
+ parts: [{ text: 'This is the second part.' }],
374
+ },
375
+ },
376
+ ],
377
+ };
378
+ })();
379
+ vi.mocked(mockContentGenerator.generateContentStream).mockResolvedValue(multiChunkStream);
380
+ // 2. Action: Send a message and consume the stream.
381
+ const stream = await chat.sendMessageStream({ model: 'test-model' }, 'test message', 'prompt-id-multi-chunk', new AbortController().signal);
382
+ for await (const _ of stream) {
383
+ // Consume the stream to trigger history recording.
384
+ }
385
+ // 3. Assert: Check that the final history was correctly consolidated.
386
+ const history = chat.getHistory();
387
+ // The history should contain the user's turn and ONE consolidated model turn.
388
+ expect(history.length).toBe(2);
389
+ const modelTurn = history[1];
390
+ expect(modelTurn.role).toBe('model');
391
+ // The model turn should have 3 distinct parts: the merged text, the function call, and the final text.
392
+ expect(modelTurn?.parts?.length).toBe(3);
393
+ expect(modelTurn?.parts[0].text).toBe('This is the first part.');
394
+ expect(modelTurn.parts[1].functionCall).toBeDefined();
395
+ expect(modelTurn.parts[2].text).toBe('This is the second part.');
396
+ });
397
+ it('should preserve text parts that stream in the same chunk as a thought', async () => {
398
+ // 1. Mock the API to return a single chunk containing both a thought and visible text.
399
+ const mixedContentStream = (async function* () {
400
+ yield {
401
+ candidates: [
402
+ {
403
+ content: {
404
+ role: 'model',
405
+ parts: [
406
+ { thought: 'This is a thought.' },
407
+ { text: 'This is the visible text that should not be lost.' },
408
+ ],
409
+ },
410
+ finishReason: 'STOP',
411
+ },
412
+ ],
413
+ };
414
+ })();
415
+ vi.mocked(mockContentGenerator.generateContentStream).mockResolvedValue(mixedContentStream);
416
+ // 2. Action: Send a message and fully consume the stream to trigger history recording.
417
+ const stream = await chat.sendMessageStream({ model: 'test-model' }, 'test message', 'prompt-id-mixed-chunk', new AbortController().signal);
418
+ for await (const _ of stream) {
419
+ // This loop consumes the stream.
420
+ }
421
+ // 3. Assert: Check the final state of the history.
422
+ const history = chat.getHistory();
423
+ // The history should contain two turns: the user's message and the model's response.
424
+ expect(history.length).toBe(2);
425
+ const modelTurn = history[1];
426
+ expect(modelTurn.role).toBe('model');
427
+ // CRUCIAL ASSERTION:
428
+ // The buggy code would fail here, resulting in parts.length being 0.
429
+ // The corrected code will pass, preserving the single visible text part.
430
+ expect(modelTurn?.parts?.length).toBe(1);
431
+ expect(modelTurn?.parts[0].text).toBe('This is the visible text that should not be lost.');
432
+ });
433
+ it('should throw an error when a tool call is followed by an empty stream response', async () => {
434
+ // 1. Setup: A history where the model has just made a function call.
435
+ const initialHistory = [
436
+ {
437
+ role: 'user',
438
+ parts: [{ text: 'Find a good Italian restaurant for me.' }],
439
+ },
440
+ {
441
+ role: 'model',
442
+ parts: [
443
+ {
444
+ functionCall: {
445
+ name: 'find_restaurant',
446
+ args: { cuisine: 'Italian' },
447
+ },
448
+ },
449
+ ],
450
+ },
451
+ ];
452
+ chat.setHistory(initialHistory);
453
+ // 2. Mock the API to return an empty/thought-only stream.
454
+ const emptyStreamResponse = (async function* () {
455
+ yield {
456
+ candidates: [
457
+ {
458
+ content: { role: 'model', parts: [{ thought: true }] },
459
+ finishReason: 'STOP',
460
+ },
461
+ ],
462
+ };
463
+ })();
464
+ vi.mocked(mockContentGenerator.generateContentStream).mockResolvedValue(emptyStreamResponse);
465
+ // 3. Action: Send the function response back to the model and consume the stream.
466
+ const stream = await chat.sendMessageStream({ model: 'gemini-2.0-flash' }, {
467
+ functionResponse: {
468
+ name: 'find_restaurant',
469
+ response: { name: 'Vesuvio' },
470
+ },
471
+ }, 'prompt-id-stream-1', new AbortController().signal);
472
+ // 4. Assert: The stream processing should throw an InvalidStreamError.
473
+ await expect((async () => {
474
+ for await (const _ of stream) {
475
+ // This loop consumes the stream to trigger the internal logic.
476
+ }
477
+ })()).rejects.toThrow(InvalidStreamError);
478
+ });
479
+ it('should succeed when there is a tool call without finish reason', async () => {
480
+ // Setup: Stream with tool call but no finish reason
481
+ const streamWithToolCall = (async function* () {
482
+ yield {
483
+ candidates: [
484
+ {
485
+ content: {
486
+ role: 'model',
487
+ parts: [
488
+ {
489
+ functionCall: {
490
+ name: 'test_function',
491
+ args: { param: 'value' },
492
+ },
493
+ },
494
+ ],
495
+ },
496
+ // No finishReason
497
+ },
498
+ ],
499
+ };
500
+ })();
501
+ vi.mocked(mockContentGenerator.generateContentStream).mockResolvedValue(streamWithToolCall);
502
+ const stream = await chat.sendMessageStream({ model: 'test-model' }, 'test message', 'prompt-id-1', new AbortController().signal);
503
+ // Should not throw an error
504
+ await expect((async () => {
505
+ for await (const _ of stream) {
506
+ // consume stream
507
+ }
508
+ })()).resolves.not.toThrow();
509
+ });
510
+ it('should throw InvalidStreamError when no tool call and no finish reason', async () => {
511
+ // Setup: Stream with text but no finish reason and no tool call
512
+ const streamWithoutFinishReason = (async function* () {
513
+ yield {
514
+ candidates: [
515
+ {
516
+ content: {
517
+ role: 'model',
518
+ parts: [{ text: 'some response' }],
519
+ },
520
+ // No finishReason
521
+ },
522
+ ],
523
+ };
524
+ })();
525
+ vi.mocked(mockContentGenerator.generateContentStream).mockResolvedValue(streamWithoutFinishReason);
526
+ const stream = await chat.sendMessageStream({ model: 'gemini-2.0-flash' }, 'test message', 'prompt-id-1', new AbortController().signal);
527
+ await expect((async () => {
528
+ for await (const _ of stream) {
529
+ // consume stream
530
+ }
531
+ })()).rejects.toThrow(InvalidStreamError);
532
+ });
533
+ it('should throw InvalidStreamError when no tool call and empty response text', async () => {
534
+ // Setup: Stream with finish reason but empty response (only thoughts)
535
+ const streamWithEmptyResponse = (async function* () {
536
+ yield {
537
+ candidates: [
538
+ {
539
+ content: {
540
+ role: 'model',
541
+ parts: [{ thought: 'thinking...' }],
542
+ },
543
+ finishReason: 'STOP',
544
+ },
545
+ ],
546
+ };
547
+ })();
548
+ vi.mocked(mockContentGenerator.generateContentStream).mockResolvedValue(streamWithEmptyResponse);
549
+ const stream = await chat.sendMessageStream({ model: 'gemini-2.0-flash' }, 'test message', 'prompt-id-1', new AbortController().signal);
550
+ await expect((async () => {
551
+ for await (const _ of stream) {
552
+ // consume stream
553
+ }
554
+ })()).rejects.toThrow(InvalidStreamError);
555
+ });
556
+ it('should succeed when there is finish reason and response text', async () => {
557
+ // Setup: Stream with both finish reason and text content
558
+ const validStream = (async function* () {
559
+ yield {
560
+ candidates: [
561
+ {
562
+ content: {
563
+ role: 'model',
564
+ parts: [{ text: 'valid response' }],
565
+ },
566
+ finishReason: 'STOP',
567
+ },
568
+ ],
569
+ };
570
+ })();
571
+ vi.mocked(mockContentGenerator.generateContentStream).mockResolvedValue(validStream);
572
+ const stream = await chat.sendMessageStream({ model: 'test-model' }, 'test message', 'prompt-id-1', new AbortController().signal);
573
+ // Should not throw an error
574
+ await expect((async () => {
575
+ for await (const _ of stream) {
576
+ // consume stream
577
+ }
578
+ })()).resolves.not.toThrow();
579
+ });
580
+ it('should throw InvalidStreamError when finishReason is MALFORMED_FUNCTION_CALL', async () => {
581
+ // Setup: Stream with MALFORMED_FUNCTION_CALL finish reason and empty response
582
+ const streamWithMalformedFunctionCall = (async function* () {
583
+ yield {
584
+ candidates: [
585
+ {
586
+ content: {
587
+ role: 'model',
588
+ parts: [], // Empty parts
589
+ },
590
+ finishReason: 'MALFORMED_FUNCTION_CALL',
591
+ },
592
+ ],
593
+ };
594
+ })();
595
+ vi.mocked(mockContentGenerator.generateContentStream).mockResolvedValue(streamWithMalformedFunctionCall);
596
+ const stream = await chat.sendMessageStream({ model: 'gemini-2.5-pro' }, 'test', 'prompt-id-malformed', new AbortController().signal);
597
+ // Should throw an error
598
+ await expect((async () => {
599
+ for await (const _ of stream) {
600
+ // consume stream
601
+ }
602
+ })()).rejects.toThrow(InvalidStreamError);
603
+ });
604
+ it('should retry when finishReason is MALFORMED_FUNCTION_CALL', async () => {
605
+ // 1. Mock the API to fail once with MALFORMED_FUNCTION_CALL, then succeed.
606
+ vi.mocked(mockContentGenerator.generateContentStream)
607
+ .mockImplementationOnce(async () => (async function* () {
608
+ yield {
609
+ candidates: [
610
+ {
611
+ content: { parts: [], role: 'model' },
612
+ finishReason: 'MALFORMED_FUNCTION_CALL',
613
+ },
614
+ ],
615
+ };
616
+ })())
617
+ .mockImplementationOnce(async () =>
618
+ // Second attempt succeeds
619
+ (async function* () {
620
+ yield {
621
+ candidates: [
622
+ {
623
+ content: { parts: [{ text: 'Success after retry' }] },
624
+ finishReason: 'STOP',
625
+ },
626
+ ],
627
+ };
628
+ })());
629
+ // 2. Send a message
630
+ const stream = await chat.sendMessageStream({ model: 'gemini-2.5-pro' }, 'test retry', 'prompt-id-retry-malformed', new AbortController().signal);
631
+ const events = [];
632
+ for await (const event of stream) {
633
+ events.push(event);
634
+ }
635
+ // 3. Assertions
636
+ // Should be called twice (initial + retry)
637
+ expect(mockContentGenerator.generateContentStream).toHaveBeenCalledTimes(2);
638
+ // Check for a retry event
639
+ expect(events.some((e) => e.type === StreamEventType.RETRY)).toBe(true);
640
+ // Check for the successful content chunk
641
+ expect(events.some((e) => e.type === StreamEventType.CHUNK &&
642
+ e.value.candidates?.[0]?.content?.parts?.[0]?.text ===
643
+ 'Success after retry')).toBe(true);
644
+ });
645
+ it('should call generateContentStream with the correct parameters', async () => {
646
+ const response = (async function* () {
647
+ yield {
648
+ candidates: [
649
+ {
650
+ content: {
651
+ parts: [{ text: 'response' }],
652
+ role: 'model',
653
+ },
654
+ finishReason: 'STOP',
655
+ index: 0,
656
+ safetyRatings: [],
657
+ },
658
+ ],
659
+ text: () => 'response',
660
+ usageMetadata: {
661
+ promptTokenCount: 42,
662
+ candidatesTokenCount: 15,
663
+ totalTokenCount: 57,
664
+ },
665
+ };
666
+ })();
667
+ vi.mocked(mockContentGenerator.generateContentStream).mockResolvedValue(response);
668
+ const stream = await chat.sendMessageStream({ model: 'test-model' }, 'hello', 'prompt-id-1', new AbortController().signal);
669
+ for await (const _ of stream) {
670
+ // consume stream
671
+ }
672
+ expect(mockContentGenerator.generateContentStream).toHaveBeenCalledWith({
673
+ model: 'test-model',
674
+ contents: [
675
+ {
676
+ role: 'user',
677
+ parts: [{ text: 'hello' }],
678
+ },
679
+ ],
680
+ config: {
681
+ systemInstruction: '',
682
+ tools: [],
683
+ temperature: 0,
684
+ thinkingConfig: {
685
+ thinkingBudget: DEFAULT_THINKING_MODE,
686
+ },
687
+ abortSignal: expect.any(AbortSignal),
688
+ },
689
+ }, 'prompt-id-1');
690
+ });
691
+ it('should use thinkingLevel and remove thinkingBudget for gemini-3 models', async () => {
692
+ const response = (async function* () {
693
+ yield {
694
+ candidates: [
695
+ {
696
+ content: { parts: [{ text: 'response' }], role: 'model' },
697
+ finishReason: 'STOP',
698
+ },
699
+ ],
700
+ };
701
+ })();
702
+ vi.mocked(mockContentGenerator.generateContentStream).mockResolvedValue(response);
703
+ const stream = await chat.sendMessageStream({ model: 'gemini-3-test-only-model-string-for-testing' }, 'hello', 'prompt-id-thinking-level', new AbortController().signal);
704
+ for await (const _ of stream) {
705
+ // consume stream
706
+ }
707
+ expect(mockContentGenerator.generateContentStream).toHaveBeenCalledWith(expect.objectContaining({
708
+ model: 'gemini-3-test-only-model-string-for-testing',
709
+ config: expect.objectContaining({
710
+ thinkingConfig: {
711
+ thinkingBudget: undefined,
712
+ thinkingLevel: ThinkingLevel.HIGH,
713
+ },
714
+ }),
715
+ }), 'prompt-id-thinking-level');
716
+ });
717
+ it('should use thinkingBudget and remove thinkingLevel for non-gemini-3 models', async () => {
718
+ const response = (async function* () {
719
+ yield {
720
+ candidates: [
721
+ {
722
+ content: { parts: [{ text: 'response' }], role: 'model' },
723
+ finishReason: 'STOP',
724
+ },
725
+ ],
726
+ };
727
+ })();
728
+ vi.mocked(mockContentGenerator.generateContentStream).mockResolvedValue(response);
729
+ const stream = await chat.sendMessageStream({ model: 'gemini-2.0-flash' }, 'hello', 'prompt-id-thinking-budget', new AbortController().signal);
730
+ for await (const _ of stream) {
731
+ // consume stream
732
+ }
733
+ expect(mockContentGenerator.generateContentStream).toHaveBeenCalledWith(expect.objectContaining({
734
+ model: 'gemini-2.0-flash',
735
+ config: expect.objectContaining({
736
+ thinkingConfig: {
737
+ thinkingBudget: DEFAULT_THINKING_MODE,
738
+ thinkingLevel: undefined,
739
+ },
740
+ }),
741
+ }), 'prompt-id-thinking-budget');
742
+ });
743
+ });
744
+ describe('addHistory', () => {
745
+ it('should add a new content item to the history', () => {
746
+ const newContent = {
747
+ role: 'user',
748
+ parts: [{ text: 'A new message' }],
749
+ };
750
+ chat.addHistory(newContent);
751
+ const history = chat.getHistory();
752
+ expect(history.length).toBe(1);
753
+ expect(history[0]).toEqual(newContent);
754
+ });
755
+ it('should add multiple items correctly', () => {
756
+ const content1 = {
757
+ role: 'user',
758
+ parts: [{ text: 'Message 1' }],
759
+ };
760
+ const content2 = {
761
+ role: 'model',
762
+ parts: [{ text: 'Message 2' }],
763
+ };
764
+ chat.addHistory(content1);
765
+ chat.addHistory(content2);
766
+ const history = chat.getHistory();
767
+ expect(history.length).toBe(2);
768
+ expect(history[0]).toEqual(content1);
769
+ expect(history[1]).toEqual(content2);
770
+ });
771
+ });
772
+ describe('sendMessageStream with retries', () => {
773
+ it('should not retry on invalid content if model does not start with gemini-2', async () => {
774
+ // Mock the stream to fail.
775
+ vi.mocked(mockContentGenerator.generateContentStream).mockImplementation(async () => (async function* () {
776
+ yield {
777
+ candidates: [{ content: { parts: [{ text: '' }] } }],
778
+ };
779
+ })());
780
+ const stream = await chat.sendMessageStream({ model: 'gemini-1.5-pro' }, 'test', 'prompt-id-no-retry', new AbortController().signal);
781
+ await expect((async () => {
782
+ for await (const _ of stream) {
783
+ // Must loop to trigger the internal logic that throws.
784
+ }
785
+ })()).rejects.toThrow(InvalidStreamError);
786
+ // Should be called only 1 time (no retry)
787
+ expect(mockContentGenerator.generateContentStream).toHaveBeenCalledTimes(1);
788
+ expect(mockLogContentRetry).not.toHaveBeenCalled();
789
+ });
790
+ it('should yield a RETRY event when an invalid stream is encountered', async () => {
791
+ // ARRANGE: Mock the stream to fail once, then succeed.
792
+ vi.mocked(mockContentGenerator.generateContentStream)
793
+ .mockImplementationOnce(async () =>
794
+ // First attempt: An invalid stream with an empty text part.
795
+ (async function* () {
796
+ yield {
797
+ candidates: [{ content: { parts: [{ text: '' }] } }],
798
+ };
799
+ })())
800
+ .mockImplementationOnce(async () =>
801
+ // Second attempt (the retry): A minimal valid stream.
802
+ (async function* () {
803
+ yield {
804
+ candidates: [
805
+ {
806
+ content: { parts: [{ text: 'Success' }] },
807
+ finishReason: 'STOP',
808
+ },
809
+ ],
810
+ };
811
+ })());
812
+ // ACT: Send a message and collect all events from the stream.
813
+ const stream = await chat.sendMessageStream({ model: 'gemini-2.0-flash' }, 'test message', 'prompt-id-yield-retry', new AbortController().signal);
814
+ const events = [];
815
+ for await (const event of stream) {
816
+ events.push(event);
817
+ }
818
+ // ASSERT: Check that a RETRY event was present in the stream's output.
819
+ const retryEvent = events.find((e) => e.type === StreamEventType.RETRY);
820
+ expect(retryEvent).toBeDefined();
821
+ expect(retryEvent?.type).toBe(StreamEventType.RETRY);
822
+ });
823
+ it('should retry on invalid content, succeed, and report metrics', async () => {
824
+ // Use mockImplementationOnce to provide a fresh, promise-wrapped generator for each attempt.
825
+ vi.mocked(mockContentGenerator.generateContentStream)
826
+ .mockImplementationOnce(async () =>
827
+ // First call returns an invalid stream
828
+ (async function* () {
829
+ yield {
830
+ candidates: [{ content: { parts: [{ text: '' }] } }], // Invalid empty text part
831
+ };
832
+ })())
833
+ .mockImplementationOnce(async () =>
834
+ // Second call returns a valid stream
835
+ (async function* () {
836
+ yield {
837
+ candidates: [
838
+ {
839
+ content: { parts: [{ text: 'Successful response' }] },
840
+ finishReason: 'STOP',
841
+ },
842
+ ],
843
+ };
844
+ })());
845
+ const stream = await chat.sendMessageStream({ model: 'gemini-2.0-flash' }, 'test', 'prompt-id-retry-success', new AbortController().signal);
846
+ const chunks = [];
847
+ for await (const chunk of stream) {
848
+ chunks.push(chunk);
849
+ }
850
+ // Assertions
851
+ expect(mockLogContentRetry).toHaveBeenCalledTimes(1);
852
+ expect(mockLogContentRetryFailure).not.toHaveBeenCalled();
853
+ expect(mockContentGenerator.generateContentStream).toHaveBeenCalledTimes(2);
854
+ // Check for a retry event
855
+ expect(chunks.some((c) => c.type === StreamEventType.RETRY)).toBe(true);
856
+ // Check for the successful content chunk
857
+ expect(chunks.some((c) => c.type === StreamEventType.CHUNK &&
858
+ c.value.candidates?.[0]?.content?.parts?.[0]?.text ===
859
+ 'Successful response')).toBe(true);
860
+ // Check that history was recorded correctly once, with no duplicates.
861
+ const history = chat.getHistory();
862
+ expect(history.length).toBe(2);
863
+ expect(history[0]).toEqual({
864
+ role: 'user',
865
+ parts: [{ text: 'test' }],
866
+ });
867
+ expect(history[1]).toEqual({
868
+ role: 'model',
869
+ parts: [{ text: 'Successful response' }],
870
+ });
871
+ // Verify that token counting is not called when usageMetadata is missing
872
+ expect(uiTelemetryService.setLastPromptTokenCount).not.toHaveBeenCalled();
873
+ });
874
+ it('should set temperature to 1 on retry', async () => {
875
+ // Use mockImplementationOnce to provide a fresh, promise-wrapped generator for each attempt.
876
+ vi.mocked(mockContentGenerator.generateContentStream)
877
+ .mockImplementationOnce(async () =>
878
+ // First call returns an invalid stream
879
+ (async function* () {
880
+ yield {
881
+ candidates: [{ content: { parts: [{ text: '' }] } }], // Invalid empty text part
882
+ };
883
+ })())
884
+ .mockImplementationOnce(async () =>
885
+ // Second call returns a valid stream
886
+ (async function* () {
887
+ yield {
888
+ candidates: [
889
+ {
890
+ content: { parts: [{ text: 'Successful response' }] },
891
+ finishReason: 'STOP',
892
+ },
893
+ ],
894
+ };
895
+ })());
896
+ const stream = await chat.sendMessageStream({ model: 'gemini-2.0-flash' }, 'test message', 'prompt-id-retry-temperature', new AbortController().signal);
897
+ for await (const _ of stream) {
898
+ // consume stream
899
+ }
900
+ expect(mockContentGenerator.generateContentStream).toHaveBeenCalledTimes(2);
901
+ // First call should have original temperature
902
+ expect(mockContentGenerator.generateContentStream).toHaveBeenNthCalledWith(1, expect.objectContaining({
903
+ config: expect.objectContaining({
904
+ temperature: 0,
905
+ }),
906
+ }), 'prompt-id-retry-temperature');
907
+ // Second call (retry) should have temperature 1
908
+ expect(mockContentGenerator.generateContentStream).toHaveBeenNthCalledWith(2, expect.objectContaining({
909
+ config: expect.objectContaining({
910
+ temperature: 1,
911
+ }),
912
+ }), 'prompt-id-retry-temperature');
913
+ });
914
+ it('should fail after all retries on persistent invalid content and report metrics', async () => {
915
+ vi.mocked(mockContentGenerator.generateContentStream).mockImplementation(async () => (async function* () {
916
+ yield {
917
+ candidates: [
918
+ {
919
+ content: {
920
+ parts: [{ text: '' }],
921
+ role: 'model',
922
+ },
923
+ },
924
+ ],
925
+ };
926
+ })());
927
+ const stream = await chat.sendMessageStream({ model: 'gemini-2.0-flash' }, 'test', 'prompt-id-retry-fail', new AbortController().signal);
928
+ await expect(async () => {
929
+ for await (const _ of stream) {
930
+ // Must loop to trigger the internal logic that throws.
931
+ }
932
+ }).rejects.toThrow(InvalidStreamError);
933
+ // Should be called 2 times (initial + 1 retry)
934
+ expect(mockContentGenerator.generateContentStream).toHaveBeenCalledTimes(2);
935
+ expect(mockLogContentRetry).toHaveBeenCalledTimes(1);
936
+ expect(mockLogContentRetryFailure).toHaveBeenCalledTimes(1);
937
+ // History should still contain the user message.
938
+ const history = chat.getHistory();
939
+ expect(history.length).toBe(1);
940
+ expect(history[0]).toEqual({
941
+ role: 'user',
942
+ parts: [{ text: 'test' }],
943
+ });
944
+ });
945
+ describe('API error retry behavior', () => {
946
+ beforeEach(() => {
947
+ // Use a more direct mock for retry testing
948
+ mockRetryWithBackoff.mockImplementation(async (apiCall) => {
949
+ try {
950
+ return await apiCall();
951
+ }
952
+ catch (error) {
953
+ // Simulate the logic of defaultShouldRetry for ApiError
954
+ let shouldRetry = false;
955
+ if (error instanceof ApiError && error.message) {
956
+ if (error.status === 429 ||
957
+ (error.status >= 500 && error.status < 600)) {
958
+ shouldRetry = true;
959
+ }
960
+ // Explicitly don't retry on these
961
+ if (error.status === 400) {
962
+ shouldRetry = false;
963
+ }
964
+ }
965
+ if (shouldRetry) {
966
+ // Try again
967
+ return await apiCall();
968
+ }
969
+ throw error;
970
+ }
971
+ });
972
+ });
973
+ it('should not retry on 400 Bad Request errors', async () => {
974
+ const error400 = new ApiError({ message: 'Bad Request', status: 400 });
975
+ vi.mocked(mockContentGenerator.generateContentStream).mockRejectedValue(error400);
976
+ const stream = await chat.sendMessageStream({ model: 'gemini-2.0-flash' }, 'test message', 'prompt-id-400', new AbortController().signal);
977
+ await expect((async () => {
978
+ for await (const _ of stream) {
979
+ /* consume stream */
980
+ }
981
+ })()).rejects.toThrow(error400);
982
+ // Should only be called once (no retry)
983
+ expect(mockContentGenerator.generateContentStream).toHaveBeenCalledTimes(1);
984
+ });
985
+ it('should retry on 429 Rate Limit errors', async () => {
986
+ const error429 = new ApiError({ message: 'Rate Limited', status: 429 });
987
+ vi.mocked(mockContentGenerator.generateContentStream)
988
+ .mockRejectedValueOnce(error429)
989
+ .mockResolvedValueOnce((async function* () {
990
+ yield {
991
+ candidates: [
992
+ {
993
+ content: { parts: [{ text: 'Success after retry' }] },
994
+ finishReason: 'STOP',
995
+ },
996
+ ],
997
+ };
998
+ })());
999
+ const stream = await chat.sendMessageStream({ model: 'test-model' }, 'test message', 'prompt-id-429-retry', new AbortController().signal);
1000
+ const events = [];
1001
+ for await (const event of stream) {
1002
+ events.push(event);
1003
+ }
1004
+ // Should be called twice (initial + retry)
1005
+ expect(mockContentGenerator.generateContentStream).toHaveBeenCalledTimes(2);
1006
+ // Should have successful content
1007
+ expect(events.some((e) => e.type === StreamEventType.CHUNK &&
1008
+ e.value.candidates?.[0]?.content?.parts?.[0]?.text ===
1009
+ 'Success after retry')).toBe(true);
1010
+ });
1011
+ it('should retry on 5xx server errors', async () => {
1012
+ const error500 = new ApiError({
1013
+ message: 'Internal Server Error 500',
1014
+ status: 500,
1015
+ });
1016
+ vi.mocked(mockContentGenerator.generateContentStream)
1017
+ .mockRejectedValueOnce(error500)
1018
+ .mockResolvedValueOnce((async function* () {
1019
+ yield {
1020
+ candidates: [
1021
+ {
1022
+ content: { parts: [{ text: 'Recovered from 500' }] },
1023
+ finishReason: 'STOP',
1024
+ },
1025
+ ],
1026
+ };
1027
+ })());
1028
+ const stream = await chat.sendMessageStream({ model: 'test-model' }, 'test message', 'prompt-id-500-retry', new AbortController().signal);
1029
+ const events = [];
1030
+ for await (const event of stream) {
1031
+ events.push(event);
1032
+ }
1033
+ // Should be called twice (initial + retry)
1034
+ expect(mockContentGenerator.generateContentStream).toHaveBeenCalledTimes(2);
1035
+ });
1036
+ it('should retry on specific fetch errors when configured', async () => {
1037
+ vi.mocked(mockConfig.getRetryFetchErrors).mockReturnValue(true);
1038
+ const fetchError = new Error('exception TypeError: fetch failed sending request');
1039
+ vi.mocked(mockContentGenerator.generateContentStream)
1040
+ .mockRejectedValueOnce(fetchError)
1041
+ .mockResolvedValueOnce((async function* () {
1042
+ yield {
1043
+ candidates: [
1044
+ {
1045
+ content: { parts: [{ text: 'Success after fetch error' }] },
1046
+ finishReason: 'STOP',
1047
+ },
1048
+ ],
1049
+ };
1050
+ })());
1051
+ mockRetryWithBackoff.mockImplementation(async (apiCall, options) => {
1052
+ try {
1053
+ return await apiCall();
1054
+ }
1055
+ catch (error) {
1056
+ if (options?.retryFetchErrors &&
1057
+ error instanceof Error &&
1058
+ error.message.includes('exception TypeError: fetch failed sending request')) {
1059
+ return await apiCall();
1060
+ }
1061
+ throw error;
1062
+ }
1063
+ });
1064
+ const stream = await chat.sendMessageStream({ model: 'test-model' }, 'test message', 'prompt-id-fetch-error-retry', new AbortController().signal);
1065
+ const events = [];
1066
+ for await (const event of stream) {
1067
+ events.push(event);
1068
+ }
1069
+ expect(mockContentGenerator.generateContentStream).toHaveBeenCalledTimes(2);
1070
+ expect(events.some((e) => e.type === StreamEventType.CHUNK &&
1071
+ e.value.candidates?.[0]?.content?.parts?.[0]?.text ===
1072
+ 'Success after fetch error')).toBe(true);
1073
+ });
1074
+ afterEach(() => {
1075
+ // Reset to default behavior
1076
+ mockRetryWithBackoff.mockImplementation(async (apiCall) => apiCall());
1077
+ });
1078
+ });
1079
+ });
1080
+ it('should correctly retry and append to an existing history mid-conversation', async () => {
1081
+ // 1. Setup
1082
+ const initialHistory = [
1083
+ { role: 'user', parts: [{ text: 'First question' }] },
1084
+ { role: 'model', parts: [{ text: 'First answer' }] },
1085
+ ];
1086
+ chat.setHistory(initialHistory);
1087
+ // 2. Mock the API to fail once with an empty stream, then succeed.
1088
+ vi.mocked(mockContentGenerator.generateContentStream)
1089
+ .mockImplementationOnce(async () => (async function* () {
1090
+ yield {
1091
+ candidates: [{ content: { parts: [{ text: '' }] } }],
1092
+ };
1093
+ })())
1094
+ .mockImplementationOnce(async () =>
1095
+ // Second attempt succeeds
1096
+ (async function* () {
1097
+ yield {
1098
+ candidates: [
1099
+ {
1100
+ content: { parts: [{ text: 'Second answer' }] },
1101
+ finishReason: 'STOP',
1102
+ },
1103
+ ],
1104
+ };
1105
+ })());
1106
+ // 3. Send a new message
1107
+ const stream = await chat.sendMessageStream({ model: 'gemini-2.0-flash' }, 'Second question', 'prompt-id-retry-existing', new AbortController().signal);
1108
+ for await (const _ of stream) {
1109
+ // consume stream
1110
+ }
1111
+ // 4. Assert the final history and metrics
1112
+ const history = chat.getHistory();
1113
+ expect(history.length).toBe(4);
1114
+ // Assert that the correct metrics were reported for one empty-stream retry
1115
+ expect(mockLogContentRetry).toHaveBeenCalledTimes(1);
1116
+ // Explicitly verify the structure of each part to satisfy TypeScript
1117
+ const turn1 = history[0];
1118
+ if (!turn1?.parts?.[0] || !('text' in turn1.parts[0])) {
1119
+ throw new Error('Test setup error: First turn is not a valid text part.');
1120
+ }
1121
+ expect(turn1.parts[0].text).toBe('First question');
1122
+ const turn2 = history[1];
1123
+ if (!turn2?.parts?.[0] || !('text' in turn2.parts[0])) {
1124
+ throw new Error('Test setup error: Second turn is not a valid text part.');
1125
+ }
1126
+ expect(turn2.parts[0].text).toBe('First answer');
1127
+ const turn3 = history[2];
1128
+ if (!turn3?.parts?.[0] || !('text' in turn3.parts[0])) {
1129
+ throw new Error('Test setup error: Third turn is not a valid text part.');
1130
+ }
1131
+ expect(turn3.parts[0].text).toBe('Second question');
1132
+ const turn4 = history[3];
1133
+ if (!turn4?.parts?.[0] || !('text' in turn4.parts[0])) {
1134
+ throw new Error('Test setup error: Fourth turn is not a valid text part.');
1135
+ }
1136
+ expect(turn4.parts[0].text).toBe('Second answer');
1137
+ });
1138
+ it('should retry if the model returns a completely empty stream (no chunks)', async () => {
1139
+ // 1. Mock the API to return an empty stream first, then a valid one.
1140
+ vi.mocked(mockContentGenerator.generateContentStream)
1141
+ .mockImplementationOnce(
1142
+ // First call resolves to an async generator that yields nothing.
1143
+ async () => (async function* () { })())
1144
+ .mockImplementationOnce(
1145
+ // Second call returns a valid stream.
1146
+ async () => (async function* () {
1147
+ yield {
1148
+ candidates: [
1149
+ {
1150
+ content: {
1151
+ parts: [{ text: 'Successful response after empty' }],
1152
+ },
1153
+ finishReason: 'STOP',
1154
+ },
1155
+ ],
1156
+ };
1157
+ })());
1158
+ // 2. Call the method and consume the stream.
1159
+ const stream = await chat.sendMessageStream({ model: 'gemini-2.0-flash' }, 'test empty stream', 'prompt-id-empty-stream', new AbortController().signal);
1160
+ const chunks = [];
1161
+ for await (const chunk of stream) {
1162
+ chunks.push(chunk);
1163
+ }
1164
+ // 3. Assert the results.
1165
+ expect(mockContentGenerator.generateContentStream).toHaveBeenCalledTimes(2);
1166
+ expect(chunks.some((c) => c.type === StreamEventType.CHUNK &&
1167
+ c.value.candidates?.[0]?.content?.parts?.[0]?.text ===
1168
+ 'Successful response after empty')).toBe(true);
1169
+ const history = chat.getHistory();
1170
+ expect(history.length).toBe(2);
1171
+ // Explicitly verify the structure of each part to satisfy TypeScript
1172
+ const turn1 = history[0];
1173
+ if (!turn1?.parts?.[0] || !('text' in turn1.parts[0])) {
1174
+ throw new Error('Test setup error: First turn is not a valid text part.');
1175
+ }
1176
+ expect(turn1.parts[0].text).toBe('test empty stream');
1177
+ const turn2 = history[1];
1178
+ if (!turn2?.parts?.[0] || !('text' in turn2.parts[0])) {
1179
+ throw new Error('Test setup error: Second turn is not a valid text part.');
1180
+ }
1181
+ expect(turn2.parts[0].text).toBe('Successful response after empty');
1182
+ });
1183
+ it('should queue a subsequent sendMessageStream call until the first stream is fully consumed', async () => {
1184
+ // 1. Create a promise to manually control the stream's lifecycle
1185
+ let continueFirstStream;
1186
+ const firstStreamContinuePromise = new Promise((resolve) => {
1187
+ continueFirstStream = resolve;
1188
+ });
1189
+ // 2. Mock the API to return controllable async generators
1190
+ const firstStreamGenerator = (async function* () {
1191
+ yield {
1192
+ candidates: [
1193
+ { content: { parts: [{ text: 'first response part 1' }] } },
1194
+ ],
1195
+ };
1196
+ await firstStreamContinuePromise; // Pause the stream
1197
+ yield {
1198
+ candidates: [
1199
+ {
1200
+ content: { parts: [{ text: ' part 2' }] },
1201
+ finishReason: 'STOP',
1202
+ },
1203
+ ],
1204
+ };
1205
+ })();
1206
+ const secondStreamGenerator = (async function* () {
1207
+ yield {
1208
+ candidates: [
1209
+ {
1210
+ content: { parts: [{ text: 'second response' }] },
1211
+ finishReason: 'STOP',
1212
+ },
1213
+ ],
1214
+ };
1215
+ })();
1216
+ vi.mocked(mockContentGenerator.generateContentStream)
1217
+ .mockResolvedValueOnce(firstStreamGenerator)
1218
+ .mockResolvedValueOnce(secondStreamGenerator);
1219
+ // 3. Start the first stream and consume only the first chunk to pause it
1220
+ const firstStream = await chat.sendMessageStream({ model: 'test-model' }, 'first', 'prompt-1', new AbortController().signal);
1221
+ const firstStreamIterator = firstStream[Symbol.asyncIterator]();
1222
+ await firstStreamIterator.next();
1223
+ // 4. While the first stream is paused, start the second call. It will block.
1224
+ const secondStreamPromise = chat.sendMessageStream({ model: 'test-model' }, 'second', 'prompt-2', new AbortController().signal);
1225
+ // 5. Assert that only one API call has been made so far.
1226
+ expect(mockContentGenerator.generateContentStream).toHaveBeenCalledTimes(1);
1227
+ // 6. Unblock and fully consume the first stream to completion.
1228
+ continueFirstStream();
1229
+ await firstStreamIterator.next(); // Consume the rest of the stream
1230
+ await firstStreamIterator.next(); // Finish the iterator
1231
+ // 7. Now that the first stream is done, await the second promise to get its generator.
1232
+ const secondStream = await secondStreamPromise;
1233
+ // 8. Start consuming the second stream, which triggers its internal API call.
1234
+ const secondStreamIterator = secondStream[Symbol.asyncIterator]();
1235
+ await secondStreamIterator.next();
1236
+ // 9. The second API call should now have been made.
1237
+ expect(mockContentGenerator.generateContentStream).toHaveBeenCalledTimes(2);
1238
+ // 10. FIX: Fully consume the second stream to ensure recordHistory is called.
1239
+ await secondStreamIterator.next(); // This finishes the iterator.
1240
+ // 11. Final check on history.
1241
+ const history = chat.getHistory();
1242
+ expect(history.length).toBe(4);
1243
+ const turn4 = history[3];
1244
+ if (!turn4?.parts?.[0] || !('text' in turn4.parts[0])) {
1245
+ throw new Error('Test setup error: Fourth turn is not a valid text part.');
1246
+ }
1247
+ expect(turn4.parts[0].text).toBe('second response');
1248
+ });
1249
+ describe('Fallback Integration (Retries)', () => {
1250
+ const error429 = new ApiError({
1251
+ message: 'API Error 429: Quota exceeded',
1252
+ status: 429,
1253
+ });
1254
+ // Define the simulated behavior for retryWithBackoff for these tests.
1255
+ // This simulation tries the apiCall, if it fails, it calls the callback,
1256
+ // and then tries the apiCall again if the callback returns true.
1257
+ const simulateRetryBehavior = async (apiCall, options) => {
1258
+ try {
1259
+ return await apiCall();
1260
+ }
1261
+ catch (error) {
1262
+ if (options.onPersistent429) {
1263
+ // We simulate the "persistent" trigger here for simplicity.
1264
+ const shouldRetry = await options.onPersistent429(options.authType, error);
1265
+ if (shouldRetry) {
1266
+ return apiCall();
1267
+ }
1268
+ }
1269
+ throw error; // Stop if callback returns false/null or doesn't exist
1270
+ }
1271
+ };
1272
+ beforeEach(() => {
1273
+ mockRetryWithBackoff.mockImplementation(simulateRetryBehavior);
1274
+ });
1275
+ afterEach(() => {
1276
+ mockRetryWithBackoff.mockImplementation(async (apiCall) => apiCall());
1277
+ });
1278
+ it('should call handleFallback with the specific failed model and retry if handler returns true', async () => {
1279
+ const authType = AuthType.LOGIN_WITH_GOOGLE;
1280
+ vi.mocked(mockConfig.getContentGeneratorConfig).mockReturnValue({
1281
+ authType,
1282
+ });
1283
+ vi.mocked(mockContentGenerator.generateContentStream)
1284
+ .mockRejectedValueOnce(error429) // Attempt 1 fails
1285
+ .mockResolvedValueOnce(
1286
+ // Attempt 2 succeeds
1287
+ (async function* () {
1288
+ yield {
1289
+ candidates: [
1290
+ {
1291
+ content: { parts: [{ text: 'Success on retry' }] },
1292
+ finishReason: 'STOP',
1293
+ },
1294
+ ],
1295
+ };
1296
+ })());
1297
+ mockHandleFallback.mockImplementation(async () => true);
1298
+ const stream = await chat.sendMessageStream({ model: 'test-model' }, 'trigger 429', 'prompt-id-fb1', new AbortController().signal);
1299
+ // Consume stream to trigger logic
1300
+ for await (const _ of stream) {
1301
+ // no-op
1302
+ }
1303
+ expect(mockContentGenerator.generateContentStream).toHaveBeenCalledTimes(2);
1304
+ expect(mockHandleFallback).toHaveBeenCalledTimes(1);
1305
+ expect(mockHandleFallback).toHaveBeenCalledWith(mockConfig, 'test-model', authType, error429);
1306
+ const history = chat.getHistory();
1307
+ const modelTurn = history[1];
1308
+ expect(modelTurn.parts[0].text).toBe('Success on retry');
1309
+ });
1310
+ });
1311
+ it('should discard valid partial content from a failed attempt upon retry', async () => {
1312
+ // Mock the stream to fail on the first attempt after yielding some valid content.
1313
+ vi.mocked(mockContentGenerator.generateContentStream)
1314
+ .mockImplementationOnce(async () =>
1315
+ // First attempt: yields one valid chunk, then one invalid chunk
1316
+ (async function* () {
1317
+ yield {
1318
+ candidates: [
1319
+ {
1320
+ content: {
1321
+ parts: [{ text: 'This valid part should be discarded' }],
1322
+ },
1323
+ },
1324
+ ],
1325
+ };
1326
+ yield {
1327
+ candidates: [{ content: { parts: [{ text: '' }] } }], // Invalid chunk triggers retry
1328
+ };
1329
+ })())
1330
+ .mockImplementationOnce(async () =>
1331
+ // Second attempt (the retry): succeeds
1332
+ (async function* () {
1333
+ yield {
1334
+ candidates: [
1335
+ {
1336
+ content: {
1337
+ parts: [{ text: 'Successful final response' }],
1338
+ },
1339
+ finishReason: 'STOP',
1340
+ },
1341
+ ],
1342
+ };
1343
+ })());
1344
+ // Send a message and consume the stream
1345
+ const stream = await chat.sendMessageStream({ model: 'gemini-2.0-flash' }, 'test message', 'prompt-id-discard-test', new AbortController().signal);
1346
+ const events = [];
1347
+ for await (const event of stream) {
1348
+ events.push(event);
1349
+ }
1350
+ // Check that a retry happened
1351
+ expect(mockContentGenerator.generateContentStream).toHaveBeenCalledTimes(2);
1352
+ expect(events.some((e) => e.type === StreamEventType.RETRY)).toBe(true);
1353
+ // Check the final recorded history
1354
+ const history = chat.getHistory();
1355
+ expect(history.length).toBe(2); // user turn + final model turn
1356
+ const modelTurn = history[1];
1357
+ // The model turn should only contain the text from the successful attempt
1358
+ expect(modelTurn.parts[0].text).toBe('Successful final response');
1359
+ // It should NOT contain any text from the failed attempt
1360
+ expect(modelTurn.parts[0].text).not.toContain('This valid part should be discarded');
1361
+ });
1362
+ describe('stripThoughtsFromHistory', () => {
1363
+ it('should strip thought signatures', () => {
1364
+ chat.setHistory([
1365
+ {
1366
+ role: 'user',
1367
+ parts: [{ text: 'hello' }],
1368
+ },
1369
+ {
1370
+ role: 'model',
1371
+ parts: [
1372
+ { text: 'thinking...', thoughtSignature: 'thought-123' },
1373
+ {
1374
+ functionCall: { name: 'test', args: {} },
1375
+ thoughtSignature: 'thought-456',
1376
+ },
1377
+ ],
1378
+ },
1379
+ ]);
1380
+ chat.stripThoughtsFromHistory();
1381
+ expect(chat.getHistory()).toEqual([
1382
+ {
1383
+ role: 'user',
1384
+ parts: [{ text: 'hello' }],
1385
+ },
1386
+ {
1387
+ role: 'model',
1388
+ parts: [
1389
+ { text: 'thinking...' },
1390
+ { functionCall: { name: 'test', args: {} } },
1391
+ ],
1392
+ },
1393
+ ]);
1394
+ });
1395
+ });
1396
+ describe('ensureActiveLoopHasThoughtSignatures', () => {
1397
+ it('should add thoughtSignature to the first functionCall in each model turn of the active loop', () => {
1398
+ const chat = new GeminiChat(mockConfig, '', [], []);
1399
+ const history = [
1400
+ { role: 'user', parts: [{ text: 'Old message' }] },
1401
+ {
1402
+ role: 'model',
1403
+ parts: [{ functionCall: { name: 'old_tool', args: {} } }],
1404
+ },
1405
+ { role: 'user', parts: [{ text: 'Find a restaurant' }] }, // active loop starts here
1406
+ {
1407
+ role: 'model',
1408
+ parts: [
1409
+ { functionCall: { name: 'find_restaurant', args: {} } }, // This one gets a signature
1410
+ { functionCall: { name: 'find_restaurant_2', args: {} } }, // This one does NOT
1411
+ ],
1412
+ },
1413
+ {
1414
+ role: 'user',
1415
+ parts: [
1416
+ { functionResponse: { name: 'find_restaurant', response: {} } },
1417
+ ],
1418
+ },
1419
+ {
1420
+ role: 'model',
1421
+ parts: [
1422
+ {
1423
+ functionCall: { name: 'tool_with_sig', args: {} },
1424
+ thoughtSignature: 'existing-sig',
1425
+ },
1426
+ { functionCall: { name: 'another_tool', args: {} } }, // This one does NOT get a signature
1427
+ ],
1428
+ },
1429
+ ];
1430
+ const newContents = chat.ensureActiveLoopHasThoughtSignatures(history);
1431
+ // Outside active loop - unchanged
1432
+ expect(newContents[1]?.parts?.[0]).not.toHaveProperty('thoughtSignature');
1433
+ // Inside active loop, first model turn
1434
+ // First function call gets a signature
1435
+ expect(newContents[3]?.parts?.[0]?.thoughtSignature).toBe(SYNTHETIC_THOUGHT_SIGNATURE);
1436
+ // Second function call does NOT
1437
+ expect(newContents[3]?.parts?.[1]).not.toHaveProperty('thoughtSignature');
1438
+ // User functionResponse part - unchanged (this is not a model turn)
1439
+ expect(newContents[4]?.parts?.[0]).not.toHaveProperty('thoughtSignature');
1440
+ // Inside active loop, second model turn
1441
+ // First function call already has a signature, so nothing changes
1442
+ expect(newContents[5]?.parts?.[0]?.thoughtSignature).toBe('existing-sig');
1443
+ // Second function call does NOT get a signature
1444
+ expect(newContents[5]?.parts?.[1]).not.toHaveProperty('thoughtSignature');
1445
+ });
1446
+ it('should not modify contents if there is no user text message', () => {
1447
+ const chat = new GeminiChat(mockConfig, '', [], []);
1448
+ const history = [
1449
+ {
1450
+ role: 'user',
1451
+ parts: [{ functionResponse: { name: 'tool1', response: {} } }],
1452
+ },
1453
+ {
1454
+ role: 'model',
1455
+ parts: [{ functionCall: { name: 'tool2', args: {} } }],
1456
+ },
1457
+ ];
1458
+ const newContents = chat.ensureActiveLoopHasThoughtSignatures(history);
1459
+ expect(newContents).toEqual(history);
1460
+ expect(newContents[1]?.parts?.[0]).not.toHaveProperty('thoughtSignature');
1461
+ });
1462
+ it('should handle an empty history', () => {
1463
+ const chat = new GeminiChat(mockConfig, '', []);
1464
+ const history = [];
1465
+ const newContents = chat.ensureActiveLoopHasThoughtSignatures(history);
1466
+ expect(newContents).toEqual([]);
1467
+ });
1468
+ it('should handle history with only a user message', () => {
1469
+ const chat = new GeminiChat(mockConfig, '', []);
1470
+ const history = [{ role: 'user', parts: [{ text: 'Hello' }] }];
1471
+ const newContents = chat.ensureActiveLoopHasThoughtSignatures(history);
1472
+ expect(newContents).toEqual(history);
1473
+ });
1474
+ });
1475
+ describe('Availability Service Integration', () => {
1476
+ let mockAvailabilityService;
1477
+ beforeEach(async () => {
1478
+ mockAvailabilityService = createAvailabilityServiceMock();
1479
+ vi.mocked(mockConfig.getModelAvailabilityService).mockReturnValue(mockAvailabilityService);
1480
+ // Stateful mock for activeModel
1481
+ let activeModel = 'model-a';
1482
+ vi.mocked(mockConfig.getActiveModel).mockImplementation(() => activeModel);
1483
+ vi.mocked(mockConfig.setActiveModel).mockImplementation((model) => {
1484
+ activeModel = model;
1485
+ });
1486
+ vi.spyOn(policyHelpers, 'resolvePolicyChain').mockReturnValue([
1487
+ {
1488
+ model: 'model-a',
1489
+ isLastResort: false,
1490
+ actions: {},
1491
+ stateTransitions: {},
1492
+ },
1493
+ {
1494
+ model: 'model-b',
1495
+ isLastResort: false,
1496
+ actions: {},
1497
+ stateTransitions: {},
1498
+ },
1499
+ {
1500
+ model: 'model-c',
1501
+ isLastResort: true,
1502
+ actions: {},
1503
+ stateTransitions: {},
1504
+ },
1505
+ ]);
1506
+ });
1507
+ it('should mark healthy on successful stream', async () => {
1508
+ vi.mocked(mockAvailabilityService.selectFirstAvailable).mockReturnValue({
1509
+ selectedModel: 'model-b',
1510
+ skipped: [],
1511
+ });
1512
+ // Simulate selection happening upstream
1513
+ mockConfig.setActiveModel('model-b');
1514
+ vi.mocked(mockContentGenerator.generateContentStream).mockResolvedValue((async function* () {
1515
+ yield {
1516
+ candidates: [
1517
+ {
1518
+ content: { parts: [{ text: 'Response' }], role: 'model' },
1519
+ finishReason: 'STOP',
1520
+ },
1521
+ ],
1522
+ };
1523
+ })());
1524
+ const stream = await chat.sendMessageStream({ model: 'gemini-pro' }, 'test', 'prompt-healthy', new AbortController().signal);
1525
+ for await (const _ of stream) {
1526
+ // consume
1527
+ }
1528
+ expect(mockAvailabilityService.markHealthy).toHaveBeenCalledWith('model-b');
1529
+ });
1530
+ it('caps retries to a single attempt when selection is sticky', async () => {
1531
+ vi.mocked(mockAvailabilityService.selectFirstAvailable).mockReturnValue({
1532
+ selectedModel: 'model-a',
1533
+ attempts: 1,
1534
+ skipped: [],
1535
+ });
1536
+ vi.mocked(mockContentGenerator.generateContentStream).mockResolvedValue((async function* () {
1537
+ yield {
1538
+ candidates: [
1539
+ {
1540
+ content: { parts: [{ text: 'Response' }], role: 'model' },
1541
+ finishReason: 'STOP',
1542
+ },
1543
+ ],
1544
+ };
1545
+ })());
1546
+ const stream = await chat.sendMessageStream({ model: 'gemini-pro' }, 'test', 'prompt-sticky-once', new AbortController().signal);
1547
+ for await (const _ of stream) {
1548
+ // consume
1549
+ }
1550
+ expect(mockRetryWithBackoff).toHaveBeenCalledWith(expect.any(Function), expect.objectContaining({ maxAttempts: 1 }));
1551
+ expect(mockAvailabilityService.consumeStickyAttempt).toHaveBeenCalledWith('model-a');
1552
+ });
1553
+ it('should pass attempted model to onPersistent429 callback which calls handleFallback', async () => {
1554
+ vi.mocked(mockAvailabilityService.selectFirstAvailable).mockReturnValue({
1555
+ selectedModel: 'model-a',
1556
+ skipped: [],
1557
+ });
1558
+ // Simulate selection happening upstream
1559
+ mockConfig.setActiveModel('model-a');
1560
+ // Simulate retry logic behavior: catch error, call onPersistent429
1561
+ const error = new TerminalQuotaError('Quota', {
1562
+ code: 429,
1563
+ message: 'quota',
1564
+ details: [],
1565
+ });
1566
+ vi.mocked(mockContentGenerator.generateContentStream).mockRejectedValue(error);
1567
+ // We need retryWithBackoff to trigger the callback
1568
+ mockRetryWithBackoff.mockImplementation(async (apiCall, options) => {
1569
+ try {
1570
+ await apiCall();
1571
+ }
1572
+ catch (e) {
1573
+ if (options?.onPersistent429) {
1574
+ await options.onPersistent429(AuthType.LOGIN_WITH_GOOGLE, e);
1575
+ }
1576
+ throw e; // throw anyway to end test
1577
+ }
1578
+ });
1579
+ const consume = async () => {
1580
+ const stream = await chat.sendMessageStream({ model: 'gemini-pro' }, 'test', 'prompt-fallback-arg', new AbortController().signal);
1581
+ for await (const _ of stream) {
1582
+ // consume
1583
+ }
1584
+ };
1585
+ await expect(consume()).rejects.toThrow();
1586
+ // handleFallback is called with the ATTEMPTED model (model-a), not the requested one (gemini-pro)
1587
+ expect(mockHandleFallback).toHaveBeenCalledWith(expect.anything(), 'model-a', expect.anything(), error);
1588
+ });
1589
+ it('re-resolves generateContentConfig when active model changes between retries', async () => {
1590
+ // Availability enabled with stateful active model
1591
+ let activeModel = 'model-a';
1592
+ vi.mocked(mockConfig.getActiveModel).mockImplementation(() => activeModel);
1593
+ vi.mocked(mockConfig.setActiveModel).mockImplementation((model) => {
1594
+ activeModel = model;
1595
+ });
1596
+ // Different configs per model
1597
+ vi.mocked(mockConfig.modelConfigService.getResolvedConfig).mockImplementation((key) => {
1598
+ if (key.model === 'model-a') {
1599
+ return makeResolvedModelConfig('model-a', { temperature: 0.1 });
1600
+ }
1601
+ if (key.model === 'model-b') {
1602
+ return makeResolvedModelConfig('model-b', { temperature: 0.9 });
1603
+ }
1604
+ // Default for the initial requested model in this test
1605
+ return makeResolvedModelConfig('model-a', { temperature: 0.1 });
1606
+ });
1607
+ // First attempt uses model-a, then simulate availability switching to model-b
1608
+ mockRetryWithBackoff.mockImplementation(async (apiCall) => {
1609
+ await apiCall(); // first attempt
1610
+ activeModel = 'model-b'; // simulate switch before retry
1611
+ return apiCall(); // second attempt
1612
+ });
1613
+ // Generators for each attempt
1614
+ const firstResponse = (async function* () {
1615
+ yield {
1616
+ candidates: [
1617
+ {
1618
+ content: { parts: [{ text: 'first' }], role: 'model' },
1619
+ finishReason: 'STOP',
1620
+ },
1621
+ ],
1622
+ };
1623
+ })();
1624
+ const secondResponse = (async function* () {
1625
+ yield {
1626
+ candidates: [
1627
+ {
1628
+ content: { parts: [{ text: 'second' }], role: 'model' },
1629
+ finishReason: 'STOP',
1630
+ },
1631
+ ],
1632
+ };
1633
+ })();
1634
+ vi.mocked(mockContentGenerator.generateContentStream)
1635
+ .mockResolvedValueOnce(firstResponse)
1636
+ .mockResolvedValueOnce(secondResponse);
1637
+ const stream = await chat.sendMessageStream({ model: 'gemini-pro' }, 'test', 'prompt-config-refresh', new AbortController().signal);
1638
+ // Consume to drive both attempts
1639
+ for await (const _ of stream) {
1640
+ // consume
1641
+ }
1642
+ expect(mockContentGenerator.generateContentStream).toHaveBeenNthCalledWith(1, expect.objectContaining({
1643
+ model: 'model-a',
1644
+ config: expect.objectContaining({ temperature: 0.1 }),
1645
+ }), expect.any(String));
1646
+ expect(mockContentGenerator.generateContentStream).toHaveBeenNthCalledWith(2, expect.objectContaining({
1647
+ model: 'model-b',
1648
+ config: expect.objectContaining({ temperature: 0.9 }),
1649
+ }), expect.any(String));
1650
+ });
1651
+ });
1652
+ });
1653
+ //# sourceMappingURL=geminiChat.test.js.map