@blackbox_ai/blackbox-cli-core 0.0.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (897) hide show
  1. package/LICENSE +203 -0
  2. package/README.md +420 -0
  3. package/dist/.last_build +0 -0
  4. package/dist/index.d.ts +13 -0
  5. package/dist/index.js +14 -0
  6. package/dist/index.js.map +1 -0
  7. package/dist/src/__mocks__/fs/promises.d.ts +11 -0
  8. package/dist/src/__mocks__/fs/promises.js +17 -0
  9. package/dist/src/__mocks__/fs/promises.js.map +1 -0
  10. package/dist/src/blackbox/blackboxContentGenerator.d.ts +70 -0
  11. package/dist/src/blackbox/blackboxContentGenerator.js +180 -0
  12. package/dist/src/blackbox/blackboxContentGenerator.js.map +1 -0
  13. package/dist/src/blackbox/blackboxContentGenerator.test.d.ts +6 -0
  14. package/dist/src/blackbox/blackboxContentGenerator.test.js +1178 -0
  15. package/dist/src/blackbox/blackboxContentGenerator.test.js.map +1 -0
  16. package/dist/src/blackbox/blackboxOAuth2.d.ts +191 -0
  17. package/dist/src/blackbox/blackboxOAuth2.js +566 -0
  18. package/dist/src/blackbox/blackboxOAuth2.js.map +1 -0
  19. package/dist/src/blackbox/blackboxOAuth2.test.d.ts +6 -0
  20. package/dist/src/blackbox/blackboxOAuth2.test.js +1718 -0
  21. package/dist/src/blackbox/blackboxOAuth2.test.js.map +1 -0
  22. package/dist/src/blackbox/sharedTokenManager.d.ts +196 -0
  23. package/dist/src/blackbox/sharedTokenManager.js +647 -0
  24. package/dist/src/blackbox/sharedTokenManager.js.map +1 -0
  25. package/dist/src/blackbox/sharedTokenManager.test.d.ts +7 -0
  26. package/dist/src/blackbox/sharedTokenManager.test.js +662 -0
  27. package/dist/src/blackbox/sharedTokenManager.test.js.map +1 -0
  28. package/dist/src/code_assist/codeAssist.d.ts +10 -0
  29. package/dist/src/code_assist/codeAssist.js +19 -0
  30. package/dist/src/code_assist/codeAssist.js.map +1 -0
  31. package/dist/src/code_assist/converter.d.ts +72 -0
  32. package/dist/src/code_assist/converter.js +159 -0
  33. package/dist/src/code_assist/converter.js.map +1 -0
  34. package/dist/src/code_assist/converter.test.d.ts +6 -0
  35. package/dist/src/code_assist/converter.test.js +362 -0
  36. package/dist/src/code_assist/converter.test.js.map +1 -0
  37. package/dist/src/code_assist/oauth2.d.ts +22 -0
  38. package/dist/src/code_assist/oauth2.js +368 -0
  39. package/dist/src/code_assist/oauth2.js.map +1 -0
  40. package/dist/src/code_assist/oauth2.test.d.ts +6 -0
  41. package/dist/src/code_assist/oauth2.test.js +436 -0
  42. package/dist/src/code_assist/oauth2.test.js.map +1 -0
  43. package/dist/src/code_assist/server.d.ts +37 -0
  44. package/dist/src/code_assist/server.js +125 -0
  45. package/dist/src/code_assist/server.js.map +1 -0
  46. package/dist/src/code_assist/server.test.d.ts +6 -0
  47. package/dist/src/code_assist/server.test.js +134 -0
  48. package/dist/src/code_assist/server.test.js.map +1 -0
  49. package/dist/src/code_assist/setup.d.ts +20 -0
  50. package/dist/src/code_assist/setup.js +101 -0
  51. package/dist/src/code_assist/setup.js.map +1 -0
  52. package/dist/src/code_assist/setup.test.d.ts +6 -0
  53. package/dist/src/code_assist/setup.test.js +171 -0
  54. package/dist/src/code_assist/setup.test.js.map +1 -0
  55. package/dist/src/code_assist/types.d.ts +148 -0
  56. package/dist/src/code_assist/types.js +46 -0
  57. package/dist/src/code_assist/types.js.map +1 -0
  58. package/dist/src/config/blackboxModels.d.ts +28 -0
  59. package/dist/src/config/blackboxModels.js +148 -0
  60. package/dist/src/config/blackboxModels.js.map +1 -0
  61. package/dist/src/config/config.d.ts +381 -0
  62. package/dist/src/config/config.js +753 -0
  63. package/dist/src/config/config.js.map +1 -0
  64. package/dist/src/config/config.test.d.ts +6 -0
  65. package/dist/src/config/config.test.js +674 -0
  66. package/dist/src/config/config.test.js.map +1 -0
  67. package/dist/src/config/flashFallback.test.d.ts +6 -0
  68. package/dist/src/config/flashFallback.test.js +87 -0
  69. package/dist/src/config/flashFallback.test.js.map +1 -0
  70. package/dist/src/config/models.d.ts +12 -0
  71. package/dist/src/config/models.js +13 -0
  72. package/dist/src/config/models.js.map +1 -0
  73. package/dist/src/config/storage.d.ts +32 -0
  74. package/dist/src/config/storage.js +90 -0
  75. package/dist/src/config/storage.js.map +1 -0
  76. package/dist/src/config/storage.test.d.ts +6 -0
  77. package/dist/src/config/storage.test.js +43 -0
  78. package/dist/src/config/storage.test.js.map +1 -0
  79. package/dist/src/core/__tests__/openaiTimeoutHandling.test.d.ts +6 -0
  80. package/dist/src/core/__tests__/openaiTimeoutHandling.test.js +292 -0
  81. package/dist/src/core/__tests__/openaiTimeoutHandling.test.js.map +1 -0
  82. package/dist/src/core/__tests__/orphanedToolCallsTest.d.ts +64 -0
  83. package/dist/src/core/__tests__/orphanedToolCallsTest.js +122 -0
  84. package/dist/src/core/__tests__/orphanedToolCallsTest.js.map +1 -0
  85. package/dist/src/core/client.d.ts +75 -0
  86. package/dist/src/core/client.js +826 -0
  87. package/dist/src/core/client.js.map +1 -0
  88. package/dist/src/core/client.test.d.ts +6 -0
  89. package/dist/src/core/client.test.js +2059 -0
  90. package/dist/src/core/client.test.js.map +1 -0
  91. package/dist/src/core/contentGenerator.d.ts +51 -0
  92. package/dist/src/core/contentGenerator.js +149 -0
  93. package/dist/src/core/contentGenerator.js.map +1 -0
  94. package/dist/src/core/contentGenerator.test.d.ts +6 -0
  95. package/dist/src/core/contentGenerator.test.js +133 -0
  96. package/dist/src/core/contentGenerator.test.js.map +1 -0
  97. package/dist/src/core/coreToolScheduler.d.ts +126 -0
  98. package/dist/src/core/coreToolScheduler.js +630 -0
  99. package/dist/src/core/coreToolScheduler.js.map +1 -0
  100. package/dist/src/core/coreToolScheduler.test.d.ts +6 -0
  101. package/dist/src/core/coreToolScheduler.test.js +1228 -0
  102. package/dist/src/core/coreToolScheduler.test.js.map +1 -0
  103. package/dist/src/core/geminiChat.d.ts +139 -0
  104. package/dist/src/core/geminiChat.js +636 -0
  105. package/dist/src/core/geminiChat.js.map +1 -0
  106. package/dist/src/core/geminiChat.test.d.ts +6 -0
  107. package/dist/src/core/geminiChat.test.js +1178 -0
  108. package/dist/src/core/geminiChat.test.js.map +1 -0
  109. package/dist/src/core/geminiRequest.d.ts +13 -0
  110. package/dist/src/core/geminiRequest.js +11 -0
  111. package/dist/src/core/geminiRequest.js.map +1 -0
  112. package/dist/src/core/geminiRequest.test.d.ts +6 -0
  113. package/dist/src/core/geminiRequest.test.js +73 -0
  114. package/dist/src/core/geminiRequest.test.js.map +1 -0
  115. package/dist/src/core/logger.d.ts +68 -0
  116. package/dist/src/core/logger.js +370 -0
  117. package/dist/src/core/logger.js.map +1 -0
  118. package/dist/src/core/logger.test.d.ts +6 -0
  119. package/dist/src/core/logger.test.js +591 -0
  120. package/dist/src/core/logger.test.js.map +1 -0
  121. package/dist/src/core/loggingContentGenerator.d.ts +25 -0
  122. package/dist/src/core/loggingContentGenerator.js +97 -0
  123. package/dist/src/core/loggingContentGenerator.js.map +1 -0
  124. package/dist/src/core/nonInteractiveToolExecutor.d.ts +10 -0
  125. package/dist/src/core/nonInteractiveToolExecutor.js +24 -0
  126. package/dist/src/core/nonInteractiveToolExecutor.js.map +1 -0
  127. package/dist/src/core/nonInteractiveToolExecutor.test.d.ts +6 -0
  128. package/dist/src/core/nonInteractiveToolExecutor.test.js +236 -0
  129. package/dist/src/core/nonInteractiveToolExecutor.test.js.map +1 -0
  130. package/dist/src/core/openaiContentGenerator/constants.d.ts +2 -0
  131. package/dist/src/core/openaiContentGenerator/constants.js +3 -0
  132. package/dist/src/core/openaiContentGenerator/constants.js.map +1 -0
  133. package/dist/src/core/openaiContentGenerator/converter.d.ts +107 -0
  134. package/dist/src/core/openaiContentGenerator/converter.js +802 -0
  135. package/dist/src/core/openaiContentGenerator/converter.js.map +1 -0
  136. package/dist/src/core/openaiContentGenerator/converter.test.d.ts +6 -0
  137. package/dist/src/core/openaiContentGenerator/converter.test.js +47 -0
  138. package/dist/src/core/openaiContentGenerator/converter.test.js.map +1 -0
  139. package/dist/src/core/openaiContentGenerator/errorHandler.d.ts +20 -0
  140. package/dist/src/core/openaiContentGenerator/errorHandler.js +82 -0
  141. package/dist/src/core/openaiContentGenerator/errorHandler.js.map +1 -0
  142. package/dist/src/core/openaiContentGenerator/errorHandler.test.d.ts +6 -0
  143. package/dist/src/core/openaiContentGenerator/errorHandler.test.js +287 -0
  144. package/dist/src/core/openaiContentGenerator/errorHandler.test.js.map +1 -0
  145. package/dist/src/core/openaiContentGenerator/index.d.ts +22 -0
  146. package/dist/src/core/openaiContentGenerator/index.js +41 -0
  147. package/dist/src/core/openaiContentGenerator/index.js.map +1 -0
  148. package/dist/src/core/openaiContentGenerator/openaiContentGenerator.d.ts +21 -0
  149. package/dist/src/core/openaiContentGenerator/openaiContentGenerator.js +105 -0
  150. package/dist/src/core/openaiContentGenerator/openaiContentGenerator.js.map +1 -0
  151. package/dist/src/core/openaiContentGenerator/openaiContentGenerator.test.d.ts +6 -0
  152. package/dist/src/core/openaiContentGenerator/openaiContentGenerator.test.js +230 -0
  153. package/dist/src/core/openaiContentGenerator/openaiContentGenerator.test.js.map +1 -0
  154. package/dist/src/core/openaiContentGenerator/pipeline.d.ts +66 -0
  155. package/dist/src/core/openaiContentGenerator/pipeline.js +256 -0
  156. package/dist/src/core/openaiContentGenerator/pipeline.js.map +1 -0
  157. package/dist/src/core/openaiContentGenerator/pipeline.test.d.ts +6 -0
  158. package/dist/src/core/openaiContentGenerator/pipeline.test.js +977 -0
  159. package/dist/src/core/openaiContentGenerator/pipeline.test.js.map +1 -0
  160. package/dist/src/core/openaiContentGenerator/provider/README.md +61 -0
  161. package/dist/src/core/openaiContentGenerator/provider/dashscope.d.ts +63 -0
  162. package/dist/src/core/openaiContentGenerator/provider/dashscope.js +241 -0
  163. package/dist/src/core/openaiContentGenerator/provider/dashscope.js.map +1 -0
  164. package/dist/src/core/openaiContentGenerator/provider/dashscope.test.d.ts +6 -0
  165. package/dist/src/core/openaiContentGenerator/provider/dashscope.test.js +707 -0
  166. package/dist/src/core/openaiContentGenerator/provider/dashscope.test.js.map +1 -0
  167. package/dist/src/core/openaiContentGenerator/provider/deepseek.d.ts +14 -0
  168. package/dist/src/core/openaiContentGenerator/provider/deepseek.js +52 -0
  169. package/dist/src/core/openaiContentGenerator/provider/deepseek.js.map +1 -0
  170. package/dist/src/core/openaiContentGenerator/provider/deepseek.test.d.ts +6 -0
  171. package/dist/src/core/openaiContentGenerator/provider/deepseek.test.js +103 -0
  172. package/dist/src/core/openaiContentGenerator/provider/deepseek.test.js.map +1 -0
  173. package/dist/src/core/openaiContentGenerator/provider/default.d.ts +15 -0
  174. package/dist/src/core/openaiContentGenerator/provider/default.js +38 -0
  175. package/dist/src/core/openaiContentGenerator/provider/default.js.map +1 -0
  176. package/dist/src/core/openaiContentGenerator/provider/default.test.d.ts +6 -0
  177. package/dist/src/core/openaiContentGenerator/provider/default.test.js +176 -0
  178. package/dist/src/core/openaiContentGenerator/provider/default.test.js.map +1 -0
  179. package/dist/src/core/openaiContentGenerator/provider/index.d.ts +5 -0
  180. package/dist/src/core/openaiContentGenerator/provider/index.js +5 -0
  181. package/dist/src/core/openaiContentGenerator/provider/index.js.map +1 -0
  182. package/dist/src/core/openaiContentGenerator/provider/openrouter.d.ts +8 -0
  183. package/dist/src/core/openaiContentGenerator/provider/openrouter.js +21 -0
  184. package/dist/src/core/openaiContentGenerator/provider/openrouter.js.map +1 -0
  185. package/dist/src/core/openaiContentGenerator/provider/openrouter.test.d.ts +6 -0
  186. package/dist/src/core/openaiContentGenerator/provider/openrouter.test.js +152 -0
  187. package/dist/src/core/openaiContentGenerator/provider/openrouter.test.js.map +1 -0
  188. package/dist/src/core/openaiContentGenerator/provider/types.d.ts +23 -0
  189. package/dist/src/core/openaiContentGenerator/provider/types.js +2 -0
  190. package/dist/src/core/openaiContentGenerator/provider/types.js.map +1 -0
  191. package/dist/src/core/openaiContentGenerator/streamingToolCallParser.d.ts +142 -0
  192. package/dist/src/core/openaiContentGenerator/streamingToolCallParser.js +363 -0
  193. package/dist/src/core/openaiContentGenerator/streamingToolCallParser.js.map +1 -0
  194. package/dist/src/core/openaiContentGenerator/streamingToolCallParser.test.d.ts +6 -0
  195. package/dist/src/core/openaiContentGenerator/streamingToolCallParser.test.js +537 -0
  196. package/dist/src/core/openaiContentGenerator/streamingToolCallParser.test.js.map +1 -0
  197. package/dist/src/core/openaiContentGenerator/telemetryService.d.ts +35 -0
  198. package/dist/src/core/openaiContentGenerator/telemetryService.js +146 -0
  199. package/dist/src/core/openaiContentGenerator/telemetryService.js.map +1 -0
  200. package/dist/src/core/openaiContentGenerator/telemetryService.test.d.ts +6 -0
  201. package/dist/src/core/openaiContentGenerator/telemetryService.test.js +978 -0
  202. package/dist/src/core/openaiContentGenerator/telemetryService.test.js.map +1 -0
  203. package/dist/src/core/prompts.d.ts +76 -0
  204. package/dist/src/core/prompts.js +860 -0
  205. package/dist/src/core/prompts.js.map +1 -0
  206. package/dist/src/core/prompts.test.d.ts +6 -0
  207. package/dist/src/core/prompts.test.js +436 -0
  208. package/dist/src/core/prompts.test.js.map +1 -0
  209. package/dist/src/core/tokenLimits.d.ts +25 -0
  210. package/dist/src/core/tokenLimits.js +175 -0
  211. package/dist/src/core/tokenLimits.js.map +1 -0
  212. package/dist/src/core/tokenLimits.test.d.ts +1 -0
  213. package/dist/src/core/tokenLimits.test.js +261 -0
  214. package/dist/src/core/tokenLimits.test.js.map +1 -0
  215. package/dist/src/core/turn.d.ts +140 -0
  216. package/dist/src/core/turn.js +168 -0
  217. package/dist/src/core/turn.js.map +1 -0
  218. package/dist/src/core/turn.test.d.ts +6 -0
  219. package/dist/src/core/turn.test.js +450 -0
  220. package/dist/src/core/turn.test.js.map +1 -0
  221. package/dist/src/generated/git-commit.d.ts +7 -0
  222. package/dist/src/generated/git-commit.js +10 -0
  223. package/dist/src/generated/git-commit.js.map +1 -0
  224. package/dist/src/ide/constants.d.ts +6 -0
  225. package/dist/src/ide/constants.js +7 -0
  226. package/dist/src/ide/constants.js.map +1 -0
  227. package/dist/src/ide/detect-ide.d.ts +25 -0
  228. package/dist/src/ide/detect-ide.js +104 -0
  229. package/dist/src/ide/detect-ide.js.map +1 -0
  230. package/dist/src/ide/detect-ide.test.d.ts +6 -0
  231. package/dist/src/ide/detect-ide.test.js +120 -0
  232. package/dist/src/ide/detect-ide.test.js.map +1 -0
  233. package/dist/src/ide/ide-client.d.ts +67 -0
  234. package/dist/src/ide/ide-client.js +424 -0
  235. package/dist/src/ide/ide-client.js.map +1 -0
  236. package/dist/src/ide/ide-client.test.d.ts +6 -0
  237. package/dist/src/ide/ide-client.test.js +165 -0
  238. package/dist/src/ide/ide-client.test.js.map +1 -0
  239. package/dist/src/ide/ide-installer.d.ts +14 -0
  240. package/dist/src/ide/ide-installer.js +107 -0
  241. package/dist/src/ide/ide-installer.js.map +1 -0
  242. package/dist/src/ide/ide-installer.test.d.ts +6 -0
  243. package/dist/src/ide/ide-installer.test.js +113 -0
  244. package/dist/src/ide/ide-installer.test.js.map +1 -0
  245. package/dist/src/ide/ideContext.d.ts +374 -0
  246. package/dist/src/ide/ideContext.js +147 -0
  247. package/dist/src/ide/ideContext.js.map +1 -0
  248. package/dist/src/ide/ideContext.test.d.ts +6 -0
  249. package/dist/src/ide/ideContext.test.js +265 -0
  250. package/dist/src/ide/ideContext.test.js.map +1 -0
  251. package/dist/src/ide/process-utils.d.ts +21 -0
  252. package/dist/src/ide/process-utils.js +164 -0
  253. package/dist/src/ide/process-utils.js.map +1 -0
  254. package/dist/src/ide/process-utils.test.d.ts +6 -0
  255. package/dist/src/ide/process-utils.test.js +158 -0
  256. package/dist/src/ide/process-utils.test.js.map +1 -0
  257. package/dist/src/index.d.ts +86 -0
  258. package/dist/src/index.js +97 -0
  259. package/dist/src/index.js.map +1 -0
  260. package/dist/src/index.test.d.ts +6 -0
  261. package/dist/src/index.test.js +12 -0
  262. package/dist/src/index.test.js.map +1 -0
  263. package/dist/src/mcp/google-auth-provider.d.ts +23 -0
  264. package/dist/src/mcp/google-auth-provider.js +72 -0
  265. package/dist/src/mcp/google-auth-provider.js.map +1 -0
  266. package/dist/src/mcp/google-auth-provider.test.d.ts +6 -0
  267. package/dist/src/mcp/google-auth-provider.test.js +89 -0
  268. package/dist/src/mcp/google-auth-provider.test.js.map +1 -0
  269. package/dist/src/mcp/oauth-provider.d.ts +146 -0
  270. package/dist/src/mcp/oauth-provider.js +601 -0
  271. package/dist/src/mcp/oauth-provider.js.map +1 -0
  272. package/dist/src/mcp/oauth-provider.test.d.ts +6 -0
  273. package/dist/src/mcp/oauth-provider.test.js +672 -0
  274. package/dist/src/mcp/oauth-provider.test.js.map +1 -0
  275. package/dist/src/mcp/oauth-token-storage.d.ts +61 -0
  276. package/dist/src/mcp/oauth-token-storage.js +148 -0
  277. package/dist/src/mcp/oauth-token-storage.js.map +1 -0
  278. package/dist/src/mcp/oauth-token-storage.test.d.ts +6 -0
  279. package/dist/src/mcp/oauth-token-storage.test.js +208 -0
  280. package/dist/src/mcp/oauth-token-storage.test.js.map +1 -0
  281. package/dist/src/mcp/oauth-utils.d.ts +119 -0
  282. package/dist/src/mcp/oauth-utils.js +235 -0
  283. package/dist/src/mcp/oauth-utils.js.map +1 -0
  284. package/dist/src/mcp/oauth-utils.test.d.ts +6 -0
  285. package/dist/src/mcp/oauth-utils.test.js +199 -0
  286. package/dist/src/mcp/oauth-utils.test.js.map +1 -0
  287. package/dist/src/mcp/token-storage/base-token-storage.d.ts +19 -0
  288. package/dist/src/mcp/token-storage/base-token-storage.js +36 -0
  289. package/dist/src/mcp/token-storage/base-token-storage.js.map +1 -0
  290. package/dist/src/mcp/token-storage/base-token-storage.test.d.ts +6 -0
  291. package/dist/src/mcp/token-storage/base-token-storage.test.js +160 -0
  292. package/dist/src/mcp/token-storage/base-token-storage.test.js.map +1 -0
  293. package/dist/src/mcp/token-storage/types.d.ts +34 -0
  294. package/dist/src/mcp/token-storage/types.js +7 -0
  295. package/dist/src/mcp/token-storage/types.js.map +1 -0
  296. package/dist/src/mocks/msw.d.ts +6 -0
  297. package/dist/src/mocks/msw.js +8 -0
  298. package/dist/src/mocks/msw.js.map +1 -0
  299. package/dist/src/prompts/mcp-prompts.d.ts +8 -0
  300. package/dist/src/prompts/mcp-prompts.js +13 -0
  301. package/dist/src/prompts/mcp-prompts.js.map +1 -0
  302. package/dist/src/prompts/prompt-registry.d.ts +34 -0
  303. package/dist/src/prompts/prompt-registry.js +63 -0
  304. package/dist/src/prompts/prompt-registry.js.map +1 -0
  305. package/dist/src/services/chatRecordingService.d.ts +150 -0
  306. package/dist/src/services/chatRecordingService.js +321 -0
  307. package/dist/src/services/chatRecordingService.js.map +1 -0
  308. package/dist/src/services/chatRecordingService.test.d.ts +6 -0
  309. package/dist/src/services/chatRecordingService.test.js +290 -0
  310. package/dist/src/services/chatRecordingService.test.js.map +1 -0
  311. package/dist/src/services/fileDiscoveryService.d.ts +35 -0
  312. package/dist/src/services/fileDiscoveryService.js +91 -0
  313. package/dist/src/services/fileDiscoveryService.js.map +1 -0
  314. package/dist/src/services/fileDiscoveryService.test.d.ts +6 -0
  315. package/dist/src/services/fileDiscoveryService.test.js +143 -0
  316. package/dist/src/services/fileDiscoveryService.test.js.map +1 -0
  317. package/dist/src/services/fileSystemService.d.ts +31 -0
  318. package/dist/src/services/fileSystemService.js +18 -0
  319. package/dist/src/services/fileSystemService.js.map +1 -0
  320. package/dist/src/services/fileSystemService.test.d.ts +6 -0
  321. package/dist/src/services/fileSystemService.test.js +41 -0
  322. package/dist/src/services/fileSystemService.test.js.map +1 -0
  323. package/dist/src/services/gitService.d.ts +23 -0
  324. package/dist/src/services/gitService.js +110 -0
  325. package/dist/src/services/gitService.js.map +1 -0
  326. package/dist/src/services/gitService.test.d.ts +6 -0
  327. package/dist/src/services/gitService.test.js +212 -0
  328. package/dist/src/services/gitService.test.js.map +1 -0
  329. package/dist/src/services/loopDetectionService.d.ts +98 -0
  330. package/dist/src/services/loopDetectionService.js +363 -0
  331. package/dist/src/services/loopDetectionService.js.map +1 -0
  332. package/dist/src/services/loopDetectionService.test.d.ts +6 -0
  333. package/dist/src/services/loopDetectionService.test.js +560 -0
  334. package/dist/src/services/loopDetectionService.test.js.map +1 -0
  335. package/dist/src/services/shellExecutionService.d.ts +68 -0
  336. package/dist/src/services/shellExecutionService.js +332 -0
  337. package/dist/src/services/shellExecutionService.js.map +1 -0
  338. package/dist/src/services/shellExecutionService.test.d.ts +6 -0
  339. package/dist/src/services/shellExecutionService.test.js +517 -0
  340. package/dist/src/services/shellExecutionService.test.js.map +1 -0
  341. package/dist/src/subagents/builtin-agents.d.ts +35 -0
  342. package/dist/src/subagents/builtin-agents.js +85 -0
  343. package/dist/src/subagents/builtin-agents.js.map +1 -0
  344. package/dist/src/subagents/builtin-agents.test.d.ts +6 -0
  345. package/dist/src/subagents/builtin-agents.test.js +78 -0
  346. package/dist/src/subagents/builtin-agents.test.js.map +1 -0
  347. package/dist/src/subagents/index.d.ts +29 -0
  348. package/dist/src/subagents/index.js +15 -0
  349. package/dist/src/subagents/index.js.map +1 -0
  350. package/dist/src/subagents/subagent-events.d.ts +93 -0
  351. package/dist/src/subagents/subagent-events.js +31 -0
  352. package/dist/src/subagents/subagent-events.js.map +1 -0
  353. package/dist/src/subagents/subagent-hooks.d.ts +29 -0
  354. package/dist/src/subagents/subagent-hooks.js +7 -0
  355. package/dist/src/subagents/subagent-hooks.js.map +1 -0
  356. package/dist/src/subagents/subagent-manager.d.ts +170 -0
  357. package/dist/src/subagents/subagent-manager.js +593 -0
  358. package/dist/src/subagents/subagent-manager.js.map +1 -0
  359. package/dist/src/subagents/subagent-manager.test.d.ts +6 -0
  360. package/dist/src/subagents/subagent-manager.test.js +822 -0
  361. package/dist/src/subagents/subagent-manager.test.js.map +1 -0
  362. package/dist/src/subagents/subagent-statistics.d.ts +46 -0
  363. package/dist/src/subagents/subagent-statistics.js +193 -0
  364. package/dist/src/subagents/subagent-statistics.js.map +1 -0
  365. package/dist/src/subagents/subagent-statistics.test.d.ts +6 -0
  366. package/dist/src/subagents/subagent-statistics.test.js +231 -0
  367. package/dist/src/subagents/subagent-statistics.test.js.map +1 -0
  368. package/dist/src/subagents/subagent.d.ts +161 -0
  369. package/dist/src/subagents/subagent.js +667 -0
  370. package/dist/src/subagents/subagent.js.map +1 -0
  371. package/dist/src/subagents/subagent.test.d.ts +6 -0
  372. package/dist/src/subagents/subagent.test.js +487 -0
  373. package/dist/src/subagents/subagent.test.js.map +1 -0
  374. package/dist/src/subagents/types.d.ts +218 -0
  375. package/dist/src/subagents/types.js +58 -0
  376. package/dist/src/subagents/types.js.map +1 -0
  377. package/dist/src/subagents/types.test.d.ts +6 -0
  378. package/dist/src/subagents/types.test.js +31 -0
  379. package/dist/src/subagents/types.test.js.map +1 -0
  380. package/dist/src/subagents/validation.d.ts +63 -0
  381. package/dist/src/subagents/validation.js +293 -0
  382. package/dist/src/subagents/validation.js.map +1 -0
  383. package/dist/src/subagents/validation.test.d.ts +6 -0
  384. package/dist/src/subagents/validation.test.js +330 -0
  385. package/dist/src/subagents/validation.test.js.map +1 -0
  386. package/dist/src/telemetry/blackbox-logger/blackbox-logger.d.ts +80 -0
  387. package/dist/src/telemetry/blackbox-logger/blackbox-logger.js +583 -0
  388. package/dist/src/telemetry/blackbox-logger/blackbox-logger.js.map +1 -0
  389. package/dist/src/telemetry/blackbox-logger/blackbox-logger.test.d.ts +6 -0
  390. package/dist/src/telemetry/blackbox-logger/blackbox-logger.test.js +301 -0
  391. package/dist/src/telemetry/blackbox-logger/blackbox-logger.test.js.map +1 -0
  392. package/dist/src/telemetry/blackbox-logger/event-types.d.ts +73 -0
  393. package/dist/src/telemetry/blackbox-logger/event-types.js +2 -0
  394. package/dist/src/telemetry/blackbox-logger/event-types.js.map +1 -0
  395. package/dist/src/telemetry/clearcut-logger/clearcut-logger.d.ts +121 -0
  396. package/dist/src/telemetry/clearcut-logger/clearcut-logger.js +773 -0
  397. package/dist/src/telemetry/clearcut-logger/clearcut-logger.js.map +1 -0
  398. package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.d.ts +17 -0
  399. package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.js +420 -0
  400. package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.js.map +1 -0
  401. package/dist/src/telemetry/clearcut-logger/event-metadata-key.d.ts +90 -0
  402. package/dist/src/telemetry/clearcut-logger/event-metadata-key.js +229 -0
  403. package/dist/src/telemetry/clearcut-logger/event-metadata-key.js.map +1 -0
  404. package/dist/src/telemetry/constants.d.ts +34 -0
  405. package/dist/src/telemetry/constants.js +35 -0
  406. package/dist/src/telemetry/constants.js.map +1 -0
  407. package/dist/src/telemetry/file-exporters.d.ts +29 -0
  408. package/dist/src/telemetry/file-exporters.js +62 -0
  409. package/dist/src/telemetry/file-exporters.js.map +1 -0
  410. package/dist/src/telemetry/index.d.ts +20 -0
  411. package/dist/src/telemetry/index.js +21 -0
  412. package/dist/src/telemetry/index.js.map +1 -0
  413. package/dist/src/telemetry/integration.test.circular.d.ts +6 -0
  414. package/dist/src/telemetry/integration.test.circular.js +95 -0
  415. package/dist/src/telemetry/integration.test.circular.js.map +1 -0
  416. package/dist/src/telemetry/loggers.d.ts +26 -0
  417. package/dist/src/telemetry/loggers.js +406 -0
  418. package/dist/src/telemetry/loggers.js.map +1 -0
  419. package/dist/src/telemetry/loggers.test.circular.d.ts +6 -0
  420. package/dist/src/telemetry/loggers.test.circular.js +107 -0
  421. package/dist/src/telemetry/loggers.test.circular.js.map +1 -0
  422. package/dist/src/telemetry/loggers.test.d.ts +6 -0
  423. package/dist/src/telemetry/loggers.test.js +638 -0
  424. package/dist/src/telemetry/loggers.test.js.map +1 -0
  425. package/dist/src/telemetry/metrics.d.ts +40 -0
  426. package/dist/src/telemetry/metrics.js +229 -0
  427. package/dist/src/telemetry/metrics.js.map +1 -0
  428. package/dist/src/telemetry/metrics.test.d.ts +6 -0
  429. package/dist/src/telemetry/metrics.test.js +242 -0
  430. package/dist/src/telemetry/metrics.test.js.map +1 -0
  431. package/dist/src/telemetry/sdk.d.ts +9 -0
  432. package/dist/src/telemetry/sdk.js +161 -0
  433. package/dist/src/telemetry/sdk.js.map +1 -0
  434. package/dist/src/telemetry/sdk.test.d.ts +6 -0
  435. package/dist/src/telemetry/sdk.test.js +82 -0
  436. package/dist/src/telemetry/sdk.test.js.map +1 -0
  437. package/dist/src/telemetry/telemetry-utils.d.ts +6 -0
  438. package/dist/src/telemetry/telemetry-utils.js +14 -0
  439. package/dist/src/telemetry/telemetry-utils.js.map +1 -0
  440. package/dist/src/telemetry/telemetry-utils.test.d.ts +6 -0
  441. package/dist/src/telemetry/telemetry-utils.test.js +40 -0
  442. package/dist/src/telemetry/telemetry-utils.test.js.map +1 -0
  443. package/dist/src/telemetry/telemetry.test.d.ts +6 -0
  444. package/dist/src/telemetry/telemetry.test.js +50 -0
  445. package/dist/src/telemetry/telemetry.test.js.map +1 -0
  446. package/dist/src/telemetry/tool-call-decision.d.ts +13 -0
  447. package/dist/src/telemetry/tool-call-decision.js +29 -0
  448. package/dist/src/telemetry/tool-call-decision.js.map +1 -0
  449. package/dist/src/telemetry/types.d.ts +236 -0
  450. package/dist/src/telemetry/types.js +405 -0
  451. package/dist/src/telemetry/types.js.map +1 -0
  452. package/dist/src/telemetry/uiTelemetry.d.ts +75 -0
  453. package/dist/src/telemetry/uiTelemetry.js +153 -0
  454. package/dist/src/telemetry/uiTelemetry.js.map +1 -0
  455. package/dist/src/telemetry/uiTelemetry.test.d.ts +6 -0
  456. package/dist/src/telemetry/uiTelemetry.test.js +558 -0
  457. package/dist/src/telemetry/uiTelemetry.test.js.map +1 -0
  458. package/dist/src/test-utils/config.d.ts +17 -0
  459. package/dist/src/test-utils/config.js +32 -0
  460. package/dist/src/test-utils/config.js.map +1 -0
  461. package/dist/src/test-utils/mockWorkspaceContext.d.ts +13 -0
  462. package/dist/src/test-utils/mockWorkspaceContext.js +24 -0
  463. package/dist/src/test-utils/mockWorkspaceContext.js.map +1 -0
  464. package/dist/src/test-utils/tools.d.ts +45 -0
  465. package/dist/src/test-utils/tools.js +105 -0
  466. package/dist/src/test-utils/tools.js.map +1 -0
  467. package/dist/src/tools/diffOptions.d.ts +9 -0
  468. package/dist/src/tools/diffOptions.js +38 -0
  469. package/dist/src/tools/diffOptions.js.map +1 -0
  470. package/dist/src/tools/diffOptions.test.d.ts +6 -0
  471. package/dist/src/tools/diffOptions.test.js +119 -0
  472. package/dist/src/tools/diffOptions.test.js.map +1 -0
  473. package/dist/src/tools/edit.d.ts +56 -0
  474. package/dist/src/tools/edit.js +434 -0
  475. package/dist/src/tools/edit.js.map +1 -0
  476. package/dist/src/tools/edit.test.d.ts +6 -0
  477. package/dist/src/tools/edit.test.js +569 -0
  478. package/dist/src/tools/edit.test.js.map +1 -0
  479. package/dist/src/tools/exitPlanMode.d.ts +28 -0
  480. package/dist/src/tools/exitPlanMode.js +137 -0
  481. package/dist/src/tools/exitPlanMode.js.map +1 -0
  482. package/dist/src/tools/exitPlanMode.test.d.ts +6 -0
  483. package/dist/src/tools/exitPlanMode.test.js +219 -0
  484. package/dist/src/tools/exitPlanMode.test.js.map +1 -0
  485. package/dist/src/tools/glob.d.ts +52 -0
  486. package/dist/src/tools/glob.js +237 -0
  487. package/dist/src/tools/glob.js.map +1 -0
  488. package/dist/src/tools/glob.test.d.ts +6 -0
  489. package/dist/src/tools/glob.test.js +375 -0
  490. package/dist/src/tools/glob.test.js.map +1 -0
  491. package/dist/src/tools/grep.d.ts +51 -0
  492. package/dist/src/tools/grep.js +566 -0
  493. package/dist/src/tools/grep.js.map +1 -0
  494. package/dist/src/tools/grep.test.d.ts +6 -0
  495. package/dist/src/tools/grep.test.js +356 -0
  496. package/dist/src/tools/grep.test.js.map +1 -0
  497. package/dist/src/tools/ls.d.ts +68 -0
  498. package/dist/src/tools/ls.js +227 -0
  499. package/dist/src/tools/ls.js.map +1 -0
  500. package/dist/src/tools/ls.test.d.ts +6 -0
  501. package/dist/src/tools/ls.test.js +389 -0
  502. package/dist/src/tools/ls.test.js.map +1 -0
  503. package/dist/src/tools/mcp-client-manager.d.ts +38 -0
  504. package/dist/src/tools/mcp-client-manager.js +74 -0
  505. package/dist/src/tools/mcp-client-manager.js.map +1 -0
  506. package/dist/src/tools/mcp-client-manager.test.d.ts +6 -0
  507. package/dist/src/tools/mcp-client-manager.test.js +39 -0
  508. package/dist/src/tools/mcp-client-manager.test.js.map +1 -0
  509. package/dist/src/tools/mcp-client.d.ts +199 -0
  510. package/dist/src/tools/mcp-client.js +995 -0
  511. package/dist/src/tools/mcp-client.js.map +1 -0
  512. package/dist/src/tools/mcp-client.test.d.ts +6 -0
  513. package/dist/src/tools/mcp-client.test.js +454 -0
  514. package/dist/src/tools/mcp-client.test.js.map +1 -0
  515. package/dist/src/tools/mcp-tool.d.ts +23 -0
  516. package/dist/src/tools/mcp-tool.js +240 -0
  517. package/dist/src/tools/mcp-tool.js.map +1 -0
  518. package/dist/src/tools/mcp-tool.test.d.ts +6 -0
  519. package/dist/src/tools/mcp-tool.test.js +576 -0
  520. package/dist/src/tools/mcp-tool.test.js.map +1 -0
  521. package/dist/src/tools/memoryTool.d.ts +41 -0
  522. package/dist/src/tools/memoryTool.js +435 -0
  523. package/dist/src/tools/memoryTool.js.map +1 -0
  524. package/dist/src/tools/memoryTool.test.d.ts +6 -0
  525. package/dist/src/tools/memoryTool.test.js +420 -0
  526. package/dist/src/tools/memoryTool.test.js.map +1 -0
  527. package/dist/src/tools/modifiable-tool.d.ts +32 -0
  528. package/dist/src/tools/modifiable-tool.js +88 -0
  529. package/dist/src/tools/modifiable-tool.js.map +1 -0
  530. package/dist/src/tools/modifiable-tool.test.d.ts +6 -0
  531. package/dist/src/tools/modifiable-tool.test.js +193 -0
  532. package/dist/src/tools/modifiable-tool.test.js.map +1 -0
  533. package/dist/src/tools/read-file.d.ts +35 -0
  534. package/dist/src/tools/read-file.js +128 -0
  535. package/dist/src/tools/read-file.js.map +1 -0
  536. package/dist/src/tools/read-file.test.d.ts +6 -0
  537. package/dist/src/tools/read-file.test.js +311 -0
  538. package/dist/src/tools/read-file.test.js.map +1 -0
  539. package/dist/src/tools/read-many-files.d.ts +60 -0
  540. package/dist/src/tools/read-many-files.js +416 -0
  541. package/dist/src/tools/read-many-files.js.map +1 -0
  542. package/dist/src/tools/read-many-files.test.d.ts +6 -0
  543. package/dist/src/tools/read-many-files.test.js +565 -0
  544. package/dist/src/tools/read-many-files.test.js.map +1 -0
  545. package/dist/src/tools/ripGrep.d.ts +47 -0
  546. package/dist/src/tools/ripGrep.js +375 -0
  547. package/dist/src/tools/ripGrep.js.map +1 -0
  548. package/dist/src/tools/ripGrep.test.d.ts +6 -0
  549. package/dist/src/tools/ripGrep.test.js +874 -0
  550. package/dist/src/tools/ripGrep.test.js.map +1 -0
  551. package/dist/src/tools/shell.d.ts +23 -0
  552. package/dist/src/tools/shell.js +387 -0
  553. package/dist/src/tools/shell.js.map +1 -0
  554. package/dist/src/tools/shell.test.d.ts +6 -0
  555. package/dist/src/tools/shell.test.js +632 -0
  556. package/dist/src/tools/shell.test.js.map +1 -0
  557. package/dist/src/tools/task.d.ts +59 -0
  558. package/dist/src/tools/task.js +412 -0
  559. package/dist/src/tools/task.js.map +1 -0
  560. package/dist/src/tools/task.test.d.ts +6 -0
  561. package/dist/src/tools/task.test.js +369 -0
  562. package/dist/src/tools/task.test.js.map +1 -0
  563. package/dist/src/tools/todoWrite.d.ts +42 -0
  564. package/dist/src/tools/todoWrite.js +385 -0
  565. package/dist/src/tools/todoWrite.js.map +1 -0
  566. package/dist/src/tools/todoWrite.test.d.ts +6 -0
  567. package/dist/src/tools/todoWrite.test.js +222 -0
  568. package/dist/src/tools/todoWrite.test.js.map +1 -0
  569. package/dist/src/tools/tool-error.d.ts +43 -0
  570. package/dist/src/tools/tool-error.js +58 -0
  571. package/dist/src/tools/tool-error.js.map +1 -0
  572. package/dist/src/tools/tool-names.d.ts +23 -0
  573. package/dist/src/tools/tool-names.js +24 -0
  574. package/dist/src/tools/tool-names.js.map +1 -0
  575. package/dist/src/tools/tool-registry.d.ts +86 -0
  576. package/dist/src/tools/tool-registry.js +369 -0
  577. package/dist/src/tools/tool-registry.js.map +1 -0
  578. package/dist/src/tools/tool-registry.test.d.ts +6 -0
  579. package/dist/src/tools/tool-registry.test.js +332 -0
  580. package/dist/src/tools/tool-registry.test.js.map +1 -0
  581. package/dist/src/tools/tools.d.ts +316 -0
  582. package/dist/src/tools/tools.js +251 -0
  583. package/dist/src/tools/tools.js.map +1 -0
  584. package/dist/src/tools/tools.test.d.ts +6 -0
  585. package/dist/src/tools/tools.test.js +205 -0
  586. package/dist/src/tools/tools.test.js.map +1 -0
  587. package/dist/src/tools/web-fetch.d.ts +31 -0
  588. package/dist/src/tools/web-fetch.js +161 -0
  589. package/dist/src/tools/web-fetch.js.map +1 -0
  590. package/dist/src/tools/web-fetch.test.d.ts +6 -0
  591. package/dist/src/tools/web-fetch.test.js +133 -0
  592. package/dist/src/tools/web-fetch.test.js.map +1 -0
  593. package/dist/src/tools/web-search.d.ts +40 -0
  594. package/dist/src/tools/web-search.js +134 -0
  595. package/dist/src/tools/web-search.js.map +1 -0
  596. package/dist/src/tools/web-search.test.d.ts +6 -0
  597. package/dist/src/tools/web-search.test.js +125 -0
  598. package/dist/src/tools/web-search.test.js.map +1 -0
  599. package/dist/src/tools/write-file.d.ts +52 -0
  600. package/dist/src/tools/write-file.js +298 -0
  601. package/dist/src/tools/write-file.js.map +1 -0
  602. package/dist/src/tools/write-file.test.d.ts +6 -0
  603. package/dist/src/tools/write-file.test.js +436 -0
  604. package/dist/src/tools/write-file.test.js.map +1 -0
  605. package/dist/src/utils/LruCache.d.ts +13 -0
  606. package/dist/src/utils/LruCache.js +38 -0
  607. package/dist/src/utils/LruCache.js.map +1 -0
  608. package/dist/src/utils/bfsFileSearch.d.ts +24 -0
  609. package/dist/src/utils/bfsFileSearch.js +89 -0
  610. package/dist/src/utils/bfsFileSearch.js.map +1 -0
  611. package/dist/src/utils/bfsFileSearch.test.d.ts +6 -0
  612. package/dist/src/utils/bfsFileSearch.test.js +163 -0
  613. package/dist/src/utils/bfsFileSearch.test.js.map +1 -0
  614. package/dist/src/utils/browser.d.ts +13 -0
  615. package/dist/src/utils/browser.js +50 -0
  616. package/dist/src/utils/browser.js.map +1 -0
  617. package/dist/src/utils/editor.d.ts +28 -0
  618. package/dist/src/utils/editor.js +186 -0
  619. package/dist/src/utils/editor.js.map +1 -0
  620. package/dist/src/utils/editor.test.d.ts +6 -0
  621. package/dist/src/utils/editor.test.js +445 -0
  622. package/dist/src/utils/editor.test.js.map +1 -0
  623. package/dist/src/utils/environmentContext.d.ts +21 -0
  624. package/dist/src/utils/environmentContext.js +90 -0
  625. package/dist/src/utils/environmentContext.js.map +1 -0
  626. package/dist/src/utils/environmentContext.test.d.ts +6 -0
  627. package/dist/src/utils/environmentContext.test.js +148 -0
  628. package/dist/src/utils/environmentContext.test.js.map +1 -0
  629. package/dist/src/utils/errorParsing.d.ts +8 -0
  630. package/dist/src/utils/errorParsing.js +93 -0
  631. package/dist/src/utils/errorParsing.js.map +1 -0
  632. package/dist/src/utils/errorParsing.test.d.ts +6 -0
  633. package/dist/src/utils/errorParsing.test.js +172 -0
  634. package/dist/src/utils/errorParsing.test.js.map +1 -0
  635. package/dist/src/utils/errorReporting.d.ts +14 -0
  636. package/dist/src/utils/errorReporting.js +88 -0
  637. package/dist/src/utils/errorReporting.js.map +1 -0
  638. package/dist/src/utils/errorReporting.test.d.ts +6 -0
  639. package/dist/src/utils/errorReporting.test.js +130 -0
  640. package/dist/src/utils/errorReporting.test.js.map +1 -0
  641. package/dist/src/utils/errors.d.ts +33 -0
  642. package/dist/src/utils/errors.js +86 -0
  643. package/dist/src/utils/errors.js.map +1 -0
  644. package/dist/src/utils/fetch.d.ts +11 -0
  645. package/dist/src/utils/fetch.js +51 -0
  646. package/dist/src/utils/fetch.js.map +1 -0
  647. package/dist/src/utils/fileUtils.d.ts +53 -0
  648. package/dist/src/utils/fileUtils.js +283 -0
  649. package/dist/src/utils/fileUtils.js.map +1 -0
  650. package/dist/src/utils/fileUtils.test.d.ts +6 -0
  651. package/dist/src/utils/fileUtils.test.js +364 -0
  652. package/dist/src/utils/fileUtils.test.js.map +1 -0
  653. package/dist/src/utils/filesearch/crawlCache.d.ts +25 -0
  654. package/dist/src/utils/filesearch/crawlCache.js +57 -0
  655. package/dist/src/utils/filesearch/crawlCache.js.map +1 -0
  656. package/dist/src/utils/filesearch/crawlCache.test.d.ts +6 -0
  657. package/dist/src/utils/filesearch/crawlCache.test.js +103 -0
  658. package/dist/src/utils/filesearch/crawlCache.test.js.map +1 -0
  659. package/dist/src/utils/filesearch/crawler.d.ts +15 -0
  660. package/dist/src/utils/filesearch/crawler.js +50 -0
  661. package/dist/src/utils/filesearch/crawler.js.map +1 -0
  662. package/dist/src/utils/filesearch/crawler.test.d.ts +6 -0
  663. package/dist/src/utils/filesearch/crawler.test.js +468 -0
  664. package/dist/src/utils/filesearch/crawler.test.js.map +1 -0
  665. package/dist/src/utils/filesearch/fileSearch.d.ts +38 -0
  666. package/dist/src/utils/filesearch/fileSearch.js +191 -0
  667. package/dist/src/utils/filesearch/fileSearch.js.map +1 -0
  668. package/dist/src/utils/filesearch/fileSearch.test.d.ts +6 -0
  669. package/dist/src/utils/filesearch/fileSearch.test.js +642 -0
  670. package/dist/src/utils/filesearch/fileSearch.test.js.map +1 -0
  671. package/dist/src/utils/filesearch/ignore.d.ts +42 -0
  672. package/dist/src/utils/filesearch/ignore.js +106 -0
  673. package/dist/src/utils/filesearch/ignore.js.map +1 -0
  674. package/dist/src/utils/filesearch/ignore.test.d.ts +6 -0
  675. package/dist/src/utils/filesearch/ignore.test.js +144 -0
  676. package/dist/src/utils/filesearch/ignore.test.js.map +1 -0
  677. package/dist/src/utils/filesearch/result-cache.d.ts +33 -0
  678. package/dist/src/utils/filesearch/result-cache.js +59 -0
  679. package/dist/src/utils/filesearch/result-cache.js.map +1 -0
  680. package/dist/src/utils/filesearch/result-cache.test.d.ts +6 -0
  681. package/dist/src/utils/filesearch/result-cache.test.js +46 -0
  682. package/dist/src/utils/filesearch/result-cache.test.js.map +1 -0
  683. package/dist/src/utils/flashFallback.integration.test.d.ts +6 -0
  684. package/dist/src/utils/flashFallback.integration.test.js +119 -0
  685. package/dist/src/utils/flashFallback.integration.test.js.map +1 -0
  686. package/dist/src/utils/formatters.d.ts +6 -0
  687. package/dist/src/utils/formatters.js +16 -0
  688. package/dist/src/utils/formatters.js.map +1 -0
  689. package/dist/src/utils/generateContentResponseUtilities.d.ts +13 -0
  690. package/dist/src/utils/generateContentResponseUtilities.js +80 -0
  691. package/dist/src/utils/generateContentResponseUtilities.js.map +1 -0
  692. package/dist/src/utils/generateContentResponseUtilities.test.d.ts +6 -0
  693. package/dist/src/utils/generateContentResponseUtilities.test.js +235 -0
  694. package/dist/src/utils/generateContentResponseUtilities.test.js.map +1 -0
  695. package/dist/src/utils/getFolderStructure.d.ts +31 -0
  696. package/dist/src/utils/getFolderStructure.js +246 -0
  697. package/dist/src/utils/getFolderStructure.js.map +1 -0
  698. package/dist/src/utils/getFolderStructure.test.d.ts +6 -0
  699. package/dist/src/utils/getFolderStructure.test.js +282 -0
  700. package/dist/src/utils/getFolderStructure.test.js.map +1 -0
  701. package/dist/src/utils/getPty.d.ts +19 -0
  702. package/dist/src/utils/getPty.js +23 -0
  703. package/dist/src/utils/getPty.js.map +1 -0
  704. package/dist/src/utils/gitIgnoreParser.d.ts +20 -0
  705. package/dist/src/utils/gitIgnoreParser.js +61 -0
  706. package/dist/src/utils/gitIgnoreParser.js.map +1 -0
  707. package/dist/src/utils/gitIgnoreParser.test.d.ts +6 -0
  708. package/dist/src/utils/gitIgnoreParser.test.js +154 -0
  709. package/dist/src/utils/gitIgnoreParser.test.js.map +1 -0
  710. package/dist/src/utils/gitUtils.d.ts +17 -0
  711. package/dist/src/utils/gitUtils.js +61 -0
  712. package/dist/src/utils/gitUtils.js.map +1 -0
  713. package/dist/src/utils/ignorePatterns.d.ts +103 -0
  714. package/dist/src/utils/ignorePatterns.js +220 -0
  715. package/dist/src/utils/ignorePatterns.js.map +1 -0
  716. package/dist/src/utils/ignorePatterns.test.d.ts +6 -0
  717. package/dist/src/utils/ignorePatterns.test.js +250 -0
  718. package/dist/src/utils/ignorePatterns.test.js.map +1 -0
  719. package/dist/src/utils/installationManager.d.ts +16 -0
  720. package/dist/src/utils/installationManager.js +50 -0
  721. package/dist/src/utils/installationManager.js.map +1 -0
  722. package/dist/src/utils/installationManager.test.d.ts +6 -0
  723. package/dist/src/utils/installationManager.test.js +83 -0
  724. package/dist/src/utils/installationManager.test.js.map +1 -0
  725. package/dist/src/utils/language-detection.d.ts +6 -0
  726. package/dist/src/utils/language-detection.js +101 -0
  727. package/dist/src/utils/language-detection.js.map +1 -0
  728. package/dist/src/utils/memoryDiscovery.d.ts +15 -0
  729. package/dist/src/utils/memoryDiscovery.js +271 -0
  730. package/dist/src/utils/memoryDiscovery.js.map +1 -0
  731. package/dist/src/utils/memoryDiscovery.test.d.ts +6 -0
  732. package/dist/src/utils/memoryDiscovery.test.js +219 -0
  733. package/dist/src/utils/memoryDiscovery.test.js.map +1 -0
  734. package/dist/src/utils/memoryImportProcessor.d.ts +42 -0
  735. package/dist/src/utils/memoryImportProcessor.js +296 -0
  736. package/dist/src/utils/memoryImportProcessor.js.map +1 -0
  737. package/dist/src/utils/memoryImportProcessor.test.d.ts +6 -0
  738. package/dist/src/utils/memoryImportProcessor.test.js +573 -0
  739. package/dist/src/utils/memoryImportProcessor.test.js.map +1 -0
  740. package/dist/src/utils/messageInspectors.d.ts +8 -0
  741. package/dist/src/utils/messageInspectors.js +16 -0
  742. package/dist/src/utils/messageInspectors.js.map +1 -0
  743. package/dist/src/utils/nextSpeakerChecker.d.ts +12 -0
  744. package/dist/src/utils/nextSpeakerChecker.js +91 -0
  745. package/dist/src/utils/nextSpeakerChecker.js.map +1 -0
  746. package/dist/src/utils/nextSpeakerChecker.test.d.ts +6 -0
  747. package/dist/src/utils/nextSpeakerChecker.test.js +168 -0
  748. package/dist/src/utils/nextSpeakerChecker.test.js.map +1 -0
  749. package/dist/src/utils/openaiLogger.d.ts +42 -0
  750. package/dist/src/utils/openaiLogger.js +123 -0
  751. package/dist/src/utils/openaiLogger.js.map +1 -0
  752. package/dist/src/utils/partUtils.d.ts +35 -0
  753. package/dist/src/utils/partUtils.js +133 -0
  754. package/dist/src/utils/partUtils.js.map +1 -0
  755. package/dist/src/utils/partUtils.test.d.ts +6 -0
  756. package/dist/src/utils/partUtils.test.js +241 -0
  757. package/dist/src/utils/partUtils.test.js.map +1 -0
  758. package/dist/src/utils/pathReader.d.ts +17 -0
  759. package/dist/src/utils/pathReader.js +92 -0
  760. package/dist/src/utils/pathReader.js.map +1 -0
  761. package/dist/src/utils/pathReader.test.d.ts +6 -0
  762. package/dist/src/utils/pathReader.test.js +363 -0
  763. package/dist/src/utils/pathReader.test.js.map +1 -0
  764. package/dist/src/utils/paths.d.ts +58 -0
  765. package/dist/src/utils/paths.js +159 -0
  766. package/dist/src/utils/paths.js.map +1 -0
  767. package/dist/src/utils/paths.test.d.ts +6 -0
  768. package/dist/src/utils/paths.test.js +225 -0
  769. package/dist/src/utils/paths.test.js.map +1 -0
  770. package/dist/src/utils/projectSummary.d.ts +22 -0
  771. package/dist/src/utils/projectSummary.js +86 -0
  772. package/dist/src/utils/projectSummary.js.map +1 -0
  773. package/dist/src/utils/quotaErrorDetection.d.ts +20 -0
  774. package/dist/src/utils/quotaErrorDetection.js +114 -0
  775. package/dist/src/utils/quotaErrorDetection.js.map +1 -0
  776. package/dist/src/utils/quotaErrorDetection.test.d.ts +6 -0
  777. package/dist/src/utils/quotaErrorDetection.test.js +153 -0
  778. package/dist/src/utils/quotaErrorDetection.test.js.map +1 -0
  779. package/dist/src/utils/request-tokenizer/imageTokenizer.d.ts +112 -0
  780. package/dist/src/utils/request-tokenizer/imageTokenizer.js +401 -0
  781. package/dist/src/utils/request-tokenizer/imageTokenizer.js.map +1 -0
  782. package/dist/src/utils/request-tokenizer/imageTokenizer.test.d.ts +6 -0
  783. package/dist/src/utils/request-tokenizer/imageTokenizer.test.js +114 -0
  784. package/dist/src/utils/request-tokenizer/imageTokenizer.test.js.map +1 -0
  785. package/dist/src/utils/request-tokenizer/index.d.ts +18 -0
  786. package/dist/src/utils/request-tokenizer/index.js +30 -0
  787. package/dist/src/utils/request-tokenizer/index.js.map +1 -0
  788. package/dist/src/utils/request-tokenizer/requestTokenizer.d.ts +56 -0
  789. package/dist/src/utils/request-tokenizer/requestTokenizer.js +263 -0
  790. package/dist/src/utils/request-tokenizer/requestTokenizer.js.map +1 -0
  791. package/dist/src/utils/request-tokenizer/requestTokenizer.test.d.ts +6 -0
  792. package/dist/src/utils/request-tokenizer/requestTokenizer.test.js +245 -0
  793. package/dist/src/utils/request-tokenizer/requestTokenizer.test.js.map +1 -0
  794. package/dist/src/utils/request-tokenizer/supportedImageFormats.d.ts +30 -0
  795. package/dist/src/utils/request-tokenizer/supportedImageFormats.js +41 -0
  796. package/dist/src/utils/request-tokenizer/supportedImageFormats.js.map +1 -0
  797. package/dist/src/utils/request-tokenizer/textTokenizer.d.ts +29 -0
  798. package/dist/src/utils/request-tokenizer/textTokenizer.js +88 -0
  799. package/dist/src/utils/request-tokenizer/textTokenizer.js.map +1 -0
  800. package/dist/src/utils/request-tokenizer/textTokenizer.test.d.ts +6 -0
  801. package/dist/src/utils/request-tokenizer/textTokenizer.test.js +253 -0
  802. package/dist/src/utils/request-tokenizer/textTokenizer.test.js.map +1 -0
  803. package/dist/src/utils/request-tokenizer/types.d.ts +55 -0
  804. package/dist/src/utils/request-tokenizer/types.js +7 -0
  805. package/dist/src/utils/request-tokenizer/types.js.map +1 -0
  806. package/dist/src/utils/retry.d.ts +30 -0
  807. package/dist/src/utils/retry.js +288 -0
  808. package/dist/src/utils/retry.js.map +1 -0
  809. package/dist/src/utils/retry.test.d.ts +6 -0
  810. package/dist/src/utils/retry.test.js +452 -0
  811. package/dist/src/utils/retry.test.js.map +1 -0
  812. package/dist/src/utils/safeJsonParse.d.ts +15 -0
  813. package/dist/src/utils/safeJsonParse.js +41 -0
  814. package/dist/src/utils/safeJsonParse.js.map +1 -0
  815. package/dist/src/utils/safeJsonParse.test.d.ts +6 -0
  816. package/dist/src/utils/safeJsonParse.test.js +112 -0
  817. package/dist/src/utils/safeJsonParse.test.js.map +1 -0
  818. package/dist/src/utils/safeJsonStringify.d.ts +13 -0
  819. package/dist/src/utils/safeJsonStringify.js +25 -0
  820. package/dist/src/utils/safeJsonStringify.js.map +1 -0
  821. package/dist/src/utils/safeJsonStringify.test.d.ts +6 -0
  822. package/dist/src/utils/safeJsonStringify.test.js +61 -0
  823. package/dist/src/utils/safeJsonStringify.test.js.map +1 -0
  824. package/dist/src/utils/schemaValidator.d.ts +15 -0
  825. package/dist/src/utils/schemaValidator.js +57 -0
  826. package/dist/src/utils/schemaValidator.js.map +1 -0
  827. package/dist/src/utils/secure-browser-launcher.d.ts +23 -0
  828. package/dist/src/utils/secure-browser-launcher.js +165 -0
  829. package/dist/src/utils/secure-browser-launcher.js.map +1 -0
  830. package/dist/src/utils/secure-browser-launcher.test.d.ts +6 -0
  831. package/dist/src/utils/secure-browser-launcher.test.js +149 -0
  832. package/dist/src/utils/secure-browser-launcher.test.js.map +1 -0
  833. package/dist/src/utils/session.d.ts +6 -0
  834. package/dist/src/utils/session.js +8 -0
  835. package/dist/src/utils/session.js.map +1 -0
  836. package/dist/src/utils/shell-utils.d.ts +121 -0
  837. package/dist/src/utils/shell-utils.js +381 -0
  838. package/dist/src/utils/shell-utils.js.map +1 -0
  839. package/dist/src/utils/shell-utils.test.d.ts +6 -0
  840. package/dist/src/utils/shell-utils.test.js +346 -0
  841. package/dist/src/utils/shell-utils.test.js.map +1 -0
  842. package/dist/src/utils/shellReadOnlyChecker.d.ts +6 -0
  843. package/dist/src/utils/shellReadOnlyChecker.js +247 -0
  844. package/dist/src/utils/shellReadOnlyChecker.js.map +1 -0
  845. package/dist/src/utils/shellReadOnlyChecker.test.d.ts +6 -0
  846. package/dist/src/utils/shellReadOnlyChecker.test.js +47 -0
  847. package/dist/src/utils/shellReadOnlyChecker.test.js.map +1 -0
  848. package/dist/src/utils/subagentGenerator.d.ts +20 -0
  849. package/dist/src/utils/subagentGenerator.js +116 -0
  850. package/dist/src/utils/subagentGenerator.js.map +1 -0
  851. package/dist/src/utils/subagentGenerator.test.d.ts +6 -0
  852. package/dist/src/utils/subagentGenerator.test.js +158 -0
  853. package/dist/src/utils/subagentGenerator.test.js.map +1 -0
  854. package/dist/src/utils/summarizer.d.ts +25 -0
  855. package/dist/src/utils/summarizer.js +51 -0
  856. package/dist/src/utils/summarizer.js.map +1 -0
  857. package/dist/src/utils/summarizer.test.d.ts +6 -0
  858. package/dist/src/utils/summarizer.test.js +131 -0
  859. package/dist/src/utils/summarizer.test.js.map +1 -0
  860. package/dist/src/utils/systemEncoding.d.ts +40 -0
  861. package/dist/src/utils/systemEncoding.js +149 -0
  862. package/dist/src/utils/systemEncoding.js.map +1 -0
  863. package/dist/src/utils/systemEncoding.test.d.ts +6 -0
  864. package/dist/src/utils/systemEncoding.test.js +368 -0
  865. package/dist/src/utils/systemEncoding.test.js.map +1 -0
  866. package/dist/src/utils/testUtils.d.ts +29 -0
  867. package/dist/src/utils/testUtils.js +70 -0
  868. package/dist/src/utils/testUtils.js.map +1 -0
  869. package/dist/src/utils/textUtils.d.ts +13 -0
  870. package/dist/src/utils/textUtils.js +28 -0
  871. package/dist/src/utils/textUtils.js.map +1 -0
  872. package/dist/src/utils/tool-utils.d.ts +19 -0
  873. package/dist/src/utils/tool-utils.js +58 -0
  874. package/dist/src/utils/tool-utils.js.map +1 -0
  875. package/dist/src/utils/tool-utils.test.d.ts +6 -0
  876. package/dist/src/utils/tool-utils.test.js +61 -0
  877. package/dist/src/utils/tool-utils.test.js.map +1 -0
  878. package/dist/src/utils/userAccountManager.d.ts +20 -0
  879. package/dist/src/utils/userAccountManager.js +114 -0
  880. package/dist/src/utils/userAccountManager.js.map +1 -0
  881. package/dist/src/utils/userAccountManager.test.d.ts +6 -0
  882. package/dist/src/utils/userAccountManager.test.js +223 -0
  883. package/dist/src/utils/userAccountManager.test.js.map +1 -0
  884. package/dist/src/utils/workspaceContext.d.ts +66 -0
  885. package/dist/src/utils/workspaceContext.js +171 -0
  886. package/dist/src/utils/workspaceContext.js.map +1 -0
  887. package/dist/src/utils/workspaceContext.test.d.ts +6 -0
  888. package/dist/src/utils/workspaceContext.test.js +318 -0
  889. package/dist/src/utils/workspaceContext.test.js.map +1 -0
  890. package/dist/src/utils/yaml-parser.d.ts +29 -0
  891. package/dist/src/utils/yaml-parser.js +172 -0
  892. package/dist/src/utils/yaml-parser.js.map +1 -0
  893. package/dist/src/utils/yaml-parser.test.d.ts +6 -0
  894. package/dist/src/utils/yaml-parser.test.js +170 -0
  895. package/dist/src/utils/yaml-parser.test.js.map +1 -0
  896. package/dist/tsconfig.tsbuildinfo +1 -0
  897. package/package.json +89 -0
@@ -0,0 +1,674 @@
1
+ /**
2
+ * @license
3
+ * Copyright 2025 Google LLC
4
+ * SPDX-License-Identifier: Apache-2.0
5
+ */
6
+ import { describe, it, expect, vi, beforeEach } from 'vitest';
7
+ import { Config, ApprovalMode } from './config.js';
8
+ import * as path from 'node:path';
9
+ import { setGeminiMdFilename as mockSetGeminiMdFilename } from '../tools/memoryTool.js';
10
+ import { DEFAULT_TELEMETRY_TARGET, DEFAULT_OTLP_ENDPOINT, } from '../telemetry/index.js';
11
+ import { AuthType, createContentGeneratorConfig, } from '../core/contentGenerator.js';
12
+ import { GeminiClient } from '../core/client.js';
13
+ import { GitService } from '../services/gitService.js';
14
+ vi.mock('fs', async (importOriginal) => {
15
+ const actual = await importOriginal();
16
+ return {
17
+ ...actual,
18
+ existsSync: vi.fn().mockReturnValue(true),
19
+ statSync: vi.fn().mockReturnValue({
20
+ isDirectory: vi.fn().mockReturnValue(true),
21
+ }),
22
+ realpathSync: vi.fn((path) => path),
23
+ };
24
+ });
25
+ import { ShellTool } from '../tools/shell.js';
26
+ import { ReadFileTool } from '../tools/read-file.js';
27
+ vi.mock('fs', async (importOriginal) => {
28
+ const actual = await importOriginal();
29
+ return {
30
+ ...actual,
31
+ existsSync: vi.fn().mockReturnValue(true),
32
+ statSync: vi.fn().mockReturnValue({
33
+ isDirectory: vi.fn().mockReturnValue(true),
34
+ }),
35
+ realpathSync: vi.fn((path) => path),
36
+ };
37
+ });
38
+ // Mock dependencies that might be called during Config construction or createServerConfig
39
+ vi.mock('../tools/tool-registry', () => {
40
+ const ToolRegistryMock = vi.fn();
41
+ ToolRegistryMock.prototype.registerTool = vi.fn();
42
+ ToolRegistryMock.prototype.discoverAllTools = vi.fn();
43
+ ToolRegistryMock.prototype.getAllTools = vi.fn(() => []); // Mock methods if needed
44
+ ToolRegistryMock.prototype.getTool = vi.fn();
45
+ ToolRegistryMock.prototype.getFunctionDeclarations = vi.fn(() => []);
46
+ return { ToolRegistry: ToolRegistryMock };
47
+ });
48
+ vi.mock('../utils/memoryDiscovery.js', () => ({
49
+ loadServerHierarchicalMemory: vi.fn(),
50
+ }));
51
+ // Mock individual tools if their constructors are complex or have side effects
52
+ vi.mock('../tools/ls');
53
+ vi.mock('../tools/read-file');
54
+ vi.mock('../tools/grep');
55
+ vi.mock('../tools/glob');
56
+ vi.mock('../tools/edit');
57
+ vi.mock('../tools/shell');
58
+ vi.mock('../tools/write-file');
59
+ vi.mock('../tools/web-fetch');
60
+ vi.mock('../tools/read-many-files');
61
+ vi.mock('../tools/memoryTool', () => ({
62
+ MemoryTool: vi.fn(),
63
+ setGeminiMdFilename: vi.fn(),
64
+ getCurrentGeminiMdFilename: vi.fn(() => 'BLACKBOX.md'), // Mock the original filename
65
+ DEFAULT_CONTEXT_FILENAME: 'BLACKBOX.md',
66
+ GEMINI_CONFIG_DIR: '.gemini',
67
+ }));
68
+ vi.mock('../core/contentGenerator.js', async (importOriginal) => {
69
+ const actual = await importOriginal();
70
+ return {
71
+ ...actual,
72
+ createContentGeneratorConfig: vi.fn(),
73
+ };
74
+ });
75
+ vi.mock('../core/client.js', () => ({
76
+ GeminiClient: vi.fn().mockImplementation(() => ({
77
+ initialize: vi.fn().mockResolvedValue(undefined),
78
+ })),
79
+ }));
80
+ vi.mock('../telemetry/index.js', async (importOriginal) => {
81
+ const actual = await importOriginal();
82
+ return {
83
+ ...actual,
84
+ initializeTelemetry: vi.fn(),
85
+ };
86
+ });
87
+ vi.mock('../services/gitService.js', () => {
88
+ const GitServiceMock = vi.fn();
89
+ GitServiceMock.prototype.initialize = vi.fn();
90
+ return { GitService: GitServiceMock };
91
+ });
92
+ vi.mock('../ide/ide-client.js', () => ({
93
+ IdeClient: {
94
+ getInstance: vi.fn().mockResolvedValue({
95
+ getConnectionStatus: vi.fn(),
96
+ initialize: vi.fn(),
97
+ shutdown: vi.fn(),
98
+ }),
99
+ },
100
+ }));
101
+ describe('Server Config (config.ts)', () => {
102
+ const MODEL = 'gemini-pro';
103
+ const SANDBOX = {
104
+ command: 'docker',
105
+ image: 'blackbox-cli-sandbox',
106
+ };
107
+ const TARGET_DIR = '/path/to/target';
108
+ const DEBUG_MODE = false;
109
+ const QUESTION = 'test question';
110
+ const FULL_CONTEXT = false;
111
+ const USER_MEMORY = 'Test User Memory';
112
+ const TELEMETRY_SETTINGS = { enabled: false };
113
+ const EMBEDDING_MODEL = 'gemini-embedding';
114
+ const SESSION_ID = 'test-session-id';
115
+ const baseParams = {
116
+ cwd: '/tmp',
117
+ embeddingModel: EMBEDDING_MODEL,
118
+ sandbox: SANDBOX,
119
+ targetDir: TARGET_DIR,
120
+ debugMode: DEBUG_MODE,
121
+ question: QUESTION,
122
+ fullContext: FULL_CONTEXT,
123
+ userMemory: USER_MEMORY,
124
+ telemetry: TELEMETRY_SETTINGS,
125
+ sessionId: SESSION_ID,
126
+ model: MODEL,
127
+ usageStatisticsEnabled: false,
128
+ };
129
+ beforeEach(() => {
130
+ // Reset mocks if necessary
131
+ vi.clearAllMocks();
132
+ });
133
+ describe('initialize', () => {
134
+ it('should throw an error if checkpointing is enabled and GitService fails', async () => {
135
+ const gitError = new Error('Git is not installed');
136
+ GitService.prototype.initialize.mockRejectedValue(gitError);
137
+ const config = new Config({
138
+ ...baseParams,
139
+ checkpointing: true,
140
+ });
141
+ await expect(config.initialize()).rejects.toThrow(gitError);
142
+ });
143
+ it('should not throw an error if checkpointing is disabled and GitService fails', async () => {
144
+ const gitError = new Error('Git is not installed');
145
+ GitService.prototype.initialize.mockRejectedValue(gitError);
146
+ const config = new Config({
147
+ ...baseParams,
148
+ checkpointing: false,
149
+ });
150
+ await expect(config.initialize()).resolves.toBeUndefined();
151
+ });
152
+ it('should throw an error if initialized more than once', async () => {
153
+ const config = new Config({
154
+ ...baseParams,
155
+ checkpointing: false,
156
+ });
157
+ await expect(config.initialize()).resolves.toBeUndefined();
158
+ await expect(config.initialize()).rejects.toThrow('Config was already initialized');
159
+ });
160
+ });
161
+ describe('refreshAuth', () => {
162
+ it('should refresh auth and update config', async () => {
163
+ const config = new Config(baseParams);
164
+ const authType = AuthType.USE_GEMINI;
165
+ const newModel = 'gemini-flash';
166
+ const mockContentConfig = {
167
+ model: newModel,
168
+ apiKey: 'test-key',
169
+ };
170
+ createContentGeneratorConfig.mockReturnValue(mockContentConfig);
171
+ // Set fallback mode to true to ensure it gets reset
172
+ config.setFallbackMode(true);
173
+ expect(config.isInFallbackMode()).toBe(true);
174
+ await config.refreshAuth(authType);
175
+ expect(createContentGeneratorConfig).toHaveBeenCalledWith(config, authType);
176
+ // Verify that contentGeneratorConfig is updated with the new model
177
+ expect(config.getContentGeneratorConfig()).toEqual(mockContentConfig);
178
+ expect(config.getContentGeneratorConfig().model).toBe(newModel);
179
+ expect(config.getModel()).toBe(newModel); // getModel() should return the updated model
180
+ expect(GeminiClient).toHaveBeenCalledWith(config);
181
+ // Verify that fallback mode is reset
182
+ expect(config.isInFallbackMode()).toBe(false);
183
+ });
184
+ it('should preserve conversation history when refreshing auth', async () => {
185
+ const config = new Config(baseParams);
186
+ const authType = AuthType.USE_GEMINI;
187
+ const mockContentConfig = {
188
+ model: 'gemini-pro',
189
+ apiKey: 'test-key',
190
+ };
191
+ createContentGeneratorConfig.mockReturnValue(mockContentConfig);
192
+ // Mock the existing client with some history
193
+ const mockExistingHistory = [
194
+ { role: 'user', parts: [{ text: 'Hello' }] },
195
+ { role: 'model', parts: [{ text: 'Hi there!' }] },
196
+ { role: 'user', parts: [{ text: 'How are you?' }] },
197
+ ];
198
+ const mockExistingClient = {
199
+ isInitialized: vi.fn().mockReturnValue(true),
200
+ getHistory: vi.fn().mockReturnValue(mockExistingHistory),
201
+ };
202
+ const mockNewClient = {
203
+ isInitialized: vi.fn().mockReturnValue(true),
204
+ getHistory: vi.fn().mockReturnValue([]),
205
+ setHistory: vi.fn(),
206
+ initialize: vi.fn().mockResolvedValue(undefined),
207
+ };
208
+ // Set the existing client
209
+ config.geminiClient = mockExistingClient;
210
+ GeminiClient.mockImplementation(() => mockNewClient);
211
+ await config.refreshAuth(authType);
212
+ // Verify that existing history was retrieved
213
+ expect(mockExistingClient.getHistory).toHaveBeenCalled();
214
+ // Verify that new client was created and initialized
215
+ expect(GeminiClient).toHaveBeenCalledWith(config);
216
+ expect(mockNewClient.initialize).toHaveBeenCalledWith(mockContentConfig);
217
+ // Verify that history was restored to the new client
218
+ expect(mockNewClient.setHistory).toHaveBeenCalledWith(mockExistingHistory, { stripThoughts: false });
219
+ });
220
+ it('should handle case when no existing client is initialized', async () => {
221
+ const config = new Config(baseParams);
222
+ const authType = AuthType.USE_GEMINI;
223
+ const mockContentConfig = {
224
+ model: 'gemini-pro',
225
+ apiKey: 'test-key',
226
+ };
227
+ createContentGeneratorConfig.mockReturnValue(mockContentConfig);
228
+ const mockNewClient = {
229
+ isInitialized: vi.fn().mockReturnValue(true),
230
+ getHistory: vi.fn().mockReturnValue([]),
231
+ setHistory: vi.fn(),
232
+ initialize: vi.fn().mockResolvedValue(undefined),
233
+ };
234
+ // No existing client
235
+ config.geminiClient = null;
236
+ GeminiClient.mockImplementation(() => mockNewClient);
237
+ await config.refreshAuth(authType);
238
+ // Verify that new client was created and initialized
239
+ expect(GeminiClient).toHaveBeenCalledWith(config);
240
+ expect(mockNewClient.initialize).toHaveBeenCalledWith(mockContentConfig);
241
+ // Verify that setHistory was not called since there was no existing history
242
+ expect(mockNewClient.setHistory).not.toHaveBeenCalled();
243
+ });
244
+ it('should strip thoughts when switching from GenAI to Vertex', async () => {
245
+ const config = new Config(baseParams);
246
+ const mockContentConfig = {
247
+ model: 'gemini-pro',
248
+ apiKey: 'test-key',
249
+ authType: AuthType.USE_GEMINI,
250
+ };
251
+ config.contentGeneratorConfig = mockContentConfig;
252
+ createContentGeneratorConfig.mockReturnValue({
253
+ ...mockContentConfig,
254
+ authType: AuthType.LOGIN_WITH_GOOGLE,
255
+ });
256
+ const mockExistingHistory = [
257
+ { role: 'user', parts: [{ text: 'Hello' }] },
258
+ ];
259
+ const mockExistingClient = {
260
+ isInitialized: vi.fn().mockReturnValue(true),
261
+ getHistory: vi.fn().mockReturnValue(mockExistingHistory),
262
+ };
263
+ const mockNewClient = {
264
+ isInitialized: vi.fn().mockReturnValue(true),
265
+ getHistory: vi.fn().mockReturnValue([]),
266
+ setHistory: vi.fn(),
267
+ initialize: vi.fn().mockResolvedValue(undefined),
268
+ };
269
+ config.geminiClient = mockExistingClient;
270
+ GeminiClient.mockImplementation(() => mockNewClient);
271
+ await config.refreshAuth(AuthType.LOGIN_WITH_GOOGLE);
272
+ expect(mockNewClient.setHistory).toHaveBeenCalledWith(mockExistingHistory, { stripThoughts: true });
273
+ });
274
+ it('should not strip thoughts when switching from Vertex to GenAI', async () => {
275
+ const config = new Config(baseParams);
276
+ const mockContentConfig = {
277
+ model: 'gemini-pro',
278
+ apiKey: 'test-key',
279
+ authType: AuthType.LOGIN_WITH_GOOGLE,
280
+ };
281
+ config.contentGeneratorConfig = mockContentConfig;
282
+ createContentGeneratorConfig.mockReturnValue({
283
+ ...mockContentConfig,
284
+ authType: AuthType.USE_GEMINI,
285
+ });
286
+ const mockExistingHistory = [
287
+ { role: 'user', parts: [{ text: 'Hello' }] },
288
+ ];
289
+ const mockExistingClient = {
290
+ isInitialized: vi.fn().mockReturnValue(true),
291
+ getHistory: vi.fn().mockReturnValue(mockExistingHistory),
292
+ };
293
+ const mockNewClient = {
294
+ isInitialized: vi.fn().mockReturnValue(true),
295
+ getHistory: vi.fn().mockReturnValue([]),
296
+ setHistory: vi.fn(),
297
+ initialize: vi.fn().mockResolvedValue(undefined),
298
+ };
299
+ config.geminiClient = mockExistingClient;
300
+ GeminiClient.mockImplementation(() => mockNewClient);
301
+ await config.refreshAuth(AuthType.USE_GEMINI);
302
+ expect(mockNewClient.setHistory).toHaveBeenCalledWith(mockExistingHistory, { stripThoughts: false });
303
+ });
304
+ });
305
+ it('Config constructor should store userMemory correctly', () => {
306
+ const config = new Config(baseParams);
307
+ expect(config.getUserMemory()).toBe(USER_MEMORY);
308
+ // Verify other getters if needed
309
+ expect(config.getTargetDir()).toBe(path.resolve(TARGET_DIR)); // Check resolved path
310
+ });
311
+ it('Config constructor should default userMemory to empty string if not provided', () => {
312
+ const paramsWithoutMemory = { ...baseParams };
313
+ delete paramsWithoutMemory.userMemory;
314
+ const config = new Config(paramsWithoutMemory);
315
+ expect(config.getUserMemory()).toBe('');
316
+ });
317
+ it('Config constructor should call setGeminiMdFilename with contextFileName if provided', () => {
318
+ const contextFileName = 'CUSTOM_AGENTS.md';
319
+ const paramsWithContextFile = {
320
+ ...baseParams,
321
+ contextFileName,
322
+ };
323
+ new Config(paramsWithContextFile);
324
+ expect(mockSetGeminiMdFilename).toHaveBeenCalledWith(contextFileName);
325
+ });
326
+ it('Config constructor should not call setGeminiMdFilename if contextFileName is not provided', () => {
327
+ new Config(baseParams); // baseParams does not have contextFileName
328
+ expect(mockSetGeminiMdFilename).not.toHaveBeenCalled();
329
+ });
330
+ it('should set default file filtering settings when not provided', () => {
331
+ const config = new Config(baseParams);
332
+ expect(config.getFileFilteringRespectGitIgnore()).toBe(true);
333
+ });
334
+ it('should set custom file filtering settings when provided', () => {
335
+ const paramsWithFileFiltering = {
336
+ ...baseParams,
337
+ fileFiltering: {
338
+ respectGitIgnore: false,
339
+ },
340
+ };
341
+ const config = new Config(paramsWithFileFiltering);
342
+ expect(config.getFileFilteringRespectGitIgnore()).toBe(false);
343
+ });
344
+ it('should initialize WorkspaceContext with includeDirectories', () => {
345
+ const includeDirectories = ['/path/to/dir1', '/path/to/dir2'];
346
+ const paramsWithIncludeDirs = {
347
+ ...baseParams,
348
+ includeDirectories,
349
+ };
350
+ const config = new Config(paramsWithIncludeDirs);
351
+ const workspaceContext = config.getWorkspaceContext();
352
+ const directories = workspaceContext.getDirectories();
353
+ // Should include the target directory plus the included directories
354
+ expect(directories).toHaveLength(3);
355
+ expect(directories).toContain(path.resolve(baseParams.targetDir));
356
+ expect(directories).toContain('/path/to/dir1');
357
+ expect(directories).toContain('/path/to/dir2');
358
+ });
359
+ it('Config constructor should set telemetry to true when provided as true', () => {
360
+ const paramsWithTelemetry = {
361
+ ...baseParams,
362
+ telemetry: { enabled: true },
363
+ };
364
+ const config = new Config(paramsWithTelemetry);
365
+ expect(config.getTelemetryEnabled()).toBe(true);
366
+ });
367
+ it('Config constructor should set telemetry to false when provided as false', () => {
368
+ const paramsWithTelemetry = {
369
+ ...baseParams,
370
+ telemetry: { enabled: false },
371
+ };
372
+ const config = new Config(paramsWithTelemetry);
373
+ expect(config.getTelemetryEnabled()).toBe(false);
374
+ });
375
+ it('Config constructor should default telemetry to default value if not provided', () => {
376
+ const paramsWithoutTelemetry = { ...baseParams };
377
+ delete paramsWithoutTelemetry.telemetry;
378
+ const config = new Config(paramsWithoutTelemetry);
379
+ expect(config.getTelemetryEnabled()).toBe(TELEMETRY_SETTINGS.enabled);
380
+ });
381
+ it('should have a getFileService method that returns FileDiscoveryService', () => {
382
+ const config = new Config(baseParams);
383
+ const fileService = config.getFileService();
384
+ expect(fileService).toBeDefined();
385
+ });
386
+ describe('Usage Statistics', () => {
387
+ it('defaults usage statistics to enabled if not specified', () => {
388
+ const config = new Config({
389
+ ...baseParams,
390
+ usageStatisticsEnabled: undefined,
391
+ });
392
+ expect(config.getUsageStatisticsEnabled()).toBe(true);
393
+ });
394
+ it.each([{ enabled: true }, { enabled: false }])('sets usage statistics based on the provided value (enabled: $enabled)', ({ enabled }) => {
395
+ const config = new Config({
396
+ ...baseParams,
397
+ usageStatisticsEnabled: enabled,
398
+ });
399
+ expect(config.getUsageStatisticsEnabled()).toBe(enabled);
400
+ });
401
+ });
402
+ describe('Telemetry Settings', () => {
403
+ it('should return default telemetry target if not provided', () => {
404
+ const params = {
405
+ ...baseParams,
406
+ telemetry: { enabled: true },
407
+ };
408
+ const config = new Config(params);
409
+ expect(config.getTelemetryTarget()).toBe(DEFAULT_TELEMETRY_TARGET);
410
+ });
411
+ it('should return provided OTLP endpoint', () => {
412
+ const endpoint = 'http://custom.otel.collector:4317';
413
+ const params = {
414
+ ...baseParams,
415
+ telemetry: { enabled: true, otlpEndpoint: endpoint },
416
+ };
417
+ const config = new Config(params);
418
+ expect(config.getTelemetryOtlpEndpoint()).toBe(endpoint);
419
+ });
420
+ it('should return default OTLP endpoint if not provided', () => {
421
+ const params = {
422
+ ...baseParams,
423
+ telemetry: { enabled: true },
424
+ };
425
+ const config = new Config(params);
426
+ expect(config.getTelemetryOtlpEndpoint()).toBe(DEFAULT_OTLP_ENDPOINT);
427
+ });
428
+ it('should return provided logPrompts setting', () => {
429
+ const params = {
430
+ ...baseParams,
431
+ telemetry: { enabled: true, logPrompts: false },
432
+ };
433
+ const config = new Config(params);
434
+ expect(config.getTelemetryLogPromptsEnabled()).toBe(false);
435
+ });
436
+ it('should return default logPrompts setting (true) if not provided', () => {
437
+ const params = {
438
+ ...baseParams,
439
+ telemetry: { enabled: true },
440
+ };
441
+ const config = new Config(params);
442
+ expect(config.getTelemetryLogPromptsEnabled()).toBe(true);
443
+ });
444
+ it('should return default logPrompts setting (true) if telemetry object is not provided', () => {
445
+ const paramsWithoutTelemetry = { ...baseParams };
446
+ delete paramsWithoutTelemetry.telemetry;
447
+ const config = new Config(paramsWithoutTelemetry);
448
+ expect(config.getTelemetryLogPromptsEnabled()).toBe(true);
449
+ });
450
+ it('should return default telemetry target if telemetry object is not provided', () => {
451
+ const paramsWithoutTelemetry = { ...baseParams };
452
+ delete paramsWithoutTelemetry.telemetry;
453
+ const config = new Config(paramsWithoutTelemetry);
454
+ expect(config.getTelemetryTarget()).toBe(DEFAULT_TELEMETRY_TARGET);
455
+ });
456
+ it('should return default OTLP endpoint if telemetry object is not provided', () => {
457
+ const paramsWithoutTelemetry = { ...baseParams };
458
+ delete paramsWithoutTelemetry.telemetry;
459
+ const config = new Config(paramsWithoutTelemetry);
460
+ expect(config.getTelemetryOtlpEndpoint()).toBe(DEFAULT_OTLP_ENDPOINT);
461
+ });
462
+ it('should return provided OTLP protocol', () => {
463
+ const params = {
464
+ ...baseParams,
465
+ telemetry: { enabled: true, otlpProtocol: 'http' },
466
+ };
467
+ const config = new Config(params);
468
+ expect(config.getTelemetryOtlpProtocol()).toBe('http');
469
+ });
470
+ it('should return default OTLP protocol if not provided', () => {
471
+ const params = {
472
+ ...baseParams,
473
+ telemetry: { enabled: true },
474
+ };
475
+ const config = new Config(params);
476
+ expect(config.getTelemetryOtlpProtocol()).toBe('grpc');
477
+ });
478
+ it('should return default OTLP protocol if telemetry object is not provided', () => {
479
+ const paramsWithoutTelemetry = { ...baseParams };
480
+ delete paramsWithoutTelemetry.telemetry;
481
+ const config = new Config(paramsWithoutTelemetry);
482
+ expect(config.getTelemetryOtlpProtocol()).toBe('grpc');
483
+ });
484
+ });
485
+ describe('UseRipgrep Configuration', () => {
486
+ it('should default useRipgrep to false when not provided', () => {
487
+ const config = new Config(baseParams);
488
+ expect(config.getUseRipgrep()).toBe(false);
489
+ });
490
+ it('should set useRipgrep to true when provided as true', () => {
491
+ const paramsWithRipgrep = {
492
+ ...baseParams,
493
+ useRipgrep: true,
494
+ };
495
+ const config = new Config(paramsWithRipgrep);
496
+ expect(config.getUseRipgrep()).toBe(true);
497
+ });
498
+ it('should set useRipgrep to false when explicitly provided as false', () => {
499
+ const paramsWithRipgrep = {
500
+ ...baseParams,
501
+ useRipgrep: false,
502
+ };
503
+ const config = new Config(paramsWithRipgrep);
504
+ expect(config.getUseRipgrep()).toBe(false);
505
+ });
506
+ it('should default useRipgrep to false when undefined', () => {
507
+ const paramsWithUndefinedRipgrep = {
508
+ ...baseParams,
509
+ useRipgrep: undefined,
510
+ };
511
+ const config = new Config(paramsWithUndefinedRipgrep);
512
+ expect(config.getUseRipgrep()).toBe(false);
513
+ });
514
+ });
515
+ describe('createToolRegistry', () => {
516
+ it('should register a tool if coreTools contains an argument-specific pattern', async () => {
517
+ const params = {
518
+ ...baseParams,
519
+ coreTools: ['ShellTool(git status)'],
520
+ };
521
+ const config = new Config(params);
522
+ await config.initialize();
523
+ // The ToolRegistry class is mocked, so we can inspect its prototype's methods.
524
+ const registerToolMock = (await vi.importMock('../tools/tool-registry')).ToolRegistry.prototype.registerTool;
525
+ // Check that registerTool was called for ShellTool
526
+ const wasShellToolRegistered = registerToolMock.mock.calls.some((call) => call[0] instanceof vi.mocked(ShellTool));
527
+ expect(wasShellToolRegistered).toBe(true);
528
+ // Check that registerTool was NOT called for ReadFileTool
529
+ const wasReadFileToolRegistered = registerToolMock.mock.calls.some((call) => call[0] instanceof vi.mocked(ReadFileTool));
530
+ expect(wasReadFileToolRegistered).toBe(false);
531
+ });
532
+ });
533
+ });
534
+ describe('setApprovalMode with folder trust', () => {
535
+ it('should throw an error when setting YOLO mode in an untrusted folder', () => {
536
+ const config = new Config({
537
+ sessionId: 'test',
538
+ targetDir: '.',
539
+ debugMode: false,
540
+ model: 'test-model',
541
+ cwd: '.',
542
+ trustedFolder: false, // Untrusted
543
+ });
544
+ expect(() => config.setApprovalMode(ApprovalMode.YOLO)).toThrow('Cannot enable privileged approval modes in an untrusted folder.');
545
+ });
546
+ it('should throw an error when setting AUTO_EDIT mode in an untrusted folder', () => {
547
+ const config = new Config({
548
+ sessionId: 'test',
549
+ targetDir: '.',
550
+ debugMode: false,
551
+ model: 'test-model',
552
+ cwd: '.',
553
+ trustedFolder: false, // Untrusted
554
+ });
555
+ expect(() => config.setApprovalMode(ApprovalMode.AUTO_EDIT)).toThrow('Cannot enable privileged approval modes in an untrusted folder.');
556
+ });
557
+ it('should NOT throw an error when setting DEFAULT mode in an untrusted folder', () => {
558
+ const config = new Config({
559
+ sessionId: 'test',
560
+ targetDir: '.',
561
+ debugMode: false,
562
+ model: 'test-model',
563
+ cwd: '.',
564
+ trustedFolder: false, // Untrusted
565
+ });
566
+ expect(() => config.setApprovalMode(ApprovalMode.DEFAULT)).not.toThrow();
567
+ });
568
+ it('should NOT throw an error when setting PLAN mode in an untrusted folder', () => {
569
+ const config = new Config({
570
+ sessionId: 'test',
571
+ targetDir: '.',
572
+ debugMode: false,
573
+ model: 'test-model',
574
+ cwd: '.',
575
+ trustedFolder: false, // Untrusted
576
+ });
577
+ expect(() => config.setApprovalMode(ApprovalMode.PLAN)).not.toThrow();
578
+ });
579
+ it('should NOT throw an error when setting any mode in a trusted folder', () => {
580
+ const config = new Config({
581
+ sessionId: 'test',
582
+ targetDir: '.',
583
+ debugMode: false,
584
+ model: 'test-model',
585
+ cwd: '.',
586
+ trustedFolder: true, // Trusted
587
+ });
588
+ expect(() => config.setApprovalMode(ApprovalMode.YOLO)).not.toThrow();
589
+ expect(() => config.setApprovalMode(ApprovalMode.AUTO_EDIT)).not.toThrow();
590
+ expect(() => config.setApprovalMode(ApprovalMode.DEFAULT)).not.toThrow();
591
+ expect(() => config.setApprovalMode(ApprovalMode.PLAN)).not.toThrow();
592
+ });
593
+ it('should NOT throw an error when setting any mode if trustedFolder is undefined', () => {
594
+ const config = new Config({
595
+ sessionId: 'test',
596
+ targetDir: '.',
597
+ debugMode: false,
598
+ model: 'test-model',
599
+ cwd: '.',
600
+ trustedFolder: undefined, // Undefined
601
+ });
602
+ expect(() => config.setApprovalMode(ApprovalMode.YOLO)).not.toThrow();
603
+ expect(() => config.setApprovalMode(ApprovalMode.AUTO_EDIT)).not.toThrow();
604
+ expect(() => config.setApprovalMode(ApprovalMode.DEFAULT)).not.toThrow();
605
+ expect(() => config.setApprovalMode(ApprovalMode.PLAN)).not.toThrow();
606
+ });
607
+ describe('Model Switch Logging', () => {
608
+ it('should log model switch when setModel is called with different model', async () => {
609
+ const config = new Config({
610
+ sessionId: 'test-model-switch',
611
+ targetDir: '.',
612
+ debugMode: false,
613
+ model: 'blackbox3-coder-plus',
614
+ cwd: '.',
615
+ });
616
+ // Initialize the config to set up content generator
617
+ await config.initialize();
618
+ // Mock the logger's logModelSwitch method
619
+ const logModelSwitchSpy = vi.spyOn(config['logger'], 'logModelSwitch');
620
+ // Change the model
621
+ await config.setModel('blackbox-vl-max-latest', {
622
+ reason: 'vision_auto_switch',
623
+ context: 'Test model switch',
624
+ });
625
+ // Verify that logModelSwitch was called with correct parameters
626
+ expect(logModelSwitchSpy).toHaveBeenCalledWith({
627
+ fromModel: 'blackbox3-coder-plus',
628
+ toModel: 'blackbox-vl-max-latest',
629
+ reason: 'vision_auto_switch',
630
+ context: 'Test model switch',
631
+ });
632
+ });
633
+ it('should not log when setModel is called with same model', async () => {
634
+ const config = new Config({
635
+ sessionId: 'test-same-model',
636
+ targetDir: '.',
637
+ debugMode: false,
638
+ model: 'blackbox3-coder-plus',
639
+ cwd: '.',
640
+ });
641
+ // Initialize the config to set up content generator
642
+ await config.initialize();
643
+ // Mock the logger's logModelSwitch method
644
+ const logModelSwitchSpy = vi.spyOn(config['logger'], 'logModelSwitch');
645
+ // Set the same model
646
+ await config.setModel('blackbox3-coder-plus');
647
+ // Verify that logModelSwitch was not called
648
+ expect(logModelSwitchSpy).not.toHaveBeenCalled();
649
+ });
650
+ it('should use default reason when no options provided', async () => {
651
+ const config = new Config({
652
+ sessionId: 'test-default-reason',
653
+ targetDir: '.',
654
+ debugMode: false,
655
+ model: 'blackbox3-coder-plus',
656
+ cwd: '.',
657
+ });
658
+ // Initialize the config to set up content generator
659
+ await config.initialize();
660
+ // Mock the logger's logModelSwitch method
661
+ const logModelSwitchSpy = vi.spyOn(config['logger'], 'logModelSwitch');
662
+ // Change the model without options
663
+ await config.setModel('blackbox-vl-max-latest');
664
+ // Verify that logModelSwitch was called with default reason
665
+ expect(logModelSwitchSpy).toHaveBeenCalledWith({
666
+ fromModel: 'blackbox3-coder-plus',
667
+ toModel: 'blackbox-vl-max-latest',
668
+ reason: 'manual',
669
+ context: undefined,
670
+ });
671
+ });
672
+ });
673
+ });
674
+ //# sourceMappingURL=config.test.js.map