@didim365/agent-cli-core 0.1.1 → 0.1.3

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 (1081) hide show
  1. package/dist/src/core/apiKeyCredentialStorage.d.ts +23 -3
  2. package/dist/src/core/apiKeyCredentialStorage.js +56 -16
  3. package/dist/src/core/apiKeyCredentialStorage.js.map +1 -1
  4. package/dist/src/generated/git-commit.d.ts +1 -1
  5. package/dist/src/generated/git-commit.js +1 -1
  6. package/package.json +6 -2
  7. package/dist/docs/00_project/ai_adapter/01-overview.md +0 -172
  8. package/dist/docs/00_project/ai_adapter/02-architecture.md +0 -448
  9. package/dist/docs/00_project/ai_adapter/03-technical-design.md +0 -1470
  10. package/dist/docs/00_project/ai_adapter/04-integration-design.md +0 -1934
  11. package/dist/docs/00_project/ai_adapter/05-implementation-plan.md +0 -336
  12. package/dist/docs/00_project/ai_adapter/06-didiaistudio-plan.md +0 -559
  13. package/dist/docs/00_project/ai_adapter/README.md +0 -145
  14. package/dist/docs/00_project/ai_adapter/agent_service_openapi.json +0 -1
  15. 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
  16. package/dist/docs/00_project/ai_adapter/event-mapping-matrix.md +0 -148
  17. package/dist/docs/00_project/ai_adapter/migration-plan.md +0 -205
  18. package/dist/docs/00_project/ai_adapter/template/00_vibecoding_workflow.md +0 -627
  19. package/dist/docs/00_project/ai_adapter/template/01_todolist_performance_template.md +0 -436
  20. package/dist/docs/00_project/ai_adapter/template/02_code_review_template.md +0 -248
  21. package/dist/docs/00_project/ai_adapter/template/03_work_result_report_template.md +0 -133
  22. package/dist/docs/00_project/ai_adapter/template/100_Python_Performance_Guide.md +0 -472
  23. package/dist/docs/00_project/ai_adapter/template/99_TDD_plan.md +0 -123
  24. package/dist/docs/00_project/ai_adapter/todolist/00_master_implementation_plan.md +0 -433
  25. package/dist/docs/00_project/ai_adapter/todolist/phase1_foundation_todolist.md +0 -726
  26. package/dist/docs/00_project/ai_adapter/todolist/phase2_core_refactoring_todolist.md +0 -974
  27. package/dist/docs/00_project/ai_adapter/todolist/phase3_handoff.md +0 -203
  28. package/dist/docs/00_project/ai_adapter/todolist/phase3_provider_extension_todolist.md +0 -1382
  29. package/dist/docs/00_project/ai_adapter/utility-migration.md +0 -237
  30. package/dist/docs/00_project/ai_adapter/working_history/.gitkeep +0 -0
  31. 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
  32. 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
  33. 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
  34. package/dist/docs/00_project/ai_adapter/working_history/Phase1_M1.3_Provider/354/204/240/355/203/235_20260206.md +0 -269
  35. 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
  36. 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
  37. 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
  38. 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
  39. package/dist/docs/00_project/ai_adapter/working_history/Phase2_M2.2_EventMapper/352/265/254/355/230/204_20260207.md +0 -372
  40. package/dist/docs/00_project/ai_adapter/working_history/Phase2_M2.3_GeminiAdapter/352/265/254/355/230/204_20260208.md +0 -205
  41. 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
  42. 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
  43. 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
  44. 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
  45. 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
  46. 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
  47. 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
  48. 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
  49. 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
  50. 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
  51. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.1.1_ClaudeAdapter/352/265/254/355/230/204_20260209.md +0 -225
  52. 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
  53. 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
  54. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.1.4_ClaudeErrorMapping_20260209.md +0 -98
  55. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.2.A_OpenAIAdapterCore_20260210.md +0 -264
  56. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.2.B_OpenAIStreamConverter_20260210.md +0 -204
  57. 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
  58. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.3_OpenAICompatibleAdapter_20260211.md +0 -251
  59. 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
  60. 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
  61. 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
  62. 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
  63. 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
  64. package/dist/docs/00_project/ai_adapter/working_history/phase2_tradeoff_EventType/354/240/204/355/231/230_20260208.md +0 -286
  65. package/dist/docs/00_project/white_labeling/template/00_vibecoding_workflow.md +0 -627
  66. package/dist/docs/00_project/white_labeling/template/01_todolist_performance_template.md +0 -400
  67. package/dist/docs/00_project/white_labeling/template/02_code_review_template.md +0 -248
  68. package/dist/docs/00_project/white_labeling/template/03_work_result_report_template.md +0 -133
  69. package/dist/docs/00_project/white_labeling/template/100_Python_Performance_Guide.md +0 -472
  70. package/dist/docs/00_project/white_labeling/template/99_TDD_plan.md +0 -123
  71. 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
  72. 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
  73. package/dist/docs/00_project/white_labeling//354/225/261/352/265/254/354/241/260.md +0 -310
  74. package/dist/docs/CONTRIBUTING.md +0 -554
  75. package/dist/docs/ai_adapter/01-overview.md +0 -155
  76. package/dist/docs/ai_adapter/02-architecture.md +0 -452
  77. package/dist/docs/ai_adapter/03-technical-design.md +0 -1470
  78. package/dist/docs/ai_adapter/04-integration-design.md +0 -1904
  79. package/dist/docs/ai_adapter/05-implementation-plan.md +0 -312
  80. package/dist/docs/ai_adapter/06-didiaistudio-plan.md +0 -559
  81. package/dist/docs/ai_adapter/README.md +0 -118
  82. package/dist/docs/ai_adapter/agent_service_openapi.json +0 -1
  83. 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
  84. package/dist/docs/ai_adapter/event-mapping-matrix.md +0 -140
  85. package/dist/docs/ai_adapter/migration-plan.md +0 -205
  86. package/dist/docs/ai_adapter/template/00_vibecoding_workflow.md +0 -636
  87. package/dist/docs/ai_adapter/template/01_todolist_performance_template.md +0 -372
  88. package/dist/docs/ai_adapter/template/02_code_review_template.md +0 -220
  89. package/dist/docs/ai_adapter/template/03_work_result_report_template.md +0 -120
  90. package/dist/docs/ai_adapter/template/100_Python_Performance_Guide.md +0 -453
  91. package/dist/docs/ai_adapter/template/99_TDD_plan.md +0 -111
  92. package/dist/docs/ai_adapter/todolist/00_master_implementation_plan.md +0 -433
  93. package/dist/docs/ai_adapter/todolist/phase1_foundation_todolist.md +0 -726
  94. package/dist/docs/ai_adapter/todolist/phase2_core_refactoring_todolist.md +0 -974
  95. package/dist/docs/ai_adapter/todolist/phase3_handoff.md +0 -203
  96. package/dist/docs/ai_adapter/todolist/phase3_provider_extension_todolist.md +0 -1382
  97. package/dist/docs/ai_adapter/utility-migration.md +0 -237
  98. package/dist/docs/ai_adapter/working_history/.gitkeep +0 -0
  99. 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
  100. 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
  101. package/dist/docs/ai_adapter/working_history/Phase1_M1.2_Adapter/354/235/270/355/224/204/353/235/274_20260203.md +0 -378
  102. package/dist/docs/ai_adapter/working_history/Phase1_M1.3_Provider/354/204/240/355/203/235_20260206.md +0 -269
  103. 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
  104. 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
  105. 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
  106. 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
  107. package/dist/docs/ai_adapter/working_history/Phase2_M2.2_EventMapper/352/265/254/355/230/204_20260207.md +0 -372
  108. package/dist/docs/ai_adapter/working_history/Phase2_M2.3_GeminiAdapter/352/265/254/355/230/204_20260208.md +0 -205
  109. 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
  110. 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
  111. 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
  112. 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
  113. 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
  114. 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
  115. 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
  116. 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
  117. 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
  118. 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
  119. package/dist/docs/ai_adapter/working_history/Phase3_M3.1.1_ClaudeAdapter/352/265/254/355/230/204_20260209.md +0 -225
  120. 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
  121. 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
  122. package/dist/docs/ai_adapter/working_history/Phase3_M3.1.4_ClaudeErrorMapping_20260209.md +0 -98
  123. package/dist/docs/ai_adapter/working_history/Phase3_M3.2.A_OpenAIAdapterCore_20260210.md +0 -264
  124. package/dist/docs/ai_adapter/working_history/Phase3_M3.2.B_OpenAIStreamConverter_20260210.md +0 -204
  125. 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
  126. package/dist/docs/ai_adapter/working_history/Phase3_M3.3_OpenAICompatibleAdapter_20260211.md +0 -251
  127. 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
  128. 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
  129. 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
  130. 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
  131. 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
  132. package/dist/docs/ai_adapter/working_history/phase2_tradeoff_EventType/354/240/204/355/231/230_20260208.md +0 -286
  133. package/dist/docs/api/index.md +0 -5
  134. package/dist/docs/api/providers.md +0 -56
  135. package/dist/docs/architecture.md +0 -80
  136. package/dist/docs/assets/connected_devtools.png +0 -0
  137. package/dist/docs/assets/gemini-screenshot.png +0 -0
  138. package/dist/docs/assets/monitoring-dashboard-logs.png +0 -0
  139. package/dist/docs/assets/monitoring-dashboard-metrics.png +0 -0
  140. package/dist/docs/assets/monitoring-dashboard-overview.png +0 -0
  141. package/dist/docs/assets/release_patch.png +0 -0
  142. package/dist/docs/assets/theme-ansi-light.png +0 -0
  143. package/dist/docs/assets/theme-ansi.png +0 -0
  144. package/dist/docs/assets/theme-atom-one.png +0 -0
  145. package/dist/docs/assets/theme-ayu-light.png +0 -0
  146. package/dist/docs/assets/theme-ayu.png +0 -0
  147. package/dist/docs/assets/theme-custom.png +0 -0
  148. package/dist/docs/assets/theme-default-light.png +0 -0
  149. package/dist/docs/assets/theme-default.png +0 -0
  150. package/dist/docs/assets/theme-dracula.png +0 -0
  151. package/dist/docs/assets/theme-github-light.png +0 -0
  152. package/dist/docs/assets/theme-github.png +0 -0
  153. package/dist/docs/assets/theme-google-light.png +0 -0
  154. package/dist/docs/assets/theme-xcode-light.png +0 -0
  155. package/dist/docs/change_model/model_command_multi_provider_plan.md +0 -221
  156. package/dist/docs/change_model/model_command_multi_provider_todolist.md +0 -206
  157. package/dist/docs/changelogs/index.md +0 -726
  158. package/dist/docs/changelogs/latest.md +0 -370
  159. package/dist/docs/changelogs/preview.md +0 -332
  160. package/dist/docs/cli/authentication.md +0 -3
  161. package/dist/docs/cli/checkpointing.md +0 -94
  162. package/dist/docs/cli/commands.md +0 -375
  163. package/dist/docs/cli/custom-commands.md +0 -315
  164. package/dist/docs/cli/enterprise.md +0 -565
  165. package/dist/docs/cli/gemini-ignore.md +0 -71
  166. package/dist/docs/cli/gemini-md.md +0 -108
  167. package/dist/docs/cli/generation-settings.md +0 -210
  168. package/dist/docs/cli/headless.md +0 -388
  169. package/dist/docs/cli/index.md +0 -65
  170. package/dist/docs/cli/keyboard-shortcuts.md +0 -129
  171. package/dist/docs/cli/model-routing.md +0 -42
  172. package/dist/docs/cli/model.md +0 -62
  173. package/dist/docs/cli/sandbox.md +0 -171
  174. package/dist/docs/cli/session-management.md +0 -158
  175. package/dist/docs/cli/settings.md +0 -130
  176. package/dist/docs/cli/skills.md +0 -188
  177. package/dist/docs/cli/system-prompt.md +0 -125
  178. package/dist/docs/cli/telemetry.md +0 -826
  179. package/dist/docs/cli/themes.md +0 -235
  180. package/dist/docs/cli/token-caching.md +0 -20
  181. package/dist/docs/cli/trusted-folders.md +0 -95
  182. package/dist/docs/cli/tutorials/skills-getting-started.md +0 -124
  183. package/dist/docs/cli/tutorials.md +0 -87
  184. package/dist/docs/cli/uninstall.md +0 -65
  185. package/dist/docs/configuration.md +0 -108
  186. package/dist/docs/core/index.md +0 -105
  187. package/dist/docs/core/long-term-memory-design.md +0 -254
  188. package/dist/docs/core/long-term-memory-proposal.md +0 -112
  189. package/dist/docs/core/memport.md +0 -246
  190. package/dist/docs/core/policy-engine.md +0 -300
  191. package/dist/docs/core/tools-api.md +0 -131
  192. package/dist/docs/examples/proxy-script.md +0 -83
  193. package/dist/docs/extensions/best-practices.md +0 -139
  194. package/dist/docs/extensions/index.md +0 -44
  195. package/dist/docs/extensions/reference.md +0 -312
  196. package/dist/docs/extensions/releasing.md +0 -183
  197. package/dist/docs/extensions/writing-extensions.md +0 -283
  198. package/dist/docs/faq.md +0 -154
  199. package/dist/docs/get-started/authentication.md +0 -321
  200. package/dist/docs/get-started/configuration-v1.md +0 -888
  201. package/dist/docs/get-started/configuration.md +0 -1567
  202. package/dist/docs/get-started/examples.md +0 -219
  203. package/dist/docs/get-started/gemini-3.md +0 -101
  204. package/dist/docs/get-started/index.md +0 -71
  205. package/dist/docs/get-started/installation.md +0 -141
  206. package/dist/docs/hooks/best-practices.md +0 -677
  207. package/dist/docs/hooks/index.md +0 -178
  208. package/dist/docs/hooks/reference.md +0 -322
  209. package/dist/docs/hooks/writing-hooks.md +0 -450
  210. package/dist/docs/ide-integration/ide-companion-spec.md +0 -267
  211. package/dist/docs/ide-integration/index.md +0 -202
  212. package/dist/docs/index.md +0 -153
  213. package/dist/docs/integration-tests.md +0 -211
  214. package/dist/docs/issue-and-pr-automation.md +0 -134
  215. package/dist/docs/local-development.md +0 -128
  216. package/dist/docs/mermaid/context.mmd +0 -103
  217. package/dist/docs/mermaid/render-path.mmd +0 -64
  218. package/dist/docs/migration.md +0 -78
  219. package/dist/docs/npm.md +0 -62
  220. package/dist/docs/providers.md +0 -136
  221. package/dist/docs/quota-and-pricing.md +0 -158
  222. package/dist/docs/release-confidence.md +0 -164
  223. package/dist/docs/releases.md +0 -539
  224. package/dist/docs/sidebar.json +0 -140
  225. package/dist/docs/tools/file-system.md +0 -217
  226. package/dist/docs/tools/index.md +0 -98
  227. package/dist/docs/tools/mcp-server.md +0 -1068
  228. package/dist/docs/tools/memory.md +0 -54
  229. package/dist/docs/tools/shell.md +0 -260
  230. package/dist/docs/tools/todos.md +0 -57
  231. package/dist/docs/tools/web-fetch.md +0 -59
  232. package/dist/docs/tools/web-search.md +0 -42
  233. package/dist/docs/tos-privacy.md +0 -96
  234. package/dist/docs/troubleshooting.md +0 -173
  235. package/dist/src/agents/a2a-client-manager.test.d.ts +0 -6
  236. package/dist/src/agents/a2a-client-manager.test.js +0 -220
  237. package/dist/src/agents/a2a-client-manager.test.js.map +0 -1
  238. package/dist/src/agents/a2aUtils.test.d.ts +0 -6
  239. package/dist/src/agents/a2aUtils.test.js +0 -147
  240. package/dist/src/agents/a2aUtils.test.js.map +0 -1
  241. package/dist/src/agents/acknowledgedAgents.test.d.ts +0 -6
  242. package/dist/src/agents/acknowledgedAgents.test.js +0 -70
  243. package/dist/src/agents/acknowledgedAgents.test.js.map +0 -1
  244. package/dist/src/agents/agent-scheduler.test.d.ts +0 -6
  245. package/dist/src/agents/agent-scheduler.test.js +0 -56
  246. package/dist/src/agents/agent-scheduler.test.js.map +0 -1
  247. package/dist/src/agents/agentLoader.test.d.ts +0 -6
  248. package/dist/src/agents/agentLoader.test.js +0 -304
  249. package/dist/src/agents/agentLoader.test.js.map +0 -1
  250. package/dist/src/agents/cli-help-agent.test.d.ts +0 -6
  251. package/dist/src/agents/cli-help-agent.test.js +0 -67
  252. package/dist/src/agents/cli-help-agent.test.js.map +0 -1
  253. package/dist/src/agents/codebase-investigator.test.d.ts +0 -6
  254. package/dist/src/agents/codebase-investigator.test.js +0 -42
  255. package/dist/src/agents/codebase-investigator.test.js.map +0 -1
  256. package/dist/src/agents/generalist-agent.test.d.ts +0 -6
  257. package/dist/src/agents/generalist-agent.test.js +0 -31
  258. package/dist/src/agents/generalist-agent.test.js.map +0 -1
  259. package/dist/src/agents/local-executor.test.d.ts +0 -6
  260. package/dist/src/agents/local-executor.test.js +0 -1577
  261. package/dist/src/agents/local-executor.test.js.map +0 -1
  262. package/dist/src/agents/local-invocation.test.d.ts +0 -6
  263. package/dist/src/agents/local-invocation.test.js +0 -228
  264. package/dist/src/agents/local-invocation.test.js.map +0 -1
  265. package/dist/src/agents/registry.test.d.ts +0 -6
  266. package/dist/src/agents/registry.test.js +0 -773
  267. package/dist/src/agents/registry.test.js.map +0 -1
  268. package/dist/src/agents/registry_acknowledgement.test.d.ts +0 -6
  269. package/dist/src/agents/registry_acknowledgement.test.js +0 -130
  270. package/dist/src/agents/registry_acknowledgement.test.js.map +0 -1
  271. package/dist/src/agents/remote-invocation.test.d.ts +0 -6
  272. package/dist/src/agents/remote-invocation.test.js +0 -213
  273. package/dist/src/agents/remote-invocation.test.js.map +0 -1
  274. package/dist/src/agents/subagent-tool-wrapper.test.d.ts +0 -6
  275. package/dist/src/agents/subagent-tool-wrapper.test.js +0 -109
  276. package/dist/src/agents/subagent-tool-wrapper.test.js.map +0 -1
  277. package/dist/src/agents/utils.test.d.ts +0 -6
  278. package/dist/src/agents/utils.test.js +0 -87
  279. package/dist/src/agents/utils.test.js.map +0 -1
  280. package/dist/src/availability/fallbackIntegration.test.d.ts +0 -6
  281. package/dist/src/availability/fallbackIntegration.test.js +0 -58
  282. package/dist/src/availability/fallbackIntegration.test.js.map +0 -1
  283. package/dist/src/availability/modelAvailabilityService.test.d.ts +0 -6
  284. package/dist/src/availability/modelAvailabilityService.test.js +0 -140
  285. package/dist/src/availability/modelAvailabilityService.test.js.map +0 -1
  286. package/dist/src/availability/policyCatalog.test.d.ts +0 -6
  287. package/dist/src/availability/policyCatalog.test.js +0 -70
  288. package/dist/src/availability/policyCatalog.test.js.map +0 -1
  289. package/dist/src/availability/policyHelpers.test.d.ts +0 -6
  290. package/dist/src/availability/policyHelpers.test.js +0 -220
  291. package/dist/src/availability/policyHelpers.test.js.map +0 -1
  292. package/dist/src/code_assist/admin/admin_controls.test.d.ts +0 -6
  293. package/dist/src/code_assist/admin/admin_controls.test.js +0 -200
  294. package/dist/src/code_assist/admin/admin_controls.test.js.map +0 -1
  295. package/dist/src/code_assist/codeAssist.test.d.ts +0 -6
  296. package/dist/src/code_assist/codeAssist.test.js +0 -102
  297. package/dist/src/code_assist/codeAssist.test.js.map +0 -1
  298. package/dist/src/code_assist/converter.test.d.ts +0 -6
  299. package/dist/src/code_assist/converter.test.js +0 -391
  300. package/dist/src/code_assist/converter.test.js.map +0 -1
  301. package/dist/src/code_assist/experiments/client_metadata.test.d.ts +0 -6
  302. package/dist/src/code_assist/experiments/client_metadata.test.js +0 -96
  303. package/dist/src/code_assist/experiments/client_metadata.test.js.map +0 -1
  304. package/dist/src/code_assist/experiments/experiments.test.d.ts +0 -6
  305. package/dist/src/code_assist/experiments/experiments.test.js +0 -93
  306. package/dist/src/code_assist/experiments/experiments.test.js.map +0 -1
  307. package/dist/src/code_assist/experiments/experiments_local.test.d.ts +0 -6
  308. package/dist/src/code_assist/experiments/experiments_local.test.js +0 -115
  309. package/dist/src/code_assist/experiments/experiments_local.test.js.map +0 -1
  310. package/dist/src/code_assist/oauth-credential-storage.test.d.ts +0 -6
  311. package/dist/src/code_assist/oauth-credential-storage.test.js +0 -198
  312. package/dist/src/code_assist/oauth-credential-storage.test.js.map +0 -1
  313. package/dist/src/code_assist/oauth2.test.d.ts +0 -6
  314. package/dist/src/code_assist/oauth2.test.js +0 -1065
  315. package/dist/src/code_assist/oauth2.test.js.map +0 -1
  316. package/dist/src/code_assist/server.test.d.ts +0 -6
  317. package/dist/src/code_assist/server.test.js +0 -453
  318. package/dist/src/code_assist/server.test.js.map +0 -1
  319. package/dist/src/code_assist/setup.test.d.ts +0 -6
  320. package/dist/src/code_assist/setup.test.js +0 -517
  321. package/dist/src/code_assist/setup.test.js.map +0 -1
  322. package/dist/src/code_assist/telemetry.test.d.ts +0 -6
  323. package/dist/src/code_assist/telemetry.test.js +0 -301
  324. package/dist/src/code_assist/telemetry.test.js.map +0 -1
  325. package/dist/src/commands/extensions.test.d.ts +0 -6
  326. package/dist/src/commands/extensions.test.js +0 -19
  327. package/dist/src/commands/extensions.test.js.map +0 -1
  328. package/dist/src/commands/init.test.d.ts +0 -6
  329. package/dist/src/commands/init.test.js +0 -25
  330. package/dist/src/commands/init.test.js.map +0 -1
  331. package/dist/src/commands/memory.test.d.ts +0 -6
  332. package/dist/src/commands/memory.test.js +0 -182
  333. package/dist/src/commands/memory.test.js.map +0 -1
  334. package/dist/src/commands/restore.test.d.ts +0 -6
  335. package/dist/src/commands/restore.test.js +0 -137
  336. package/dist/src/commands/restore.test.js.map +0 -1
  337. package/dist/src/config/config.test.d.ts +0 -6
  338. package/dist/src/config/config.test.js +0 -1811
  339. package/dist/src/config/config.test.js.map +0 -1
  340. package/dist/src/config/flashFallback.test.d.ts +0 -6
  341. package/dist/src/config/flashFallback.test.js +0 -63
  342. package/dist/src/config/flashFallback.test.js.map +0 -1
  343. package/dist/src/config/models.test.d.ts +0 -6
  344. package/dist/src/config/models.test.js +0 -146
  345. package/dist/src/config/models.test.js.map +0 -1
  346. package/dist/src/config/storage.test.d.ts +0 -6
  347. package/dist/src/config/storage.test.js +0 -115
  348. package/dist/src/config/storage.test.js.map +0 -1
  349. package/dist/src/confirmation-bus/message-bus.test.d.ts +0 -6
  350. package/dist/src/confirmation-bus/message-bus.test.js +0 -170
  351. package/dist/src/confirmation-bus/message-bus.test.js.map +0 -1
  352. package/dist/src/core/apiKeyCredentialStorage.test.d.ts +0 -6
  353. package/dist/src/core/apiKeyCredentialStorage.test.js +0 -71
  354. package/dist/src/core/apiKeyCredentialStorage.test.js.map +0 -1
  355. package/dist/src/core/baseLlmClient.test.d.ts +0 -6
  356. package/dist/src/core/baseLlmClient.test.js +0 -569
  357. package/dist/src/core/baseLlmClient.test.js.map +0 -1
  358. package/dist/src/core/baseLlmClient_new_types.test.d.ts +0 -1
  359. package/dist/src/core/baseLlmClient_new_types.test.js +0 -387
  360. package/dist/src/core/baseLlmClient_new_types.test.js.map +0 -1
  361. package/dist/src/core/client.test.d.ts +0 -6
  362. package/dist/src/core/client.test.js +0 -2654
  363. package/dist/src/core/client.test.js.map +0 -1
  364. package/dist/src/core/contentGenerator.multiProvider.test.d.ts +0 -6
  365. package/dist/src/core/contentGenerator.multiProvider.test.js +0 -314
  366. package/dist/src/core/contentGenerator.multiProvider.test.js.map +0 -1
  367. package/dist/src/core/contentGenerator.test.d.ts +0 -6
  368. package/dist/src/core/contentGenerator.test.js +0 -299
  369. package/dist/src/core/contentGenerator.test.js.map +0 -1
  370. package/dist/src/core/contentGenerator_new_types.test.d.ts +0 -6
  371. package/dist/src/core/contentGenerator_new_types.test.js +0 -292
  372. package/dist/src/core/contentGenerator_new_types.test.js.map +0 -1
  373. package/dist/src/core/coreToolHookTriggers.test.d.ts +0 -6
  374. package/dist/src/core/coreToolHookTriggers.test.js +0 -159
  375. package/dist/src/core/coreToolHookTriggers.test.js.map +0 -1
  376. package/dist/src/core/coreToolScheduler.test.d.ts +0 -6
  377. package/dist/src/core/coreToolScheduler.test.js +0 -1684
  378. package/dist/src/core/coreToolScheduler.test.js.map +0 -1
  379. package/dist/src/core/fakeContentGenerator.test.d.ts +0 -6
  380. package/dist/src/core/fakeContentGenerator.test.js +0 -127
  381. package/dist/src/core/fakeContentGenerator.test.js.map +0 -1
  382. package/dist/src/core/geminiChat.test.d.ts +0 -6
  383. package/dist/src/core/geminiChat.test.js +0 -1773
  384. package/dist/src/core/geminiChat.test.js.map +0 -1
  385. package/dist/src/core/geminiChat_network_retry.test.d.ts +0 -6
  386. package/dist/src/core/geminiChat_network_retry.test.js +0 -201
  387. package/dist/src/core/geminiChat_network_retry.test.js.map +0 -1
  388. package/dist/src/core/logger.test.d.ts +0 -6
  389. package/dist/src/core/logger.test.js +0 -550
  390. package/dist/src/core/logger.test.js.map +0 -1
  391. package/dist/src/core/loggingContentGenerator.test.d.ts +0 -6
  392. package/dist/src/core/loggingContentGenerator.test.js +0 -221
  393. package/dist/src/core/loggingContentGenerator.test.js.map +0 -1
  394. package/dist/src/core/prompts-substitution.test.d.ts +0 -6
  395. package/dist/src/core/prompts-substitution.test.js +0 -101
  396. package/dist/src/core/prompts-substitution.test.js.map +0 -1
  397. package/dist/src/core/prompts.test.d.ts +0 -6
  398. package/dist/src/core/prompts.test.js +0 -391
  399. package/dist/src/core/prompts.test.js.map +0 -1
  400. package/dist/src/core/recordingContentGenerator.test.d.ts +0 -6
  401. package/dist/src/core/recordingContentGenerator.test.js +0 -101
  402. package/dist/src/core/recordingContentGenerator.test.js.map +0 -1
  403. package/dist/src/core/tokenLimits.test.d.ts +0 -6
  404. package/dist/src/core/tokenLimits.test.js +0 -30
  405. package/dist/src/core/tokenLimits.test.js.map +0 -1
  406. package/dist/src/core/turn.test.d.ts +0 -6
  407. package/dist/src/core/turn.test.js +0 -739
  408. package/dist/src/core/turn.test.js.map +0 -1
  409. package/dist/src/fallback/handler.test.d.ts +0 -6
  410. package/dist/src/fallback/handler.test.js +0 -242
  411. package/dist/src/fallback/handler.test.js.map +0 -1
  412. package/dist/src/hooks/hookAggregator.test.d.ts +0 -6
  413. package/dist/src/hooks/hookAggregator.test.js +0 -387
  414. package/dist/src/hooks/hookAggregator.test.js.map +0 -1
  415. package/dist/src/hooks/hookEventHandler.test.d.ts +0 -6
  416. package/dist/src/hooks/hookEventHandler.test.js +0 -603
  417. package/dist/src/hooks/hookEventHandler.test.js.map +0 -1
  418. package/dist/src/hooks/hookPlanner.test.d.ts +0 -6
  419. package/dist/src/hooks/hookPlanner.test.js +0 -315
  420. package/dist/src/hooks/hookPlanner.test.js.map +0 -1
  421. package/dist/src/hooks/hookRegistry.test.d.ts +0 -6
  422. package/dist/src/hooks/hookRegistry.test.js +0 -529
  423. package/dist/src/hooks/hookRegistry.test.js.map +0 -1
  424. package/dist/src/hooks/hookRunner.test.d.ts +0 -6
  425. package/dist/src/hooks/hookRunner.test.js +0 -606
  426. package/dist/src/hooks/hookRunner.test.js.map +0 -1
  427. package/dist/src/hooks/hookSystem.test.d.ts +0 -6
  428. package/dist/src/hooks/hookSystem.test.js +0 -330
  429. package/dist/src/hooks/hookSystem.test.js.map +0 -1
  430. package/dist/src/hooks/hookSystem_new_types.test.d.ts +0 -6
  431. package/dist/src/hooks/hookSystem_new_types.test.js +0 -243
  432. package/dist/src/hooks/hookSystem_new_types.test.js.map +0 -1
  433. package/dist/src/hooks/hookTranslator.test.d.ts +0 -6
  434. package/dist/src/hooks/hookTranslator.test.js +0 -192
  435. package/dist/src/hooks/hookTranslator.test.js.map +0 -1
  436. package/dist/src/hooks/trustedHooks.test.d.ts +0 -6
  437. package/dist/src/hooks/trustedHooks.test.js +0 -154
  438. package/dist/src/hooks/trustedHooks.test.js.map +0 -1
  439. package/dist/src/hooks/types.test.d.ts +0 -6
  440. package/dist/src/hooks/types.test.js +0 -278
  441. package/dist/src/hooks/types.test.js.map +0 -1
  442. package/dist/src/ide/detect-ide.test.d.ts +0 -6
  443. package/dist/src/ide/detect-ide.test.js +0 -195
  444. package/dist/src/ide/detect-ide.test.js.map +0 -1
  445. package/dist/src/ide/ide-client.test.d.ts +0 -6
  446. package/dist/src/ide/ide-client.test.js +0 -753
  447. package/dist/src/ide/ide-client.test.js.map +0 -1
  448. package/dist/src/ide/ide-installer.test.d.ts +0 -6
  449. package/dist/src/ide/ide-installer.test.js +0 -193
  450. package/dist/src/ide/ide-installer.test.js.map +0 -1
  451. package/dist/src/ide/ideContext.test.d.ts +0 -6
  452. package/dist/src/ide/ideContext.test.js +0 -393
  453. package/dist/src/ide/ideContext.test.js.map +0 -1
  454. package/dist/src/ide/process-utils.test.d.ts +0 -6
  455. package/dist/src/ide/process-utils.test.js +0 -151
  456. package/dist/src/ide/process-utils.test.js.map +0 -1
  457. package/dist/src/index.test.d.ts +0 -6
  458. package/dist/src/index.test.js +0 -53
  459. package/dist/src/index.test.js.map +0 -1
  460. package/dist/src/mcp/google-auth-provider.test.d.ts +0 -6
  461. package/dist/src/mcp/google-auth-provider.test.js +0 -167
  462. package/dist/src/mcp/google-auth-provider.test.js.map +0 -1
  463. package/dist/src/mcp/oauth-provider.test.d.ts +0 -6
  464. package/dist/src/mcp/oauth-provider.test.js +0 -1355
  465. package/dist/src/mcp/oauth-provider.test.js.map +0 -1
  466. package/dist/src/mcp/oauth-token-storage.test.d.ts +0 -6
  467. package/dist/src/mcp/oauth-token-storage.test.js +0 -305
  468. package/dist/src/mcp/oauth-token-storage.test.js.map +0 -1
  469. package/dist/src/mcp/oauth-utils.test.d.ts +0 -6
  470. package/dist/src/mcp/oauth-utils.test.js +0 -289
  471. package/dist/src/mcp/oauth-utils.test.js.map +0 -1
  472. package/dist/src/mcp/sa-impersonation-provider.test.d.ts +0 -6
  473. package/dist/src/mcp/sa-impersonation-provider.test.js +0 -117
  474. package/dist/src/mcp/sa-impersonation-provider.test.js.map +0 -1
  475. package/dist/src/mcp/token-storage/base-token-storage.test.d.ts +0 -6
  476. package/dist/src/mcp/token-storage/base-token-storage.test.js +0 -151
  477. package/dist/src/mcp/token-storage/base-token-storage.test.js.map +0 -1
  478. package/dist/src/mcp/token-storage/file-token-storage.test.d.ts +0 -6
  479. package/dist/src/mcp/token-storage/file-token-storage.test.js +0 -238
  480. package/dist/src/mcp/token-storage/file-token-storage.test.js.map +0 -1
  481. package/dist/src/mcp/token-storage/hybrid-token-storage.test.d.ts +0 -6
  482. package/dist/src/mcp/token-storage/hybrid-token-storage.test.js +0 -193
  483. package/dist/src/mcp/token-storage/hybrid-token-storage.test.js.map +0 -1
  484. package/dist/src/mcp/token-storage/keychain-token-storage.test.d.ts +0 -6
  485. package/dist/src/mcp/token-storage/keychain-token-storage.test.js +0 -305
  486. package/dist/src/mcp/token-storage/keychain-token-storage.test.js.map +0 -1
  487. package/dist/src/output/json-formatter.test.d.ts +0 -6
  488. package/dist/src/output/json-formatter.test.js +0 -294
  489. package/dist/src/output/json-formatter.test.js.map +0 -1
  490. package/dist/src/output/stream-json-formatter.test.d.ts +0 -6
  491. package/dist/src/output/stream-json-formatter.test.js +0 -477
  492. package/dist/src/output/stream-json-formatter.test.js.map +0 -1
  493. package/dist/src/policy/config.test.d.ts +0 -6
  494. package/dist/src/policy/config.test.js +0 -598
  495. package/dist/src/policy/config.test.js.map +0 -1
  496. package/dist/src/policy/persistence.test.d.ts +0 -6
  497. package/dist/src/policy/persistence.test.js +0 -154
  498. package/dist/src/policy/persistence.test.js.map +0 -1
  499. package/dist/src/policy/policy-engine.test.d.ts +0 -6
  500. package/dist/src/policy/policy-engine.test.js +0 -1299
  501. package/dist/src/policy/policy-engine.test.js.map +0 -1
  502. package/dist/src/policy/policy-updater.test.d.ts +0 -6
  503. package/dist/src/policy/policy-updater.test.js +0 -116
  504. package/dist/src/policy/policy-updater.test.js.map +0 -1
  505. package/dist/src/policy/shell-safety.test.d.ts +0 -6
  506. package/dist/src/policy/shell-safety.test.js +0 -438
  507. package/dist/src/policy/shell-safety.test.js.map +0 -1
  508. package/dist/src/policy/toml-loader.test.d.ts +0 -6
  509. package/dist/src/policy/toml-loader.test.js +0 -409
  510. package/dist/src/policy/toml-loader.test.js.map +0 -1
  511. package/dist/src/policy/utils.test.d.ts +0 -6
  512. package/dist/src/policy/utils.test.js +0 -92
  513. package/dist/src/policy/utils.test.js.map +0 -1
  514. package/dist/src/prompts/mcp-prompts.test.d.ts +0 -6
  515. package/dist/src/prompts/mcp-prompts.test.js +0 -39
  516. package/dist/src/prompts/mcp-prompts.test.js.map +0 -1
  517. package/dist/src/prompts/prompt-registry.test.d.ts +0 -6
  518. package/dist/src/prompts/prompt-registry.test.js +0 -96
  519. package/dist/src/prompts/prompt-registry.test.js.map +0 -1
  520. package/dist/src/providers/__tests__/bundleSize.test.d.ts +0 -6
  521. package/dist/src/providers/__tests__/bundleSize.test.js +0 -75
  522. package/dist/src/providers/__tests__/bundleSize.test.js.map +0 -1
  523. package/dist/src/providers/__tests__/errorHandling.integration.test.d.ts +0 -6
  524. package/dist/src/providers/__tests__/errorHandling.integration.test.js +0 -339
  525. package/dist/src/providers/__tests__/errorHandling.integration.test.js.map +0 -1
  526. package/dist/src/providers/__tests__/multiProvider.integration.test.d.ts +0 -6
  527. package/dist/src/providers/__tests__/multiProvider.integration.test.js +0 -419
  528. package/dist/src/providers/__tests__/multiProvider.integration.test.js.map +0 -1
  529. package/dist/src/providers/__tests__/performance.test.d.ts +0 -6
  530. package/dist/src/providers/__tests__/performance.test.js +0 -270
  531. package/dist/src/providers/__tests__/performance.test.js.map +0 -1
  532. package/dist/src/providers/__tests__/providerConfigIntegration.test.d.ts +0 -6
  533. package/dist/src/providers/__tests__/providerConfigIntegration.test.js +0 -245
  534. package/dist/src/providers/__tests__/providerConfigIntegration.test.js.map +0 -1
  535. package/dist/src/providers/baseAdapter.test.d.ts +0 -1
  536. package/dist/src/providers/baseAdapter.test.js +0 -142
  537. package/dist/src/providers/baseAdapter.test.js.map +0 -1
  538. package/dist/src/providers/claude/adapter.test.d.ts +0 -6
  539. package/dist/src/providers/claude/adapter.test.js +0 -628
  540. package/dist/src/providers/claude/adapter.test.js.map +0 -1
  541. package/dist/src/providers/claude/bootstrap.test.d.ts +0 -6
  542. package/dist/src/providers/claude/bootstrap.test.js +0 -74
  543. package/dist/src/providers/claude/bootstrap.test.js.map +0 -1
  544. package/dist/src/providers/claude/converter.test.d.ts +0 -6
  545. package/dist/src/providers/claude/converter.test.js +0 -1002
  546. package/dist/src/providers/claude/converter.test.js.map +0 -1
  547. package/dist/src/providers/claude/exports.test.d.ts +0 -6
  548. package/dist/src/providers/claude/exports.test.js +0 -40
  549. package/dist/src/providers/claude/exports.test.js.map +0 -1
  550. package/dist/src/providers/configAdapter.test.d.ts +0 -1
  551. package/dist/src/providers/configAdapter.test.js +0 -150
  552. package/dist/src/providers/configAdapter.test.js.map +0 -1
  553. package/dist/src/providers/contentResolver.test.d.ts +0 -1
  554. package/dist/src/providers/contentResolver.test.js +0 -89
  555. package/dist/src/providers/contentResolver.test.js.map +0 -1
  556. package/dist/src/providers/factory.test.d.ts +0 -1
  557. package/dist/src/providers/factory.test.js +0 -151
  558. package/dist/src/providers/factory.test.js.map +0 -1
  559. package/dist/src/providers/gemini/adapterBridge.test.d.ts +0 -6
  560. package/dist/src/providers/gemini/adapterBridge.test.js +0 -164
  561. package/dist/src/providers/gemini/adapterBridge.test.js.map +0 -1
  562. package/dist/src/providers/gemini/bootstrap.test.d.ts +0 -6
  563. package/dist/src/providers/gemini/bootstrap.test.js +0 -72
  564. package/dist/src/providers/gemini/bootstrap.test.js.map +0 -1
  565. package/dist/src/providers/gemini/configConverter.test.d.ts +0 -6
  566. package/dist/src/providers/gemini/configConverter.test.js +0 -218
  567. package/dist/src/providers/gemini/configConverter.test.js.map +0 -1
  568. package/dist/src/providers/gemini/errorClassifier.test.d.ts +0 -6
  569. package/dist/src/providers/gemini/errorClassifier.test.js +0 -83
  570. package/dist/src/providers/gemini/errorClassifier.test.js.map +0 -1
  571. package/dist/src/providers/gemini/eventMapper.test.d.ts +0 -6
  572. package/dist/src/providers/gemini/eventMapper.test.js +0 -502
  573. package/dist/src/providers/gemini/eventMapper.test.js.map +0 -1
  574. package/dist/src/providers/gemini/exports.test.d.ts +0 -6
  575. package/dist/src/providers/gemini/exports.test.js +0 -90
  576. package/dist/src/providers/gemini/exports.test.js.map +0 -1
  577. package/dist/src/providers/gemini/featureFlag.test.d.ts +0 -6
  578. package/dist/src/providers/gemini/featureFlag.test.js +0 -139
  579. package/dist/src/providers/gemini/featureFlag.test.js.map +0 -1
  580. package/dist/src/providers/gemini/geminiAdapter.test.d.ts +0 -6
  581. package/dist/src/providers/gemini/geminiAdapter.test.js +0 -279
  582. package/dist/src/providers/gemini/geminiAdapter.test.js.map +0 -1
  583. package/dist/src/providers/gemini/geminiConverter.test.d.ts +0 -6
  584. package/dist/src/providers/gemini/geminiConverter.test.js +0 -474
  585. package/dist/src/providers/gemini/geminiConverter.test.js.map +0 -1
  586. package/dist/src/providers/gemini/geminiParity.test.d.ts +0 -6
  587. package/dist/src/providers/gemini/geminiParity.test.js +0 -754
  588. package/dist/src/providers/gemini/geminiParity.test.js.map +0 -1
  589. package/dist/src/providers/gemini/geminiStream.test.d.ts +0 -6
  590. package/dist/src/providers/gemini/geminiStream.test.js +0 -391
  591. package/dist/src/providers/gemini/geminiStream.test.js.map +0 -1
  592. package/dist/src/providers/gemini/historyBuilder.test.d.ts +0 -6
  593. package/dist/src/providers/gemini/historyBuilder.test.js +0 -207
  594. package/dist/src/providers/gemini/historyBuilder.test.js.map +0 -1
  595. package/dist/src/providers/gemini/requestBuilder.test.d.ts +0 -6
  596. package/dist/src/providers/gemini/requestBuilder.test.js +0 -358
  597. package/dist/src/providers/gemini/requestBuilder.test.js.map +0 -1
  598. package/dist/src/providers/gemini/streamConverter.test.d.ts +0 -6
  599. package/dist/src/providers/gemini/streamConverter.test.js +0 -131
  600. package/dist/src/providers/gemini/streamConverter.test.js.map +0 -1
  601. package/dist/src/providers/modelSpec.test.d.ts +0 -1
  602. package/dist/src/providers/modelSpec.test.js +0 -119
  603. package/dist/src/providers/modelSpec.test.js.map +0 -1
  604. package/dist/src/providers/openai/adapter.test.d.ts +0 -6
  605. package/dist/src/providers/openai/adapter.test.js +0 -274
  606. package/dist/src/providers/openai/adapter.test.js.map +0 -1
  607. package/dist/src/providers/openai/bootstrap.test.d.ts +0 -6
  608. package/dist/src/providers/openai/bootstrap.test.js +0 -76
  609. package/dist/src/providers/openai/bootstrap.test.js.map +0 -1
  610. package/dist/src/providers/openai/converter.test.d.ts +0 -6
  611. package/dist/src/providers/openai/converter.test.js +0 -1133
  612. package/dist/src/providers/openai/converter.test.js.map +0 -1
  613. package/dist/src/providers/openai-compatible/__tests__/compatibility.test.d.ts +0 -6
  614. package/dist/src/providers/openai-compatible/__tests__/compatibility.test.js +0 -356
  615. package/dist/src/providers/openai-compatible/__tests__/compatibility.test.js.map +0 -1
  616. package/dist/src/providers/openai-compatible/adapter.test.d.ts +0 -6
  617. package/dist/src/providers/openai-compatible/adapter.test.js +0 -240
  618. package/dist/src/providers/openai-compatible/adapter.test.js.map +0 -1
  619. package/dist/src/providers/openai-compatible/bootstrap.test.d.ts +0 -6
  620. package/dist/src/providers/openai-compatible/bootstrap.test.js +0 -145
  621. package/dist/src/providers/openai-compatible/bootstrap.test.js.map +0 -1
  622. package/dist/src/providers/openai-compatible/promptBuilder.test.d.ts +0 -6
  623. package/dist/src/providers/openai-compatible/promptBuilder.test.js +0 -154
  624. package/dist/src/providers/openai-compatible/promptBuilder.test.js.map +0 -1
  625. package/dist/src/providers/providerConfig.test.d.ts +0 -1
  626. package/dist/src/providers/providerConfig.test.js +0 -145
  627. package/dist/src/providers/providerConfig.test.js.map +0 -1
  628. package/dist/src/providers/providerConfigIntegration.test.d.ts +0 -6
  629. package/dist/src/providers/providerConfigIntegration.test.js +0 -187
  630. package/dist/src/providers/providerConfigIntegration.test.js.map +0 -1
  631. package/dist/src/providers/providerSelector.test.d.ts +0 -1
  632. package/dist/src/providers/providerSelector.test.js +0 -199
  633. package/dist/src/providers/providerSelector.test.js.map +0 -1
  634. package/dist/src/providers/providerTypes.test.d.ts +0 -1
  635. package/dist/src/providers/providerTypes.test.js +0 -95
  636. package/dist/src/providers/providerTypes.test.js.map +0 -1
  637. package/dist/src/providers/registry.test.d.ts +0 -1
  638. package/dist/src/providers/registry.test.js +0 -207
  639. package/dist/src/providers/registry.test.js.map +0 -1
  640. package/dist/src/providers/streamAssembler.test.d.ts +0 -1
  641. package/dist/src/providers/streamAssembler.test.js +0 -247
  642. package/dist/src/providers/streamAssembler.test.js.map +0 -1
  643. package/dist/src/providers/telemetryBridge.test.d.ts +0 -6
  644. package/dist/src/providers/telemetryBridge.test.js +0 -235
  645. package/dist/src/providers/telemetryBridge.test.js.map +0 -1
  646. package/dist/src/providers/types.test.d.ts +0 -6
  647. package/dist/src/providers/types.test.js +0 -253
  648. package/dist/src/providers/types.test.js.map +0 -1
  649. package/dist/src/resources/resource-registry.test.d.ts +0 -6
  650. package/dist/src/resources/resource-registry.test.js +0 -54
  651. package/dist/src/resources/resource-registry.test.js.map +0 -1
  652. package/dist/src/routing/modelRouterService.test.d.ts +0 -6
  653. package/dist/src/routing/modelRouterService.test.js +0 -106
  654. package/dist/src/routing/modelRouterService.test.js.map +0 -1
  655. package/dist/src/routing/strategies/classifierStrategy.test.d.ts +0 -6
  656. package/dist/src/routing/strategies/classifierStrategy.test.js +0 -249
  657. package/dist/src/routing/strategies/classifierStrategy.test.js.map +0 -1
  658. package/dist/src/routing/strategies/compositeStrategy.test.d.ts +0 -6
  659. package/dist/src/routing/strategies/compositeStrategy.test.js +0 -124
  660. package/dist/src/routing/strategies/compositeStrategy.test.js.map +0 -1
  661. package/dist/src/routing/strategies/defaultStrategy.test.d.ts +0 -6
  662. package/dist/src/routing/strategies/defaultStrategy.test.js +0 -102
  663. package/dist/src/routing/strategies/defaultStrategy.test.js.map +0 -1
  664. package/dist/src/routing/strategies/fallbackStrategy.test.d.ts +0 -6
  665. package/dist/src/routing/strategies/fallbackStrategy.test.js +0 -96
  666. package/dist/src/routing/strategies/fallbackStrategy.test.js.map +0 -1
  667. package/dist/src/routing/strategies/numericalClassifierStrategy.test.d.ts +0 -6
  668. package/dist/src/routing/strategies/numericalClassifierStrategy.test.js +0 -367
  669. package/dist/src/routing/strategies/numericalClassifierStrategy.test.js.map +0 -1
  670. package/dist/src/routing/strategies/overrideStrategy.test.d.ts +0 -6
  671. package/dist/src/routing/strategies/overrideStrategy.test.js +0 -59
  672. package/dist/src/routing/strategies/overrideStrategy.test.js.map +0 -1
  673. package/dist/src/safety/built-in.test.d.ts +0 -6
  674. package/dist/src/safety/built-in.test.js +0 -199
  675. package/dist/src/safety/built-in.test.js.map +0 -1
  676. package/dist/src/safety/checker-runner.test.d.ts +0 -6
  677. package/dist/src/safety/checker-runner.test.js +0 -238
  678. package/dist/src/safety/checker-runner.test.js.map +0 -1
  679. package/dist/src/safety/context-builder.test.d.ts +0 -6
  680. package/dist/src/safety/context-builder.test.js +0 -49
  681. package/dist/src/safety/context-builder.test.js.map +0 -1
  682. package/dist/src/safety/registry.test.d.ts +0 -6
  683. package/dist/src/safety/registry.test.js +0 -31
  684. package/dist/src/safety/registry.test.js.map +0 -1
  685. package/dist/src/scheduler/confirmation.test.d.ts +0 -6
  686. package/dist/src/scheduler/confirmation.test.js +0 -325
  687. package/dist/src/scheduler/confirmation.test.js.map +0 -1
  688. package/dist/src/scheduler/policy.test.d.ts +0 -6
  689. package/dist/src/scheduler/policy.test.js +0 -299
  690. package/dist/src/scheduler/policy.test.js.map +0 -1
  691. package/dist/src/scheduler/scheduler.test.d.ts +0 -6
  692. package/dist/src/scheduler/scheduler.test.js +0 -822
  693. package/dist/src/scheduler/scheduler.test.js.map +0 -1
  694. package/dist/src/scheduler/state-manager.test.d.ts +0 -6
  695. package/dist/src/scheduler/state-manager.test.js +0 -429
  696. package/dist/src/scheduler/state-manager.test.js.map +0 -1
  697. package/dist/src/scheduler/tool-executor.test.d.ts +0 -6
  698. package/dist/src/scheduler/tool-executor.test.js +0 -232
  699. package/dist/src/scheduler/tool-executor.test.js.map +0 -1
  700. package/dist/src/scheduler/tool-modifier.test.d.ts +0 -6
  701. package/dist/src/scheduler/tool-modifier.test.js +0 -159
  702. package/dist/src/scheduler/tool-modifier.test.js.map +0 -1
  703. package/dist/src/services/chatCompressionService.test.d.ts +0 -6
  704. package/dist/src/services/chatCompressionService.test.js +0 -573
  705. package/dist/src/services/chatCompressionService.test.js.map +0 -1
  706. package/dist/src/services/chatRecordingService.test.d.ts +0 -6
  707. package/dist/src/services/chatRecordingService.test.js +0 -486
  708. package/dist/src/services/chatRecordingService.test.js.map +0 -1
  709. package/dist/src/services/contextManager.test.d.ts +0 -6
  710. package/dist/src/services/contextManager.test.js +0 -104
  711. package/dist/src/services/contextManager.test.js.map +0 -1
  712. package/dist/src/services/environmentSanitization.test.d.ts +0 -6
  713. package/dist/src/services/environmentSanitization.test.js +0 -284
  714. package/dist/src/services/environmentSanitization.test.js.map +0 -1
  715. package/dist/src/services/fileDiscoveryService.test.d.ts +0 -6
  716. package/dist/src/services/fileDiscoveryService.test.js +0 -223
  717. package/dist/src/services/fileDiscoveryService.test.js.map +0 -1
  718. package/dist/src/services/fileSystemService.test.d.ts +0 -6
  719. package/dist/src/services/fileSystemService.test.js +0 -41
  720. package/dist/src/services/fileSystemService.test.js.map +0 -1
  721. package/dist/src/services/gitService.test.d.ts +0 -6
  722. package/dist/src/services/gitService.test.js +0 -264
  723. package/dist/src/services/gitService.test.js.map +0 -1
  724. package/dist/src/services/loopDetectionService.test.d.ts +0 -6
  725. package/dist/src/services/loopDetectionService.test.js +0 -881
  726. package/dist/src/services/loopDetectionService.test.js.map +0 -1
  727. package/dist/src/services/modelConfig.golden.test.d.ts +0 -6
  728. package/dist/src/services/modelConfig.golden.test.js +0 -74
  729. package/dist/src/services/modelConfig.golden.test.js.map +0 -1
  730. package/dist/src/services/modelConfig.integration.test.d.ts +0 -6
  731. package/dist/src/services/modelConfig.integration.test.js +0 -247
  732. package/dist/src/services/modelConfig.integration.test.js.map +0 -1
  733. package/dist/src/services/modelConfigBridge.test.d.ts +0 -6
  734. package/dist/src/services/modelConfigBridge.test.js +0 -410
  735. package/dist/src/services/modelConfigBridge.test.js.map +0 -1
  736. package/dist/src/services/modelConfigService.test.d.ts +0 -6
  737. package/dist/src/services/modelConfigService.test.js +0 -868
  738. package/dist/src/services/modelConfigService.test.js.map +0 -1
  739. package/dist/src/services/sessionSummaryService.test.d.ts +0 -6
  740. package/dist/src/services/sessionSummaryService.test.js +0 -785
  741. package/dist/src/services/sessionSummaryService.test.js.map +0 -1
  742. package/dist/src/services/sessionSummaryUtils.test.d.ts +0 -6
  743. package/dist/src/services/sessionSummaryUtils.test.js +0 -160
  744. package/dist/src/services/sessionSummaryUtils.test.js.map +0 -1
  745. package/dist/src/services/shellExecutionService.test.d.ts +0 -6
  746. package/dist/src/services/shellExecutionService.test.js +0 -1080
  747. package/dist/src/services/shellExecutionService.test.js.map +0 -1
  748. package/dist/src/skills/skillLoader.test.d.ts +0 -6
  749. package/dist/src/skills/skillLoader.test.js +0 -185
  750. package/dist/src/skills/skillLoader.test.js.map +0 -1
  751. package/dist/src/skills/skillManager.test.d.ts +0 -6
  752. package/dist/src/skills/skillManager.test.js +0 -297
  753. package/dist/src/skills/skillManager.test.js.map +0 -1
  754. package/dist/src/telemetry/activity-detector.test.d.ts +0 -6
  755. package/dist/src/telemetry/activity-detector.test.js +0 -136
  756. package/dist/src/telemetry/activity-detector.test.js.map +0 -1
  757. package/dist/src/telemetry/activity-monitor.test.d.ts +0 -6
  758. package/dist/src/telemetry/activity-monitor.test.js +0 -251
  759. package/dist/src/telemetry/activity-monitor.test.js.map +0 -1
  760. package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.d.ts +0 -19
  761. package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.js +0 -964
  762. package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.js.map +0 -1
  763. package/dist/src/telemetry/config.test.d.ts +0 -6
  764. package/dist/src/telemetry/config.test.js +0 -149
  765. package/dist/src/telemetry/config.test.js.map +0 -1
  766. package/dist/src/telemetry/gcp-exporters.test.d.ts +0 -6
  767. package/dist/src/telemetry/gcp-exporters.test.js +0 -318
  768. package/dist/src/telemetry/gcp-exporters.test.js.map +0 -1
  769. package/dist/src/telemetry/high-water-mark-tracker.test.d.ts +0 -6
  770. package/dist/src/telemetry/high-water-mark-tracker.test.js +0 -152
  771. package/dist/src/telemetry/high-water-mark-tracker.test.js.map +0 -1
  772. package/dist/src/telemetry/integration.test.circular.d.ts +0 -6
  773. package/dist/src/telemetry/integration.test.circular.js +0 -54
  774. package/dist/src/telemetry/integration.test.circular.js.map +0 -1
  775. package/dist/src/telemetry/loggers.test.circular.d.ts +0 -6
  776. package/dist/src/telemetry/loggers.test.circular.js +0 -107
  777. package/dist/src/telemetry/loggers.test.circular.js.map +0 -1
  778. package/dist/src/telemetry/loggers.test.d.ts +0 -6
  779. package/dist/src/telemetry/loggers.test.js +0 -1618
  780. package/dist/src/telemetry/loggers.test.js.map +0 -1
  781. package/dist/src/telemetry/memory-monitor.test.d.ts +0 -6
  782. package/dist/src/telemetry/memory-monitor.test.js +0 -472
  783. package/dist/src/telemetry/memory-monitor.test.js.map +0 -1
  784. package/dist/src/telemetry/metrics.test.d.ts +0 -6
  785. package/dist/src/telemetry/metrics.test.js +0 -1176
  786. package/dist/src/telemetry/metrics.test.js.map +0 -1
  787. package/dist/src/telemetry/rate-limiter.test.d.ts +0 -6
  788. package/dist/src/telemetry/rate-limiter.test.js +0 -207
  789. package/dist/src/telemetry/rate-limiter.test.js.map +0 -1
  790. package/dist/src/telemetry/sanitize.test.d.ts +0 -6
  791. package/dist/src/telemetry/sanitize.test.js +0 -279
  792. package/dist/src/telemetry/sanitize.test.js.map +0 -1
  793. package/dist/src/telemetry/sdk.test.d.ts +0 -6
  794. package/dist/src/telemetry/sdk.test.js +0 -360
  795. package/dist/src/telemetry/sdk.test.js.map +0 -1
  796. package/dist/src/telemetry/semantic.test.d.ts +0 -6
  797. package/dist/src/telemetry/semantic.test.js +0 -387
  798. package/dist/src/telemetry/semantic.test.js.map +0 -1
  799. package/dist/src/telemetry/semantic.truncation.test.d.ts +0 -1
  800. package/dist/src/telemetry/semantic.truncation.test.js +0 -92
  801. package/dist/src/telemetry/semantic.truncation.test.js.map +0 -1
  802. package/dist/src/telemetry/startupProfiler.test.d.ts +0 -6
  803. package/dist/src/telemetry/startupProfiler.test.js +0 -285
  804. package/dist/src/telemetry/startupProfiler.test.js.map +0 -1
  805. package/dist/src/telemetry/telemetry-utils.test.d.ts +0 -6
  806. package/dist/src/telemetry/telemetry-utils.test.js +0 -41
  807. package/dist/src/telemetry/telemetry-utils.test.js.map +0 -1
  808. package/dist/src/telemetry/telemetry.test.d.ts +0 -6
  809. package/dist/src/telemetry/telemetry.test.js +0 -57
  810. package/dist/src/telemetry/telemetry.test.js.map +0 -1
  811. package/dist/src/telemetry/uiTelemetry.test.d.ts +0 -6
  812. package/dist/src/telemetry/uiTelemetry.test.js +0 -584
  813. package/dist/src/telemetry/uiTelemetry.test.js.map +0 -1
  814. package/dist/src/tools/activate-skill.test.d.ts +0 -6
  815. package/dist/src/tools/activate-skill.test.js +0 -113
  816. package/dist/src/tools/activate-skill.test.js.map +0 -1
  817. package/dist/src/tools/ask-user.test.d.ts +0 -6
  818. package/dist/src/tools/ask-user.test.js +0 -187
  819. package/dist/src/tools/ask-user.test.js.map +0 -1
  820. package/dist/src/tools/base-tool-invocation.test.d.ts +0 -6
  821. package/dist/src/tools/base-tool-invocation.test.js +0 -85
  822. package/dist/src/tools/base-tool-invocation.test.js.map +0 -1
  823. package/dist/src/tools/confirmation-policy.test.d.ts +0 -6
  824. package/dist/src/tools/confirmation-policy.test.js +0 -143
  825. package/dist/src/tools/confirmation-policy.test.js.map +0 -1
  826. package/dist/src/tools/diffOptions.test.d.ts +0 -6
  827. package/dist/src/tools/diffOptions.test.js +0 -172
  828. package/dist/src/tools/diffOptions.test.js.map +0 -1
  829. package/dist/src/tools/edit.test.d.ts +0 -6
  830. package/dist/src/tools/edit.test.js +0 -729
  831. package/dist/src/tools/edit.test.js.map +0 -1
  832. package/dist/src/tools/get-internal-docs.test.d.ts +0 -6
  833. package/dist/src/tools/get-internal-docs.test.js +0 -57
  834. package/dist/src/tools/get-internal-docs.test.js.map +0 -1
  835. package/dist/src/tools/glob.test.d.ts +0 -6
  836. package/dist/src/tools/glob.test.js +0 -433
  837. package/dist/src/tools/glob.test.js.map +0 -1
  838. package/dist/src/tools/grep.test.d.ts +0 -6
  839. package/dist/src/tools/grep.test.js +0 -328
  840. package/dist/src/tools/grep.test.js.map +0 -1
  841. package/dist/src/tools/ls.test.d.ts +0 -6
  842. package/dist/src/tools/ls.test.js +0 -242
  843. package/dist/src/tools/ls.test.js.map +0 -1
  844. package/dist/src/tools/mcp-client-manager.test.d.ts +0 -6
  845. package/dist/src/tools/mcp-client-manager.test.js +0 -251
  846. package/dist/src/tools/mcp-client-manager.test.js.map +0 -1
  847. package/dist/src/tools/mcp-client.test.d.ts +0 -6
  848. package/dist/src/tools/mcp-client.test.js +0 -1346
  849. package/dist/src/tools/mcp-client.test.js.map +0 -1
  850. package/dist/src/tools/mcp-tool.test.d.ts +0 -6
  851. package/dist/src/tools/mcp-tool.test.js +0 -657
  852. package/dist/src/tools/mcp-tool.test.js.map +0 -1
  853. package/dist/src/tools/memoryTool.test.d.ts +0 -6
  854. package/dist/src/tools/memoryTool.test.js +0 -302
  855. package/dist/src/tools/memoryTool.test.js.map +0 -1
  856. package/dist/src/tools/message-bus-integration.test.d.ts +0 -6
  857. package/dist/src/tools/message-bus-integration.test.js +0 -169
  858. package/dist/src/tools/message-bus-integration.test.js.map +0 -1
  859. package/dist/src/tools/modifiable-tool.test.d.ts +0 -6
  860. package/dist/src/tools/modifiable-tool.test.js +0 -237
  861. package/dist/src/tools/modifiable-tool.test.js.map +0 -1
  862. package/dist/src/tools/read-file.test.d.ts +0 -6
  863. package/dist/src/tools/read-file.test.js +0 -376
  864. package/dist/src/tools/read-file.test.js.map +0 -1
  865. package/dist/src/tools/read-many-files.test.d.ts +0 -6
  866. package/dist/src/tools/read-many-files.test.js +0 -567
  867. package/dist/src/tools/read-many-files.test.js.map +0 -1
  868. package/dist/src/tools/ripGrep.test.d.ts +0 -6
  869. package/dist/src/tools/ripGrep.test.js +0 -1139
  870. package/dist/src/tools/ripGrep.test.js.map +0 -1
  871. package/dist/src/tools/shell.test.d.ts +0 -6
  872. package/dist/src/tools/shell.test.js +0 -526
  873. package/dist/src/tools/shell.test.js.map +0 -1
  874. package/dist/src/tools/tool-names.test.d.ts +0 -6
  875. package/dist/src/tools/tool-names.test.js +0 -43
  876. package/dist/src/tools/tool-names.test.js.map +0 -1
  877. package/dist/src/tools/tool-registry.test.d.ts +0 -6
  878. package/dist/src/tools/tool-registry.test.js +0 -461
  879. package/dist/src/tools/tool-registry.test.js.map +0 -1
  880. package/dist/src/tools/tools.test.d.ts +0 -6
  881. package/dist/src/tools/tools.test.js +0 -207
  882. package/dist/src/tools/tools.test.js.map +0 -1
  883. package/dist/src/tools/web-fetch.test.d.ts +0 -6
  884. package/dist/src/tools/web-fetch.test.js +0 -442
  885. package/dist/src/tools/web-fetch.test.js.map +0 -1
  886. package/dist/src/tools/web-search.test.d.ts +0 -6
  887. package/dist/src/tools/web-search.test.js +0 -214
  888. package/dist/src/tools/web-search.test.js.map +0 -1
  889. package/dist/src/tools/write-file.test.d.ts +0 -6
  890. package/dist/src/tools/write-file.test.js +0 -681
  891. package/dist/src/tools/write-file.test.js.map +0 -1
  892. package/dist/src/tools/write-todos.test.d.ts +0 -6
  893. package/dist/src/tools/write-todos.test.js +0 -90
  894. package/dist/src/tools/write-todos.test.js.map +0 -1
  895. package/dist/src/utils/apiConversionUtils.test.d.ts +0 -6
  896. package/dist/src/utils/apiConversionUtils.test.js +0 -150
  897. package/dist/src/utils/apiConversionUtils.test.js.map +0 -1
  898. package/dist/src/utils/bfsFileSearch.test.d.ts +0 -6
  899. package/dist/src/utils/bfsFileSearch.test.js +0 -227
  900. package/dist/src/utils/bfsFileSearch.test.js.map +0 -1
  901. package/dist/src/utils/channel.test.d.ts +0 -6
  902. package/dist/src/utils/channel.test.js +0 -170
  903. package/dist/src/utils/channel.test.js.map +0 -1
  904. package/dist/src/utils/checkpointUtils.test.d.ts +0 -6
  905. package/dist/src/utils/checkpointUtils.test.js +0 -229
  906. package/dist/src/utils/checkpointUtils.test.js.map +0 -1
  907. package/dist/src/utils/customHeaderUtils.test.d.ts +0 -6
  908. package/dist/src/utils/customHeaderUtils.test.js +0 -77
  909. package/dist/src/utils/customHeaderUtils.test.js.map +0 -1
  910. package/dist/src/utils/debugLogger.test.d.ts +0 -6
  911. package/dist/src/utils/debugLogger.test.js +0 -69
  912. package/dist/src/utils/debugLogger.test.js.map +0 -1
  913. package/dist/src/utils/delay.test.d.ts +0 -6
  914. package/dist/src/utils/delay.test.js +0 -88
  915. package/dist/src/utils/delay.test.js.map +0 -1
  916. package/dist/src/utils/editCorrector.test.d.ts +0 -6
  917. package/dist/src/utils/editCorrector.test.js +0 -533
  918. package/dist/src/utils/editCorrector.test.js.map +0 -1
  919. package/dist/src/utils/editor.test.d.ts +0 -6
  920. package/dist/src/utils/editor.test.js +0 -429
  921. package/dist/src/utils/editor.test.js.map +0 -1
  922. package/dist/src/utils/environmentContext.test.d.ts +0 -6
  923. package/dist/src/utils/environmentContext.test.js +0 -114
  924. package/dist/src/utils/environmentContext.test.js.map +0 -1
  925. package/dist/src/utils/errorParsing.test.d.ts +0 -6
  926. package/dist/src/utils/errorParsing.test.js +0 -84
  927. package/dist/src/utils/errorParsing.test.js.map +0 -1
  928. package/dist/src/utils/errorReporting.test.d.ts +0 -6
  929. package/dist/src/utils/errorReporting.test.js +0 -133
  930. package/dist/src/utils/errorReporting.test.js.map +0 -1
  931. package/dist/src/utils/errors.test.d.ts +0 -6
  932. package/dist/src/utils/errors.test.js +0 -155
  933. package/dist/src/utils/errors.test.js.map +0 -1
  934. package/dist/src/utils/events.test.d.ts +0 -6
  935. package/dist/src/utils/events.test.js +0 -237
  936. package/dist/src/utils/events.test.js.map +0 -1
  937. package/dist/src/utils/extensionLoader.test.d.ts +0 -6
  938. package/dist/src/utils/extensionLoader.test.js +0 -176
  939. package/dist/src/utils/extensionLoader.test.js.map +0 -1
  940. package/dist/src/utils/fileDiffUtils.test.d.ts +0 -6
  941. package/dist/src/utils/fileDiffUtils.test.js +0 -84
  942. package/dist/src/utils/fileDiffUtils.test.js.map +0 -1
  943. package/dist/src/utils/fileUtils.test.d.ts +0 -6
  944. package/dist/src/utils/fileUtils.test.js +0 -780
  945. package/dist/src/utils/fileUtils.test.js.map +0 -1
  946. package/dist/src/utils/filesearch/crawlCache.test.d.ts +0 -6
  947. package/dist/src/utils/filesearch/crawlCache.test.js +0 -103
  948. package/dist/src/utils/filesearch/crawlCache.test.js.map +0 -1
  949. package/dist/src/utils/filesearch/crawler.test.d.ts +0 -6
  950. package/dist/src/utils/filesearch/crawler.test.js +0 -495
  951. package/dist/src/utils/filesearch/crawler.test.js.map +0 -1
  952. package/dist/src/utils/filesearch/fileSearch.test.d.ts +0 -6
  953. package/dist/src/utils/filesearch/fileSearch.test.js +0 -663
  954. package/dist/src/utils/filesearch/fileSearch.test.js.map +0 -1
  955. package/dist/src/utils/filesearch/ignore.test.d.ts +0 -6
  956. package/dist/src/utils/filesearch/ignore.test.js +0 -144
  957. package/dist/src/utils/filesearch/ignore.test.js.map +0 -1
  958. package/dist/src/utils/filesearch/result-cache.test.d.ts +0 -6
  959. package/dist/src/utils/filesearch/result-cache.test.js +0 -46
  960. package/dist/src/utils/filesearch/result-cache.test.js.map +0 -1
  961. package/dist/src/utils/flashFallback.test.d.ts +0 -6
  962. package/dist/src/utils/flashFallback.test.js +0 -103
  963. package/dist/src/utils/flashFallback.test.js.map +0 -1
  964. package/dist/src/utils/formatters.test.d.ts +0 -6
  965. package/dist/src/utils/formatters.test.js +0 -26
  966. package/dist/src/utils/formatters.test.js.map +0 -1
  967. package/dist/src/utils/geminiIgnoreParser.test.d.ts +0 -6
  968. package/dist/src/utils/geminiIgnoreParser.test.js +0 -98
  969. package/dist/src/utils/geminiIgnoreParser.test.js.map +0 -1
  970. package/dist/src/utils/geminiTypeConversion.test.d.ts +0 -6
  971. package/dist/src/utils/geminiTypeConversion.test.js +0 -310
  972. package/dist/src/utils/geminiTypeConversion.test.js.map +0 -1
  973. package/dist/src/utils/generateContentResponseUtilities.test.d.ts +0 -6
  974. package/dist/src/utils/generateContentResponseUtilities.test.js +0 -512
  975. package/dist/src/utils/generateContentResponseUtilities.test.js.map +0 -1
  976. package/dist/src/utils/getFolderStructure.test.d.ts +0 -6
  977. package/dist/src/utils/getFolderStructure.test.js +0 -283
  978. package/dist/src/utils/getFolderStructure.test.js.map +0 -1
  979. package/dist/src/utils/gitIgnoreParser.test.d.ts +0 -6
  980. package/dist/src/utils/gitIgnoreParser.test.js +0 -243
  981. package/dist/src/utils/gitIgnoreParser.test.js.map +0 -1
  982. package/dist/src/utils/googleErrors.test.d.ts +0 -6
  983. package/dist/src/utils/googleErrors.test.js +0 -309
  984. package/dist/src/utils/googleErrors.test.js.map +0 -1
  985. package/dist/src/utils/googleQuotaErrors.test.d.ts +0 -6
  986. package/dist/src/utils/googleQuotaErrors.test.js +0 -548
  987. package/dist/src/utils/googleQuotaErrors.test.js.map +0 -1
  988. package/dist/src/utils/ignorePatterns.test.d.ts +0 -6
  989. package/dist/src/utils/ignorePatterns.test.js +0 -246
  990. package/dist/src/utils/ignorePatterns.test.js.map +0 -1
  991. package/dist/src/utils/installationManager.test.d.ts +0 -6
  992. package/dist/src/utils/installationManager.test.js +0 -93
  993. package/dist/src/utils/installationManager.test.js.map +0 -1
  994. package/dist/src/utils/llm-edit-fixer.test.d.ts +0 -6
  995. package/dist/src/utils/llm-edit-fixer.test.js +0 -223
  996. package/dist/src/utils/llm-edit-fixer.test.js.map +0 -1
  997. package/dist/src/utils/llmUtils.test.d.ts +0 -6
  998. package/dist/src/utils/llmUtils.test.js +0 -196
  999. package/dist/src/utils/llmUtils.test.js.map +0 -1
  1000. package/dist/src/utils/memoryDiscovery.test.d.ts +0 -6
  1001. package/dist/src/utils/memoryDiscovery.test.js +0 -542
  1002. package/dist/src/utils/memoryDiscovery.test.js.map +0 -1
  1003. package/dist/src/utils/memoryImportProcessor.test.d.ts +0 -6
  1004. package/dist/src/utils/memoryImportProcessor.test.js +0 -581
  1005. package/dist/src/utils/memoryImportProcessor.test.js.map +0 -1
  1006. package/dist/src/utils/nextSpeakerChecker.test.d.ts +0 -6
  1007. package/dist/src/utils/nextSpeakerChecker.test.js +0 -191
  1008. package/dist/src/utils/nextSpeakerChecker.test.js.map +0 -1
  1009. package/dist/src/utils/partUtils.test.d.ts +0 -6
  1010. package/dist/src/utils/partUtils.test.js +0 -397
  1011. package/dist/src/utils/partUtils.test.js.map +0 -1
  1012. package/dist/src/utils/pathCorrector.test.d.ts +0 -6
  1013. package/dist/src/utils/pathCorrector.test.js +0 -87
  1014. package/dist/src/utils/pathCorrector.test.js.map +0 -1
  1015. package/dist/src/utils/pathReader.test.d.ts +0 -6
  1016. package/dist/src/utils/pathReader.test.js +0 -406
  1017. package/dist/src/utils/pathReader.test.js.map +0 -1
  1018. package/dist/src/utils/paths.test.d.ts +0 -6
  1019. package/dist/src/utils/paths.test.js +0 -402
  1020. package/dist/src/utils/paths.test.js.map +0 -1
  1021. package/dist/src/utils/retry.test.d.ts +0 -6
  1022. package/dist/src/utils/retry.test.js +0 -548
  1023. package/dist/src/utils/retry.test.js.map +0 -1
  1024. package/dist/src/utils/retry_llm_error.test.d.ts +0 -6
  1025. package/dist/src/utils/retry_llm_error.test.js +0 -280
  1026. package/dist/src/utils/retry_llm_error.test.js.map +0 -1
  1027. package/dist/src/utils/safeJsonStringify.test.d.ts +0 -6
  1028. package/dist/src/utils/safeJsonStringify.test.js +0 -61
  1029. package/dist/src/utils/safeJsonStringify.test.js.map +0 -1
  1030. package/dist/src/utils/schemaValidator.test.d.ts +0 -6
  1031. package/dist/src/utils/schemaValidator.test.js +0 -113
  1032. package/dist/src/utils/schemaValidator.test.js.map +0 -1
  1033. package/dist/src/utils/secure-browser-launcher.test.d.ts +0 -6
  1034. package/dist/src/utils/secure-browser-launcher.test.js +0 -149
  1035. package/dist/src/utils/secure-browser-launcher.test.js.map +0 -1
  1036. package/dist/src/utils/security.test.d.ts +0 -1
  1037. package/dist/src/utils/security.test.js +0 -121
  1038. package/dist/src/utils/security.test.js.map +0 -1
  1039. package/dist/src/utils/shell-utils.integration.test.d.ts +0 -1
  1040. package/dist/src/utils/shell-utils.integration.test.js +0 -58
  1041. package/dist/src/utils/shell-utils.integration.test.js.map +0 -1
  1042. package/dist/src/utils/shell-utils.test.d.ts +0 -6
  1043. package/dist/src/utils/shell-utils.test.js +0 -437
  1044. package/dist/src/utils/shell-utils.test.js.map +0 -1
  1045. package/dist/src/utils/stdio.test.d.ts +0 -6
  1046. package/dist/src/utils/stdio.test.js +0 -47
  1047. package/dist/src/utils/stdio.test.js.map +0 -1
  1048. package/dist/src/utils/summarizer.test.d.ts +0 -6
  1049. package/dist/src/utils/summarizer.test.js +0 -152
  1050. package/dist/src/utils/summarizer.test.js.map +0 -1
  1051. package/dist/src/utils/systemEncoding.test.d.ts +0 -6
  1052. package/dist/src/utils/systemEncoding.test.js +0 -369
  1053. package/dist/src/utils/systemEncoding.test.js.map +0 -1
  1054. package/dist/src/utils/terminalSerializer.test.d.ts +0 -6
  1055. package/dist/src/utils/terminalSerializer.test.js +0 -193
  1056. package/dist/src/utils/terminalSerializer.test.js.map +0 -1
  1057. package/dist/src/utils/textUtils.test.d.ts +0 -6
  1058. package/dist/src/utils/textUtils.test.js +0 -76
  1059. package/dist/src/utils/textUtils.test.js.map +0 -1
  1060. package/dist/src/utils/thoughtUtils.test.d.ts +0 -6
  1061. package/dist/src/utils/thoughtUtils.test.js +0 -78
  1062. package/dist/src/utils/thoughtUtils.test.js.map +0 -1
  1063. package/dist/src/utils/tokenCalculation.test.d.ts +0 -6
  1064. package/dist/src/utils/tokenCalculation.test.js +0 -184
  1065. package/dist/src/utils/tokenCalculation.test.js.map +0 -1
  1066. package/dist/src/utils/tool-utils.test.d.ts +0 -6
  1067. package/dist/src/utils/tool-utils.test.js +0 -84
  1068. package/dist/src/utils/tool-utils.test.js.map +0 -1
  1069. package/dist/src/utils/toolCallContext.test.d.ts +0 -6
  1070. package/dist/src/utils/toolCallContext.test.js +0 -68
  1071. package/dist/src/utils/toolCallContext.test.js.map +0 -1
  1072. package/dist/src/utils/userAccountManager.test.d.ts +0 -6
  1073. package/dist/src/utils/userAccountManager.test.js +0 -225
  1074. package/dist/src/utils/userAccountManager.test.js.map +0 -1
  1075. package/dist/src/utils/version.test.d.ts +0 -6
  1076. package/dist/src/utils/version.test.js +0 -39
  1077. package/dist/src/utils/version.test.js.map +0 -1
  1078. package/dist/src/utils/workspaceContext.test.d.ts +0 -6
  1079. package/dist/src/utils/workspaceContext.test.js +0 -374
  1080. package/dist/src/utils/workspaceContext.test.js.map +0 -1
  1081. package/dist/tsconfig.tsbuildinfo +0 -1
@@ -1,881 +0,0 @@
1
- /**
2
- * @license
3
- * Copyright 2025 Google LLC
4
- * SPDX-License-Identifier: Apache-2.0
5
- */
6
- import { afterEach, beforeEach, describe, expect, it, vi } from 'vitest';
7
- import { LlmEventType } from '../providers/events.js';
8
- import * as loggers from '../telemetry/loggers.js';
9
- import { LoopType } from '../telemetry/types.js';
10
- import { LoopDetectionService } from './loopDetectionService.js';
11
- import { createAvailabilityServiceMock } from '../availability/testUtils.js';
12
- vi.mock('../telemetry/loggers.js', () => ({
13
- logLoopDetected: vi.fn(),
14
- logLoopDetectionDisabled: vi.fn(),
15
- logLlmLoopCheck: vi.fn(),
16
- }));
17
- const TOOL_CALL_LOOP_THRESHOLD = 5;
18
- const CONTENT_LOOP_THRESHOLD = 10;
19
- const CONTENT_CHUNK_SIZE = 50;
20
- describe('LoopDetectionService', () => {
21
- let service;
22
- let mockConfig;
23
- beforeEach(() => {
24
- mockConfig = {
25
- getTelemetryEnabled: () => true,
26
- isInteractive: () => false,
27
- getModelAvailabilityService: vi
28
- .fn()
29
- .mockReturnValue(createAvailabilityServiceMock()),
30
- };
31
- service = new LoopDetectionService(mockConfig);
32
- vi.clearAllMocks();
33
- });
34
- const createToolCallRequestEvent = (name, args) => ({
35
- type: LlmEventType.ToolCallRequest,
36
- name,
37
- args,
38
- callId: 'test-id',
39
- isClientInitiated: false,
40
- promptId: 'test-prompt-id',
41
- });
42
- const createContentEvent = (content) => ({
43
- type: LlmEventType.TextDelta,
44
- text: content,
45
- });
46
- const createRepetitiveContent = (id, length) => {
47
- const baseString = `This is a unique sentence, id=${id}. `;
48
- let content = '';
49
- while (content.length < length) {
50
- content += baseString;
51
- }
52
- return content.slice(0, length);
53
- };
54
- describe('Tool Call Loop Detection', () => {
55
- it(`should not detect a loop for fewer than TOOL_CALL_LOOP_THRESHOLD identical calls`, () => {
56
- const event = createToolCallRequestEvent('testTool', { param: 'value' });
57
- for (let i = 0; i < TOOL_CALL_LOOP_THRESHOLD - 1; i++) {
58
- expect(service.addAndCheck(event)).toBe(false);
59
- }
60
- expect(loggers.logLoopDetected).not.toHaveBeenCalled();
61
- });
62
- it(`should detect a loop on the TOOL_CALL_LOOP_THRESHOLD-th identical call`, () => {
63
- const event = createToolCallRequestEvent('testTool', { param: 'value' });
64
- for (let i = 0; i < TOOL_CALL_LOOP_THRESHOLD - 1; i++) {
65
- service.addAndCheck(event);
66
- }
67
- expect(service.addAndCheck(event)).toBe(true);
68
- expect(loggers.logLoopDetected).toHaveBeenCalledTimes(1);
69
- });
70
- it('should detect a loop on subsequent identical calls', () => {
71
- const event = createToolCallRequestEvent('testTool', { param: 'value' });
72
- for (let i = 0; i < TOOL_CALL_LOOP_THRESHOLD; i++) {
73
- service.addAndCheck(event);
74
- }
75
- expect(service.addAndCheck(event)).toBe(true);
76
- expect(loggers.logLoopDetected).toHaveBeenCalledTimes(1);
77
- });
78
- it('should not detect a loop for different tool calls', () => {
79
- const event1 = createToolCallRequestEvent('testTool', {
80
- param: 'value1',
81
- });
82
- const event2 = createToolCallRequestEvent('testTool', {
83
- param: 'value2',
84
- });
85
- const event3 = createToolCallRequestEvent('anotherTool', {
86
- param: 'value1',
87
- });
88
- for (let i = 0; i < TOOL_CALL_LOOP_THRESHOLD - 2; i++) {
89
- expect(service.addAndCheck(event1)).toBe(false);
90
- expect(service.addAndCheck(event2)).toBe(false);
91
- expect(service.addAndCheck(event3)).toBe(false);
92
- }
93
- });
94
- it('should not reset tool call counter for other event types', () => {
95
- const toolCallEvent = createToolCallRequestEvent('testTool', {
96
- param: 'value',
97
- });
98
- const otherEvent = {
99
- type: 'thought',
100
- };
101
- // Send events just below the threshold
102
- for (let i = 0; i < TOOL_CALL_LOOP_THRESHOLD - 1; i++) {
103
- expect(service.addAndCheck(toolCallEvent)).toBe(false);
104
- }
105
- // Send a different event type
106
- expect(service.addAndCheck(otherEvent)).toBe(false);
107
- // Send the tool call event again, which should now trigger the loop
108
- expect(service.addAndCheck(toolCallEvent)).toBe(true);
109
- expect(loggers.logLoopDetected).toHaveBeenCalledTimes(1);
110
- });
111
- it('should not detect a loop when disabled for session', () => {
112
- service.disableForSession();
113
- expect(loggers.logLoopDetectionDisabled).toHaveBeenCalledTimes(1);
114
- const event = createToolCallRequestEvent('testTool', { param: 'value' });
115
- for (let i = 0; i < TOOL_CALL_LOOP_THRESHOLD; i++) {
116
- expect(service.addAndCheck(event)).toBe(false);
117
- }
118
- expect(loggers.logLoopDetected).not.toHaveBeenCalled();
119
- });
120
- it('should stop reporting a loop if disabled after detection', () => {
121
- const event = createToolCallRequestEvent('testTool', { param: 'value' });
122
- for (let i = 0; i < TOOL_CALL_LOOP_THRESHOLD; i++) {
123
- service.addAndCheck(event);
124
- }
125
- expect(service.addAndCheck(event)).toBe(true);
126
- service.disableForSession();
127
- // Should now return false even though a loop was previously detected
128
- expect(service.addAndCheck(event)).toBe(false);
129
- });
130
- });
131
- describe('Content Loop Detection', () => {
132
- const generateRandomString = (length) => {
133
- let result = '';
134
- const characters = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789';
135
- const charactersLength = characters.length;
136
- for (let i = 0; i < length; i++) {
137
- result += characters.charAt(Math.floor(Math.random() * charactersLength));
138
- }
139
- return result;
140
- };
141
- it('should not detect a loop for random content', () => {
142
- service.reset('');
143
- for (let i = 0; i < 1000; i++) {
144
- const content = generateRandomString(10);
145
- const isLoop = service.addAndCheck(createContentEvent(content));
146
- expect(isLoop).toBe(false);
147
- }
148
- expect(loggers.logLoopDetected).not.toHaveBeenCalled();
149
- });
150
- it('should detect a loop when a chunk of content repeats consecutively', () => {
151
- service.reset('');
152
- const repeatedContent = createRepetitiveContent(1, CONTENT_CHUNK_SIZE);
153
- let isLoop = false;
154
- for (let i = 0; i < CONTENT_LOOP_THRESHOLD; i++) {
155
- isLoop = service.addAndCheck(createContentEvent(repeatedContent));
156
- }
157
- expect(isLoop).toBe(true);
158
- expect(loggers.logLoopDetected).toHaveBeenCalledTimes(1);
159
- });
160
- it('should not detect a loop if repetitions are very far apart', () => {
161
- service.reset('');
162
- const repeatedContent = createRepetitiveContent(1, CONTENT_CHUNK_SIZE);
163
- const fillerContent = generateRandomString(500);
164
- let isLoop = false;
165
- for (let i = 0; i < CONTENT_LOOP_THRESHOLD; i++) {
166
- isLoop = service.addAndCheck(createContentEvent(repeatedContent));
167
- isLoop = service.addAndCheck(createContentEvent(fillerContent));
168
- }
169
- expect(isLoop).toBe(false);
170
- expect(loggers.logLoopDetected).not.toHaveBeenCalled();
171
- });
172
- it('should detect a loop with longer repeating patterns (e.g. ~150 chars)', () => {
173
- service.reset('');
174
- const longPattern = createRepetitiveContent(1, 150);
175
- expect(longPattern.length).toBe(150);
176
- let isLoop = false;
177
- for (let i = 0; i < CONTENT_LOOP_THRESHOLD + 2; i++) {
178
- isLoop = service.addAndCheck(createContentEvent(longPattern));
179
- if (isLoop)
180
- break;
181
- }
182
- expect(isLoop).toBe(true);
183
- expect(loggers.logLoopDetected).toHaveBeenCalledTimes(1);
184
- });
185
- it('should detect the specific user-provided loop example', () => {
186
- service.reset('');
187
- const userPattern = `I will not output any text.
188
- I will just end the turn.
189
- I am done.
190
- I will not do anything else.
191
- I will wait for the user's next command.
192
- `;
193
- let isLoop = false;
194
- // Loop enough times to trigger the threshold
195
- for (let i = 0; i < CONTENT_LOOP_THRESHOLD + 5; i++) {
196
- isLoop = service.addAndCheck(createContentEvent(userPattern));
197
- if (isLoop)
198
- break;
199
- }
200
- expect(isLoop).toBe(true);
201
- expect(loggers.logLoopDetected).toHaveBeenCalledTimes(1);
202
- });
203
- it('should detect the second specific user-provided loop example', () => {
204
- service.reset('');
205
- const userPattern = 'I have added all the requested logs and verified the test file. I will now mark the task as complete.\n ';
206
- let isLoop = false;
207
- for (let i = 0; i < CONTENT_LOOP_THRESHOLD + 5; i++) {
208
- isLoop = service.addAndCheck(createContentEvent(userPattern));
209
- if (isLoop)
210
- break;
211
- }
212
- expect(isLoop).toBe(true);
213
- expect(loggers.logLoopDetected).toHaveBeenCalledTimes(1);
214
- });
215
- it('should detect a loop of alternating short phrases', () => {
216
- service.reset('');
217
- const alternatingPattern = 'Thinking... Done. ';
218
- let isLoop = false;
219
- // Needs more iterations because the pattern is short relative to chunk size,
220
- // so it takes a few slides of the window to find the exact alignment.
221
- for (let i = 0; i < CONTENT_LOOP_THRESHOLD * 3; i++) {
222
- isLoop = service.addAndCheck(createContentEvent(alternatingPattern));
223
- if (isLoop)
224
- break;
225
- }
226
- expect(isLoop).toBe(true);
227
- expect(loggers.logLoopDetected).toHaveBeenCalledTimes(1);
228
- });
229
- it('should detect a loop of repeated complex thought processes', () => {
230
- service.reset('');
231
- const thoughtPattern = 'I need to check the file. The file does not exist. I will create the file. ';
232
- let isLoop = false;
233
- for (let i = 0; i < CONTENT_LOOP_THRESHOLD + 5; i++) {
234
- isLoop = service.addAndCheck(createContentEvent(thoughtPattern));
235
- if (isLoop)
236
- break;
237
- }
238
- expect(isLoop).toBe(true);
239
- expect(loggers.logLoopDetected).toHaveBeenCalledTimes(1);
240
- });
241
- });
242
- describe('Content Loop Detection with Code Blocks', () => {
243
- it('should not detect a loop when repetitive content is inside a code block', () => {
244
- service.reset('');
245
- const repeatedContent = createRepetitiveContent(1, CONTENT_CHUNK_SIZE);
246
- service.addAndCheck(createContentEvent('```\n'));
247
- for (let i = 0; i < CONTENT_LOOP_THRESHOLD; i++) {
248
- const isLoop = service.addAndCheck(createContentEvent(repeatedContent));
249
- expect(isLoop).toBe(false);
250
- }
251
- const isLoop = service.addAndCheck(createContentEvent('\n```'));
252
- expect(isLoop).toBe(false);
253
- expect(loggers.logLoopDetected).not.toHaveBeenCalled();
254
- });
255
- it('should not detect loops when content transitions into a code block', () => {
256
- service.reset('');
257
- const repeatedContent = createRepetitiveContent(1, CONTENT_CHUNK_SIZE);
258
- // Add some repetitive content outside of code block
259
- for (let i = 0; i < CONTENT_LOOP_THRESHOLD - 2; i++) {
260
- service.addAndCheck(createContentEvent(repeatedContent));
261
- }
262
- // Now transition into a code block - this should prevent loop detection
263
- // even though we were already close to the threshold
264
- const codeBlockStart = '```javascript\n';
265
- const isLoop = service.addAndCheck(createContentEvent(codeBlockStart));
266
- expect(isLoop).toBe(false);
267
- // Continue adding repetitive content inside the code block - should not trigger loop
268
- for (let i = 0; i < CONTENT_LOOP_THRESHOLD; i++) {
269
- const isLoopInside = service.addAndCheck(createContentEvent(repeatedContent));
270
- expect(isLoopInside).toBe(false);
271
- }
272
- expect(loggers.logLoopDetected).not.toHaveBeenCalled();
273
- });
274
- it('should skip loop detection when already inside a code block (this.inCodeBlock)', () => {
275
- service.reset('');
276
- // Start with content that puts us inside a code block
277
- service.addAndCheck(createContentEvent('Here is some code:\n```\n'));
278
- // Verify we are now inside a code block and any content should be ignored for loop detection
279
- const repeatedContent = createRepetitiveContent(1, CONTENT_CHUNK_SIZE);
280
- for (let i = 0; i < CONTENT_LOOP_THRESHOLD + 5; i++) {
281
- const isLoop = service.addAndCheck(createContentEvent(repeatedContent));
282
- expect(isLoop).toBe(false);
283
- }
284
- expect(loggers.logLoopDetected).not.toHaveBeenCalled();
285
- });
286
- it('should correctly track inCodeBlock state with multiple fence transitions', () => {
287
- service.reset('');
288
- const repeatedContent = createRepetitiveContent(1, CONTENT_CHUNK_SIZE);
289
- // Outside code block - should track content
290
- service.addAndCheck(createContentEvent('Normal text '));
291
- // Enter code block (1 fence) - should stop tracking
292
- const enterResult = service.addAndCheck(createContentEvent('```\n'));
293
- expect(enterResult).toBe(false);
294
- // Inside code block - should not track loops
295
- for (let i = 0; i < 5; i++) {
296
- const insideResult = service.addAndCheck(createContentEvent(repeatedContent));
297
- expect(insideResult).toBe(false);
298
- }
299
- // Exit code block (2nd fence) - should reset tracking but still return false
300
- const exitResult = service.addAndCheck(createContentEvent('```\n'));
301
- expect(exitResult).toBe(false);
302
- // Enter code block again (3rd fence) - should stop tracking again
303
- const reenterResult = service.addAndCheck(createContentEvent('```python\n'));
304
- expect(reenterResult).toBe(false);
305
- expect(loggers.logLoopDetected).not.toHaveBeenCalled();
306
- });
307
- it('should detect a loop when repetitive content is outside a code block', () => {
308
- service.reset('');
309
- const repeatedContent = createRepetitiveContent(1, CONTENT_CHUNK_SIZE);
310
- service.addAndCheck(createContentEvent('```'));
311
- service.addAndCheck(createContentEvent('\nsome code\n'));
312
- service.addAndCheck(createContentEvent('```'));
313
- let isLoop = false;
314
- for (let i = 0; i < CONTENT_LOOP_THRESHOLD; i++) {
315
- isLoop = service.addAndCheck(createContentEvent(repeatedContent));
316
- }
317
- expect(isLoop).toBe(true);
318
- expect(loggers.logLoopDetected).toHaveBeenCalledTimes(1);
319
- });
320
- it('should handle content with multiple code blocks and no loops', () => {
321
- service.reset('');
322
- service.addAndCheck(createContentEvent('```\ncode1\n```'));
323
- service.addAndCheck(createContentEvent('\nsome text\n'));
324
- const isLoop = service.addAndCheck(createContentEvent('```\ncode2\n```'));
325
- expect(isLoop).toBe(false);
326
- expect(loggers.logLoopDetected).not.toHaveBeenCalled();
327
- });
328
- it('should handle content with mixed code blocks and looping text', () => {
329
- service.reset('');
330
- const repeatedContent = createRepetitiveContent(1, CONTENT_CHUNK_SIZE);
331
- service.addAndCheck(createContentEvent('```'));
332
- service.addAndCheck(createContentEvent('\ncode1\n'));
333
- service.addAndCheck(createContentEvent('```'));
334
- let isLoop = false;
335
- for (let i = 0; i < CONTENT_LOOP_THRESHOLD; i++) {
336
- isLoop = service.addAndCheck(createContentEvent(repeatedContent));
337
- }
338
- expect(isLoop).toBe(true);
339
- expect(loggers.logLoopDetected).toHaveBeenCalledTimes(1);
340
- });
341
- it('should not detect a loop for a long code block with some repeating tokens', () => {
342
- service.reset('');
343
- const repeatingTokens = 'for (let i = 0; i < 10; i++) { console.log(i); }';
344
- service.addAndCheck(createContentEvent('```\n'));
345
- for (let i = 0; i < 20; i++) {
346
- const isLoop = service.addAndCheck(createContentEvent(repeatingTokens));
347
- expect(isLoop).toBe(false);
348
- }
349
- const isLoop = service.addAndCheck(createContentEvent('\n```'));
350
- expect(isLoop).toBe(false);
351
- expect(loggers.logLoopDetected).not.toHaveBeenCalled();
352
- });
353
- it('should reset tracking when a code fence is found', () => {
354
- service.reset('');
355
- const repeatedContent = createRepetitiveContent(1, CONTENT_CHUNK_SIZE);
356
- for (let i = 0; i < CONTENT_LOOP_THRESHOLD - 1; i++) {
357
- service.addAndCheck(createContentEvent(repeatedContent));
358
- }
359
- // This should not trigger a loop because of the reset
360
- service.addAndCheck(createContentEvent('```'));
361
- // We are now in a code block, so loop detection should be off.
362
- // Let's add the repeated content again, it should not trigger a loop.
363
- let isLoop = false;
364
- for (let i = 0; i < CONTENT_LOOP_THRESHOLD; i++) {
365
- isLoop = service.addAndCheck(createContentEvent(repeatedContent));
366
- expect(isLoop).toBe(false);
367
- }
368
- expect(loggers.logLoopDetected).not.toHaveBeenCalled();
369
- });
370
- it('should reset tracking when a table is detected', () => {
371
- service.reset('');
372
- const repeatedContent = createRepetitiveContent(1, CONTENT_CHUNK_SIZE);
373
- for (let i = 0; i < CONTENT_LOOP_THRESHOLD - 1; i++) {
374
- service.addAndCheck(createContentEvent(repeatedContent));
375
- }
376
- // This should reset tracking and not trigger a loop
377
- service.addAndCheck(createContentEvent('| Column 1 | Column 2 |'));
378
- // Add more repeated content after table - should not trigger loop
379
- for (let i = 0; i < CONTENT_LOOP_THRESHOLD - 1; i++) {
380
- const isLoop = service.addAndCheck(createContentEvent(repeatedContent));
381
- expect(isLoop).toBe(false);
382
- }
383
- expect(loggers.logLoopDetected).not.toHaveBeenCalled();
384
- });
385
- it('should reset tracking when a list item is detected', () => {
386
- service.reset('');
387
- const repeatedContent = createRepetitiveContent(1, CONTENT_CHUNK_SIZE);
388
- for (let i = 0; i < CONTENT_LOOP_THRESHOLD - 1; i++) {
389
- service.addAndCheck(createContentEvent(repeatedContent));
390
- }
391
- // This should reset tracking and not trigger a loop
392
- service.addAndCheck(createContentEvent('* List item'));
393
- // Add more repeated content after list - should not trigger loop
394
- for (let i = 0; i < CONTENT_LOOP_THRESHOLD - 1; i++) {
395
- const isLoop = service.addAndCheck(createContentEvent(repeatedContent));
396
- expect(isLoop).toBe(false);
397
- }
398
- expect(loggers.logLoopDetected).not.toHaveBeenCalled();
399
- });
400
- it('should reset tracking when a heading is detected', () => {
401
- service.reset('');
402
- const repeatedContent = createRepetitiveContent(1, CONTENT_CHUNK_SIZE);
403
- for (let i = 0; i < CONTENT_LOOP_THRESHOLD - 1; i++) {
404
- service.addAndCheck(createContentEvent(repeatedContent));
405
- }
406
- // This should reset tracking and not trigger a loop
407
- service.addAndCheck(createContentEvent('## Heading'));
408
- // Add more repeated content after heading - should not trigger loop
409
- for (let i = 0; i < CONTENT_LOOP_THRESHOLD - 1; i++) {
410
- const isLoop = service.addAndCheck(createContentEvent(repeatedContent));
411
- expect(isLoop).toBe(false);
412
- }
413
- expect(loggers.logLoopDetected).not.toHaveBeenCalled();
414
- });
415
- it('should reset tracking when a blockquote is detected', () => {
416
- service.reset('');
417
- const repeatedContent = createRepetitiveContent(1, CONTENT_CHUNK_SIZE);
418
- for (let i = 0; i < CONTENT_LOOP_THRESHOLD - 1; i++) {
419
- service.addAndCheck(createContentEvent(repeatedContent));
420
- }
421
- // This should reset tracking and not trigger a loop
422
- service.addAndCheck(createContentEvent('> Quote text'));
423
- // Add more repeated content after blockquote - should not trigger loop
424
- for (let i = 0; i < CONTENT_LOOP_THRESHOLD - 1; i++) {
425
- const isLoop = service.addAndCheck(createContentEvent(repeatedContent));
426
- expect(isLoop).toBe(false);
427
- }
428
- expect(loggers.logLoopDetected).not.toHaveBeenCalled();
429
- });
430
- it('should reset tracking for various list item formats', () => {
431
- const repeatedContent = createRepetitiveContent(1, CONTENT_CHUNK_SIZE);
432
- // Test different list formats - make sure they start at beginning of line
433
- const listFormats = [
434
- '* Bullet item',
435
- '- Dash item',
436
- '+ Plus item',
437
- '1. Numbered item',
438
- '42. Another numbered item',
439
- ];
440
- listFormats.forEach((listFormat, index) => {
441
- service.reset('');
442
- // Build up to near threshold
443
- for (let i = 0; i < CONTENT_LOOP_THRESHOLD - 1; i++) {
444
- service.addAndCheck(createContentEvent(repeatedContent));
445
- }
446
- // Reset should occur with list item - add newline to ensure it starts at beginning
447
- service.addAndCheck(createContentEvent('\n' + listFormat));
448
- // Should not trigger loop after reset - use different content to avoid any cached state issues
449
- const newRepeatedContent = createRepetitiveContent(index + 100, CONTENT_CHUNK_SIZE);
450
- for (let i = 0; i < CONTENT_LOOP_THRESHOLD - 1; i++) {
451
- const isLoop = service.addAndCheck(createContentEvent(newRepeatedContent));
452
- expect(isLoop).toBe(false);
453
- }
454
- });
455
- expect(loggers.logLoopDetected).not.toHaveBeenCalled();
456
- });
457
- it('should reset tracking for various table formats', () => {
458
- const repeatedContent = createRepetitiveContent(1, CONTENT_CHUNK_SIZE);
459
- const tableFormats = [
460
- '| Column 1 | Column 2 |',
461
- '|---|---|',
462
- '|++|++|',
463
- '+---+---+',
464
- ];
465
- tableFormats.forEach((tableFormat, index) => {
466
- service.reset('');
467
- // Build up to near threshold
468
- for (let i = 0; i < CONTENT_LOOP_THRESHOLD - 1; i++) {
469
- service.addAndCheck(createContentEvent(repeatedContent));
470
- }
471
- // Reset should occur with table format - add newline to ensure it starts at beginning
472
- service.addAndCheck(createContentEvent('\n' + tableFormat));
473
- // Should not trigger loop after reset - use different content to avoid any cached state issues
474
- const newRepeatedContent = createRepetitiveContent(index + 200, CONTENT_CHUNK_SIZE);
475
- for (let i = 0; i < CONTENT_LOOP_THRESHOLD - 1; i++) {
476
- const isLoop = service.addAndCheck(createContentEvent(newRepeatedContent));
477
- expect(isLoop).toBe(false);
478
- }
479
- });
480
- expect(loggers.logLoopDetected).not.toHaveBeenCalled();
481
- });
482
- it('should reset tracking for various heading levels', () => {
483
- const repeatedContent = createRepetitiveContent(1, CONTENT_CHUNK_SIZE);
484
- const headingFormats = [
485
- '# H1 Heading',
486
- '## H2 Heading',
487
- '### H3 Heading',
488
- '#### H4 Heading',
489
- '##### H5 Heading',
490
- '###### H6 Heading',
491
- ];
492
- headingFormats.forEach((headingFormat, index) => {
493
- service.reset('');
494
- // Build up to near threshold
495
- for (let i = 0; i < CONTENT_LOOP_THRESHOLD - 1; i++) {
496
- service.addAndCheck(createContentEvent(repeatedContent));
497
- }
498
- // Reset should occur with heading - add newline to ensure it starts at beginning
499
- service.addAndCheck(createContentEvent('\n' + headingFormat));
500
- // Should not trigger loop after reset - use different content to avoid any cached state issues
501
- const newRepeatedContent = createRepetitiveContent(index + 300, CONTENT_CHUNK_SIZE);
502
- for (let i = 0; i < CONTENT_LOOP_THRESHOLD - 1; i++) {
503
- const isLoop = service.addAndCheck(createContentEvent(newRepeatedContent));
504
- expect(isLoop).toBe(false);
505
- }
506
- });
507
- expect(loggers.logLoopDetected).not.toHaveBeenCalled();
508
- });
509
- });
510
- describe('Edge Cases', () => {
511
- it('should handle empty content', () => {
512
- const event = createContentEvent('');
513
- expect(service.addAndCheck(event)).toBe(false);
514
- });
515
- });
516
- describe('Divider Content Detection', () => {
517
- it('should not detect a loop for repeating divider-like content', () => {
518
- service.reset('');
519
- const dividerContent = '-'.repeat(CONTENT_CHUNK_SIZE);
520
- let isLoop = false;
521
- for (let i = 0; i < CONTENT_LOOP_THRESHOLD + 5; i++) {
522
- isLoop = service.addAndCheck(createContentEvent(dividerContent));
523
- expect(isLoop).toBe(false);
524
- }
525
- expect(loggers.logLoopDetected).not.toHaveBeenCalled();
526
- });
527
- it('should not detect a loop for repeating complex box-drawing dividers', () => {
528
- service.reset('');
529
- const dividerContent = '╭─'.repeat(CONTENT_CHUNK_SIZE / 2);
530
- let isLoop = false;
531
- for (let i = 0; i < CONTENT_LOOP_THRESHOLD + 5; i++) {
532
- isLoop = service.addAndCheck(createContentEvent(dividerContent));
533
- expect(isLoop).toBe(false);
534
- }
535
- expect(loggers.logLoopDetected).not.toHaveBeenCalled();
536
- });
537
- });
538
- describe('Reset Functionality', () => {
539
- it('tool call should reset content count', () => {
540
- const contentEvent = createContentEvent('Some content.');
541
- const toolEvent = createToolCallRequestEvent('testTool', {
542
- param: 'value',
543
- });
544
- for (let i = 0; i < 9; i++) {
545
- service.addAndCheck(contentEvent);
546
- }
547
- service.addAndCheck(toolEvent);
548
- // Should start fresh
549
- expect(service.addAndCheck(createContentEvent('Fresh content.'))).toBe(false);
550
- });
551
- });
552
- describe('General Behavior', () => {
553
- it('should return false for unhandled event types', () => {
554
- const otherEvent = {
555
- type: 'unhandled_event',
556
- };
557
- expect(service.addAndCheck(otherEvent)).toBe(false);
558
- expect(service.addAndCheck(otherEvent)).toBe(false);
559
- });
560
- });
561
- describe('addAndCheck - LlmEvent support (M2.2.2.3)', () => {
562
- it('should detect tool call loop via LlmEvent ToolCallRequest', () => {
563
- const llmToolCallEvent = {
564
- type: LlmEventType.ToolCallRequest,
565
- callId: 'call-1',
566
- name: 'testTool',
567
- args: { param: 'value' },
568
- };
569
- for (let i = 0; i < TOOL_CALL_LOOP_THRESHOLD - 1; i++) {
570
- expect(service.addAndCheck(llmToolCallEvent)).toBe(false);
571
- }
572
- expect(service.addAndCheck(llmToolCallEvent)).toBe(true);
573
- expect(loggers.logLoopDetected).toHaveBeenCalledTimes(1);
574
- });
575
- it('should detect content loop via LlmEvent TextDelta', () => {
576
- service.reset('');
577
- const repeatedContent = createRepetitiveContent(1, CONTENT_CHUNK_SIZE);
578
- const llmTextEvent = {
579
- type: LlmEventType.TextDelta,
580
- text: repeatedContent,
581
- };
582
- let isLoop = false;
583
- for (let i = 0; i < CONTENT_LOOP_THRESHOLD; i++) {
584
- isLoop = service.addAndCheck(llmTextEvent);
585
- }
586
- expect(isLoop).toBe(true);
587
- expect(loggers.logLoopDetected).toHaveBeenCalledTimes(1);
588
- });
589
- it('should reset content tracking when ToolCallRequest arrives', () => {
590
- service.reset('');
591
- const repeatedContent = createRepetitiveContent(1, CONTENT_CHUNK_SIZE);
592
- const llmTextEvent = {
593
- type: LlmEventType.TextDelta,
594
- text: repeatedContent,
595
- };
596
- const llmToolCallEvent = {
597
- type: LlmEventType.ToolCallRequest,
598
- callId: 'call-1',
599
- name: 'someTool',
600
- args: { key: 'val' },
601
- };
602
- // Build up near content loop threshold
603
- for (let i = 0; i < CONTENT_LOOP_THRESHOLD - 2; i++) {
604
- service.addAndCheck(llmTextEvent);
605
- }
606
- // Tool call should reset content tracking
607
- service.addAndCheck(llmToolCallEvent);
608
- // Content should start fresh — no loop detection
609
- for (let i = 0; i < CONTENT_LOOP_THRESHOLD - 2; i++) {
610
- expect(service.addAndCheck(llmTextEvent)).toBe(false);
611
- }
612
- });
613
- it('should return false for non-monitored LlmEvent types', () => {
614
- const finishedEvent = {
615
- type: LlmEventType.Finished,
616
- finishReason: 'end_turn',
617
- };
618
- const errorEvent = {
619
- type: LlmEventType.Error,
620
- error: 'some error',
621
- };
622
- const retryEvent = {
623
- type: LlmEventType.Retry,
624
- };
625
- expect(service.addAndCheck(finishedEvent)).toBe(false);
626
- expect(service.addAndCheck(errorEvent)).toBe(false);
627
- expect(service.addAndCheck(retryEvent)).toBe(false);
628
- });
629
- it('should respect disabledForSession flag', () => {
630
- service.disableForSession();
631
- const llmToolCallEvent = {
632
- type: LlmEventType.ToolCallRequest,
633
- callId: 'call-1',
634
- name: 'testTool',
635
- args: { param: 'value' },
636
- };
637
- for (let i = 0; i < TOOL_CALL_LOOP_THRESHOLD + 5; i++) {
638
- expect(service.addAndCheck(llmToolCallEvent)).toBe(false);
639
- }
640
- expect(loggers.logLoopDetected).not.toHaveBeenCalled();
641
- });
642
- });
643
- });
644
- describe('LoopDetectionService LLM Checks', () => {
645
- let service;
646
- let mockConfig;
647
- let mockGeminiClient;
648
- let mockBaseLlmClient;
649
- let abortController;
650
- beforeEach(() => {
651
- mockGeminiClient = {
652
- getHistory: vi.fn().mockReturnValue([]),
653
- };
654
- mockBaseLlmClient = {
655
- generateJson: vi.fn(),
656
- };
657
- const mockAvailability = createAvailabilityServiceMock();
658
- vi.mocked(mockAvailability.snapshot).mockReturnValue({ available: true });
659
- mockConfig = {
660
- getGeminiClient: () => mockGeminiClient,
661
- getBaseLlmClient: () => mockBaseLlmClient,
662
- getDebugMode: () => false,
663
- getTelemetryEnabled: () => true,
664
- getModel: vi.fn().mockReturnValue('cognitive-loop-v1'),
665
- modelConfigService: {
666
- getResolvedConfig: vi.fn().mockImplementation((key) => {
667
- if (key.model === 'loop-detection') {
668
- return { model: 'gemini-2.5-flash', generateContentConfig: {} };
669
- }
670
- return {
671
- model: 'cognitive-loop-v1',
672
- generateContentConfig: {},
673
- };
674
- }),
675
- },
676
- isInteractive: () => false,
677
- getModelAvailabilityService: vi.fn().mockReturnValue(mockAvailability),
678
- };
679
- service = new LoopDetectionService(mockConfig);
680
- abortController = new AbortController();
681
- vi.clearAllMocks();
682
- });
683
- afterEach(() => {
684
- vi.restoreAllMocks();
685
- });
686
- const advanceTurns = async (count) => {
687
- for (let i = 0; i < count; i++) {
688
- await service.turnStarted(abortController.signal);
689
- }
690
- };
691
- it('should not trigger LLM check before LLM_CHECK_AFTER_TURNS', async () => {
692
- await advanceTurns(29);
693
- expect(mockBaseLlmClient.generateJson).not.toHaveBeenCalled();
694
- });
695
- it('should trigger LLM check on the 30th turn', async () => {
696
- mockBaseLlmClient.generateJson = vi
697
- .fn()
698
- .mockResolvedValue({ unproductive_state_confidence: 0.1 });
699
- await advanceTurns(30);
700
- expect(mockBaseLlmClient.generateJson).toHaveBeenCalledTimes(1);
701
- expect(mockBaseLlmClient.generateJson).toHaveBeenCalledWith(expect.objectContaining({
702
- modelConfigKey: { model: 'loop-detection' },
703
- systemInstruction: expect.any(String),
704
- contents: expect.any(Array),
705
- schema: expect.any(Object),
706
- promptId: expect.any(String),
707
- }));
708
- });
709
- it('should detect a cognitive loop when confidence is high', async () => {
710
- // First check at turn 30
711
- mockBaseLlmClient.generateJson = vi.fn().mockResolvedValue({
712
- unproductive_state_confidence: 0.85,
713
- unproductive_state_analysis: 'Repetitive actions',
714
- });
715
- await advanceTurns(30);
716
- expect(mockBaseLlmClient.generateJson).toHaveBeenCalledTimes(1);
717
- expect(mockBaseLlmClient.generateJson).toHaveBeenCalledWith(expect.objectContaining({
718
- modelConfigKey: { model: 'loop-detection' },
719
- }));
720
- // The confidence of 0.85 will result in a low interval.
721
- // The interval will be: 5 + (15 - 5) * (1 - 0.85) = 5 + 10 * 0.15 = 6.5 -> rounded to 7
722
- await advanceTurns(6); // advance to turn 36
723
- mockBaseLlmClient.generateJson = vi.fn().mockResolvedValue({
724
- unproductive_state_confidence: 0.95,
725
- unproductive_state_analysis: 'Repetitive actions',
726
- });
727
- const finalResult = await service.turnStarted(abortController.signal); // This is turn 37
728
- expect(finalResult).toBe(true);
729
- expect(loggers.logLoopDetected).toHaveBeenCalledWith(mockConfig, expect.objectContaining({
730
- 'event.name': 'loop_detected',
731
- loop_type: LoopType.LLM_DETECTED_LOOP,
732
- confirmed_by_model: 'cognitive-loop-v1',
733
- }));
734
- });
735
- it('should not detect a loop when confidence is low', async () => {
736
- mockBaseLlmClient.generateJson = vi.fn().mockResolvedValue({
737
- unproductive_state_confidence: 0.5,
738
- unproductive_state_analysis: 'Looks okay',
739
- });
740
- await advanceTurns(30);
741
- const result = await service.turnStarted(abortController.signal);
742
- expect(result).toBe(false);
743
- expect(loggers.logLoopDetected).not.toHaveBeenCalled();
744
- });
745
- it('should adjust the check interval based on confidence', async () => {
746
- // Confidence is 0.0, so interval should be MAX_LLM_CHECK_INTERVAL (15)
747
- mockBaseLlmClient.generateJson = vi
748
- .fn()
749
- .mockResolvedValue({ unproductive_state_confidence: 0.0 });
750
- await advanceTurns(30); // First check at turn 30
751
- expect(mockBaseLlmClient.generateJson).toHaveBeenCalledTimes(1);
752
- await advanceTurns(14); // Advance to turn 44
753
- expect(mockBaseLlmClient.generateJson).toHaveBeenCalledTimes(1);
754
- await service.turnStarted(abortController.signal); // Turn 45
755
- expect(mockBaseLlmClient.generateJson).toHaveBeenCalledTimes(2);
756
- });
757
- it('should handle errors from generateJson gracefully', async () => {
758
- mockBaseLlmClient.generateJson = vi
759
- .fn()
760
- .mockRejectedValue(new Error('API error'));
761
- await advanceTurns(30);
762
- const result = await service.turnStarted(abortController.signal);
763
- expect(result).toBe(false);
764
- expect(loggers.logLoopDetected).not.toHaveBeenCalled();
765
- });
766
- it('should not trigger LLM check when disabled for session', async () => {
767
- service.disableForSession();
768
- expect(loggers.logLoopDetectionDisabled).toHaveBeenCalledTimes(1);
769
- await advanceTurns(30);
770
- const result = await service.turnStarted(abortController.signal);
771
- expect(result).toBe(false);
772
- expect(mockBaseLlmClient.generateJson).not.toHaveBeenCalled();
773
- });
774
- it('should prepend user message if history starts with a function call', async () => {
775
- const functionCallHistory = [
776
- {
777
- role: 'model',
778
- parts: [{ functionCall: { name: 'someTool', args: {} } }],
779
- },
780
- {
781
- role: 'model',
782
- parts: [{ text: 'Some follow up text' }],
783
- },
784
- ];
785
- vi.mocked(mockGeminiClient.getHistory).mockReturnValue(functionCallHistory);
786
- mockBaseLlmClient.generateJson = vi
787
- .fn()
788
- .mockResolvedValue({ unproductive_state_confidence: 0.1 });
789
- await advanceTurns(30);
790
- expect(mockBaseLlmClient.generateJson).toHaveBeenCalledTimes(1);
791
- const calledArg = vi.mocked(mockBaseLlmClient.generateJson).mock
792
- .calls[0][0];
793
- expect(calledArg.contents[0]).toEqual({
794
- role: 'user',
795
- parts: [{ text: 'Recent conversation history:' }],
796
- });
797
- // Verify the original history follows
798
- expect(calledArg.contents[1]).toEqual(functionCallHistory[0]);
799
- });
800
- it('should detect a loop when confidence is exactly equal to the threshold (0.9)', async () => {
801
- mockBaseLlmClient.generateJson = vi
802
- .fn()
803
- .mockResolvedValueOnce({
804
- unproductive_state_confidence: 0.9,
805
- unproductive_state_analysis: 'Flash says loop',
806
- })
807
- .mockResolvedValueOnce({
808
- unproductive_state_confidence: 0.9,
809
- unproductive_state_analysis: 'Main says loop',
810
- });
811
- await advanceTurns(30);
812
- // It should have called generateJson twice
813
- expect(mockBaseLlmClient.generateJson).toHaveBeenCalledTimes(2);
814
- expect(mockBaseLlmClient.generateJson).toHaveBeenNthCalledWith(1, expect.objectContaining({
815
- modelConfigKey: { model: 'loop-detection' },
816
- }));
817
- expect(mockBaseLlmClient.generateJson).toHaveBeenNthCalledWith(2, expect.objectContaining({
818
- modelConfigKey: { model: 'loop-detection-double-check' },
819
- }));
820
- // And it should have detected a loop
821
- expect(loggers.logLoopDetected).toHaveBeenCalledWith(mockConfig, expect.objectContaining({
822
- 'event.name': 'loop_detected',
823
- loop_type: LoopType.LLM_DETECTED_LOOP,
824
- confirmed_by_model: 'cognitive-loop-v1',
825
- }));
826
- });
827
- it('should not detect a loop when Flash is confident (0.9) but Main model is not (0.89)', async () => {
828
- mockBaseLlmClient.generateJson = vi
829
- .fn()
830
- .mockResolvedValueOnce({
831
- unproductive_state_confidence: 0.9,
832
- unproductive_state_analysis: 'Flash says loop',
833
- })
834
- .mockResolvedValueOnce({
835
- unproductive_state_confidence: 0.89,
836
- unproductive_state_analysis: 'Main says no loop',
837
- });
838
- await advanceTurns(30);
839
- expect(mockBaseLlmClient.generateJson).toHaveBeenCalledTimes(2);
840
- expect(mockBaseLlmClient.generateJson).toHaveBeenNthCalledWith(1, expect.objectContaining({
841
- modelConfigKey: { model: 'loop-detection' },
842
- }));
843
- expect(mockBaseLlmClient.generateJson).toHaveBeenNthCalledWith(2, expect.objectContaining({
844
- modelConfigKey: { model: 'loop-detection-double-check' },
845
- }));
846
- // Should NOT have detected a loop
847
- expect(loggers.logLoopDetected).not.toHaveBeenCalled();
848
- // But should have updated the interval based on the main model's confidence (0.89)
849
- // Interval = 5 + (15-5) * (1 - 0.89) = 5 + 10 * 0.11 = 5 + 1.1 = 6.1 -> 6
850
- // Advance by 6 turns
851
- await advanceTurns(6);
852
- // Next turn (37) should trigger another check
853
- await service.turnStarted(abortController.signal);
854
- expect(mockBaseLlmClient.generateJson).toHaveBeenCalledTimes(3);
855
- });
856
- it('should only call Flash model if main model is unavailable', async () => {
857
- // Mock availability to return unavailable for the main model
858
- const availability = mockConfig.getModelAvailabilityService();
859
- vi.mocked(availability.snapshot).mockReturnValue({
860
- available: false,
861
- reason: 'quota',
862
- });
863
- mockBaseLlmClient.generateJson = vi.fn().mockResolvedValueOnce({
864
- unproductive_state_confidence: 0.9,
865
- unproductive_state_analysis: 'Flash says loop',
866
- });
867
- await advanceTurns(30);
868
- // It should have called generateJson only once
869
- expect(mockBaseLlmClient.generateJson).toHaveBeenCalledTimes(1);
870
- expect(mockBaseLlmClient.generateJson).toHaveBeenCalledWith(expect.objectContaining({
871
- modelConfigKey: { model: 'loop-detection' },
872
- }));
873
- // And it should have detected a loop
874
- expect(loggers.logLoopDetected).toHaveBeenCalledWith(mockConfig, expect.objectContaining({
875
- 'event.name': 'loop_detected',
876
- loop_type: LoopType.LLM_DETECTED_LOOP,
877
- confirmed_by_model: 'gemini-2.5-flash',
878
- }));
879
- });
880
- });
881
- //# sourceMappingURL=loopDetectionService.test.js.map