@google/gemini-cli-core 0.30.0-preview.6 → 0.31.0-preview.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 (687) hide show
  1. package/README.md +1 -1
  2. package/dist/docs/CONTRIBUTING.md +6 -7
  3. package/dist/docs/changelogs/index.md +22 -2
  4. package/dist/docs/changelogs/latest.md +359 -293
  5. package/dist/docs/changelogs/preview.md +300 -349
  6. package/dist/docs/cli/cli-reference.md +23 -23
  7. package/dist/docs/cli/enterprise.md +7 -7
  8. package/dist/docs/cli/gemini-md.md +1 -1
  9. package/dist/docs/cli/model.md +1 -1
  10. package/dist/docs/cli/plan-mode.md +180 -80
  11. package/dist/docs/cli/sandbox.md +3 -3
  12. package/dist/docs/cli/settings.md +59 -51
  13. package/dist/docs/cli/telemetry.md +4 -1
  14. package/dist/docs/cli/themes.md +3 -3
  15. package/dist/docs/cli/trusted-folders.md +31 -0
  16. package/dist/docs/cli/tutorials/memory-management.md +2 -2
  17. package/dist/docs/cli/tutorials/session-management.md +1 -1
  18. package/dist/docs/core/index.md +7 -7
  19. package/dist/docs/core/subagents.md +155 -39
  20. package/dist/docs/extensions/reference.md +38 -14
  21. package/dist/docs/get-started/authentication.md +4 -4
  22. package/dist/docs/get-started/examples.md +2 -2
  23. package/dist/docs/get-started/gemini-3.md +17 -3
  24. package/dist/docs/get-started/index.md +11 -2
  25. package/dist/docs/hooks/best-practices.md +1 -1
  26. package/dist/docs/hooks/reference.md +8 -0
  27. package/dist/docs/ide-integration/index.md +14 -0
  28. package/dist/docs/index.md +62 -67
  29. package/dist/docs/redirects.json +19 -0
  30. package/dist/docs/{cli → reference}/commands.md +67 -11
  31. package/dist/docs/{get-started → reference}/configuration.md +93 -24
  32. package/dist/docs/{cli → reference}/keyboard-shortcuts.md +3 -3
  33. package/dist/docs/{core → reference}/policy-engine.md +63 -27
  34. package/dist/docs/{faq.md → resources/faq.md} +1 -1
  35. package/dist/docs/{quota-and-pricing.md → resources/quota-and-pricing.md} +12 -5
  36. package/dist/docs/{tos-privacy.md → resources/tos-privacy.md} +2 -2
  37. package/dist/docs/{troubleshooting.md → resources/troubleshooting.md} +1 -1
  38. package/dist/docs/sidebar.json +203 -166
  39. package/dist/docs/tools/file-system.md +7 -4
  40. package/dist/docs/tools/index.md +5 -2
  41. package/dist/docs/tools/internal-docs.md +5 -5
  42. package/dist/docs/tools/mcp-server.md +62 -2
  43. package/dist/docs/tools/planning.md +2 -0
  44. package/dist/docs/tools/shell.md +3 -3
  45. package/dist/src/agents/a2a-client-manager.test.js +1 -2
  46. package/dist/src/agents/a2a-client-manager.test.js.map +1 -1
  47. package/dist/src/agents/a2aUtils.d.ts +1 -5
  48. package/dist/src/agents/a2aUtils.js +1 -1
  49. package/dist/src/agents/a2aUtils.js.map +1 -1
  50. package/dist/src/agents/acknowledgedAgents.js +1 -0
  51. package/dist/src/agents/acknowledgedAgents.js.map +1 -1
  52. package/dist/src/agents/agent-scheduler.js +1 -0
  53. package/dist/src/agents/agent-scheduler.js.map +1 -1
  54. package/dist/src/agents/agentLoader.d.ts +0 -1
  55. package/dist/src/agents/agentLoader.js +22 -21
  56. package/dist/src/agents/agentLoader.js.map +1 -1
  57. package/dist/src/agents/agentLoader.test.js +1 -5
  58. package/dist/src/agents/agentLoader.test.js.map +1 -1
  59. package/dist/src/agents/auth-provider/api-key-provider.d.ts +30 -0
  60. package/dist/src/agents/auth-provider/api-key-provider.js +66 -0
  61. package/dist/src/agents/auth-provider/api-key-provider.js.map +1 -0
  62. package/dist/src/agents/auth-provider/api-key-provider.test.d.ts +6 -0
  63. package/dist/src/agents/auth-provider/api-key-provider.test.js +130 -0
  64. package/dist/src/agents/auth-provider/api-key-provider.test.js.map +1 -0
  65. package/dist/src/agents/auth-provider/base-provider.d.ts +2 -2
  66. package/dist/src/agents/auth-provider/base-provider.js.map +1 -1
  67. package/dist/src/agents/auth-provider/factory.js +6 -3
  68. package/dist/src/agents/auth-provider/factory.js.map +1 -1
  69. package/dist/src/agents/auth-provider/factory.test.js +12 -0
  70. package/dist/src/agents/auth-provider/factory.test.js.map +1 -1
  71. package/dist/src/agents/auth-provider/types.d.ts +2 -4
  72. package/dist/src/agents/browser/analyzeScreenshot.d.ts +35 -0
  73. package/dist/src/agents/browser/analyzeScreenshot.js +183 -0
  74. package/dist/src/agents/browser/analyzeScreenshot.js.map +1 -0
  75. package/dist/src/agents/browser/analyzeScreenshot.test.d.ts +6 -0
  76. package/dist/src/agents/browser/analyzeScreenshot.test.js +161 -0
  77. package/dist/src/agents/browser/analyzeScreenshot.test.js.map +1 -0
  78. package/dist/src/agents/browser/browserAgentDefinition.d.ts +50 -0
  79. package/dist/src/agents/browser/browserAgentDefinition.js +141 -0
  80. package/dist/src/agents/browser/browserAgentDefinition.js.map +1 -0
  81. package/dist/src/agents/browser/browserAgentFactory.d.ts +42 -0
  82. package/dist/src/agents/browser/browserAgentFactory.js +107 -0
  83. package/dist/src/agents/browser/browserAgentFactory.js.map +1 -0
  84. package/dist/src/agents/browser/browserAgentFactory.test.d.ts +6 -0
  85. package/dist/src/agents/browser/browserAgentFactory.test.js +186 -0
  86. package/dist/src/agents/browser/browserAgentFactory.test.js.map +1 -0
  87. package/dist/src/agents/browser/browserAgentInvocation.d.ts +44 -0
  88. package/dist/src/agents/browser/browserAgentInvocation.js +109 -0
  89. package/dist/src/agents/browser/browserAgentInvocation.js.map +1 -0
  90. package/dist/src/agents/browser/browserAgentInvocation.test.d.ts +6 -0
  91. package/dist/src/agents/browser/browserAgentInvocation.test.js +87 -0
  92. package/dist/src/agents/browser/browserAgentInvocation.test.js.map +1 -0
  93. package/dist/src/agents/browser/browserManager.d.ts +110 -0
  94. package/dist/src/agents/browser/browserManager.js +323 -0
  95. package/dist/src/agents/browser/browserManager.js.map +1 -0
  96. package/dist/src/agents/browser/browserManager.test.d.ts +6 -0
  97. package/dist/src/agents/browser/browserManager.test.js +314 -0
  98. package/dist/src/agents/browser/browserManager.test.js.map +1 -0
  99. package/dist/src/agents/browser/mcpToolWrapper.d.ts +45 -0
  100. package/dist/src/agents/browser/mcpToolWrapper.js +356 -0
  101. package/dist/src/agents/browser/mcpToolWrapper.js.map +1 -0
  102. package/dist/src/agents/browser/mcpToolWrapper.test.d.ts +6 -0
  103. package/dist/src/agents/browser/mcpToolWrapper.test.js +126 -0
  104. package/dist/src/agents/browser/mcpToolWrapper.test.js.map +1 -0
  105. package/dist/src/agents/browser/mcpToolWrapperConfirmation.test.d.ts +6 -0
  106. package/dist/src/agents/browser/mcpToolWrapperConfirmation.test.js +57 -0
  107. package/dist/src/agents/browser/mcpToolWrapperConfirmation.test.js.map +1 -0
  108. package/dist/src/agents/browser/modelAvailability.d.ts +23 -0
  109. package/dist/src/agents/browser/modelAvailability.js +23 -0
  110. package/dist/src/agents/browser/modelAvailability.js.map +1 -0
  111. package/dist/src/agents/local-executor.js +73 -31
  112. package/dist/src/agents/local-executor.js.map +1 -1
  113. package/dist/src/agents/local-executor.test.js +157 -4
  114. package/dist/src/agents/local-executor.test.js.map +1 -1
  115. package/dist/src/agents/local-invocation.test.js.map +1 -1
  116. package/dist/src/agents/registry.js +8 -0
  117. package/dist/src/agents/registry.js.map +1 -1
  118. package/dist/src/agents/registry.test.js.map +1 -1
  119. package/dist/src/agents/remote-invocation.d.ts +2 -1
  120. package/dist/src/agents/remote-invocation.js +3 -3
  121. package/dist/src/agents/remote-invocation.js.map +1 -1
  122. package/dist/src/agents/subagent-tool-wrapper.js +6 -0
  123. package/dist/src/agents/subagent-tool-wrapper.js.map +1 -1
  124. package/dist/src/agents/subagent-tool.d.ts +3 -0
  125. package/dist/src/agents/subagent-tool.js +62 -3
  126. package/dist/src/agents/subagent-tool.js.map +1 -1
  127. package/dist/src/agents/subagent-tool.test.js +143 -0
  128. package/dist/src/agents/subagent-tool.test.js.map +1 -1
  129. package/dist/src/availability/fallbackIntegration.test.js +4 -1
  130. package/dist/src/availability/fallbackIntegration.test.js.map +1 -1
  131. package/dist/src/availability/policyHelpers.js +3 -1
  132. package/dist/src/availability/policyHelpers.js.map +1 -1
  133. package/dist/src/availability/policyHelpers.test.js +51 -5
  134. package/dist/src/availability/policyHelpers.test.js.map +1 -1
  135. package/dist/src/code_assist/admin/admin_controls.js +1 -0
  136. package/dist/src/code_assist/admin/admin_controls.js.map +1 -1
  137. package/dist/src/code_assist/converter.js +8 -2
  138. package/dist/src/code_assist/converter.js.map +1 -1
  139. package/dist/src/code_assist/converter.test.js.map +1 -1
  140. package/dist/src/code_assist/experiments/experiments.js +1 -1
  141. package/dist/src/code_assist/experiments/experiments.js.map +1 -1
  142. package/dist/src/code_assist/oauth-credential-storage.js +1 -1
  143. package/dist/src/code_assist/oauth-credential-storage.js.map +1 -1
  144. package/dist/src/code_assist/oauth-credential-storage.test.js +5 -0
  145. package/dist/src/code_assist/oauth-credential-storage.test.js.map +1 -1
  146. package/dist/src/code_assist/oauth2.js +11 -8
  147. package/dist/src/code_assist/oauth2.js.map +1 -1
  148. package/dist/src/code_assist/oauth2.test.js +55 -0
  149. package/dist/src/code_assist/oauth2.test.js.map +1 -1
  150. package/dist/src/code_assist/server.js +22 -13
  151. package/dist/src/code_assist/server.js.map +1 -1
  152. package/dist/src/code_assist/server.test.js +26 -0
  153. package/dist/src/code_assist/server.test.js.map +1 -1
  154. package/dist/src/code_assist/telemetry.js +16 -3
  155. package/dist/src/code_assist/telemetry.js.map +1 -1
  156. package/dist/src/code_assist/telemetry.test.js +10 -0
  157. package/dist/src/code_assist/telemetry.test.js.map +1 -1
  158. package/dist/src/code_assist/types.d.ts +13 -12
  159. package/dist/src/code_assist/types.js.map +1 -1
  160. package/dist/src/config/config.d.ts +83 -8
  161. package/dist/src/config/config.js +127 -23
  162. package/dist/src/config/config.js.map +1 -1
  163. package/dist/src/config/config.test.js +285 -10
  164. package/dist/src/config/config.test.js.map +1 -1
  165. package/dist/src/config/projectRegistry.js +1 -0
  166. package/dist/src/config/projectRegistry.js.map +1 -1
  167. package/dist/src/config/storage.d.ts +17 -1
  168. package/dist/src/config/storage.js +82 -2
  169. package/dist/src/config/storage.js.map +1 -1
  170. package/dist/src/config/storage.test.js +149 -2
  171. package/dist/src/config/storage.test.js.map +1 -1
  172. package/dist/src/config/userHintService.d.ts +46 -0
  173. package/dist/src/config/userHintService.js +81 -0
  174. package/dist/src/config/userHintService.js.map +1 -0
  175. package/dist/src/config/userHintService.test.d.ts +6 -0
  176. package/dist/src/config/userHintService.test.js +62 -0
  177. package/dist/src/config/userHintService.test.js.map +1 -0
  178. package/dist/src/confirmation-bus/message-bus.js +15 -3
  179. package/dist/src/confirmation-bus/message-bus.js.map +1 -1
  180. package/dist/src/confirmation-bus/message-bus.test.js +15 -0
  181. package/dist/src/confirmation-bus/message-bus.test.js.map +1 -1
  182. package/dist/src/confirmation-bus/types.d.ts +7 -0
  183. package/dist/src/confirmation-bus/types.js.map +1 -1
  184. package/dist/src/core/baseLlmClient.d.ts +2 -3
  185. package/dist/src/core/baseLlmClient.js +7 -5
  186. package/dist/src/core/baseLlmClient.js.map +1 -1
  187. package/dist/src/core/baseLlmClient.test.js +45 -20
  188. package/dist/src/core/baseLlmClient.test.js.map +1 -1
  189. package/dist/src/core/client.js +18 -7
  190. package/dist/src/core/client.js.map +1 -1
  191. package/dist/src/core/coreToolHookTriggers.d.ts +2 -3
  192. package/dist/src/core/coreToolHookTriggers.js +8 -3
  193. package/dist/src/core/coreToolHookTriggers.js.map +1 -1
  194. package/dist/src/core/coreToolScheduler.js +2 -1
  195. package/dist/src/core/coreToolScheduler.js.map +1 -1
  196. package/dist/src/core/coreToolScheduler.test.js +10 -3
  197. package/dist/src/core/coreToolScheduler.test.js.map +1 -1
  198. package/dist/src/core/fakeContentGenerator.js +2 -0
  199. package/dist/src/core/fakeContentGenerator.js.map +1 -1
  200. package/dist/src/core/geminiChat.d.ts +1 -1
  201. package/dist/src/core/geminiChat.js +5 -5
  202. package/dist/src/core/geminiChat.js.map +1 -1
  203. package/dist/src/core/geminiChat.test.js +1 -0
  204. package/dist/src/core/geminiChat.test.js.map +1 -1
  205. package/dist/src/core/geminiChat_network_retry.test.js +1 -0
  206. package/dist/src/core/geminiChat_network_retry.test.js.map +1 -1
  207. package/dist/src/core/logger.js +2 -0
  208. package/dist/src/core/logger.js.map +1 -1
  209. package/dist/src/core/loggingContentGenerator.d.ts +14 -2
  210. package/dist/src/core/loggingContentGenerator.js +98 -4
  211. package/dist/src/core/loggingContentGenerator.js.map +1 -1
  212. package/dist/src/core/loggingContentGenerator.test.js +275 -1
  213. package/dist/src/core/loggingContentGenerator.test.js.map +1 -1
  214. package/dist/src/core/prompts.test.js +55 -27
  215. package/dist/src/core/prompts.test.js.map +1 -1
  216. package/dist/src/core/recordingContentGenerator.test.js +5 -0
  217. package/dist/src/core/recordingContentGenerator.test.js.map +1 -1
  218. package/dist/src/core/turn.d.ts +4 -2
  219. package/dist/src/core/turn.js +2 -0
  220. package/dist/src/core/turn.js.map +1 -1
  221. package/dist/src/core/turn.test.js +4 -1
  222. package/dist/src/core/turn.test.js.map +1 -1
  223. package/dist/src/generated/git-commit.d.ts +2 -2
  224. package/dist/src/generated/git-commit.js +2 -2
  225. package/dist/src/hooks/hookAggregator.d.ts +1 -2
  226. package/dist/src/hooks/hookAggregator.js +1 -2
  227. package/dist/src/hooks/hookAggregator.js.map +1 -1
  228. package/dist/src/hooks/hookEventHandler.d.ts +2 -2
  229. package/dist/src/hooks/hookEventHandler.js +13 -4
  230. package/dist/src/hooks/hookEventHandler.js.map +1 -1
  231. package/dist/src/hooks/hookEventHandler.test.js +1 -2
  232. package/dist/src/hooks/hookEventHandler.test.js.map +1 -1
  233. package/dist/src/hooks/hookPlanner.d.ts +1 -2
  234. package/dist/src/hooks/hookPlanner.js.map +1 -1
  235. package/dist/src/hooks/hookRegistry.d.ts +8 -0
  236. package/dist/src/hooks/hookRegistry.js +31 -3
  237. package/dist/src/hooks/hookRegistry.js.map +1 -1
  238. package/dist/src/hooks/hookRegistry.test.js.map +1 -1
  239. package/dist/src/hooks/hookRunner.d.ts +5 -2
  240. package/dist/src/hooks/hookRunner.js +52 -2
  241. package/dist/src/hooks/hookRunner.js.map +1 -1
  242. package/dist/src/hooks/hookRunner.test.js.map +1 -1
  243. package/dist/src/hooks/hookSystem.d.ts +11 -3
  244. package/dist/src/hooks/hookSystem.js +10 -4
  245. package/dist/src/hooks/hookSystem.js.map +1 -1
  246. package/dist/src/hooks/hookSystem.test.js +1 -0
  247. package/dist/src/hooks/hookSystem.test.js.map +1 -1
  248. package/dist/src/hooks/runtimeHooks.test.d.ts +6 -0
  249. package/dist/src/hooks/runtimeHooks.test.js +100 -0
  250. package/dist/src/hooks/runtimeHooks.test.js.map +1 -0
  251. package/dist/src/hooks/trustedHooks.js +6 -1
  252. package/dist/src/hooks/trustedHooks.js.map +1 -1
  253. package/dist/src/hooks/trustedHooks.test.js +17 -9
  254. package/dist/src/hooks/trustedHooks.test.js.map +1 -1
  255. package/dist/src/hooks/types.d.ts +49 -8
  256. package/dist/src/hooks/types.js +20 -1
  257. package/dist/src/hooks/types.js.map +1 -1
  258. package/dist/src/ide/detect-ide.d.ts +0 -1
  259. package/dist/src/ide/detect-ide.js +1 -1
  260. package/dist/src/ide/detect-ide.js.map +1 -1
  261. package/dist/src/ide/ide-client.js +3 -2
  262. package/dist/src/ide/ide-client.js.map +1 -1
  263. package/dist/src/ide/ide-connection-utils.js +90 -14
  264. package/dist/src/ide/ide-connection-utils.js.map +1 -1
  265. package/dist/src/ide/ide-connection-utils.test.js +78 -0
  266. package/dist/src/ide/ide-connection-utils.test.js.map +1 -1
  267. package/dist/src/ide/ide-installer.test.js +1 -2
  268. package/dist/src/ide/ide-installer.test.js.map +1 -1
  269. package/dist/src/ide/process-utils.d.ts +7 -0
  270. package/dist/src/ide/process-utils.js +20 -0
  271. package/dist/src/ide/process-utils.js.map +1 -1
  272. package/dist/src/ide/process-utils.test.js +30 -0
  273. package/dist/src/ide/process-utils.test.js.map +1 -1
  274. package/dist/src/index.d.ts +6 -1
  275. package/dist/src/index.js +6 -1
  276. package/dist/src/index.js.map +1 -1
  277. package/dist/src/mcp/oauth-provider.d.ts +1 -1
  278. package/dist/src/mcp/oauth-provider.js +8 -7
  279. package/dist/src/mcp/oauth-provider.js.map +1 -1
  280. package/dist/src/mcp/oauth-provider.test.js +34 -2
  281. package/dist/src/mcp/oauth-provider.test.js.map +1 -1
  282. package/dist/src/mcp/oauth-utils.js +2 -0
  283. package/dist/src/mcp/oauth-utils.js.map +1 -1
  284. package/dist/src/mcp/oauth-utils.test.js +12 -0
  285. package/dist/src/mcp/oauth-utils.test.js.map +1 -1
  286. package/dist/src/mcp/token-storage/file-token-storage.js +4 -1
  287. package/dist/src/mcp/token-storage/file-token-storage.js.map +1 -1
  288. package/dist/src/mcp/token-storage/file-token-storage.test.js +40 -2
  289. package/dist/src/mcp/token-storage/file-token-storage.test.js.map +1 -1
  290. package/dist/src/mcp/token-storage/keychain-token-storage.js +2 -0
  291. package/dist/src/mcp/token-storage/keychain-token-storage.js.map +1 -1
  292. package/dist/src/policy/config.d.ts +18 -9
  293. package/dist/src/policy/config.js +75 -54
  294. package/dist/src/policy/config.js.map +1 -1
  295. package/dist/src/policy/config.test.js +26 -26
  296. package/dist/src/policy/integrity.d.ts +45 -0
  297. package/dist/src/policy/integrity.js +121 -0
  298. package/dist/src/policy/integrity.js.map +1 -0
  299. package/dist/src/policy/integrity.test.d.ts +6 -0
  300. package/dist/src/policy/integrity.test.js +132 -0
  301. package/dist/src/policy/integrity.test.js.map +1 -0
  302. package/dist/src/policy/persistence.test.js +29 -19
  303. package/dist/src/policy/persistence.test.js.map +1 -1
  304. package/dist/src/policy/policies/conseca.toml +6 -0
  305. package/dist/src/policy/policies/plan.toml +28 -12
  306. package/dist/src/policy/policies/read-only.toml +11 -10
  307. package/dist/src/policy/policies/write.toml +11 -10
  308. package/dist/src/policy/policies/yolo.toml +11 -10
  309. package/dist/src/policy/policy-engine.d.ts +16 -3
  310. package/dist/src/policy/policy-engine.js +154 -29
  311. package/dist/src/policy/policy-engine.js.map +1 -1
  312. package/dist/src/policy/policy-engine.test.js +480 -9
  313. package/dist/src/policy/policy-engine.test.js.map +1 -1
  314. package/dist/src/policy/policy-updater.test.js +11 -6
  315. package/dist/src/policy/policy-updater.test.js.map +1 -1
  316. package/dist/src/policy/toml-loader.d.ts +13 -2
  317. package/dist/src/policy/toml-loader.js +55 -34
  318. package/dist/src/policy/toml-loader.js.map +1 -1
  319. package/dist/src/policy/toml-loader.test.js +115 -7
  320. package/dist/src/policy/toml-loader.test.js.map +1 -1
  321. package/dist/src/policy/types.d.ts +18 -1
  322. package/dist/src/policy/types.js +1 -0
  323. package/dist/src/policy/types.js.map +1 -1
  324. package/dist/src/policy/workspace-policy.test.d.ts +6 -0
  325. package/dist/src/policy/workspace-policy.test.js +231 -0
  326. package/dist/src/policy/workspace-policy.test.js.map +1 -0
  327. package/dist/src/prompts/promptProvider.js +11 -13
  328. package/dist/src/prompts/promptProvider.js.map +1 -1
  329. package/dist/src/prompts/promptProvider.test.js +64 -3
  330. package/dist/src/prompts/promptProvider.test.js.map +1 -1
  331. package/dist/src/prompts/snippets.js +41 -10
  332. package/dist/src/prompts/snippets.js.map +1 -1
  333. package/dist/src/prompts/snippets.legacy.js +1 -0
  334. package/dist/src/prompts/snippets.legacy.js.map +1 -1
  335. package/dist/src/routing/modelRouterService.js +3 -1
  336. package/dist/src/routing/modelRouterService.js.map +1 -1
  337. package/dist/src/routing/modelRouterService.test.js +12 -6
  338. package/dist/src/routing/modelRouterService.test.js.map +1 -1
  339. package/dist/src/routing/strategies/approvalModeStrategy.d.ts +18 -0
  340. package/dist/src/routing/strategies/approvalModeStrategy.js +58 -0
  341. package/dist/src/routing/strategies/approvalModeStrategy.js.map +1 -0
  342. package/dist/src/routing/strategies/approvalModeStrategy.test.d.ts +6 -0
  343. package/dist/src/routing/strategies/approvalModeStrategy.test.js +110 -0
  344. package/dist/src/routing/strategies/approvalModeStrategy.test.js.map +1 -0
  345. package/dist/src/safety/checker-runner.js +1 -0
  346. package/dist/src/safety/checker-runner.js.map +1 -1
  347. package/dist/src/safety/conseca/conseca.d.ts +31 -0
  348. package/dist/src/safety/conseca/conseca.js +105 -0
  349. package/dist/src/safety/conseca/conseca.js.map +1 -0
  350. package/dist/src/safety/conseca/conseca.test.d.ts +6 -0
  351. package/dist/src/safety/conseca/conseca.test.js +226 -0
  352. package/dist/src/safety/conseca/conseca.test.js.map +1 -0
  353. package/dist/src/safety/conseca/integration.test.d.ts +6 -0
  354. package/dist/src/safety/conseca/integration.test.js +19 -0
  355. package/dist/src/safety/conseca/integration.test.js.map +1 -0
  356. package/dist/src/safety/conseca/policy-enforcer.d.ts +13 -0
  357. package/dist/src/safety/conseca/policy-enforcer.js +135 -0
  358. package/dist/src/safety/conseca/policy-enforcer.js.map +1 -0
  359. package/dist/src/safety/conseca/policy-enforcer.test.d.ts +6 -0
  360. package/dist/src/safety/conseca/policy-enforcer.test.js +141 -0
  361. package/dist/src/safety/conseca/policy-enforcer.test.js.map +1 -0
  362. package/dist/src/safety/conseca/policy-generator.d.ts +15 -0
  363. package/dist/src/safety/conseca/policy-generator.js +144 -0
  364. package/dist/src/safety/conseca/policy-generator.js.map +1 -0
  365. package/dist/src/safety/conseca/policy-generator.test.d.ts +6 -0
  366. package/dist/src/safety/conseca/policy-generator.test.js +84 -0
  367. package/dist/src/safety/conseca/policy-generator.test.js.map +1 -0
  368. package/dist/src/safety/conseca/types.d.ts +15 -0
  369. package/dist/src/safety/conseca/types.js +7 -0
  370. package/dist/src/safety/conseca/types.js.map +1 -0
  371. package/dist/src/safety/context-builder.d.ts +3 -3
  372. package/dist/src/safety/context-builder.js +60 -4
  373. package/dist/src/safety/context-builder.js.map +1 -1
  374. package/dist/src/safety/context-builder.test.js +98 -18
  375. package/dist/src/safety/context-builder.test.js.map +1 -1
  376. package/dist/src/safety/protocol.d.ts +4 -0
  377. package/dist/src/safety/registry.d.ts +2 -1
  378. package/dist/src/safety/registry.js +14 -4
  379. package/dist/src/safety/registry.js.map +1 -1
  380. package/dist/src/safety/registry.test.js +5 -2
  381. package/dist/src/safety/registry.test.js.map +1 -1
  382. package/dist/src/scheduler/confirmation.d.ts +0 -13
  383. package/dist/src/scheduler/confirmation.js +1 -1
  384. package/dist/src/scheduler/confirmation.js.map +1 -1
  385. package/dist/src/scheduler/policy.js +6 -2
  386. package/dist/src/scheduler/policy.js.map +1 -1
  387. package/dist/src/scheduler/policy.test.js +4 -3
  388. package/dist/src/scheduler/policy.test.js.map +1 -1
  389. package/dist/src/scheduler/scheduler.d.ts +3 -1
  390. package/dist/src/scheduler/scheduler.js +148 -28
  391. package/dist/src/scheduler/scheduler.js.map +1 -1
  392. package/dist/src/scheduler/scheduler.test.js +341 -242
  393. package/dist/src/scheduler/scheduler.test.js.map +1 -1
  394. package/dist/src/scheduler/scheduler_parallel.test.d.ts +6 -0
  395. package/dist/src/scheduler/scheduler_parallel.test.js +309 -0
  396. package/dist/src/scheduler/scheduler_parallel.test.js.map +1 -0
  397. package/dist/src/scheduler/state-manager.d.ts +8 -0
  398. package/dist/src/scheduler/state-manager.js +30 -2
  399. package/dist/src/scheduler/state-manager.js.map +1 -1
  400. package/dist/src/scheduler/state-manager.test.js +61 -0
  401. package/dist/src/scheduler/state-manager.test.js.map +1 -1
  402. package/dist/src/scheduler/tool-executor.js +15 -7
  403. package/dist/src/scheduler/tool-executor.js.map +1 -1
  404. package/dist/src/scheduler/tool-executor.test.js +1 -1
  405. package/dist/src/scheduler/tool-executor.test.js.map +1 -1
  406. package/dist/src/scheduler/types.d.ts +23 -0
  407. package/dist/src/services/FolderTrustDiscoveryService.d.ts +32 -0
  408. package/dist/src/services/FolderTrustDiscoveryService.js +167 -0
  409. package/dist/src/services/FolderTrustDiscoveryService.js.map +1 -0
  410. package/dist/src/services/FolderTrustDiscoveryService.test.d.ts +6 -0
  411. package/dist/src/services/FolderTrustDiscoveryService.test.js +118 -0
  412. package/dist/src/services/FolderTrustDiscoveryService.test.js.map +1 -0
  413. package/dist/src/services/chatCompressionService.d.ts +0 -14
  414. package/dist/src/services/chatCompressionService.js +29 -7
  415. package/dist/src/services/chatCompressionService.js.map +1 -1
  416. package/dist/src/services/chatCompressionService.test.js +3 -1
  417. package/dist/src/services/chatCompressionService.test.js.map +1 -1
  418. package/dist/src/services/chatRecordingService.d.ts +7 -1
  419. package/dist/src/services/chatRecordingService.js +12 -1
  420. package/dist/src/services/chatRecordingService.js.map +1 -1
  421. package/dist/src/services/chatRecordingService.test.js +34 -0
  422. package/dist/src/services/chatRecordingService.test.js.map +1 -1
  423. package/dist/src/services/loopDetectionService.js +1 -2
  424. package/dist/src/services/loopDetectionService.js.map +1 -1
  425. package/dist/src/services/sessionSummaryUtils.js +3 -0
  426. package/dist/src/services/sessionSummaryUtils.js.map +1 -1
  427. package/dist/src/services/shellExecutionService.js +6 -0
  428. package/dist/src/services/shellExecutionService.js.map +1 -1
  429. package/dist/src/skills/skillLoader.js +2 -2
  430. package/dist/src/skills/skillLoader.js.map +1 -1
  431. package/dist/src/telemetry/clearcut-logger/clearcut-logger.d.ts +3 -1
  432. package/dist/src/telemetry/clearcut-logger/clearcut-logger.js +35 -4
  433. package/dist/src/telemetry/clearcut-logger/clearcut-logger.js.map +1 -1
  434. package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.d.ts +0 -1
  435. package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.js +19 -5
  436. package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.js.map +1 -1
  437. package/dist/src/telemetry/clearcut-logger/event-metadata-key.d.ts +14 -1
  438. package/dist/src/telemetry/clearcut-logger/event-metadata-key.js +29 -1
  439. package/dist/src/telemetry/clearcut-logger/event-metadata-key.js.map +1 -1
  440. package/dist/src/telemetry/conseca-logger.d.ts +9 -0
  441. package/dist/src/telemetry/conseca-logger.js +91 -0
  442. package/dist/src/telemetry/conseca-logger.js.map +1 -0
  443. package/dist/src/telemetry/conseca-logger.test.d.ts +6 -0
  444. package/dist/src/telemetry/conseca-logger.test.js +89 -0
  445. package/dist/src/telemetry/conseca-logger.test.js.map +1 -0
  446. package/dist/src/telemetry/gcp-exporters.js +1 -2
  447. package/dist/src/telemetry/gcp-exporters.js.map +1 -1
  448. package/dist/src/telemetry/index.d.ts +2 -1
  449. package/dist/src/telemetry/index.js +2 -1
  450. package/dist/src/telemetry/index.js.map +1 -1
  451. package/dist/src/telemetry/integration.test.circular.js +3 -0
  452. package/dist/src/telemetry/integration.test.circular.js.map +1 -1
  453. package/dist/src/telemetry/loggers.d.ts +1 -2
  454. package/dist/src/telemetry/loggers.js +3 -13
  455. package/dist/src/telemetry/loggers.js.map +1 -1
  456. package/dist/src/telemetry/loggers.test.circular.js +3 -0
  457. package/dist/src/telemetry/loggers.test.circular.js.map +1 -1
  458. package/dist/src/telemetry/loggers.test.js +6 -5
  459. package/dist/src/telemetry/loggers.test.js.map +1 -1
  460. package/dist/src/telemetry/metrics.d.ts +1 -3
  461. package/dist/src/telemetry/metrics.js +3 -2
  462. package/dist/src/telemetry/metrics.js.map +1 -1
  463. package/dist/src/telemetry/metrics.test.js +7 -3
  464. package/dist/src/telemetry/metrics.test.js.map +1 -1
  465. package/dist/src/telemetry/sanitize.test.js +19 -18
  466. package/dist/src/telemetry/sanitize.test.js.map +1 -1
  467. package/dist/src/telemetry/semantic.d.ts +7 -9
  468. package/dist/src/telemetry/semantic.js +8 -8
  469. package/dist/src/telemetry/semantic.js.map +1 -1
  470. package/dist/src/telemetry/types.d.ts +42 -4
  471. package/dist/src/telemetry/types.js +87 -2
  472. package/dist/src/telemetry/types.js.map +1 -1
  473. package/dist/src/telemetry/uiTelemetry.d.ts +1 -2
  474. package/dist/src/telemetry/uiTelemetry.js.map +1 -1
  475. package/dist/src/telemetry/uiTelemetry.test.js +1 -2
  476. package/dist/src/telemetry/uiTelemetry.test.js.map +1 -1
  477. package/dist/src/tools/ask-user.test.js +1 -19
  478. package/dist/src/tools/ask-user.test.js.map +1 -1
  479. package/dist/src/tools/confirmation-policy.test.js +14 -17
  480. package/dist/src/tools/confirmation-policy.test.js.map +1 -1
  481. package/dist/src/tools/definitions/dynamic-declaration-helpers.js +1 -1
  482. package/dist/src/tools/definitions/dynamic-declaration-helpers.js.map +1 -1
  483. package/dist/src/tools/definitions/model-family-sets/default-legacy.js +14 -16
  484. package/dist/src/tools/definitions/model-family-sets/default-legacy.js.map +1 -1
  485. package/dist/src/tools/definitions/model-family-sets/gemini-3.js +24 -59
  486. package/dist/src/tools/definitions/model-family-sets/gemini-3.js.map +1 -1
  487. package/dist/src/tools/diff-utils.d.ts +9 -0
  488. package/dist/src/tools/diff-utils.js +66 -0
  489. package/dist/src/tools/diff-utils.js.map +1 -0
  490. package/dist/src/tools/diff-utils.test.d.ts +6 -0
  491. package/dist/src/tools/diff-utils.test.js +53 -0
  492. package/dist/src/tools/diff-utils.test.js.map +1 -0
  493. package/dist/src/tools/edit.d.ts +9 -4
  494. package/dist/src/tools/edit.js +203 -34
  495. package/dist/src/tools/edit.js.map +1 -1
  496. package/dist/src/tools/edit.test.js +225 -10
  497. package/dist/src/tools/edit.test.js.map +1 -1
  498. package/dist/src/tools/enter-plan-mode.js +1 -1
  499. package/dist/src/tools/enter-plan-mode.js.map +1 -1
  500. package/dist/src/tools/enter-plan-mode.test.js +1 -1
  501. package/dist/src/tools/enter-plan-mode.test.js.map +1 -1
  502. package/dist/src/tools/exit-plan-mode.js +10 -24
  503. package/dist/src/tools/exit-plan-mode.js.map +1 -1
  504. package/dist/src/tools/exit-plan-mode.test.js +1 -1
  505. package/dist/src/tools/exit-plan-mode.test.js.map +1 -1
  506. package/dist/src/tools/grep-utils.d.ts +49 -0
  507. package/dist/src/tools/grep-utils.js +139 -0
  508. package/dist/src/tools/grep-utils.js.map +1 -0
  509. package/dist/src/tools/grep.js +4 -44
  510. package/dist/src/tools/grep.js.map +1 -1
  511. package/dist/src/tools/grep.test.js +21 -2
  512. package/dist/src/tools/grep.test.js.map +1 -1
  513. package/dist/src/tools/ls.js +6 -1
  514. package/dist/src/tools/ls.js.map +1 -1
  515. package/dist/src/tools/ls.test.js +2 -2
  516. package/dist/src/tools/ls.test.js.map +1 -1
  517. package/dist/src/tools/mcp-client-manager.js +16 -18
  518. package/dist/src/tools/mcp-client-manager.js.map +1 -1
  519. package/dist/src/tools/mcp-client-manager.test.js +51 -0
  520. package/dist/src/tools/mcp-client-manager.test.js.map +1 -1
  521. package/dist/src/tools/mcp-client.d.ts +22 -1
  522. package/dist/src/tools/mcp-client.js +95 -36
  523. package/dist/src/tools/mcp-client.js.map +1 -1
  524. package/dist/src/tools/mcp-client.test.js +148 -20
  525. package/dist/src/tools/mcp-client.test.js.map +1 -1
  526. package/dist/src/tools/mcp-tool.d.ts +15 -5
  527. package/dist/src/tools/mcp-tool.js +36 -8
  528. package/dist/src/tools/mcp-tool.js.map +1 -1
  529. package/dist/src/tools/memoryTool.js +1 -1
  530. package/dist/src/tools/memoryTool.js.map +1 -1
  531. package/dist/src/tools/memoryTool.test.js +5 -0
  532. package/dist/src/tools/memoryTool.test.js.map +1 -1
  533. package/dist/src/tools/omissionPlaceholderDetector.d.ts +15 -0
  534. package/dist/src/tools/omissionPlaceholderDetector.js +90 -0
  535. package/dist/src/tools/omissionPlaceholderDetector.js.map +1 -0
  536. package/dist/src/tools/omissionPlaceholderDetector.test.d.ts +6 -0
  537. package/dist/src/tools/omissionPlaceholderDetector.test.js +49 -0
  538. package/dist/src/tools/omissionPlaceholderDetector.test.js.map +1 -0
  539. package/dist/src/tools/read-file.d.ts +4 -4
  540. package/dist/src/tools/read-file.js +17 -10
  541. package/dist/src/tools/read-file.js.map +1 -1
  542. package/dist/src/tools/read-file.test.js +20 -10
  543. package/dist/src/tools/read-file.test.js.map +1 -1
  544. package/dist/src/tools/ripGrep.js +49 -46
  545. package/dist/src/tools/ripGrep.js.map +1 -1
  546. package/dist/src/tools/ripGrep.test.js +52 -37
  547. package/dist/src/tools/ripGrep.test.js.map +1 -1
  548. package/dist/src/tools/shell.d.ts +2 -2
  549. package/dist/src/tools/shell.js +2 -2
  550. package/dist/src/tools/shell.js.map +1 -1
  551. package/dist/src/tools/shell.test.js +1 -2
  552. package/dist/src/tools/shell.test.js.map +1 -1
  553. package/dist/src/tools/tool-names.d.ts +0 -6
  554. package/dist/src/tools/tool-names.js +0 -15
  555. package/dist/src/tools/tool-names.js.map +1 -1
  556. package/dist/src/tools/tool-registry.d.ts +1 -0
  557. package/dist/src/tools/tool-registry.js +33 -6
  558. package/dist/src/tools/tool-registry.js.map +1 -1
  559. package/dist/src/tools/tool-registry.test.js +47 -0
  560. package/dist/src/tools/tool-registry.test.js.map +1 -1
  561. package/dist/src/tools/tools.d.ts +21 -1
  562. package/dist/src/tools/tools.js +19 -3
  563. package/dist/src/tools/tools.js.map +1 -1
  564. package/dist/src/tools/tools.test.js +24 -0
  565. package/dist/src/tools/tools.test.js.map +1 -1
  566. package/dist/src/tools/web-fetch.d.ts +9 -1
  567. package/dist/src/tools/web-fetch.js +273 -34
  568. package/dist/src/tools/web-fetch.js.map +1 -1
  569. package/dist/src/tools/web-fetch.test.js +303 -30
  570. package/dist/src/tools/web-fetch.test.js.map +1 -1
  571. package/dist/src/tools/write-file.js +14 -10
  572. package/dist/src/tools/write-file.js.map +1 -1
  573. package/dist/src/tools/write-file.test.js +75 -0
  574. package/dist/src/tools/write-file.test.js.map +1 -1
  575. package/dist/src/tools/write-todos.d.ts +2 -2
  576. package/dist/src/tools/write-todos.js +1 -1
  577. package/dist/src/tools/write-todos.js.map +1 -1
  578. package/dist/src/tools/xcode-mcp-fix-transport.js +4 -1
  579. package/dist/src/tools/xcode-mcp-fix-transport.js.map +1 -1
  580. package/dist/src/utils/approvalModeUtils.d.ts +14 -0
  581. package/dist/src/utils/approvalModeUtils.js +35 -0
  582. package/dist/src/utils/approvalModeUtils.js.map +1 -0
  583. package/dist/src/utils/approvalModeUtils.test.d.ts +6 -0
  584. package/dist/src/utils/approvalModeUtils.test.js +36 -0
  585. package/dist/src/utils/approvalModeUtils.test.js.map +1 -0
  586. package/dist/src/utils/authConsent.d.ts +1 -1
  587. package/dist/src/utils/authConsent.js +10 -8
  588. package/dist/src/utils/authConsent.js.map +1 -1
  589. package/dist/src/utils/authConsent.test.js +89 -44
  590. package/dist/src/utils/authConsent.test.js.map +1 -1
  591. package/dist/src/utils/compatibility.d.ts +41 -0
  592. package/dist/src/utils/compatibility.js +112 -0
  593. package/dist/src/utils/compatibility.js.map +1 -0
  594. package/dist/src/utils/compatibility.test.d.ts +6 -0
  595. package/dist/src/utils/compatibility.test.js +233 -0
  596. package/dist/src/utils/compatibility.test.js.map +1 -0
  597. package/dist/src/utils/editCorrector.js +22 -29
  598. package/dist/src/utils/editCorrector.js.map +1 -1
  599. package/dist/src/utils/editCorrector.test.js.map +1 -1
  600. package/dist/src/utils/envExpansion.d.ts +18 -0
  601. package/dist/src/utils/envExpansion.js +46 -0
  602. package/dist/src/utils/envExpansion.js.map +1 -0
  603. package/dist/src/utils/envExpansion.test.d.ts +6 -0
  604. package/dist/src/utils/envExpansion.test.js +110 -0
  605. package/dist/src/utils/envExpansion.test.js.map +1 -0
  606. package/dist/src/utils/errors.d.ts +1 -0
  607. package/dist/src/utils/errors.js +55 -10
  608. package/dist/src/utils/errors.js.map +1 -1
  609. package/dist/src/utils/errors.test.js +27 -1
  610. package/dist/src/utils/errors.test.js.map +1 -1
  611. package/dist/src/utils/events.d.ts +17 -0
  612. package/dist/src/utils/events.js +12 -0
  613. package/dist/src/utils/events.js.map +1 -1
  614. package/dist/src/utils/events.test.d.ts +1 -1
  615. package/dist/src/utils/events.test.js +50 -3
  616. package/dist/src/utils/events.test.js.map +1 -1
  617. package/dist/src/utils/fastAckHelper.js +2 -1
  618. package/dist/src/utils/fastAckHelper.js.map +1 -1
  619. package/dist/src/utils/fetch.d.ts +1 -1
  620. package/dist/src/utils/fetch.js +15 -2
  621. package/dist/src/utils/fetch.js.map +1 -1
  622. package/dist/src/utils/fileDiffUtils.d.ts +2 -2
  623. package/dist/src/utils/fileDiffUtils.js +1 -2
  624. package/dist/src/utils/fileDiffUtils.js.map +1 -1
  625. package/dist/src/utils/fileUtils.d.ts +5 -3
  626. package/dist/src/utils/fileUtils.js +25 -16
  627. package/dist/src/utils/fileUtils.js.map +1 -1
  628. package/dist/src/utils/fileUtils.test.js +14 -13
  629. package/dist/src/utils/fileUtils.test.js.map +1 -1
  630. package/dist/src/utils/filesearch/fileSearch.js +4 -1
  631. package/dist/src/utils/filesearch/fileSearch.js.map +1 -1
  632. package/dist/src/utils/getFolderStructure.test.js +4 -5
  633. package/dist/src/utils/getFolderStructure.test.js.map +1 -1
  634. package/dist/src/utils/getPty.js +4 -0
  635. package/dist/src/utils/getPty.js.map +1 -1
  636. package/dist/src/utils/googleErrors.js +29 -5
  637. package/dist/src/utils/googleErrors.js.map +1 -1
  638. package/dist/src/utils/googleQuotaErrors.js +10 -0
  639. package/dist/src/utils/googleQuotaErrors.js.map +1 -1
  640. package/dist/src/utils/googleQuotaErrors.test.js +16 -1
  641. package/dist/src/utils/googleQuotaErrors.test.js.map +1 -1
  642. package/dist/src/utils/memoryDiscovery.js +2 -0
  643. package/dist/src/utils/memoryDiscovery.js.map +1 -1
  644. package/dist/src/utils/memoryDiscovery.test.js +1 -2
  645. package/dist/src/utils/memoryDiscovery.test.js.map +1 -1
  646. package/dist/src/utils/retry.d.ts +1 -1
  647. package/dist/src/utils/retry.js +9 -4
  648. package/dist/src/utils/retry.js.map +1 -1
  649. package/dist/src/utils/retry.test.js +15 -12
  650. package/dist/src/utils/retry.test.js.map +1 -1
  651. package/dist/src/utils/safeJsonStringify.js +3 -0
  652. package/dist/src/utils/safeJsonStringify.js.map +1 -1
  653. package/dist/src/utils/schemaValidator.js +5 -3
  654. package/dist/src/utils/schemaValidator.js.map +1 -1
  655. package/dist/src/utils/session.d.ts +1 -0
  656. package/dist/src/utils/session.js +3 -0
  657. package/dist/src/utils/session.js.map +1 -1
  658. package/dist/src/utils/sessionUtils.d.ts +14 -0
  659. package/dist/src/utils/sessionUtils.js +113 -0
  660. package/dist/src/utils/sessionUtils.js.map +1 -0
  661. package/dist/src/utils/sessionUtils.test.d.ts +1 -0
  662. package/dist/src/utils/sessionUtils.test.js +137 -0
  663. package/dist/src/utils/sessionUtils.test.js.map +1 -0
  664. package/dist/src/utils/shell-utils.js +1 -0
  665. package/dist/src/utils/shell-utils.js.map +1 -1
  666. package/dist/src/utils/stdio.js +6 -0
  667. package/dist/src/utils/stdio.js.map +1 -1
  668. package/dist/src/utils/textUtils.d.ts +9 -0
  669. package/dist/src/utils/textUtils.js +15 -0
  670. package/dist/src/utils/textUtils.js.map +1 -1
  671. package/dist/src/utils/textUtils.test.js +42 -1
  672. package/dist/src/utils/textUtils.test.js.map +1 -1
  673. package/dist/src/utils/toolCallContext.d.ts +0 -5
  674. package/dist/src/utils/toolCallContext.js +1 -1
  675. package/dist/src/utils/toolCallContext.js.map +1 -1
  676. package/dist/src/utils/userAccountManager.js +3 -0
  677. package/dist/src/utils/userAccountManager.js.map +1 -1
  678. package/dist/tsconfig.tsbuildinfo +1 -1
  679. package/package.json +6 -3
  680. package/dist/docs/architecture.md +0 -80
  681. package/dist/docs/cli/index.md +0 -123
  682. package/dist/docs/core/concepts.md +0 -137
  683. package/dist/docs/get-started/configuration-v1.md +0 -882
  684. package/dist/google-gemini-cli-core-0.30.0-preview.5.tgz +0 -0
  685. /package/dist/docs/{core → reference}/memport.md +0 -0
  686. /package/dist/docs/{core → reference}/tools-api.md +0 -0
  687. /package/dist/docs/{cli → resources}/uninstall.md +0 -0
@@ -5,6 +5,7 @@
5
5
  */
6
6
  import { describe, it, expect, vi, beforeEach, afterEach } from 'vitest';
7
7
  import { Config, DEFAULT_FILE_FILTERING_OPTIONS } from './config.js';
8
+ import { DEFAULT_MAX_ATTEMPTS } from '../utils/retry.js';
8
9
  import { ExperimentFlags } from '../code_assist/experiments/flagNames.js';
9
10
  import { debugLogger } from '../utils/debugLogger.js';
10
11
  import { ApprovalMode } from '../policy/types.js';
@@ -13,7 +14,7 @@ import { FileDiscoveryService } from '../services/fileDiscoveryService.js';
13
14
  import * as path from 'node:path';
14
15
  import * as fs from 'node:fs';
15
16
  import { setGeminiMdFilename as mockSetGeminiMdFilename } from '../tools/memoryTool.js';
16
- import { DEFAULT_TELEMETRY_TARGET, DEFAULT_OTLP_ENDPOINT, } from '../telemetry/index.js';
17
+ import { DEFAULT_TELEMETRY_TARGET, DEFAULT_OTLP_ENDPOINT, uiTelemetryService, } from '../telemetry/index.js';
17
18
  import { AuthType, createContentGenerator, createContentGeneratorConfig, } from '../core/contentGenerator.js';
18
19
  import { GeminiClient } from '../core/client.js';
19
20
  import { GitService } from '../services/gitService.js';
@@ -21,12 +22,12 @@ import { ShellTool } from '../tools/shell.js';
21
22
  import { ReadFileTool } from '../tools/read-file.js';
22
23
  import { GrepTool } from '../tools/grep.js';
23
24
  import { RipGrepTool, canUseRipgrep } from '../tools/ripGrep.js';
24
- import { logRipgrepFallback } from '../telemetry/loggers.js';
25
+ import { logRipgrepFallback, logApprovalModeDuration, } from '../telemetry/loggers.js';
25
26
  import { RipgrepFallbackEvent } from '../telemetry/types.js';
26
27
  import { ToolRegistry } from '../tools/tool-registry.js';
27
28
  import { ACTIVATE_SKILL_TOOL_NAME } from '../tools/tool-names.js';
28
29
  import { DEFAULT_MODEL_CONFIGS } from './defaultModelConfigs.js';
29
- import { DEFAULT_GEMINI_MODEL } from './models.js';
30
+ import { DEFAULT_GEMINI_MODEL, PREVIEW_GEMINI_3_1_MODEL, DEFAULT_GEMINI_MODEL_AUTO, } from './models.js';
30
31
  import { Storage } from './storage.js';
31
32
  vi.mock('fs', async (importOriginal) => {
32
33
  const actual = await importOriginal();
@@ -107,6 +108,7 @@ vi.mock('../telemetry/loggers.js', async (importOriginal) => {
107
108
  return {
108
109
  ...actual,
109
110
  logRipgrepFallback: vi.fn(),
111
+ logApprovalModeDuration: vi.fn(),
110
112
  };
111
113
  });
112
114
  vi.mock('../services/gitService.js', () => {
@@ -166,7 +168,6 @@ vi.mock('../services/contextManager.js', () => ({
166
168
  }));
167
169
  import { BaseLlmClient } from '../core/baseLlmClient.js';
168
170
  import { tokenLimit } from '../core/tokenLimits.js';
169
- import { uiTelemetryService } from '../telemetry/index.js';
170
171
  import { getCodeAssistServer } from '../code_assist/codeAssist.js';
171
172
  import { getExperiments } from '../code_assist/experiments/experiments.js';
172
173
  import { ContextManager } from '../services/contextManager.js';
@@ -205,6 +206,26 @@ describe('Server Config (config.ts)', () => {
205
206
  model: MODEL,
206
207
  usageStatisticsEnabled: false,
207
208
  };
209
+ describe('maxAttempts', () => {
210
+ it('should default to DEFAULT_MAX_ATTEMPTS', () => {
211
+ const config = new Config(baseParams);
212
+ expect(config.getMaxAttempts()).toBe(DEFAULT_MAX_ATTEMPTS);
213
+ });
214
+ it('should use provided maxAttempts if <= DEFAULT_MAX_ATTEMPTS', () => {
215
+ const config = new Config({
216
+ ...baseParams,
217
+ maxAttempts: 5,
218
+ });
219
+ expect(config.getMaxAttempts()).toBe(5);
220
+ });
221
+ it('should cap maxAttempts at DEFAULT_MAX_ATTEMPTS', () => {
222
+ const config = new Config({
223
+ ...baseParams,
224
+ maxAttempts: 20,
225
+ });
226
+ expect(config.getMaxAttempts()).toBe(DEFAULT_MAX_ATTEMPTS);
227
+ });
228
+ });
208
229
  beforeEach(() => {
209
230
  // Reset mocks if necessary
210
231
  vi.clearAllMocks();
@@ -577,6 +598,36 @@ describe('Server Config (config.ts)', () => {
577
598
  expect(config.getUsageStatisticsEnabled()).toBe(enabled);
578
599
  });
579
600
  });
601
+ describe('Plan Settings', () => {
602
+ const testCases = [
603
+ {
604
+ name: 'should pass custom plan directory to storage',
605
+ planSettings: { directory: 'custom-plans' },
606
+ expected: 'custom-plans',
607
+ },
608
+ {
609
+ name: 'should call setCustomPlansDir with undefined if directory is not provided',
610
+ planSettings: {},
611
+ expected: undefined,
612
+ },
613
+ {
614
+ name: 'should call setCustomPlansDir with undefined if planSettings is not provided',
615
+ planSettings: undefined,
616
+ expected: undefined,
617
+ },
618
+ ];
619
+ testCases.forEach(({ name, planSettings, expected }) => {
620
+ it(`${name}`, () => {
621
+ const setCustomPlansDirSpy = vi.spyOn(Storage.prototype, 'setCustomPlansDir');
622
+ new Config({
623
+ ...baseParams,
624
+ planSettings,
625
+ });
626
+ expect(setCustomPlansDirSpy).toHaveBeenCalledWith(expected);
627
+ setCustomPlansDirSpy.mockRestore();
628
+ });
629
+ });
630
+ });
580
631
  describe('Telemetry Settings', () => {
581
632
  it('should return default telemetry target if not provided', () => {
582
633
  const params = {
@@ -970,6 +1021,66 @@ describe('Server Config (config.ts)', () => {
970
1021
  expect(mockCoreEvents.emitFeedback).not.toHaveBeenCalled();
971
1022
  });
972
1023
  });
1024
+ describe('BrowserAgentConfig', () => {
1025
+ it('should return default browser agent config when not provided', () => {
1026
+ const config = new Config(baseParams);
1027
+ const browserConfig = config.getBrowserAgentConfig();
1028
+ expect(browserConfig.enabled).toBe(false);
1029
+ expect(browserConfig.model).toBeUndefined();
1030
+ expect(browserConfig.customConfig.sessionMode).toBe('persistent');
1031
+ expect(browserConfig.customConfig.headless).toBe(false);
1032
+ expect(browserConfig.customConfig.profilePath).toBeUndefined();
1033
+ expect(browserConfig.customConfig.visualModel).toBeUndefined();
1034
+ });
1035
+ it('should return custom browser agent config from agents.overrides', () => {
1036
+ const params = {
1037
+ ...baseParams,
1038
+ agents: {
1039
+ overrides: {
1040
+ browser_agent: {
1041
+ enabled: true,
1042
+ modelConfig: { model: 'custom-model' },
1043
+ },
1044
+ },
1045
+ browser: {
1046
+ sessionMode: 'existing',
1047
+ headless: true,
1048
+ profilePath: '/path/to/profile',
1049
+ visualModel: 'custom-visual-model',
1050
+ },
1051
+ },
1052
+ };
1053
+ const config = new Config(params);
1054
+ const browserConfig = config.getBrowserAgentConfig();
1055
+ expect(browserConfig.enabled).toBe(true);
1056
+ expect(browserConfig.model).toBe('custom-model');
1057
+ expect(browserConfig.customConfig.sessionMode).toBe('existing');
1058
+ expect(browserConfig.customConfig.headless).toBe(true);
1059
+ expect(browserConfig.customConfig.profilePath).toBe('/path/to/profile');
1060
+ expect(browserConfig.customConfig.visualModel).toBe('custom-visual-model');
1061
+ });
1062
+ it('should apply defaults for partial custom config', () => {
1063
+ const params = {
1064
+ ...baseParams,
1065
+ agents: {
1066
+ overrides: {
1067
+ browser_agent: {
1068
+ enabled: true,
1069
+ },
1070
+ },
1071
+ browser: {
1072
+ headless: true,
1073
+ },
1074
+ },
1075
+ };
1076
+ const config = new Config(params);
1077
+ const browserConfig = config.getBrowserAgentConfig();
1078
+ expect(browserConfig.enabled).toBe(true);
1079
+ expect(browserConfig.customConfig.headless).toBe(true);
1080
+ // Defaults for unspecified fields
1081
+ expect(browserConfig.customConfig.sessionMode).toBe('persistent');
1082
+ });
1083
+ });
973
1084
  });
974
1085
  describe('setApprovalMode with folder trust', () => {
975
1086
  const baseParams = {
@@ -1035,13 +1146,80 @@ describe('setApprovalMode with folder trust', () => {
1035
1146
  config.setApprovalMode(ApprovalMode.DEFAULT);
1036
1147
  expect(updateSpy).toHaveBeenCalled();
1037
1148
  });
1038
- it('should not update system instruction when switching between non-Plan modes', () => {
1149
+ it('should update system instruction when entering YOLO mode', () => {
1150
+ const config = new Config(baseParams);
1151
+ vi.spyOn(config, 'isTrustedFolder').mockReturnValue(true);
1152
+ vi.spyOn(config, 'getToolRegistry').mockReturnValue({
1153
+ getTool: vi.fn().mockReturnValue(undefined),
1154
+ unregisterTool: vi.fn(),
1155
+ registerTool: vi.fn(),
1156
+ });
1157
+ const updateSpy = vi.spyOn(config, 'updateSystemInstructionIfInitialized');
1158
+ config.setApprovalMode(ApprovalMode.YOLO);
1159
+ expect(updateSpy).toHaveBeenCalled();
1160
+ });
1161
+ it('should not update system instruction when switching between non-Plan/non-YOLO modes', () => {
1039
1162
  const config = new Config(baseParams);
1040
1163
  vi.spyOn(config, 'isTrustedFolder').mockReturnValue(true);
1041
1164
  const updateSpy = vi.spyOn(config, 'updateSystemInstructionIfInitialized');
1042
1165
  config.setApprovalMode(ApprovalMode.AUTO_EDIT);
1043
1166
  expect(updateSpy).not.toHaveBeenCalled();
1044
1167
  });
1168
+ describe('approval mode duration logging', () => {
1169
+ beforeEach(() => {
1170
+ vi.mocked(logApprovalModeDuration).mockClear();
1171
+ });
1172
+ it('should initialize lastModeSwitchTime with performance.now() and log positive duration', () => {
1173
+ const startTime = 1000;
1174
+ const endTime = 5000;
1175
+ const performanceSpy = vi.spyOn(performance, 'now');
1176
+ performanceSpy.mockReturnValueOnce(startTime);
1177
+ const config = new Config(baseParams);
1178
+ vi.spyOn(config, 'isTrustedFolder').mockReturnValue(true);
1179
+ performanceSpy.mockReturnValueOnce(endTime);
1180
+ config.setApprovalMode(ApprovalMode.PLAN);
1181
+ expect(logApprovalModeDuration).toHaveBeenCalledWith(config, expect.objectContaining({
1182
+ mode: ApprovalMode.DEFAULT,
1183
+ duration_ms: endTime - startTime,
1184
+ }));
1185
+ performanceSpy.mockRestore();
1186
+ });
1187
+ it('should skip logging if duration is zero or negative', () => {
1188
+ const startTime = 5000;
1189
+ const endTime = 4000;
1190
+ const performanceSpy = vi.spyOn(performance, 'now');
1191
+ performanceSpy.mockReturnValueOnce(startTime);
1192
+ const config = new Config(baseParams);
1193
+ vi.spyOn(config, 'isTrustedFolder').mockReturnValue(true);
1194
+ performanceSpy.mockReturnValueOnce(endTime);
1195
+ config.setApprovalMode(ApprovalMode.PLAN);
1196
+ expect(logApprovalModeDuration).not.toHaveBeenCalled();
1197
+ performanceSpy.mockRestore();
1198
+ });
1199
+ it('should update lastModeSwitchTime after logging to prevent double counting', () => {
1200
+ const time1 = 1000;
1201
+ const time2 = 3000;
1202
+ const time3 = 6000;
1203
+ const performanceSpy = vi.spyOn(performance, 'now');
1204
+ performanceSpy.mockReturnValueOnce(time1);
1205
+ const config = new Config(baseParams);
1206
+ vi.spyOn(config, 'isTrustedFolder').mockReturnValue(true);
1207
+ performanceSpy.mockReturnValueOnce(time2);
1208
+ config.setApprovalMode(ApprovalMode.PLAN);
1209
+ expect(logApprovalModeDuration).toHaveBeenCalledWith(config, expect.objectContaining({
1210
+ mode: ApprovalMode.DEFAULT,
1211
+ duration_ms: time2 - time1,
1212
+ }));
1213
+ vi.mocked(logApprovalModeDuration).mockClear();
1214
+ performanceSpy.mockReturnValueOnce(time3);
1215
+ config.setApprovalMode(ApprovalMode.YOLO);
1216
+ expect(logApprovalModeDuration).toHaveBeenCalledWith(config, expect.objectContaining({
1217
+ mode: ApprovalMode.PLAN,
1218
+ duration_ms: time3 - time2,
1219
+ }));
1220
+ performanceSpy.mockRestore();
1221
+ });
1222
+ });
1045
1223
  describe('registerCoreTools', () => {
1046
1224
  beforeEach(() => {
1047
1225
  vi.clearAllMocks();
@@ -1665,14 +1843,15 @@ describe('Config Quota & Preview Model Access', () => {
1665
1843
  vi.mocked(getCodeAssistServer).mockReturnValue(undefined);
1666
1844
  const result = await config.refreshUserQuota();
1667
1845
  expect(result).toBeUndefined();
1668
- expect(config.getHasAccessToPreviewModel()).toBe(false);
1846
+ // Never set => stays null (unknown); getter returns true so UI shows preview
1847
+ expect(config.getHasAccessToPreviewModel()).toBe(true);
1669
1848
  });
1670
1849
  it('should return undefined if retrieveUserQuota fails', async () => {
1671
1850
  mockCodeAssistServer.retrieveUserQuota.mockRejectedValue(new Error('Network error'));
1672
1851
  const result = await config.refreshUserQuota();
1673
1852
  expect(result).toBeUndefined();
1674
- // Should remain default (false)
1675
- expect(config.getHasAccessToPreviewModel()).toBe(false);
1853
+ // Never set => stays null (unknown); getter returns true so UI shows preview
1854
+ expect(config.getHasAccessToPreviewModel()).toBe(true);
1676
1855
  });
1677
1856
  });
1678
1857
  describe('refreshUserQuotaIfStale', () => {
@@ -1768,6 +1947,26 @@ describe('Config Quota & Preview Model Access', () => {
1768
1947
  expect(config.isPlanEnabled()).toBe(false);
1769
1948
  });
1770
1949
  });
1950
+ describe('getPlanModeRoutingEnabled', () => {
1951
+ it('should default to true when not provided', async () => {
1952
+ const config = new Config(baseParams);
1953
+ expect(await config.getPlanModeRoutingEnabled()).toBe(true);
1954
+ });
1955
+ it('should return true when explicitly enabled in planSettings', async () => {
1956
+ const config = new Config({
1957
+ ...baseParams,
1958
+ planSettings: { modelRouting: true },
1959
+ });
1960
+ expect(await config.getPlanModeRoutingEnabled()).toBe(true);
1961
+ });
1962
+ it('should return false when explicitly disabled in planSettings', async () => {
1963
+ const config = new Config({
1964
+ ...baseParams,
1965
+ planSettings: { modelRouting: false },
1966
+ });
1967
+ expect(await config.getPlanModeRoutingEnabled()).toBe(false);
1968
+ });
1969
+ });
1771
1970
  });
1772
1971
  describe('Config JIT Initialization', () => {
1773
1972
  let config;
@@ -1939,7 +2138,7 @@ describe('Plans Directory Initialization', () => {
1939
2138
  plan: true,
1940
2139
  });
1941
2140
  await config.initialize();
1942
- const plansDir = config.storage.getProjectTempPlansDir();
2141
+ const plansDir = config.storage.getPlansDir();
1943
2142
  expect(fs.promises.mkdir).toHaveBeenCalledWith(plansDir, {
1944
2143
  recursive: true,
1945
2144
  });
@@ -1952,7 +2151,7 @@ describe('Plans Directory Initialization', () => {
1952
2151
  plan: false,
1953
2152
  });
1954
2153
  await config.initialize();
1955
- const plansDir = config.storage.getProjectTempPlansDir();
2154
+ const plansDir = config.storage.getPlansDir();
1956
2155
  expect(fs.promises.mkdir).not.toHaveBeenCalledWith(plansDir, {
1957
2156
  recursive: true,
1958
2157
  });
@@ -2028,6 +2227,21 @@ describe('syncPlanModeTools', () => {
2028
2227
  const registeredTool = registerSpy.mock.calls.find((call) => call[0] instanceof EnterPlanModeTool);
2029
2228
  expect(registeredTool).toBeUndefined();
2030
2229
  });
2230
+ it('should NOT register EnterPlanModeTool when in YOLO mode, even if plan is enabled', async () => {
2231
+ const config = new Config({
2232
+ ...baseParams,
2233
+ approvalMode: ApprovalMode.YOLO,
2234
+ plan: true,
2235
+ });
2236
+ const registry = new ToolRegistry(config, config.getMessageBus());
2237
+ vi.spyOn(config, 'getToolRegistry').mockReturnValue(registry);
2238
+ const registerSpy = vi.spyOn(registry, 'registerTool');
2239
+ vi.spyOn(registry, 'getTool').mockReturnValue(undefined);
2240
+ config.syncPlanModeTools();
2241
+ const { EnterPlanModeTool } = await import('../tools/enter-plan-mode.js');
2242
+ const registeredTool = registerSpy.mock.calls.find((call) => call[0] instanceof EnterPlanModeTool);
2243
+ expect(registeredTool).toBeUndefined();
2244
+ });
2031
2245
  it('should call geminiClient.setTools if initialized', async () => {
2032
2246
  const config = new Config(baseParams);
2033
2247
  const registry = new ToolRegistry(config, config.getMessageBus());
@@ -2041,4 +2255,65 @@ describe('syncPlanModeTools', () => {
2041
2255
  expect(setToolsSpy).toHaveBeenCalled();
2042
2256
  });
2043
2257
  });
2258
+ describe('Model Persistence Bug Fix (#19864)', () => {
2259
+ const baseParams = {
2260
+ sessionId: 'test-session',
2261
+ cwd: '/tmp',
2262
+ targetDir: '/path/to/target',
2263
+ debugMode: false,
2264
+ model: PREVIEW_GEMINI_3_1_MODEL, // User saved preview model
2265
+ };
2266
+ it('should NOT reset preview model for CodeAssist auth when refreshUserQuota is not called (no projectId)', async () => {
2267
+ const mockContentConfig = {
2268
+ authType: AuthType.LOGIN_WITH_GOOGLE,
2269
+ };
2270
+ const mockContentGenerator = {
2271
+ generateContent: vi.fn(),
2272
+ };
2273
+ vi.mocked(createContentGeneratorConfig).mockResolvedValue(mockContentConfig);
2274
+ vi.mocked(createContentGenerator).mockResolvedValue(mockContentGenerator);
2275
+ // getCodeAssistServer returns undefined by default, so refreshUserQuota() isn't called;
2276
+ // hasAccessToPreviewModel stays null; reset only when === false, so we don't reset.
2277
+ const config = new Config(baseParams);
2278
+ // Verify initial model is the preview model
2279
+ expect(config.getModel()).toBe(PREVIEW_GEMINI_3_1_MODEL);
2280
+ // Call refreshAuth to simulate restart (CodeAssist auth, no projectId)
2281
+ await config.refreshAuth(AuthType.LOGIN_WITH_GOOGLE);
2282
+ // Verify the model was NOT reset (bug fix)
2283
+ expect(config.getModel()).toBe(PREVIEW_GEMINI_3_1_MODEL);
2284
+ expect(config.getModel()).not.toBe(DEFAULT_GEMINI_MODEL_AUTO);
2285
+ });
2286
+ it('should NOT reset preview model for USE_GEMINI (hasAccessToPreviewModel is set to true)', async () => {
2287
+ const mockContentConfig = {
2288
+ authType: AuthType.USE_GEMINI,
2289
+ };
2290
+ const mockContentGenerator = {
2291
+ generateContent: vi.fn(),
2292
+ };
2293
+ vi.mocked(createContentGeneratorConfig).mockResolvedValue(mockContentConfig);
2294
+ vi.mocked(createContentGenerator).mockResolvedValue(mockContentGenerator);
2295
+ const config = new Config(baseParams);
2296
+ // Verify initial model is the preview model
2297
+ expect(config.getModel()).toBe(PREVIEW_GEMINI_3_1_MODEL);
2298
+ // Call refreshAuth
2299
+ await config.refreshAuth(AuthType.USE_GEMINI);
2300
+ // For USE_GEMINI, hasAccessToPreviewModel should be set to true
2301
+ // So the model should NOT be reset
2302
+ expect(config.getModel()).toBe(PREVIEW_GEMINI_3_1_MODEL);
2303
+ expect(config.getHasAccessToPreviewModel()).toBe(true);
2304
+ });
2305
+ it('should persist model when user selects it with persistMode=true', () => {
2306
+ const onModelChange = vi.fn();
2307
+ const config = new Config({
2308
+ ...baseParams,
2309
+ model: DEFAULT_GEMINI_MODEL_AUTO, // Initial model
2310
+ onModelChange,
2311
+ });
2312
+ // User selects preview model with persist mode enabled
2313
+ config.setModel(PREVIEW_GEMINI_3_1_MODEL, false); // isTemporary = false
2314
+ // Verify onModelChange was called to persist the model
2315
+ expect(onModelChange).toHaveBeenCalledWith(PREVIEW_GEMINI_3_1_MODEL);
2316
+ expect(config.getModel()).toBe(PREVIEW_GEMINI_3_1_MODEL);
2317
+ });
2318
+ });
2044
2319
  //# sourceMappingURL=config.test.js.map