@office-ai/aioncli-core 0.2.3 → 0.18.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (1051) hide show
  1. package/dist/index.d.ts +16 -3
  2. package/dist/index.js +15 -3
  3. package/dist/index.js.map +1 -1
  4. package/dist/src/agents/codebase-investigator.d.ts +46 -0
  5. package/dist/src/agents/codebase-investigator.js +132 -0
  6. package/dist/src/agents/codebase-investigator.js.map +1 -0
  7. package/dist/src/agents/codebase-investigator.test.js +35 -0
  8. package/dist/src/agents/codebase-investigator.test.js.map +1 -0
  9. package/dist/src/agents/executor.d.ts +114 -0
  10. package/dist/src/agents/executor.js +779 -0
  11. package/dist/src/agents/executor.js.map +1 -0
  12. package/dist/src/agents/executor.test.js +1362 -0
  13. package/dist/src/agents/executor.test.js.map +1 -0
  14. package/dist/src/agents/invocation.d.ts +46 -0
  15. package/dist/src/agents/invocation.js +102 -0
  16. package/dist/src/agents/invocation.js.map +1 -0
  17. package/dist/src/agents/invocation.test.js +215 -0
  18. package/dist/src/agents/invocation.test.js.map +1 -0
  19. package/dist/src/agents/registry.d.ts +40 -0
  20. package/dist/src/agents/registry.js +105 -0
  21. package/dist/src/agents/registry.js.map +1 -0
  22. package/dist/src/agents/registry.test.d.ts +6 -0
  23. package/dist/src/agents/registry.test.js +160 -0
  24. package/dist/src/agents/registry.test.js.map +1 -0
  25. package/dist/src/agents/schema-utils.d.ts +39 -0
  26. package/dist/src/agents/schema-utils.js +57 -0
  27. package/dist/src/agents/schema-utils.js.map +1 -0
  28. package/dist/src/agents/schema-utils.test.d.ts +6 -0
  29. package/dist/src/agents/schema-utils.test.js +144 -0
  30. package/dist/src/agents/schema-utils.test.js.map +1 -0
  31. package/dist/src/agents/subagent-tool-wrapper.d.ts +38 -0
  32. package/dist/src/agents/subagent-tool-wrapper.js +48 -0
  33. package/dist/src/agents/subagent-tool-wrapper.js.map +1 -0
  34. package/dist/src/agents/subagent-tool-wrapper.test.d.ts +6 -0
  35. package/dist/src/agents/subagent-tool-wrapper.test.js +110 -0
  36. package/dist/src/agents/subagent-tool-wrapper.test.js.map +1 -0
  37. package/dist/src/agents/types.d.ts +146 -0
  38. package/dist/src/agents/types.js +19 -0
  39. package/dist/src/agents/types.js.map +1 -0
  40. package/dist/src/agents/utils.d.ts +15 -0
  41. package/dist/src/agents/utils.js +29 -0
  42. package/dist/src/agents/utils.js.map +1 -0
  43. package/dist/src/agents/utils.test.d.ts +6 -0
  44. package/dist/src/agents/utils.test.js +87 -0
  45. package/dist/src/agents/utils.test.js.map +1 -0
  46. package/dist/src/code_assist/codeAssist.d.ts +6 -3
  47. package/dist/src/code_assist/codeAssist.js +13 -1
  48. package/dist/src/code_assist/codeAssist.js.map +1 -1
  49. package/dist/src/code_assist/codeAssist.test.d.ts +6 -0
  50. package/dist/src/code_assist/codeAssist.test.js +99 -0
  51. package/dist/src/code_assist/codeAssist.test.js.map +1 -0
  52. package/dist/src/code_assist/converter.d.ts +5 -1
  53. package/dist/src/code_assist/converter.js +39 -5
  54. package/dist/src/code_assist/converter.js.map +1 -1
  55. package/dist/src/code_assist/converter.test.js +112 -0
  56. package/dist/src/code_assist/converter.test.js.map +1 -1
  57. package/dist/src/code_assist/experiments/client_metadata.d.ts +12 -0
  58. package/dist/src/code_assist/experiments/client_metadata.js +50 -0
  59. package/dist/src/code_assist/experiments/client_metadata.js.map +1 -0
  60. package/dist/src/code_assist/experiments/client_metadata.test.d.ts +6 -0
  61. package/dist/src/code_assist/experiments/client_metadata.test.js +99 -0
  62. package/dist/src/code_assist/experiments/client_metadata.test.js.map +1 -0
  63. package/dist/src/code_assist/experiments/experiments.d.ts +17 -0
  64. package/dist/src/code_assist/experiments/experiments.js +36 -0
  65. package/dist/src/code_assist/experiments/experiments.js.map +1 -0
  66. package/dist/src/code_assist/experiments/experiments.test.d.ts +6 -0
  67. package/dist/src/code_assist/experiments/experiments.test.js +92 -0
  68. package/dist/src/code_assist/experiments/experiments.test.js.map +1 -0
  69. package/dist/src/code_assist/experiments/flagNames.d.ts +13 -0
  70. package/dist/src/code_assist/experiments/flagNames.js +13 -0
  71. package/dist/src/code_assist/experiments/flagNames.js.map +1 -0
  72. package/dist/src/code_assist/experiments/types.d.ts +35 -0
  73. package/dist/src/code_assist/experiments/types.js +7 -0
  74. package/dist/src/code_assist/experiments/types.js.map +1 -0
  75. package/dist/src/code_assist/oauth-credential-storage.d.ts +25 -0
  76. package/dist/src/code_assist/oauth-credential-storage.js +110 -0
  77. package/dist/src/code_assist/oauth-credential-storage.js.map +1 -0
  78. package/dist/src/code_assist/oauth-credential-storage.test.d.ts +6 -0
  79. package/dist/src/code_assist/oauth-credential-storage.test.js +198 -0
  80. package/dist/src/code_assist/oauth-credential-storage.test.js.map +1 -0
  81. package/dist/src/code_assist/oauth2.d.ts +3 -3
  82. package/dist/src/code_assist/oauth2.js +252 -125
  83. package/dist/src/code_assist/oauth2.js.map +1 -1
  84. package/dist/src/code_assist/oauth2.test.js +788 -350
  85. package/dist/src/code_assist/oauth2.test.js.map +1 -1
  86. package/dist/src/code_assist/server.d.ts +8 -6
  87. package/dist/src/code_assist/server.js +41 -10
  88. package/dist/src/code_assist/server.js.map +1 -1
  89. package/dist/src/code_assist/server.test.js +151 -28
  90. package/dist/src/code_assist/server.test.js.map +1 -1
  91. package/dist/src/code_assist/setup.d.ts +2 -2
  92. package/dist/src/code_assist/setup.js +5 -3
  93. package/dist/src/code_assist/setup.js.map +1 -1
  94. package/dist/src/code_assist/setup.test.js.map +1 -1
  95. package/dist/src/code_assist/types.d.ts +18 -3
  96. package/dist/src/code_assist/types.js.map +1 -1
  97. package/dist/src/commands/extensions.d.ts +7 -0
  98. package/dist/src/commands/extensions.js +9 -0
  99. package/dist/src/commands/extensions.js.map +1 -0
  100. package/dist/src/commands/extensions.test.d.ts +6 -0
  101. package/dist/src/commands/extensions.test.js +19 -0
  102. package/dist/src/commands/extensions.test.js.map +1 -0
  103. package/dist/src/config/config.d.ts +282 -60
  104. package/dist/src/config/config.js +677 -129
  105. package/dist/src/config/config.js.map +1 -1
  106. package/dist/src/config/config.test.js +1020 -146
  107. package/dist/src/config/config.test.js.map +1 -1
  108. package/dist/src/config/constants.d.ts +11 -0
  109. package/dist/src/config/constants.js +16 -0
  110. package/dist/src/config/constants.js.map +1 -0
  111. package/dist/src/config/defaultModelConfigs.d.ts +7 -0
  112. package/dist/src/config/defaultModelConfigs.js +185 -0
  113. package/dist/src/config/defaultModelConfigs.js.map +1 -0
  114. package/dist/src/config/models.d.ts +37 -0
  115. package/dist/src/config/models.js +72 -0
  116. package/dist/src/config/models.js.map +1 -1
  117. package/dist/src/config/models.test.d.ts +6 -0
  118. package/dist/src/config/models.test.js +116 -0
  119. package/dist/src/config/models.test.js.map +1 -0
  120. package/dist/src/config/storage.d.ts +36 -0
  121. package/dist/src/config/storage.js +115 -0
  122. package/dist/src/config/storage.js.map +1 -0
  123. package/dist/src/config/storage.test.d.ts +6 -0
  124. package/dist/src/config/storage.test.js +48 -0
  125. package/dist/src/config/storage.test.js.map +1 -0
  126. package/dist/src/confirmation-bus/index.d.ts +7 -0
  127. package/dist/src/confirmation-bus/index.js +8 -0
  128. package/dist/src/confirmation-bus/index.js.map +1 -0
  129. package/dist/src/confirmation-bus/message-bus.d.ts +18 -0
  130. package/dist/src/confirmation-bus/message-bus.js +87 -0
  131. package/dist/src/confirmation-bus/message-bus.js.map +1 -0
  132. package/dist/src/confirmation-bus/message-bus.test.d.ts +6 -0
  133. package/dist/src/confirmation-bus/message-bus.test.js +170 -0
  134. package/dist/src/confirmation-bus/message-bus.test.js.map +1 -0
  135. package/dist/src/confirmation-bus/types.d.ts +49 -0
  136. package/dist/src/confirmation-bus/types.js +16 -0
  137. package/dist/src/confirmation-bus/types.js.map +1 -0
  138. package/dist/src/core/apiKeyCredentialStorage.d.ts +17 -0
  139. package/dist/src/core/apiKeyCredentialStorage.js +64 -0
  140. package/dist/src/core/apiKeyCredentialStorage.js.map +1 -0
  141. package/dist/src/core/apiKeyCredentialStorage.test.d.ts +6 -0
  142. package/dist/src/core/apiKeyCredentialStorage.test.js +71 -0
  143. package/dist/src/core/apiKeyCredentialStorage.test.js.map +1 -0
  144. package/dist/src/core/baseLlmClient.d.ts +50 -0
  145. package/dist/src/core/baseLlmClient.js +185 -0
  146. package/dist/src/core/baseLlmClient.js.map +1 -0
  147. package/dist/src/core/baseLlmClient.test.d.ts +6 -0
  148. package/dist/src/core/baseLlmClient.test.js +311 -0
  149. package/dist/src/core/baseLlmClient.test.js.map +1 -0
  150. package/dist/src/core/client.d.ts +30 -42
  151. package/dist/src/core/client.js +178 -477
  152. package/dist/src/core/client.js.map +1 -1
  153. package/dist/src/core/client.test.js +739 -617
  154. package/dist/src/core/client.test.js.map +1 -1
  155. package/dist/src/core/contentGenerator.d.ts +7 -6
  156. package/dist/src/core/contentGenerator.js +59 -45
  157. package/dist/src/core/contentGenerator.js.map +1 -1
  158. package/dist/src/core/contentGenerator.test.js +50 -4
  159. package/dist/src/core/contentGenerator.test.js.map +1 -1
  160. package/dist/src/core/coreToolScheduler.d.ts +28 -11
  161. package/dist/src/core/coreToolScheduler.js +493 -161
  162. package/dist/src/core/coreToolScheduler.js.map +1 -1
  163. package/dist/src/core/coreToolScheduler.test.js +995 -163
  164. package/dist/src/core/coreToolScheduler.test.js.map +1 -1
  165. package/dist/src/core/fakeContentGenerator.d.ts +33 -0
  166. package/dist/src/core/fakeContentGenerator.js +58 -0
  167. package/dist/src/core/fakeContentGenerator.js.map +1 -0
  168. package/dist/src/core/fakeContentGenerator.test.d.ts +6 -0
  169. package/dist/src/core/fakeContentGenerator.test.js +127 -0
  170. package/dist/src/core/fakeContentGenerator.test.js.map +1 -0
  171. package/dist/src/core/geminiChat.d.ts +61 -55
  172. package/dist/src/core/geminiChat.js +388 -366
  173. package/dist/src/core/geminiChat.js.map +1 -1
  174. package/dist/src/core/geminiChat.test.js +1600 -355
  175. package/dist/src/core/geminiChat.test.js.map +1 -1
  176. package/dist/src/core/geminiRequest.js +1 -0
  177. package/dist/src/core/geminiRequest.js.map +1 -1
  178. package/dist/src/core/logger.d.ts +11 -4
  179. package/dist/src/core/logger.js +39 -30
  180. package/dist/src/core/logger.js.map +1 -1
  181. package/dist/src/core/logger.test.js +62 -45
  182. package/dist/src/core/logger.test.js.map +1 -1
  183. package/dist/src/core/loggingContentGenerator.d.ts +4 -3
  184. package/dist/src/core/loggingContentGenerator.js +116 -37
  185. package/dist/src/core/loggingContentGenerator.js.map +1 -1
  186. package/dist/src/core/loggingContentGenerator.test.d.ts +6 -0
  187. package/dist/src/core/loggingContentGenerator.test.js +180 -0
  188. package/dist/src/core/loggingContentGenerator.test.js.map +1 -0
  189. package/dist/src/core/nonInteractiveToolExecutor.d.ts +4 -5
  190. package/dist/src/core/nonInteractiveToolExecutor.js +17 -120
  191. package/dist/src/core/nonInteractiveToolExecutor.js.map +1 -1
  192. package/dist/src/core/nonInteractiveToolExecutor.test.js +168 -84
  193. package/dist/src/core/nonInteractiveToolExecutor.test.js.map +1 -1
  194. package/dist/src/core/openaiContentGenerator.d.ts +4 -3
  195. package/dist/src/core/openaiContentGenerator.js +49 -19
  196. package/dist/src/core/openaiContentGenerator.js.map +1 -1
  197. package/dist/src/core/openaiContentGenerator.test.js +1 -0
  198. package/dist/src/core/openaiContentGenerator.test.js.map +1 -1
  199. package/dist/src/core/prompts.d.ts +7 -1
  200. package/dist/src/core/prompts.js +198 -195
  201. package/dist/src/core/prompts.js.map +1 -1
  202. package/dist/src/core/prompts.test.js +172 -104
  203. package/dist/src/core/prompts.test.js.map +1 -1
  204. package/dist/src/core/recordingContentGenerator.d.ts +18 -0
  205. package/dist/src/core/recordingContentGenerator.js +77 -0
  206. package/dist/src/core/recordingContentGenerator.js.map +1 -0
  207. package/dist/src/core/recordingContentGenerator.test.d.ts +6 -0
  208. package/dist/src/core/recordingContentGenerator.test.js +101 -0
  209. package/dist/src/core/recordingContentGenerator.test.js.map +1 -0
  210. package/dist/src/core/subagent.d.ts +24 -18
  211. package/dist/src/core/subagent.js +125 -90
  212. package/dist/src/core/subagent.js.map +1 -1
  213. package/dist/src/core/subagent.test.js +59 -44
  214. package/dist/src/core/subagent.test.js.map +1 -1
  215. package/dist/src/core/tokenLimits.test.d.ts +6 -0
  216. package/dist/src/core/tokenLimits.test.js +26 -0
  217. package/dist/src/core/tokenLimits.test.js.map +1 -0
  218. package/dist/src/core/turn.d.ts +57 -13
  219. package/dist/src/core/turn.js +79 -35
  220. package/dist/src/core/turn.js.map +1 -1
  221. package/dist/src/core/turn.test.js +373 -120
  222. package/dist/src/core/turn.test.js.map +1 -1
  223. package/dist/src/fallback/handler.d.ts +7 -0
  224. package/dist/src/fallback/handler.js +181 -0
  225. package/dist/src/fallback/handler.js.map +1 -0
  226. package/dist/src/fallback/handler.test.d.ts +6 -0
  227. package/dist/src/fallback/handler.test.js +245 -0
  228. package/dist/src/fallback/handler.test.js.map +1 -0
  229. package/dist/src/fallback/types.d.ts +14 -0
  230. package/dist/src/fallback/types.js +7 -0
  231. package/dist/src/fallback/types.js.map +1 -0
  232. package/dist/src/generated/git-commit.d.ts +2 -2
  233. package/dist/src/generated/git-commit.js +2 -2
  234. package/dist/src/generated/git-commit.js.map +1 -1
  235. package/dist/src/hooks/hookAggregator.d.ts +68 -0
  236. package/dist/src/hooks/hookAggregator.js +262 -0
  237. package/dist/src/hooks/hookAggregator.js.map +1 -0
  238. package/dist/src/hooks/hookAggregator.test.d.ts +6 -0
  239. package/dist/src/hooks/hookAggregator.test.js +387 -0
  240. package/dist/src/hooks/hookAggregator.test.js.map +1 -0
  241. package/dist/src/hooks/hookPlanner.d.ts +46 -0
  242. package/dist/src/hooks/hookPlanner.js +108 -0
  243. package/dist/src/hooks/hookPlanner.js.map +1 -0
  244. package/dist/src/hooks/hookPlanner.test.d.ts +6 -0
  245. package/dist/src/hooks/hookPlanner.test.js +255 -0
  246. package/dist/src/hooks/hookPlanner.test.js.map +1 -0
  247. package/dist/src/hooks/hookRegistry.d.ts +87 -0
  248. package/dist/src/hooks/hookRegistry.js +198 -0
  249. package/dist/src/hooks/hookRegistry.js.map +1 -0
  250. package/dist/src/hooks/hookRegistry.test.d.ts +6 -0
  251. package/dist/src/hooks/hookRegistry.test.js +341 -0
  252. package/dist/src/hooks/hookRegistry.test.js.map +1 -0
  253. package/dist/src/hooks/hookRunner.d.ts +42 -0
  254. package/dist/src/hooks/hookRunner.js +272 -0
  255. package/dist/src/hooks/hookRunner.js.map +1 -0
  256. package/dist/src/hooks/hookRunner.test.d.ts +6 -0
  257. package/dist/src/hooks/hookRunner.test.js +468 -0
  258. package/dist/src/hooks/hookRunner.test.js.map +1 -0
  259. package/dist/src/hooks/hookTranslator.d.ts +113 -0
  260. package/dist/src/hooks/hookTranslator.js +232 -0
  261. package/dist/src/hooks/hookTranslator.js.map +1 -0
  262. package/dist/src/hooks/hookTranslator.test.d.ts +6 -0
  263. package/dist/src/hooks/hookTranslator.test.js +192 -0
  264. package/dist/src/hooks/hookTranslator.test.js.map +1 -0
  265. package/dist/src/hooks/types.d.ts +384 -0
  266. package/dist/src/hooks/types.js +284 -0
  267. package/dist/src/hooks/types.js.map +1 -0
  268. package/dist/src/hooks/types.test.d.ts +6 -0
  269. package/dist/src/hooks/types.test.js +313 -0
  270. package/dist/src/hooks/types.test.js.map +1 -0
  271. package/dist/src/ide/constants.d.ts +3 -0
  272. package/dist/src/ide/constants.js +3 -0
  273. package/dist/src/ide/constants.js.map +1 -1
  274. package/dist/src/ide/detect-ide.d.ts +52 -12
  275. package/dist/src/ide/detect-ide.js +51 -65
  276. package/dist/src/ide/detect-ide.js.map +1 -1
  277. package/dist/src/ide/detect-ide.test.js +95 -52
  278. package/dist/src/ide/detect-ide.test.js.map +1 -1
  279. package/dist/src/ide/ide-client.d.ts +72 -24
  280. package/dist/src/ide/ide-client.js +380 -84
  281. package/dist/src/ide/ide-client.js.map +1 -1
  282. package/dist/src/ide/ide-client.test.js +539 -35
  283. package/dist/src/ide/ide-client.test.js.map +1 -1
  284. package/dist/src/ide/ide-installer.d.ts +2 -2
  285. package/dist/src/ide/ide-installer.js +93 -35
  286. package/dist/src/ide/ide-installer.js.map +1 -1
  287. package/dist/src/ide/ide-installer.test.js +157 -26
  288. package/dist/src/ide/ide-installer.test.js.map +1 -1
  289. package/dist/src/ide/ideContext.d.ts +35 -365
  290. package/dist/src/ide/ideContext.js +60 -106
  291. package/dist/src/ide/ideContext.js.map +1 -1
  292. package/dist/src/ide/ideContext.test.js +152 -24
  293. package/dist/src/ide/ideContext.test.js.map +1 -1
  294. package/dist/src/ide/process-utils.d.ts +7 -5
  295. package/dist/src/ide/process-utils.js +108 -67
  296. package/dist/src/ide/process-utils.js.map +1 -1
  297. package/dist/src/ide/process-utils.test.d.ts +6 -0
  298. package/dist/src/ide/process-utils.test.js +151 -0
  299. package/dist/src/ide/process-utils.test.js.map +1 -0
  300. package/dist/src/ide/types.d.ts +486 -0
  301. package/dist/src/ide/types.js +138 -0
  302. package/dist/src/ide/types.js.map +1 -0
  303. package/dist/src/index.d.ts +41 -2
  304. package/dist/src/index.js +44 -2
  305. package/dist/src/index.js.map +1 -1
  306. package/dist/src/mcp/google-auth-provider.d.ts +5 -3
  307. package/dist/src/mcp/google-auth-provider.js +21 -3
  308. package/dist/src/mcp/google-auth-provider.js.map +1 -1
  309. package/dist/src/mcp/google-auth-provider.test.js +42 -9
  310. package/dist/src/mcp/google-auth-provider.test.js.map +1 -1
  311. package/dist/src/mcp/oauth-provider.d.ts +25 -18
  312. package/dist/src/mcp/oauth-provider.js +194 -97
  313. package/dist/src/mcp/oauth-provider.js.map +1 -1
  314. package/dist/src/mcp/oauth-provider.test.js +581 -39
  315. package/dist/src/mcp/oauth-provider.test.js.map +1 -1
  316. package/dist/src/mcp/oauth-token-storage.d.ts +14 -32
  317. package/dist/src/mcp/oauth-token-storage.js +58 -28
  318. package/dist/src/mcp/oauth-token-storage.js.map +1 -1
  319. package/dist/src/mcp/oauth-token-storage.test.js +262 -162
  320. package/dist/src/mcp/oauth-token-storage.test.js.map +1 -1
  321. package/dist/src/mcp/oauth-utils.d.ts +16 -1
  322. package/dist/src/mcp/oauth-utils.js +68 -33
  323. package/dist/src/mcp/oauth-utils.js.map +1 -1
  324. package/dist/src/mcp/oauth-utils.test.js +86 -3
  325. package/dist/src/mcp/oauth-utils.test.js.map +1 -1
  326. package/dist/src/mcp/sa-impersonation-provider.d.ts +27 -0
  327. package/dist/src/mcp/sa-impersonation-provider.js +113 -0
  328. package/dist/src/mcp/sa-impersonation-provider.js.map +1 -0
  329. package/dist/src/mcp/sa-impersonation-provider.test.d.ts +6 -0
  330. package/dist/src/mcp/sa-impersonation-provider.test.js +117 -0
  331. package/dist/src/mcp/sa-impersonation-provider.test.js.map +1 -0
  332. package/dist/src/mcp/token-storage/base-token-storage.d.ts +19 -0
  333. package/dist/src/mcp/token-storage/base-token-storage.js +36 -0
  334. package/dist/src/mcp/token-storage/base-token-storage.js.map +1 -0
  335. package/dist/src/mcp/token-storage/base-token-storage.test.d.ts +6 -0
  336. package/dist/src/mcp/token-storage/base-token-storage.test.js +151 -0
  337. package/dist/src/mcp/token-storage/base-token-storage.test.js.map +1 -0
  338. package/dist/src/mcp/token-storage/file-token-storage.d.ts +24 -0
  339. package/dist/src/mcp/token-storage/file-token-storage.js +145 -0
  340. package/dist/src/mcp/token-storage/file-token-storage.js.map +1 -0
  341. package/dist/src/mcp/token-storage/file-token-storage.test.d.ts +6 -0
  342. package/dist/src/mcp/token-storage/file-token-storage.test.js +238 -0
  343. package/dist/src/mcp/token-storage/file-token-storage.test.js.map +1 -0
  344. package/dist/src/mcp/token-storage/hybrid-token-storage.d.ts +23 -0
  345. package/dist/src/mcp/token-storage/hybrid-token-storage.js +78 -0
  346. package/dist/src/mcp/token-storage/hybrid-token-storage.js.map +1 -0
  347. package/dist/src/mcp/token-storage/hybrid-token-storage.test.d.ts +6 -0
  348. package/dist/src/mcp/token-storage/hybrid-token-storage.test.js +193 -0
  349. package/dist/src/mcp/token-storage/hybrid-token-storage.test.js.map +1 -0
  350. package/dist/src/mcp/token-storage/index.d.ts +11 -0
  351. package/dist/src/mcp/token-storage/index.js +12 -0
  352. package/dist/src/mcp/token-storage/index.js.map +1 -0
  353. package/dist/src/mcp/token-storage/keychain-token-storage.d.ts +35 -0
  354. package/dist/src/mcp/token-storage/keychain-token-storage.js +246 -0
  355. package/dist/src/mcp/token-storage/keychain-token-storage.js.map +1 -0
  356. package/dist/src/mcp/token-storage/keychain-token-storage.test.d.ts +6 -0
  357. package/dist/src/mcp/token-storage/keychain-token-storage.test.js +305 -0
  358. package/dist/src/mcp/token-storage/keychain-token-storage.test.js.map +1 -0
  359. package/dist/src/mcp/token-storage/types.d.ts +44 -0
  360. package/dist/src/mcp/token-storage/types.js +11 -0
  361. package/dist/src/mcp/token-storage/types.js.map +1 -0
  362. package/dist/src/output/json-formatter.d.ts +11 -0
  363. package/dist/src/output/json-formatter.js +30 -0
  364. package/dist/src/output/json-formatter.js.map +1 -0
  365. package/dist/src/output/json-formatter.test.d.ts +6 -0
  366. package/dist/src/output/json-formatter.test.js +266 -0
  367. package/dist/src/output/json-formatter.test.js.map +1 -0
  368. package/dist/src/output/stream-json-formatter.d.ts +32 -0
  369. package/dist/src/output/stream-json-formatter.js +52 -0
  370. package/dist/src/output/stream-json-formatter.js.map +1 -0
  371. package/dist/src/output/stream-json-formatter.test.d.ts +6 -0
  372. package/dist/src/output/stream-json-formatter.test.js +479 -0
  373. package/dist/src/output/stream-json-formatter.test.js.map +1 -0
  374. package/dist/src/output/types.d.ts +82 -0
  375. package/dist/src/output/types.js +22 -0
  376. package/dist/src/output/types.js.map +1 -0
  377. package/dist/src/policy/config.d.ts +31 -0
  378. package/dist/src/policy/config.js +199 -0
  379. package/dist/src/policy/config.js.map +1 -0
  380. package/dist/src/policy/config.test.d.ts +6 -0
  381. package/dist/src/policy/config.test.js +538 -0
  382. package/dist/src/policy/config.test.js.map +1 -0
  383. package/dist/src/policy/index.d.ts +9 -0
  384. package/dist/src/policy/index.js +10 -0
  385. package/dist/src/policy/index.js.map +1 -0
  386. package/dist/src/policy/policies/discovered.toml +8 -0
  387. package/dist/src/policy/policies/read-only.toml +56 -0
  388. package/dist/src/policy/policies/write.toml +73 -0
  389. package/dist/src/policy/policies/yolo.toml +31 -0
  390. package/dist/src/policy/policy-engine.d.ts +39 -0
  391. package/dist/src/policy/policy-engine.js +158 -0
  392. package/dist/src/policy/policy-engine.js.map +1 -0
  393. package/dist/src/policy/policy-engine.test.d.ts +6 -0
  394. package/dist/src/policy/policy-engine.test.js +899 -0
  395. package/dist/src/policy/policy-engine.test.js.map +1 -0
  396. package/dist/src/policy/stable-stringify.d.ts +58 -0
  397. package/dist/src/policy/stable-stringify.js +122 -0
  398. package/dist/src/policy/stable-stringify.js.map +1 -0
  399. package/dist/src/policy/toml-loader.d.ts +47 -0
  400. package/dist/src/policy/toml-loader.js +411 -0
  401. package/dist/src/policy/toml-loader.js.map +1 -0
  402. package/dist/src/policy/toml-loader.test.d.ts +6 -0
  403. package/dist/src/policy/toml-loader.test.js +376 -0
  404. package/dist/src/policy/toml-loader.test.js.map +1 -0
  405. package/dist/src/policy/types.d.ts +130 -0
  406. package/dist/src/policy/types.js +22 -0
  407. package/dist/src/policy/types.js.map +1 -0
  408. package/dist/src/prompts/mcp-prompts.d.ts +2 -2
  409. package/dist/src/prompts/mcp-prompts.test.d.ts +6 -0
  410. package/dist/src/prompts/mcp-prompts.test.js +39 -0
  411. package/dist/src/prompts/mcp-prompts.test.js.map +1 -0
  412. package/dist/src/prompts/prompt-registry.d.ts +1 -1
  413. package/dist/src/prompts/prompt-registry.js +2 -1
  414. package/dist/src/prompts/prompt-registry.js.map +1 -1
  415. package/dist/src/prompts/prompt-registry.test.d.ts +6 -0
  416. package/dist/src/prompts/prompt-registry.test.js +96 -0
  417. package/dist/src/prompts/prompt-registry.test.js.map +1 -0
  418. package/dist/src/routing/modelRouterService.d.ts +23 -0
  419. package/dist/src/routing/modelRouterService.js +85 -0
  420. package/dist/src/routing/modelRouterService.js.map +1 -0
  421. package/dist/src/routing/modelRouterService.test.d.ts +6 -0
  422. package/dist/src/routing/modelRouterService.test.js +160 -0
  423. package/dist/src/routing/modelRouterService.test.js.map +1 -0
  424. package/dist/src/routing/routingStrategy.d.ts +62 -0
  425. package/dist/src/routing/routingStrategy.js +7 -0
  426. package/dist/src/routing/routingStrategy.js.map +1 -0
  427. package/dist/src/routing/strategies/classifierStrategy.d.ts +12 -0
  428. package/dist/src/routing/strategies/classifierStrategy.js +166 -0
  429. package/dist/src/routing/strategies/classifierStrategy.js.map +1 -0
  430. package/dist/src/routing/strategies/classifierStrategy.test.d.ts +6 -0
  431. package/dist/src/routing/strategies/classifierStrategy.test.js +196 -0
  432. package/dist/src/routing/strategies/classifierStrategy.test.js.map +1 -0
  433. package/dist/src/routing/strategies/compositeStrategy.d.ts +26 -0
  434. package/dist/src/routing/strategies/compositeStrategy.js +68 -0
  435. package/dist/src/routing/strategies/compositeStrategy.js.map +1 -0
  436. package/dist/src/routing/strategies/compositeStrategy.test.d.ts +6 -0
  437. package/dist/src/routing/strategies/compositeStrategy.test.js +123 -0
  438. package/dist/src/routing/strategies/compositeStrategy.test.js.map +1 -0
  439. package/dist/src/routing/strategies/defaultStrategy.d.ts +12 -0
  440. package/dist/src/routing/strategies/defaultStrategy.js +20 -0
  441. package/dist/src/routing/strategies/defaultStrategy.js.map +1 -0
  442. package/dist/src/routing/strategies/defaultStrategy.test.d.ts +6 -0
  443. package/dist/src/routing/strategies/defaultStrategy.test.js +26 -0
  444. package/dist/src/routing/strategies/defaultStrategy.test.js.map +1 -0
  445. package/dist/src/routing/strategies/fallbackStrategy.d.ts +12 -0
  446. package/dist/src/routing/strategies/fallbackStrategy.js +25 -0
  447. package/dist/src/routing/strategies/fallbackStrategy.js.map +1 -0
  448. package/dist/src/routing/strategies/fallbackStrategy.test.d.ts +6 -0
  449. package/dist/src/routing/strategies/fallbackStrategy.test.js +59 -0
  450. package/dist/src/routing/strategies/fallbackStrategy.test.js.map +1 -0
  451. package/dist/src/routing/strategies/overrideStrategy.d.ts +15 -0
  452. package/dist/src/routing/strategies/overrideStrategy.js +28 -0
  453. package/dist/src/routing/strategies/overrideStrategy.js.map +1 -0
  454. package/dist/src/routing/strategies/overrideStrategy.test.d.ts +6 -0
  455. package/dist/src/routing/strategies/overrideStrategy.test.js +45 -0
  456. package/dist/src/routing/strategies/overrideStrategy.test.js.map +1 -0
  457. package/dist/src/safety/built-in.d.ts +21 -0
  458. package/dist/src/safety/built-in.js +106 -0
  459. package/dist/src/safety/built-in.js.map +1 -0
  460. package/dist/src/safety/built-in.test.d.ts +6 -0
  461. package/dist/src/safety/built-in.test.js +199 -0
  462. package/dist/src/safety/built-in.test.js.map +1 -0
  463. package/dist/src/safety/checker-runner.d.ts +48 -0
  464. package/dist/src/safety/checker-runner.js +208 -0
  465. package/dist/src/safety/checker-runner.js.map +1 -0
  466. package/dist/src/safety/checker-runner.test.d.ts +6 -0
  467. package/dist/src/safety/checker-runner.test.js +238 -0
  468. package/dist/src/safety/checker-runner.test.js.map +1 -0
  469. package/dist/src/safety/context-builder.d.ts +23 -0
  470. package/dist/src/safety/context-builder.js +47 -0
  471. package/dist/src/safety/context-builder.js.map +1 -0
  472. package/dist/src/safety/context-builder.test.d.ts +6 -0
  473. package/dist/src/safety/context-builder.test.js +49 -0
  474. package/dist/src/safety/context-builder.test.js.map +1 -0
  475. package/dist/src/safety/protocol.d.ts +88 -0
  476. package/dist/src/safety/protocol.js +15 -0
  477. package/dist/src/safety/protocol.js.map +1 -0
  478. package/dist/src/safety/registry.d.ts +26 -0
  479. package/dist/src/safety/registry.js +65 -0
  480. package/dist/src/safety/registry.js.map +1 -0
  481. package/dist/src/safety/registry.test.d.ts +6 -0
  482. package/dist/src/safety/registry.test.js +31 -0
  483. package/dist/src/safety/registry.test.js.map +1 -0
  484. package/dist/src/services/chatCompressionService.d.ts +32 -0
  485. package/dist/src/services/chatCompressionService.js +162 -0
  486. package/dist/src/services/chatCompressionService.js.map +1 -0
  487. package/dist/src/services/chatCompressionService.test.d.ts +6 -0
  488. package/dist/src/services/chatCompressionService.test.js +210 -0
  489. package/dist/src/services/chatCompressionService.test.js.map +1 -0
  490. package/dist/src/services/chatRecordingService.d.ts +10 -15
  491. package/dist/src/services/chatRecordingService.js +43 -29
  492. package/dist/src/services/chatRecordingService.js.map +1 -1
  493. package/dist/src/services/chatRecordingService.test.js +69 -25
  494. package/dist/src/services/chatRecordingService.test.js.map +1 -1
  495. package/dist/src/services/fileDiscoveryService.d.ts +8 -10
  496. package/dist/src/services/fileDiscoveryService.js +31 -53
  497. package/dist/src/services/fileDiscoveryService.js.map +1 -1
  498. package/dist/src/services/fileDiscoveryService.test.js +94 -14
  499. package/dist/src/services/fileDiscoveryService.test.js.map +1 -1
  500. package/dist/src/services/fileSystemService.d.ts +9 -0
  501. package/dist/src/services/fileSystemService.js +12 -1
  502. package/dist/src/services/fileSystemService.js.map +1 -1
  503. package/dist/src/services/fileSystemService.test.js +1 -1
  504. package/dist/src/services/fileSystemService.test.js.map +1 -1
  505. package/dist/src/services/gitService.d.ts +3 -1
  506. package/dist/src/services/gitService.js +30 -24
  507. package/dist/src/services/gitService.js.map +1 -1
  508. package/dist/src/services/gitService.test.js +30 -37
  509. package/dist/src/services/gitService.test.js.map +1 -1
  510. package/dist/src/services/loopDetectionService.d.ts +12 -3
  511. package/dist/src/services/loopDetectionService.js +148 -55
  512. package/dist/src/services/loopDetectionService.js.map +1 -1
  513. package/dist/src/services/loopDetectionService.test.js +280 -21
  514. package/dist/src/services/loopDetectionService.test.js.map +1 -1
  515. package/dist/src/services/modelConfig.golden.test.d.ts +6 -0
  516. package/dist/src/services/modelConfig.golden.test.js +42 -0
  517. package/dist/src/services/modelConfig.golden.test.js.map +1 -0
  518. package/dist/src/services/modelConfig.integration.test.d.ts +6 -0
  519. package/dist/src/services/modelConfig.integration.test.js +247 -0
  520. package/dist/src/services/modelConfig.integration.test.js.map +1 -0
  521. package/dist/src/services/modelConfigService.d.ts +48 -0
  522. package/dist/src/services/modelConfigService.js +151 -0
  523. package/dist/src/services/modelConfigService.js.map +1 -0
  524. package/dist/src/services/modelConfigService.test.d.ts +6 -0
  525. package/dist/src/services/modelConfigService.test.js +531 -0
  526. package/dist/src/services/modelConfigService.test.js.map +1 -0
  527. package/dist/src/services/shellExecutionService.d.ts +37 -2
  528. package/dist/src/services/shellExecutionService.js +361 -67
  529. package/dist/src/services/shellExecutionService.js.map +1 -1
  530. package/dist/src/services/shellExecutionService.test.js +333 -71
  531. package/dist/src/services/shellExecutionService.test.js.map +1 -1
  532. package/dist/src/services/test-data/resolved-aliases.golden.json +202 -0
  533. package/dist/src/telemetry/activity-detector.d.ts +41 -0
  534. package/dist/src/telemetry/activity-detector.js +61 -0
  535. package/dist/src/telemetry/activity-detector.js.map +1 -0
  536. package/dist/src/telemetry/activity-detector.test.d.ts +6 -0
  537. package/dist/src/telemetry/activity-detector.test.js +136 -0
  538. package/dist/src/telemetry/activity-detector.test.js.map +1 -0
  539. package/dist/src/telemetry/activity-monitor.d.ts +116 -0
  540. package/dist/src/telemetry/activity-monitor.js +209 -0
  541. package/dist/src/telemetry/activity-monitor.js.map +1 -0
  542. package/dist/src/telemetry/activity-monitor.test.d.ts +6 -0
  543. package/dist/src/telemetry/activity-monitor.test.js +251 -0
  544. package/dist/src/telemetry/activity-monitor.test.js.map +1 -0
  545. package/dist/src/telemetry/activity-types.d.ts +19 -0
  546. package/dist/src/telemetry/activity-types.js +21 -0
  547. package/dist/src/telemetry/activity-types.js.map +1 -0
  548. package/dist/src/telemetry/clearcut-logger/clearcut-logger.d.ts +53 -5
  549. package/dist/src/telemetry/clearcut-logger/clearcut-logger.js +581 -56
  550. package/dist/src/telemetry/clearcut-logger/clearcut-logger.js.map +1 -1
  551. package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.d.ts +2 -0
  552. package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.js +467 -31
  553. package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.js.map +1 -1
  554. package/dist/src/telemetry/clearcut-logger/event-metadata-key.d.ts +75 -4
  555. package/dist/src/telemetry/clearcut-logger/event-metadata-key.js +182 -6
  556. package/dist/src/telemetry/clearcut-logger/event-metadata-key.js.map +1 -1
  557. package/dist/src/telemetry/config.d.ts +31 -0
  558. package/dist/src/telemetry/config.js +76 -0
  559. package/dist/src/telemetry/config.js.map +1 -0
  560. package/dist/src/telemetry/config.test.d.ts +6 -0
  561. package/dist/src/telemetry/config.test.js +124 -0
  562. package/dist/src/telemetry/config.test.js.map +1 -0
  563. package/dist/src/telemetry/constants.d.ts +0 -18
  564. package/dist/src/telemetry/constants.js +0 -18
  565. package/dist/src/telemetry/constants.js.map +1 -1
  566. package/dist/src/telemetry/file-exporters.d.ts +5 -4
  567. package/dist/src/telemetry/file-exporters.js +1 -1
  568. package/dist/src/telemetry/file-exporters.js.map +1 -1
  569. package/dist/src/telemetry/gcp-exporters.d.ts +34 -0
  570. package/dist/src/telemetry/gcp-exporters.js +116 -0
  571. package/dist/src/telemetry/gcp-exporters.js.map +1 -0
  572. package/dist/src/telemetry/gcp-exporters.test.d.ts +6 -0
  573. package/dist/src/telemetry/gcp-exporters.test.js +318 -0
  574. package/dist/src/telemetry/gcp-exporters.test.js.map +1 -0
  575. package/dist/src/telemetry/high-water-mark-tracker.d.ts +43 -0
  576. package/dist/src/telemetry/high-water-mark-tracker.js +88 -0
  577. package/dist/src/telemetry/high-water-mark-tracker.js.map +1 -0
  578. package/dist/src/telemetry/high-water-mark-tracker.test.d.ts +6 -0
  579. package/dist/src/telemetry/high-water-mark-tracker.test.js +152 -0
  580. package/dist/src/telemetry/high-water-mark-tracker.test.js.map +1 -0
  581. package/dist/src/telemetry/index.d.ts +16 -2
  582. package/dist/src/telemetry/index.js +25 -2
  583. package/dist/src/telemetry/index.js.map +1 -1
  584. package/dist/src/telemetry/loggers.d.ts +25 -3
  585. package/dist/src/telemetry/loggers.js +333 -154
  586. package/dist/src/telemetry/loggers.js.map +1 -1
  587. package/dist/src/telemetry/loggers.test.circular.js +3 -4
  588. package/dist/src/telemetry/loggers.test.circular.js.map +1 -1
  589. package/dist/src/telemetry/loggers.test.js +868 -63
  590. package/dist/src/telemetry/loggers.test.js.map +1 -1
  591. package/dist/src/telemetry/memory-monitor.d.ts +149 -0
  592. package/dist/src/telemetry/memory-monitor.js +335 -0
  593. package/dist/src/telemetry/memory-monitor.js.map +1 -0
  594. package/dist/src/telemetry/memory-monitor.test.d.ts +6 -0
  595. package/dist/src/telemetry/memory-monitor.test.js +472 -0
  596. package/dist/src/telemetry/memory-monitor.test.js.map +1 -0
  597. package/dist/src/telemetry/metrics.d.ts +498 -11
  598. package/dist/src/telemetry/metrics.js +729 -84
  599. package/dist/src/telemetry/metrics.js.map +1 -1
  600. package/dist/src/telemetry/metrics.test.js +964 -101
  601. package/dist/src/telemetry/metrics.test.js.map +1 -1
  602. package/dist/src/telemetry/rate-limiter.d.ts +48 -0
  603. package/dist/src/telemetry/rate-limiter.js +100 -0
  604. package/dist/src/telemetry/rate-limiter.js.map +1 -0
  605. package/dist/src/telemetry/rate-limiter.test.d.ts +6 -0
  606. package/dist/src/telemetry/rate-limiter.test.js +207 -0
  607. package/dist/src/telemetry/rate-limiter.test.js.map +1 -0
  608. package/dist/src/telemetry/sdk.d.ts +1 -1
  609. package/dist/src/telemetry/sdk.js +23 -4
  610. package/dist/src/telemetry/sdk.js.map +1 -1
  611. package/dist/src/telemetry/sdk.test.js +108 -0
  612. package/dist/src/telemetry/sdk.test.js.map +1 -1
  613. package/dist/src/telemetry/semantic.d.ts +82 -0
  614. package/dist/src/telemetry/semantic.js +269 -0
  615. package/dist/src/telemetry/semantic.js.map +1 -0
  616. package/dist/src/telemetry/semantic.test.d.ts +6 -0
  617. package/dist/src/telemetry/semantic.test.js +387 -0
  618. package/dist/src/telemetry/semantic.test.js.map +1 -0
  619. package/dist/src/telemetry/telemetry-utils.d.ts +6 -0
  620. package/dist/src/telemetry/telemetry-utils.js +14 -0
  621. package/dist/src/telemetry/telemetry-utils.js.map +1 -0
  622. package/dist/src/telemetry/telemetry-utils.test.d.ts +6 -0
  623. package/dist/src/telemetry/telemetry-utils.test.js +41 -0
  624. package/dist/src/telemetry/telemetry-utils.test.js.map +1 -0
  625. package/dist/src/telemetry/telemetryAttributes.d.ts +8 -0
  626. package/dist/src/telemetry/telemetryAttributes.js +19 -0
  627. package/dist/src/telemetry/telemetryAttributes.js.map +1 -0
  628. package/dist/src/telemetry/trace.d.ts +46 -0
  629. package/dist/src/telemetry/trace.js +121 -0
  630. package/dist/src/telemetry/trace.js.map +1 -0
  631. package/dist/src/telemetry/types.d.ts +351 -25
  632. package/dist/src/telemetry/types.js +1071 -63
  633. package/dist/src/telemetry/types.js.map +1 -1
  634. package/dist/src/telemetry/uiTelemetry.d.ts +4 -4
  635. package/dist/src/telemetry/uiTelemetry.js +14 -15
  636. package/dist/src/telemetry/uiTelemetry.js.map +1 -1
  637. package/dist/src/telemetry/uiTelemetry.test.js +122 -96
  638. package/dist/src/telemetry/uiTelemetry.test.js.map +1 -1
  639. package/dist/src/test-utils/config.d.ts +3 -2
  640. package/dist/src/test-utils/config.js +1 -1
  641. package/dist/src/test-utils/config.js.map +1 -1
  642. package/dist/src/test-utils/index.d.ts +6 -0
  643. package/dist/src/test-utils/index.js +7 -0
  644. package/dist/src/test-utils/index.js.map +1 -0
  645. package/dist/src/test-utils/mock-tool.d.ts +66 -0
  646. package/dist/src/test-utils/{tools.js → mock-tool.js} +45 -29
  647. package/dist/src/test-utils/mock-tool.js.map +1 -0
  648. package/dist/src/test-utils/mockWorkspaceContext.d.ts +1 -1
  649. package/dist/src/tools/base-tool-invocation.test.d.ts +6 -0
  650. package/dist/src/tools/base-tool-invocation.test.js +85 -0
  651. package/dist/src/tools/base-tool-invocation.test.js.map +1 -0
  652. package/dist/src/tools/diffOptions.d.ts +1 -1
  653. package/dist/src/tools/diffOptions.js +21 -13
  654. package/dist/src/tools/diffOptions.js.map +1 -1
  655. package/dist/src/tools/diffOptions.test.js +58 -22
  656. package/dist/src/tools/diffOptions.test.js.map +1 -1
  657. package/dist/src/tools/edit.d.ts +10 -8
  658. package/dist/src/tools/edit.js +100 -79
  659. package/dist/src/tools/edit.js.map +1 -1
  660. package/dist/src/tools/edit.test.js +429 -163
  661. package/dist/src/tools/edit.test.js.map +1 -1
  662. package/dist/src/tools/glob.d.ts +11 -5
  663. package/dist/src/tools/glob.js +58 -42
  664. package/dist/src/tools/glob.js.map +1 -1
  665. package/dist/src/tools/glob.test.js +249 -166
  666. package/dist/src/tools/glob.test.js.map +1 -1
  667. package/dist/src/tools/grep.d.ts +7 -5
  668. package/dist/src/tools/grep.js +66 -40
  669. package/dist/src/tools/grep.js.map +1 -1
  670. package/dist/src/tools/grep.test.js +41 -15
  671. package/dist/src/tools/grep.test.js.map +1 -1
  672. package/dist/src/tools/ls.d.ts +7 -5
  673. package/dist/src/tools/ls.js +54 -68
  674. package/dist/src/tools/ls.js.map +1 -1
  675. package/dist/src/tools/ls.test.js +150 -293
  676. package/dist/src/tools/ls.test.js.map +1 -1
  677. package/dist/src/tools/mcp-client-manager.d.ts +52 -12
  678. package/dist/src/tools/mcp-client-manager.js +196 -27
  679. package/dist/src/tools/mcp-client-manager.js.map +1 -1
  680. package/dist/src/tools/mcp-client-manager.test.js +139 -13
  681. package/dist/src/tools/mcp-client-manager.test.js.map +1 -1
  682. package/dist/src/tools/mcp-client.d.ts +28 -24
  683. package/dist/src/tools/mcp-client.js +338 -351
  684. package/dist/src/tools/mcp-client.js.map +1 -1
  685. package/dist/src/tools/mcp-client.test.js +380 -193
  686. package/dist/src/tools/mcp-client.test.js.map +1 -1
  687. package/dist/src/tools/mcp-tool.d.ts +11 -5
  688. package/dist/src/tools/mcp-tool.js +66 -17
  689. package/dist/src/tools/mcp-tool.js.map +1 -1
  690. package/dist/src/tools/mcp-tool.test.js +278 -211
  691. package/dist/src/tools/mcp-tool.test.js.map +1 -1
  692. package/dist/src/tools/memoryTool.d.ts +10 -7
  693. package/dist/src/tools/memoryTool.js +28 -49
  694. package/dist/src/tools/memoryTool.js.map +1 -1
  695. package/dist/src/tools/memoryTool.test.js +26 -13
  696. package/dist/src/tools/memoryTool.test.js.map +1 -1
  697. package/dist/src/tools/message-bus-integration.test.d.ts +6 -0
  698. package/dist/src/tools/message-bus-integration.test.js +196 -0
  699. package/dist/src/tools/message-bus-integration.test.js.map +1 -0
  700. package/dist/src/tools/modifiable-tool.d.ts +7 -3
  701. package/dist/src/tools/modifiable-tool.js +41 -19
  702. package/dist/src/tools/modifiable-tool.js.map +1 -1
  703. package/dist/src/tools/modifiable-tool.test.js +70 -35
  704. package/dist/src/tools/modifiable-tool.test.js.map +1 -1
  705. package/dist/src/tools/read-file.d.ts +9 -7
  706. package/dist/src/tools/read-file.js +39 -60
  707. package/dist/src/tools/read-file.js.map +1 -1
  708. package/dist/src/tools/read-file.test.js +103 -36
  709. package/dist/src/tools/read-file.test.js.map +1 -1
  710. package/dist/src/tools/read-many-files.d.ts +9 -14
  711. package/dist/src/tools/read-many-files.js +71 -155
  712. package/dist/src/tools/read-many-files.js.map +1 -1
  713. package/dist/src/tools/read-many-files.test.js +98 -44
  714. package/dist/src/tools/read-many-files.test.js.map +1 -1
  715. package/dist/src/tools/ripGrep.d.ts +73 -0
  716. package/dist/src/tools/ripGrep.js +395 -0
  717. package/dist/src/tools/ripGrep.js.map +1 -0
  718. package/dist/src/tools/ripGrep.test.d.ts +6 -0
  719. package/dist/src/tools/ripGrep.test.js +1305 -0
  720. package/dist/src/tools/ripGrep.test.js.map +1 -0
  721. package/dist/src/tools/shell.d.ts +19 -6
  722. package/dist/src/tools/shell.js +92 -56
  723. package/dist/src/tools/shell.js.map +1 -1
  724. package/dist/src/tools/shell.test.js +176 -103
  725. package/dist/src/tools/shell.test.js.map +1 -1
  726. package/dist/src/tools/smart-edit.d.ts +78 -0
  727. package/dist/src/tools/smart-edit.js +717 -0
  728. package/dist/src/tools/smart-edit.js.map +1 -0
  729. package/dist/src/tools/smart-edit.test.d.ts +6 -0
  730. package/dist/src/tools/smart-edit.test.js +592 -0
  731. package/dist/src/tools/smart-edit.test.js.map +1 -0
  732. package/dist/src/tools/tool-error.d.ts +39 -1
  733. package/dist/src/tools/tool-error.js +54 -0
  734. package/dist/src/tools/tool-error.js.map +1 -1
  735. package/dist/src/tools/tool-names.d.ts +17 -0
  736. package/dist/src/tools/tool-names.js +21 -0
  737. package/dist/src/tools/tool-names.js.map +1 -0
  738. package/dist/src/tools/tool-registry.d.ts +38 -20
  739. package/dist/src/tools/tool-registry.js +134 -77
  740. package/dist/src/tools/tool-registry.js.map +1 -1
  741. package/dist/src/tools/tool-registry.test.js +218 -58
  742. package/dist/src/tools/tool-registry.test.js.map +1 -1
  743. package/dist/src/tools/tools.d.ts +49 -17
  744. package/dist/src/tools/tools.js +150 -8
  745. package/dist/src/tools/tools.js.map +1 -1
  746. package/dist/src/tools/tools.test.js +1 -2
  747. package/dist/src/tools/tools.test.js.map +1 -1
  748. package/dist/src/tools/web-fetch.d.ts +14 -5
  749. package/dist/src/tools/web-fetch.js +90 -44
  750. package/dist/src/tools/web-fetch.js.map +1 -1
  751. package/dist/src/tools/web-fetch.test.js +388 -20
  752. package/dist/src/tools/web-fetch.test.js.map +1 -1
  753. package/dist/src/tools/web-search.d.ts +8 -6
  754. package/dist/src/tools/web-search.js +40 -15
  755. package/dist/src/tools/web-search.js.map +1 -1
  756. package/dist/src/tools/web-search.test.js +75 -1
  757. package/dist/src/tools/web-search.test.js.map +1 -1
  758. package/dist/src/tools/write-file.d.ts +7 -5
  759. package/dist/src/tools/write-file.js +54 -54
  760. package/dist/src/tools/write-file.js.map +1 -1
  761. package/dist/src/tools/write-file.test.js +237 -146
  762. package/dist/src/tools/write-file.test.js.map +1 -1
  763. package/dist/src/tools/write-todos.d.ts +50 -0
  764. package/dist/src/tools/write-todos.js +193 -0
  765. package/dist/src/tools/write-todos.js.map +1 -0
  766. package/dist/src/tools/write-todos.test.d.ts +6 -0
  767. package/dist/src/tools/write-todos.test.js +89 -0
  768. package/dist/src/tools/write-todos.test.js.map +1 -0
  769. package/dist/src/utils/bfsFileSearch.d.ts +2 -2
  770. package/dist/src/utils/bfsFileSearch.js +16 -9
  771. package/dist/src/utils/bfsFileSearch.js.map +1 -1
  772. package/dist/src/utils/bfsFileSearch.test.js +3 -3
  773. package/dist/src/utils/bfsFileSearch.test.js.map +1 -1
  774. package/dist/src/utils/channel.d.ts +19 -0
  775. package/dist/src/utils/channel.js +49 -0
  776. package/dist/src/utils/channel.js.map +1 -0
  777. package/dist/src/utils/channel.test.d.ts +6 -0
  778. package/dist/src/utils/channel.test.js +170 -0
  779. package/dist/src/utils/channel.test.js.map +1 -0
  780. package/dist/src/utils/debugLogger.d.ts +25 -0
  781. package/dist/src/utils/debugLogger.js +33 -0
  782. package/dist/src/utils/debugLogger.js.map +1 -0
  783. package/dist/src/utils/debugLogger.test.d.ts +6 -0
  784. package/dist/src/utils/debugLogger.test.js +69 -0
  785. package/dist/src/utils/debugLogger.test.js.map +1 -0
  786. package/dist/src/utils/delay.d.ts +16 -0
  787. package/dist/src/utils/delay.js +43 -0
  788. package/dist/src/utils/delay.js.map +1 -0
  789. package/dist/src/utils/delay.test.d.ts +6 -0
  790. package/dist/src/utils/delay.test.js +88 -0
  791. package/dist/src/utils/delay.test.js.map +1 -0
  792. package/dist/src/utils/editCorrector.d.ts +9 -8
  793. package/dist/src/utils/editCorrector.js +62 -34
  794. package/dist/src/utils/editCorrector.js.map +1 -1
  795. package/dist/src/utils/editCorrector.test.js +52 -87
  796. package/dist/src/utils/editCorrector.test.js.map +1 -1
  797. package/dist/src/utils/editor.d.ts +4 -2
  798. package/dist/src/utils/editor.js +56 -55
  799. package/dist/src/utils/editor.js.map +1 -1
  800. package/dist/src/utils/editor.test.js +47 -88
  801. package/dist/src/utils/editor.test.js.map +1 -1
  802. package/dist/src/utils/environmentContext.d.ts +3 -2
  803. package/dist/src/utils/environmentContext.js +20 -33
  804. package/dist/src/utils/environmentContext.js.map +1 -1
  805. package/dist/src/utils/environmentContext.test.js +6 -34
  806. package/dist/src/utils/environmentContext.test.js.map +1 -1
  807. package/dist/src/utils/errorParsing.d.ts +1 -1
  808. package/dist/src/utils/errorParsing.js +5 -33
  809. package/dist/src/utils/errorParsing.js.map +1 -1
  810. package/dist/src/utils/errorParsing.test.js +0 -88
  811. package/dist/src/utils/errorParsing.test.js.map +1 -1
  812. package/dist/src/utils/errorReporting.d.ts +1 -1
  813. package/dist/src/utils/errors.d.ts +28 -0
  814. package/dist/src/utils/errors.js +48 -0
  815. package/dist/src/utils/errors.js.map +1 -1
  816. package/dist/src/utils/events.d.ts +121 -0
  817. package/dist/src/utils/events.js +84 -0
  818. package/dist/src/utils/events.js.map +1 -0
  819. package/dist/src/utils/events.test.d.ts +6 -0
  820. package/dist/src/utils/events.test.js +212 -0
  821. package/dist/src/utils/events.test.js.map +1 -0
  822. package/dist/src/utils/extensionLoader.d.ts +86 -0
  823. package/dist/src/utils/extensionLoader.js +208 -0
  824. package/dist/src/utils/extensionLoader.js.map +1 -0
  825. package/dist/src/utils/extensionLoader.test.d.ts +6 -0
  826. package/dist/src/utils/extensionLoader.test.js +154 -0
  827. package/dist/src/utils/extensionLoader.test.js.map +1 -0
  828. package/dist/src/utils/fetch.d.ts +1 -0
  829. package/dist/src/utils/fetch.js +5 -1
  830. package/dist/src/utils/fetch.js.map +1 -1
  831. package/dist/src/utils/fileUtils.d.ts +28 -12
  832. package/dist/src/utils/fileUtils.js +204 -81
  833. package/dist/src/utils/fileUtils.js.map +1 -1
  834. package/dist/src/utils/fileUtils.test.js +426 -82
  835. package/dist/src/utils/fileUtils.test.js.map +1 -1
  836. package/dist/src/utils/filesearch/crawler.d.ts +1 -1
  837. package/dist/src/utils/filesearch/crawler.test.js +2 -2
  838. package/dist/src/utils/filesearch/crawler.test.js.map +1 -1
  839. package/dist/src/utils/filesearch/fileSearch.d.ts +1 -0
  840. package/dist/src/utils/filesearch/fileSearch.js +14 -9
  841. package/dist/src/utils/filesearch/fileSearch.js.map +1 -1
  842. package/dist/src/utils/filesearch/fileSearch.test.js +90 -0
  843. package/dist/src/utils/filesearch/fileSearch.test.js.map +1 -1
  844. package/dist/src/utils/flashFallback.test.d.ts +6 -0
  845. package/dist/src/utils/flashFallback.test.js +103 -0
  846. package/dist/src/utils/flashFallback.test.js.map +1 -0
  847. package/dist/src/utils/formatters.d.ts +1 -0
  848. package/dist/src/utils/formatters.js +2 -1
  849. package/dist/src/utils/formatters.js.map +1 -1
  850. package/dist/src/utils/formatters.test.d.ts +6 -0
  851. package/dist/src/utils/formatters.test.js +26 -0
  852. package/dist/src/utils/formatters.test.js.map +1 -0
  853. package/dist/src/utils/geminiIgnoreParser.d.ts +18 -0
  854. package/dist/src/utils/geminiIgnoreParser.js +61 -0
  855. package/dist/src/utils/geminiIgnoreParser.js.map +1 -0
  856. package/dist/src/utils/geminiIgnoreParser.test.d.ts +6 -0
  857. package/dist/src/utils/geminiIgnoreParser.test.js +50 -0
  858. package/dist/src/utils/geminiIgnoreParser.test.js.map +1 -0
  859. package/dist/src/utils/generateContentResponseUtilities.d.ts +1 -2
  860. package/dist/src/utils/generateContentResponseUtilities.js +1 -13
  861. package/dist/src/utils/generateContentResponseUtilities.js.map +1 -1
  862. package/dist/src/utils/generateContentResponseUtilities.test.js +2 -40
  863. package/dist/src/utils/generateContentResponseUtilities.test.js.map +1 -1
  864. package/dist/src/utils/getFolderStructure.d.ts +2 -2
  865. package/dist/src/utils/getFolderStructure.js +12 -20
  866. package/dist/src/utils/getFolderStructure.js.map +1 -1
  867. package/dist/src/utils/getFolderStructure.test.js +11 -10
  868. package/dist/src/utils/getFolderStructure.test.js.map +1 -1
  869. package/dist/src/utils/gitIgnoreParser.d.ts +7 -8
  870. package/dist/src/utils/gitIgnoreParser.js +145 -36
  871. package/dist/src/utils/gitIgnoreParser.js.map +1 -1
  872. package/dist/src/utils/gitIgnoreParser.test.js +127 -38
  873. package/dist/src/utils/gitIgnoreParser.test.js.map +1 -1
  874. package/dist/src/utils/gitUtils.js +2 -2
  875. package/dist/src/utils/gitUtils.js.map +1 -1
  876. package/dist/src/utils/googleErrors.d.ts +104 -0
  877. package/dist/src/utils/googleErrors.js +152 -0
  878. package/dist/src/utils/googleErrors.js.map +1 -0
  879. package/dist/src/utils/googleErrors.test.d.ts +6 -0
  880. package/dist/src/utils/googleErrors.test.js +301 -0
  881. package/dist/src/utils/googleErrors.test.js.map +1 -0
  882. package/dist/src/utils/googleQuotaErrors.d.ts +37 -0
  883. package/dist/src/utils/googleQuotaErrors.js +157 -0
  884. package/dist/src/utils/googleQuotaErrors.js.map +1 -0
  885. package/dist/src/utils/googleQuotaErrors.test.d.ts +6 -0
  886. package/dist/src/utils/googleQuotaErrors.test.js +311 -0
  887. package/dist/src/utils/googleQuotaErrors.test.js.map +1 -0
  888. package/dist/src/utils/httpErrors.d.ts +18 -0
  889. package/dist/src/utils/httpErrors.js +36 -0
  890. package/dist/src/utils/httpErrors.js.map +1 -0
  891. package/dist/src/utils/ignorePatterns.d.ts +103 -0
  892. package/dist/src/utils/ignorePatterns.js +220 -0
  893. package/dist/src/utils/ignorePatterns.js.map +1 -0
  894. package/dist/src/utils/ignorePatterns.test.d.ts +6 -0
  895. package/dist/src/utils/ignorePatterns.test.js +246 -0
  896. package/dist/src/utils/ignorePatterns.test.js.map +1 -0
  897. package/dist/src/utils/installationManager.d.ts +16 -0
  898. package/dist/src/utils/installationManager.js +51 -0
  899. package/dist/src/utils/installationManager.js.map +1 -0
  900. package/dist/src/utils/installationManager.test.d.ts +6 -0
  901. package/dist/src/utils/installationManager.test.js +85 -0
  902. package/dist/src/utils/installationManager.test.js.map +1 -0
  903. package/dist/src/utils/language-detection.d.ts +6 -0
  904. package/dist/src/utils/language-detection.js +101 -0
  905. package/dist/src/utils/language-detection.js.map +1 -0
  906. package/dist/src/utils/llm-edit-fixer.d.ts +26 -0
  907. package/dist/src/utils/llm-edit-fixer.js +155 -0
  908. package/dist/src/utils/llm-edit-fixer.js.map +1 -0
  909. package/dist/src/utils/llm-edit-fixer.test.d.ts +6 -0
  910. package/dist/src/utils/llm-edit-fixer.test.js +223 -0
  911. package/dist/src/utils/llm-edit-fixer.test.js.map +1 -0
  912. package/dist/src/utils/memoryDiscovery.d.ts +26 -6
  913. package/dist/src/utils/memoryDiscovery.js +239 -40
  914. package/dist/src/utils/memoryDiscovery.js.map +1 -1
  915. package/dist/src/utils/memoryDiscovery.test.js +365 -44
  916. package/dist/src/utils/memoryDiscovery.test.js.map +1 -1
  917. package/dist/src/utils/memoryImportProcessor.js +19 -25
  918. package/dist/src/utils/memoryImportProcessor.js.map +1 -1
  919. package/dist/src/utils/memoryImportProcessor.test.js +24 -155
  920. package/dist/src/utils/memoryImportProcessor.test.js.map +1 -1
  921. package/dist/src/utils/messageInspectors.d.ts +1 -1
  922. package/dist/src/utils/nextSpeakerChecker.d.ts +3 -3
  923. package/dist/src/utils/nextSpeakerChecker.js +10 -4
  924. package/dist/src/utils/nextSpeakerChecker.js.map +1 -1
  925. package/dist/src/utils/nextSpeakerChecker.test.js +85 -66
  926. package/dist/src/utils/nextSpeakerChecker.test.js.map +1 -1
  927. package/dist/src/utils/package.d.ts +12 -0
  928. package/dist/src/utils/package.js +15 -0
  929. package/dist/src/utils/package.js.map +1 -0
  930. package/dist/src/utils/partUtils.d.ts +22 -1
  931. package/dist/src/utils/partUtils.js +68 -0
  932. package/dist/src/utils/partUtils.js.map +1 -1
  933. package/dist/src/utils/partUtils.test.js +112 -1
  934. package/dist/src/utils/partUtils.test.js.map +1 -1
  935. package/dist/src/utils/pathCorrector.d.ts +25 -0
  936. package/dist/src/utils/pathCorrector.js +33 -0
  937. package/dist/src/utils/pathCorrector.js.map +1 -0
  938. package/dist/src/utils/pathCorrector.test.d.ts +6 -0
  939. package/dist/src/utils/pathCorrector.test.js +83 -0
  940. package/dist/src/utils/pathCorrector.test.js.map +1 -0
  941. package/dist/src/utils/pathReader.d.ts +17 -0
  942. package/dist/src/utils/pathReader.js +92 -0
  943. package/dist/src/utils/pathReader.js.map +1 -0
  944. package/dist/src/utils/pathReader.test.d.ts +6 -0
  945. package/dist/src/utils/pathReader.test.js +406 -0
  946. package/dist/src/utils/pathReader.test.js.map +1 -0
  947. package/dist/src/utils/paths.d.ts +1 -18
  948. package/dist/src/utils/paths.js +133 -57
  949. package/dist/src/utils/paths.js.map +1 -1
  950. package/dist/src/utils/paths.test.js +200 -68
  951. package/dist/src/utils/paths.test.js.map +1 -1
  952. package/dist/src/utils/promptIdContext.d.ts +7 -0
  953. package/dist/src/utils/promptIdContext.js +8 -0
  954. package/dist/src/utils/promptIdContext.js.map +1 -0
  955. package/dist/src/utils/quotaErrorDetection.d.ts +1 -3
  956. package/dist/src/utils/quotaErrorDetection.js +0 -46
  957. package/dist/src/utils/quotaErrorDetection.js.map +1 -1
  958. package/dist/src/utils/retry.d.ts +5 -10
  959. package/dist/src/utils/retry.js +114 -197
  960. package/dist/src/utils/retry.js.map +1 -1
  961. package/dist/src/utils/retry.test.js +196 -130
  962. package/dist/src/utils/retry.test.js.map +1 -1
  963. package/dist/src/utils/safeJsonStringify.d.ts +4 -4
  964. package/dist/src/utils/safeJsonStringify.js +31 -7
  965. package/dist/src/utils/safeJsonStringify.js.map +1 -1
  966. package/dist/src/utils/schemaValidator.js +15 -1
  967. package/dist/src/utils/schemaValidator.js.map +1 -1
  968. package/dist/src/utils/schemaValidator.test.d.ts +6 -0
  969. package/dist/src/utils/schemaValidator.test.js +113 -0
  970. package/dist/src/utils/schemaValidator.test.js.map +1 -0
  971. package/dist/src/utils/session.js +1 -1
  972. package/dist/src/utils/session.js.map +1 -1
  973. package/dist/src/utils/shell-utils.d.ts +21 -3
  974. package/dist/src/utils/shell-utils.js +427 -159
  975. package/dist/src/utils/shell-utils.js.map +1 -1
  976. package/dist/src/utils/shell-utils.test.js +250 -59
  977. package/dist/src/utils/shell-utils.test.js.map +1 -1
  978. package/dist/src/utils/stdio.d.ts +32 -0
  979. package/dist/src/utils/stdio.js +85 -0
  980. package/dist/src/utils/stdio.js.map +1 -0
  981. package/dist/src/utils/stdio.test.d.ts +6 -0
  982. package/dist/src/utils/stdio.test.js +47 -0
  983. package/dist/src/utils/stdio.test.js.map +1 -0
  984. package/dist/src/utils/summarizer.d.ts +6 -4
  985. package/dist/src/utils/summarizer.js +8 -9
  986. package/dist/src/utils/summarizer.js.map +1 -1
  987. package/dist/src/utils/summarizer.test.js +32 -12
  988. package/dist/src/utils/summarizer.test.js.map +1 -1
  989. package/dist/src/utils/systemEncoding.js +7 -6
  990. package/dist/src/utils/systemEncoding.js.map +1 -1
  991. package/dist/src/utils/systemEncoding.test.js +4 -3
  992. package/dist/src/utils/systemEncoding.test.js.map +1 -1
  993. package/dist/src/utils/terminal.d.ts +14 -0
  994. package/dist/src/utils/terminal.js +38 -0
  995. package/dist/src/utils/terminal.js.map +1 -0
  996. package/dist/src/utils/terminalSerializer.d.ts +25 -0
  997. package/dist/src/utils/terminalSerializer.js +432 -0
  998. package/dist/src/utils/terminalSerializer.js.map +1 -0
  999. package/dist/src/utils/terminalSerializer.test.d.ts +6 -0
  1000. package/dist/src/utils/terminalSerializer.test.js +176 -0
  1001. package/dist/src/utils/terminalSerializer.test.js.map +1 -0
  1002. package/dist/src/utils/textUtils.d.ts +5 -0
  1003. package/dist/src/utils/textUtils.js +14 -0
  1004. package/dist/src/utils/textUtils.js.map +1 -1
  1005. package/dist/src/utils/textUtils.test.d.ts +6 -0
  1006. package/dist/src/utils/textUtils.test.js +59 -0
  1007. package/dist/src/utils/textUtils.test.js.map +1 -0
  1008. package/dist/src/utils/thoughtUtils.d.ts +21 -0
  1009. package/dist/src/utils/thoughtUtils.js +39 -0
  1010. package/dist/src/utils/thoughtUtils.js.map +1 -0
  1011. package/dist/src/utils/thoughtUtils.test.d.ts +6 -0
  1012. package/dist/src/utils/thoughtUtils.test.js +78 -0
  1013. package/dist/src/utils/thoughtUtils.test.js.map +1 -0
  1014. package/dist/src/utils/tool-utils.d.ts +19 -0
  1015. package/dist/src/utils/tool-utils.js +67 -0
  1016. package/dist/src/utils/tool-utils.js.map +1 -0
  1017. package/dist/src/utils/tool-utils.test.d.ts +6 -0
  1018. package/dist/src/utils/tool-utils.test.js +69 -0
  1019. package/dist/src/utils/tool-utils.test.js.map +1 -0
  1020. package/dist/src/utils/userAccountManager.d.ts +20 -0
  1021. package/dist/src/utils/userAccountManager.js +115 -0
  1022. package/dist/src/utils/userAccountManager.js.map +1 -0
  1023. package/dist/src/utils/userAccountManager.test.d.ts +6 -0
  1024. package/dist/src/utils/{user_account.test.js → userAccountManager.test.js} +41 -36
  1025. package/dist/src/utils/userAccountManager.test.js.map +1 -0
  1026. package/dist/src/utils/workspaceContext.d.ts +4 -3
  1027. package/dist/src/utils/workspaceContext.js +23 -17
  1028. package/dist/src/utils/workspaceContext.js.map +1 -1
  1029. package/dist/src/utils/workspaceContext.test.js +45 -19
  1030. package/dist/src/utils/workspaceContext.test.js.map +1 -1
  1031. package/dist/tsconfig.tsbuildinfo +1 -1
  1032. package/package.json +24 -10
  1033. package/dist/src/core/modelCheck.d.ts +0 -14
  1034. package/dist/src/core/modelCheck.js +0 -62
  1035. package/dist/src/core/modelCheck.js.map +0 -1
  1036. package/dist/src/test-utils/tools.d.ts +0 -44
  1037. package/dist/src/test-utils/tools.js.map +0 -1
  1038. package/dist/src/utils/flashFallback.integration.test.js +0 -118
  1039. package/dist/src/utils/flashFallback.integration.test.js.map +0 -1
  1040. package/dist/src/utils/user_account.d.ts +0 -9
  1041. package/dist/src/utils/user_account.js +0 -109
  1042. package/dist/src/utils/user_account.js.map +0 -1
  1043. package/dist/src/utils/user_account.test.js.map +0 -1
  1044. package/dist/src/utils/user_id.d.ts +0 -11
  1045. package/dist/src/utils/user_id.js +0 -49
  1046. package/dist/src/utils/user_id.js.map +0 -1
  1047. package/dist/src/utils/user_id.test.js +0 -21
  1048. package/dist/src/utils/user_id.test.js.map +0 -1
  1049. /package/dist/src/{utils/flashFallback.integration.test.d.ts → agents/codebase-investigator.test.d.ts} +0 -0
  1050. /package/dist/src/{utils/user_account.test.d.ts → agents/executor.test.d.ts} +0 -0
  1051. /package/dist/src/{utils/user_id.test.d.ts → agents/invocation.test.d.ts} +0 -0
@@ -4,8 +4,10 @@
4
4
  * SPDX-License-Identifier: Apache-2.0
5
5
  */
6
6
  import { describe, it, expect, vi, beforeEach } from 'vitest';
7
- import { FileOperation } from './metrics.js';
7
+ import { FileOperation, MemoryMetricType, ToolExecutionPhase, ApiRequestPhase, } from './metrics.js';
8
8
  import { makeFakeConfig } from '../test-utils/config.js';
9
+ import { ModelRoutingEvent, AgentFinishEvent } from './types.js';
10
+ import { AgentTerminateMode } from '../agents/types.js';
9
11
  const mockCounterAddFn = vi.fn();
10
12
  const mockHistogramRecordFn = vi.fn();
11
13
  const mockCreateCounterFn = vi.fn();
@@ -27,18 +29,44 @@ function originalOtelMockFactory() {
27
29
  },
28
30
  ValueType: {
29
31
  INT: 1,
32
+ DOUBLE: 2,
30
33
  },
31
34
  diag: {
32
35
  setLogger: vi.fn(),
36
+ warn: vi.fn(),
37
+ },
38
+ DiagConsoleLogger: vi.fn(),
39
+ DiagLogLevel: {
40
+ NONE: 0,
41
+ INFO: 1,
33
42
  },
34
43
  };
35
44
  }
36
45
  vi.mock('@opentelemetry/api');
46
+ vi.mock('./telemetryAttributes.js');
37
47
  describe('Telemetry Metrics', () => {
38
48
  let initializeMetricsModule;
39
49
  let recordTokenUsageMetricsModule;
40
50
  let recordFileOperationMetricModule;
41
51
  let recordChatCompressionMetricsModule;
52
+ let recordModelRoutingMetricsModule;
53
+ let recordStartupPerformanceModule;
54
+ let recordMemoryUsageModule;
55
+ let recordCpuUsageModule;
56
+ let recordToolQueueDepthModule;
57
+ let recordToolExecutionBreakdownModule;
58
+ let recordTokenEfficiencyModule;
59
+ let recordApiRequestBreakdownModule;
60
+ let recordPerformanceScoreModule;
61
+ let recordPerformanceRegressionModule;
62
+ let recordBaselineComparisonModule;
63
+ let recordGenAiClientTokenUsageModule;
64
+ let recordGenAiClientOperationDurationModule;
65
+ let recordFlickerFrameModule;
66
+ let recordExitFailModule;
67
+ let recordAgentRunMetricsModule;
68
+ let recordLinesChangedModule;
69
+ let recordSlowRenderModule;
42
70
  beforeEach(async () => {
43
71
  vi.resetModules();
44
72
  vi.doMock('@opentelemetry/api', () => {
@@ -46,12 +74,40 @@ describe('Telemetry Metrics', () => {
46
74
  actualApi.metrics.getMeter.mockReturnValue(mockMeterInstance);
47
75
  return actualApi;
48
76
  });
77
+ const { getCommonAttributes } = await import('./telemetryAttributes.js');
78
+ getCommonAttributes.mockReturnValue({
79
+ 'session.id': 'test-session-id',
80
+ 'installation.id': 'test-installation-id',
81
+ 'user.email': 'test@example.com',
82
+ });
49
83
  const metricsJsModule = await import('./metrics.js');
50
84
  initializeMetricsModule = metricsJsModule.initializeMetrics;
51
85
  recordTokenUsageMetricsModule = metricsJsModule.recordTokenUsageMetrics;
52
86
  recordFileOperationMetricModule = metricsJsModule.recordFileOperationMetric;
53
87
  recordChatCompressionMetricsModule =
54
88
  metricsJsModule.recordChatCompressionMetrics;
89
+ recordModelRoutingMetricsModule = metricsJsModule.recordModelRoutingMetrics;
90
+ recordStartupPerformanceModule = metricsJsModule.recordStartupPerformance;
91
+ recordMemoryUsageModule = metricsJsModule.recordMemoryUsage;
92
+ recordCpuUsageModule = metricsJsModule.recordCpuUsage;
93
+ recordToolQueueDepthModule = metricsJsModule.recordToolQueueDepth;
94
+ recordToolExecutionBreakdownModule =
95
+ metricsJsModule.recordToolExecutionBreakdown;
96
+ recordTokenEfficiencyModule = metricsJsModule.recordTokenEfficiency;
97
+ recordApiRequestBreakdownModule = metricsJsModule.recordApiRequestBreakdown;
98
+ recordPerformanceScoreModule = metricsJsModule.recordPerformanceScore;
99
+ recordPerformanceRegressionModule =
100
+ metricsJsModule.recordPerformanceRegression;
101
+ recordBaselineComparisonModule = metricsJsModule.recordBaselineComparison;
102
+ recordGenAiClientTokenUsageModule =
103
+ metricsJsModule.recordGenAiClientTokenUsage;
104
+ recordGenAiClientOperationDurationModule =
105
+ metricsJsModule.recordGenAiClientOperationDuration;
106
+ recordFlickerFrameModule = metricsJsModule.recordFlickerFrame;
107
+ recordExitFailModule = metricsJsModule.recordExitFail;
108
+ recordAgentRunMetricsModule = metricsJsModule.recordAgentRunMetrics;
109
+ recordLinesChangedModule = metricsJsModule.recordLinesChanged;
110
+ recordSlowRenderModule = metricsJsModule.recordSlowRender;
55
111
  const otelApiModule = await import('@opentelemetry/api');
56
112
  mockCounterAddFn.mockClear();
57
113
  mockCreateCounterFn.mockClear();
@@ -62,6 +118,75 @@ describe('Telemetry Metrics', () => {
62
118
  mockCreateCounterFn.mockReturnValue(mockCounterInstance);
63
119
  mockCreateHistogramFn.mockReturnValue(mockHistogramInstance);
64
120
  });
121
+ describe('recordFlickerFrame', () => {
122
+ it('does not record metrics if not initialized', () => {
123
+ const config = makeFakeConfig({});
124
+ recordFlickerFrameModule(config);
125
+ expect(mockCounterAddFn).not.toHaveBeenCalled();
126
+ });
127
+ it('records a flicker frame event when initialized', () => {
128
+ const config = makeFakeConfig({});
129
+ initializeMetricsModule(config);
130
+ recordFlickerFrameModule(config);
131
+ // Called for session, then for flicker
132
+ expect(mockCounterAddFn).toHaveBeenCalledTimes(2);
133
+ expect(mockCounterAddFn).toHaveBeenNthCalledWith(2, 1, {
134
+ 'session.id': 'test-session-id',
135
+ 'installation.id': 'test-installation-id',
136
+ 'user.email': 'test@example.com',
137
+ });
138
+ });
139
+ });
140
+ describe('recordExitFail', () => {
141
+ it('does not record metrics if not initialized', () => {
142
+ const config = makeFakeConfig({});
143
+ recordExitFailModule(config);
144
+ expect(mockCounterAddFn).not.toHaveBeenCalled();
145
+ });
146
+ it('records a exit fail event when initialized', () => {
147
+ const config = makeFakeConfig({});
148
+ initializeMetricsModule(config);
149
+ recordExitFailModule(config);
150
+ // Called for session, then for exit fail
151
+ expect(mockCounterAddFn).toHaveBeenCalledTimes(2);
152
+ expect(mockCounterAddFn).toHaveBeenNthCalledWith(2, 1, {
153
+ 'session.id': 'test-session-id',
154
+ 'installation.id': 'test-installation-id',
155
+ 'user.email': 'test@example.com',
156
+ });
157
+ });
158
+ });
159
+ describe('recordSlowRender', () => {
160
+ it('does not record metrics if not initialized', () => {
161
+ const config = makeFakeConfig({});
162
+ recordSlowRenderModule(config, 123);
163
+ expect(mockHistogramRecordFn).not.toHaveBeenCalled();
164
+ });
165
+ it('records a slow render event when initialized', () => {
166
+ const config = makeFakeConfig({});
167
+ initializeMetricsModule(config);
168
+ recordSlowRenderModule(config, 123);
169
+ expect(mockHistogramRecordFn).toHaveBeenCalledWith(123, {
170
+ 'session.id': 'test-session-id',
171
+ 'installation.id': 'test-installation-id',
172
+ 'user.email': 'test@example.com',
173
+ });
174
+ });
175
+ });
176
+ describe('initializeMetrics', () => {
177
+ const mockConfig = {
178
+ getSessionId: () => 'test-session-id',
179
+ getTelemetryEnabled: () => true,
180
+ };
181
+ it('should apply common attributes including email', () => {
182
+ initializeMetricsModule(mockConfig);
183
+ expect(mockCounterAddFn).toHaveBeenCalledWith(1, {
184
+ 'session.id': 'test-session-id',
185
+ 'installation.id': 'test-installation-id',
186
+ 'user.email': 'test@example.com',
187
+ });
188
+ });
189
+ });
65
190
  describe('recordChatCompressionMetrics', () => {
66
191
  it('does not record metrics if not initialized', () => {
67
192
  const lol = makeFakeConfig({});
@@ -80,6 +205,8 @@ describe('Telemetry Metrics', () => {
80
205
  });
81
206
  expect(mockCounterAddFn).toHaveBeenCalledWith(1, {
82
207
  'session.id': 'test-session-id',
208
+ 'installation.id': 'test-installation-id',
209
+ 'user.email': 'test@example.com',
83
210
  tokens_after: 100,
84
211
  tokens_before: 200,
85
212
  });
@@ -88,153 +215,889 @@ describe('Telemetry Metrics', () => {
88
215
  describe('recordTokenUsageMetrics', () => {
89
216
  const mockConfig = {
90
217
  getSessionId: () => 'test-session-id',
218
+ getTelemetryEnabled: () => true,
91
219
  };
92
220
  it('should not record metrics if not initialized', () => {
93
- recordTokenUsageMetricsModule(mockConfig, 'gemini-pro', 100, 'input');
94
- expect(mockCounterAddFn).not.toHaveBeenCalled();
95
- });
96
- it('should record token usage with the correct attributes', () => {
97
- initializeMetricsModule(mockConfig);
98
- recordTokenUsageMetricsModule(mockConfig, 'gemini-pro', 100, 'input');
99
- expect(mockCounterAddFn).toHaveBeenCalledTimes(2);
100
- expect(mockCounterAddFn).toHaveBeenNthCalledWith(1, 1, {
101
- 'session.id': 'test-session-id',
102
- });
103
- expect(mockCounterAddFn).toHaveBeenNthCalledWith(2, 100, {
104
- 'session.id': 'test-session-id',
221
+ recordTokenUsageMetricsModule(mockConfig, 100, {
105
222
  model: 'gemini-pro',
106
223
  type: 'input',
107
224
  });
225
+ expect(mockCounterAddFn).not.toHaveBeenCalled();
108
226
  });
109
- it('should record token usage for different types', () => {
227
+ it.each([
228
+ { type: 'input', tokens: 100, model: 'gemini-pro' },
229
+ { type: 'output', tokens: 50, model: 'gemini-pro' },
230
+ { type: 'thought', tokens: 25, model: 'gemini-pro' },
231
+ { type: 'cache', tokens: 75, model: 'gemini-pro' },
232
+ { type: 'tool', tokens: 125, model: 'gemini-pro' },
233
+ { type: 'input', tokens: 200, model: 'gemini-different-model' },
234
+ ])('should record token usage for $type type with $tokens tokens for model $model', ({ type, tokens, model }) => {
110
235
  initializeMetricsModule(mockConfig);
111
236
  mockCounterAddFn.mockClear();
112
- recordTokenUsageMetricsModule(mockConfig, 'gemini-pro', 50, 'output');
113
- expect(mockCounterAddFn).toHaveBeenCalledWith(50, {
114
- 'session.id': 'test-session-id',
115
- model: 'gemini-pro',
116
- type: 'output',
237
+ recordTokenUsageMetricsModule(mockConfig, tokens, {
238
+ model,
239
+ type: type,
117
240
  });
118
- recordTokenUsageMetricsModule(mockConfig, 'gemini-pro', 25, 'thought');
119
- expect(mockCounterAddFn).toHaveBeenCalledWith(25, {
241
+ expect(mockCounterAddFn).toHaveBeenCalledWith(tokens, {
120
242
  'session.id': 'test-session-id',
121
- model: 'gemini-pro',
122
- type: 'thought',
243
+ 'installation.id': 'test-installation-id',
244
+ 'user.email': 'test@example.com',
245
+ model,
246
+ type,
123
247
  });
124
- recordTokenUsageMetricsModule(mockConfig, 'gemini-pro', 75, 'cache');
125
- expect(mockCounterAddFn).toHaveBeenCalledWith(75, {
126
- 'session.id': 'test-session-id',
127
- model: 'gemini-pro',
128
- type: 'cache',
248
+ });
249
+ });
250
+ describe('recordLinesChanged metric', () => {
251
+ const mockConfig = {
252
+ getSessionId: () => 'test-session-id',
253
+ getTelemetryEnabled: () => true,
254
+ };
255
+ it('should not record lines added/removed if not initialized', () => {
256
+ recordLinesChangedModule(mockConfig, 10, 'added', {
257
+ function_name: 'fn',
258
+ });
259
+ recordLinesChangedModule(mockConfig, 5, 'removed', {
260
+ function_name: 'fn',
261
+ });
262
+ expect(mockCounterAddFn).not.toHaveBeenCalled();
263
+ });
264
+ it('should record lines added with function_name after initialization', () => {
265
+ initializeMetricsModule(mockConfig);
266
+ mockCounterAddFn.mockClear();
267
+ recordLinesChangedModule(mockConfig, 10, 'added', {
268
+ function_name: 'my-fn',
129
269
  });
130
- recordTokenUsageMetricsModule(mockConfig, 'gemini-pro', 125, 'tool');
131
- expect(mockCounterAddFn).toHaveBeenCalledWith(125, {
270
+ expect(mockCounterAddFn).toHaveBeenCalledWith(10, {
132
271
  'session.id': 'test-session-id',
133
- model: 'gemini-pro',
134
- type: 'tool',
272
+ 'installation.id': 'test-installation-id',
273
+ 'user.email': 'test@example.com',
274
+ type: 'added',
275
+ function_name: 'my-fn',
135
276
  });
136
277
  });
137
- it('should handle different models', () => {
278
+ it('should record lines removed with function_name after initialization', () => {
138
279
  initializeMetricsModule(mockConfig);
139
280
  mockCounterAddFn.mockClear();
140
- recordTokenUsageMetricsModule(mockConfig, 'gemini-ultra', 200, 'input');
141
- expect(mockCounterAddFn).toHaveBeenCalledWith(200, {
281
+ recordLinesChangedModule(mockConfig, 7, 'removed', {
282
+ function_name: 'my-fn',
283
+ });
284
+ expect(mockCounterAddFn).toHaveBeenCalledWith(7, {
142
285
  'session.id': 'test-session-id',
143
- model: 'gemini-ultra',
144
- type: 'input',
286
+ 'installation.id': 'test-installation-id',
287
+ 'user.email': 'test@example.com',
288
+ type: 'removed',
289
+ function_name: 'my-fn',
145
290
  });
146
291
  });
147
292
  });
148
293
  describe('recordFileOperationMetric', () => {
149
294
  const mockConfig = {
150
295
  getSessionId: () => 'test-session-id',
296
+ getTelemetryEnabled: () => true,
297
+ };
298
+ it.each([
299
+ {
300
+ name: 'should not record metrics if not initialized',
301
+ initialized: false,
302
+ attributes: {
303
+ operation: FileOperation.CREATE,
304
+ lines: 10,
305
+ mimetype: 'text/plain',
306
+ extension: 'txt',
307
+ },
308
+ shouldCall: false,
309
+ },
310
+ {
311
+ name: 'should record file creation with all attributes',
312
+ initialized: true,
313
+ attributes: {
314
+ operation: FileOperation.CREATE,
315
+ lines: 10,
316
+ mimetype: 'text/plain',
317
+ extension: 'txt',
318
+ },
319
+ shouldCall: true,
320
+ },
321
+ {
322
+ name: 'should record file read with minimal attributes',
323
+ initialized: true,
324
+ attributes: { operation: FileOperation.READ },
325
+ shouldCall: true,
326
+ },
327
+ {
328
+ name: 'should record file update with some attributes',
329
+ initialized: true,
330
+ attributes: {
331
+ operation: FileOperation.UPDATE,
332
+ mimetype: 'application/javascript',
333
+ },
334
+ shouldCall: true,
335
+ },
336
+ {
337
+ name: 'should record file update with no optional attributes',
338
+ initialized: true,
339
+ attributes: { operation: FileOperation.UPDATE },
340
+ shouldCall: true,
341
+ },
342
+ ])('$name', ({ initialized, attributes, shouldCall }) => {
343
+ if (initialized) {
344
+ initializeMetricsModule(mockConfig);
345
+ // The session start event also calls the counter.
346
+ mockCounterAddFn.mockClear();
347
+ }
348
+ recordFileOperationMetricModule(mockConfig, attributes);
349
+ if (shouldCall) {
350
+ expect(mockCounterAddFn).toHaveBeenCalledWith(1, {
351
+ 'session.id': 'test-session-id',
352
+ 'installation.id': 'test-installation-id',
353
+ 'user.email': 'test@example.com',
354
+ ...attributes,
355
+ });
356
+ }
357
+ else {
358
+ expect(mockCounterAddFn).not.toHaveBeenCalled();
359
+ }
360
+ });
361
+ });
362
+ describe('recordModelRoutingMetrics', () => {
363
+ const mockConfig = {
364
+ getSessionId: () => 'test-session-id',
365
+ getTelemetryEnabled: () => true,
151
366
  };
152
367
  it('should not record metrics if not initialized', () => {
153
- recordFileOperationMetricModule(mockConfig, FileOperation.CREATE, 10, 'text/plain', 'txt');
368
+ const event = new ModelRoutingEvent('gemini-pro', 'default', 100, 'test-reason', false, undefined);
369
+ recordModelRoutingMetricsModule(mockConfig, event);
370
+ expect(mockHistogramRecordFn).not.toHaveBeenCalled();
154
371
  expect(mockCounterAddFn).not.toHaveBeenCalled();
155
372
  });
156
- it('should record file creation with all attributes', () => {
373
+ it('should record latency for a successful routing decision', () => {
157
374
  initializeMetricsModule(mockConfig);
158
- recordFileOperationMetricModule(mockConfig, FileOperation.CREATE, 10, 'text/plain', 'txt');
159
- expect(mockCounterAddFn).toHaveBeenCalledTimes(2);
160
- expect(mockCounterAddFn).toHaveBeenNthCalledWith(1, 1, {
375
+ const event = new ModelRoutingEvent('gemini-pro', 'default', 150, 'test-reason', false, undefined);
376
+ recordModelRoutingMetricsModule(mockConfig, event);
377
+ expect(mockHistogramRecordFn).toHaveBeenCalledWith(150, {
161
378
  'session.id': 'test-session-id',
379
+ 'installation.id': 'test-installation-id',
380
+ 'user.email': 'test@example.com',
381
+ 'routing.decision_model': 'gemini-pro',
382
+ 'routing.decision_source': 'default',
162
383
  });
384
+ // The session counter is called once on init
385
+ expect(mockCounterAddFn).toHaveBeenCalledTimes(1);
386
+ });
387
+ it('should record latency and failure for a failed routing decision', () => {
388
+ initializeMetricsModule(mockConfig);
389
+ const event = new ModelRoutingEvent('gemini-pro', 'classifier', 200, 'test-reason', true, 'test-error');
390
+ recordModelRoutingMetricsModule(mockConfig, event);
391
+ expect(mockHistogramRecordFn).toHaveBeenCalledWith(200, {
392
+ 'session.id': 'test-session-id',
393
+ 'installation.id': 'test-installation-id',
394
+ 'user.email': 'test@example.com',
395
+ 'routing.decision_model': 'gemini-pro',
396
+ 'routing.decision_source': 'classifier',
397
+ });
398
+ expect(mockCounterAddFn).toHaveBeenCalledTimes(2);
163
399
  expect(mockCounterAddFn).toHaveBeenNthCalledWith(2, 1, {
164
400
  'session.id': 'test-session-id',
165
- operation: FileOperation.CREATE,
166
- lines: 10,
167
- mimetype: 'text/plain',
168
- extension: 'txt',
401
+ 'installation.id': 'test-installation-id',
402
+ 'user.email': 'test@example.com',
403
+ 'routing.decision_source': 'classifier',
404
+ 'routing.error_message': 'test-error',
169
405
  });
170
406
  });
171
- it('should record file read with minimal attributes', () => {
407
+ });
408
+ describe('recordAgentRunMetrics', () => {
409
+ const mockConfig = {
410
+ getSessionId: () => 'test-session-id',
411
+ getTelemetryEnabled: () => true,
412
+ };
413
+ it('should not record metrics if not initialized', () => {
414
+ const event = new AgentFinishEvent('agent-123', 'TestAgent', 1000, 5, AgentTerminateMode.GOAL);
415
+ recordAgentRunMetricsModule(mockConfig, event);
416
+ expect(mockCounterAddFn).not.toHaveBeenCalled();
417
+ expect(mockHistogramRecordFn).not.toHaveBeenCalled();
418
+ });
419
+ it('should record agent run metrics', () => {
172
420
  initializeMetricsModule(mockConfig);
173
421
  mockCounterAddFn.mockClear();
174
- recordFileOperationMetricModule(mockConfig, FileOperation.READ);
422
+ mockHistogramRecordFn.mockClear();
423
+ const event = new AgentFinishEvent('agent-123', 'TestAgent', 1000, 5, AgentTerminateMode.GOAL);
424
+ recordAgentRunMetricsModule(mockConfig, event);
425
+ // Verify agent run counter
175
426
  expect(mockCounterAddFn).toHaveBeenCalledWith(1, {
176
427
  'session.id': 'test-session-id',
177
- operation: FileOperation.READ,
428
+ 'installation.id': 'test-installation-id',
429
+ 'user.email': 'test@example.com',
430
+ agent_name: 'TestAgent',
431
+ terminate_reason: 'GOAL',
178
432
  });
179
- });
180
- it('should record file update with some attributes', () => {
181
- initializeMetricsModule(mockConfig);
182
- mockCounterAddFn.mockClear();
183
- recordFileOperationMetricModule(mockConfig, FileOperation.UPDATE, undefined, 'application/javascript');
184
- expect(mockCounterAddFn).toHaveBeenCalledWith(1, {
433
+ // Verify agent duration histogram
434
+ expect(mockHistogramRecordFn).toHaveBeenCalledWith(1000, {
185
435
  'session.id': 'test-session-id',
186
- operation: FileOperation.UPDATE,
187
- mimetype: 'application/javascript',
436
+ 'installation.id': 'test-installation-id',
437
+ 'user.email': 'test@example.com',
438
+ agent_name: 'TestAgent',
188
439
  });
189
- });
190
- it('should include diffStat when provided', () => {
191
- initializeMetricsModule(mockConfig);
192
- mockCounterAddFn.mockClear();
193
- const diffStat = {
194
- ai_added_lines: 5,
195
- ai_removed_lines: 2,
196
- user_added_lines: 3,
197
- user_removed_lines: 1,
198
- };
199
- recordFileOperationMetricModule(mockConfig, FileOperation.UPDATE, undefined, undefined, undefined, diffStat);
200
- expect(mockCounterAddFn).toHaveBeenCalledWith(1, {
440
+ // Verify agent turns histogram
441
+ expect(mockHistogramRecordFn).toHaveBeenCalledWith(5, {
201
442
  'session.id': 'test-session-id',
202
- operation: FileOperation.UPDATE,
203
- ai_added_lines: 5,
204
- ai_removed_lines: 2,
205
- user_added_lines: 3,
206
- user_removed_lines: 1,
443
+ 'installation.id': 'test-installation-id',
444
+ 'user.email': 'test@example.com',
445
+ agent_name: 'TestAgent',
207
446
  });
208
447
  });
209
- it('should not include diffStat attributes when diffStat is not provided', () => {
210
- initializeMetricsModule(mockConfig);
211
- mockCounterAddFn.mockClear();
212
- recordFileOperationMetricModule(mockConfig, FileOperation.UPDATE, 10, 'text/plain', 'txt', undefined);
213
- expect(mockCounterAddFn).toHaveBeenCalledWith(1, {
214
- 'session.id': 'test-session-id',
215
- operation: FileOperation.UPDATE,
216
- lines: 10,
217
- mimetype: 'text/plain',
218
- extension: 'txt',
448
+ });
449
+ describe('OpenTelemetry GenAI Semantic Convention Metrics', () => {
450
+ const mockConfig = {
451
+ getSessionId: () => 'test-session-id',
452
+ getTelemetryEnabled: () => true,
453
+ };
454
+ describe('recordGenAiClientTokenUsage', () => {
455
+ it('should not record metrics when not initialized', () => {
456
+ recordGenAiClientTokenUsageModule(mockConfig, 100, {
457
+ 'gen_ai.operation.name': 'generate_content',
458
+ 'gen_ai.provider.name': 'gcp.gen_ai',
459
+ 'gen_ai.token.type': 'input',
460
+ });
461
+ expect(mockHistogramRecordFn).not.toHaveBeenCalled();
462
+ });
463
+ it('should record input token usage with correct attributes', () => {
464
+ initializeMetricsModule(mockConfig);
465
+ mockHistogramRecordFn.mockClear();
466
+ recordGenAiClientTokenUsageModule(mockConfig, 150, {
467
+ 'gen_ai.operation.name': 'generate_content',
468
+ 'gen_ai.provider.name': 'gcp.gen_ai',
469
+ 'gen_ai.token.type': 'input',
470
+ 'gen_ai.request.model': 'gemini-2.0-flash',
471
+ 'gen_ai.response.model': 'gemini-2.0-flash',
472
+ });
473
+ expect(mockHistogramRecordFn).toHaveBeenCalledWith(150, {
474
+ 'session.id': 'test-session-id',
475
+ 'installation.id': 'test-installation-id',
476
+ 'user.email': 'test@example.com',
477
+ 'gen_ai.operation.name': 'generate_content',
478
+ 'gen_ai.provider.name': 'gcp.gen_ai',
479
+ 'gen_ai.token.type': 'input',
480
+ 'gen_ai.request.model': 'gemini-2.0-flash',
481
+ 'gen_ai.response.model': 'gemini-2.0-flash',
482
+ });
483
+ });
484
+ it('should record output token usage with correct attributes', () => {
485
+ initializeMetricsModule(mockConfig);
486
+ mockHistogramRecordFn.mockClear();
487
+ recordGenAiClientTokenUsageModule(mockConfig, 75, {
488
+ 'gen_ai.operation.name': 'generate_content',
489
+ 'gen_ai.provider.name': 'gcp.vertex_ai',
490
+ 'gen_ai.token.type': 'output',
491
+ 'gen_ai.request.model': 'gemini-pro',
492
+ });
493
+ expect(mockHistogramRecordFn).toHaveBeenCalledWith(75, {
494
+ 'session.id': 'test-session-id',
495
+ 'installation.id': 'test-installation-id',
496
+ 'user.email': 'test@example.com',
497
+ 'gen_ai.operation.name': 'generate_content',
498
+ 'gen_ai.provider.name': 'gcp.vertex_ai',
499
+ 'gen_ai.token.type': 'output',
500
+ 'gen_ai.request.model': 'gemini-pro',
501
+ });
502
+ });
503
+ it('should record token usage with optional attributes', () => {
504
+ initializeMetricsModule(mockConfig);
505
+ mockHistogramRecordFn.mockClear();
506
+ recordGenAiClientTokenUsageModule(mockConfig, 200, {
507
+ 'gen_ai.operation.name': 'generate_content',
508
+ 'gen_ai.provider.name': 'gcp.vertex_ai',
509
+ 'gen_ai.token.type': 'input',
510
+ 'gen_ai.request.model': 'text-embedding-004',
511
+ 'server.address': 'aiplatform.googleapis.com',
512
+ 'server.port': 443,
513
+ });
514
+ expect(mockHistogramRecordFn).toHaveBeenCalledWith(200, {
515
+ 'session.id': 'test-session-id',
516
+ 'installation.id': 'test-installation-id',
517
+ 'user.email': 'test@example.com',
518
+ 'gen_ai.operation.name': 'generate_content',
519
+ 'gen_ai.provider.name': 'gcp.vertex_ai',
520
+ 'gen_ai.token.type': 'input',
521
+ 'gen_ai.request.model': 'text-embedding-004',
522
+ 'server.address': 'aiplatform.googleapis.com',
523
+ 'server.port': 443,
524
+ });
219
525
  });
220
526
  });
221
- it('should handle diffStat with all zero values', () => {
222
- initializeMetricsModule(mockConfig);
223
- mockCounterAddFn.mockClear();
224
- const diffStat = {
225
- ai_added_lines: 0,
226
- ai_removed_lines: 0,
227
- user_added_lines: 0,
228
- user_removed_lines: 0,
229
- };
230
- recordFileOperationMetricModule(mockConfig, FileOperation.UPDATE, undefined, undefined, undefined, diffStat);
231
- expect(mockCounterAddFn).toHaveBeenCalledWith(1, {
232
- 'session.id': 'test-session-id',
233
- operation: FileOperation.UPDATE,
234
- ai_added_lines: 0,
235
- ai_removed_lines: 0,
236
- user_added_lines: 0,
237
- user_removed_lines: 0,
527
+ describe('recordGenAiClientOperationDuration', () => {
528
+ it('should not record metrics when not initialized', () => {
529
+ recordGenAiClientOperationDurationModule(mockConfig, 2.5, {
530
+ 'gen_ai.operation.name': 'generate_content',
531
+ 'gen_ai.provider.name': 'gcp.gen_ai',
532
+ });
533
+ expect(mockHistogramRecordFn).not.toHaveBeenCalled();
534
+ });
535
+ it('should record successful operation duration with correct attributes', () => {
536
+ initializeMetricsModule(mockConfig);
537
+ mockHistogramRecordFn.mockClear();
538
+ recordGenAiClientOperationDurationModule(mockConfig, 1.25, {
539
+ 'gen_ai.operation.name': 'generate_content',
540
+ 'gen_ai.provider.name': 'gcp.gen_ai',
541
+ 'gen_ai.request.model': 'gemini-2.0-flash',
542
+ 'gen_ai.response.model': 'gemini-2.0-flash',
543
+ });
544
+ expect(mockHistogramRecordFn).toHaveBeenCalledWith(1.25, {
545
+ 'session.id': 'test-session-id',
546
+ 'installation.id': 'test-installation-id',
547
+ 'user.email': 'test@example.com',
548
+ 'gen_ai.operation.name': 'generate_content',
549
+ 'gen_ai.provider.name': 'gcp.gen_ai',
550
+ 'gen_ai.request.model': 'gemini-2.0-flash',
551
+ 'gen_ai.response.model': 'gemini-2.0-flash',
552
+ });
553
+ });
554
+ it('should record failed operation duration with error type', () => {
555
+ initializeMetricsModule(mockConfig);
556
+ mockHistogramRecordFn.mockClear();
557
+ recordGenAiClientOperationDurationModule(mockConfig, 3.75, {
558
+ 'gen_ai.operation.name': 'generate_content',
559
+ 'gen_ai.provider.name': 'gcp.vertex_ai',
560
+ 'gen_ai.request.model': 'gemini-pro',
561
+ 'error.type': 'quota_exceeded',
562
+ });
563
+ expect(mockHistogramRecordFn).toHaveBeenCalledWith(3.75, {
564
+ 'session.id': 'test-session-id',
565
+ 'installation.id': 'test-installation-id',
566
+ 'user.email': 'test@example.com',
567
+ 'gen_ai.operation.name': 'generate_content',
568
+ 'gen_ai.provider.name': 'gcp.vertex_ai',
569
+ 'gen_ai.request.model': 'gemini-pro',
570
+ 'error.type': 'quota_exceeded',
571
+ });
572
+ });
573
+ it('should record operation duration with server details', () => {
574
+ initializeMetricsModule(mockConfig);
575
+ mockHistogramRecordFn.mockClear();
576
+ recordGenAiClientOperationDurationModule(mockConfig, 0.95, {
577
+ 'gen_ai.operation.name': 'generate_content',
578
+ 'gen_ai.provider.name': 'gcp.vertex_ai',
579
+ 'gen_ai.request.model': 'gemini-1.5-pro',
580
+ 'gen_ai.response.model': 'gemini-1.5-pro-001',
581
+ 'server.address': 'us-central1-aiplatform.googleapis.com',
582
+ 'server.port': 443,
583
+ });
584
+ expect(mockHistogramRecordFn).toHaveBeenCalledWith(0.95, {
585
+ 'session.id': 'test-session-id',
586
+ 'installation.id': 'test-installation-id',
587
+ 'user.email': 'test@example.com',
588
+ 'gen_ai.operation.name': 'generate_content',
589
+ 'gen_ai.provider.name': 'gcp.vertex_ai',
590
+ 'gen_ai.request.model': 'gemini-1.5-pro',
591
+ 'gen_ai.response.model': 'gemini-1.5-pro-001',
592
+ 'server.address': 'us-central1-aiplatform.googleapis.com',
593
+ 'server.port': 443,
594
+ });
595
+ });
596
+ it('should handle minimal required attributes', () => {
597
+ initializeMetricsModule(mockConfig);
598
+ mockHistogramRecordFn.mockClear();
599
+ recordGenAiClientOperationDurationModule(mockConfig, 2.1, {
600
+ 'gen_ai.operation.name': 'generate_content',
601
+ 'gen_ai.provider.name': 'gcp.gen_ai',
602
+ });
603
+ expect(mockHistogramRecordFn).toHaveBeenCalledWith(2.1, {
604
+ 'session.id': 'test-session-id',
605
+ 'installation.id': 'test-installation-id',
606
+ 'user.email': 'test@example.com',
607
+ 'gen_ai.operation.name': 'generate_content',
608
+ 'gen_ai.provider.name': 'gcp.gen_ai',
609
+ });
610
+ });
611
+ });
612
+ });
613
+ describe('Performance Monitoring Metrics', () => {
614
+ const mockConfig = {
615
+ getSessionId: () => 'test-session-id',
616
+ getTelemetryEnabled: () => true,
617
+ };
618
+ describe('recordStartupPerformance', () => {
619
+ it('should not record metrics when performance monitoring is disabled', async () => {
620
+ // Re-import with performance monitoring disabled by mocking the config
621
+ const mockConfigDisabled = {
622
+ getSessionId: () => 'test-session-id',
623
+ getTelemetryEnabled: () => false, // Disable telemetry to disable performance monitoring
624
+ };
625
+ initializeMetricsModule(mockConfigDisabled);
626
+ mockHistogramRecordFn.mockClear();
627
+ recordStartupPerformanceModule(mockConfigDisabled, 100, {
628
+ phase: 'settings_loading',
629
+ details: {
630
+ auth_type: 'gemini',
631
+ },
632
+ });
633
+ expect(mockHistogramRecordFn).not.toHaveBeenCalled();
634
+ });
635
+ it('should record startup performance with phase and details', () => {
636
+ initializeMetricsModule(mockConfig);
637
+ mockHistogramRecordFn.mockClear();
638
+ recordStartupPerformanceModule(mockConfig, 150, {
639
+ phase: 'settings_loading',
640
+ details: {
641
+ auth_type: 'gemini',
642
+ telemetry_enabled: true,
643
+ settings_sources: 2,
644
+ },
645
+ });
646
+ expect(mockHistogramRecordFn).toHaveBeenCalledWith(150, {
647
+ 'session.id': 'test-session-id',
648
+ 'installation.id': 'test-installation-id',
649
+ 'user.email': 'test@example.com',
650
+ phase: 'settings_loading',
651
+ auth_type: 'gemini',
652
+ telemetry_enabled: true,
653
+ settings_sources: 2,
654
+ });
655
+ });
656
+ it('should record startup performance without details', () => {
657
+ initializeMetricsModule(mockConfig);
658
+ mockHistogramRecordFn.mockClear();
659
+ recordStartupPerformanceModule(mockConfig, 50, { phase: 'cleanup' });
660
+ expect(mockHistogramRecordFn).toHaveBeenCalledWith(50, {
661
+ 'session.id': 'test-session-id',
662
+ 'installation.id': 'test-installation-id',
663
+ 'user.email': 'test@example.com',
664
+ phase: 'cleanup',
665
+ });
666
+ });
667
+ it('should handle floating-point duration values from performance.now()', () => {
668
+ initializeMetricsModule(mockConfig);
669
+ mockHistogramRecordFn.mockClear();
670
+ // Test with realistic floating-point values that performance.now() would return
671
+ const floatingPointDuration = 123.45678;
672
+ recordStartupPerformanceModule(mockConfig, floatingPointDuration, {
673
+ phase: 'total_startup',
674
+ details: {
675
+ is_tty: true,
676
+ has_question: false,
677
+ },
678
+ });
679
+ expect(mockHistogramRecordFn).toHaveBeenCalledWith(floatingPointDuration, {
680
+ 'session.id': 'test-session-id',
681
+ 'installation.id': 'test-installation-id',
682
+ 'user.email': 'test@example.com',
683
+ phase: 'total_startup',
684
+ is_tty: true,
685
+ has_question: false,
686
+ });
687
+ });
688
+ });
689
+ describe('recordMemoryUsage', () => {
690
+ it.each([
691
+ {
692
+ memory_type: MemoryMetricType.HEAP_USED,
693
+ component: 'startup',
694
+ value: 15728640,
695
+ },
696
+ {
697
+ memory_type: MemoryMetricType.HEAP_TOTAL,
698
+ component: 'api_call',
699
+ value: 31457280,
700
+ },
701
+ {
702
+ memory_type: MemoryMetricType.EXTERNAL,
703
+ component: 'tool_execution',
704
+ value: 2097152,
705
+ },
706
+ {
707
+ memory_type: MemoryMetricType.RSS,
708
+ component: 'memory_monitor',
709
+ value: 41943040,
710
+ },
711
+ {
712
+ memory_type: MemoryMetricType.HEAP_USED,
713
+ component: undefined,
714
+ value: 15728640,
715
+ },
716
+ ])('should record memory usage for $memory_type', ({ memory_type, component, value }) => {
717
+ initializeMetricsModule(mockConfig);
718
+ mockHistogramRecordFn.mockClear();
719
+ recordMemoryUsageModule(mockConfig, value, {
720
+ memory_type,
721
+ component,
722
+ });
723
+ const expectedAttributes = {
724
+ 'session.id': 'test-session-id',
725
+ 'installation.id': 'test-installation-id',
726
+ 'user.email': 'test@example.com',
727
+ memory_type,
728
+ };
729
+ if (component) {
730
+ expectedAttributes['component'] = component;
731
+ }
732
+ expect(mockHistogramRecordFn).toHaveBeenCalledWith(value, expectedAttributes);
733
+ });
734
+ });
735
+ describe('recordCpuUsage', () => {
736
+ it('should record CPU usage percentage', () => {
737
+ initializeMetricsModule(mockConfig);
738
+ mockHistogramRecordFn.mockClear();
739
+ recordCpuUsageModule(mockConfig, 85.5, {
740
+ component: 'tool_execution',
741
+ });
742
+ expect(mockHistogramRecordFn).toHaveBeenCalledWith(85.5, {
743
+ 'session.id': 'test-session-id',
744
+ 'installation.id': 'test-installation-id',
745
+ 'user.email': 'test@example.com',
746
+ component: 'tool_execution',
747
+ });
748
+ });
749
+ it('should record CPU usage without component', () => {
750
+ initializeMetricsModule(mockConfig);
751
+ mockHistogramRecordFn.mockClear();
752
+ recordCpuUsageModule(mockConfig, 42.3, {});
753
+ expect(mockHistogramRecordFn).toHaveBeenCalledWith(42.3, {
754
+ 'session.id': 'test-session-id',
755
+ 'installation.id': 'test-installation-id',
756
+ 'user.email': 'test@example.com',
757
+ });
758
+ });
759
+ });
760
+ describe('recordToolQueueDepth', () => {
761
+ it('should record tool queue depth', () => {
762
+ initializeMetricsModule(mockConfig);
763
+ mockHistogramRecordFn.mockClear();
764
+ recordToolQueueDepthModule(mockConfig, 3);
765
+ expect(mockHistogramRecordFn).toHaveBeenCalledWith(3, {
766
+ 'session.id': 'test-session-id',
767
+ 'installation.id': 'test-installation-id',
768
+ 'user.email': 'test@example.com',
769
+ });
770
+ });
771
+ it('should record zero queue depth', () => {
772
+ initializeMetricsModule(mockConfig);
773
+ mockHistogramRecordFn.mockClear();
774
+ recordToolQueueDepthModule(mockConfig, 0);
775
+ expect(mockHistogramRecordFn).toHaveBeenCalledWith(0, {
776
+ 'session.id': 'test-session-id',
777
+ 'installation.id': 'test-installation-id',
778
+ 'user.email': 'test@example.com',
779
+ });
780
+ });
781
+ });
782
+ describe('recordToolExecutionBreakdown', () => {
783
+ it('should record tool execution breakdown for all phases', () => {
784
+ initializeMetricsModule(mockConfig);
785
+ mockHistogramRecordFn.mockClear();
786
+ recordToolExecutionBreakdownModule(mockConfig, 25, {
787
+ function_name: 'Read',
788
+ phase: ToolExecutionPhase.VALIDATION,
789
+ });
790
+ expect(mockHistogramRecordFn).toHaveBeenCalledWith(25, {
791
+ 'session.id': 'test-session-id',
792
+ 'installation.id': 'test-installation-id',
793
+ 'user.email': 'test@example.com',
794
+ function_name: 'Read',
795
+ phase: 'validation',
796
+ });
797
+ });
798
+ it('should record execution breakdown for different phases', () => {
799
+ initializeMetricsModule(mockConfig);
800
+ mockHistogramRecordFn.mockClear();
801
+ recordToolExecutionBreakdownModule(mockConfig, 50, {
802
+ function_name: 'Bash',
803
+ phase: ToolExecutionPhase.PREPARATION,
804
+ });
805
+ recordToolExecutionBreakdownModule(mockConfig, 1500, {
806
+ function_name: 'Bash',
807
+ phase: ToolExecutionPhase.EXECUTION,
808
+ });
809
+ recordToolExecutionBreakdownModule(mockConfig, 75, {
810
+ function_name: 'Bash',
811
+ phase: ToolExecutionPhase.RESULT_PROCESSING,
812
+ });
813
+ expect(mockHistogramRecordFn).toHaveBeenCalledTimes(3); // One for each call
814
+ expect(mockHistogramRecordFn).toHaveBeenNthCalledWith(1, 50, {
815
+ 'session.id': 'test-session-id',
816
+ 'installation.id': 'test-installation-id',
817
+ 'user.email': 'test@example.com',
818
+ function_name: 'Bash',
819
+ phase: 'preparation',
820
+ });
821
+ expect(mockHistogramRecordFn).toHaveBeenNthCalledWith(2, 1500, {
822
+ 'session.id': 'test-session-id',
823
+ 'installation.id': 'test-installation-id',
824
+ 'user.email': 'test@example.com',
825
+ function_name: 'Bash',
826
+ phase: 'execution',
827
+ });
828
+ expect(mockHistogramRecordFn).toHaveBeenNthCalledWith(3, 75, {
829
+ 'session.id': 'test-session-id',
830
+ 'installation.id': 'test-installation-id',
831
+ 'user.email': 'test@example.com',
832
+ function_name: 'Bash',
833
+ phase: 'result_processing',
834
+ });
835
+ });
836
+ });
837
+ describe('recordTokenEfficiency', () => {
838
+ it('should record token efficiency metrics', () => {
839
+ initializeMetricsModule(mockConfig);
840
+ mockHistogramRecordFn.mockClear();
841
+ recordTokenEfficiencyModule(mockConfig, 0.85, {
842
+ model: 'gemini-pro',
843
+ metric: 'cache_hit_rate',
844
+ context: 'api_request',
845
+ });
846
+ expect(mockHistogramRecordFn).toHaveBeenCalledWith(0.85, {
847
+ 'session.id': 'test-session-id',
848
+ 'installation.id': 'test-installation-id',
849
+ 'user.email': 'test@example.com',
850
+ model: 'gemini-pro',
851
+ metric: 'cache_hit_rate',
852
+ context: 'api_request',
853
+ });
854
+ });
855
+ it('should record token efficiency without context', () => {
856
+ initializeMetricsModule(mockConfig);
857
+ mockHistogramRecordFn.mockClear();
858
+ recordTokenEfficiencyModule(mockConfig, 125.5, {
859
+ model: 'gemini-pro',
860
+ metric: 'tokens_per_operation',
861
+ });
862
+ expect(mockHistogramRecordFn).toHaveBeenCalledWith(125.5, {
863
+ 'session.id': 'test-session-id',
864
+ 'installation.id': 'test-installation-id',
865
+ 'user.email': 'test@example.com',
866
+ model: 'gemini-pro',
867
+ metric: 'tokens_per_operation',
868
+ });
869
+ });
870
+ });
871
+ describe('recordApiRequestBreakdown', () => {
872
+ it('should record API request breakdown for all phases', () => {
873
+ initializeMetricsModule(mockConfig);
874
+ mockHistogramRecordFn.mockClear();
875
+ recordApiRequestBreakdownModule(mockConfig, 15, {
876
+ model: 'gemini-pro',
877
+ phase: ApiRequestPhase.REQUEST_PREPARATION,
878
+ });
879
+ expect(mockHistogramRecordFn).toHaveBeenCalledWith(15, {
880
+ 'session.id': 'test-session-id',
881
+ 'installation.id': 'test-installation-id',
882
+ 'user.email': 'test@example.com',
883
+ model: 'gemini-pro',
884
+ phase: 'request_preparation',
885
+ });
886
+ });
887
+ it('should record API request breakdown for different phases', () => {
888
+ initializeMetricsModule(mockConfig);
889
+ mockHistogramRecordFn.mockClear();
890
+ recordApiRequestBreakdownModule(mockConfig, 250, {
891
+ model: 'gemini-pro',
892
+ phase: ApiRequestPhase.NETWORK_LATENCY,
893
+ });
894
+ recordApiRequestBreakdownModule(mockConfig, 100, {
895
+ model: 'gemini-pro',
896
+ phase: ApiRequestPhase.RESPONSE_PROCESSING,
897
+ });
898
+ recordApiRequestBreakdownModule(mockConfig, 50, {
899
+ model: 'gemini-pro',
900
+ phase: ApiRequestPhase.TOKEN_PROCESSING,
901
+ });
902
+ expect(mockHistogramRecordFn).toHaveBeenCalledTimes(3); // One for each call
903
+ expect(mockHistogramRecordFn).toHaveBeenNthCalledWith(1, 250, {
904
+ 'session.id': 'test-session-id',
905
+ 'installation.id': 'test-installation-id',
906
+ 'user.email': 'test@example.com',
907
+ model: 'gemini-pro',
908
+ phase: 'network_latency',
909
+ });
910
+ expect(mockHistogramRecordFn).toHaveBeenNthCalledWith(2, 100, {
911
+ 'session.id': 'test-session-id',
912
+ 'installation.id': 'test-installation-id',
913
+ 'user.email': 'test@example.com',
914
+ model: 'gemini-pro',
915
+ phase: 'response_processing',
916
+ });
917
+ expect(mockHistogramRecordFn).toHaveBeenNthCalledWith(3, 50, {
918
+ 'session.id': 'test-session-id',
919
+ 'installation.id': 'test-installation-id',
920
+ 'user.email': 'test@example.com',
921
+ model: 'gemini-pro',
922
+ phase: 'token_processing',
923
+ });
924
+ });
925
+ });
926
+ describe('recordPerformanceScore', () => {
927
+ it('should record performance score with category and baseline', () => {
928
+ initializeMetricsModule(mockConfig);
929
+ mockHistogramRecordFn.mockClear();
930
+ recordPerformanceScoreModule(mockConfig, 85.5, {
931
+ category: 'memory_efficiency',
932
+ baseline: 80.0,
933
+ });
934
+ expect(mockHistogramRecordFn).toHaveBeenCalledWith(85.5, {
935
+ 'session.id': 'test-session-id',
936
+ 'installation.id': 'test-installation-id',
937
+ 'user.email': 'test@example.com',
938
+ category: 'memory_efficiency',
939
+ baseline: 80.0,
940
+ });
941
+ });
942
+ it('should record performance score without baseline', () => {
943
+ initializeMetricsModule(mockConfig);
944
+ mockHistogramRecordFn.mockClear();
945
+ recordPerformanceScoreModule(mockConfig, 92.3, {
946
+ category: 'overall_performance',
947
+ });
948
+ expect(mockHistogramRecordFn).toHaveBeenCalledWith(92.3, {
949
+ 'session.id': 'test-session-id',
950
+ 'installation.id': 'test-installation-id',
951
+ 'user.email': 'test@example.com',
952
+ category: 'overall_performance',
953
+ });
954
+ });
955
+ });
956
+ describe('recordPerformanceRegression', () => {
957
+ it('should record performance regression with baseline comparison', () => {
958
+ initializeMetricsModule(mockConfig);
959
+ mockCounterAddFn.mockClear();
960
+ mockHistogramRecordFn.mockClear();
961
+ recordPerformanceRegressionModule(mockConfig, {
962
+ metric: 'startup_time',
963
+ current_value: 1200,
964
+ baseline_value: 1000,
965
+ severity: 'medium',
966
+ });
967
+ // Verify regression counter
968
+ expect(mockCounterAddFn).toHaveBeenCalledWith(1, {
969
+ 'session.id': 'test-session-id',
970
+ 'installation.id': 'test-installation-id',
971
+ 'user.email': 'test@example.com',
972
+ metric: 'startup_time',
973
+ severity: 'medium',
974
+ current_value: 1200,
975
+ baseline_value: 1000,
976
+ });
977
+ // Verify baseline comparison histogram (20% increase)
978
+ expect(mockHistogramRecordFn).toHaveBeenCalledWith(20, {
979
+ 'session.id': 'test-session-id',
980
+ 'installation.id': 'test-installation-id',
981
+ 'user.email': 'test@example.com',
982
+ metric: 'startup_time',
983
+ severity: 'medium',
984
+ current_value: 1200,
985
+ baseline_value: 1000,
986
+ });
987
+ });
988
+ it('should handle zero baseline value gracefully', () => {
989
+ initializeMetricsModule(mockConfig);
990
+ mockCounterAddFn.mockClear();
991
+ mockHistogramRecordFn.mockClear();
992
+ recordPerformanceRegressionModule(mockConfig, {
993
+ metric: 'memory_usage',
994
+ current_value: 100,
995
+ baseline_value: 0,
996
+ severity: 'high',
997
+ });
998
+ // Verify regression counter still recorded
999
+ expect(mockCounterAddFn).toHaveBeenCalledWith(1, {
1000
+ 'session.id': 'test-session-id',
1001
+ 'installation.id': 'test-installation-id',
1002
+ 'user.email': 'test@example.com',
1003
+ metric: 'memory_usage',
1004
+ severity: 'high',
1005
+ current_value: 100,
1006
+ baseline_value: 0,
1007
+ });
1008
+ // Verify no baseline comparison due to zero baseline
1009
+ expect(mockHistogramRecordFn).not.toHaveBeenCalled();
1010
+ });
1011
+ it('should record different severity levels', () => {
1012
+ initializeMetricsModule(mockConfig);
1013
+ mockCounterAddFn.mockClear();
1014
+ recordPerformanceRegressionModule(mockConfig, {
1015
+ metric: 'api_latency',
1016
+ current_value: 500,
1017
+ baseline_value: 400,
1018
+ severity: 'low',
1019
+ });
1020
+ recordPerformanceRegressionModule(mockConfig, {
1021
+ metric: 'cpu_usage',
1022
+ current_value: 90,
1023
+ baseline_value: 70,
1024
+ severity: 'high',
1025
+ });
1026
+ expect(mockCounterAddFn).toHaveBeenNthCalledWith(1, 1, {
1027
+ 'session.id': 'test-session-id',
1028
+ 'installation.id': 'test-installation-id',
1029
+ 'user.email': 'test@example.com',
1030
+ metric: 'api_latency',
1031
+ severity: 'low',
1032
+ current_value: 500,
1033
+ baseline_value: 400,
1034
+ });
1035
+ expect(mockCounterAddFn).toHaveBeenNthCalledWith(2, 1, {
1036
+ 'session.id': 'test-session-id',
1037
+ 'installation.id': 'test-installation-id',
1038
+ 'user.email': 'test@example.com',
1039
+ metric: 'cpu_usage',
1040
+ severity: 'high',
1041
+ current_value: 90,
1042
+ baseline_value: 70,
1043
+ });
1044
+ });
1045
+ });
1046
+ describe('recordBaselineComparison', () => {
1047
+ it('should record baseline comparison with percentage change', () => {
1048
+ initializeMetricsModule(mockConfig);
1049
+ mockHistogramRecordFn.mockClear();
1050
+ recordBaselineComparisonModule(mockConfig, {
1051
+ metric: 'memory_usage',
1052
+ current_value: 120,
1053
+ baseline_value: 100,
1054
+ category: 'performance_tracking',
1055
+ });
1056
+ // 20% increase: (120 - 100) / 100 * 100 = 20%
1057
+ expect(mockHistogramRecordFn).toHaveBeenCalledWith(20, {
1058
+ 'session.id': 'test-session-id',
1059
+ 'installation.id': 'test-installation-id',
1060
+ 'user.email': 'test@example.com',
1061
+ metric: 'memory_usage',
1062
+ category: 'performance_tracking',
1063
+ current_value: 120,
1064
+ baseline_value: 100,
1065
+ });
1066
+ });
1067
+ it('should handle negative percentage change (improvement)', () => {
1068
+ initializeMetricsModule(mockConfig);
1069
+ mockHistogramRecordFn.mockClear();
1070
+ recordBaselineComparisonModule(mockConfig, {
1071
+ metric: 'startup_time',
1072
+ current_value: 800,
1073
+ baseline_value: 1000,
1074
+ category: 'optimization',
1075
+ });
1076
+ // 20% decrease: (800 - 1000) / 1000 * 100 = -20%
1077
+ expect(mockHistogramRecordFn).toHaveBeenCalledWith(-20, {
1078
+ 'session.id': 'test-session-id',
1079
+ 'installation.id': 'test-installation-id',
1080
+ 'user.email': 'test@example.com',
1081
+ metric: 'startup_time',
1082
+ category: 'optimization',
1083
+ current_value: 800,
1084
+ baseline_value: 1000,
1085
+ });
1086
+ });
1087
+ it('should skip recording when baseline is zero', async () => {
1088
+ // Access the actual mocked module
1089
+ const mockedModule = (await vi.importMock('@opentelemetry/api'));
1090
+ const diagSpy = vi.spyOn(mockedModule.diag, 'warn');
1091
+ initializeMetricsModule(mockConfig);
1092
+ mockHistogramRecordFn.mockClear();
1093
+ recordBaselineComparisonModule(mockConfig, {
1094
+ metric: 'new_metric',
1095
+ current_value: 50,
1096
+ baseline_value: 0,
1097
+ category: 'testing',
1098
+ });
1099
+ expect(diagSpy).toHaveBeenCalledWith('Baseline value is zero, skipping comparison.');
1100
+ expect(mockHistogramRecordFn).not.toHaveBeenCalled();
238
1101
  });
239
1102
  });
240
1103
  });