@didim365/agent-cli-core 0.1.1 → 0.1.2

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 (1076) hide show
  1. package/package.json +6 -2
  2. package/dist/docs/00_project/ai_adapter/01-overview.md +0 -172
  3. package/dist/docs/00_project/ai_adapter/02-architecture.md +0 -448
  4. package/dist/docs/00_project/ai_adapter/03-technical-design.md +0 -1470
  5. package/dist/docs/00_project/ai_adapter/04-integration-design.md +0 -1934
  6. package/dist/docs/00_project/ai_adapter/05-implementation-plan.md +0 -336
  7. package/dist/docs/00_project/ai_adapter/06-didiaistudio-plan.md +0 -559
  8. package/dist/docs/00_project/ai_adapter/README.md +0 -145
  9. package/dist/docs/00_project/ai_adapter/agent_service_openapi.json +0 -1
  10. package/dist/docs/00_project/ai_adapter/didimStudi-AISTUDIO /341/204/213/341/205/254/341/204/207/341/205/256 /341/204/211/341/205/245/341/204/207/341/205/265/341/204/211/341/205/263 /341/204/221/341/205/263/341/206/257/341/204/205/341/205/251/341/204/213/341/205/256 /341/204/213/341/205/247/341/206/253/341/204/200/341/205/247/341/206/257 /341/204/207/341/205/241/341/206/274/341/204/211/341/205/265/341/206/250-100226-093925.pdf +0 -0
  11. package/dist/docs/00_project/ai_adapter/event-mapping-matrix.md +0 -148
  12. package/dist/docs/00_project/ai_adapter/migration-plan.md +0 -205
  13. package/dist/docs/00_project/ai_adapter/template/00_vibecoding_workflow.md +0 -627
  14. package/dist/docs/00_project/ai_adapter/template/01_todolist_performance_template.md +0 -436
  15. package/dist/docs/00_project/ai_adapter/template/02_code_review_template.md +0 -248
  16. package/dist/docs/00_project/ai_adapter/template/03_work_result_report_template.md +0 -133
  17. package/dist/docs/00_project/ai_adapter/template/100_Python_Performance_Guide.md +0 -472
  18. package/dist/docs/00_project/ai_adapter/template/99_TDD_plan.md +0 -123
  19. package/dist/docs/00_project/ai_adapter/todolist/00_master_implementation_plan.md +0 -433
  20. package/dist/docs/00_project/ai_adapter/todolist/phase1_foundation_todolist.md +0 -726
  21. package/dist/docs/00_project/ai_adapter/todolist/phase2_core_refactoring_todolist.md +0 -974
  22. package/dist/docs/00_project/ai_adapter/todolist/phase3_handoff.md +0 -203
  23. package/dist/docs/00_project/ai_adapter/todolist/phase3_provider_extension_todolist.md +0 -1382
  24. package/dist/docs/00_project/ai_adapter/utility-migration.md +0 -237
  25. package/dist/docs/00_project/ai_adapter/working_history/.gitkeep +0 -0
  26. package/dist/docs/00_project/ai_adapter/working_history/Phase1_M1.0_/354/275/224/353/223/234/354/235/270/353/262/244/355/206/240/353/246/254_20260201.md +0 -197
  27. package/dist/docs/00_project/ai_adapter/working_history/Phase1_M1.1_/355/203/200/354/236/205/354/204/244/352/263/204_20260201.md +0 -185
  28. package/dist/docs/00_project/ai_adapter/working_history/Phase1_M1.2_Adapter/354/235/270/355/224/204/353/235/274_20260203.md +0 -378
  29. package/dist/docs/00_project/ai_adapter/working_history/Phase1_M1.3_Provider/354/204/240/355/203/235_20260206.md +0 -269
  30. package/dist/docs/00_project/ai_adapter/working_history/Phase1_M1.4_/354/234/240/355/213/270/353/246/254/355/213/260/353/247/210/354/235/264/352/267/270/353/240/210/354/235/264/354/205/230_20260206.md +0 -86
  31. package/dist/docs/00_project/ai_adapter/working_history/Phase2_ETC_/354/227/260/352/270/260/354/236/221/354/227/205/354/240/225/353/246/254_20260208.md +0 -157
  32. package/dist/docs/00_project/ai_adapter/working_history/Phase2_M2.0_/353/224/224/353/240/211/355/206/240/353/246/254/354/236/254/352/265/254/354/204/261_20260207.md +0 -107
  33. package/dist/docs/00_project/ai_adapter/working_history/Phase2_M2.1_ContentGenerator/354/235/270/355/204/260/355/216/230/354/235/264/354/212/244/354/236/254/354/240/225/354/235/230_20260207.md +0 -630
  34. package/dist/docs/00_project/ai_adapter/working_history/Phase2_M2.2_EventMapper/352/265/254/355/230/204_20260207.md +0 -372
  35. package/dist/docs/00_project/ai_adapter/working_history/Phase2_M2.3_GeminiAdapter/352/265/254/355/230/204_20260208.md +0 -205
  36. package/dist/docs/00_project/ai_adapter/working_history/Phase2_M2.4_ModelConfigService/355/230/270/355/231/230/353/240/210/354/235/264/354/226/264_20260208.md +0 -275
  37. package/dist/docs/00_project/ai_adapter/working_history/Phase2_M2.5_/354/234/240/355/213/270/353/246/254/355/213/260/353/240/210/354/235/264/354/226/264/353/246/254/355/214/251/355/206/240/353/247/201_20260208.md +0 -239
  38. package/dist/docs/00_project/ai_adapter/working_history/Phase2_M2.6_/353/235/274/354/232/260/355/214/205/353/240/210/354/235/264/354/226/264/355/203/200/354/236/205/353/217/205/353/246/275/355/231/224_20260208.md +0 -228
  39. package/dist/docs/00_project/ai_adapter/working_history/Phase3_ETC_/352/270/260/353/263/270/354/273/250/355/205/215/354/212/244/355/212/270/355/214/214/354/235/274/353/252/205AGENTS/354/240/204/355/231/230_20260211.md +0 -470
  40. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.0.1_Gemini/354/240/204/354/232/251/355/214/214/354/235/274/353/254/274/353/246/254/354/240/201/354/235/264/353/217/231_20260209.md +0 -271
  41. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.0.2_messageInspectors/353/247/210/354/235/264/352/267/270/353/240/210/354/235/264/354/205/230_20260209.md +0 -330
  42. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.0.3_/355/205/224/353/240/210/353/251/224/355/212/270/353/246/254Agent/353/217/205/353/246/275/355/231/224_20260209.md +0 -251
  43. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.0.4_/353/263/200/355/231/230/353/270/214/353/246/277/354/247/200/354/240/225/353/246/254_20260209.md +0 -136
  44. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.0.5_/353/237/260/355/203/200/354/236/204/354/213/244/355/226/211/352/262/275/353/241/234/354/227/260/352/262/260_20260209.md +0 -232
  45. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.1.0_Claude/354/202/254/354/240/204/354/244/200/353/271/204_20260209.md +0 -191
  46. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.1.1_ClaudeAdapter/352/265/254/355/230/204_20260209.md +0 -225
  47. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.1.2_ClaudeConverter/352/263/240/353/217/204/355/231/224_20260209.md +0 -171
  48. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.1.3_ClaudeStreamError/352/263/240/353/217/204/355/231/224_20260209.md +0 -198
  49. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.1.4_ClaudeErrorMapping_20260209.md +0 -98
  50. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.2.A_OpenAIAdapterCore_20260210.md +0 -264
  51. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.2.B_OpenAIStreamConverter_20260210.md +0 -204
  52. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.3.2_/353/252/250/353/215/270/355/205/234/355/224/214/353/246/277/355/233/205/353/263/264/354/231/204_20260211.md +0 -106
  53. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.3_OpenAICompatibleAdapter_20260211.md +0 -251
  54. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.4.2_E2E/355/205/214/354/212/244/355/212/270/354/213/234/353/202/230/353/246/254/354/230/244_20260210.md +0 -264
  55. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.4.3_/354/204/261/353/212/245/355/232/214/352/267/200/355/205/214/354/212/244/355/212/270_20260211.md +0 -176
  56. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.4.5_/354/225/210/354/240/225/355/231/224/354/236/221/354/227/205_20260211.md +0 -204
  57. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.4.A_CLI/355/206/265/355/225/251_3Provider/355/206/265/355/225/251/355/205/214/354/212/244/355/212/270_20260210.md +0 -316
  58. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.4.A_UI/354/203/201/355/203/234/353/260/224/354/210/230/354/240/225_20260210.md +0 -262
  59. package/dist/docs/00_project/ai_adapter/working_history/phase2_tradeoff_EventType/354/240/204/355/231/230_20260208.md +0 -286
  60. package/dist/docs/00_project/white_labeling/template/00_vibecoding_workflow.md +0 -627
  61. package/dist/docs/00_project/white_labeling/template/01_todolist_performance_template.md +0 -400
  62. package/dist/docs/00_project/white_labeling/template/02_code_review_template.md +0 -248
  63. package/dist/docs/00_project/white_labeling/template/03_work_result_report_template.md +0 -133
  64. package/dist/docs/00_project/white_labeling/template/100_Python_Performance_Guide.md +0 -472
  65. package/dist/docs/00_project/white_labeling/template/99_TDD_plan.md +0 -123
  66. package/dist/docs/00_project/white_labeling/todolist/Phase_CLI/355/214/250/355/202/244/354/247/200/353/252/205/353/263/200/352/262/275_todolist.md +0 -431
  67. package/dist/docs/00_project/white_labeling/working_history/Phase_CLI/355/214/250/355/202/244/354/247/200/353/252/205/353/263/200/352/262/275_20260214.md +0 -238
  68. package/dist/docs/00_project/white_labeling//354/225/261/352/265/254/354/241/260.md +0 -310
  69. package/dist/docs/CONTRIBUTING.md +0 -554
  70. package/dist/docs/ai_adapter/01-overview.md +0 -155
  71. package/dist/docs/ai_adapter/02-architecture.md +0 -452
  72. package/dist/docs/ai_adapter/03-technical-design.md +0 -1470
  73. package/dist/docs/ai_adapter/04-integration-design.md +0 -1904
  74. package/dist/docs/ai_adapter/05-implementation-plan.md +0 -312
  75. package/dist/docs/ai_adapter/06-didiaistudio-plan.md +0 -559
  76. package/dist/docs/ai_adapter/README.md +0 -118
  77. package/dist/docs/ai_adapter/agent_service_openapi.json +0 -1
  78. package/dist/docs/ai_adapter/didimStudi-AISTUDIO /341/204/213/341/205/254/341/204/207/341/205/256 /341/204/211/341/205/245/341/204/207/341/205/265/341/204/211/341/205/263 /341/204/221/341/205/263/341/206/257/341/204/205/341/205/251/341/204/213/341/205/256 /341/204/213/341/205/247/341/206/253/341/204/200/341/205/247/341/206/257 /341/204/207/341/205/241/341/206/274/341/204/211/341/205/265/341/206/250-100226-093925.pdf +0 -0
  79. package/dist/docs/ai_adapter/event-mapping-matrix.md +0 -140
  80. package/dist/docs/ai_adapter/migration-plan.md +0 -205
  81. package/dist/docs/ai_adapter/template/00_vibecoding_workflow.md +0 -636
  82. package/dist/docs/ai_adapter/template/01_todolist_performance_template.md +0 -372
  83. package/dist/docs/ai_adapter/template/02_code_review_template.md +0 -220
  84. package/dist/docs/ai_adapter/template/03_work_result_report_template.md +0 -120
  85. package/dist/docs/ai_adapter/template/100_Python_Performance_Guide.md +0 -453
  86. package/dist/docs/ai_adapter/template/99_TDD_plan.md +0 -111
  87. package/dist/docs/ai_adapter/todolist/00_master_implementation_plan.md +0 -433
  88. package/dist/docs/ai_adapter/todolist/phase1_foundation_todolist.md +0 -726
  89. package/dist/docs/ai_adapter/todolist/phase2_core_refactoring_todolist.md +0 -974
  90. package/dist/docs/ai_adapter/todolist/phase3_handoff.md +0 -203
  91. package/dist/docs/ai_adapter/todolist/phase3_provider_extension_todolist.md +0 -1382
  92. package/dist/docs/ai_adapter/utility-migration.md +0 -237
  93. package/dist/docs/ai_adapter/working_history/.gitkeep +0 -0
  94. package/dist/docs/ai_adapter/working_history/Phase1_M1.0_/354/275/224/353/223/234/354/235/270/353/262/244/355/206/240/353/246/254_20260201.md +0 -185
  95. package/dist/docs/ai_adapter/working_history/Phase1_M1.1_/355/203/200/354/236/205/354/204/244/352/263/204_20260201.md +0 -185
  96. package/dist/docs/ai_adapter/working_history/Phase1_M1.2_Adapter/354/235/270/355/224/204/353/235/274_20260203.md +0 -378
  97. package/dist/docs/ai_adapter/working_history/Phase1_M1.3_Provider/354/204/240/355/203/235_20260206.md +0 -269
  98. package/dist/docs/ai_adapter/working_history/Phase1_M1.4_/354/234/240/355/213/270/353/246/254/355/213/260/353/247/210/354/235/264/352/267/270/353/240/210/354/235/264/354/205/230_20260206.md +0 -86
  99. package/dist/docs/ai_adapter/working_history/Phase2_ETC_/354/227/260/352/270/260/354/236/221/354/227/205/354/240/225/353/246/254_20260208.md +0 -157
  100. package/dist/docs/ai_adapter/working_history/Phase2_M2.0_/353/224/224/353/240/211/355/206/240/353/246/254/354/236/254/352/265/254/354/204/261_20260207.md +0 -107
  101. package/dist/docs/ai_adapter/working_history/Phase2_M2.1_ContentGenerator/354/235/270/355/204/260/355/216/230/354/235/264/354/212/244/354/236/254/354/240/225/354/235/230_20260207.md +0 -630
  102. package/dist/docs/ai_adapter/working_history/Phase2_M2.2_EventMapper/352/265/254/355/230/204_20260207.md +0 -372
  103. package/dist/docs/ai_adapter/working_history/Phase2_M2.3_GeminiAdapter/352/265/254/355/230/204_20260208.md +0 -205
  104. package/dist/docs/ai_adapter/working_history/Phase2_M2.4_ModelConfigService/355/230/270/355/231/230/353/240/210/354/235/264/354/226/264_20260208.md +0 -275
  105. package/dist/docs/ai_adapter/working_history/Phase2_M2.5_/354/234/240/355/213/270/353/246/254/355/213/260/353/240/210/354/235/264/354/226/264/353/246/254/355/214/251/355/206/240/353/247/201_20260208.md +0 -239
  106. package/dist/docs/ai_adapter/working_history/Phase2_M2.6_/353/235/274/354/232/260/355/214/205/353/240/210/354/235/264/354/226/264/355/203/200/354/236/205/353/217/205/353/246/275/355/231/224_20260208.md +0 -228
  107. package/dist/docs/ai_adapter/working_history/Phase3_ETC_/352/270/260/353/263/270/354/273/250/355/205/215/354/212/244/355/212/270/355/214/214/354/235/274/353/252/205AGENTS/354/240/204/355/231/230_20260211.md +0 -367
  108. package/dist/docs/ai_adapter/working_history/Phase3_M3.0.1_Gemini/354/240/204/354/232/251/355/214/214/354/235/274/353/254/274/353/246/254/354/240/201/354/235/264/353/217/231_20260209.md +0 -271
  109. package/dist/docs/ai_adapter/working_history/Phase3_M3.0.2_messageInspectors/353/247/210/354/235/264/352/267/270/353/240/210/354/235/264/354/205/230_20260209.md +0 -330
  110. package/dist/docs/ai_adapter/working_history/Phase3_M3.0.3_/355/205/224/353/240/210/353/251/224/355/212/270/353/246/254Agent/353/217/205/353/246/275/355/231/224_20260209.md +0 -251
  111. package/dist/docs/ai_adapter/working_history/Phase3_M3.0.4_/353/263/200/355/231/230/353/270/214/353/246/277/354/247/200/354/240/225/353/246/254_20260209.md +0 -136
  112. package/dist/docs/ai_adapter/working_history/Phase3_M3.0.5_/353/237/260/355/203/200/354/236/204/354/213/244/355/226/211/352/262/275/353/241/234/354/227/260/352/262/260_20260209.md +0 -232
  113. package/dist/docs/ai_adapter/working_history/Phase3_M3.1.0_Claude/354/202/254/354/240/204/354/244/200/353/271/204_20260209.md +0 -191
  114. package/dist/docs/ai_adapter/working_history/Phase3_M3.1.1_ClaudeAdapter/352/265/254/355/230/204_20260209.md +0 -225
  115. package/dist/docs/ai_adapter/working_history/Phase3_M3.1.2_ClaudeConverter/352/263/240/353/217/204/355/231/224_20260209.md +0 -171
  116. package/dist/docs/ai_adapter/working_history/Phase3_M3.1.3_ClaudeStreamError/352/263/240/353/217/204/355/231/224_20260209.md +0 -198
  117. package/dist/docs/ai_adapter/working_history/Phase3_M3.1.4_ClaudeErrorMapping_20260209.md +0 -98
  118. package/dist/docs/ai_adapter/working_history/Phase3_M3.2.A_OpenAIAdapterCore_20260210.md +0 -264
  119. package/dist/docs/ai_adapter/working_history/Phase3_M3.2.B_OpenAIStreamConverter_20260210.md +0 -204
  120. package/dist/docs/ai_adapter/working_history/Phase3_M3.3.2_/353/252/250/353/215/270/355/205/234/355/224/214/353/246/277/355/233/205/353/263/264/354/231/204_20260211.md +0 -106
  121. package/dist/docs/ai_adapter/working_history/Phase3_M3.3_OpenAICompatibleAdapter_20260211.md +0 -251
  122. package/dist/docs/ai_adapter/working_history/Phase3_M3.4.2_E2E/355/205/214/354/212/244/355/212/270/354/213/234/353/202/230/353/246/254/354/230/244_20260210.md +0 -264
  123. package/dist/docs/ai_adapter/working_history/Phase3_M3.4.3_/354/204/261/353/212/245/355/232/214/352/267/200/355/205/214/354/212/244/355/212/270_20260211.md +0 -176
  124. package/dist/docs/ai_adapter/working_history/Phase3_M3.4.5_/354/225/210/354/240/225/355/231/224/354/236/221/354/227/205_20260211.md +0 -204
  125. package/dist/docs/ai_adapter/working_history/Phase3_M3.4.A_CLI/355/206/265/355/225/251_3Provider/355/206/265/355/225/251/355/205/214/354/212/244/355/212/270_20260210.md +0 -316
  126. package/dist/docs/ai_adapter/working_history/Phase3_M3.4.A_UI/354/203/201/355/203/234/353/260/224/354/210/230/354/240/225_20260210.md +0 -262
  127. package/dist/docs/ai_adapter/working_history/phase2_tradeoff_EventType/354/240/204/355/231/230_20260208.md +0 -286
  128. package/dist/docs/api/index.md +0 -5
  129. package/dist/docs/api/providers.md +0 -56
  130. package/dist/docs/architecture.md +0 -80
  131. package/dist/docs/assets/connected_devtools.png +0 -0
  132. package/dist/docs/assets/gemini-screenshot.png +0 -0
  133. package/dist/docs/assets/monitoring-dashboard-logs.png +0 -0
  134. package/dist/docs/assets/monitoring-dashboard-metrics.png +0 -0
  135. package/dist/docs/assets/monitoring-dashboard-overview.png +0 -0
  136. package/dist/docs/assets/release_patch.png +0 -0
  137. package/dist/docs/assets/theme-ansi-light.png +0 -0
  138. package/dist/docs/assets/theme-ansi.png +0 -0
  139. package/dist/docs/assets/theme-atom-one.png +0 -0
  140. package/dist/docs/assets/theme-ayu-light.png +0 -0
  141. package/dist/docs/assets/theme-ayu.png +0 -0
  142. package/dist/docs/assets/theme-custom.png +0 -0
  143. package/dist/docs/assets/theme-default-light.png +0 -0
  144. package/dist/docs/assets/theme-default.png +0 -0
  145. package/dist/docs/assets/theme-dracula.png +0 -0
  146. package/dist/docs/assets/theme-github-light.png +0 -0
  147. package/dist/docs/assets/theme-github.png +0 -0
  148. package/dist/docs/assets/theme-google-light.png +0 -0
  149. package/dist/docs/assets/theme-xcode-light.png +0 -0
  150. package/dist/docs/change_model/model_command_multi_provider_plan.md +0 -221
  151. package/dist/docs/change_model/model_command_multi_provider_todolist.md +0 -206
  152. package/dist/docs/changelogs/index.md +0 -726
  153. package/dist/docs/changelogs/latest.md +0 -370
  154. package/dist/docs/changelogs/preview.md +0 -332
  155. package/dist/docs/cli/authentication.md +0 -3
  156. package/dist/docs/cli/checkpointing.md +0 -94
  157. package/dist/docs/cli/commands.md +0 -375
  158. package/dist/docs/cli/custom-commands.md +0 -315
  159. package/dist/docs/cli/enterprise.md +0 -565
  160. package/dist/docs/cli/gemini-ignore.md +0 -71
  161. package/dist/docs/cli/gemini-md.md +0 -108
  162. package/dist/docs/cli/generation-settings.md +0 -210
  163. package/dist/docs/cli/headless.md +0 -388
  164. package/dist/docs/cli/index.md +0 -65
  165. package/dist/docs/cli/keyboard-shortcuts.md +0 -129
  166. package/dist/docs/cli/model-routing.md +0 -42
  167. package/dist/docs/cli/model.md +0 -62
  168. package/dist/docs/cli/sandbox.md +0 -171
  169. package/dist/docs/cli/session-management.md +0 -158
  170. package/dist/docs/cli/settings.md +0 -130
  171. package/dist/docs/cli/skills.md +0 -188
  172. package/dist/docs/cli/system-prompt.md +0 -125
  173. package/dist/docs/cli/telemetry.md +0 -826
  174. package/dist/docs/cli/themes.md +0 -235
  175. package/dist/docs/cli/token-caching.md +0 -20
  176. package/dist/docs/cli/trusted-folders.md +0 -95
  177. package/dist/docs/cli/tutorials/skills-getting-started.md +0 -124
  178. package/dist/docs/cli/tutorials.md +0 -87
  179. package/dist/docs/cli/uninstall.md +0 -65
  180. package/dist/docs/configuration.md +0 -108
  181. package/dist/docs/core/index.md +0 -105
  182. package/dist/docs/core/long-term-memory-design.md +0 -254
  183. package/dist/docs/core/long-term-memory-proposal.md +0 -112
  184. package/dist/docs/core/memport.md +0 -246
  185. package/dist/docs/core/policy-engine.md +0 -300
  186. package/dist/docs/core/tools-api.md +0 -131
  187. package/dist/docs/examples/proxy-script.md +0 -83
  188. package/dist/docs/extensions/best-practices.md +0 -139
  189. package/dist/docs/extensions/index.md +0 -44
  190. package/dist/docs/extensions/reference.md +0 -312
  191. package/dist/docs/extensions/releasing.md +0 -183
  192. package/dist/docs/extensions/writing-extensions.md +0 -283
  193. package/dist/docs/faq.md +0 -154
  194. package/dist/docs/get-started/authentication.md +0 -321
  195. package/dist/docs/get-started/configuration-v1.md +0 -888
  196. package/dist/docs/get-started/configuration.md +0 -1567
  197. package/dist/docs/get-started/examples.md +0 -219
  198. package/dist/docs/get-started/gemini-3.md +0 -101
  199. package/dist/docs/get-started/index.md +0 -71
  200. package/dist/docs/get-started/installation.md +0 -141
  201. package/dist/docs/hooks/best-practices.md +0 -677
  202. package/dist/docs/hooks/index.md +0 -178
  203. package/dist/docs/hooks/reference.md +0 -322
  204. package/dist/docs/hooks/writing-hooks.md +0 -450
  205. package/dist/docs/ide-integration/ide-companion-spec.md +0 -267
  206. package/dist/docs/ide-integration/index.md +0 -202
  207. package/dist/docs/index.md +0 -153
  208. package/dist/docs/integration-tests.md +0 -211
  209. package/dist/docs/issue-and-pr-automation.md +0 -134
  210. package/dist/docs/local-development.md +0 -128
  211. package/dist/docs/mermaid/context.mmd +0 -103
  212. package/dist/docs/mermaid/render-path.mmd +0 -64
  213. package/dist/docs/migration.md +0 -78
  214. package/dist/docs/npm.md +0 -62
  215. package/dist/docs/providers.md +0 -136
  216. package/dist/docs/quota-and-pricing.md +0 -158
  217. package/dist/docs/release-confidence.md +0 -164
  218. package/dist/docs/releases.md +0 -539
  219. package/dist/docs/sidebar.json +0 -140
  220. package/dist/docs/tools/file-system.md +0 -217
  221. package/dist/docs/tools/index.md +0 -98
  222. package/dist/docs/tools/mcp-server.md +0 -1068
  223. package/dist/docs/tools/memory.md +0 -54
  224. package/dist/docs/tools/shell.md +0 -260
  225. package/dist/docs/tools/todos.md +0 -57
  226. package/dist/docs/tools/web-fetch.md +0 -59
  227. package/dist/docs/tools/web-search.md +0 -42
  228. package/dist/docs/tos-privacy.md +0 -96
  229. package/dist/docs/troubleshooting.md +0 -173
  230. package/dist/src/agents/a2a-client-manager.test.d.ts +0 -6
  231. package/dist/src/agents/a2a-client-manager.test.js +0 -220
  232. package/dist/src/agents/a2a-client-manager.test.js.map +0 -1
  233. package/dist/src/agents/a2aUtils.test.d.ts +0 -6
  234. package/dist/src/agents/a2aUtils.test.js +0 -147
  235. package/dist/src/agents/a2aUtils.test.js.map +0 -1
  236. package/dist/src/agents/acknowledgedAgents.test.d.ts +0 -6
  237. package/dist/src/agents/acknowledgedAgents.test.js +0 -70
  238. package/dist/src/agents/acknowledgedAgents.test.js.map +0 -1
  239. package/dist/src/agents/agent-scheduler.test.d.ts +0 -6
  240. package/dist/src/agents/agent-scheduler.test.js +0 -56
  241. package/dist/src/agents/agent-scheduler.test.js.map +0 -1
  242. package/dist/src/agents/agentLoader.test.d.ts +0 -6
  243. package/dist/src/agents/agentLoader.test.js +0 -304
  244. package/dist/src/agents/agentLoader.test.js.map +0 -1
  245. package/dist/src/agents/cli-help-agent.test.d.ts +0 -6
  246. package/dist/src/agents/cli-help-agent.test.js +0 -67
  247. package/dist/src/agents/cli-help-agent.test.js.map +0 -1
  248. package/dist/src/agents/codebase-investigator.test.d.ts +0 -6
  249. package/dist/src/agents/codebase-investigator.test.js +0 -42
  250. package/dist/src/agents/codebase-investigator.test.js.map +0 -1
  251. package/dist/src/agents/generalist-agent.test.d.ts +0 -6
  252. package/dist/src/agents/generalist-agent.test.js +0 -31
  253. package/dist/src/agents/generalist-agent.test.js.map +0 -1
  254. package/dist/src/agents/local-executor.test.d.ts +0 -6
  255. package/dist/src/agents/local-executor.test.js +0 -1577
  256. package/dist/src/agents/local-executor.test.js.map +0 -1
  257. package/dist/src/agents/local-invocation.test.d.ts +0 -6
  258. package/dist/src/agents/local-invocation.test.js +0 -228
  259. package/dist/src/agents/local-invocation.test.js.map +0 -1
  260. package/dist/src/agents/registry.test.d.ts +0 -6
  261. package/dist/src/agents/registry.test.js +0 -773
  262. package/dist/src/agents/registry.test.js.map +0 -1
  263. package/dist/src/agents/registry_acknowledgement.test.d.ts +0 -6
  264. package/dist/src/agents/registry_acknowledgement.test.js +0 -130
  265. package/dist/src/agents/registry_acknowledgement.test.js.map +0 -1
  266. package/dist/src/agents/remote-invocation.test.d.ts +0 -6
  267. package/dist/src/agents/remote-invocation.test.js +0 -213
  268. package/dist/src/agents/remote-invocation.test.js.map +0 -1
  269. package/dist/src/agents/subagent-tool-wrapper.test.d.ts +0 -6
  270. package/dist/src/agents/subagent-tool-wrapper.test.js +0 -109
  271. package/dist/src/agents/subagent-tool-wrapper.test.js.map +0 -1
  272. package/dist/src/agents/utils.test.d.ts +0 -6
  273. package/dist/src/agents/utils.test.js +0 -87
  274. package/dist/src/agents/utils.test.js.map +0 -1
  275. package/dist/src/availability/fallbackIntegration.test.d.ts +0 -6
  276. package/dist/src/availability/fallbackIntegration.test.js +0 -58
  277. package/dist/src/availability/fallbackIntegration.test.js.map +0 -1
  278. package/dist/src/availability/modelAvailabilityService.test.d.ts +0 -6
  279. package/dist/src/availability/modelAvailabilityService.test.js +0 -140
  280. package/dist/src/availability/modelAvailabilityService.test.js.map +0 -1
  281. package/dist/src/availability/policyCatalog.test.d.ts +0 -6
  282. package/dist/src/availability/policyCatalog.test.js +0 -70
  283. package/dist/src/availability/policyCatalog.test.js.map +0 -1
  284. package/dist/src/availability/policyHelpers.test.d.ts +0 -6
  285. package/dist/src/availability/policyHelpers.test.js +0 -220
  286. package/dist/src/availability/policyHelpers.test.js.map +0 -1
  287. package/dist/src/code_assist/admin/admin_controls.test.d.ts +0 -6
  288. package/dist/src/code_assist/admin/admin_controls.test.js +0 -200
  289. package/dist/src/code_assist/admin/admin_controls.test.js.map +0 -1
  290. package/dist/src/code_assist/codeAssist.test.d.ts +0 -6
  291. package/dist/src/code_assist/codeAssist.test.js +0 -102
  292. package/dist/src/code_assist/codeAssist.test.js.map +0 -1
  293. package/dist/src/code_assist/converter.test.d.ts +0 -6
  294. package/dist/src/code_assist/converter.test.js +0 -391
  295. package/dist/src/code_assist/converter.test.js.map +0 -1
  296. package/dist/src/code_assist/experiments/client_metadata.test.d.ts +0 -6
  297. package/dist/src/code_assist/experiments/client_metadata.test.js +0 -96
  298. package/dist/src/code_assist/experiments/client_metadata.test.js.map +0 -1
  299. package/dist/src/code_assist/experiments/experiments.test.d.ts +0 -6
  300. package/dist/src/code_assist/experiments/experiments.test.js +0 -93
  301. package/dist/src/code_assist/experiments/experiments.test.js.map +0 -1
  302. package/dist/src/code_assist/experiments/experiments_local.test.d.ts +0 -6
  303. package/dist/src/code_assist/experiments/experiments_local.test.js +0 -115
  304. package/dist/src/code_assist/experiments/experiments_local.test.js.map +0 -1
  305. package/dist/src/code_assist/oauth-credential-storage.test.d.ts +0 -6
  306. package/dist/src/code_assist/oauth-credential-storage.test.js +0 -198
  307. package/dist/src/code_assist/oauth-credential-storage.test.js.map +0 -1
  308. package/dist/src/code_assist/oauth2.test.d.ts +0 -6
  309. package/dist/src/code_assist/oauth2.test.js +0 -1065
  310. package/dist/src/code_assist/oauth2.test.js.map +0 -1
  311. package/dist/src/code_assist/server.test.d.ts +0 -6
  312. package/dist/src/code_assist/server.test.js +0 -453
  313. package/dist/src/code_assist/server.test.js.map +0 -1
  314. package/dist/src/code_assist/setup.test.d.ts +0 -6
  315. package/dist/src/code_assist/setup.test.js +0 -517
  316. package/dist/src/code_assist/setup.test.js.map +0 -1
  317. package/dist/src/code_assist/telemetry.test.d.ts +0 -6
  318. package/dist/src/code_assist/telemetry.test.js +0 -301
  319. package/dist/src/code_assist/telemetry.test.js.map +0 -1
  320. package/dist/src/commands/extensions.test.d.ts +0 -6
  321. package/dist/src/commands/extensions.test.js +0 -19
  322. package/dist/src/commands/extensions.test.js.map +0 -1
  323. package/dist/src/commands/init.test.d.ts +0 -6
  324. package/dist/src/commands/init.test.js +0 -25
  325. package/dist/src/commands/init.test.js.map +0 -1
  326. package/dist/src/commands/memory.test.d.ts +0 -6
  327. package/dist/src/commands/memory.test.js +0 -182
  328. package/dist/src/commands/memory.test.js.map +0 -1
  329. package/dist/src/commands/restore.test.d.ts +0 -6
  330. package/dist/src/commands/restore.test.js +0 -137
  331. package/dist/src/commands/restore.test.js.map +0 -1
  332. package/dist/src/config/config.test.d.ts +0 -6
  333. package/dist/src/config/config.test.js +0 -1811
  334. package/dist/src/config/config.test.js.map +0 -1
  335. package/dist/src/config/flashFallback.test.d.ts +0 -6
  336. package/dist/src/config/flashFallback.test.js +0 -63
  337. package/dist/src/config/flashFallback.test.js.map +0 -1
  338. package/dist/src/config/models.test.d.ts +0 -6
  339. package/dist/src/config/models.test.js +0 -146
  340. package/dist/src/config/models.test.js.map +0 -1
  341. package/dist/src/config/storage.test.d.ts +0 -6
  342. package/dist/src/config/storage.test.js +0 -115
  343. package/dist/src/config/storage.test.js.map +0 -1
  344. package/dist/src/confirmation-bus/message-bus.test.d.ts +0 -6
  345. package/dist/src/confirmation-bus/message-bus.test.js +0 -170
  346. package/dist/src/confirmation-bus/message-bus.test.js.map +0 -1
  347. package/dist/src/core/apiKeyCredentialStorage.test.d.ts +0 -6
  348. package/dist/src/core/apiKeyCredentialStorage.test.js +0 -71
  349. package/dist/src/core/apiKeyCredentialStorage.test.js.map +0 -1
  350. package/dist/src/core/baseLlmClient.test.d.ts +0 -6
  351. package/dist/src/core/baseLlmClient.test.js +0 -569
  352. package/dist/src/core/baseLlmClient.test.js.map +0 -1
  353. package/dist/src/core/baseLlmClient_new_types.test.d.ts +0 -1
  354. package/dist/src/core/baseLlmClient_new_types.test.js +0 -387
  355. package/dist/src/core/baseLlmClient_new_types.test.js.map +0 -1
  356. package/dist/src/core/client.test.d.ts +0 -6
  357. package/dist/src/core/client.test.js +0 -2654
  358. package/dist/src/core/client.test.js.map +0 -1
  359. package/dist/src/core/contentGenerator.multiProvider.test.d.ts +0 -6
  360. package/dist/src/core/contentGenerator.multiProvider.test.js +0 -314
  361. package/dist/src/core/contentGenerator.multiProvider.test.js.map +0 -1
  362. package/dist/src/core/contentGenerator.test.d.ts +0 -6
  363. package/dist/src/core/contentGenerator.test.js +0 -299
  364. package/dist/src/core/contentGenerator.test.js.map +0 -1
  365. package/dist/src/core/contentGenerator_new_types.test.d.ts +0 -6
  366. package/dist/src/core/contentGenerator_new_types.test.js +0 -292
  367. package/dist/src/core/contentGenerator_new_types.test.js.map +0 -1
  368. package/dist/src/core/coreToolHookTriggers.test.d.ts +0 -6
  369. package/dist/src/core/coreToolHookTriggers.test.js +0 -159
  370. package/dist/src/core/coreToolHookTriggers.test.js.map +0 -1
  371. package/dist/src/core/coreToolScheduler.test.d.ts +0 -6
  372. package/dist/src/core/coreToolScheduler.test.js +0 -1684
  373. package/dist/src/core/coreToolScheduler.test.js.map +0 -1
  374. package/dist/src/core/fakeContentGenerator.test.d.ts +0 -6
  375. package/dist/src/core/fakeContentGenerator.test.js +0 -127
  376. package/dist/src/core/fakeContentGenerator.test.js.map +0 -1
  377. package/dist/src/core/geminiChat.test.d.ts +0 -6
  378. package/dist/src/core/geminiChat.test.js +0 -1773
  379. package/dist/src/core/geminiChat.test.js.map +0 -1
  380. package/dist/src/core/geminiChat_network_retry.test.d.ts +0 -6
  381. package/dist/src/core/geminiChat_network_retry.test.js +0 -201
  382. package/dist/src/core/geminiChat_network_retry.test.js.map +0 -1
  383. package/dist/src/core/logger.test.d.ts +0 -6
  384. package/dist/src/core/logger.test.js +0 -550
  385. package/dist/src/core/logger.test.js.map +0 -1
  386. package/dist/src/core/loggingContentGenerator.test.d.ts +0 -6
  387. package/dist/src/core/loggingContentGenerator.test.js +0 -221
  388. package/dist/src/core/loggingContentGenerator.test.js.map +0 -1
  389. package/dist/src/core/prompts-substitution.test.d.ts +0 -6
  390. package/dist/src/core/prompts-substitution.test.js +0 -101
  391. package/dist/src/core/prompts-substitution.test.js.map +0 -1
  392. package/dist/src/core/prompts.test.d.ts +0 -6
  393. package/dist/src/core/prompts.test.js +0 -391
  394. package/dist/src/core/prompts.test.js.map +0 -1
  395. package/dist/src/core/recordingContentGenerator.test.d.ts +0 -6
  396. package/dist/src/core/recordingContentGenerator.test.js +0 -101
  397. package/dist/src/core/recordingContentGenerator.test.js.map +0 -1
  398. package/dist/src/core/tokenLimits.test.d.ts +0 -6
  399. package/dist/src/core/tokenLimits.test.js +0 -30
  400. package/dist/src/core/tokenLimits.test.js.map +0 -1
  401. package/dist/src/core/turn.test.d.ts +0 -6
  402. package/dist/src/core/turn.test.js +0 -739
  403. package/dist/src/core/turn.test.js.map +0 -1
  404. package/dist/src/fallback/handler.test.d.ts +0 -6
  405. package/dist/src/fallback/handler.test.js +0 -242
  406. package/dist/src/fallback/handler.test.js.map +0 -1
  407. package/dist/src/hooks/hookAggregator.test.d.ts +0 -6
  408. package/dist/src/hooks/hookAggregator.test.js +0 -387
  409. package/dist/src/hooks/hookAggregator.test.js.map +0 -1
  410. package/dist/src/hooks/hookEventHandler.test.d.ts +0 -6
  411. package/dist/src/hooks/hookEventHandler.test.js +0 -603
  412. package/dist/src/hooks/hookEventHandler.test.js.map +0 -1
  413. package/dist/src/hooks/hookPlanner.test.d.ts +0 -6
  414. package/dist/src/hooks/hookPlanner.test.js +0 -315
  415. package/dist/src/hooks/hookPlanner.test.js.map +0 -1
  416. package/dist/src/hooks/hookRegistry.test.d.ts +0 -6
  417. package/dist/src/hooks/hookRegistry.test.js +0 -529
  418. package/dist/src/hooks/hookRegistry.test.js.map +0 -1
  419. package/dist/src/hooks/hookRunner.test.d.ts +0 -6
  420. package/dist/src/hooks/hookRunner.test.js +0 -606
  421. package/dist/src/hooks/hookRunner.test.js.map +0 -1
  422. package/dist/src/hooks/hookSystem.test.d.ts +0 -6
  423. package/dist/src/hooks/hookSystem.test.js +0 -330
  424. package/dist/src/hooks/hookSystem.test.js.map +0 -1
  425. package/dist/src/hooks/hookSystem_new_types.test.d.ts +0 -6
  426. package/dist/src/hooks/hookSystem_new_types.test.js +0 -243
  427. package/dist/src/hooks/hookSystem_new_types.test.js.map +0 -1
  428. package/dist/src/hooks/hookTranslator.test.d.ts +0 -6
  429. package/dist/src/hooks/hookTranslator.test.js +0 -192
  430. package/dist/src/hooks/hookTranslator.test.js.map +0 -1
  431. package/dist/src/hooks/trustedHooks.test.d.ts +0 -6
  432. package/dist/src/hooks/trustedHooks.test.js +0 -154
  433. package/dist/src/hooks/trustedHooks.test.js.map +0 -1
  434. package/dist/src/hooks/types.test.d.ts +0 -6
  435. package/dist/src/hooks/types.test.js +0 -278
  436. package/dist/src/hooks/types.test.js.map +0 -1
  437. package/dist/src/ide/detect-ide.test.d.ts +0 -6
  438. package/dist/src/ide/detect-ide.test.js +0 -195
  439. package/dist/src/ide/detect-ide.test.js.map +0 -1
  440. package/dist/src/ide/ide-client.test.d.ts +0 -6
  441. package/dist/src/ide/ide-client.test.js +0 -753
  442. package/dist/src/ide/ide-client.test.js.map +0 -1
  443. package/dist/src/ide/ide-installer.test.d.ts +0 -6
  444. package/dist/src/ide/ide-installer.test.js +0 -193
  445. package/dist/src/ide/ide-installer.test.js.map +0 -1
  446. package/dist/src/ide/ideContext.test.d.ts +0 -6
  447. package/dist/src/ide/ideContext.test.js +0 -393
  448. package/dist/src/ide/ideContext.test.js.map +0 -1
  449. package/dist/src/ide/process-utils.test.d.ts +0 -6
  450. package/dist/src/ide/process-utils.test.js +0 -151
  451. package/dist/src/ide/process-utils.test.js.map +0 -1
  452. package/dist/src/index.test.d.ts +0 -6
  453. package/dist/src/index.test.js +0 -53
  454. package/dist/src/index.test.js.map +0 -1
  455. package/dist/src/mcp/google-auth-provider.test.d.ts +0 -6
  456. package/dist/src/mcp/google-auth-provider.test.js +0 -167
  457. package/dist/src/mcp/google-auth-provider.test.js.map +0 -1
  458. package/dist/src/mcp/oauth-provider.test.d.ts +0 -6
  459. package/dist/src/mcp/oauth-provider.test.js +0 -1355
  460. package/dist/src/mcp/oauth-provider.test.js.map +0 -1
  461. package/dist/src/mcp/oauth-token-storage.test.d.ts +0 -6
  462. package/dist/src/mcp/oauth-token-storage.test.js +0 -305
  463. package/dist/src/mcp/oauth-token-storage.test.js.map +0 -1
  464. package/dist/src/mcp/oauth-utils.test.d.ts +0 -6
  465. package/dist/src/mcp/oauth-utils.test.js +0 -289
  466. package/dist/src/mcp/oauth-utils.test.js.map +0 -1
  467. package/dist/src/mcp/sa-impersonation-provider.test.d.ts +0 -6
  468. package/dist/src/mcp/sa-impersonation-provider.test.js +0 -117
  469. package/dist/src/mcp/sa-impersonation-provider.test.js.map +0 -1
  470. package/dist/src/mcp/token-storage/base-token-storage.test.d.ts +0 -6
  471. package/dist/src/mcp/token-storage/base-token-storage.test.js +0 -151
  472. package/dist/src/mcp/token-storage/base-token-storage.test.js.map +0 -1
  473. package/dist/src/mcp/token-storage/file-token-storage.test.d.ts +0 -6
  474. package/dist/src/mcp/token-storage/file-token-storage.test.js +0 -238
  475. package/dist/src/mcp/token-storage/file-token-storage.test.js.map +0 -1
  476. package/dist/src/mcp/token-storage/hybrid-token-storage.test.d.ts +0 -6
  477. package/dist/src/mcp/token-storage/hybrid-token-storage.test.js +0 -193
  478. package/dist/src/mcp/token-storage/hybrid-token-storage.test.js.map +0 -1
  479. package/dist/src/mcp/token-storage/keychain-token-storage.test.d.ts +0 -6
  480. package/dist/src/mcp/token-storage/keychain-token-storage.test.js +0 -305
  481. package/dist/src/mcp/token-storage/keychain-token-storage.test.js.map +0 -1
  482. package/dist/src/output/json-formatter.test.d.ts +0 -6
  483. package/dist/src/output/json-formatter.test.js +0 -294
  484. package/dist/src/output/json-formatter.test.js.map +0 -1
  485. package/dist/src/output/stream-json-formatter.test.d.ts +0 -6
  486. package/dist/src/output/stream-json-formatter.test.js +0 -477
  487. package/dist/src/output/stream-json-formatter.test.js.map +0 -1
  488. package/dist/src/policy/config.test.d.ts +0 -6
  489. package/dist/src/policy/config.test.js +0 -598
  490. package/dist/src/policy/config.test.js.map +0 -1
  491. package/dist/src/policy/persistence.test.d.ts +0 -6
  492. package/dist/src/policy/persistence.test.js +0 -154
  493. package/dist/src/policy/persistence.test.js.map +0 -1
  494. package/dist/src/policy/policy-engine.test.d.ts +0 -6
  495. package/dist/src/policy/policy-engine.test.js +0 -1299
  496. package/dist/src/policy/policy-engine.test.js.map +0 -1
  497. package/dist/src/policy/policy-updater.test.d.ts +0 -6
  498. package/dist/src/policy/policy-updater.test.js +0 -116
  499. package/dist/src/policy/policy-updater.test.js.map +0 -1
  500. package/dist/src/policy/shell-safety.test.d.ts +0 -6
  501. package/dist/src/policy/shell-safety.test.js +0 -438
  502. package/dist/src/policy/shell-safety.test.js.map +0 -1
  503. package/dist/src/policy/toml-loader.test.d.ts +0 -6
  504. package/dist/src/policy/toml-loader.test.js +0 -409
  505. package/dist/src/policy/toml-loader.test.js.map +0 -1
  506. package/dist/src/policy/utils.test.d.ts +0 -6
  507. package/dist/src/policy/utils.test.js +0 -92
  508. package/dist/src/policy/utils.test.js.map +0 -1
  509. package/dist/src/prompts/mcp-prompts.test.d.ts +0 -6
  510. package/dist/src/prompts/mcp-prompts.test.js +0 -39
  511. package/dist/src/prompts/mcp-prompts.test.js.map +0 -1
  512. package/dist/src/prompts/prompt-registry.test.d.ts +0 -6
  513. package/dist/src/prompts/prompt-registry.test.js +0 -96
  514. package/dist/src/prompts/prompt-registry.test.js.map +0 -1
  515. package/dist/src/providers/__tests__/bundleSize.test.d.ts +0 -6
  516. package/dist/src/providers/__tests__/bundleSize.test.js +0 -75
  517. package/dist/src/providers/__tests__/bundleSize.test.js.map +0 -1
  518. package/dist/src/providers/__tests__/errorHandling.integration.test.d.ts +0 -6
  519. package/dist/src/providers/__tests__/errorHandling.integration.test.js +0 -339
  520. package/dist/src/providers/__tests__/errorHandling.integration.test.js.map +0 -1
  521. package/dist/src/providers/__tests__/multiProvider.integration.test.d.ts +0 -6
  522. package/dist/src/providers/__tests__/multiProvider.integration.test.js +0 -419
  523. package/dist/src/providers/__tests__/multiProvider.integration.test.js.map +0 -1
  524. package/dist/src/providers/__tests__/performance.test.d.ts +0 -6
  525. package/dist/src/providers/__tests__/performance.test.js +0 -270
  526. package/dist/src/providers/__tests__/performance.test.js.map +0 -1
  527. package/dist/src/providers/__tests__/providerConfigIntegration.test.d.ts +0 -6
  528. package/dist/src/providers/__tests__/providerConfigIntegration.test.js +0 -245
  529. package/dist/src/providers/__tests__/providerConfigIntegration.test.js.map +0 -1
  530. package/dist/src/providers/baseAdapter.test.d.ts +0 -1
  531. package/dist/src/providers/baseAdapter.test.js +0 -142
  532. package/dist/src/providers/baseAdapter.test.js.map +0 -1
  533. package/dist/src/providers/claude/adapter.test.d.ts +0 -6
  534. package/dist/src/providers/claude/adapter.test.js +0 -628
  535. package/dist/src/providers/claude/adapter.test.js.map +0 -1
  536. package/dist/src/providers/claude/bootstrap.test.d.ts +0 -6
  537. package/dist/src/providers/claude/bootstrap.test.js +0 -74
  538. package/dist/src/providers/claude/bootstrap.test.js.map +0 -1
  539. package/dist/src/providers/claude/converter.test.d.ts +0 -6
  540. package/dist/src/providers/claude/converter.test.js +0 -1002
  541. package/dist/src/providers/claude/converter.test.js.map +0 -1
  542. package/dist/src/providers/claude/exports.test.d.ts +0 -6
  543. package/dist/src/providers/claude/exports.test.js +0 -40
  544. package/dist/src/providers/claude/exports.test.js.map +0 -1
  545. package/dist/src/providers/configAdapter.test.d.ts +0 -1
  546. package/dist/src/providers/configAdapter.test.js +0 -150
  547. package/dist/src/providers/configAdapter.test.js.map +0 -1
  548. package/dist/src/providers/contentResolver.test.d.ts +0 -1
  549. package/dist/src/providers/contentResolver.test.js +0 -89
  550. package/dist/src/providers/contentResolver.test.js.map +0 -1
  551. package/dist/src/providers/factory.test.d.ts +0 -1
  552. package/dist/src/providers/factory.test.js +0 -151
  553. package/dist/src/providers/factory.test.js.map +0 -1
  554. package/dist/src/providers/gemini/adapterBridge.test.d.ts +0 -6
  555. package/dist/src/providers/gemini/adapterBridge.test.js +0 -164
  556. package/dist/src/providers/gemini/adapterBridge.test.js.map +0 -1
  557. package/dist/src/providers/gemini/bootstrap.test.d.ts +0 -6
  558. package/dist/src/providers/gemini/bootstrap.test.js +0 -72
  559. package/dist/src/providers/gemini/bootstrap.test.js.map +0 -1
  560. package/dist/src/providers/gemini/configConverter.test.d.ts +0 -6
  561. package/dist/src/providers/gemini/configConverter.test.js +0 -218
  562. package/dist/src/providers/gemini/configConverter.test.js.map +0 -1
  563. package/dist/src/providers/gemini/errorClassifier.test.d.ts +0 -6
  564. package/dist/src/providers/gemini/errorClassifier.test.js +0 -83
  565. package/dist/src/providers/gemini/errorClassifier.test.js.map +0 -1
  566. package/dist/src/providers/gemini/eventMapper.test.d.ts +0 -6
  567. package/dist/src/providers/gemini/eventMapper.test.js +0 -502
  568. package/dist/src/providers/gemini/eventMapper.test.js.map +0 -1
  569. package/dist/src/providers/gemini/exports.test.d.ts +0 -6
  570. package/dist/src/providers/gemini/exports.test.js +0 -90
  571. package/dist/src/providers/gemini/exports.test.js.map +0 -1
  572. package/dist/src/providers/gemini/featureFlag.test.d.ts +0 -6
  573. package/dist/src/providers/gemini/featureFlag.test.js +0 -139
  574. package/dist/src/providers/gemini/featureFlag.test.js.map +0 -1
  575. package/dist/src/providers/gemini/geminiAdapter.test.d.ts +0 -6
  576. package/dist/src/providers/gemini/geminiAdapter.test.js +0 -279
  577. package/dist/src/providers/gemini/geminiAdapter.test.js.map +0 -1
  578. package/dist/src/providers/gemini/geminiConverter.test.d.ts +0 -6
  579. package/dist/src/providers/gemini/geminiConverter.test.js +0 -474
  580. package/dist/src/providers/gemini/geminiConverter.test.js.map +0 -1
  581. package/dist/src/providers/gemini/geminiParity.test.d.ts +0 -6
  582. package/dist/src/providers/gemini/geminiParity.test.js +0 -754
  583. package/dist/src/providers/gemini/geminiParity.test.js.map +0 -1
  584. package/dist/src/providers/gemini/geminiStream.test.d.ts +0 -6
  585. package/dist/src/providers/gemini/geminiStream.test.js +0 -391
  586. package/dist/src/providers/gemini/geminiStream.test.js.map +0 -1
  587. package/dist/src/providers/gemini/historyBuilder.test.d.ts +0 -6
  588. package/dist/src/providers/gemini/historyBuilder.test.js +0 -207
  589. package/dist/src/providers/gemini/historyBuilder.test.js.map +0 -1
  590. package/dist/src/providers/gemini/requestBuilder.test.d.ts +0 -6
  591. package/dist/src/providers/gemini/requestBuilder.test.js +0 -358
  592. package/dist/src/providers/gemini/requestBuilder.test.js.map +0 -1
  593. package/dist/src/providers/gemini/streamConverter.test.d.ts +0 -6
  594. package/dist/src/providers/gemini/streamConverter.test.js +0 -131
  595. package/dist/src/providers/gemini/streamConverter.test.js.map +0 -1
  596. package/dist/src/providers/modelSpec.test.d.ts +0 -1
  597. package/dist/src/providers/modelSpec.test.js +0 -119
  598. package/dist/src/providers/modelSpec.test.js.map +0 -1
  599. package/dist/src/providers/openai/adapter.test.d.ts +0 -6
  600. package/dist/src/providers/openai/adapter.test.js +0 -274
  601. package/dist/src/providers/openai/adapter.test.js.map +0 -1
  602. package/dist/src/providers/openai/bootstrap.test.d.ts +0 -6
  603. package/dist/src/providers/openai/bootstrap.test.js +0 -76
  604. package/dist/src/providers/openai/bootstrap.test.js.map +0 -1
  605. package/dist/src/providers/openai/converter.test.d.ts +0 -6
  606. package/dist/src/providers/openai/converter.test.js +0 -1133
  607. package/dist/src/providers/openai/converter.test.js.map +0 -1
  608. package/dist/src/providers/openai-compatible/__tests__/compatibility.test.d.ts +0 -6
  609. package/dist/src/providers/openai-compatible/__tests__/compatibility.test.js +0 -356
  610. package/dist/src/providers/openai-compatible/__tests__/compatibility.test.js.map +0 -1
  611. package/dist/src/providers/openai-compatible/adapter.test.d.ts +0 -6
  612. package/dist/src/providers/openai-compatible/adapter.test.js +0 -240
  613. package/dist/src/providers/openai-compatible/adapter.test.js.map +0 -1
  614. package/dist/src/providers/openai-compatible/bootstrap.test.d.ts +0 -6
  615. package/dist/src/providers/openai-compatible/bootstrap.test.js +0 -145
  616. package/dist/src/providers/openai-compatible/bootstrap.test.js.map +0 -1
  617. package/dist/src/providers/openai-compatible/promptBuilder.test.d.ts +0 -6
  618. package/dist/src/providers/openai-compatible/promptBuilder.test.js +0 -154
  619. package/dist/src/providers/openai-compatible/promptBuilder.test.js.map +0 -1
  620. package/dist/src/providers/providerConfig.test.d.ts +0 -1
  621. package/dist/src/providers/providerConfig.test.js +0 -145
  622. package/dist/src/providers/providerConfig.test.js.map +0 -1
  623. package/dist/src/providers/providerConfigIntegration.test.d.ts +0 -6
  624. package/dist/src/providers/providerConfigIntegration.test.js +0 -187
  625. package/dist/src/providers/providerConfigIntegration.test.js.map +0 -1
  626. package/dist/src/providers/providerSelector.test.d.ts +0 -1
  627. package/dist/src/providers/providerSelector.test.js +0 -199
  628. package/dist/src/providers/providerSelector.test.js.map +0 -1
  629. package/dist/src/providers/providerTypes.test.d.ts +0 -1
  630. package/dist/src/providers/providerTypes.test.js +0 -95
  631. package/dist/src/providers/providerTypes.test.js.map +0 -1
  632. package/dist/src/providers/registry.test.d.ts +0 -1
  633. package/dist/src/providers/registry.test.js +0 -207
  634. package/dist/src/providers/registry.test.js.map +0 -1
  635. package/dist/src/providers/streamAssembler.test.d.ts +0 -1
  636. package/dist/src/providers/streamAssembler.test.js +0 -247
  637. package/dist/src/providers/streamAssembler.test.js.map +0 -1
  638. package/dist/src/providers/telemetryBridge.test.d.ts +0 -6
  639. package/dist/src/providers/telemetryBridge.test.js +0 -235
  640. package/dist/src/providers/telemetryBridge.test.js.map +0 -1
  641. package/dist/src/providers/types.test.d.ts +0 -6
  642. package/dist/src/providers/types.test.js +0 -253
  643. package/dist/src/providers/types.test.js.map +0 -1
  644. package/dist/src/resources/resource-registry.test.d.ts +0 -6
  645. package/dist/src/resources/resource-registry.test.js +0 -54
  646. package/dist/src/resources/resource-registry.test.js.map +0 -1
  647. package/dist/src/routing/modelRouterService.test.d.ts +0 -6
  648. package/dist/src/routing/modelRouterService.test.js +0 -106
  649. package/dist/src/routing/modelRouterService.test.js.map +0 -1
  650. package/dist/src/routing/strategies/classifierStrategy.test.d.ts +0 -6
  651. package/dist/src/routing/strategies/classifierStrategy.test.js +0 -249
  652. package/dist/src/routing/strategies/classifierStrategy.test.js.map +0 -1
  653. package/dist/src/routing/strategies/compositeStrategy.test.d.ts +0 -6
  654. package/dist/src/routing/strategies/compositeStrategy.test.js +0 -124
  655. package/dist/src/routing/strategies/compositeStrategy.test.js.map +0 -1
  656. package/dist/src/routing/strategies/defaultStrategy.test.d.ts +0 -6
  657. package/dist/src/routing/strategies/defaultStrategy.test.js +0 -102
  658. package/dist/src/routing/strategies/defaultStrategy.test.js.map +0 -1
  659. package/dist/src/routing/strategies/fallbackStrategy.test.d.ts +0 -6
  660. package/dist/src/routing/strategies/fallbackStrategy.test.js +0 -96
  661. package/dist/src/routing/strategies/fallbackStrategy.test.js.map +0 -1
  662. package/dist/src/routing/strategies/numericalClassifierStrategy.test.d.ts +0 -6
  663. package/dist/src/routing/strategies/numericalClassifierStrategy.test.js +0 -367
  664. package/dist/src/routing/strategies/numericalClassifierStrategy.test.js.map +0 -1
  665. package/dist/src/routing/strategies/overrideStrategy.test.d.ts +0 -6
  666. package/dist/src/routing/strategies/overrideStrategy.test.js +0 -59
  667. package/dist/src/routing/strategies/overrideStrategy.test.js.map +0 -1
  668. package/dist/src/safety/built-in.test.d.ts +0 -6
  669. package/dist/src/safety/built-in.test.js +0 -199
  670. package/dist/src/safety/built-in.test.js.map +0 -1
  671. package/dist/src/safety/checker-runner.test.d.ts +0 -6
  672. package/dist/src/safety/checker-runner.test.js +0 -238
  673. package/dist/src/safety/checker-runner.test.js.map +0 -1
  674. package/dist/src/safety/context-builder.test.d.ts +0 -6
  675. package/dist/src/safety/context-builder.test.js +0 -49
  676. package/dist/src/safety/context-builder.test.js.map +0 -1
  677. package/dist/src/safety/registry.test.d.ts +0 -6
  678. package/dist/src/safety/registry.test.js +0 -31
  679. package/dist/src/safety/registry.test.js.map +0 -1
  680. package/dist/src/scheduler/confirmation.test.d.ts +0 -6
  681. package/dist/src/scheduler/confirmation.test.js +0 -325
  682. package/dist/src/scheduler/confirmation.test.js.map +0 -1
  683. package/dist/src/scheduler/policy.test.d.ts +0 -6
  684. package/dist/src/scheduler/policy.test.js +0 -299
  685. package/dist/src/scheduler/policy.test.js.map +0 -1
  686. package/dist/src/scheduler/scheduler.test.d.ts +0 -6
  687. package/dist/src/scheduler/scheduler.test.js +0 -822
  688. package/dist/src/scheduler/scheduler.test.js.map +0 -1
  689. package/dist/src/scheduler/state-manager.test.d.ts +0 -6
  690. package/dist/src/scheduler/state-manager.test.js +0 -429
  691. package/dist/src/scheduler/state-manager.test.js.map +0 -1
  692. package/dist/src/scheduler/tool-executor.test.d.ts +0 -6
  693. package/dist/src/scheduler/tool-executor.test.js +0 -232
  694. package/dist/src/scheduler/tool-executor.test.js.map +0 -1
  695. package/dist/src/scheduler/tool-modifier.test.d.ts +0 -6
  696. package/dist/src/scheduler/tool-modifier.test.js +0 -159
  697. package/dist/src/scheduler/tool-modifier.test.js.map +0 -1
  698. package/dist/src/services/chatCompressionService.test.d.ts +0 -6
  699. package/dist/src/services/chatCompressionService.test.js +0 -573
  700. package/dist/src/services/chatCompressionService.test.js.map +0 -1
  701. package/dist/src/services/chatRecordingService.test.d.ts +0 -6
  702. package/dist/src/services/chatRecordingService.test.js +0 -486
  703. package/dist/src/services/chatRecordingService.test.js.map +0 -1
  704. package/dist/src/services/contextManager.test.d.ts +0 -6
  705. package/dist/src/services/contextManager.test.js +0 -104
  706. package/dist/src/services/contextManager.test.js.map +0 -1
  707. package/dist/src/services/environmentSanitization.test.d.ts +0 -6
  708. package/dist/src/services/environmentSanitization.test.js +0 -284
  709. package/dist/src/services/environmentSanitization.test.js.map +0 -1
  710. package/dist/src/services/fileDiscoveryService.test.d.ts +0 -6
  711. package/dist/src/services/fileDiscoveryService.test.js +0 -223
  712. package/dist/src/services/fileDiscoveryService.test.js.map +0 -1
  713. package/dist/src/services/fileSystemService.test.d.ts +0 -6
  714. package/dist/src/services/fileSystemService.test.js +0 -41
  715. package/dist/src/services/fileSystemService.test.js.map +0 -1
  716. package/dist/src/services/gitService.test.d.ts +0 -6
  717. package/dist/src/services/gitService.test.js +0 -264
  718. package/dist/src/services/gitService.test.js.map +0 -1
  719. package/dist/src/services/loopDetectionService.test.d.ts +0 -6
  720. package/dist/src/services/loopDetectionService.test.js +0 -881
  721. package/dist/src/services/loopDetectionService.test.js.map +0 -1
  722. package/dist/src/services/modelConfig.golden.test.d.ts +0 -6
  723. package/dist/src/services/modelConfig.golden.test.js +0 -74
  724. package/dist/src/services/modelConfig.golden.test.js.map +0 -1
  725. package/dist/src/services/modelConfig.integration.test.d.ts +0 -6
  726. package/dist/src/services/modelConfig.integration.test.js +0 -247
  727. package/dist/src/services/modelConfig.integration.test.js.map +0 -1
  728. package/dist/src/services/modelConfigBridge.test.d.ts +0 -6
  729. package/dist/src/services/modelConfigBridge.test.js +0 -410
  730. package/dist/src/services/modelConfigBridge.test.js.map +0 -1
  731. package/dist/src/services/modelConfigService.test.d.ts +0 -6
  732. package/dist/src/services/modelConfigService.test.js +0 -868
  733. package/dist/src/services/modelConfigService.test.js.map +0 -1
  734. package/dist/src/services/sessionSummaryService.test.d.ts +0 -6
  735. package/dist/src/services/sessionSummaryService.test.js +0 -785
  736. package/dist/src/services/sessionSummaryService.test.js.map +0 -1
  737. package/dist/src/services/sessionSummaryUtils.test.d.ts +0 -6
  738. package/dist/src/services/sessionSummaryUtils.test.js +0 -160
  739. package/dist/src/services/sessionSummaryUtils.test.js.map +0 -1
  740. package/dist/src/services/shellExecutionService.test.d.ts +0 -6
  741. package/dist/src/services/shellExecutionService.test.js +0 -1080
  742. package/dist/src/services/shellExecutionService.test.js.map +0 -1
  743. package/dist/src/skills/skillLoader.test.d.ts +0 -6
  744. package/dist/src/skills/skillLoader.test.js +0 -185
  745. package/dist/src/skills/skillLoader.test.js.map +0 -1
  746. package/dist/src/skills/skillManager.test.d.ts +0 -6
  747. package/dist/src/skills/skillManager.test.js +0 -297
  748. package/dist/src/skills/skillManager.test.js.map +0 -1
  749. package/dist/src/telemetry/activity-detector.test.d.ts +0 -6
  750. package/dist/src/telemetry/activity-detector.test.js +0 -136
  751. package/dist/src/telemetry/activity-detector.test.js.map +0 -1
  752. package/dist/src/telemetry/activity-monitor.test.d.ts +0 -6
  753. package/dist/src/telemetry/activity-monitor.test.js +0 -251
  754. package/dist/src/telemetry/activity-monitor.test.js.map +0 -1
  755. package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.d.ts +0 -19
  756. package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.js +0 -964
  757. package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.js.map +0 -1
  758. package/dist/src/telemetry/config.test.d.ts +0 -6
  759. package/dist/src/telemetry/config.test.js +0 -149
  760. package/dist/src/telemetry/config.test.js.map +0 -1
  761. package/dist/src/telemetry/gcp-exporters.test.d.ts +0 -6
  762. package/dist/src/telemetry/gcp-exporters.test.js +0 -318
  763. package/dist/src/telemetry/gcp-exporters.test.js.map +0 -1
  764. package/dist/src/telemetry/high-water-mark-tracker.test.d.ts +0 -6
  765. package/dist/src/telemetry/high-water-mark-tracker.test.js +0 -152
  766. package/dist/src/telemetry/high-water-mark-tracker.test.js.map +0 -1
  767. package/dist/src/telemetry/integration.test.circular.d.ts +0 -6
  768. package/dist/src/telemetry/integration.test.circular.js +0 -54
  769. package/dist/src/telemetry/integration.test.circular.js.map +0 -1
  770. package/dist/src/telemetry/loggers.test.circular.d.ts +0 -6
  771. package/dist/src/telemetry/loggers.test.circular.js +0 -107
  772. package/dist/src/telemetry/loggers.test.circular.js.map +0 -1
  773. package/dist/src/telemetry/loggers.test.d.ts +0 -6
  774. package/dist/src/telemetry/loggers.test.js +0 -1618
  775. package/dist/src/telemetry/loggers.test.js.map +0 -1
  776. package/dist/src/telemetry/memory-monitor.test.d.ts +0 -6
  777. package/dist/src/telemetry/memory-monitor.test.js +0 -472
  778. package/dist/src/telemetry/memory-monitor.test.js.map +0 -1
  779. package/dist/src/telemetry/metrics.test.d.ts +0 -6
  780. package/dist/src/telemetry/metrics.test.js +0 -1176
  781. package/dist/src/telemetry/metrics.test.js.map +0 -1
  782. package/dist/src/telemetry/rate-limiter.test.d.ts +0 -6
  783. package/dist/src/telemetry/rate-limiter.test.js +0 -207
  784. package/dist/src/telemetry/rate-limiter.test.js.map +0 -1
  785. package/dist/src/telemetry/sanitize.test.d.ts +0 -6
  786. package/dist/src/telemetry/sanitize.test.js +0 -279
  787. package/dist/src/telemetry/sanitize.test.js.map +0 -1
  788. package/dist/src/telemetry/sdk.test.d.ts +0 -6
  789. package/dist/src/telemetry/sdk.test.js +0 -360
  790. package/dist/src/telemetry/sdk.test.js.map +0 -1
  791. package/dist/src/telemetry/semantic.test.d.ts +0 -6
  792. package/dist/src/telemetry/semantic.test.js +0 -387
  793. package/dist/src/telemetry/semantic.test.js.map +0 -1
  794. package/dist/src/telemetry/semantic.truncation.test.d.ts +0 -1
  795. package/dist/src/telemetry/semantic.truncation.test.js +0 -92
  796. package/dist/src/telemetry/semantic.truncation.test.js.map +0 -1
  797. package/dist/src/telemetry/startupProfiler.test.d.ts +0 -6
  798. package/dist/src/telemetry/startupProfiler.test.js +0 -285
  799. package/dist/src/telemetry/startupProfiler.test.js.map +0 -1
  800. package/dist/src/telemetry/telemetry-utils.test.d.ts +0 -6
  801. package/dist/src/telemetry/telemetry-utils.test.js +0 -41
  802. package/dist/src/telemetry/telemetry-utils.test.js.map +0 -1
  803. package/dist/src/telemetry/telemetry.test.d.ts +0 -6
  804. package/dist/src/telemetry/telemetry.test.js +0 -57
  805. package/dist/src/telemetry/telemetry.test.js.map +0 -1
  806. package/dist/src/telemetry/uiTelemetry.test.d.ts +0 -6
  807. package/dist/src/telemetry/uiTelemetry.test.js +0 -584
  808. package/dist/src/telemetry/uiTelemetry.test.js.map +0 -1
  809. package/dist/src/tools/activate-skill.test.d.ts +0 -6
  810. package/dist/src/tools/activate-skill.test.js +0 -113
  811. package/dist/src/tools/activate-skill.test.js.map +0 -1
  812. package/dist/src/tools/ask-user.test.d.ts +0 -6
  813. package/dist/src/tools/ask-user.test.js +0 -187
  814. package/dist/src/tools/ask-user.test.js.map +0 -1
  815. package/dist/src/tools/base-tool-invocation.test.d.ts +0 -6
  816. package/dist/src/tools/base-tool-invocation.test.js +0 -85
  817. package/dist/src/tools/base-tool-invocation.test.js.map +0 -1
  818. package/dist/src/tools/confirmation-policy.test.d.ts +0 -6
  819. package/dist/src/tools/confirmation-policy.test.js +0 -143
  820. package/dist/src/tools/confirmation-policy.test.js.map +0 -1
  821. package/dist/src/tools/diffOptions.test.d.ts +0 -6
  822. package/dist/src/tools/diffOptions.test.js +0 -172
  823. package/dist/src/tools/diffOptions.test.js.map +0 -1
  824. package/dist/src/tools/edit.test.d.ts +0 -6
  825. package/dist/src/tools/edit.test.js +0 -729
  826. package/dist/src/tools/edit.test.js.map +0 -1
  827. package/dist/src/tools/get-internal-docs.test.d.ts +0 -6
  828. package/dist/src/tools/get-internal-docs.test.js +0 -57
  829. package/dist/src/tools/get-internal-docs.test.js.map +0 -1
  830. package/dist/src/tools/glob.test.d.ts +0 -6
  831. package/dist/src/tools/glob.test.js +0 -433
  832. package/dist/src/tools/glob.test.js.map +0 -1
  833. package/dist/src/tools/grep.test.d.ts +0 -6
  834. package/dist/src/tools/grep.test.js +0 -328
  835. package/dist/src/tools/grep.test.js.map +0 -1
  836. package/dist/src/tools/ls.test.d.ts +0 -6
  837. package/dist/src/tools/ls.test.js +0 -242
  838. package/dist/src/tools/ls.test.js.map +0 -1
  839. package/dist/src/tools/mcp-client-manager.test.d.ts +0 -6
  840. package/dist/src/tools/mcp-client-manager.test.js +0 -251
  841. package/dist/src/tools/mcp-client-manager.test.js.map +0 -1
  842. package/dist/src/tools/mcp-client.test.d.ts +0 -6
  843. package/dist/src/tools/mcp-client.test.js +0 -1346
  844. package/dist/src/tools/mcp-client.test.js.map +0 -1
  845. package/dist/src/tools/mcp-tool.test.d.ts +0 -6
  846. package/dist/src/tools/mcp-tool.test.js +0 -657
  847. package/dist/src/tools/mcp-tool.test.js.map +0 -1
  848. package/dist/src/tools/memoryTool.test.d.ts +0 -6
  849. package/dist/src/tools/memoryTool.test.js +0 -302
  850. package/dist/src/tools/memoryTool.test.js.map +0 -1
  851. package/dist/src/tools/message-bus-integration.test.d.ts +0 -6
  852. package/dist/src/tools/message-bus-integration.test.js +0 -169
  853. package/dist/src/tools/message-bus-integration.test.js.map +0 -1
  854. package/dist/src/tools/modifiable-tool.test.d.ts +0 -6
  855. package/dist/src/tools/modifiable-tool.test.js +0 -237
  856. package/dist/src/tools/modifiable-tool.test.js.map +0 -1
  857. package/dist/src/tools/read-file.test.d.ts +0 -6
  858. package/dist/src/tools/read-file.test.js +0 -376
  859. package/dist/src/tools/read-file.test.js.map +0 -1
  860. package/dist/src/tools/read-many-files.test.d.ts +0 -6
  861. package/dist/src/tools/read-many-files.test.js +0 -567
  862. package/dist/src/tools/read-many-files.test.js.map +0 -1
  863. package/dist/src/tools/ripGrep.test.d.ts +0 -6
  864. package/dist/src/tools/ripGrep.test.js +0 -1139
  865. package/dist/src/tools/ripGrep.test.js.map +0 -1
  866. package/dist/src/tools/shell.test.d.ts +0 -6
  867. package/dist/src/tools/shell.test.js +0 -526
  868. package/dist/src/tools/shell.test.js.map +0 -1
  869. package/dist/src/tools/tool-names.test.d.ts +0 -6
  870. package/dist/src/tools/tool-names.test.js +0 -43
  871. package/dist/src/tools/tool-names.test.js.map +0 -1
  872. package/dist/src/tools/tool-registry.test.d.ts +0 -6
  873. package/dist/src/tools/tool-registry.test.js +0 -461
  874. package/dist/src/tools/tool-registry.test.js.map +0 -1
  875. package/dist/src/tools/tools.test.d.ts +0 -6
  876. package/dist/src/tools/tools.test.js +0 -207
  877. package/dist/src/tools/tools.test.js.map +0 -1
  878. package/dist/src/tools/web-fetch.test.d.ts +0 -6
  879. package/dist/src/tools/web-fetch.test.js +0 -442
  880. package/dist/src/tools/web-fetch.test.js.map +0 -1
  881. package/dist/src/tools/web-search.test.d.ts +0 -6
  882. package/dist/src/tools/web-search.test.js +0 -214
  883. package/dist/src/tools/web-search.test.js.map +0 -1
  884. package/dist/src/tools/write-file.test.d.ts +0 -6
  885. package/dist/src/tools/write-file.test.js +0 -681
  886. package/dist/src/tools/write-file.test.js.map +0 -1
  887. package/dist/src/tools/write-todos.test.d.ts +0 -6
  888. package/dist/src/tools/write-todos.test.js +0 -90
  889. package/dist/src/tools/write-todos.test.js.map +0 -1
  890. package/dist/src/utils/apiConversionUtils.test.d.ts +0 -6
  891. package/dist/src/utils/apiConversionUtils.test.js +0 -150
  892. package/dist/src/utils/apiConversionUtils.test.js.map +0 -1
  893. package/dist/src/utils/bfsFileSearch.test.d.ts +0 -6
  894. package/dist/src/utils/bfsFileSearch.test.js +0 -227
  895. package/dist/src/utils/bfsFileSearch.test.js.map +0 -1
  896. package/dist/src/utils/channel.test.d.ts +0 -6
  897. package/dist/src/utils/channel.test.js +0 -170
  898. package/dist/src/utils/channel.test.js.map +0 -1
  899. package/dist/src/utils/checkpointUtils.test.d.ts +0 -6
  900. package/dist/src/utils/checkpointUtils.test.js +0 -229
  901. package/dist/src/utils/checkpointUtils.test.js.map +0 -1
  902. package/dist/src/utils/customHeaderUtils.test.d.ts +0 -6
  903. package/dist/src/utils/customHeaderUtils.test.js +0 -77
  904. package/dist/src/utils/customHeaderUtils.test.js.map +0 -1
  905. package/dist/src/utils/debugLogger.test.d.ts +0 -6
  906. package/dist/src/utils/debugLogger.test.js +0 -69
  907. package/dist/src/utils/debugLogger.test.js.map +0 -1
  908. package/dist/src/utils/delay.test.d.ts +0 -6
  909. package/dist/src/utils/delay.test.js +0 -88
  910. package/dist/src/utils/delay.test.js.map +0 -1
  911. package/dist/src/utils/editCorrector.test.d.ts +0 -6
  912. package/dist/src/utils/editCorrector.test.js +0 -533
  913. package/dist/src/utils/editCorrector.test.js.map +0 -1
  914. package/dist/src/utils/editor.test.d.ts +0 -6
  915. package/dist/src/utils/editor.test.js +0 -429
  916. package/dist/src/utils/editor.test.js.map +0 -1
  917. package/dist/src/utils/environmentContext.test.d.ts +0 -6
  918. package/dist/src/utils/environmentContext.test.js +0 -114
  919. package/dist/src/utils/environmentContext.test.js.map +0 -1
  920. package/dist/src/utils/errorParsing.test.d.ts +0 -6
  921. package/dist/src/utils/errorParsing.test.js +0 -84
  922. package/dist/src/utils/errorParsing.test.js.map +0 -1
  923. package/dist/src/utils/errorReporting.test.d.ts +0 -6
  924. package/dist/src/utils/errorReporting.test.js +0 -133
  925. package/dist/src/utils/errorReporting.test.js.map +0 -1
  926. package/dist/src/utils/errors.test.d.ts +0 -6
  927. package/dist/src/utils/errors.test.js +0 -155
  928. package/dist/src/utils/errors.test.js.map +0 -1
  929. package/dist/src/utils/events.test.d.ts +0 -6
  930. package/dist/src/utils/events.test.js +0 -237
  931. package/dist/src/utils/events.test.js.map +0 -1
  932. package/dist/src/utils/extensionLoader.test.d.ts +0 -6
  933. package/dist/src/utils/extensionLoader.test.js +0 -176
  934. package/dist/src/utils/extensionLoader.test.js.map +0 -1
  935. package/dist/src/utils/fileDiffUtils.test.d.ts +0 -6
  936. package/dist/src/utils/fileDiffUtils.test.js +0 -84
  937. package/dist/src/utils/fileDiffUtils.test.js.map +0 -1
  938. package/dist/src/utils/fileUtils.test.d.ts +0 -6
  939. package/dist/src/utils/fileUtils.test.js +0 -780
  940. package/dist/src/utils/fileUtils.test.js.map +0 -1
  941. package/dist/src/utils/filesearch/crawlCache.test.d.ts +0 -6
  942. package/dist/src/utils/filesearch/crawlCache.test.js +0 -103
  943. package/dist/src/utils/filesearch/crawlCache.test.js.map +0 -1
  944. package/dist/src/utils/filesearch/crawler.test.d.ts +0 -6
  945. package/dist/src/utils/filesearch/crawler.test.js +0 -495
  946. package/dist/src/utils/filesearch/crawler.test.js.map +0 -1
  947. package/dist/src/utils/filesearch/fileSearch.test.d.ts +0 -6
  948. package/dist/src/utils/filesearch/fileSearch.test.js +0 -663
  949. package/dist/src/utils/filesearch/fileSearch.test.js.map +0 -1
  950. package/dist/src/utils/filesearch/ignore.test.d.ts +0 -6
  951. package/dist/src/utils/filesearch/ignore.test.js +0 -144
  952. package/dist/src/utils/filesearch/ignore.test.js.map +0 -1
  953. package/dist/src/utils/filesearch/result-cache.test.d.ts +0 -6
  954. package/dist/src/utils/filesearch/result-cache.test.js +0 -46
  955. package/dist/src/utils/filesearch/result-cache.test.js.map +0 -1
  956. package/dist/src/utils/flashFallback.test.d.ts +0 -6
  957. package/dist/src/utils/flashFallback.test.js +0 -103
  958. package/dist/src/utils/flashFallback.test.js.map +0 -1
  959. package/dist/src/utils/formatters.test.d.ts +0 -6
  960. package/dist/src/utils/formatters.test.js +0 -26
  961. package/dist/src/utils/formatters.test.js.map +0 -1
  962. package/dist/src/utils/geminiIgnoreParser.test.d.ts +0 -6
  963. package/dist/src/utils/geminiIgnoreParser.test.js +0 -98
  964. package/dist/src/utils/geminiIgnoreParser.test.js.map +0 -1
  965. package/dist/src/utils/geminiTypeConversion.test.d.ts +0 -6
  966. package/dist/src/utils/geminiTypeConversion.test.js +0 -310
  967. package/dist/src/utils/geminiTypeConversion.test.js.map +0 -1
  968. package/dist/src/utils/generateContentResponseUtilities.test.d.ts +0 -6
  969. package/dist/src/utils/generateContentResponseUtilities.test.js +0 -512
  970. package/dist/src/utils/generateContentResponseUtilities.test.js.map +0 -1
  971. package/dist/src/utils/getFolderStructure.test.d.ts +0 -6
  972. package/dist/src/utils/getFolderStructure.test.js +0 -283
  973. package/dist/src/utils/getFolderStructure.test.js.map +0 -1
  974. package/dist/src/utils/gitIgnoreParser.test.d.ts +0 -6
  975. package/dist/src/utils/gitIgnoreParser.test.js +0 -243
  976. package/dist/src/utils/gitIgnoreParser.test.js.map +0 -1
  977. package/dist/src/utils/googleErrors.test.d.ts +0 -6
  978. package/dist/src/utils/googleErrors.test.js +0 -309
  979. package/dist/src/utils/googleErrors.test.js.map +0 -1
  980. package/dist/src/utils/googleQuotaErrors.test.d.ts +0 -6
  981. package/dist/src/utils/googleQuotaErrors.test.js +0 -548
  982. package/dist/src/utils/googleQuotaErrors.test.js.map +0 -1
  983. package/dist/src/utils/ignorePatterns.test.d.ts +0 -6
  984. package/dist/src/utils/ignorePatterns.test.js +0 -246
  985. package/dist/src/utils/ignorePatterns.test.js.map +0 -1
  986. package/dist/src/utils/installationManager.test.d.ts +0 -6
  987. package/dist/src/utils/installationManager.test.js +0 -93
  988. package/dist/src/utils/installationManager.test.js.map +0 -1
  989. package/dist/src/utils/llm-edit-fixer.test.d.ts +0 -6
  990. package/dist/src/utils/llm-edit-fixer.test.js +0 -223
  991. package/dist/src/utils/llm-edit-fixer.test.js.map +0 -1
  992. package/dist/src/utils/llmUtils.test.d.ts +0 -6
  993. package/dist/src/utils/llmUtils.test.js +0 -196
  994. package/dist/src/utils/llmUtils.test.js.map +0 -1
  995. package/dist/src/utils/memoryDiscovery.test.d.ts +0 -6
  996. package/dist/src/utils/memoryDiscovery.test.js +0 -542
  997. package/dist/src/utils/memoryDiscovery.test.js.map +0 -1
  998. package/dist/src/utils/memoryImportProcessor.test.d.ts +0 -6
  999. package/dist/src/utils/memoryImportProcessor.test.js +0 -581
  1000. package/dist/src/utils/memoryImportProcessor.test.js.map +0 -1
  1001. package/dist/src/utils/nextSpeakerChecker.test.d.ts +0 -6
  1002. package/dist/src/utils/nextSpeakerChecker.test.js +0 -191
  1003. package/dist/src/utils/nextSpeakerChecker.test.js.map +0 -1
  1004. package/dist/src/utils/partUtils.test.d.ts +0 -6
  1005. package/dist/src/utils/partUtils.test.js +0 -397
  1006. package/dist/src/utils/partUtils.test.js.map +0 -1
  1007. package/dist/src/utils/pathCorrector.test.d.ts +0 -6
  1008. package/dist/src/utils/pathCorrector.test.js +0 -87
  1009. package/dist/src/utils/pathCorrector.test.js.map +0 -1
  1010. package/dist/src/utils/pathReader.test.d.ts +0 -6
  1011. package/dist/src/utils/pathReader.test.js +0 -406
  1012. package/dist/src/utils/pathReader.test.js.map +0 -1
  1013. package/dist/src/utils/paths.test.d.ts +0 -6
  1014. package/dist/src/utils/paths.test.js +0 -402
  1015. package/dist/src/utils/paths.test.js.map +0 -1
  1016. package/dist/src/utils/retry.test.d.ts +0 -6
  1017. package/dist/src/utils/retry.test.js +0 -548
  1018. package/dist/src/utils/retry.test.js.map +0 -1
  1019. package/dist/src/utils/retry_llm_error.test.d.ts +0 -6
  1020. package/dist/src/utils/retry_llm_error.test.js +0 -280
  1021. package/dist/src/utils/retry_llm_error.test.js.map +0 -1
  1022. package/dist/src/utils/safeJsonStringify.test.d.ts +0 -6
  1023. package/dist/src/utils/safeJsonStringify.test.js +0 -61
  1024. package/dist/src/utils/safeJsonStringify.test.js.map +0 -1
  1025. package/dist/src/utils/schemaValidator.test.d.ts +0 -6
  1026. package/dist/src/utils/schemaValidator.test.js +0 -113
  1027. package/dist/src/utils/schemaValidator.test.js.map +0 -1
  1028. package/dist/src/utils/secure-browser-launcher.test.d.ts +0 -6
  1029. package/dist/src/utils/secure-browser-launcher.test.js +0 -149
  1030. package/dist/src/utils/secure-browser-launcher.test.js.map +0 -1
  1031. package/dist/src/utils/security.test.d.ts +0 -1
  1032. package/dist/src/utils/security.test.js +0 -121
  1033. package/dist/src/utils/security.test.js.map +0 -1
  1034. package/dist/src/utils/shell-utils.integration.test.d.ts +0 -1
  1035. package/dist/src/utils/shell-utils.integration.test.js +0 -58
  1036. package/dist/src/utils/shell-utils.integration.test.js.map +0 -1
  1037. package/dist/src/utils/shell-utils.test.d.ts +0 -6
  1038. package/dist/src/utils/shell-utils.test.js +0 -437
  1039. package/dist/src/utils/shell-utils.test.js.map +0 -1
  1040. package/dist/src/utils/stdio.test.d.ts +0 -6
  1041. package/dist/src/utils/stdio.test.js +0 -47
  1042. package/dist/src/utils/stdio.test.js.map +0 -1
  1043. package/dist/src/utils/summarizer.test.d.ts +0 -6
  1044. package/dist/src/utils/summarizer.test.js +0 -152
  1045. package/dist/src/utils/summarizer.test.js.map +0 -1
  1046. package/dist/src/utils/systemEncoding.test.d.ts +0 -6
  1047. package/dist/src/utils/systemEncoding.test.js +0 -369
  1048. package/dist/src/utils/systemEncoding.test.js.map +0 -1
  1049. package/dist/src/utils/terminalSerializer.test.d.ts +0 -6
  1050. package/dist/src/utils/terminalSerializer.test.js +0 -193
  1051. package/dist/src/utils/terminalSerializer.test.js.map +0 -1
  1052. package/dist/src/utils/textUtils.test.d.ts +0 -6
  1053. package/dist/src/utils/textUtils.test.js +0 -76
  1054. package/dist/src/utils/textUtils.test.js.map +0 -1
  1055. package/dist/src/utils/thoughtUtils.test.d.ts +0 -6
  1056. package/dist/src/utils/thoughtUtils.test.js +0 -78
  1057. package/dist/src/utils/thoughtUtils.test.js.map +0 -1
  1058. package/dist/src/utils/tokenCalculation.test.d.ts +0 -6
  1059. package/dist/src/utils/tokenCalculation.test.js +0 -184
  1060. package/dist/src/utils/tokenCalculation.test.js.map +0 -1
  1061. package/dist/src/utils/tool-utils.test.d.ts +0 -6
  1062. package/dist/src/utils/tool-utils.test.js +0 -84
  1063. package/dist/src/utils/tool-utils.test.js.map +0 -1
  1064. package/dist/src/utils/toolCallContext.test.d.ts +0 -6
  1065. package/dist/src/utils/toolCallContext.test.js +0 -68
  1066. package/dist/src/utils/toolCallContext.test.js.map +0 -1
  1067. package/dist/src/utils/userAccountManager.test.d.ts +0 -6
  1068. package/dist/src/utils/userAccountManager.test.js +0 -225
  1069. package/dist/src/utils/userAccountManager.test.js.map +0 -1
  1070. package/dist/src/utils/version.test.d.ts +0 -6
  1071. package/dist/src/utils/version.test.js +0 -39
  1072. package/dist/src/utils/version.test.js.map +0 -1
  1073. package/dist/src/utils/workspaceContext.test.d.ts +0 -6
  1074. package/dist/src/utils/workspaceContext.test.js +0 -374
  1075. package/dist/src/utils/workspaceContext.test.js.map +0 -1
  1076. package/dist/tsconfig.tsbuildinfo +0 -1
@@ -1,964 +0,0 @@
1
- /**
2
- * @license
3
- * Copyright 2025 Google LLC
4
- * SPDX-License-Identifier: Apache-2.0
5
- */
6
- import 'vitest';
7
- import { vi, describe, it, expect, afterEach, beforeAll, afterAll, beforeEach, } from 'vitest';
8
- import { ClearcutLogger, EventNames, TEST_ONLY } from './clearcut-logger.js';
9
- import { AuthType } from '../../core/contentGenerator.js';
10
- import { EventMetadataKey } from './event-metadata-key.js';
11
- import { makeFakeConfig } from '../../test-utils/config.js';
12
- import { http, HttpResponse } from 'msw';
13
- import { server } from '../../mocks/msw.js';
14
- import { StartSessionEvent, UserPromptEvent, makeChatCompressionEvent, ModelRoutingEvent, ToolCallEvent, AgentStartEvent, AgentFinishEvent, WebFetchFallbackAttemptEvent, HookCallEvent, } from '../types.js';
15
- import { AgentTerminateMode } from '../../agents/types.js';
16
- import { GIT_COMMIT_INFO, CLI_VERSION } from '../../generated/git-commit.js';
17
- import { UserAccountManager } from '../../utils/userAccountManager.js';
18
- import { InstallationManager } from '../../utils/installationManager.js';
19
- import si from 'systeminformation';
20
- expect.extend({
21
- toHaveEventName(received, name) {
22
- const { isNot } = this;
23
- const event = JSON.parse(received[0].source_extension_json);
24
- const pass = event.event_name === name;
25
- return {
26
- pass,
27
- message: () => `event name ${event.event_name} does${isNot ? ' not ' : ''} match ${name}}`,
28
- };
29
- },
30
- toHaveMetadataValue(received, [key, value]) {
31
- const event = JSON.parse(received[0].source_extension_json);
32
- const metadata = event['event_metadata'][0];
33
- const data = metadata.find((m) => m.gemini_cli_key === key)?.value;
34
- const pass = data !== undefined && data === value;
35
- return {
36
- pass,
37
- message: () => `event ${received} should have: ${value}. Found: ${data}`,
38
- };
39
- },
40
- toHaveMetadataKey(received, key) {
41
- const { isNot } = this;
42
- const event = JSON.parse(received[0].source_extension_json);
43
- const metadata = event['event_metadata'][0];
44
- const pass = metadata.some((m) => m.gemini_cli_key === key);
45
- return {
46
- pass,
47
- message: () => `event ${received} ${isNot ? 'has' : 'does not have'} the metadata key ${key}`,
48
- };
49
- },
50
- toHaveGwsExperiments(received, exps) {
51
- const { isNot } = this;
52
- const gwsExperiment = received[0].exp?.gws_experiment;
53
- const pass = gwsExperiment !== undefined &&
54
- gwsExperiment.length === exps.length &&
55
- gwsExperiment.every((val, idx) => val === exps[idx]);
56
- return {
57
- pass,
58
- message: () => `exp.gws_experiment ${JSON.stringify(gwsExperiment)} does${isNot ? '' : ' not'} match ${JSON.stringify(exps)}`,
59
- };
60
- },
61
- });
62
- vi.mock('node:os', async (importOriginal) => {
63
- const actual = await importOriginal();
64
- return {
65
- ...actual,
66
- cpus: vi.fn(() => [{ model: 'Intel(R) Core(TM) i9-9980HK CPU @ 2.40GHz' }]),
67
- totalmem: vi.fn(() => 32 * 1024 * 1024 * 1024),
68
- };
69
- });
70
- vi.mock('../../utils/userAccountManager.js');
71
- vi.mock('../../utils/installationManager.js');
72
- vi.mock('systeminformation', () => ({
73
- default: {
74
- graphics: vi.fn().mockResolvedValue({
75
- controllers: [{ model: 'Mock GPU' }],
76
- }),
77
- },
78
- }));
79
- const mockUserAccount = vi.mocked(UserAccountManager.prototype);
80
- const mockInstallMgr = vi.mocked(InstallationManager.prototype);
81
- beforeEach(() => {
82
- // Ensure Antigravity detection doesn't interfere with other tests
83
- vi.stubEnv('ANTIGRAVITY_CLI_ALIAS', '');
84
- });
85
- // TODO(richieforeman): Consider moving this to test setup globally.
86
- beforeAll(() => {
87
- server.listen({});
88
- });
89
- afterEach(() => {
90
- server.resetHandlers();
91
- });
92
- afterAll(() => {
93
- server.close();
94
- });
95
- describe('ClearcutLogger', () => {
96
- const NEXT_WAIT_MS = 1234;
97
- const CLEARCUT_URL = 'https://play.googleapis.com/log';
98
- const MOCK_DATE = new Date('2025-01-02T00:00:00.000Z');
99
- const EXAMPLE_RESPONSE = `["${NEXT_WAIT_MS}",null,[[["ANDROID_BACKUP",0],["BATTERY_STATS",0],["SMART_SETUP",0],["TRON",0]],-3334737594024971225],[]]`;
100
- // A helper to get the internal events array for testing
101
- const getEvents = (l) => l['events'].toArray();
102
- const getEventsSize = (l) => l['events'].size;
103
- const requeueFailedEvents = (l, events) => l['requeueFailedEvents'](events);
104
- afterEach(() => {
105
- vi.unstubAllEnvs();
106
- });
107
- beforeEach(() => {
108
- vi.stubEnv('ANTIGRAVITY_CLI_ALIAS', '');
109
- vi.stubEnv('TERM_PROGRAM', '');
110
- vi.stubEnv('CURSOR_TRACE_ID', '');
111
- vi.stubEnv('CODESPACES', '');
112
- vi.stubEnv('VSCODE_IPC_HOOK_CLI', '');
113
- vi.stubEnv('EDITOR_IN_CLOUD_SHELL', '');
114
- vi.stubEnv('CLOUD_SHELL', '');
115
- vi.stubEnv('TERM_PRODUCT', '');
116
- vi.stubEnv('MONOSPACE_ENV', '');
117
- vi.stubEnv('REPLIT_USER', '');
118
- vi.stubEnv('__COG_BASHRC_SOURCED', '');
119
- });
120
- function setup({ config = {
121
- experiments: {
122
- experimentIds: [123, 456, 789],
123
- },
124
- }, lifetimeGoogleAccounts = 1, cachedGoogleAccount = 'test@google.com', } = {}) {
125
- server.resetHandlers(http.post(CLEARCUT_URL, () => HttpResponse.text(EXAMPLE_RESPONSE)));
126
- vi.useFakeTimers();
127
- vi.setSystemTime(MOCK_DATE);
128
- const loggerConfig = makeFakeConfig({
129
- ...config,
130
- });
131
- ClearcutLogger.clearInstance();
132
- mockUserAccount.getCachedGoogleAccount.mockReturnValue(cachedGoogleAccount);
133
- mockUserAccount.getLifetimeGoogleAccounts.mockReturnValue(lifetimeGoogleAccounts);
134
- mockInstallMgr.getInstallationId = vi
135
- .fn()
136
- .mockReturnValue('test-installation-id');
137
- const logger = ClearcutLogger.getInstance(loggerConfig);
138
- return { logger, loggerConfig };
139
- }
140
- afterEach(() => {
141
- ClearcutLogger.clearInstance();
142
- TEST_ONLY.resetCachedGpuInfoForTesting();
143
- vi.useRealTimers();
144
- vi.restoreAllMocks();
145
- });
146
- describe('getInstance', () => {
147
- it.each([
148
- { usageStatisticsEnabled: false, expectedValue: undefined },
149
- {
150
- usageStatisticsEnabled: true,
151
- expectedValue: expect.any(ClearcutLogger),
152
- },
153
- ])('returns an instance if usage statistics are enabled', ({ usageStatisticsEnabled, expectedValue }) => {
154
- ClearcutLogger.clearInstance();
155
- const { logger } = setup({
156
- config: {
157
- usageStatisticsEnabled,
158
- },
159
- });
160
- expect(logger).toEqual(expectedValue);
161
- });
162
- it('is a singleton', () => {
163
- ClearcutLogger.clearInstance();
164
- const { loggerConfig } = setup();
165
- const logger1 = ClearcutLogger.getInstance(loggerConfig);
166
- const logger2 = ClearcutLogger.getInstance(loggerConfig);
167
- expect(logger1).toBe(logger2);
168
- });
169
- });
170
- describe('createLogEvent', () => {
171
- it('logs the total number of google accounts', async () => {
172
- const { logger } = setup({
173
- lifetimeGoogleAccounts: 9001,
174
- });
175
- const event = logger?.createLogEvent(EventNames.API_ERROR, []);
176
- expect(event?.event_metadata[0]).toContainEqual({
177
- gemini_cli_key: EventMetadataKey.GEMINI_CLI_GOOGLE_ACCOUNTS_COUNT,
178
- value: '9001',
179
- });
180
- });
181
- it('logs default metadata', () => {
182
- // Define expected values
183
- const session_id = 'my-session-id';
184
- const auth_type = AuthType.USE_GEMINI;
185
- const google_accounts = 123;
186
- const surface = 'ide-1234';
187
- const cli_version = CLI_VERSION;
188
- const git_commit_hash = GIT_COMMIT_INFO;
189
- const prompt_id = 'my-prompt-123';
190
- // Setup logger with expected values
191
- const { logger, loggerConfig } = setup({
192
- lifetimeGoogleAccounts: google_accounts,
193
- config: { sessionId: session_id },
194
- });
195
- vi.spyOn(loggerConfig, 'getContentGeneratorConfig').mockReturnValue({
196
- authType: auth_type,
197
- });
198
- logger?.logNewPromptEvent(new UserPromptEvent(1, prompt_id)); // prompt_id == session_id before this
199
- vi.stubEnv('SURFACE', surface);
200
- // Create log event
201
- const event = logger?.createLogEvent(EventNames.API_ERROR, []);
202
- // Ensure expected values exist
203
- expect(event?.event_metadata[0]).toEqual(expect.arrayContaining([
204
- {
205
- gemini_cli_key: EventMetadataKey.GEMINI_CLI_SESSION_ID,
206
- value: session_id,
207
- },
208
- {
209
- gemini_cli_key: EventMetadataKey.GEMINI_CLI_AUTH_TYPE,
210
- value: JSON.stringify(auth_type),
211
- },
212
- {
213
- gemini_cli_key: EventMetadataKey.GEMINI_CLI_GOOGLE_ACCOUNTS_COUNT,
214
- value: `${google_accounts}`,
215
- },
216
- {
217
- gemini_cli_key: EventMetadataKey.GEMINI_CLI_SURFACE,
218
- value: surface,
219
- },
220
- {
221
- gemini_cli_key: EventMetadataKey.GEMINI_CLI_VERSION,
222
- value: cli_version,
223
- },
224
- {
225
- gemini_cli_key: EventMetadataKey.GEMINI_CLI_GIT_COMMIT_HASH,
226
- value: git_commit_hash,
227
- },
228
- {
229
- gemini_cli_key: EventMetadataKey.GEMINI_CLI_PROMPT_ID,
230
- value: prompt_id,
231
- },
232
- {
233
- gemini_cli_key: EventMetadataKey.GEMINI_CLI_OS,
234
- value: process.platform,
235
- },
236
- {
237
- gemini_cli_key: EventMetadataKey.GEMINI_CLI_USER_SETTINGS,
238
- value: logger?.getConfigJson(),
239
- },
240
- ]));
241
- });
242
- it('logs the current nodejs version', () => {
243
- const { logger } = setup({});
244
- const event = logger?.createLogEvent(EventNames.API_ERROR, []);
245
- expect(event?.event_metadata[0]).toContainEqual({
246
- gemini_cli_key: EventMetadataKey.GEMINI_CLI_NODE_VERSION,
247
- value: process.versions.node,
248
- });
249
- });
250
- it('logs all user settings', () => {
251
- const { logger } = setup({
252
- config: {},
253
- });
254
- vi.stubEnv('TERM_PROGRAM', 'vscode');
255
- vi.stubEnv('SURFACE', 'ide-1234');
256
- const event = logger?.createLogEvent(EventNames.TOOL_CALL, []);
257
- expect(event?.event_metadata[0]).toContainEqual({
258
- gemini_cli_key: EventMetadataKey.GEMINI_CLI_USER_SETTINGS,
259
- value: logger?.getConfigJson(),
260
- });
261
- });
262
- it('logs the GPU information (single GPU)', async () => {
263
- vi.mocked(si.graphics).mockResolvedValueOnce({
264
- controllers: [{ model: 'Single GPU' }],
265
- });
266
- const { logger, loggerConfig } = setup({});
267
- await logger?.logStartSessionEvent(new StartSessionEvent(loggerConfig));
268
- const event = logger?.createLogEvent(EventNames.API_ERROR, []);
269
- const gpuInfoEntry = event?.event_metadata[0].find((item) => item.gemini_cli_key === EventMetadataKey.GEMINI_CLI_GPU_INFO);
270
- expect(gpuInfoEntry).toBeDefined();
271
- expect(gpuInfoEntry?.value).toBe('Single GPU');
272
- });
273
- it('logs multiple GPUs', async () => {
274
- vi.mocked(si.graphics).mockResolvedValueOnce({
275
- controllers: [{ model: 'GPU 1' }, { model: 'GPU 2' }],
276
- });
277
- const { logger, loggerConfig } = setup({});
278
- await logger?.logStartSessionEvent(new StartSessionEvent(loggerConfig));
279
- const event = logger?.createLogEvent(EventNames.API_ERROR, []);
280
- const metadata = event?.event_metadata[0];
281
- const gpuInfoEntry = metadata?.find((m) => m.gemini_cli_key === EventMetadataKey.GEMINI_CLI_GPU_INFO);
282
- expect(gpuInfoEntry?.value).toBe('GPU 1, GPU 2');
283
- });
284
- it('logs NA when no GPUs are found', async () => {
285
- vi.mocked(si.graphics).mockResolvedValueOnce({
286
- controllers: [],
287
- });
288
- const { logger, loggerConfig } = setup({});
289
- await logger?.logStartSessionEvent(new StartSessionEvent(loggerConfig));
290
- const event = logger?.createLogEvent(EventNames.API_ERROR, []);
291
- const metadata = event?.event_metadata[0];
292
- const gpuInfoEntry = metadata?.find((m) => m.gemini_cli_key === EventMetadataKey.GEMINI_CLI_GPU_INFO);
293
- expect(gpuInfoEntry?.value).toBe('NA');
294
- });
295
- it('logs FAILED when GPU detection fails', async () => {
296
- vi.mocked(si.graphics).mockRejectedValueOnce(new Error('Detection failed'));
297
- const { logger, loggerConfig } = setup({});
298
- await logger?.logStartSessionEvent(new StartSessionEvent(loggerConfig));
299
- const event = logger?.createLogEvent(EventNames.API_ERROR, []);
300
- expect(event?.event_metadata[0]).toContainEqual({
301
- gemini_cli_key: EventMetadataKey.GEMINI_CLI_GPU_INFO,
302
- value: 'FAILED',
303
- });
304
- });
305
- it.each([
306
- {
307
- name: 'github action',
308
- env: { GITHUB_SHA: '8675309' },
309
- expected: 'GitHub',
310
- },
311
- {
312
- name: 'Cloud Shell via EDITOR_IN_CLOUD_SHELL',
313
- env: { EDITOR_IN_CLOUD_SHELL: 'true' },
314
- expected: 'cloudshell',
315
- },
316
- {
317
- name: 'Cloud Shell via CLOUD_SHELL',
318
- env: { CLOUD_SHELL: 'true' },
319
- expected: 'cloudshell',
320
- },
321
- {
322
- name: 'VSCode via TERM_PROGRAM',
323
- env: {
324
- TERM_PROGRAM: 'vscode',
325
- GITHUB_SHA: undefined,
326
- MONOSPACE_ENV: '',
327
- },
328
- expected: 'vscode',
329
- },
330
- {
331
- name: 'SURFACE env var',
332
- env: { SURFACE: 'ide-1234' },
333
- expected: 'ide-1234',
334
- },
335
- {
336
- name: 'SURFACE env var takes precedence',
337
- env: { TERM_PROGRAM: 'vscode', SURFACE: 'ide-1234' },
338
- expected: 'ide-1234',
339
- },
340
- {
341
- name: 'Cursor',
342
- env: {
343
- CURSOR_TRACE_ID: 'abc123',
344
- TERM_PROGRAM: 'vscode',
345
- GITHUB_SHA: undefined,
346
- },
347
- expected: 'cursor',
348
- },
349
- {
350
- name: 'Firebase Studio',
351
- env: {
352
- MONOSPACE_ENV: 'true',
353
- TERM_PROGRAM: 'vscode',
354
- GITHUB_SHA: undefined,
355
- },
356
- expected: 'firebasestudio',
357
- },
358
- {
359
- name: 'Devin',
360
- env: {
361
- __COG_BASHRC_SOURCED: 'true',
362
- TERM_PROGRAM: 'vscode',
363
- GITHUB_SHA: undefined,
364
- },
365
- expected: 'devin',
366
- },
367
- {
368
- name: 'unidentified',
369
- env: {
370
- GITHUB_SHA: undefined,
371
- TERM_PROGRAM: undefined,
372
- SURFACE: undefined,
373
- },
374
- expected: 'SURFACE_NOT_SET',
375
- },
376
- ])('logs the current surface as $expected from $name', ({ env, expected }) => {
377
- const { logger } = setup({});
378
- for (const [key, value] of Object.entries(env)) {
379
- vi.stubEnv(key, value);
380
- }
381
- const event = logger?.createLogEvent(EventNames.API_ERROR, []);
382
- expect(event?.event_metadata[0]).toContainEqual({
383
- gemini_cli_key: EventMetadataKey.GEMINI_CLI_SURFACE,
384
- value: expected,
385
- });
386
- });
387
- });
388
- describe('GH_WORKFLOW_NAME metadata', () => {
389
- it('includes workflow name when GH_WORKFLOW_NAME is set', () => {
390
- const { logger } = setup({});
391
- vi.stubEnv('GH_WORKFLOW_NAME', 'test-workflow');
392
- const event = logger?.createLogEvent(EventNames.API_ERROR, []);
393
- expect(event?.event_metadata[0]).toContainEqual({
394
- gemini_cli_key: EventMetadataKey.GEMINI_CLI_GH_WORKFLOW_NAME,
395
- value: 'test-workflow',
396
- });
397
- });
398
- it('does not include workflow name when GH_WORKFLOW_NAME is not set', () => {
399
- const { logger } = setup({});
400
- vi.stubEnv('GH_WORKFLOW_NAME', undefined);
401
- const event = logger?.createLogEvent(EventNames.API_ERROR, []);
402
- const hasWorkflowName = event?.event_metadata[0].some((item) => item.gemini_cli_key === EventMetadataKey.GEMINI_CLI_GH_WORKFLOW_NAME);
403
- expect(hasWorkflowName).toBe(false);
404
- });
405
- });
406
- describe('GITHUB_REPOSITORY metadata', () => {
407
- it('includes hashed repository when GITHUB_REPOSITORY is set', () => {
408
- vi.stubEnv('GITHUB_REPOSITORY', 'google/gemini-cli');
409
- const { logger } = setup({});
410
- const event = logger?.createLogEvent(EventNames.API_ERROR, []);
411
- const repositoryMetadata = event?.event_metadata[0].find((item) => item.gemini_cli_key ===
412
- EventMetadataKey.GEMINI_CLI_GH_REPOSITORY_NAME_HASH);
413
- expect(repositoryMetadata).toBeDefined();
414
- expect(repositoryMetadata?.value).toMatch(/^[a-f0-9]{64}$/);
415
- expect(repositoryMetadata?.value).not.toBe('google/gemini-cli');
416
- });
417
- it('hashes repository name consistently', () => {
418
- vi.stubEnv('GITHUB_REPOSITORY', 'google/gemini-cli');
419
- const { logger } = setup({});
420
- const event1 = logger?.createLogEvent(EventNames.API_ERROR, []);
421
- const event2 = logger?.createLogEvent(EventNames.API_ERROR, []);
422
- const hash1 = event1?.event_metadata[0].find((item) => item.gemini_cli_key ===
423
- EventMetadataKey.GEMINI_CLI_GH_REPOSITORY_NAME_HASH)?.value;
424
- const hash2 = event2?.event_metadata[0].find((item) => item.gemini_cli_key ===
425
- EventMetadataKey.GEMINI_CLI_GH_REPOSITORY_NAME_HASH)?.value;
426
- expect(hash1).toBeDefined();
427
- expect(hash2).toBeDefined();
428
- expect(hash1).toBe(hash2);
429
- });
430
- it('produces different hashes for different repositories', () => {
431
- vi.stubEnv('GITHUB_REPOSITORY', 'google/gemini-cli');
432
- const { logger: logger1 } = setup({});
433
- const event1 = logger1?.createLogEvent(EventNames.API_ERROR, []);
434
- const hash1 = event1?.event_metadata[0].find((item) => item.gemini_cli_key ===
435
- EventMetadataKey.GEMINI_CLI_GH_REPOSITORY_NAME_HASH)?.value;
436
- vi.stubEnv('GITHUB_REPOSITORY', 'google/other-repo');
437
- ClearcutLogger.clearInstance();
438
- const { logger: logger2 } = setup({});
439
- const event2 = logger2?.createLogEvent(EventNames.API_ERROR, []);
440
- const hash2 = event2?.event_metadata[0].find((item) => item.gemini_cli_key ===
441
- EventMetadataKey.GEMINI_CLI_GH_REPOSITORY_NAME_HASH)?.value;
442
- expect(hash1).toBeDefined();
443
- expect(hash2).toBeDefined();
444
- expect(hash1).not.toBe(hash2);
445
- });
446
- it('does not include repository when GITHUB_REPOSITORY is not set', () => {
447
- vi.stubEnv('GITHUB_REPOSITORY', undefined);
448
- const { logger } = setup({});
449
- const event = logger?.createLogEvent(EventNames.API_ERROR, []);
450
- const hasRepository = event?.event_metadata[0].some((item) => item.gemini_cli_key ===
451
- EventMetadataKey.GEMINI_CLI_GH_REPOSITORY_NAME_HASH);
452
- expect(hasRepository).toBe(false);
453
- });
454
- });
455
- describe('logChatCompressionEvent', () => {
456
- it('logs an event with proper fields', () => {
457
- const { logger } = setup();
458
- logger?.logChatCompressionEvent(makeChatCompressionEvent({
459
- tokens_before: 9001,
460
- tokens_after: 8000,
461
- }));
462
- const events = getEvents(logger);
463
- expect(events.length).toBe(1);
464
- expect(events[0]).toHaveEventName(EventNames.CHAT_COMPRESSION);
465
- expect(events[0]).toHaveMetadataValue([
466
- EventMetadataKey.GEMINI_CLI_COMPRESSION_TOKENS_BEFORE,
467
- '9001',
468
- ]);
469
- expect(events[0]).toHaveMetadataValue([
470
- EventMetadataKey.GEMINI_CLI_COMPRESSION_TOKENS_AFTER,
471
- '8000',
472
- ]);
473
- });
474
- });
475
- describe('logRipgrepFallbackEvent', () => {
476
- it('logs an event with the proper name', () => {
477
- const { logger } = setup();
478
- // Spy on flushToClearcut to prevent it from clearing the queue
479
- const flushSpy = vi
480
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
481
- .spyOn(logger, 'flushToClearcut')
482
- .mockResolvedValue({ nextRequestWaitMs: 0 });
483
- logger?.logRipgrepFallbackEvent();
484
- const events = getEvents(logger);
485
- expect(events.length).toBe(1);
486
- expect(events[0]).toHaveEventName(EventNames.RIPGREP_FALLBACK);
487
- expect(flushSpy).toHaveBeenCalledOnce();
488
- });
489
- });
490
- describe('enqueueLogEvent', () => {
491
- it('should add events to the queue', () => {
492
- const { logger } = setup();
493
- logger.enqueueLogEvent(logger.createLogEvent(EventNames.API_ERROR));
494
- expect(getEventsSize(logger)).toBe(1);
495
- });
496
- it('should evict the oldest event when the queue is full', () => {
497
- const { logger } = setup();
498
- for (let i = 0; i < TEST_ONLY.MAX_EVENTS; i++) {
499
- logger.enqueueLogEvent(logger.createLogEvent(EventNames.API_ERROR, [
500
- {
501
- gemini_cli_key: EventMetadataKey.GEMINI_CLI_AI_ADDED_LINES,
502
- value: `${i}`,
503
- },
504
- ]));
505
- }
506
- let events = getEvents(logger);
507
- expect(events.length).toBe(TEST_ONLY.MAX_EVENTS);
508
- expect(events[0]).toHaveMetadataValue([
509
- EventMetadataKey.GEMINI_CLI_AI_ADDED_LINES,
510
- '0',
511
- ]);
512
- // This should push out the first event
513
- logger.enqueueLogEvent(logger.createLogEvent(EventNames.API_ERROR, [
514
- {
515
- gemini_cli_key: EventMetadataKey.GEMINI_CLI_AI_ADDED_LINES,
516
- value: `${TEST_ONLY.MAX_EVENTS}`,
517
- },
518
- ]));
519
- events = getEvents(logger);
520
- expect(events.length).toBe(TEST_ONLY.MAX_EVENTS);
521
- expect(events[0]).toHaveMetadataValue([
522
- EventMetadataKey.GEMINI_CLI_AI_ADDED_LINES,
523
- '1',
524
- ]);
525
- expect(events.at(TEST_ONLY.MAX_EVENTS - 1)).toHaveMetadataValue([
526
- EventMetadataKey.GEMINI_CLI_AI_ADDED_LINES,
527
- `${TEST_ONLY.MAX_EVENTS}`,
528
- ]);
529
- });
530
- });
531
- describe('flushToClearcut', () => {
532
- it('allows for usage with a configured proxy agent', async () => {
533
- const { logger } = setup({
534
- config: {
535
- proxy: 'http://mycoolproxy.whatever.com:3128',
536
- },
537
- });
538
- logger.enqueueLogEvent(logger.createLogEvent(EventNames.API_ERROR));
539
- const response = await logger.flushToClearcut();
540
- expect(response.nextRequestWaitMs).toBe(NEXT_WAIT_MS);
541
- });
542
- it('should clear events on successful flush', async () => {
543
- const { logger } = setup();
544
- logger.enqueueLogEvent(logger.createLogEvent(EventNames.API_ERROR));
545
- const response = await logger.flushToClearcut();
546
- expect(getEvents(logger)).toEqual([]);
547
- expect(response.nextRequestWaitMs).toBe(NEXT_WAIT_MS);
548
- });
549
- it('should handle a network error and requeue events', async () => {
550
- const { logger } = setup();
551
- server.resetHandlers(http.post(CLEARCUT_URL, () => HttpResponse.error()));
552
- logger.enqueueLogEvent(logger.createLogEvent(EventNames.API_REQUEST));
553
- logger.enqueueLogEvent(logger.createLogEvent(EventNames.API_ERROR));
554
- expect(getEventsSize(logger)).toBe(2);
555
- const x = logger.flushToClearcut();
556
- await x;
557
- expect(getEventsSize(logger)).toBe(2);
558
- const events = getEvents(logger);
559
- expect(events.length).toBe(2);
560
- expect(events[0]).toHaveEventName(EventNames.API_REQUEST);
561
- });
562
- it('should handle an HTTP error and requeue events', async () => {
563
- const { logger } = setup();
564
- server.resetHandlers(http.post(CLEARCUT_URL, () => new HttpResponse({ 'the system is down': true }, {
565
- status: 500,
566
- })));
567
- logger.enqueueLogEvent(logger.createLogEvent(EventNames.API_REQUEST));
568
- logger.enqueueLogEvent(logger.createLogEvent(EventNames.API_ERROR));
569
- expect(getEvents(logger).length).toBe(2);
570
- await logger.flushToClearcut();
571
- const events = getEvents(logger);
572
- expect(events[0]).toHaveEventName(EventNames.API_REQUEST);
573
- });
574
- });
575
- describe('requeueFailedEvents logic', () => {
576
- it('should limit the number of requeued events to max_retry_events', () => {
577
- const { logger } = setup();
578
- const eventsToLogCount = TEST_ONLY.MAX_RETRY_EVENTS + 5;
579
- const eventsToSend = [];
580
- for (let i = 0; i < eventsToLogCount; i++) {
581
- eventsToSend.push([
582
- {
583
- event_time_ms: Date.now(),
584
- source_extension_json: JSON.stringify({ event_id: i }),
585
- },
586
- ]);
587
- }
588
- requeueFailedEvents(logger, eventsToSend);
589
- expect(getEventsSize(logger)).toBe(TEST_ONLY.MAX_RETRY_EVENTS);
590
- const firstRequeuedEvent = JSON.parse(getEvents(logger)[0][0].source_extension_json);
591
- // The last `maxRetryEvents` are kept. The oldest of those is at index `eventsToLogCount - maxRetryEvents`.
592
- expect(firstRequeuedEvent.event_id).toBe(eventsToLogCount - TEST_ONLY.MAX_RETRY_EVENTS);
593
- });
594
- it('should not requeue more events than available space in the queue', () => {
595
- const { logger } = setup();
596
- const maxEvents = TEST_ONLY.MAX_EVENTS;
597
- const spaceToLeave = 5;
598
- const initialEventCount = maxEvents - spaceToLeave;
599
- for (let i = 0; i < initialEventCount; i++) {
600
- logger.enqueueLogEvent(logger.createLogEvent(EventNames.API_ERROR));
601
- }
602
- expect(getEventsSize(logger)).toBe(initialEventCount);
603
- const failedEventsCount = 10; // More than spaceToLeave
604
- const eventsToSend = [];
605
- for (let i = 0; i < failedEventsCount; i++) {
606
- eventsToSend.push([
607
- {
608
- event_time_ms: Date.now(),
609
- source_extension_json: JSON.stringify({ event_id: `failed_${i}` }),
610
- },
611
- ]);
612
- }
613
- requeueFailedEvents(logger, eventsToSend);
614
- // availableSpace is 5. eventsToRequeue is min(10, 5) = 5.
615
- // Total size should be initialEventCount + 5 = maxEvents.
616
- expect(getEventsSize(logger)).toBe(maxEvents);
617
- // The requeued events are the *last* 5 of the failed events.
618
- // startIndex = max(0, 10 - 5) = 5.
619
- // Loop unshifts events from index 9 down to 5.
620
- // The first element in the deque is the one with id 'failed_5'.
621
- const firstRequeuedEvent = JSON.parse(getEvents(logger)[0][0].source_extension_json);
622
- expect(firstRequeuedEvent.event_id).toBe('failed_5');
623
- });
624
- });
625
- describe('logModelRoutingEvent', () => {
626
- it('logs a successful routing event', () => {
627
- const { logger } = setup();
628
- const event = new ModelRoutingEvent('gemini-pro', 'default-strategy', 123, 'some reasoning', false, undefined);
629
- logger?.logModelRoutingEvent(event);
630
- const events = getEvents(logger);
631
- expect(events.length).toBe(1);
632
- expect(events[0]).toHaveEventName(EventNames.MODEL_ROUTING);
633
- expect(events[0]).toHaveMetadataValue([
634
- EventMetadataKey.GEMINI_CLI_ROUTING_DECISION,
635
- 'gemini-pro',
636
- ]);
637
- expect(events[0]).toHaveMetadataValue([
638
- EventMetadataKey.GEMINI_CLI_ROUTING_DECISION_SOURCE,
639
- 'default-strategy',
640
- ]);
641
- expect(events[0]).toHaveMetadataValue([
642
- EventMetadataKey.GEMINI_CLI_ROUTING_LATENCY_MS,
643
- '123',
644
- ]);
645
- expect(events[0]).toHaveMetadataValue([
646
- EventMetadataKey.GEMINI_CLI_ROUTING_FAILURE,
647
- 'false',
648
- ]);
649
- });
650
- it('logs a failed routing event with a reason', () => {
651
- const { logger } = setup();
652
- const event = new ModelRoutingEvent('gemini-pro', 'router-exception', 234, 'some reasoning', true, 'Something went wrong');
653
- logger?.logModelRoutingEvent(event);
654
- const events = getEvents(logger);
655
- expect(events.length).toBe(1);
656
- expect(events[0]).toHaveEventName(EventNames.MODEL_ROUTING);
657
- expect(events[0]).toHaveMetadataValue([
658
- EventMetadataKey.GEMINI_CLI_ROUTING_DECISION,
659
- 'gemini-pro',
660
- ]);
661
- expect(events[0]).toHaveMetadataValue([
662
- EventMetadataKey.GEMINI_CLI_ROUTING_DECISION_SOURCE,
663
- 'router-exception',
664
- ]);
665
- expect(events[0]).toHaveMetadataValue([
666
- EventMetadataKey.GEMINI_CLI_ROUTING_LATENCY_MS,
667
- '234',
668
- ]);
669
- expect(events[0]).toHaveMetadataValue([
670
- EventMetadataKey.GEMINI_CLI_ROUTING_FAILURE,
671
- 'true',
672
- ]);
673
- expect(events[0]).toHaveMetadataValue([
674
- EventMetadataKey.GEMINI_CLI_ROUTING_FAILURE_REASON,
675
- 'Something went wrong',
676
- ]);
677
- });
678
- });
679
- describe('logAgentStartEvent', () => {
680
- it('logs an event with proper fields', () => {
681
- const { logger } = setup();
682
- const event = new AgentStartEvent('agent-123', 'TestAgent');
683
- logger?.logAgentStartEvent(event);
684
- const events = getEvents(logger);
685
- expect(events.length).toBe(1);
686
- expect(events[0]).toHaveEventName(EventNames.AGENT_START);
687
- expect(events[0]).toHaveMetadataValue([
688
- EventMetadataKey.GEMINI_CLI_AGENT_ID,
689
- 'agent-123',
690
- ]);
691
- expect(events[0]).toHaveMetadataValue([
692
- EventMetadataKey.GEMINI_CLI_AGENT_NAME,
693
- 'TestAgent',
694
- ]);
695
- });
696
- });
697
- describe('logExperiments', () => {
698
- it('async path includes exp.gws_experiment field with experiment IDs', async () => {
699
- const { logger } = setup();
700
- const event = logger.createLogEvent(EventNames.START_SESSION, []);
701
- await logger?.enqueueLogEventAfterExperimentsLoadAsync(event);
702
- await vi.runAllTimersAsync();
703
- const events = getEvents(logger);
704
- expect(events.length).toBe(1);
705
- expect(events[0]).toHaveEventName(EventNames.START_SESSION);
706
- // Both metadata and exp.gws_experiment should be populated
707
- expect(events[0]).toHaveMetadataValue([
708
- EventMetadataKey.GEMINI_CLI_EXPERIMENT_IDS,
709
- '123,456,789',
710
- ]);
711
- expect(events[0]).toHaveGwsExperiments([123, 456, 789]);
712
- });
713
- it('async path includes empty gws_experiment array when no experiments', async () => {
714
- const { logger } = setup({
715
- config: {
716
- experiments: {
717
- experimentIds: [],
718
- },
719
- },
720
- });
721
- const event = logger.createLogEvent(EventNames.START_SESSION, []);
722
- await logger?.enqueueLogEventAfterExperimentsLoadAsync(event);
723
- await vi.runAllTimersAsync();
724
- const events = getEvents(logger);
725
- expect(events.length).toBe(1);
726
- expect(events[0]).toHaveGwsExperiments([]);
727
- });
728
- it('non-async path does not include exp.gws_experiment field', () => {
729
- const { logger } = setup();
730
- const event = new AgentStartEvent('agent-123', 'TestAgent');
731
- // logAgentStartEvent uses the non-async enqueueLogEvent path
732
- logger?.logAgentStartEvent(event);
733
- const events = getEvents(logger);
734
- expect(events.length).toBe(1);
735
- // exp.gws_experiment should NOT be present for non-async events
736
- expect(events[0][0].exp).toBeUndefined();
737
- });
738
- });
739
- describe('logAgentFinishEvent', () => {
740
- it('logs an event with proper fields (success)', () => {
741
- const { logger } = setup();
742
- const event = new AgentFinishEvent('agent-123', 'TestAgent', 1000, 5, AgentTerminateMode.GOAL);
743
- logger?.logAgentFinishEvent(event);
744
- const events = getEvents(logger);
745
- expect(events.length).toBe(1);
746
- expect(events[0]).toHaveEventName(EventNames.AGENT_FINISH);
747
- expect(events[0]).toHaveMetadataValue([
748
- EventMetadataKey.GEMINI_CLI_AGENT_ID,
749
- 'agent-123',
750
- ]);
751
- expect(events[0]).toHaveMetadataValue([
752
- EventMetadataKey.GEMINI_CLI_AGENT_NAME,
753
- 'TestAgent',
754
- ]);
755
- expect(events[0]).toHaveMetadataValue([
756
- EventMetadataKey.GEMINI_CLI_AGENT_DURATION_MS,
757
- '1000',
758
- ]);
759
- expect(events[0]).toHaveMetadataValue([
760
- EventMetadataKey.GEMINI_CLI_AGENT_TURN_COUNT,
761
- '5',
762
- ]);
763
- expect(events[0]).toHaveMetadataValue([
764
- EventMetadataKey.GEMINI_CLI_AGENT_TERMINATE_REASON,
765
- 'GOAL',
766
- ]);
767
- });
768
- it('logs an event with proper fields (error)', () => {
769
- const { logger } = setup();
770
- const event = new AgentFinishEvent('agent-123', 'TestAgent', 500, 2, AgentTerminateMode.ERROR);
771
- logger?.logAgentFinishEvent(event);
772
- const events = getEvents(logger);
773
- expect(events.length).toBe(1);
774
- expect(events[0]).toHaveEventName(EventNames.AGENT_FINISH);
775
- expect(events[0]).toHaveMetadataValue([
776
- EventMetadataKey.GEMINI_CLI_AGENT_TERMINATE_REASON,
777
- 'ERROR',
778
- ]);
779
- });
780
- });
781
- describe('logToolCallEvent', () => {
782
- it('logs an event with all diff metadata', () => {
783
- const { logger } = setup();
784
- const completedToolCall = {
785
- request: { name: 'test', args: {}, prompt_id: 'prompt-123' },
786
- response: {
787
- resultDisplay: {
788
- diffStat: {
789
- model_added_lines: 1,
790
- model_removed_lines: 2,
791
- model_added_chars: 3,
792
- model_removed_chars: 4,
793
- user_added_lines: 5,
794
- user_removed_lines: 6,
795
- user_added_chars: 7,
796
- user_removed_chars: 8,
797
- },
798
- },
799
- },
800
- status: 'success',
801
- };
802
- logger?.logToolCallEvent(new ToolCallEvent(completedToolCall));
803
- const events = getEvents(logger);
804
- expect(events.length).toBe(1);
805
- expect(events[0]).toHaveEventName(EventNames.TOOL_CALL);
806
- expect(events[0]).toHaveMetadataValue([
807
- EventMetadataKey.GEMINI_CLI_AI_ADDED_LINES,
808
- '1',
809
- ]);
810
- expect(events[0]).toHaveMetadataValue([
811
- EventMetadataKey.GEMINI_CLI_AI_REMOVED_LINES,
812
- '2',
813
- ]);
814
- expect(events[0]).toHaveMetadataValue([
815
- EventMetadataKey.GEMINI_CLI_AI_ADDED_CHARS,
816
- '3',
817
- ]);
818
- expect(events[0]).toHaveMetadataValue([
819
- EventMetadataKey.GEMINI_CLI_AI_REMOVED_CHARS,
820
- '4',
821
- ]);
822
- expect(events[0]).toHaveMetadataValue([
823
- EventMetadataKey.GEMINI_CLI_USER_ADDED_LINES,
824
- '5',
825
- ]);
826
- expect(events[0]).toHaveMetadataValue([
827
- EventMetadataKey.GEMINI_CLI_USER_REMOVED_LINES,
828
- '6',
829
- ]);
830
- expect(events[0]).toHaveMetadataValue([
831
- EventMetadataKey.GEMINI_CLI_USER_ADDED_CHARS,
832
- '7',
833
- ]);
834
- expect(events[0]).toHaveMetadataValue([
835
- EventMetadataKey.GEMINI_CLI_USER_REMOVED_CHARS,
836
- '8',
837
- ]);
838
- });
839
- it('logs an event with partial diff metadata', () => {
840
- const { logger } = setup();
841
- const completedToolCall = {
842
- request: { name: 'test', args: {}, prompt_id: 'prompt-123' },
843
- response: {
844
- resultDisplay: {
845
- diffStat: {
846
- model_added_lines: 1,
847
- model_removed_lines: 2,
848
- model_added_chars: 3,
849
- model_removed_chars: 4,
850
- },
851
- },
852
- },
853
- status: 'success',
854
- };
855
- logger?.logToolCallEvent(new ToolCallEvent(completedToolCall));
856
- const events = getEvents(logger);
857
- expect(events.length).toBe(1);
858
- expect(events[0]).toHaveEventName(EventNames.TOOL_CALL);
859
- expect(events[0]).toHaveMetadataValue([
860
- EventMetadataKey.GEMINI_CLI_AI_ADDED_LINES,
861
- '1',
862
- ]);
863
- expect(events[0]).toHaveMetadataValue([
864
- EventMetadataKey.GEMINI_CLI_AI_REMOVED_LINES,
865
- '2',
866
- ]);
867
- expect(events[0]).toHaveMetadataValue([
868
- EventMetadataKey.GEMINI_CLI_AI_ADDED_CHARS,
869
- '3',
870
- ]);
871
- expect(events[0]).toHaveMetadataValue([
872
- EventMetadataKey.GEMINI_CLI_AI_REMOVED_CHARS,
873
- '4',
874
- ]);
875
- expect(events[0]).not.toHaveMetadataKey(EventMetadataKey.GEMINI_CLI_USER_ADDED_LINES);
876
- expect(events[0]).not.toHaveMetadataKey(EventMetadataKey.GEMINI_CLI_USER_REMOVED_LINES);
877
- expect(events[0]).not.toHaveMetadataKey(EventMetadataKey.GEMINI_CLI_USER_ADDED_CHARS);
878
- expect(events[0]).not.toHaveMetadataKey(EventMetadataKey.GEMINI_CLI_USER_REMOVED_CHARS);
879
- });
880
- it('does not log diff metadata if diffStat is not present', () => {
881
- const { logger } = setup();
882
- const completedToolCall = {
883
- request: { name: 'test', args: {}, prompt_id: 'prompt-123' },
884
- response: {
885
- resultDisplay: {},
886
- },
887
- status: 'success',
888
- };
889
- logger?.logToolCallEvent(new ToolCallEvent(completedToolCall));
890
- const events = getEvents(logger);
891
- expect(events.length).toBe(1);
892
- expect(events[0]).toHaveEventName(EventNames.TOOL_CALL);
893
- expect(events[0]).not.toHaveMetadataKey(EventMetadataKey.GEMINI_CLI_AI_ADDED_LINES);
894
- });
895
- });
896
- describe('flushIfNeeded', () => {
897
- it('should not flush if the interval has not passed', () => {
898
- const { logger } = setup();
899
- const flushSpy = vi
900
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
901
- .spyOn(logger, 'flushToClearcut')
902
- .mockResolvedValue({ nextRequestWaitMs: 0 });
903
- logger.flushIfNeeded();
904
- expect(flushSpy).not.toHaveBeenCalled();
905
- });
906
- it('should flush if the interval has passed', async () => {
907
- const { logger } = setup();
908
- const flushSpy = vi
909
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
910
- .spyOn(logger, 'flushToClearcut')
911
- .mockResolvedValue({ nextRequestWaitMs: 0 });
912
- // Advance time by more than the flush interval
913
- await vi.advanceTimersByTimeAsync(1000 * 60 * 2);
914
- logger.flushIfNeeded();
915
- expect(flushSpy).toHaveBeenCalled();
916
- });
917
- });
918
- describe('logWebFetchFallbackAttemptEvent', () => {
919
- it('logs an event with the proper name and reason', () => {
920
- const { logger } = setup();
921
- const event = new WebFetchFallbackAttemptEvent('private_ip');
922
- logger?.logWebFetchFallbackAttemptEvent(event);
923
- const events = getEvents(logger);
924
- expect(events.length).toBe(1);
925
- expect(events[0]).toHaveEventName(EventNames.WEB_FETCH_FALLBACK_ATTEMPT);
926
- expect(events[0]).toHaveMetadataValue([
927
- EventMetadataKey.GEMINI_CLI_WEB_FETCH_FALLBACK_REASON,
928
- 'private_ip',
929
- ]);
930
- });
931
- });
932
- describe('logHookCallEvent', () => {
933
- it('logs an event with proper fields', () => {
934
- const { logger } = setup();
935
- const hookName = '/path/to/my/script.sh';
936
- const event = new HookCallEvent('before-tool', 'command', hookName, {}, // input
937
- 150, // duration
938
- true, // success
939
- {}, // output
940
- 0);
941
- logger?.logHookCallEvent(event);
942
- const events = getEvents(logger);
943
- expect(events.length).toBe(1);
944
- expect(events[0]).toHaveEventName(EventNames.HOOK_CALL);
945
- expect(events[0]).toHaveMetadataValue([
946
- EventMetadataKey.GEMINI_CLI_HOOK_EVENT_NAME,
947
- 'before-tool',
948
- ]);
949
- expect(events[0]).toHaveMetadataValue([
950
- EventMetadataKey.GEMINI_CLI_HOOK_DURATION_MS,
951
- '150',
952
- ]);
953
- expect(events[0]).toHaveMetadataValue([
954
- EventMetadataKey.GEMINI_CLI_HOOK_SUCCESS,
955
- 'true',
956
- ]);
957
- expect(events[0]).toHaveMetadataValue([
958
- EventMetadataKey.GEMINI_CLI_HOOK_EXIT_CODE,
959
- '0',
960
- ]);
961
- });
962
- });
963
- });
964
- //# sourceMappingURL=clearcut-logger.test.js.map