@anh3d0nic/qwen-code-termux-ice 21.0.1 → 21.2.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 (1281) hide show
  1. package/bin/qwen-ice +127 -331
  2. package/core/ice-core.js +101 -0
  3. package/core-dist/index.d.ts +6 -0
  4. package/core-dist/index.js +7 -0
  5. package/core-dist/index.js.map +1 -0
  6. package/core-dist/src/__mocks__/fs/promises.d.ts +11 -0
  7. package/core-dist/src/__mocks__/fs/promises.js +17 -0
  8. package/core-dist/src/__mocks__/fs/promises.js.map +1 -0
  9. package/core-dist/src/config/config.d.ts +648 -0
  10. package/core-dist/src/config/config.js +1374 -0
  11. package/core-dist/src/config/config.js.map +1 -0
  12. package/core-dist/src/config/config.test.d.ts +6 -0
  13. package/core-dist/src/config/config.test.js +1116 -0
  14. package/core-dist/src/config/config.test.js.map +1 -0
  15. package/core-dist/src/config/constants.d.ts +11 -0
  16. package/core-dist/src/config/constants.js +16 -0
  17. package/core-dist/src/config/constants.js.map +1 -0
  18. package/core-dist/src/config/models.d.ts +9 -0
  19. package/core-dist/src/config/models.js +10 -0
  20. package/core-dist/src/config/models.js.map +1 -0
  21. package/core-dist/src/config/storage.d.ts +38 -0
  22. package/core-dist/src/config/storage.js +114 -0
  23. package/core-dist/src/config/storage.js.map +1 -0
  24. package/core-dist/src/config/storage.test.d.ts +6 -0
  25. package/core-dist/src/config/storage.test.js +36 -0
  26. package/core-dist/src/config/storage.test.js.map +1 -0
  27. package/core-dist/src/confirmation-bus/message-bus.d.ts +22 -0
  28. package/core-dist/src/confirmation-bus/message-bus.js +98 -0
  29. package/core-dist/src/confirmation-bus/message-bus.js.map +1 -0
  30. package/core-dist/src/confirmation-bus/types.d.ts +104 -0
  31. package/core-dist/src/confirmation-bus/types.js +16 -0
  32. package/core-dist/src/confirmation-bus/types.js.map +1 -0
  33. package/core-dist/src/core/__tests__/openaiTimeoutHandling.test.d.ts +6 -0
  34. package/core-dist/src/core/__tests__/openaiTimeoutHandling.test.js +298 -0
  35. package/core-dist/src/core/__tests__/openaiTimeoutHandling.test.js.map +1 -0
  36. package/core-dist/src/core/__tests__/orphanedToolCallsTest.d.ts +64 -0
  37. package/core-dist/src/core/__tests__/orphanedToolCallsTest.js +122 -0
  38. package/core-dist/src/core/__tests__/orphanedToolCallsTest.js.map +1 -0
  39. package/core-dist/src/core/anthropicContentGenerator/anthropicContentGenerator.d.ts +28 -0
  40. package/core-dist/src/core/anthropicContentGenerator/anthropicContentGenerator.js +349 -0
  41. package/core-dist/src/core/anthropicContentGenerator/anthropicContentGenerator.js.map +1 -0
  42. package/core-dist/src/core/anthropicContentGenerator/anthropicContentGenerator.test.d.ts +6 -0
  43. package/core-dist/src/core/anthropicContentGenerator/anthropicContentGenerator.test.js +396 -0
  44. package/core-dist/src/core/anthropicContentGenerator/anthropicContentGenerator.test.js.map +1 -0
  45. package/core-dist/src/core/anthropicContentGenerator/converter.d.ts +48 -0
  46. package/core-dist/src/core/anthropicContentGenerator/converter.js +449 -0
  47. package/core-dist/src/core/anthropicContentGenerator/converter.js.map +1 -0
  48. package/core-dist/src/core/anthropicContentGenerator/converter.test.d.ts +6 -0
  49. package/core-dist/src/core/anthropicContentGenerator/converter.test.js +843 -0
  50. package/core-dist/src/core/anthropicContentGenerator/converter.test.js.map +1 -0
  51. package/core-dist/src/core/anthropicContentGenerator/index.d.ts +9 -0
  52. package/core-dist/src/core/anthropicContentGenerator/index.js +11 -0
  53. package/core-dist/src/core/anthropicContentGenerator/index.js.map +1 -0
  54. package/core-dist/src/core/baseLlmClient.d.ts +48 -0
  55. package/core-dist/src/core/baseLlmClient.js +98 -0
  56. package/core-dist/src/core/baseLlmClient.js.map +1 -0
  57. package/core-dist/src/core/baseLlmClient.test.d.ts +6 -0
  58. package/core-dist/src/core/baseLlmClient.test.js +319 -0
  59. package/core-dist/src/core/baseLlmClient.test.js.map +1 -0
  60. package/core-dist/src/core/client.d.ts +48 -0
  61. package/core-dist/src/core/client.js +547 -0
  62. package/core-dist/src/core/client.js.map +1 -0
  63. package/core-dist/src/core/client.test.d.ts +6 -0
  64. package/core-dist/src/core/client.test.js +1885 -0
  65. package/core-dist/src/core/client.test.js.map +1 -0
  66. package/core-dist/src/core/contentGenerator.d.ts +100 -0
  67. package/core-dist/src/core/contentGenerator.js +162 -0
  68. package/core-dist/src/core/contentGenerator.js.map +1 -0
  69. package/core-dist/src/core/contentGenerator.test.d.ts +6 -0
  70. package/core-dist/src/core/contentGenerator.test.js +95 -0
  71. package/core-dist/src/core/contentGenerator.test.js.map +1 -0
  72. package/core-dist/src/core/coreToolScheduler.d.ts +142 -0
  73. package/core-dist/src/core/coreToolScheduler.js +872 -0
  74. package/core-dist/src/core/coreToolScheduler.js.map +1 -0
  75. package/core-dist/src/core/coreToolScheduler.test.d.ts +6 -0
  76. package/core-dist/src/core/coreToolScheduler.test.js +2221 -0
  77. package/core-dist/src/core/coreToolScheduler.test.js.map +1 -0
  78. package/core-dist/src/core/geminiChat.d.ts +122 -0
  79. package/core-dist/src/core/geminiChat.js +571 -0
  80. package/core-dist/src/core/geminiChat.js.map +1 -0
  81. package/core-dist/src/core/geminiChat.test.d.ts +6 -0
  82. package/core-dist/src/core/geminiChat.test.js +1276 -0
  83. package/core-dist/src/core/geminiChat.test.js.map +1 -0
  84. package/core-dist/src/core/geminiContentGenerator/geminiContentGenerator.d.ts +38 -0
  85. package/core-dist/src/core/geminiContentGenerator/geminiContentGenerator.js +193 -0
  86. package/core-dist/src/core/geminiContentGenerator/geminiContentGenerator.js.map +1 -0
  87. package/core-dist/src/core/geminiContentGenerator/geminiContentGenerator.test.d.ts +6 -0
  88. package/core-dist/src/core/geminiContentGenerator/geminiContentGenerator.test.js +304 -0
  89. package/core-dist/src/core/geminiContentGenerator/geminiContentGenerator.test.js.map +1 -0
  90. package/core-dist/src/core/geminiContentGenerator/index.d.ts +12 -0
  91. package/core-dist/src/core/geminiContentGenerator/index.js +36 -0
  92. package/core-dist/src/core/geminiContentGenerator/index.js.map +1 -0
  93. package/core-dist/src/core/geminiContentGenerator/index.test.d.ts +6 -0
  94. package/core-dist/src/core/geminiContentGenerator/index.test.js +34 -0
  95. package/core-dist/src/core/geminiContentGenerator/index.test.js.map +1 -0
  96. package/core-dist/src/core/geminiRequest.d.ts +13 -0
  97. package/core-dist/src/core/geminiRequest.js +11 -0
  98. package/core-dist/src/core/geminiRequest.js.map +1 -0
  99. package/core-dist/src/core/geminiRequest.test.d.ts +6 -0
  100. package/core-dist/src/core/geminiRequest.test.js +73 -0
  101. package/core-dist/src/core/geminiRequest.test.js.map +1 -0
  102. package/core-dist/src/core/logger.d.ts +68 -0
  103. package/core-dist/src/core/logger.js +364 -0
  104. package/core-dist/src/core/logger.js.map +1 -0
  105. package/core-dist/src/core/logger.test.d.ts +6 -0
  106. package/core-dist/src/core/logger.test.js +520 -0
  107. package/core-dist/src/core/logger.test.js.map +1 -0
  108. package/core-dist/src/core/loggingContentGenerator/index.d.ts +6 -0
  109. package/core-dist/src/core/loggingContentGenerator/index.js +7 -0
  110. package/core-dist/src/core/loggingContentGenerator/index.js.map +1 -0
  111. package/core-dist/src/core/loggingContentGenerator/loggingContentGenerator.d.ts +36 -0
  112. package/core-dist/src/core/loggingContentGenerator/loggingContentGenerator.js +321 -0
  113. package/core-dist/src/core/loggingContentGenerator/loggingContentGenerator.js.map +1 -0
  114. package/core-dist/src/core/loggingContentGenerator/loggingContentGenerator.test.d.ts +6 -0
  115. package/core-dist/src/core/loggingContentGenerator/loggingContentGenerator.test.js +287 -0
  116. package/core-dist/src/core/loggingContentGenerator/loggingContentGenerator.test.js.map +1 -0
  117. package/core-dist/src/core/modalityDefaults.d.ts +14 -0
  118. package/core-dist/src/core/modalityDefaults.js +81 -0
  119. package/core-dist/src/core/modalityDefaults.js.map +1 -0
  120. package/core-dist/src/core/modalityDefaults.test.d.ts +6 -0
  121. package/core-dist/src/core/modalityDefaults.test.js +181 -0
  122. package/core-dist/src/core/modalityDefaults.test.js.map +1 -0
  123. package/core-dist/src/core/nonInteractiveToolExecutor.d.ts +16 -0
  124. package/core-dist/src/core/nonInteractiveToolExecutor.js +30 -0
  125. package/core-dist/src/core/nonInteractiveToolExecutor.js.map +1 -0
  126. package/core-dist/src/core/nonInteractiveToolExecutor.test.d.ts +6 -0
  127. package/core-dist/src/core/nonInteractiveToolExecutor.test.js +296 -0
  128. package/core-dist/src/core/nonInteractiveToolExecutor.test.js.map +1 -0
  129. package/core-dist/src/core/openaiContentGenerator/constants.d.ts +6 -0
  130. package/core-dist/src/core/openaiContentGenerator/constants.js +7 -0
  131. package/core-dist/src/core/openaiContentGenerator/constants.js.map +1 -0
  132. package/core-dist/src/core/openaiContentGenerator/converter.d.ts +133 -0
  133. package/core-dist/src/core/openaiContentGenerator/converter.js +1020 -0
  134. package/core-dist/src/core/openaiContentGenerator/converter.js.map +1 -0
  135. package/core-dist/src/core/openaiContentGenerator/converter.test.d.ts +6 -0
  136. package/core-dist/src/core/openaiContentGenerator/converter.test.js +1966 -0
  137. package/core-dist/src/core/openaiContentGenerator/converter.test.js.map +1 -0
  138. package/core-dist/src/core/openaiContentGenerator/errorHandler.d.ts +27 -0
  139. package/core-dist/src/core/openaiContentGenerator/errorHandler.js +84 -0
  140. package/core-dist/src/core/openaiContentGenerator/errorHandler.js.map +1 -0
  141. package/core-dist/src/core/openaiContentGenerator/errorHandler.test.d.ts +6 -0
  142. package/core-dist/src/core/openaiContentGenerator/errorHandler.test.js +267 -0
  143. package/core-dist/src/core/openaiContentGenerator/errorHandler.test.js.map +1 -0
  144. package/core-dist/src/core/openaiContentGenerator/index.d.ts +21 -0
  145. package/core-dist/src/core/openaiContentGenerator/index.js +43 -0
  146. package/core-dist/src/core/openaiContentGenerator/index.js.map +1 -0
  147. package/core-dist/src/core/openaiContentGenerator/openaiContentGenerator.d.ts +22 -0
  148. package/core-dist/src/core/openaiContentGenerator/openaiContentGenerator.js +117 -0
  149. package/core-dist/src/core/openaiContentGenerator/openaiContentGenerator.js.map +1 -0
  150. package/core-dist/src/core/openaiContentGenerator/openaiContentGenerator.test.d.ts +6 -0
  151. package/core-dist/src/core/openaiContentGenerator/openaiContentGenerator.test.js +298 -0
  152. package/core-dist/src/core/openaiContentGenerator/openaiContentGenerator.test.js.map +1 -0
  153. package/core-dist/src/core/openaiContentGenerator/pipeline.d.ts +74 -0
  154. package/core-dist/src/core/openaiContentGenerator/pipeline.js +327 -0
  155. package/core-dist/src/core/openaiContentGenerator/pipeline.js.map +1 -0
  156. package/core-dist/src/core/openaiContentGenerator/pipeline.test.d.ts +6 -0
  157. package/core-dist/src/core/openaiContentGenerator/pipeline.test.js +1143 -0
  158. package/core-dist/src/core/openaiContentGenerator/pipeline.test.js.map +1 -0
  159. package/core-dist/src/core/openaiContentGenerator/provider/README.md +61 -0
  160. package/core-dist/src/core/openaiContentGenerator/provider/dashscope.d.ts +70 -0
  161. package/core-dist/src/core/openaiContentGenerator/provider/dashscope.js +258 -0
  162. package/core-dist/src/core/openaiContentGenerator/provider/dashscope.js.map +1 -0
  163. package/core-dist/src/core/openaiContentGenerator/provider/dashscope.test.d.ts +6 -0
  164. package/core-dist/src/core/openaiContentGenerator/provider/dashscope.test.js +781 -0
  165. package/core-dist/src/core/openaiContentGenerator/provider/dashscope.test.js.map +1 -0
  166. package/core-dist/src/core/openaiContentGenerator/provider/deepseek.d.ts +14 -0
  167. package/core-dist/src/core/openaiContentGenerator/provider/deepseek.js +21 -0
  168. package/core-dist/src/core/openaiContentGenerator/provider/deepseek.js.map +1 -0
  169. package/core-dist/src/core/openaiContentGenerator/provider/deepseek.test.d.ts +6 -0
  170. package/core-dist/src/core/openaiContentGenerator/provider/deepseek.test.js +51 -0
  171. package/core-dist/src/core/openaiContentGenerator/provider/deepseek.test.js.map +1 -0
  172. package/core-dist/src/core/openaiContentGenerator/provider/default.d.ts +17 -0
  173. package/core-dist/src/core/openaiContentGenerator/provider/default.js +52 -0
  174. package/core-dist/src/core/openaiContentGenerator/provider/default.js.map +1 -0
  175. package/core-dist/src/core/openaiContentGenerator/provider/default.test.d.ts +6 -0
  176. package/core-dist/src/core/openaiContentGenerator/provider/default.test.js +227 -0
  177. package/core-dist/src/core/openaiContentGenerator/provider/default.test.js.map +1 -0
  178. package/core-dist/src/core/openaiContentGenerator/provider/index.d.ts +6 -0
  179. package/core-dist/src/core/openaiContentGenerator/provider/index.js +6 -0
  180. package/core-dist/src/core/openaiContentGenerator/provider/index.js.map +1 -0
  181. package/core-dist/src/core/openaiContentGenerator/provider/modelscope.d.ts +17 -0
  182. package/core-dist/src/core/openaiContentGenerator/provider/modelscope.js +25 -0
  183. package/core-dist/src/core/openaiContentGenerator/provider/modelscope.js.map +1 -0
  184. package/core-dist/src/core/openaiContentGenerator/provider/modelscope.test.d.ts +6 -0
  185. package/core-dist/src/core/openaiContentGenerator/provider/modelscope.test.js +66 -0
  186. package/core-dist/src/core/openaiContentGenerator/provider/modelscope.test.js.map +1 -0
  187. package/core-dist/src/core/openaiContentGenerator/provider/openrouter.d.ts +8 -0
  188. package/core-dist/src/core/openaiContentGenerator/provider/openrouter.js +21 -0
  189. package/core-dist/src/core/openaiContentGenerator/provider/openrouter.js.map +1 -0
  190. package/core-dist/src/core/openaiContentGenerator/provider/openrouter.test.d.ts +6 -0
  191. package/core-dist/src/core/openaiContentGenerator/provider/openrouter.test.js +152 -0
  192. package/core-dist/src/core/openaiContentGenerator/provider/openrouter.test.js.map +1 -0
  193. package/core-dist/src/core/openaiContentGenerator/provider/types.d.ts +26 -0
  194. package/core-dist/src/core/openaiContentGenerator/provider/types.js +2 -0
  195. package/core-dist/src/core/openaiContentGenerator/provider/types.js.map +1 -0
  196. package/core-dist/src/core/openaiContentGenerator/streamingToolCallParser.d.ts +157 -0
  197. package/core-dist/src/core/openaiContentGenerator/streamingToolCallParser.js +390 -0
  198. package/core-dist/src/core/openaiContentGenerator/streamingToolCallParser.js.map +1 -0
  199. package/core-dist/src/core/openaiContentGenerator/streamingToolCallParser.test.d.ts +6 -0
  200. package/core-dist/src/core/openaiContentGenerator/streamingToolCallParser.test.js +585 -0
  201. package/core-dist/src/core/openaiContentGenerator/streamingToolCallParser.test.js.map +1 -0
  202. package/core-dist/src/core/prompts.d.ts +81 -0
  203. package/core-dist/src/core/prompts.js +996 -0
  204. package/core-dist/src/core/prompts.js.map +1 -0
  205. package/core-dist/src/core/prompts.test.d.ts +6 -0
  206. package/core-dist/src/core/prompts.test.js +485 -0
  207. package/core-dist/src/core/prompts.test.js.map +1 -0
  208. package/core-dist/src/core/tokenLimits.d.ts +29 -0
  209. package/core-dist/src/core/tokenLimits.js +171 -0
  210. package/core-dist/src/core/tokenLimits.js.map +1 -0
  211. package/core-dist/src/core/tokenLimits.test.d.ts +1 -0
  212. package/core-dist/src/core/tokenLimits.test.js +270 -0
  213. package/core-dist/src/core/tokenLimits.test.js.map +1 -0
  214. package/core-dist/src/core/turn.d.ts +161 -0
  215. package/core-dist/src/core/turn.js +197 -0
  216. package/core-dist/src/core/turn.js.map +1 -0
  217. package/core-dist/src/core/turn.test.d.ts +6 -0
  218. package/core-dist/src/core/turn.test.js +817 -0
  219. package/core-dist/src/core/turn.test.js.map +1 -0
  220. package/core-dist/src/extension/claude-converter.d.ts +121 -0
  221. package/core-dist/src/extension/claude-converter.js +572 -0
  222. package/core-dist/src/extension/claude-converter.js.map +1 -0
  223. package/core-dist/src/extension/claude-converter.test.d.ts +6 -0
  224. package/core-dist/src/extension/claude-converter.test.js +305 -0
  225. package/core-dist/src/extension/claude-converter.test.js.map +1 -0
  226. package/core-dist/src/extension/extensionManager.d.ts +159 -0
  227. package/core-dist/src/extension/extensionManager.js +829 -0
  228. package/core-dist/src/extension/extensionManager.js.map +1 -0
  229. package/core-dist/src/extension/extensionManager.test.d.ts +6 -0
  230. package/core-dist/src/extension/extensionManager.test.js +598 -0
  231. package/core-dist/src/extension/extensionManager.test.js.map +1 -0
  232. package/core-dist/src/extension/extensionSettings.d.ts +33 -0
  233. package/core-dist/src/extension/extensionSettings.js +186 -0
  234. package/core-dist/src/extension/extensionSettings.js.map +1 -0
  235. package/core-dist/src/extension/extensionSettings.test.d.ts +1 -0
  236. package/core-dist/src/extension/extensionSettings.test.js +488 -0
  237. package/core-dist/src/extension/extensionSettings.test.js.map +1 -0
  238. package/core-dist/src/extension/gemini-converter.d.ts +47 -0
  239. package/core-dist/src/extension/gemini-converter.js +185 -0
  240. package/core-dist/src/extension/gemini-converter.js.map +1 -0
  241. package/core-dist/src/extension/gemini-converter.test.d.ts +6 -0
  242. package/core-dist/src/extension/gemini-converter.test.js +128 -0
  243. package/core-dist/src/extension/gemini-converter.test.js.map +1 -0
  244. package/core-dist/src/extension/github.d.ts +30 -0
  245. package/core-dist/src/extension/github.js +330 -0
  246. package/core-dist/src/extension/github.js.map +1 -0
  247. package/core-dist/src/extension/github.test.d.ts +6 -0
  248. package/core-dist/src/extension/github.test.js +376 -0
  249. package/core-dist/src/extension/github.test.js.map +1 -0
  250. package/core-dist/src/extension/index.d.ts +6 -0
  251. package/core-dist/src/extension/index.js +7 -0
  252. package/core-dist/src/extension/index.js.map +1 -0
  253. package/core-dist/src/extension/marketplace.d.ts +19 -0
  254. package/core-dist/src/extension/marketplace.js +222 -0
  255. package/core-dist/src/extension/marketplace.js.map +1 -0
  256. package/core-dist/src/extension/marketplace.test.d.ts +6 -0
  257. package/core-dist/src/extension/marketplace.test.js +215 -0
  258. package/core-dist/src/extension/marketplace.test.js.map +1 -0
  259. package/core-dist/src/extension/override.d.ts +25 -0
  260. package/core-dist/src/extension/override.js +82 -0
  261. package/core-dist/src/extension/override.js.map +1 -0
  262. package/core-dist/src/extension/override.test.d.ts +6 -0
  263. package/core-dist/src/extension/override.test.js +94 -0
  264. package/core-dist/src/extension/override.test.js.map +1 -0
  265. package/core-dist/src/extension/settings.d.ts +39 -0
  266. package/core-dist/src/extension/settings.js +116 -0
  267. package/core-dist/src/extension/settings.js.map +1 -0
  268. package/core-dist/src/extension/settings.test.d.ts +6 -0
  269. package/core-dist/src/extension/settings.test.js +125 -0
  270. package/core-dist/src/extension/settings.test.js.map +1 -0
  271. package/core-dist/src/extension/storage.d.ts +9 -0
  272. package/core-dist/src/extension/storage.js +38 -0
  273. package/core-dist/src/extension/storage.js.map +1 -0
  274. package/core-dist/src/extension/storage.test.d.ts +6 -0
  275. package/core-dist/src/extension/storage.test.js +64 -0
  276. package/core-dist/src/extension/storage.test.js.map +1 -0
  277. package/core-dist/src/extension/variableSchema.d.ts +40 -0
  278. package/core-dist/src/extension/variableSchema.js +26 -0
  279. package/core-dist/src/extension/variableSchema.js.map +1 -0
  280. package/core-dist/src/extension/variables.d.ts +21 -0
  281. package/core-dist/src/extension/variables.js +46 -0
  282. package/core-dist/src/extension/variables.js.map +1 -0
  283. package/core-dist/src/extension/variables.test.d.ts +6 -0
  284. package/core-dist/src/extension/variables.test.js +17 -0
  285. package/core-dist/src/extension/variables.test.js.map +1 -0
  286. package/core-dist/src/hooks/hookAggregator.d.ts +66 -0
  287. package/core-dist/src/hooks/hookAggregator.js +280 -0
  288. package/core-dist/src/hooks/hookAggregator.js.map +1 -0
  289. package/core-dist/src/hooks/hookAggregator.test.d.ts +6 -0
  290. package/core-dist/src/hooks/hookAggregator.test.js +449 -0
  291. package/core-dist/src/hooks/hookAggregator.test.js.map +1 -0
  292. package/core-dist/src/hooks/hookEventHandler.d.ts +42 -0
  293. package/core-dist/src/hooks/hookEventHandler.js +127 -0
  294. package/core-dist/src/hooks/hookEventHandler.js.map +1 -0
  295. package/core-dist/src/hooks/hookEventHandler.test.d.ts +6 -0
  296. package/core-dist/src/hooks/hookEventHandler.test.js +183 -0
  297. package/core-dist/src/hooks/hookEventHandler.test.js.map +1 -0
  298. package/core-dist/src/hooks/hookPlanner.d.ts +42 -0
  299. package/core-dist/src/hooks/hookPlanner.js +101 -0
  300. package/core-dist/src/hooks/hookPlanner.js.map +1 -0
  301. package/core-dist/src/hooks/hookPlanner.test.d.ts +6 -0
  302. package/core-dist/src/hooks/hookPlanner.test.js +303 -0
  303. package/core-dist/src/hooks/hookPlanner.test.js.map +1 -0
  304. package/core-dist/src/hooks/hookRegistry.d.ts +106 -0
  305. package/core-dist/src/hooks/hookRegistry.js +225 -0
  306. package/core-dist/src/hooks/hookRegistry.js.map +1 -0
  307. package/core-dist/src/hooks/hookRegistry.test.d.ts +6 -0
  308. package/core-dist/src/hooks/hookRegistry.test.js +539 -0
  309. package/core-dist/src/hooks/hookRegistry.test.js.map +1 -0
  310. package/core-dist/src/hooks/hookRunner.d.ts +40 -0
  311. package/core-dist/src/hooks/hookRunner.js +318 -0
  312. package/core-dist/src/hooks/hookRunner.js.map +1 -0
  313. package/core-dist/src/hooks/hookRunner.test.d.ts +6 -0
  314. package/core-dist/src/hooks/hookRunner.test.js +466 -0
  315. package/core-dist/src/hooks/hookRunner.test.js.map +1 -0
  316. package/core-dist/src/hooks/hookSystem.d.ts +43 -0
  317. package/core-dist/src/hooks/hookSystem.js +75 -0
  318. package/core-dist/src/hooks/hookSystem.js.map +1 -0
  319. package/core-dist/src/hooks/hookSystem.test.d.ts +6 -0
  320. package/core-dist/src/hooks/hookSystem.test.js +237 -0
  321. package/core-dist/src/hooks/hookSystem.test.js.map +1 -0
  322. package/core-dist/src/hooks/index.d.ts +16 -0
  323. package/core-dist/src/hooks/index.js +16 -0
  324. package/core-dist/src/hooks/index.js.map +1 -0
  325. package/core-dist/src/hooks/trustedHooks.d.ts +28 -0
  326. package/core-dist/src/hooks/trustedHooks.js +91 -0
  327. package/core-dist/src/hooks/trustedHooks.js.map +1 -0
  328. package/core-dist/src/hooks/types.d.ts +498 -0
  329. package/core-dist/src/hooks/types.js +292 -0
  330. package/core-dist/src/hooks/types.js.map +1 -0
  331. package/core-dist/src/ide/constants.d.ts +9 -0
  332. package/core-dist/src/ide/constants.js +10 -0
  333. package/core-dist/src/ide/constants.js.map +1 -0
  334. package/core-dist/src/ide/detect-ide.d.ts +56 -0
  335. package/core-dist/src/ide/detect-ide.js +68 -0
  336. package/core-dist/src/ide/detect-ide.js.map +1 -0
  337. package/core-dist/src/ide/detect-ide.test.d.ts +6 -0
  338. package/core-dist/src/ide/detect-ide.test.js +113 -0
  339. package/core-dist/src/ide/detect-ide.test.js.map +1 -0
  340. package/core-dist/src/ide/ide-client.d.ts +132 -0
  341. package/core-dist/src/ide/ide-client.js +750 -0
  342. package/core-dist/src/ide/ide-client.js.map +1 -0
  343. package/core-dist/src/ide/ide-client.test.d.ts +6 -0
  344. package/core-dist/src/ide/ide-client.test.js +463 -0
  345. package/core-dist/src/ide/ide-client.test.js.map +1 -0
  346. package/core-dist/src/ide/ide-installer.d.ts +14 -0
  347. package/core-dist/src/ide/ide-installer.js +112 -0
  348. package/core-dist/src/ide/ide-installer.js.map +1 -0
  349. package/core-dist/src/ide/ide-installer.test.d.ts +6 -0
  350. package/core-dist/src/ide/ide-installer.test.js +134 -0
  351. package/core-dist/src/ide/ide-installer.test.js.map +1 -0
  352. package/core-dist/src/ide/ideContext.d.ts +44 -0
  353. package/core-dist/src/ide/ideContext.js +101 -0
  354. package/core-dist/src/ide/ideContext.js.map +1 -0
  355. package/core-dist/src/ide/ideContext.test.d.ts +6 -0
  356. package/core-dist/src/ide/ideContext.test.js +393 -0
  357. package/core-dist/src/ide/ideContext.test.js.map +1 -0
  358. package/core-dist/src/ide/process-utils.d.ts +21 -0
  359. package/core-dist/src/ide/process-utils.js +170 -0
  360. package/core-dist/src/ide/process-utils.js.map +1 -0
  361. package/core-dist/src/ide/process-utils.test.d.ts +6 -0
  362. package/core-dist/src/ide/process-utils.test.js +130 -0
  363. package/core-dist/src/ide/process-utils.test.js.map +1 -0
  364. package/core-dist/src/ide/types.d.ts +486 -0
  365. package/core-dist/src/ide/types.js +138 -0
  366. package/core-dist/src/ide/types.js.map +1 -0
  367. package/core-dist/src/index.d.ts +179 -0
  368. package/core-dist/src/index.js +225 -0
  369. package/core-dist/src/index.js.map +1 -0
  370. package/core-dist/src/index.test.d.ts +6 -0
  371. package/core-dist/src/index.test.js +12 -0
  372. package/core-dist/src/index.test.js.map +1 -0
  373. package/core-dist/src/lsp/LspConfigLoader.d.ts +46 -0
  374. package/core-dist/src/lsp/LspConfigLoader.js +381 -0
  375. package/core-dist/src/lsp/LspConfigLoader.js.map +1 -0
  376. package/core-dist/src/lsp/LspConfigLoader.test.d.ts +6 -0
  377. package/core-dist/src/lsp/LspConfigLoader.test.js +80 -0
  378. package/core-dist/src/lsp/LspConfigLoader.test.js.map +1 -0
  379. package/core-dist/src/lsp/LspConnectionFactory.d.ts +62 -0
  380. package/core-dist/src/lsp/LspConnectionFactory.js +305 -0
  381. package/core-dist/src/lsp/LspConnectionFactory.js.map +1 -0
  382. package/core-dist/src/lsp/LspLanguageDetector.d.ts +39 -0
  383. package/core-dist/src/lsp/LspLanguageDetector.js +199 -0
  384. package/core-dist/src/lsp/LspLanguageDetector.js.map +1 -0
  385. package/core-dist/src/lsp/LspResponseNormalizer.d.ts +122 -0
  386. package/core-dist/src/lsp/LspResponseNormalizer.js +710 -0
  387. package/core-dist/src/lsp/LspResponseNormalizer.js.map +1 -0
  388. package/core-dist/src/lsp/LspServerManager.d.ts +87 -0
  389. package/core-dist/src/lsp/LspServerManager.js +563 -0
  390. package/core-dist/src/lsp/LspServerManager.js.map +1 -0
  391. package/core-dist/src/lsp/NativeLspClient.d.ts +149 -0
  392. package/core-dist/src/lsp/NativeLspClient.js +169 -0
  393. package/core-dist/src/lsp/NativeLspClient.js.map +1 -0
  394. package/core-dist/src/lsp/NativeLspService.d.ts +106 -0
  395. package/core-dist/src/lsp/NativeLspService.integration.test.d.ts +6 -0
  396. package/core-dist/src/lsp/NativeLspService.integration.test.js +663 -0
  397. package/core-dist/src/lsp/NativeLspService.integration.test.js.map +1 -0
  398. package/core-dist/src/lsp/NativeLspService.js +623 -0
  399. package/core-dist/src/lsp/NativeLspService.js.map +1 -0
  400. package/core-dist/src/lsp/NativeLspService.test.d.ts +6 -0
  401. package/core-dist/src/lsp/NativeLspService.test.js +99 -0
  402. package/core-dist/src/lsp/NativeLspService.test.js.map +1 -0
  403. package/core-dist/src/lsp/constants.d.ts +35 -0
  404. package/core-dist/src/lsp/constants.js +86 -0
  405. package/core-dist/src/lsp/constants.js.map +1 -0
  406. package/core-dist/src/lsp/types.d.ts +409 -0
  407. package/core-dist/src/lsp/types.js +7 -0
  408. package/core-dist/src/lsp/types.js.map +1 -0
  409. package/core-dist/src/mcp/constants.d.ts +22 -0
  410. package/core-dist/src/mcp/constants.js +23 -0
  411. package/core-dist/src/mcp/constants.js.map +1 -0
  412. package/core-dist/src/mcp/google-auth-provider.d.ts +23 -0
  413. package/core-dist/src/mcp/google-auth-provider.js +75 -0
  414. package/core-dist/src/mcp/google-auth-provider.js.map +1 -0
  415. package/core-dist/src/mcp/google-auth-provider.test.d.ts +6 -0
  416. package/core-dist/src/mcp/google-auth-provider.test.js +89 -0
  417. package/core-dist/src/mcp/google-auth-provider.test.js.map +1 -0
  418. package/core-dist/src/mcp/oauth-provider.d.ts +150 -0
  419. package/core-dist/src/mcp/oauth-provider.js +617 -0
  420. package/core-dist/src/mcp/oauth-provider.js.map +1 -0
  421. package/core-dist/src/mcp/oauth-provider.test.d.ts +6 -0
  422. package/core-dist/src/mcp/oauth-provider.test.js +917 -0
  423. package/core-dist/src/mcp/oauth-provider.test.js.map +1 -0
  424. package/core-dist/src/mcp/oauth-token-storage.d.ts +65 -0
  425. package/core-dist/src/mcp/oauth-token-storage.js +182 -0
  426. package/core-dist/src/mcp/oauth-token-storage.js.map +1 -0
  427. package/core-dist/src/mcp/oauth-token-storage.test.d.ts +6 -0
  428. package/core-dist/src/mcp/oauth-token-storage.test.js +307 -0
  429. package/core-dist/src/mcp/oauth-token-storage.test.js.map +1 -0
  430. package/core-dist/src/mcp/oauth-utils.d.ts +124 -0
  431. package/core-dist/src/mcp/oauth-utils.js +252 -0
  432. package/core-dist/src/mcp/oauth-utils.js.map +1 -0
  433. package/core-dist/src/mcp/oauth-utils.test.d.ts +6 -0
  434. package/core-dist/src/mcp/oauth-utils.test.js +220 -0
  435. package/core-dist/src/mcp/oauth-utils.test.js.map +1 -0
  436. package/core-dist/src/mcp/sa-impersonation-provider.d.ts +33 -0
  437. package/core-dist/src/mcp/sa-impersonation-provider.js +133 -0
  438. package/core-dist/src/mcp/sa-impersonation-provider.js.map +1 -0
  439. package/core-dist/src/mcp/sa-impersonation-provider.test.d.ts +6 -0
  440. package/core-dist/src/mcp/sa-impersonation-provider.test.js +117 -0
  441. package/core-dist/src/mcp/sa-impersonation-provider.test.js.map +1 -0
  442. package/core-dist/src/mcp/token-storage/base-token-storage.d.ts +19 -0
  443. package/core-dist/src/mcp/token-storage/base-token-storage.js +36 -0
  444. package/core-dist/src/mcp/token-storage/base-token-storage.js.map +1 -0
  445. package/core-dist/src/mcp/token-storage/base-token-storage.test.d.ts +6 -0
  446. package/core-dist/src/mcp/token-storage/base-token-storage.test.js +160 -0
  447. package/core-dist/src/mcp/token-storage/base-token-storage.test.js.map +1 -0
  448. package/core-dist/src/mcp/token-storage/file-token-storage.d.ts +24 -0
  449. package/core-dist/src/mcp/token-storage/file-token-storage.js +144 -0
  450. package/core-dist/src/mcp/token-storage/file-token-storage.js.map +1 -0
  451. package/core-dist/src/mcp/token-storage/file-token-storage.test.d.ts +6 -0
  452. package/core-dist/src/mcp/token-storage/file-token-storage.test.js +235 -0
  453. package/core-dist/src/mcp/token-storage/file-token-storage.test.js.map +1 -0
  454. package/core-dist/src/mcp/token-storage/hybrid-token-storage.d.ts +23 -0
  455. package/core-dist/src/mcp/token-storage/hybrid-token-storage.js +78 -0
  456. package/core-dist/src/mcp/token-storage/hybrid-token-storage.js.map +1 -0
  457. package/core-dist/src/mcp/token-storage/hybrid-token-storage.test.d.ts +6 -0
  458. package/core-dist/src/mcp/token-storage/hybrid-token-storage.test.js +193 -0
  459. package/core-dist/src/mcp/token-storage/hybrid-token-storage.test.js.map +1 -0
  460. package/core-dist/src/mcp/token-storage/index.d.ts +11 -0
  461. package/core-dist/src/mcp/token-storage/index.js +12 -0
  462. package/core-dist/src/mcp/token-storage/index.js.map +1 -0
  463. package/core-dist/src/mcp/token-storage/keychain-token-storage.d.ts +35 -0
  464. package/core-dist/src/mcp/token-storage/keychain-token-storage.js +248 -0
  465. package/core-dist/src/mcp/token-storage/keychain-token-storage.js.map +1 -0
  466. package/core-dist/src/mcp/token-storage/keychain-token-storage.test.d.ts +6 -0
  467. package/core-dist/src/mcp/token-storage/keychain-token-storage.test.js +254 -0
  468. package/core-dist/src/mcp/token-storage/keychain-token-storage.test.js.map +1 -0
  469. package/core-dist/src/mcp/token-storage/types.d.ts +38 -0
  470. package/core-dist/src/mcp/token-storage/types.js +11 -0
  471. package/core-dist/src/mcp/token-storage/types.js.map +1 -0
  472. package/core-dist/src/mocks/msw.d.ts +6 -0
  473. package/core-dist/src/mocks/msw.js +8 -0
  474. package/core-dist/src/mocks/msw.js.map +1 -0
  475. package/core-dist/src/models/constants.d.ts +71 -0
  476. package/core-dist/src/models/constants.js +92 -0
  477. package/core-dist/src/models/constants.js.map +1 -0
  478. package/core-dist/src/models/index.d.ts +10 -0
  479. package/core-dist/src/models/index.js +12 -0
  480. package/core-dist/src/models/index.js.map +1 -0
  481. package/core-dist/src/models/modelConfigErrors.d.ts +46 -0
  482. package/core-dist/src/models/modelConfigErrors.js +87 -0
  483. package/core-dist/src/models/modelConfigErrors.js.map +1 -0
  484. package/core-dist/src/models/modelConfigResolver.d.ts +84 -0
  485. package/core-dist/src/models/modelConfigResolver.js +204 -0
  486. package/core-dist/src/models/modelConfigResolver.js.map +1 -0
  487. package/core-dist/src/models/modelConfigResolver.test.d.ts +6 -0
  488. package/core-dist/src/models/modelConfigResolver.test.js +302 -0
  489. package/core-dist/src/models/modelConfigResolver.test.js.map +1 -0
  490. package/core-dist/src/models/modelRegistry.d.ts +55 -0
  491. package/core-dist/src/models/modelRegistry.js +182 -0
  492. package/core-dist/src/models/modelRegistry.js.map +1 -0
  493. package/core-dist/src/models/modelRegistry.test.d.ts +6 -0
  494. package/core-dist/src/models/modelRegistry.test.js +408 -0
  495. package/core-dist/src/models/modelRegistry.test.js.map +1 -0
  496. package/core-dist/src/models/modelsConfig.d.ts +343 -0
  497. package/core-dist/src/models/modelsConfig.js +957 -0
  498. package/core-dist/src/models/modelsConfig.js.map +1 -0
  499. package/core-dist/src/models/modelsConfig.test.d.ts +6 -0
  500. package/core-dist/src/models/modelsConfig.test.js +1242 -0
  501. package/core-dist/src/models/modelsConfig.test.js.map +1 -0
  502. package/core-dist/src/models/types.d.ts +114 -0
  503. package/core-dist/src/models/types.js +7 -0
  504. package/core-dist/src/models/types.js.map +1 -0
  505. package/core-dist/src/output/json-formatter.d.ts +11 -0
  506. package/core-dist/src/output/json-formatter.js +30 -0
  507. package/core-dist/src/output/json-formatter.js.map +1 -0
  508. package/core-dist/src/output/json-formatter.test.d.ts +6 -0
  509. package/core-dist/src/output/json-formatter.test.js +266 -0
  510. package/core-dist/src/output/json-formatter.test.js.map +1 -0
  511. package/core-dist/src/output/types.d.ts +25 -0
  512. package/core-dist/src/output/types.js +17 -0
  513. package/core-dist/src/output/types.js.map +1 -0
  514. package/core-dist/src/prompts/mcp-prompts.d.ts +8 -0
  515. package/core-dist/src/prompts/mcp-prompts.js +13 -0
  516. package/core-dist/src/prompts/mcp-prompts.js.map +1 -0
  517. package/core-dist/src/prompts/prompt-registry.d.ts +34 -0
  518. package/core-dist/src/prompts/prompt-registry.js +65 -0
  519. package/core-dist/src/prompts/prompt-registry.js.map +1 -0
  520. package/core-dist/src/qwen/qwenContentGenerator.d.ts +71 -0
  521. package/core-dist/src/qwen/qwenContentGenerator.js +182 -0
  522. package/core-dist/src/qwen/qwenContentGenerator.js.map +1 -0
  523. package/core-dist/src/qwen/qwenContentGenerator.test.d.ts +6 -0
  524. package/core-dist/src/qwen/qwenContentGenerator.test.js +1175 -0
  525. package/core-dist/src/qwen/qwenContentGenerator.test.js.map +1 -0
  526. package/core-dist/src/qwen/qwenOAuth2.d.ts +195 -0
  527. package/core-dist/src/qwen/qwenOAuth2.js +677 -0
  528. package/core-dist/src/qwen/qwenOAuth2.js.map +1 -0
  529. package/core-dist/src/qwen/qwenOAuth2.test.d.ts +6 -0
  530. package/core-dist/src/qwen/qwenOAuth2.test.js +1621 -0
  531. package/core-dist/src/qwen/qwenOAuth2.test.js.map +1 -0
  532. package/core-dist/src/qwen/sharedTokenManager.d.ts +196 -0
  533. package/core-dist/src/qwen/sharedTokenManager.js +649 -0
  534. package/core-dist/src/qwen/sharedTokenManager.js.map +1 -0
  535. package/core-dist/src/qwen/sharedTokenManager.test.d.ts +7 -0
  536. package/core-dist/src/qwen/sharedTokenManager.test.js +662 -0
  537. package/core-dist/src/qwen/sharedTokenManager.test.js.map +1 -0
  538. package/core-dist/src/services/chatCompressionService.d.ts +32 -0
  539. package/core-dist/src/services/chatCompressionService.js +213 -0
  540. package/core-dist/src/services/chatCompressionService.js.map +1 -0
  541. package/core-dist/src/services/chatCompressionService.test.d.ts +6 -0
  542. package/core-dist/src/services/chatCompressionService.test.js +343 -0
  543. package/core-dist/src/services/chatCompressionService.test.js.map +1 -0
  544. package/core-dist/src/services/chatRecordingService.d.ts +215 -0
  545. package/core-dist/src/services/chatRecordingService.js +285 -0
  546. package/core-dist/src/services/chatRecordingService.js.map +1 -0
  547. package/core-dist/src/services/chatRecordingService.test.d.ts +6 -0
  548. package/core-dist/src/services/chatRecordingService.test.js +299 -0
  549. package/core-dist/src/services/chatRecordingService.test.js.map +1 -0
  550. package/core-dist/src/services/fileDiscoveryService.d.ts +45 -0
  551. package/core-dist/src/services/fileDiscoveryService.js +104 -0
  552. package/core-dist/src/services/fileDiscoveryService.js.map +1 -0
  553. package/core-dist/src/services/fileDiscoveryService.test.d.ts +6 -0
  554. package/core-dist/src/services/fileDiscoveryService.test.js +143 -0
  555. package/core-dist/src/services/fileDiscoveryService.test.js.map +1 -0
  556. package/core-dist/src/services/fileSystemService.d.ts +88 -0
  557. package/core-dist/src/services/fileSystemService.js +131 -0
  558. package/core-dist/src/services/fileSystemService.js.map +1 -0
  559. package/core-dist/src/services/fileSystemService.test.d.ts +6 -0
  560. package/core-dist/src/services/fileSystemService.test.js +216 -0
  561. package/core-dist/src/services/fileSystemService.test.js.map +1 -0
  562. package/core-dist/src/services/gitService.d.ts +22 -0
  563. package/core-dist/src/services/gitService.js +98 -0
  564. package/core-dist/src/services/gitService.js.map +1 -0
  565. package/core-dist/src/services/gitService.test.d.ts +6 -0
  566. package/core-dist/src/services/gitService.test.js +187 -0
  567. package/core-dist/src/services/gitService.test.js.map +1 -0
  568. package/core-dist/src/services/loopDetectionService.d.ts +86 -0
  569. package/core-dist/src/services/loopDetectionService.js +239 -0
  570. package/core-dist/src/services/loopDetectionService.js.map +1 -0
  571. package/core-dist/src/services/loopDetectionService.test.d.ts +6 -0
  572. package/core-dist/src/services/loopDetectionService.test.js +478 -0
  573. package/core-dist/src/services/loopDetectionService.test.js.map +1 -0
  574. package/core-dist/src/services/sessionService.d.ts +200 -0
  575. package/core-dist/src/services/sessionService.js +527 -0
  576. package/core-dist/src/services/sessionService.js.map +1 -0
  577. package/core-dist/src/services/sessionService.test.d.ts +6 -0
  578. package/core-dist/src/services/sessionService.test.js +576 -0
  579. package/core-dist/src/services/sessionService.test.js.map +1 -0
  580. package/core-dist/src/services/shellExecutionService.d.ts +104 -0
  581. package/core-dist/src/services/shellExecutionService.js +626 -0
  582. package/core-dist/src/services/shellExecutionService.js.map +1 -0
  583. package/core-dist/src/services/shellExecutionService.test.d.ts +6 -0
  584. package/core-dist/src/services/shellExecutionService.test.js +684 -0
  585. package/core-dist/src/services/shellExecutionService.test.js.map +1 -0
  586. package/core-dist/src/skills/index.d.ts +19 -0
  587. package/core-dist/src/skills/index.js +9 -0
  588. package/core-dist/src/skills/index.js.map +1 -0
  589. package/core-dist/src/skills/skill-load.d.ts +4 -0
  590. package/core-dist/src/skills/skill-load.js +137 -0
  591. package/core-dist/src/skills/skill-load.js.map +1 -0
  592. package/core-dist/src/skills/skill-load.test.d.ts +6 -0
  593. package/core-dist/src/skills/skill-load.test.js +237 -0
  594. package/core-dist/src/skills/skill-load.test.js.map +1 -0
  595. package/core-dist/src/skills/skill-manager.d.ts +134 -0
  596. package/core-dist/src/skills/skill-manager.js +505 -0
  597. package/core-dist/src/skills/skill-manager.js.map +1 -0
  598. package/core-dist/src/skills/skill-manager.test.d.ts +6 -0
  599. package/core-dist/src/skills/skill-manager.test.js +527 -0
  600. package/core-dist/src/skills/skill-manager.test.js.map +1 -0
  601. package/core-dist/src/skills/types.d.ts +88 -0
  602. package/core-dist/src/skills/types.js +29 -0
  603. package/core-dist/src/skills/types.js.map +1 -0
  604. package/core-dist/src/subagents/builtin-agents.d.ts +35 -0
  605. package/core-dist/src/subagents/builtin-agents.js +85 -0
  606. package/core-dist/src/subagents/builtin-agents.js.map +1 -0
  607. package/core-dist/src/subagents/builtin-agents.test.d.ts +6 -0
  608. package/core-dist/src/subagents/builtin-agents.test.js +78 -0
  609. package/core-dist/src/subagents/builtin-agents.test.js.map +1 -0
  610. package/core-dist/src/subagents/index.d.ts +29 -0
  611. package/core-dist/src/subagents/index.js +15 -0
  612. package/core-dist/src/subagents/index.js.map +1 -0
  613. package/core-dist/src/subagents/subagent-events.d.ts +105 -0
  614. package/core-dist/src/subagents/subagent-events.js +32 -0
  615. package/core-dist/src/subagents/subagent-events.js.map +1 -0
  616. package/core-dist/src/subagents/subagent-hooks.d.ts +29 -0
  617. package/core-dist/src/subagents/subagent-hooks.js +7 -0
  618. package/core-dist/src/subagents/subagent-hooks.js.map +1 -0
  619. package/core-dist/src/subagents/subagent-manager.d.ts +178 -0
  620. package/core-dist/src/subagents/subagent-manager.js +711 -0
  621. package/core-dist/src/subagents/subagent-manager.js.map +1 -0
  622. package/core-dist/src/subagents/subagent-manager.test.d.ts +6 -0
  623. package/core-dist/src/subagents/subagent-manager.test.js +829 -0
  624. package/core-dist/src/subagents/subagent-manager.test.js.map +1 -0
  625. package/core-dist/src/subagents/subagent-statistics.d.ts +50 -0
  626. package/core-dist/src/subagents/subagent-statistics.js +210 -0
  627. package/core-dist/src/subagents/subagent-statistics.js.map +1 -0
  628. package/core-dist/src/subagents/subagent-statistics.test.d.ts +6 -0
  629. package/core-dist/src/subagents/subagent-statistics.test.js +238 -0
  630. package/core-dist/src/subagents/subagent-statistics.test.js.map +1 -0
  631. package/core-dist/src/subagents/subagent.d.ts +167 -0
  632. package/core-dist/src/subagents/subagent.js +758 -0
  633. package/core-dist/src/subagents/subagent.js.map +1 -0
  634. package/core-dist/src/subagents/subagent.test.d.ts +6 -0
  635. package/core-dist/src/subagents/subagent.test.js +819 -0
  636. package/core-dist/src/subagents/subagent.test.js.map +1 -0
  637. package/core-dist/src/subagents/types.d.ts +224 -0
  638. package/core-dist/src/subagents/types.js +58 -0
  639. package/core-dist/src/subagents/types.js.map +1 -0
  640. package/core-dist/src/subagents/types.test.d.ts +6 -0
  641. package/core-dist/src/subagents/types.test.js +31 -0
  642. package/core-dist/src/subagents/types.test.js.map +1 -0
  643. package/core-dist/src/subagents/validation.d.ts +63 -0
  644. package/core-dist/src/subagents/validation.js +293 -0
  645. package/core-dist/src/subagents/validation.js.map +1 -0
  646. package/core-dist/src/subagents/validation.test.d.ts +6 -0
  647. package/core-dist/src/subagents/validation.test.js +330 -0
  648. package/core-dist/src/subagents/validation.test.js.map +1 -0
  649. package/core-dist/src/telemetry/config.d.ts +31 -0
  650. package/core-dist/src/telemetry/config.js +74 -0
  651. package/core-dist/src/telemetry/config.js.map +1 -0
  652. package/core-dist/src/telemetry/config.test.d.ts +6 -0
  653. package/core-dist/src/telemetry/config.test.js +124 -0
  654. package/core-dist/src/telemetry/config.test.js.map +1 -0
  655. package/core-dist/src/telemetry/constants.d.ts +39 -0
  656. package/core-dist/src/telemetry/constants.js +41 -0
  657. package/core-dist/src/telemetry/constants.js.map +1 -0
  658. package/core-dist/src/telemetry/file-exporters.d.ts +29 -0
  659. package/core-dist/src/telemetry/file-exporters.js +62 -0
  660. package/core-dist/src/telemetry/file-exporters.js.map +1 -0
  661. package/core-dist/src/telemetry/index.d.ts +25 -0
  662. package/core-dist/src/telemetry/index.js +31 -0
  663. package/core-dist/src/telemetry/index.js.map +1 -0
  664. package/core-dist/src/telemetry/integration.test.circular.d.ts +6 -0
  665. package/core-dist/src/telemetry/integration.test.circular.js +95 -0
  666. package/core-dist/src/telemetry/integration.test.circular.js.map +1 -0
  667. package/core-dist/src/telemetry/loggers.d.ts +40 -0
  668. package/core-dist/src/telemetry/loggers.js +712 -0
  669. package/core-dist/src/telemetry/loggers.js.map +1 -0
  670. package/core-dist/src/telemetry/loggers.test.circular.d.ts +6 -0
  671. package/core-dist/src/telemetry/loggers.test.circular.js +107 -0
  672. package/core-dist/src/telemetry/loggers.test.circular.js.map +1 -0
  673. package/core-dist/src/telemetry/loggers.test.d.ts +6 -0
  674. package/core-dist/src/telemetry/loggers.test.js +961 -0
  675. package/core-dist/src/telemetry/loggers.test.js.map +1 -0
  676. package/core-dist/src/telemetry/metrics.d.ts +320 -0
  677. package/core-dist/src/telemetry/metrics.js +532 -0
  678. package/core-dist/src/telemetry/metrics.js.map +1 -0
  679. package/core-dist/src/telemetry/metrics.test.d.ts +6 -0
  680. package/core-dist/src/telemetry/metrics.test.js +746 -0
  681. package/core-dist/src/telemetry/metrics.test.js.map +1 -0
  682. package/core-dist/src/telemetry/qwen-logger/event-types.d.ts +89 -0
  683. package/core-dist/src/telemetry/qwen-logger/event-types.js +2 -0
  684. package/core-dist/src/telemetry/qwen-logger/event-types.js.map +1 -0
  685. package/core-dist/src/telemetry/qwen-logger/qwen-logger.d.ts +102 -0
  686. package/core-dist/src/telemetry/qwen-logger/qwen-logger.js +739 -0
  687. package/core-dist/src/telemetry/qwen-logger/qwen-logger.js.map +1 -0
  688. package/core-dist/src/telemetry/qwen-logger/qwen-logger.test.d.ts +6 -0
  689. package/core-dist/src/telemetry/qwen-logger/qwen-logger.test.js +380 -0
  690. package/core-dist/src/telemetry/qwen-logger/qwen-logger.test.js.map +1 -0
  691. package/core-dist/src/telemetry/sdk.d.ts +9 -0
  692. package/core-dist/src/telemetry/sdk.js +163 -0
  693. package/core-dist/src/telemetry/sdk.js.map +1 -0
  694. package/core-dist/src/telemetry/sdk.test.d.ts +6 -0
  695. package/core-dist/src/telemetry/sdk.test.js +116 -0
  696. package/core-dist/src/telemetry/sdk.test.js.map +1 -0
  697. package/core-dist/src/telemetry/telemetry-utils.d.ts +6 -0
  698. package/core-dist/src/telemetry/telemetry-utils.js +14 -0
  699. package/core-dist/src/telemetry/telemetry-utils.js.map +1 -0
  700. package/core-dist/src/telemetry/telemetry-utils.test.d.ts +6 -0
  701. package/core-dist/src/telemetry/telemetry-utils.test.js +40 -0
  702. package/core-dist/src/telemetry/telemetry-utils.test.js.map +1 -0
  703. package/core-dist/src/telemetry/telemetry.test.d.ts +6 -0
  704. package/core-dist/src/telemetry/telemetry.test.js +49 -0
  705. package/core-dist/src/telemetry/telemetry.test.js.map +1 -0
  706. package/core-dist/src/telemetry/tool-call-decision.d.ts +13 -0
  707. package/core-dist/src/telemetry/tool-call-decision.js +29 -0
  708. package/core-dist/src/telemetry/tool-call-decision.js.map +1 -0
  709. package/core-dist/src/telemetry/types.d.ts +363 -0
  710. package/core-dist/src/telemetry/types.js +635 -0
  711. package/core-dist/src/telemetry/types.js.map +1 -0
  712. package/core-dist/src/telemetry/uiTelemetry.d.ts +80 -0
  713. package/core-dist/src/telemetry/uiTelemetry.js +164 -0
  714. package/core-dist/src/telemetry/uiTelemetry.js.map +1 -0
  715. package/core-dist/src/telemetry/uiTelemetry.test.d.ts +6 -0
  716. package/core-dist/src/telemetry/uiTelemetry.test.js +625 -0
  717. package/core-dist/src/telemetry/uiTelemetry.test.js.map +1 -0
  718. package/core-dist/src/test-utils/config.d.ts +17 -0
  719. package/core-dist/src/test-utils/config.js +31 -0
  720. package/core-dist/src/test-utils/config.js.map +1 -0
  721. package/core-dist/src/test-utils/index.d.ts +6 -0
  722. package/core-dist/src/test-utils/index.js +7 -0
  723. package/core-dist/src/test-utils/index.js.map +1 -0
  724. package/core-dist/src/test-utils/mock-tool.d.ts +66 -0
  725. package/core-dist/src/test-utils/mock-tool.js +121 -0
  726. package/core-dist/src/test-utils/mock-tool.js.map +1 -0
  727. package/core-dist/src/test-utils/mockWorkspaceContext.d.ts +13 -0
  728. package/core-dist/src/test-utils/mockWorkspaceContext.js +24 -0
  729. package/core-dist/src/test-utils/mockWorkspaceContext.js.map +1 -0
  730. package/core-dist/src/tools/askUserQuestion.d.ts +41 -0
  731. package/core-dist/src/tools/askUserQuestion.js +247 -0
  732. package/core-dist/src/tools/askUserQuestion.js.map +1 -0
  733. package/core-dist/src/tools/askUserQuestion.test.d.ts +6 -0
  734. package/core-dist/src/tools/askUserQuestion.test.js +218 -0
  735. package/core-dist/src/tools/askUserQuestion.test.js.map +1 -0
  736. package/core-dist/src/tools/diffOptions.d.ts +9 -0
  737. package/core-dist/src/tools/diffOptions.js +46 -0
  738. package/core-dist/src/tools/diffOptions.js.map +1 -0
  739. package/core-dist/src/tools/diffOptions.test.d.ts +6 -0
  740. package/core-dist/src/tools/diffOptions.test.js +155 -0
  741. package/core-dist/src/tools/diffOptions.test.js.map +1 -0
  742. package/core-dist/src/tools/edit.d.ts +55 -0
  743. package/core-dist/src/tools/edit.js +446 -0
  744. package/core-dist/src/tools/edit.js.map +1 -0
  745. package/core-dist/src/tools/edit.test.d.ts +6 -0
  746. package/core-dist/src/tools/edit.test.js +742 -0
  747. package/core-dist/src/tools/edit.test.js.map +1 -0
  748. package/core-dist/src/tools/exitPlanMode.d.ts +28 -0
  749. package/core-dist/src/tools/exitPlanMode.js +144 -0
  750. package/core-dist/src/tools/exitPlanMode.js.map +1 -0
  751. package/core-dist/src/tools/exitPlanMode.test.d.ts +6 -0
  752. package/core-dist/src/tools/exitPlanMode.test.js +178 -0
  753. package/core-dist/src/tools/exitPlanMode.test.js.map +1 -0
  754. package/core-dist/src/tools/glob.d.ts +44 -0
  755. package/core-dist/src/tools/glob.js +195 -0
  756. package/core-dist/src/tools/glob.js.map +1 -0
  757. package/core-dist/src/tools/glob.test.d.ts +6 -0
  758. package/core-dist/src/tools/glob.test.js +481 -0
  759. package/core-dist/src/tools/glob.test.js.map +1 -0
  760. package/core-dist/src/tools/grep.d.ts +44 -0
  761. package/core-dist/src/tools/grep.js +427 -0
  762. package/core-dist/src/tools/grep.js.map +1 -0
  763. package/core-dist/src/tools/grep.test.d.ts +6 -0
  764. package/core-dist/src/tools/grep.test.js +360 -0
  765. package/core-dist/src/tools/grep.test.js.map +1 -0
  766. package/core-dist/src/tools/ls.d.ts +68 -0
  767. package/core-dist/src/tools/ls.js +221 -0
  768. package/core-dist/src/tools/ls.js.map +1 -0
  769. package/core-dist/src/tools/ls.test.d.ts +6 -0
  770. package/core-dist/src/tools/ls.test.js +246 -0
  771. package/core-dist/src/tools/ls.test.js.map +1 -0
  772. package/core-dist/src/tools/lsp.d.ts +66 -0
  773. package/core-dist/src/tools/lsp.js +894 -0
  774. package/core-dist/src/tools/lsp.js.map +1 -0
  775. package/core-dist/src/tools/lsp.test.d.ts +6 -0
  776. package/core-dist/src/tools/lsp.test.js +960 -0
  777. package/core-dist/src/tools/lsp.test.js.map +1 -0
  778. package/core-dist/src/tools/mcp-client-manager.d.ts +110 -0
  779. package/core-dist/src/tools/mcp-client-manager.js +381 -0
  780. package/core-dist/src/tools/mcp-client-manager.js.map +1 -0
  781. package/core-dist/src/tools/mcp-client-manager.test.d.ts +6 -0
  782. package/core-dist/src/tools/mcp-client-manager.test.js +207 -0
  783. package/core-dist/src/tools/mcp-client-manager.test.js.map +1 -0
  784. package/core-dist/src/tools/mcp-client.d.ts +199 -0
  785. package/core-dist/src/tools/mcp-client.js +1001 -0
  786. package/core-dist/src/tools/mcp-client.js.map +1 -0
  787. package/core-dist/src/tools/mcp-client.test.d.ts +6 -0
  788. package/core-dist/src/tools/mcp-client.test.js +307 -0
  789. package/core-dist/src/tools/mcp-client.test.js.map +1 -0
  790. package/core-dist/src/tools/mcp-tool.d.ts +69 -0
  791. package/core-dist/src/tools/mcp-tool.js +365 -0
  792. package/core-dist/src/tools/mcp-tool.js.map +1 -0
  793. package/core-dist/src/tools/mcp-tool.test.d.ts +6 -0
  794. package/core-dist/src/tools/mcp-tool.test.js +827 -0
  795. package/core-dist/src/tools/mcp-tool.test.js.map +1 -0
  796. package/core-dist/src/tools/memoryTool.d.ts +42 -0
  797. package/core-dist/src/tools/memoryTool.js +403 -0
  798. package/core-dist/src/tools/memoryTool.js.map +1 -0
  799. package/core-dist/src/tools/memoryTool.test.d.ts +6 -0
  800. package/core-dist/src/tools/memoryTool.test.js +416 -0
  801. package/core-dist/src/tools/memoryTool.test.js.map +1 -0
  802. package/core-dist/src/tools/modifiable-tool.d.ts +32 -0
  803. package/core-dist/src/tools/modifiable-tool.js +90 -0
  804. package/core-dist/src/tools/modifiable-tool.js.map +1 -0
  805. package/core-dist/src/tools/modifiable-tool.test.d.ts +6 -0
  806. package/core-dist/src/tools/modifiable-tool.test.js +188 -0
  807. package/core-dist/src/tools/modifiable-tool.test.js.map +1 -0
  808. package/core-dist/src/tools/read-file.d.ts +35 -0
  809. package/core-dist/src/tools/read-file.js +141 -0
  810. package/core-dist/src/tools/read-file.js.map +1 -0
  811. package/core-dist/src/tools/read-file.test.d.ts +6 -0
  812. package/core-dist/src/tools/read-file.test.js +333 -0
  813. package/core-dist/src/tools/read-file.test.js.map +1 -0
  814. package/core-dist/src/tools/ripGrep.d.ts +44 -0
  815. package/core-dist/src/tools/ripGrep.js +235 -0
  816. package/core-dist/src/tools/ripGrep.js.map +1 -0
  817. package/core-dist/src/tools/ripGrep.test.d.ts +6 -0
  818. package/core-dist/src/tools/ripGrep.test.js +529 -0
  819. package/core-dist/src/tools/ripGrep.test.js.map +1 -0
  820. package/core-dist/src/tools/sdk-control-client-transport.d.ts +67 -0
  821. package/core-dist/src/tools/sdk-control-client-transport.js +93 -0
  822. package/core-dist/src/tools/sdk-control-client-transport.js.map +1 -0
  823. package/core-dist/src/tools/shell.d.ts +34 -0
  824. package/core-dist/src/tools/shell.js +509 -0
  825. package/core-dist/src/tools/shell.js.map +1 -0
  826. package/core-dist/src/tools/shell.test.d.ts +6 -0
  827. package/core-dist/src/tools/shell.test.js +880 -0
  828. package/core-dist/src/tools/shell.test.js.map +1 -0
  829. package/core-dist/src/tools/skill.d.ts +45 -0
  830. package/core-dist/src/tools/skill.js +214 -0
  831. package/core-dist/src/tools/skill.js.map +1 -0
  832. package/core-dist/src/tools/skill.test.d.ts +6 -0
  833. package/core-dist/src/tools/skill.test.js +280 -0
  834. package/core-dist/src/tools/skill.test.js.map +1 -0
  835. package/core-dist/src/tools/task.d.ts +60 -0
  836. package/core-dist/src/tools/task.js +417 -0
  837. package/core-dist/src/tools/task.js.map +1 -0
  838. package/core-dist/src/tools/task.test.d.ts +6 -0
  839. package/core-dist/src/tools/task.test.js +367 -0
  840. package/core-dist/src/tools/task.test.js.map +1 -0
  841. package/core-dist/src/tools/todoWrite.d.ts +42 -0
  842. package/core-dist/src/tools/todoWrite.js +409 -0
  843. package/core-dist/src/tools/todoWrite.js.map +1 -0
  844. package/core-dist/src/tools/todoWrite.test.d.ts +6 -0
  845. package/core-dist/src/tools/todoWrite.test.js +234 -0
  846. package/core-dist/src/tools/todoWrite.test.js.map +1 -0
  847. package/core-dist/src/tools/tool-error.d.ts +45 -0
  848. package/core-dist/src/tools/tool-error.js +61 -0
  849. package/core-dist/src/tools/tool-error.js.map +1 -0
  850. package/core-dist/src/tools/tool-names.d.ts +60 -0
  851. package/core-dist/src/tools/tool-names.js +66 -0
  852. package/core-dist/src/tools/tool-names.js.map +1 -0
  853. package/core-dist/src/tools/tool-registry.d.ts +103 -0
  854. package/core-dist/src/tools/tool-registry.js +404 -0
  855. package/core-dist/src/tools/tool-registry.js.map +1 -0
  856. package/core-dist/src/tools/tool-registry.test.d.ts +6 -0
  857. package/core-dist/src/tools/tool-registry.test.js +331 -0
  858. package/core-dist/src/tools/tool-registry.test.js.map +1 -0
  859. package/core-dist/src/tools/tools.d.ts +364 -0
  860. package/core-dist/src/tools/tools.js +263 -0
  861. package/core-dist/src/tools/tools.js.map +1 -0
  862. package/core-dist/src/tools/tools.test.d.ts +6 -0
  863. package/core-dist/src/tools/tools.test.js +205 -0
  864. package/core-dist/src/tools/tools.test.js.map +1 -0
  865. package/core-dist/src/tools/web-fetch.d.ts +31 -0
  866. package/core-dist/src/tools/web-fetch.js +168 -0
  867. package/core-dist/src/tools/web-fetch.js.map +1 -0
  868. package/core-dist/src/tools/web-fetch.test.d.ts +6 -0
  869. package/core-dist/src/tools/web-fetch.test.js +134 -0
  870. package/core-dist/src/tools/web-fetch.test.js.map +1 -0
  871. package/core-dist/src/tools/web-search/base-provider.d.ts +31 -0
  872. package/core-dist/src/tools/web-search/base-provider.js +34 -0
  873. package/core-dist/src/tools/web-search/base-provider.js.map +1 -0
  874. package/core-dist/src/tools/web-search/index.d.ts +24 -0
  875. package/core-dist/src/tools/web-search/index.js +249 -0
  876. package/core-dist/src/tools/web-search/index.js.map +1 -0
  877. package/core-dist/src/tools/web-search/index.test.d.ts +6 -0
  878. package/core-dist/src/tools/web-search/index.test.js +237 -0
  879. package/core-dist/src/tools/web-search/index.test.js.map +1 -0
  880. package/core-dist/src/tools/web-search/providers/dashscope-provider.d.ts +23 -0
  881. package/core-dist/src/tools/web-search/providers/dashscope-provider.js +120 -0
  882. package/core-dist/src/tools/web-search/providers/dashscope-provider.js.map +1 -0
  883. package/core-dist/src/tools/web-search/providers/google-provider.d.ts +17 -0
  884. package/core-dist/src/tools/web-search/providers/google-provider.js +55 -0
  885. package/core-dist/src/tools/web-search/providers/google-provider.js.map +1 -0
  886. package/core-dist/src/tools/web-search/providers/tavily-provider.d.ts +17 -0
  887. package/core-dist/src/tools/web-search/providers/tavily-provider.js +54 -0
  888. package/core-dist/src/tools/web-search/providers/tavily-provider.js.map +1 -0
  889. package/core-dist/src/tools/web-search/types.d.ts +138 -0
  890. package/core-dist/src/tools/web-search/types.js +7 -0
  891. package/core-dist/src/tools/web-search/types.js.map +1 -0
  892. package/core-dist/src/tools/web-search/utils.d.ts +28 -0
  893. package/core-dist/src/tools/web-search/utils.js +35 -0
  894. package/core-dist/src/tools/web-search/utils.js.map +1 -0
  895. package/core-dist/src/tools/write-file.d.ts +52 -0
  896. package/core-dist/src/tools/write-file.js +316 -0
  897. package/core-dist/src/tools/write-file.js.map +1 -0
  898. package/core-dist/src/tools/write-file.test.d.ts +6 -0
  899. package/core-dist/src/tools/write-file.test.js +613 -0
  900. package/core-dist/src/tools/write-file.test.js.map +1 -0
  901. package/core-dist/src/utils/LruCache.d.ts +13 -0
  902. package/core-dist/src/utils/LruCache.js +38 -0
  903. package/core-dist/src/utils/LruCache.js.map +1 -0
  904. package/core-dist/src/utils/browser.d.ts +13 -0
  905. package/core-dist/src/utils/browser.js +50 -0
  906. package/core-dist/src/utils/browser.js.map +1 -0
  907. package/core-dist/src/utils/configResolver.d.ts +120 -0
  908. package/core-dist/src/utils/configResolver.js +125 -0
  909. package/core-dist/src/utils/configResolver.js.map +1 -0
  910. package/core-dist/src/utils/configResolver.test.d.ts +6 -0
  911. package/core-dist/src/utils/configResolver.test.js +99 -0
  912. package/core-dist/src/utils/configResolver.test.js.map +1 -0
  913. package/core-dist/src/utils/debugLogger.d.ts +46 -0
  914. package/core-dist/src/utils/debugLogger.js +159 -0
  915. package/core-dist/src/utils/debugLogger.js.map +1 -0
  916. package/core-dist/src/utils/debugLogger.test.d.ts +6 -0
  917. package/core-dist/src/utils/debugLogger.test.js +188 -0
  918. package/core-dist/src/utils/debugLogger.test.js.map +1 -0
  919. package/core-dist/src/utils/editHelper.d.ts +58 -0
  920. package/core-dist/src/utils/editHelper.js +342 -0
  921. package/core-dist/src/utils/editHelper.js.map +1 -0
  922. package/core-dist/src/utils/editHelper.test.d.ts +6 -0
  923. package/core-dist/src/utils/editHelper.test.js +127 -0
  924. package/core-dist/src/utils/editHelper.test.js.map +1 -0
  925. package/core-dist/src/utils/editor.d.ts +37 -0
  926. package/core-dist/src/utils/editor.js +179 -0
  927. package/core-dist/src/utils/editor.js.map +1 -0
  928. package/core-dist/src/utils/editor.test.d.ts +6 -0
  929. package/core-dist/src/utils/editor.test.js +434 -0
  930. package/core-dist/src/utils/editor.test.js.map +1 -0
  931. package/core-dist/src/utils/envVarResolver.d.ts +39 -0
  932. package/core-dist/src/utils/envVarResolver.js +100 -0
  933. package/core-dist/src/utils/envVarResolver.js.map +1 -0
  934. package/core-dist/src/utils/envVarResolver.test.d.ts +6 -0
  935. package/core-dist/src/utils/envVarResolver.test.js +221 -0
  936. package/core-dist/src/utils/envVarResolver.test.js.map +1 -0
  937. package/core-dist/src/utils/environmentContext.d.ts +21 -0
  938. package/core-dist/src/utils/environmentContext.js +73 -0
  939. package/core-dist/src/utils/environmentContext.js.map +1 -0
  940. package/core-dist/src/utils/environmentContext.test.d.ts +6 -0
  941. package/core-dist/src/utils/environmentContext.test.js +151 -0
  942. package/core-dist/src/utils/environmentContext.test.js.map +1 -0
  943. package/core-dist/src/utils/errorParsing.d.ts +7 -0
  944. package/core-dist/src/utils/errorParsing.js +72 -0
  945. package/core-dist/src/utils/errorParsing.js.map +1 -0
  946. package/core-dist/src/utils/errorParsing.test.d.ts +6 -0
  947. package/core-dist/src/utils/errorParsing.test.js +87 -0
  948. package/core-dist/src/utils/errorParsing.test.js.map +1 -0
  949. package/core-dist/src/utils/errorReporting.d.ts +14 -0
  950. package/core-dist/src/utils/errorReporting.js +56 -0
  951. package/core-dist/src/utils/errorReporting.js.map +1 -0
  952. package/core-dist/src/utils/errorReporting.test.d.ts +6 -0
  953. package/core-dist/src/utils/errorReporting.test.js +84 -0
  954. package/core-dist/src/utils/errorReporting.test.js.map +1 -0
  955. package/core-dist/src/utils/errors.d.ts +44 -0
  956. package/core-dist/src/utils/errors.js +114 -0
  957. package/core-dist/src/utils/errors.js.map +1 -0
  958. package/core-dist/src/utils/errors.test.d.ts +6 -0
  959. package/core-dist/src/utils/errors.test.js +70 -0
  960. package/core-dist/src/utils/errors.test.js.map +1 -0
  961. package/core-dist/src/utils/fetch.d.ts +14 -0
  962. package/core-dist/src/utils/fetch.js +152 -0
  963. package/core-dist/src/utils/fetch.js.map +1 -0
  964. package/core-dist/src/utils/fetch.test.d.ts +6 -0
  965. package/core-dist/src/utils/fetch.test.js +40 -0
  966. package/core-dist/src/utils/fetch.test.js.map +1 -0
  967. package/core-dist/src/utils/fileUtils.d.ts +102 -0
  968. package/core-dist/src/utils/fileUtils.js +584 -0
  969. package/core-dist/src/utils/fileUtils.js.map +1 -0
  970. package/core-dist/src/utils/fileUtils.test.d.ts +6 -0
  971. package/core-dist/src/utils/fileUtils.test.js +808 -0
  972. package/core-dist/src/utils/fileUtils.test.js.map +1 -0
  973. package/core-dist/src/utils/filesearch/crawlCache.d.ts +25 -0
  974. package/core-dist/src/utils/filesearch/crawlCache.js +57 -0
  975. package/core-dist/src/utils/filesearch/crawlCache.js.map +1 -0
  976. package/core-dist/src/utils/filesearch/crawlCache.test.d.ts +6 -0
  977. package/core-dist/src/utils/filesearch/crawlCache.test.js +103 -0
  978. package/core-dist/src/utils/filesearch/crawlCache.test.js.map +1 -0
  979. package/core-dist/src/utils/filesearch/crawler.d.ts +15 -0
  980. package/core-dist/src/utils/filesearch/crawler.js +50 -0
  981. package/core-dist/src/utils/filesearch/crawler.js.map +1 -0
  982. package/core-dist/src/utils/filesearch/crawler.test.d.ts +6 -0
  983. package/core-dist/src/utils/filesearch/crawler.test.js +468 -0
  984. package/core-dist/src/utils/filesearch/crawler.test.js.map +1 -0
  985. package/core-dist/src/utils/filesearch/fileSearch.d.ts +38 -0
  986. package/core-dist/src/utils/filesearch/fileSearch.js +194 -0
  987. package/core-dist/src/utils/filesearch/fileSearch.js.map +1 -0
  988. package/core-dist/src/utils/filesearch/fileSearch.test.d.ts +6 -0
  989. package/core-dist/src/utils/filesearch/fileSearch.test.js +642 -0
  990. package/core-dist/src/utils/filesearch/fileSearch.test.js.map +1 -0
  991. package/core-dist/src/utils/filesearch/ignore.d.ts +42 -0
  992. package/core-dist/src/utils/filesearch/ignore.js +106 -0
  993. package/core-dist/src/utils/filesearch/ignore.js.map +1 -0
  994. package/core-dist/src/utils/filesearch/ignore.test.d.ts +6 -0
  995. package/core-dist/src/utils/filesearch/ignore.test.js +144 -0
  996. package/core-dist/src/utils/filesearch/ignore.test.js.map +1 -0
  997. package/core-dist/src/utils/filesearch/result-cache.d.ts +33 -0
  998. package/core-dist/src/utils/filesearch/result-cache.js +59 -0
  999. package/core-dist/src/utils/filesearch/result-cache.js.map +1 -0
  1000. package/core-dist/src/utils/filesearch/result-cache.test.d.ts +6 -0
  1001. package/core-dist/src/utils/filesearch/result-cache.test.js +46 -0
  1002. package/core-dist/src/utils/filesearch/result-cache.test.js.map +1 -0
  1003. package/core-dist/src/utils/formatters.d.ts +6 -0
  1004. package/core-dist/src/utils/formatters.js +16 -0
  1005. package/core-dist/src/utils/formatters.js.map +1 -0
  1006. package/core-dist/src/utils/generateContentResponseUtilities.d.ts +13 -0
  1007. package/core-dist/src/utils/generateContentResponseUtilities.js +95 -0
  1008. package/core-dist/src/utils/generateContentResponseUtilities.js.map +1 -0
  1009. package/core-dist/src/utils/generateContentResponseUtilities.test.d.ts +6 -0
  1010. package/core-dist/src/utils/generateContentResponseUtilities.test.js +235 -0
  1011. package/core-dist/src/utils/generateContentResponseUtilities.test.js.map +1 -0
  1012. package/core-dist/src/utils/getFolderStructure.d.ts +31 -0
  1013. package/core-dist/src/utils/getFolderStructure.js +233 -0
  1014. package/core-dist/src/utils/getFolderStructure.js.map +1 -0
  1015. package/core-dist/src/utils/getFolderStructure.test.d.ts +6 -0
  1016. package/core-dist/src/utils/getFolderStructure.test.js +282 -0
  1017. package/core-dist/src/utils/getFolderStructure.test.js.map +1 -0
  1018. package/core-dist/src/utils/getPty.d.ts +7 -0
  1019. package/core-dist/src/utils/getPty.js +7 -0
  1020. package/core-dist/src/utils/getPty.js.map +1 -0
  1021. package/core-dist/src/utils/gitIgnoreParser.d.ts +16 -0
  1022. package/core-dist/src/utils/gitIgnoreParser.js +152 -0
  1023. package/core-dist/src/utils/gitIgnoreParser.js.map +1 -0
  1024. package/core-dist/src/utils/gitIgnoreParser.test.d.ts +6 -0
  1025. package/core-dist/src/utils/gitIgnoreParser.test.js +185 -0
  1026. package/core-dist/src/utils/gitIgnoreParser.test.js.map +1 -0
  1027. package/core-dist/src/utils/gitUtils.d.ts +21 -0
  1028. package/core-dist/src/utils/gitUtils.js +78 -0
  1029. package/core-dist/src/utils/gitUtils.js.map +1 -0
  1030. package/core-dist/src/utils/iconvHelper.d.ts +33 -0
  1031. package/core-dist/src/utils/iconvHelper.js +48 -0
  1032. package/core-dist/src/utils/iconvHelper.js.map +1 -0
  1033. package/core-dist/src/utils/ignorePatterns.d.ts +103 -0
  1034. package/core-dist/src/utils/ignorePatterns.js +222 -0
  1035. package/core-dist/src/utils/ignorePatterns.js.map +1 -0
  1036. package/core-dist/src/utils/ignorePatterns.test.d.ts +6 -0
  1037. package/core-dist/src/utils/ignorePatterns.test.js +255 -0
  1038. package/core-dist/src/utils/ignorePatterns.test.js.map +1 -0
  1039. package/core-dist/src/utils/installationManager.d.ts +16 -0
  1040. package/core-dist/src/utils/installationManager.js +52 -0
  1041. package/core-dist/src/utils/installationManager.js.map +1 -0
  1042. package/core-dist/src/utils/installationManager.test.d.ts +6 -0
  1043. package/core-dist/src/utils/installationManager.test.js +79 -0
  1044. package/core-dist/src/utils/installationManager.test.js.map +1 -0
  1045. package/core-dist/src/utils/jsonl-utils.d.ts +38 -0
  1046. package/core-dist/src/utils/jsonl-utils.js +176 -0
  1047. package/core-dist/src/utils/jsonl-utils.js.map +1 -0
  1048. package/core-dist/src/utils/language-detection.d.ts +6 -0
  1049. package/core-dist/src/utils/language-detection.js +101 -0
  1050. package/core-dist/src/utils/language-detection.js.map +1 -0
  1051. package/core-dist/src/utils/memoryDiscovery.d.ts +15 -0
  1052. package/core-dist/src/utils/memoryDiscovery.js +238 -0
  1053. package/core-dist/src/utils/memoryDiscovery.js.map +1 -0
  1054. package/core-dist/src/utils/memoryDiscovery.test.d.ts +6 -0
  1055. package/core-dist/src/utils/memoryDiscovery.test.js +212 -0
  1056. package/core-dist/src/utils/memoryDiscovery.test.js.map +1 -0
  1057. package/core-dist/src/utils/memoryImportProcessor.d.ts +41 -0
  1058. package/core-dist/src/utils/memoryImportProcessor.js +296 -0
  1059. package/core-dist/src/utils/memoryImportProcessor.js.map +1 -0
  1060. package/core-dist/src/utils/memoryImportProcessor.test.d.ts +6 -0
  1061. package/core-dist/src/utils/memoryImportProcessor.test.js +631 -0
  1062. package/core-dist/src/utils/memoryImportProcessor.test.js.map +1 -0
  1063. package/core-dist/src/utils/messageInspectors.d.ts +8 -0
  1064. package/core-dist/src/utils/messageInspectors.js +16 -0
  1065. package/core-dist/src/utils/messageInspectors.js.map +1 -0
  1066. package/core-dist/src/utils/nextSpeakerChecker.d.ts +12 -0
  1067. package/core-dist/src/utils/nextSpeakerChecker.js +99 -0
  1068. package/core-dist/src/utils/nextSpeakerChecker.js.map +1 -0
  1069. package/core-dist/src/utils/nextSpeakerChecker.test.d.ts +6 -0
  1070. package/core-dist/src/utils/nextSpeakerChecker.test.js +183 -0
  1071. package/core-dist/src/utils/nextSpeakerChecker.test.js.map +1 -0
  1072. package/core-dist/src/utils/openaiLogger.d.ts +42 -0
  1073. package/core-dist/src/utils/openaiLogger.js +140 -0
  1074. package/core-dist/src/utils/openaiLogger.js.map +1 -0
  1075. package/core-dist/src/utils/openaiLogger.test.d.ts +6 -0
  1076. package/core-dist/src/utils/openaiLogger.test.js +314 -0
  1077. package/core-dist/src/utils/openaiLogger.test.js.map +1 -0
  1078. package/core-dist/src/utils/partUtils.d.ts +35 -0
  1079. package/core-dist/src/utils/partUtils.js +133 -0
  1080. package/core-dist/src/utils/partUtils.js.map +1 -0
  1081. package/core-dist/src/utils/partUtils.test.d.ts +6 -0
  1082. package/core-dist/src/utils/partUtils.test.js +241 -0
  1083. package/core-dist/src/utils/partUtils.test.js.map +1 -0
  1084. package/core-dist/src/utils/pathReader.d.ts +17 -0
  1085. package/core-dist/src/utils/pathReader.js +92 -0
  1086. package/core-dist/src/utils/pathReader.js.map +1 -0
  1087. package/core-dist/src/utils/pathReader.test.d.ts +6 -0
  1088. package/core-dist/src/utils/pathReader.test.js +367 -0
  1089. package/core-dist/src/utils/pathReader.test.js.map +1 -0
  1090. package/core-dist/src/utils/paths.d.ts +110 -0
  1091. package/core-dist/src/utils/paths.js +269 -0
  1092. package/core-dist/src/utils/paths.js.map +1 -0
  1093. package/core-dist/src/utils/paths.test.d.ts +6 -0
  1094. package/core-dist/src/utils/paths.test.js +633 -0
  1095. package/core-dist/src/utils/paths.test.js.map +1 -0
  1096. package/core-dist/src/utils/projectSummary.d.ts +22 -0
  1097. package/core-dist/src/utils/projectSummary.js +86 -0
  1098. package/core-dist/src/utils/projectSummary.js.map +1 -0
  1099. package/core-dist/src/utils/promptIdContext.d.ts +7 -0
  1100. package/core-dist/src/utils/promptIdContext.js +8 -0
  1101. package/core-dist/src/utils/promptIdContext.js.map +1 -0
  1102. package/core-dist/src/utils/quotaErrorDetection.d.ts +19 -0
  1103. package/core-dist/src/utils/quotaErrorDetection.js +84 -0
  1104. package/core-dist/src/utils/quotaErrorDetection.js.map +1 -0
  1105. package/core-dist/src/utils/quotaErrorDetection.test.d.ts +6 -0
  1106. package/core-dist/src/utils/quotaErrorDetection.test.js +104 -0
  1107. package/core-dist/src/utils/quotaErrorDetection.test.js.map +1 -0
  1108. package/core-dist/src/utils/qwenIgnoreParser.d.ts +18 -0
  1109. package/core-dist/src/utils/qwenIgnoreParser.js +61 -0
  1110. package/core-dist/src/utils/qwenIgnoreParser.js.map +1 -0
  1111. package/core-dist/src/utils/qwenIgnoreParser.test.d.ts +6 -0
  1112. package/core-dist/src/utils/qwenIgnoreParser.test.js +50 -0
  1113. package/core-dist/src/utils/qwenIgnoreParser.test.js.map +1 -0
  1114. package/core-dist/src/utils/rateLimit.d.ts +23 -0
  1115. package/core-dist/src/utils/rateLimit.js +69 -0
  1116. package/core-dist/src/utils/rateLimit.js.map +1 -0
  1117. package/core-dist/src/utils/rateLimit.test.d.ts +6 -0
  1118. package/core-dist/src/utils/rateLimit.test.js +72 -0
  1119. package/core-dist/src/utils/rateLimit.test.js.map +1 -0
  1120. package/core-dist/src/utils/readManyFiles.d.ts +67 -0
  1121. package/core-dist/src/utils/readManyFiles.js +133 -0
  1122. package/core-dist/src/utils/readManyFiles.js.map +1 -0
  1123. package/core-dist/src/utils/readManyFiles.test.d.ts +6 -0
  1124. package/core-dist/src/utils/readManyFiles.test.js +230 -0
  1125. package/core-dist/src/utils/readManyFiles.test.js.map +1 -0
  1126. package/core-dist/src/utils/request-tokenizer/imageTokenizer.d.ts +112 -0
  1127. package/core-dist/src/utils/request-tokenizer/imageTokenizer.js +403 -0
  1128. package/core-dist/src/utils/request-tokenizer/imageTokenizer.js.map +1 -0
  1129. package/core-dist/src/utils/request-tokenizer/imageTokenizer.test.d.ts +6 -0
  1130. package/core-dist/src/utils/request-tokenizer/imageTokenizer.test.js +114 -0
  1131. package/core-dist/src/utils/request-tokenizer/imageTokenizer.test.js.map +1 -0
  1132. package/core-dist/src/utils/request-tokenizer/index.d.ts +9 -0
  1133. package/core-dist/src/utils/request-tokenizer/index.js +9 -0
  1134. package/core-dist/src/utils/request-tokenizer/index.js.map +1 -0
  1135. package/core-dist/src/utils/request-tokenizer/requestTokenizer.d.ts +52 -0
  1136. package/core-dist/src/utils/request-tokenizer/requestTokenizer.js +252 -0
  1137. package/core-dist/src/utils/request-tokenizer/requestTokenizer.js.map +1 -0
  1138. package/core-dist/src/utils/request-tokenizer/requestTokenizer.test.d.ts +6 -0
  1139. package/core-dist/src/utils/request-tokenizer/requestTokenizer.test.js +227 -0
  1140. package/core-dist/src/utils/request-tokenizer/requestTokenizer.test.js.map +1 -0
  1141. package/core-dist/src/utils/request-tokenizer/supportedImageFormats.d.ts +30 -0
  1142. package/core-dist/src/utils/request-tokenizer/supportedImageFormats.js +41 -0
  1143. package/core-dist/src/utils/request-tokenizer/supportedImageFormats.js.map +1 -0
  1144. package/core-dist/src/utils/request-tokenizer/textTokenizer.d.ts +32 -0
  1145. package/core-dist/src/utils/request-tokenizer/textTokenizer.js +54 -0
  1146. package/core-dist/src/utils/request-tokenizer/textTokenizer.js.map +1 -0
  1147. package/core-dist/src/utils/request-tokenizer/textTokenizer.test.d.ts +6 -0
  1148. package/core-dist/src/utils/request-tokenizer/textTokenizer.test.js +237 -0
  1149. package/core-dist/src/utils/request-tokenizer/textTokenizer.test.js.map +1 -0
  1150. package/core-dist/src/utils/request-tokenizer/types.d.ts +34 -0
  1151. package/core-dist/src/utils/request-tokenizer/types.js +7 -0
  1152. package/core-dist/src/utils/request-tokenizer/types.js.map +1 -0
  1153. package/core-dist/src/utils/retry.d.ts +38 -0
  1154. package/core-dist/src/utils/retry.js +180 -0
  1155. package/core-dist/src/utils/retry.js.map +1 -0
  1156. package/core-dist/src/utils/retry.test.d.ts +6 -0
  1157. package/core-dist/src/utils/retry.test.js +402 -0
  1158. package/core-dist/src/utils/retry.test.js.map +1 -0
  1159. package/core-dist/src/utils/ripgrepUtils.d.ts +61 -0
  1160. package/core-dist/src/utils/ripgrepUtils.js +227 -0
  1161. package/core-dist/src/utils/ripgrepUtils.js.map +1 -0
  1162. package/core-dist/src/utils/ripgrepUtils.test.d.ts +6 -0
  1163. package/core-dist/src/utils/ripgrepUtils.test.js +101 -0
  1164. package/core-dist/src/utils/ripgrepUtils.test.js.map +1 -0
  1165. package/core-dist/src/utils/runtimeFetchOptions.d.ts +44 -0
  1166. package/core-dist/src/utils/runtimeFetchOptions.js +92 -0
  1167. package/core-dist/src/utils/runtimeFetchOptions.js.map +1 -0
  1168. package/core-dist/src/utils/runtimeFetchOptions.test.d.ts +6 -0
  1169. package/core-dist/src/utils/runtimeFetchOptions.test.js +70 -0
  1170. package/core-dist/src/utils/runtimeFetchOptions.test.js.map +1 -0
  1171. package/core-dist/src/utils/safeJsonParse.d.ts +15 -0
  1172. package/core-dist/src/utils/safeJsonParse.js +43 -0
  1173. package/core-dist/src/utils/safeJsonParse.js.map +1 -0
  1174. package/core-dist/src/utils/safeJsonParse.test.d.ts +6 -0
  1175. package/core-dist/src/utils/safeJsonParse.test.js +112 -0
  1176. package/core-dist/src/utils/safeJsonParse.test.js.map +1 -0
  1177. package/core-dist/src/utils/safeJsonStringify.d.ts +13 -0
  1178. package/core-dist/src/utils/safeJsonStringify.js +25 -0
  1179. package/core-dist/src/utils/safeJsonStringify.js.map +1 -0
  1180. package/core-dist/src/utils/safeJsonStringify.test.d.ts +6 -0
  1181. package/core-dist/src/utils/safeJsonStringify.test.js +61 -0
  1182. package/core-dist/src/utils/safeJsonStringify.test.js.map +1 -0
  1183. package/core-dist/src/utils/schemaConverter.d.ts +15 -0
  1184. package/core-dist/src/utils/schemaConverter.js +109 -0
  1185. package/core-dist/src/utils/schemaConverter.js.map +1 -0
  1186. package/core-dist/src/utils/schemaConverter.test.d.ts +6 -0
  1187. package/core-dist/src/utils/schemaConverter.test.js +106 -0
  1188. package/core-dist/src/utils/schemaConverter.test.js.map +1 -0
  1189. package/core-dist/src/utils/schemaValidator.d.ts +16 -0
  1190. package/core-dist/src/utils/schemaValidator.js +123 -0
  1191. package/core-dist/src/utils/schemaValidator.js.map +1 -0
  1192. package/core-dist/src/utils/schemaValidator.test.d.ts +6 -0
  1193. package/core-dist/src/utils/schemaValidator.test.js +266 -0
  1194. package/core-dist/src/utils/schemaValidator.test.js.map +1 -0
  1195. package/core-dist/src/utils/secure-browser-launcher.d.ts +23 -0
  1196. package/core-dist/src/utils/secure-browser-launcher.js +165 -0
  1197. package/core-dist/src/utils/secure-browser-launcher.js.map +1 -0
  1198. package/core-dist/src/utils/secure-browser-launcher.test.d.ts +6 -0
  1199. package/core-dist/src/utils/secure-browser-launcher.test.js +149 -0
  1200. package/core-dist/src/utils/secure-browser-launcher.test.js.map +1 -0
  1201. package/core-dist/src/utils/shell-utils.d.ts +158 -0
  1202. package/core-dist/src/utils/shell-utils.js +739 -0
  1203. package/core-dist/src/utils/shell-utils.js.map +1 -0
  1204. package/core-dist/src/utils/shell-utils.test.d.ts +6 -0
  1205. package/core-dist/src/utils/shell-utils.test.js +466 -0
  1206. package/core-dist/src/utils/shell-utils.test.js.map +1 -0
  1207. package/core-dist/src/utils/shellReadOnlyChecker.d.ts +6 -0
  1208. package/core-dist/src/utils/shellReadOnlyChecker.js +290 -0
  1209. package/core-dist/src/utils/shellReadOnlyChecker.js.map +1 -0
  1210. package/core-dist/src/utils/shellReadOnlyChecker.test.d.ts +6 -0
  1211. package/core-dist/src/utils/shellReadOnlyChecker.test.js +157 -0
  1212. package/core-dist/src/utils/shellReadOnlyChecker.test.js.map +1 -0
  1213. package/core-dist/src/utils/subagentGenerator.d.ts +20 -0
  1214. package/core-dist/src/utils/subagentGenerator.js +120 -0
  1215. package/core-dist/src/utils/subagentGenerator.js.map +1 -0
  1216. package/core-dist/src/utils/subagentGenerator.test.d.ts +6 -0
  1217. package/core-dist/src/utils/subagentGenerator.test.js +135 -0
  1218. package/core-dist/src/utils/subagentGenerator.test.js.map +1 -0
  1219. package/core-dist/src/utils/summarizer.d.ts +25 -0
  1220. package/core-dist/src/utils/summarizer.js +53 -0
  1221. package/core-dist/src/utils/summarizer.js.map +1 -0
  1222. package/core-dist/src/utils/summarizer.test.d.ts +6 -0
  1223. package/core-dist/src/utils/summarizer.test.js +128 -0
  1224. package/core-dist/src/utils/summarizer.test.js.map +1 -0
  1225. package/core-dist/src/utils/symlink.d.ts +26 -0
  1226. package/core-dist/src/utils/symlink.js +43 -0
  1227. package/core-dist/src/utils/symlink.js.map +1 -0
  1228. package/core-dist/src/utils/systemEncoding.d.ts +40 -0
  1229. package/core-dist/src/utils/systemEncoding.js +160 -0
  1230. package/core-dist/src/utils/systemEncoding.js.map +1 -0
  1231. package/core-dist/src/utils/systemEncoding.test.d.ts +6 -0
  1232. package/core-dist/src/utils/systemEncoding.test.js +367 -0
  1233. package/core-dist/src/utils/systemEncoding.test.js.map +1 -0
  1234. package/core-dist/src/utils/terminalSerializer.d.ts +25 -0
  1235. package/core-dist/src/utils/terminalSerializer.js +432 -0
  1236. package/core-dist/src/utils/terminalSerializer.js.map +1 -0
  1237. package/core-dist/src/utils/terminalSerializer.test.d.ts +6 -0
  1238. package/core-dist/src/utils/terminalSerializer.test.js +176 -0
  1239. package/core-dist/src/utils/terminalSerializer.test.js.map +1 -0
  1240. package/core-dist/src/utils/testUtils.d.ts +29 -0
  1241. package/core-dist/src/utils/testUtils.js +70 -0
  1242. package/core-dist/src/utils/testUtils.js.map +1 -0
  1243. package/core-dist/src/utils/textUtils.d.ts +29 -0
  1244. package/core-dist/src/utils/textUtils.js +59 -0
  1245. package/core-dist/src/utils/textUtils.js.map +1 -0
  1246. package/core-dist/src/utils/textUtils.test.d.ts +6 -0
  1247. package/core-dist/src/utils/textUtils.test.js +91 -0
  1248. package/core-dist/src/utils/textUtils.test.js.map +1 -0
  1249. package/core-dist/src/utils/thoughtUtils.d.ts +23 -0
  1250. package/core-dist/src/utils/thoughtUtils.js +53 -0
  1251. package/core-dist/src/utils/thoughtUtils.js.map +1 -0
  1252. package/core-dist/src/utils/thoughtUtils.test.d.ts +6 -0
  1253. package/core-dist/src/utils/thoughtUtils.test.js +78 -0
  1254. package/core-dist/src/utils/thoughtUtils.test.js.map +1 -0
  1255. package/core-dist/src/utils/toml-to-markdown-converter.d.ts +22 -0
  1256. package/core-dist/src/utils/toml-to-markdown-converter.js +61 -0
  1257. package/core-dist/src/utils/toml-to-markdown-converter.js.map +1 -0
  1258. package/core-dist/src/utils/toml-to-markdown-converter.test.d.ts +6 -0
  1259. package/core-dist/src/utils/toml-to-markdown-converter.test.js +73 -0
  1260. package/core-dist/src/utils/toml-to-markdown-converter.test.js.map +1 -0
  1261. package/core-dist/src/utils/tool-utils.d.ts +22 -0
  1262. package/core-dist/src/utils/tool-utils.js +121 -0
  1263. package/core-dist/src/utils/tool-utils.js.map +1 -0
  1264. package/core-dist/src/utils/tool-utils.test.d.ts +6 -0
  1265. package/core-dist/src/utils/tool-utils.test.js +100 -0
  1266. package/core-dist/src/utils/tool-utils.test.js.map +1 -0
  1267. package/core-dist/src/utils/workspaceContext.d.ts +66 -0
  1268. package/core-dist/src/utils/workspaceContext.js +173 -0
  1269. package/core-dist/src/utils/workspaceContext.js.map +1 -0
  1270. package/core-dist/src/utils/workspaceContext.test.d.ts +6 -0
  1271. package/core-dist/src/utils/workspaceContext.test.js +313 -0
  1272. package/core-dist/src/utils/workspaceContext.test.js.map +1 -0
  1273. package/core-dist/src/utils/yaml-parser.d.ts +29 -0
  1274. package/core-dist/src/utils/yaml-parser.js +172 -0
  1275. package/core-dist/src/utils/yaml-parser.js.map +1 -0
  1276. package/core-dist/src/utils/yaml-parser.test.d.ts +6 -0
  1277. package/core-dist/src/utils/yaml-parser.test.js +170 -0
  1278. package/core-dist/src/utils/yaml-parser.test.js.map +1 -0
  1279. package/core-dist/tsconfig.tsbuildinfo +1 -0
  1280. package/package.json +3 -1
  1281. package/scripts/postinstall.cjs +102 -203
@@ -0,0 +1,1276 @@
1
+ /**
2
+ * @license
3
+ * Copyright 2025 Google LLC
4
+ * SPDX-License-Identifier: Apache-2.0
5
+ */
6
+ import { describe, it, expect, vi, beforeEach, afterEach } from 'vitest';
7
+ import { ApiError } from '@google/genai';
8
+ import { GeminiChat, InvalidStreamError, StreamEventType, } from './geminiChat.js';
9
+ import { StreamContentError } from './openaiContentGenerator/pipeline.js';
10
+ import { setSimulate429 } from '../utils/testUtils.js';
11
+ import { uiTelemetryService } from '../telemetry/uiTelemetry.js';
12
+ // Mock fs module to prevent actual file system operations during tests
13
+ const mockFileSystem = new Map();
14
+ vi.mock('node:fs', () => {
15
+ const fsModule = {
16
+ mkdirSync: vi.fn(),
17
+ writeFileSync: vi.fn((path, data) => {
18
+ mockFileSystem.set(path, data);
19
+ }),
20
+ readFileSync: vi.fn((path) => {
21
+ if (mockFileSystem.has(path)) {
22
+ return mockFileSystem.get(path);
23
+ }
24
+ throw Object.assign(new Error('ENOENT: no such file or directory'), {
25
+ code: 'ENOENT',
26
+ });
27
+ }),
28
+ existsSync: vi.fn((path) => mockFileSystem.has(path)),
29
+ appendFileSync: vi.fn(),
30
+ };
31
+ return {
32
+ default: fsModule,
33
+ ...fsModule,
34
+ };
35
+ });
36
+ // Add mock for the retry utility
37
+ const { mockRetryWithBackoff } = vi.hoisted(() => ({
38
+ mockRetryWithBackoff: vi.fn(),
39
+ }));
40
+ vi.mock('../utils/retry.js', async (importOriginal) => {
41
+ const actual = await importOriginal();
42
+ return {
43
+ ...actual,
44
+ retryWithBackoff: mockRetryWithBackoff,
45
+ };
46
+ });
47
+ const { mockLogContentRetry, mockLogContentRetryFailure } = vi.hoisted(() => ({
48
+ mockLogContentRetry: vi.fn(),
49
+ mockLogContentRetryFailure: vi.fn(),
50
+ }));
51
+ vi.mock('../telemetry/loggers.js', () => ({
52
+ logContentRetry: mockLogContentRetry,
53
+ logContentRetryFailure: mockLogContentRetryFailure,
54
+ }));
55
+ vi.mock('../telemetry/uiTelemetry.js', () => ({
56
+ uiTelemetryService: {
57
+ setLastPromptTokenCount: vi.fn(),
58
+ },
59
+ }));
60
+ describe('GeminiChat', async () => {
61
+ let mockContentGenerator;
62
+ let chat;
63
+ let mockConfig;
64
+ const config = {};
65
+ beforeEach(() => {
66
+ vi.clearAllMocks();
67
+ vi.mocked(uiTelemetryService.setLastPromptTokenCount).mockClear();
68
+ mockContentGenerator = {
69
+ generateContent: vi.fn(),
70
+ generateContentStream: vi.fn(),
71
+ countTokens: vi.fn(),
72
+ embedContent: vi.fn(),
73
+ batchEmbedContents: vi.fn(),
74
+ useSummarizedThinking: vi.fn().mockReturnValue(false),
75
+ };
76
+ // Default mock implementation for tests that don't care about retry logic
77
+ mockRetryWithBackoff.mockImplementation(async (apiCall) => apiCall());
78
+ mockConfig = {
79
+ getSessionId: () => 'test-session-id',
80
+ getTelemetryLogPromptsEnabled: () => true,
81
+ getUsageStatisticsEnabled: () => true,
82
+ getDebugMode: () => false,
83
+ getContentGeneratorConfig: vi.fn().mockReturnValue({
84
+ authType: 'gemini', // Ensure this is set for fallback tests
85
+ model: 'test-model',
86
+ }),
87
+ getModel: vi.fn().mockReturnValue('gemini-pro'),
88
+ setModel: vi.fn(),
89
+ getProjectRoot: vi.fn().mockReturnValue('/test/project/root'),
90
+ getCliVersion: vi.fn().mockReturnValue('1.0.0'),
91
+ storage: {
92
+ getProjectTempDir: vi.fn().mockReturnValue('/test/temp'),
93
+ },
94
+ getToolRegistry: vi.fn().mockReturnValue({
95
+ getTool: vi.fn(),
96
+ }),
97
+ getContentGenerator: vi.fn().mockReturnValue(mockContentGenerator),
98
+ };
99
+ // Disable 429 simulation for tests
100
+ setSimulate429(false);
101
+ // Reset history for each test by creating a new instance
102
+ chat = new GeminiChat(mockConfig, config, []);
103
+ });
104
+ afterEach(() => {
105
+ vi.restoreAllMocks();
106
+ vi.resetAllMocks();
107
+ });
108
+ /**
109
+ * Helper: consume a stream and expect it to throw InvalidStreamError
110
+ * after all transient retries exhaust. Uses fake timers to skip delays.
111
+ * Must be called within a vi.useFakeTimers() / vi.useRealTimers() block.
112
+ */
113
+ async function expectStreamExhaustion(stream) {
114
+ const collecting = (async () => {
115
+ for await (const _ of stream) {
116
+ /* consume */
117
+ }
118
+ })();
119
+ // Get assertion promise first (don't await), then advance timers.
120
+ const resultPromise = (async () => {
121
+ await expect(collecting).rejects.toThrow(InvalidStreamError);
122
+ })();
123
+ await vi.advanceTimersByTimeAsync(0);
124
+ await vi.advanceTimersByTimeAsync(35_000);
125
+ await resultPromise;
126
+ }
127
+ async function collectStreamWithFakeTimers(stream, advanceByMs = 10_000) {
128
+ const events = [];
129
+ const collecting = (async () => {
130
+ for await (const event of stream) {
131
+ events.push(event);
132
+ }
133
+ return events;
134
+ })();
135
+ await vi.advanceTimersByTimeAsync(0);
136
+ await vi.advanceTimersByTimeAsync(advanceByMs);
137
+ return collecting;
138
+ }
139
+ describe('sendMessageStream', () => {
140
+ it('should succeed if a tool call is followed by an empty part', async () => {
141
+ // 1. Mock a stream that contains a tool call, then an invalid (empty) part.
142
+ const streamWithToolCall = (async function* () {
143
+ yield {
144
+ candidates: [
145
+ {
146
+ content: {
147
+ role: 'model',
148
+ parts: [{ functionCall: { name: 'test_tool', args: {} } }],
149
+ },
150
+ },
151
+ ],
152
+ };
153
+ // This second chunk is invalid according to isValidResponse
154
+ yield {
155
+ candidates: [
156
+ {
157
+ content: {
158
+ role: 'model',
159
+ parts: [{ text: '' }],
160
+ },
161
+ },
162
+ ],
163
+ };
164
+ })();
165
+ vi.mocked(mockContentGenerator.generateContentStream).mockResolvedValue(streamWithToolCall);
166
+ // 2. Action & Assert: The stream processing should complete without throwing an error
167
+ // because the presence of a tool call makes the empty final chunk acceptable.
168
+ const stream = await chat.sendMessageStream('test-model', { message: 'test message' }, 'prompt-id-tool-call-empty-end');
169
+ await expect((async () => {
170
+ for await (const _ of stream) {
171
+ /* consume stream */
172
+ }
173
+ })()).resolves.not.toThrow();
174
+ // 3. Verify history was recorded correctly
175
+ const history = chat.getHistory();
176
+ expect(history.length).toBe(2); // user turn + model turn
177
+ const modelTurn = history[1];
178
+ expect(modelTurn?.parts?.length).toBe(1); // The empty part is discarded
179
+ expect(modelTurn?.parts[0].functionCall).toBeDefined();
180
+ });
181
+ it('should fail if the stream ends with an empty part and has no finishReason', async () => {
182
+ vi.useFakeTimers();
183
+ try {
184
+ const streamWithNoFinish = (async function* () {
185
+ yield {
186
+ candidates: [
187
+ {
188
+ content: {
189
+ role: 'model',
190
+ parts: [{ text: 'Initial content...' }],
191
+ },
192
+ },
193
+ ],
194
+ };
195
+ yield {
196
+ candidates: [
197
+ {
198
+ content: {
199
+ role: 'model',
200
+ parts: [{ text: '' }],
201
+ },
202
+ },
203
+ ],
204
+ };
205
+ })();
206
+ vi.mocked(mockContentGenerator.generateContentStream).mockResolvedValue(streamWithNoFinish);
207
+ const stream = await chat.sendMessageStream('test-model', { message: 'test message' }, 'prompt-id-no-finish-empty-end');
208
+ await expectStreamExhaustion(stream);
209
+ }
210
+ finally {
211
+ vi.useRealTimers();
212
+ }
213
+ });
214
+ it('should succeed if the stream ends with an invalid part but has a finishReason and contained a valid part', async () => {
215
+ // 1. Mock a stream that sends a valid chunk, then an invalid one, but has a finish reason.
216
+ const streamWithInvalidEnd = (async function* () {
217
+ yield {
218
+ candidates: [
219
+ {
220
+ content: {
221
+ role: 'model',
222
+ parts: [{ text: 'Initial valid content...' }],
223
+ },
224
+ },
225
+ ],
226
+ };
227
+ // This second chunk is invalid, but the response has a finishReason.
228
+ yield {
229
+ candidates: [
230
+ {
231
+ content: {
232
+ role: 'model',
233
+ parts: [{ text: '' }], // Invalid part
234
+ },
235
+ finishReason: 'STOP',
236
+ },
237
+ ],
238
+ };
239
+ })();
240
+ vi.mocked(mockContentGenerator.generateContentStream).mockResolvedValue(streamWithInvalidEnd);
241
+ // 2. Action & Assert: The stream should complete without throwing an error.
242
+ const stream = await chat.sendMessageStream('test-model', { message: 'test message' }, 'prompt-id-valid-then-invalid-end');
243
+ await expect((async () => {
244
+ for await (const _ of stream) {
245
+ /* consume stream */
246
+ }
247
+ })()).resolves.not.toThrow();
248
+ // 3. Verify history was recorded correctly with only the valid part.
249
+ const history = chat.getHistory();
250
+ expect(history.length).toBe(2); // user turn + model turn
251
+ const modelTurn = history[1];
252
+ expect(modelTurn?.parts?.length).toBe(1);
253
+ expect(modelTurn?.parts[0].text).toBe('Initial valid content...');
254
+ });
255
+ it('should consolidate subsequent text chunks after receiving an empty text chunk', async () => {
256
+ // 1. Mock the API to return a stream where one chunk is just an empty text part.
257
+ const multiChunkStream = (async function* () {
258
+ yield {
259
+ candidates: [
260
+ { content: { role: 'model', parts: [{ text: 'Hello' }] } },
261
+ ],
262
+ };
263
+ // FIX: The original test used { text: '' }, which is invalid.
264
+ // A chunk can be empty but still valid. This chunk is now removed
265
+ // as the important part is consolidating what comes after.
266
+ yield {
267
+ candidates: [
268
+ {
269
+ content: { role: 'model', parts: [{ text: ' World!' }] },
270
+ finishReason: 'STOP',
271
+ },
272
+ ],
273
+ };
274
+ })();
275
+ vi.mocked(mockContentGenerator.generateContentStream).mockResolvedValue(multiChunkStream);
276
+ // 2. Action: Send a message and consume the stream.
277
+ const stream = await chat.sendMessageStream('test-model', { message: 'test message' }, 'prompt-id-empty-chunk-consolidation');
278
+ for await (const _ of stream) {
279
+ // Consume the stream
280
+ }
281
+ // 3. Assert: Check that the final history was correctly consolidated.
282
+ const history = chat.getHistory();
283
+ expect(history.length).toBe(2);
284
+ const modelTurn = history[1];
285
+ expect(modelTurn?.parts?.length).toBe(1);
286
+ expect(modelTurn?.parts[0].text).toBe('Hello World!');
287
+ });
288
+ it('should consolidate adjacent text parts that arrive in separate stream chunks', async () => {
289
+ // 1. Mock the API to return a stream of multiple, adjacent text chunks.
290
+ const multiChunkStream = (async function* () {
291
+ yield {
292
+ candidates: [
293
+ { content: { role: 'model', parts: [{ text: 'This is the ' }] } },
294
+ ],
295
+ };
296
+ yield {
297
+ candidates: [
298
+ { content: { role: 'model', parts: [{ text: 'first part.' }] } },
299
+ ],
300
+ };
301
+ // This function call should break the consolidation.
302
+ yield {
303
+ candidates: [
304
+ {
305
+ content: {
306
+ role: 'model',
307
+ parts: [{ functionCall: { name: 'do_stuff', args: {} } }],
308
+ },
309
+ },
310
+ ],
311
+ };
312
+ yield {
313
+ candidates: [
314
+ {
315
+ content: {
316
+ role: 'model',
317
+ parts: [{ text: 'This is the second part.' }],
318
+ },
319
+ },
320
+ ],
321
+ };
322
+ })();
323
+ vi.mocked(mockContentGenerator.generateContentStream).mockResolvedValue(multiChunkStream);
324
+ // 2. Action: Send a message and consume the stream.
325
+ const stream = await chat.sendMessageStream('test-model', { message: 'test message' }, 'prompt-id-multi-chunk');
326
+ for await (const _ of stream) {
327
+ // Consume the stream to trigger history recording.
328
+ }
329
+ // 3. Assert: Check that the final history was correctly consolidated.
330
+ const history = chat.getHistory();
331
+ // The history should contain the user's turn and ONE consolidated model turn.
332
+ expect(history.length).toBe(2);
333
+ const modelTurn = history[1];
334
+ expect(modelTurn.role).toBe('model');
335
+ // The model turn should have 3 distinct parts: the merged text, the function call, and the final text.
336
+ expect(modelTurn?.parts?.length).toBe(3);
337
+ expect(modelTurn?.parts[0].text).toBe('This is the first part.');
338
+ expect(modelTurn.parts[1].functionCall).toBeDefined();
339
+ expect(modelTurn.parts[2].text).toBe('This is the second part.');
340
+ });
341
+ it('should preserve text parts that stream in the same chunk as a thought', async () => {
342
+ // 1. Mock the API to return a single chunk containing both a thought and visible text.
343
+ const mixedContentStream = (async function* () {
344
+ yield {
345
+ candidates: [
346
+ {
347
+ content: {
348
+ role: 'model',
349
+ parts: [
350
+ { thought: 'This is a thought.' },
351
+ { text: 'This is the visible text that should not be lost.' },
352
+ ],
353
+ },
354
+ finishReason: 'STOP',
355
+ },
356
+ ],
357
+ };
358
+ })();
359
+ vi.mocked(mockContentGenerator.generateContentStream).mockResolvedValue(mixedContentStream);
360
+ // 2. Action: Send a message and fully consume the stream to trigger history recording.
361
+ const stream = await chat.sendMessageStream('test-model', { message: 'test message' }, 'prompt-id-mixed-chunk');
362
+ for await (const _ of stream) {
363
+ // This loop consumes the stream.
364
+ }
365
+ // 3. Assert: Check the final state of the history.
366
+ const history = chat.getHistory();
367
+ // The history should contain two turns: the user's message and the model's response.
368
+ expect(history.length).toBe(2);
369
+ const modelTurn = history[1];
370
+ expect(modelTurn.role).toBe('model');
371
+ // CRUCIAL ASSERTION:
372
+ // The buggy code would fail here, resulting in parts.length being 0.
373
+ // The corrected code will pass, preserving the single visible text part.
374
+ expect(modelTurn?.parts?.length).toBe(1);
375
+ expect(modelTurn?.parts[0].text).toBe('This is the visible text that should not be lost.');
376
+ });
377
+ it('should throw an error when a tool call is followed by an empty stream response', async () => {
378
+ vi.useFakeTimers();
379
+ try {
380
+ // 1. Setup: A history where the model has just made a function call.
381
+ const initialHistory = [
382
+ {
383
+ role: 'user',
384
+ parts: [{ text: 'Find a good Italian restaurant for me.' }],
385
+ },
386
+ {
387
+ role: 'model',
388
+ parts: [
389
+ {
390
+ functionCall: {
391
+ name: 'find_restaurant',
392
+ args: { cuisine: 'Italian' },
393
+ },
394
+ },
395
+ ],
396
+ },
397
+ ];
398
+ chat.setHistory(initialHistory);
399
+ // 2. Mock the API to return an empty/thought-only stream.
400
+ const emptyStreamResponse = (async function* () {
401
+ yield {
402
+ candidates: [
403
+ {
404
+ content: { role: 'model', parts: [{ thought: true }] },
405
+ finishReason: 'STOP',
406
+ },
407
+ ],
408
+ };
409
+ })();
410
+ vi.mocked(mockContentGenerator.generateContentStream).mockResolvedValue(emptyStreamResponse);
411
+ // 3. Action: Send the function response back to the model and consume the stream.
412
+ const stream = await chat.sendMessageStream('test-model', {
413
+ message: {
414
+ functionResponse: {
415
+ name: 'find_restaurant',
416
+ response: { name: 'Vesuvio' },
417
+ },
418
+ },
419
+ }, 'prompt-id-stream-1');
420
+ // 4. Assert: The stream processing should throw an InvalidStreamError.
421
+ await expectStreamExhaustion(stream);
422
+ }
423
+ finally {
424
+ vi.useRealTimers();
425
+ }
426
+ });
427
+ it('should succeed when there is a tool call without finish reason', async () => {
428
+ // Setup: Stream with tool call but no finish reason
429
+ const streamWithToolCall = (async function* () {
430
+ yield {
431
+ candidates: [
432
+ {
433
+ content: {
434
+ role: 'model',
435
+ parts: [
436
+ {
437
+ functionCall: {
438
+ name: 'test_function',
439
+ args: { param: 'value' },
440
+ },
441
+ },
442
+ ],
443
+ },
444
+ // No finishReason
445
+ },
446
+ ],
447
+ };
448
+ })();
449
+ vi.mocked(mockContentGenerator.generateContentStream).mockResolvedValue(streamWithToolCall);
450
+ const stream = await chat.sendMessageStream('test-model', { message: 'test' }, 'prompt-id-1');
451
+ // Should not throw an error
452
+ await expect((async () => {
453
+ for await (const _ of stream) {
454
+ // consume stream
455
+ }
456
+ })()).resolves.not.toThrow();
457
+ });
458
+ it('should throw InvalidStreamError when no tool call and no finish reason', async () => {
459
+ vi.useFakeTimers();
460
+ try {
461
+ // Setup: Stream with text but no finish reason and no tool call
462
+ const streamWithoutFinishReason = (async function* () {
463
+ yield {
464
+ candidates: [
465
+ {
466
+ content: {
467
+ role: 'model',
468
+ parts: [{ text: 'some response' }],
469
+ },
470
+ // No finishReason
471
+ },
472
+ ],
473
+ };
474
+ })();
475
+ vi.mocked(mockContentGenerator.generateContentStream).mockResolvedValue(streamWithoutFinishReason);
476
+ const stream = await chat.sendMessageStream('test-model', { message: 'test' }, 'prompt-id-1');
477
+ await expectStreamExhaustion(stream);
478
+ }
479
+ finally {
480
+ vi.useRealTimers();
481
+ }
482
+ });
483
+ it('should throw InvalidStreamError when no tool call and empty response text', async () => {
484
+ vi.useFakeTimers();
485
+ try {
486
+ // Setup: Stream with finish reason but empty response (only thoughts)
487
+ const streamWithEmptyResponse = (async function* () {
488
+ yield {
489
+ candidates: [
490
+ {
491
+ content: {
492
+ role: 'model',
493
+ parts: [{ thought: 'thinking...' }],
494
+ },
495
+ finishReason: 'STOP',
496
+ },
497
+ ],
498
+ };
499
+ })();
500
+ vi.mocked(mockContentGenerator.generateContentStream).mockResolvedValue(streamWithEmptyResponse);
501
+ const stream = await chat.sendMessageStream('test-model', { message: 'test' }, 'prompt-id-1');
502
+ await expectStreamExhaustion(stream);
503
+ }
504
+ finally {
505
+ vi.useRealTimers();
506
+ }
507
+ });
508
+ it('should succeed when there is finish reason and response text', async () => {
509
+ // Setup: Stream with both finish reason and text content
510
+ const validStream = (async function* () {
511
+ yield {
512
+ candidates: [
513
+ {
514
+ content: {
515
+ role: 'model',
516
+ parts: [{ text: 'valid response' }],
517
+ },
518
+ finishReason: 'STOP',
519
+ },
520
+ ],
521
+ };
522
+ })();
523
+ vi.mocked(mockContentGenerator.generateContentStream).mockResolvedValue(validStream);
524
+ const stream = await chat.sendMessageStream('test-model', { message: 'test' }, 'prompt-id-1');
525
+ // Should not throw an error
526
+ await expect((async () => {
527
+ for await (const _ of stream) {
528
+ // consume stream
529
+ }
530
+ })()).resolves.not.toThrow();
531
+ });
532
+ it('should not lose finish reason when last chunk only has usage metadata', async () => {
533
+ const streamWithTrailingUsageOnlyChunk = (async function* () {
534
+ yield {
535
+ candidates: [
536
+ {
537
+ content: {
538
+ role: 'model',
539
+ parts: [{ text: 'valid response' }],
540
+ },
541
+ finishReason: 'STOP',
542
+ },
543
+ ],
544
+ };
545
+ // Some providers emit a trailing usage-only chunk after finishReason.
546
+ yield {
547
+ candidates: [],
548
+ usageMetadata: {
549
+ promptTokenCount: 11,
550
+ candidatesTokenCount: 5,
551
+ totalTokenCount: 16,
552
+ },
553
+ };
554
+ })();
555
+ vi.mocked(mockContentGenerator.generateContentStream).mockResolvedValue(streamWithTrailingUsageOnlyChunk);
556
+ const stream = await chat.sendMessageStream('test-model', { message: 'test' }, 'prompt-id-1');
557
+ await expect((async () => {
558
+ for await (const _ of stream) {
559
+ // consume stream
560
+ }
561
+ })()).resolves.not.toThrow();
562
+ });
563
+ it('should call generateContentStream with the correct parameters', async () => {
564
+ const response = (async function* () {
565
+ yield {
566
+ candidates: [
567
+ {
568
+ content: {
569
+ parts: [{ text: 'response' }],
570
+ role: 'model',
571
+ },
572
+ finishReason: 'STOP',
573
+ index: 0,
574
+ safetyRatings: [],
575
+ },
576
+ ],
577
+ text: () => 'response',
578
+ usageMetadata: {
579
+ promptTokenCount: 42,
580
+ candidatesTokenCount: 15,
581
+ totalTokenCount: 57,
582
+ },
583
+ };
584
+ })();
585
+ vi.mocked(mockContentGenerator.generateContentStream).mockResolvedValue(response);
586
+ const stream = await chat.sendMessageStream('test-model', { message: 'hello' }, 'prompt-id-1');
587
+ for await (const _ of stream) {
588
+ // consume stream
589
+ }
590
+ expect(mockContentGenerator.generateContentStream).toHaveBeenCalledWith({
591
+ model: 'test-model',
592
+ contents: [
593
+ {
594
+ role: 'user',
595
+ parts: [{ text: 'hello' }],
596
+ },
597
+ ],
598
+ config: {},
599
+ }, 'prompt-id-1');
600
+ // Verify that token counting is called when usageMetadata is present
601
+ expect(uiTelemetryService.setLastPromptTokenCount).toHaveBeenCalledWith(57);
602
+ expect(uiTelemetryService.setLastPromptTokenCount).toHaveBeenCalledTimes(1);
603
+ });
604
+ it('should keep parts with thoughtSignature when consolidating history', async () => {
605
+ const stream = (async function* () {
606
+ yield {
607
+ candidates: [
608
+ {
609
+ content: {
610
+ role: 'model',
611
+ parts: [
612
+ {
613
+ text: 'p1',
614
+ thoughtSignature: 's1',
615
+ },
616
+ ],
617
+ },
618
+ finishReason: 'STOP',
619
+ },
620
+ ],
621
+ };
622
+ })();
623
+ vi.mocked(mockContentGenerator.generateContentStream).mockResolvedValue(stream);
624
+ const res = await chat.sendMessageStream('m1', { message: 'h1' }, 'p1');
625
+ for await (const _ of res)
626
+ ;
627
+ const history = chat.getHistory();
628
+ expect(history[1].parts[0]).toEqual({
629
+ text: 'p1',
630
+ thoughtSignature: 's1',
631
+ });
632
+ });
633
+ });
634
+ describe('addHistory', () => {
635
+ it('should add a new content item to the history', () => {
636
+ const newContent = {
637
+ role: 'user',
638
+ parts: [{ text: 'A new message' }],
639
+ };
640
+ chat.addHistory(newContent);
641
+ const history = chat.getHistory();
642
+ expect(history.length).toBe(1);
643
+ expect(history[0]).toEqual(newContent);
644
+ });
645
+ it('should add multiple items correctly', () => {
646
+ const content1 = {
647
+ role: 'user',
648
+ parts: [{ text: 'Message 1' }],
649
+ };
650
+ const content2 = {
651
+ role: 'model',
652
+ parts: [{ text: 'Message 2' }],
653
+ };
654
+ chat.addHistory(content1);
655
+ chat.addHistory(content2);
656
+ const history = chat.getHistory();
657
+ expect(history.length).toBe(2);
658
+ expect(history[0]).toEqual(content1);
659
+ expect(history[1]).toEqual(content2);
660
+ });
661
+ });
662
+ describe('sendMessageStream with retries', () => {
663
+ it('should retry on invalid content, succeed, and report metrics', async () => {
664
+ vi.useFakeTimers();
665
+ try {
666
+ // Use mockImplementationOnce to provide a fresh, promise-wrapped generator for each attempt.
667
+ vi.mocked(mockContentGenerator.generateContentStream)
668
+ .mockImplementationOnce(async () =>
669
+ // First call returns an invalid stream
670
+ (async function* () {
671
+ yield {
672
+ candidates: [{ content: { parts: [{ text: '' }] } }], // Invalid empty text part
673
+ };
674
+ })())
675
+ .mockImplementationOnce(async () =>
676
+ // Second call returns a valid stream
677
+ (async function* () {
678
+ yield {
679
+ candidates: [
680
+ {
681
+ content: { parts: [{ text: 'Successful response' }] },
682
+ finishReason: 'STOP',
683
+ },
684
+ ],
685
+ };
686
+ })());
687
+ const stream = await chat.sendMessageStream('test-model', { message: 'test' }, 'prompt-id-retry-success');
688
+ const chunks = await collectStreamWithFakeTimers(stream);
689
+ // Assertions
690
+ expect(mockLogContentRetry).toHaveBeenCalledTimes(1);
691
+ expect(mockLogContentRetryFailure).not.toHaveBeenCalled();
692
+ expect(mockContentGenerator.generateContentStream).toHaveBeenCalledTimes(2);
693
+ // Check for a retry event
694
+ expect(chunks.some((c) => c.type === StreamEventType.RETRY)).toBe(true);
695
+ // Check for the successful content chunk
696
+ expect(chunks.some((c) => c.type === StreamEventType.CHUNK &&
697
+ c.value.candidates?.[0]?.content?.parts?.[0]?.text ===
698
+ 'Successful response')).toBe(true);
699
+ // Check that history was recorded correctly once, with no duplicates.
700
+ const history = chat.getHistory();
701
+ expect(history.length).toBe(2);
702
+ expect(history[0]).toEqual({
703
+ role: 'user',
704
+ parts: [{ text: 'test' }],
705
+ });
706
+ expect(history[1]).toEqual({
707
+ role: 'model',
708
+ parts: [{ text: 'Successful response' }],
709
+ });
710
+ // Verify that token counting is not called when usageMetadata is missing
711
+ expect(uiTelemetryService.setLastPromptTokenCount).not.toHaveBeenCalled();
712
+ }
713
+ finally {
714
+ vi.useRealTimers();
715
+ }
716
+ });
717
+ it('should fail after all retries on persistent invalid content and report metrics', async () => {
718
+ vi.useFakeTimers();
719
+ try {
720
+ vi.mocked(mockContentGenerator.generateContentStream).mockImplementation(async () => (async function* () {
721
+ yield {
722
+ candidates: [
723
+ {
724
+ content: {
725
+ parts: [{ text: '' }],
726
+ role: 'model',
727
+ },
728
+ },
729
+ ],
730
+ };
731
+ })());
732
+ const stream = await chat.sendMessageStream('test-model', { message: 'test' }, 'prompt-id-retry-fail');
733
+ await expectStreamExhaustion(stream);
734
+ // Should be called 3 times (1 initial + 2 transient retries)
735
+ expect(mockContentGenerator.generateContentStream).toHaveBeenCalledTimes(3);
736
+ expect(mockLogContentRetry).toHaveBeenCalledTimes(2);
737
+ expect(mockLogContentRetryFailure).toHaveBeenCalledTimes(1);
738
+ // History should still contain the user message.
739
+ const history = chat.getHistory();
740
+ expect(history.length).toBe(1);
741
+ expect(history[0]).toEqual({
742
+ role: 'user',
743
+ parts: [{ text: 'test' }],
744
+ });
745
+ }
746
+ finally {
747
+ vi.useRealTimers();
748
+ }
749
+ });
750
+ it('should retry usage-only empty streams and succeed on a later attempt', async () => {
751
+ vi.useFakeTimers();
752
+ try {
753
+ vi.mocked(mockContentGenerator.generateContentStream)
754
+ .mockImplementationOnce(async () => (async function* () {
755
+ yield {
756
+ usageMetadata: {
757
+ promptTokenCount: 10,
758
+ candidatesTokenCount: 0,
759
+ totalTokenCount: 10,
760
+ },
761
+ };
762
+ })())
763
+ .mockImplementationOnce(async () => (async function* () {
764
+ yield {
765
+ candidates: [
766
+ {
767
+ content: {
768
+ parts: [{ text: 'Recovered after empty stream' }],
769
+ },
770
+ finishReason: 'STOP',
771
+ },
772
+ ],
773
+ };
774
+ })());
775
+ const stream = await chat.sendMessageStream('test-model', { message: 'test' }, 'prompt-id-empty-usage-retry');
776
+ const events = await collectStreamWithFakeTimers(stream);
777
+ expect(mockContentGenerator.generateContentStream).toHaveBeenCalledTimes(2);
778
+ expect(mockLogContentRetry).toHaveBeenCalledTimes(1);
779
+ expect(events.some((e) => e.type === StreamEventType.CHUNK &&
780
+ e.value.candidates?.[0]?.content?.parts?.[0]?.text ===
781
+ 'Recovered after empty stream')).toBe(true);
782
+ }
783
+ finally {
784
+ vi.useRealTimers();
785
+ }
786
+ });
787
+ it('should retry on TPM throttling StreamContentError with fixed delay', async () => {
788
+ vi.useFakeTimers();
789
+ try {
790
+ const tpmError = new StreamContentError('{"error":{"code":"429","message":"Throttling: TPM(1/1)"}}');
791
+ async function* failingStreamGenerator() {
792
+ throw tpmError;
793
+ yield {};
794
+ }
795
+ const failingStream = failingStreamGenerator();
796
+ const successStream = (async function* () {
797
+ yield {
798
+ candidates: [
799
+ {
800
+ content: { parts: [{ text: 'Success after TPM retry' }] },
801
+ finishReason: 'STOP',
802
+ },
803
+ ],
804
+ };
805
+ })();
806
+ vi.mocked(mockContentGenerator.generateContentStream)
807
+ .mockResolvedValueOnce(failingStream)
808
+ .mockResolvedValueOnce(successStream);
809
+ const stream = await chat.sendMessageStream('test-model', { message: 'test' }, 'prompt-id-tpm-retry');
810
+ const iterator = stream[Symbol.asyncIterator]();
811
+ const first = await iterator.next();
812
+ expect(first.done).toBe(false);
813
+ expect(first.value.type).toBe(StreamEventType.RETRY);
814
+ // Resume generator to schedule the TPM delay, then advance timers.
815
+ const secondPromise = iterator.next();
816
+ await vi.advanceTimersByTimeAsync(60_000);
817
+ const second = await secondPromise;
818
+ expect(second.done).toBe(false);
819
+ expect(second.value.type).toBe(StreamEventType.RETRY);
820
+ const events = [first.value, second.value];
821
+ for (;;) {
822
+ const next = await iterator.next();
823
+ if (next.done)
824
+ break;
825
+ events.push(next.value);
826
+ }
827
+ expect(mockContentGenerator.generateContentStream).toHaveBeenCalledTimes(2);
828
+ expect(events.filter((e) => e.type === StreamEventType.RETRY)).toHaveLength(2);
829
+ expect(events.some((e) => e.type === StreamEventType.CHUNK &&
830
+ e.value.candidates?.[0]?.content?.parts?.[0]?.text ===
831
+ 'Success after TPM retry')).toBe(true);
832
+ expect(mockLogContentRetry).not.toHaveBeenCalled();
833
+ }
834
+ finally {
835
+ vi.useRealTimers();
836
+ }
837
+ });
838
+ it('should retry on GLM rate limit StreamContentError with backoff delay', async () => {
839
+ vi.useFakeTimers();
840
+ try {
841
+ const glmError = new StreamContentError('{"error":{"code":"1302","message":"您的账户已达到速率限制,请您控制请求频率"}}');
842
+ async function* failingStreamGenerator() {
843
+ throw glmError;
844
+ yield {};
845
+ }
846
+ const failingStream = failingStreamGenerator();
847
+ const successStream = (async function* () {
848
+ yield {
849
+ candidates: [
850
+ {
851
+ content: { parts: [{ text: 'Success after GLM retry' }] },
852
+ finishReason: 'STOP',
853
+ },
854
+ ],
855
+ };
856
+ })();
857
+ vi.mocked(mockContentGenerator.generateContentStream)
858
+ .mockResolvedValueOnce(failingStream)
859
+ .mockResolvedValueOnce(successStream);
860
+ const stream = await chat.sendMessageStream('test-model', { message: 'test' }, 'prompt-id-glm-retry');
861
+ const iterator = stream[Symbol.asyncIterator]();
862
+ const first = await iterator.next();
863
+ expect(first.done).toBe(false);
864
+ expect(first.value.type).toBe(StreamEventType.RETRY);
865
+ // Resume generator to schedule the rate limit delay, then advance timers.
866
+ const secondPromise = iterator.next();
867
+ await vi.advanceTimersByTimeAsync(60_000);
868
+ const second = await secondPromise;
869
+ expect(second.done).toBe(false);
870
+ expect(second.value.type).toBe(StreamEventType.RETRY);
871
+ // Verify retryInfo contains retry metadata
872
+ if (second.value.type === StreamEventType.RETRY &&
873
+ second.value.retryInfo) {
874
+ expect(second.value.retryInfo.attempt).toBe(1);
875
+ expect(second.value.retryInfo.maxRetries).toBe(10);
876
+ expect(second.value.retryInfo.delayMs).toBe(60000);
877
+ }
878
+ const events = [first.value, second.value];
879
+ for (;;) {
880
+ const next = await iterator.next();
881
+ if (next.done)
882
+ break;
883
+ events.push(next.value);
884
+ }
885
+ expect(mockContentGenerator.generateContentStream).toHaveBeenCalledTimes(2);
886
+ expect(events.filter((e) => e.type === StreamEventType.RETRY)).toHaveLength(2);
887
+ expect(events.some((e) => e.type === StreamEventType.CHUNK &&
888
+ e.value.candidates?.[0]?.content?.parts?.[0]?.text ===
889
+ 'Success after GLM retry')).toBe(true);
890
+ }
891
+ finally {
892
+ vi.useRealTimers();
893
+ }
894
+ });
895
+ describe('API error retry behavior', () => {
896
+ beforeEach(() => {
897
+ // Use a more direct mock for retry testing
898
+ mockRetryWithBackoff.mockImplementation(async (apiCall, options) => {
899
+ try {
900
+ return await apiCall();
901
+ }
902
+ catch (error) {
903
+ if (options?.shouldRetryOnError &&
904
+ options.shouldRetryOnError(error)) {
905
+ // Try again
906
+ return await apiCall();
907
+ }
908
+ throw error;
909
+ }
910
+ });
911
+ });
912
+ it('should not retry on 400 Bad Request errors', async () => {
913
+ const error400 = new ApiError({ message: 'Bad Request', status: 400 });
914
+ vi.mocked(mockContentGenerator.generateContentStream).mockRejectedValue(error400);
915
+ const stream = await chat.sendMessageStream('test-model', { message: 'test' }, 'prompt-id-400');
916
+ await expect((async () => {
917
+ for await (const _ of stream) {
918
+ /* consume stream */
919
+ }
920
+ })()).rejects.toThrow(error400);
921
+ // Should only be called once (no retry)
922
+ expect(mockContentGenerator.generateContentStream).toHaveBeenCalledTimes(1);
923
+ });
924
+ it('should retry on 429 Rate Limit errors', async () => {
925
+ const error429 = new ApiError({ message: 'Rate Limited', status: 429 });
926
+ vi.mocked(mockContentGenerator.generateContentStream)
927
+ .mockRejectedValueOnce(error429)
928
+ .mockResolvedValueOnce((async function* () {
929
+ yield {
930
+ candidates: [
931
+ {
932
+ content: { parts: [{ text: 'Success after retry' }] },
933
+ finishReason: 'STOP',
934
+ },
935
+ ],
936
+ };
937
+ })());
938
+ const stream = await chat.sendMessageStream('test-model', { message: 'test' }, 'prompt-id-429-retry');
939
+ const events = [];
940
+ for await (const event of stream) {
941
+ events.push(event);
942
+ }
943
+ // Should be called twice (initial + retry)
944
+ expect(mockContentGenerator.generateContentStream).toHaveBeenCalledTimes(2);
945
+ // Should have successful content
946
+ expect(events.some((e) => e.type === StreamEventType.CHUNK &&
947
+ e.value.candidates?.[0]?.content?.parts?.[0]?.text ===
948
+ 'Success after retry')).toBe(true);
949
+ });
950
+ it('should not retry on schema depth errors', async () => {
951
+ const schemaError = new ApiError({
952
+ message: 'Request failed: maximum schema depth exceeded',
953
+ status: 500,
954
+ });
955
+ vi.mocked(mockContentGenerator.generateContentStream).mockRejectedValue(schemaError);
956
+ const stream = await chat.sendMessageStream('test-model', { message: 'test' }, 'prompt-id-schema');
957
+ await expect((async () => {
958
+ for await (const _ of stream) {
959
+ /* consume stream */
960
+ }
961
+ })()).rejects.toThrow(schemaError);
962
+ // Should only be called once (no retry)
963
+ expect(mockContentGenerator.generateContentStream).toHaveBeenCalledTimes(1);
964
+ });
965
+ it('should retry on 5xx server errors', async () => {
966
+ const error500 = new ApiError({
967
+ message: 'Internal Server Error 500',
968
+ status: 500,
969
+ });
970
+ vi.mocked(mockContentGenerator.generateContentStream)
971
+ .mockRejectedValueOnce(error500)
972
+ .mockResolvedValueOnce((async function* () {
973
+ yield {
974
+ candidates: [
975
+ {
976
+ content: { parts: [{ text: 'Recovered from 500' }] },
977
+ finishReason: 'STOP',
978
+ },
979
+ ],
980
+ };
981
+ })());
982
+ const stream = await chat.sendMessageStream('test-model', { message: 'test' }, 'prompt-id-500-retry');
983
+ const events = [];
984
+ for await (const event of stream) {
985
+ events.push(event);
986
+ }
987
+ // Should be called twice (initial + retry)
988
+ expect(mockContentGenerator.generateContentStream).toHaveBeenCalledTimes(2);
989
+ });
990
+ afterEach(() => {
991
+ // Reset to default behavior
992
+ mockRetryWithBackoff.mockImplementation(async (apiCall) => apiCall());
993
+ });
994
+ });
995
+ });
996
+ it('should correctly retry and append to an existing history mid-conversation', async () => {
997
+ // 1. Setup
998
+ const initialHistory = [
999
+ { role: 'user', parts: [{ text: 'First question' }] },
1000
+ { role: 'model', parts: [{ text: 'First answer' }] },
1001
+ ];
1002
+ chat.setHistory(initialHistory);
1003
+ // 2. Mock the API to fail once with an empty stream, then succeed.
1004
+ vi.mocked(mockContentGenerator.generateContentStream)
1005
+ .mockImplementationOnce(async () => (async function* () {
1006
+ yield {
1007
+ candidates: [{ content: { parts: [{ text: '' }] } }],
1008
+ };
1009
+ })())
1010
+ .mockImplementationOnce(async () =>
1011
+ // Second attempt succeeds
1012
+ (async function* () {
1013
+ yield {
1014
+ candidates: [
1015
+ {
1016
+ content: { parts: [{ text: 'Second answer' }] },
1017
+ finishReason: 'STOP',
1018
+ },
1019
+ ],
1020
+ };
1021
+ })());
1022
+ // 3. Send a new message
1023
+ const stream = await chat.sendMessageStream('test-model', { message: 'Second question' }, 'prompt-id-retry-existing');
1024
+ for await (const _ of stream) {
1025
+ // consume stream
1026
+ }
1027
+ // 4. Assert the final history and metrics
1028
+ const history = chat.getHistory();
1029
+ expect(history.length).toBe(4);
1030
+ // Assert that the correct metrics were reported for one empty-stream retry
1031
+ expect(mockLogContentRetry).toHaveBeenCalledTimes(1);
1032
+ // Explicitly verify the structure of each part to satisfy TypeScript
1033
+ const turn1 = history[0];
1034
+ if (!turn1?.parts?.[0] || !('text' in turn1.parts[0])) {
1035
+ throw new Error('Test setup error: First turn is not a valid text part.');
1036
+ }
1037
+ expect(turn1.parts[0].text).toBe('First question');
1038
+ const turn2 = history[1];
1039
+ if (!turn2?.parts?.[0] || !('text' in turn2.parts[0])) {
1040
+ throw new Error('Test setup error: Second turn is not a valid text part.');
1041
+ }
1042
+ expect(turn2.parts[0].text).toBe('First answer');
1043
+ const turn3 = history[2];
1044
+ if (!turn3?.parts?.[0] || !('text' in turn3.parts[0])) {
1045
+ throw new Error('Test setup error: Third turn is not a valid text part.');
1046
+ }
1047
+ expect(turn3.parts[0].text).toBe('Second question');
1048
+ const turn4 = history[3];
1049
+ if (!turn4?.parts?.[0] || !('text' in turn4.parts[0])) {
1050
+ throw new Error('Test setup error: Fourth turn is not a valid text part.');
1051
+ }
1052
+ expect(turn4.parts[0].text).toBe('Second answer');
1053
+ });
1054
+ it('should retry if the model returns a completely empty stream (no chunks)', async () => {
1055
+ // 1. Mock the API to return an empty stream first, then a valid one.
1056
+ vi.mocked(mockContentGenerator.generateContentStream)
1057
+ .mockImplementationOnce(
1058
+ // First call resolves to an async generator that yields nothing.
1059
+ async () => (async function* () { })())
1060
+ .mockImplementationOnce(
1061
+ // Second call returns a valid stream.
1062
+ async () => (async function* () {
1063
+ yield {
1064
+ candidates: [
1065
+ {
1066
+ content: {
1067
+ parts: [{ text: 'Successful response after empty' }],
1068
+ },
1069
+ finishReason: 'STOP',
1070
+ },
1071
+ ],
1072
+ };
1073
+ })());
1074
+ // 2. Call the method and consume the stream.
1075
+ const stream = await chat.sendMessageStream('test-model', { message: 'test empty stream' }, 'prompt-id-empty-stream');
1076
+ const chunks = [];
1077
+ for await (const chunk of stream) {
1078
+ chunks.push(chunk);
1079
+ }
1080
+ // 3. Assert the results.
1081
+ expect(mockContentGenerator.generateContentStream).toHaveBeenCalledTimes(2);
1082
+ expect(chunks.some((c) => c.type === StreamEventType.CHUNK &&
1083
+ c.value.candidates?.[0]?.content?.parts?.[0]?.text ===
1084
+ 'Successful response after empty')).toBe(true);
1085
+ const history = chat.getHistory();
1086
+ expect(history.length).toBe(2);
1087
+ // Explicitly verify the structure of each part to satisfy TypeScript
1088
+ const turn1 = history[0];
1089
+ if (!turn1?.parts?.[0] || !('text' in turn1.parts[0])) {
1090
+ throw new Error('Test setup error: First turn is not a valid text part.');
1091
+ }
1092
+ expect(turn1.parts[0].text).toBe('test empty stream');
1093
+ const turn2 = history[1];
1094
+ if (!turn2?.parts?.[0] || !('text' in turn2.parts[0])) {
1095
+ throw new Error('Test setup error: Second turn is not a valid text part.');
1096
+ }
1097
+ expect(turn2.parts[0].text).toBe('Successful response after empty');
1098
+ });
1099
+ it('should queue a subsequent sendMessageStream call until the first stream is fully consumed', async () => {
1100
+ // 1. Create a promise to manually control the stream's lifecycle
1101
+ let continueFirstStream;
1102
+ const firstStreamContinuePromise = new Promise((resolve) => {
1103
+ continueFirstStream = resolve;
1104
+ });
1105
+ // 2. Mock the API to return controllable async generators
1106
+ const firstStreamGenerator = (async function* () {
1107
+ yield {
1108
+ candidates: [
1109
+ { content: { parts: [{ text: 'first response part 1' }] } },
1110
+ ],
1111
+ };
1112
+ await firstStreamContinuePromise; // Pause the stream
1113
+ yield {
1114
+ candidates: [
1115
+ {
1116
+ content: { parts: [{ text: ' part 2' }] },
1117
+ finishReason: 'STOP',
1118
+ },
1119
+ ],
1120
+ };
1121
+ })();
1122
+ const secondStreamGenerator = (async function* () {
1123
+ yield {
1124
+ candidates: [
1125
+ {
1126
+ content: { parts: [{ text: 'second response' }] },
1127
+ finishReason: 'STOP',
1128
+ },
1129
+ ],
1130
+ };
1131
+ })();
1132
+ vi.mocked(mockContentGenerator.generateContentStream)
1133
+ .mockResolvedValueOnce(firstStreamGenerator)
1134
+ .mockResolvedValueOnce(secondStreamGenerator);
1135
+ // 3. Start the first stream and consume only the first chunk to pause it
1136
+ const firstStream = await chat.sendMessageStream('test-model', { message: 'first' }, 'prompt-1');
1137
+ const firstStreamIterator = firstStream[Symbol.asyncIterator]();
1138
+ await firstStreamIterator.next();
1139
+ // 4. While the first stream is paused, start the second call. It will block.
1140
+ const secondStreamPromise = chat.sendMessageStream('test-model', { message: 'second' }, 'prompt-2');
1141
+ // 5. Assert that only one API call has been made so far.
1142
+ expect(mockContentGenerator.generateContentStream).toHaveBeenCalledTimes(1);
1143
+ // 6. Unblock and fully consume the first stream to completion.
1144
+ continueFirstStream();
1145
+ await firstStreamIterator.next(); // Consume the rest of the stream
1146
+ await firstStreamIterator.next(); // Finish the iterator
1147
+ // 7. Now that the first stream is done, await the second promise to get its generator.
1148
+ const secondStream = await secondStreamPromise;
1149
+ // 8. Start consuming the second stream, which triggers its internal API call.
1150
+ const secondStreamIterator = secondStream[Symbol.asyncIterator]();
1151
+ await secondStreamIterator.next();
1152
+ // 9. The second API call should now have been made.
1153
+ expect(mockContentGenerator.generateContentStream).toHaveBeenCalledTimes(2);
1154
+ // 10. FIX: Fully consume the second stream to ensure recordHistory is called.
1155
+ await secondStreamIterator.next(); // This finishes the iterator.
1156
+ // 11. Final check on history.
1157
+ const history = chat.getHistory();
1158
+ expect(history.length).toBe(4);
1159
+ const turn4 = history[3];
1160
+ if (!turn4?.parts?.[0] || !('text' in turn4.parts[0])) {
1161
+ throw new Error('Test setup error: Fourth turn is not a valid text part.');
1162
+ }
1163
+ expect(turn4.parts[0].text).toBe('second response');
1164
+ });
1165
+ describe('Model Resolution', () => {
1166
+ const mockResponse = {
1167
+ candidates: [
1168
+ {
1169
+ content: { parts: [{ text: 'response' }], role: 'model' },
1170
+ finishReason: 'STOP',
1171
+ },
1172
+ ],
1173
+ };
1174
+ it('should pass the requested model through to generateContentStream', async () => {
1175
+ vi.mocked(mockConfig.getModel).mockReturnValue('gemini-pro');
1176
+ vi.mocked(mockContentGenerator.generateContentStream).mockImplementation(async () => (async function* () {
1177
+ yield mockResponse;
1178
+ })());
1179
+ const stream = await chat.sendMessageStream('test-model', { message: 'test' }, 'prompt-id-res3');
1180
+ for await (const _ of stream) {
1181
+ // consume stream
1182
+ }
1183
+ expect(mockContentGenerator.generateContentStream).toHaveBeenCalledWith(expect.objectContaining({
1184
+ model: 'test-model',
1185
+ }), 'prompt-id-res3');
1186
+ });
1187
+ });
1188
+ it('should discard valid partial content from a failed attempt upon retry', async () => {
1189
+ // Mock the stream to fail on the first attempt after yielding some valid content.
1190
+ vi.mocked(mockContentGenerator.generateContentStream)
1191
+ .mockImplementationOnce(async () =>
1192
+ // First attempt: yields one valid chunk, then one invalid chunk
1193
+ (async function* () {
1194
+ yield {
1195
+ candidates: [
1196
+ {
1197
+ content: {
1198
+ parts: [{ text: 'This valid part should be discarded' }],
1199
+ },
1200
+ },
1201
+ ],
1202
+ };
1203
+ yield {
1204
+ candidates: [{ content: { parts: [{ text: '' }] } }], // Invalid chunk triggers retry
1205
+ };
1206
+ })())
1207
+ .mockImplementationOnce(async () =>
1208
+ // Second attempt (the retry): succeeds
1209
+ (async function* () {
1210
+ yield {
1211
+ candidates: [
1212
+ {
1213
+ content: {
1214
+ parts: [{ text: 'Successful final response' }],
1215
+ },
1216
+ finishReason: 'STOP',
1217
+ },
1218
+ ],
1219
+ };
1220
+ })());
1221
+ // Send a message and consume the stream
1222
+ const stream = await chat.sendMessageStream('test-model', { message: 'test' }, 'prompt-id-discard-test');
1223
+ const events = [];
1224
+ for await (const event of stream) {
1225
+ events.push(event);
1226
+ }
1227
+ // Check that a retry happened
1228
+ expect(mockContentGenerator.generateContentStream).toHaveBeenCalledTimes(2);
1229
+ expect(events.some((e) => e.type === StreamEventType.RETRY)).toBe(true);
1230
+ // Check the final recorded history
1231
+ const history = chat.getHistory();
1232
+ expect(history.length).toBe(2); // user turn + final model turn
1233
+ const modelTurn = history[1];
1234
+ // The model turn should only contain the text from the successful attempt
1235
+ expect(modelTurn.parts[0].text).toBe('Successful final response');
1236
+ // It should NOT contain any text from the failed attempt
1237
+ expect(modelTurn.parts[0].text).not.toContain('This valid part should be discarded');
1238
+ });
1239
+ describe('stripThoughtsFromHistory', () => {
1240
+ it('should strip thoughts and thought signatures, and remove empty content objects', () => {
1241
+ chat.setHistory([
1242
+ {
1243
+ role: 'user',
1244
+ parts: [{ text: 'hello' }],
1245
+ },
1246
+ {
1247
+ role: 'model',
1248
+ parts: [
1249
+ { text: 'thinking...', thought: true },
1250
+ { text: 'hi' },
1251
+ {
1252
+ text: 'hidden metadata',
1253
+ thoughtSignature: 'abc',
1254
+ },
1255
+ ],
1256
+ },
1257
+ {
1258
+ role: 'model',
1259
+ parts: [{ text: 'only thinking', thought: true }],
1260
+ },
1261
+ ]);
1262
+ chat.stripThoughtsFromHistory();
1263
+ expect(chat.getHistory()).toEqual([
1264
+ {
1265
+ role: 'user',
1266
+ parts: [{ text: 'hello' }],
1267
+ },
1268
+ {
1269
+ role: 'model',
1270
+ parts: [{ text: 'hi' }, { text: 'hidden metadata' }],
1271
+ },
1272
+ ]);
1273
+ });
1274
+ });
1275
+ });
1276
+ //# sourceMappingURL=geminiChat.test.js.map