@didim365/agent-cli-core 0.1.1 → 0.1.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (1076) hide show
  1. package/package.json +6 -2
  2. package/dist/docs/00_project/ai_adapter/01-overview.md +0 -172
  3. package/dist/docs/00_project/ai_adapter/02-architecture.md +0 -448
  4. package/dist/docs/00_project/ai_adapter/03-technical-design.md +0 -1470
  5. package/dist/docs/00_project/ai_adapter/04-integration-design.md +0 -1934
  6. package/dist/docs/00_project/ai_adapter/05-implementation-plan.md +0 -336
  7. package/dist/docs/00_project/ai_adapter/06-didiaistudio-plan.md +0 -559
  8. package/dist/docs/00_project/ai_adapter/README.md +0 -145
  9. package/dist/docs/00_project/ai_adapter/agent_service_openapi.json +0 -1
  10. package/dist/docs/00_project/ai_adapter/didimStudi-AISTUDIO /341/204/213/341/205/254/341/204/207/341/205/256 /341/204/211/341/205/245/341/204/207/341/205/265/341/204/211/341/205/263 /341/204/221/341/205/263/341/206/257/341/204/205/341/205/251/341/204/213/341/205/256 /341/204/213/341/205/247/341/206/253/341/204/200/341/205/247/341/206/257 /341/204/207/341/205/241/341/206/274/341/204/211/341/205/265/341/206/250-100226-093925.pdf +0 -0
  11. package/dist/docs/00_project/ai_adapter/event-mapping-matrix.md +0 -148
  12. package/dist/docs/00_project/ai_adapter/migration-plan.md +0 -205
  13. package/dist/docs/00_project/ai_adapter/template/00_vibecoding_workflow.md +0 -627
  14. package/dist/docs/00_project/ai_adapter/template/01_todolist_performance_template.md +0 -436
  15. package/dist/docs/00_project/ai_adapter/template/02_code_review_template.md +0 -248
  16. package/dist/docs/00_project/ai_adapter/template/03_work_result_report_template.md +0 -133
  17. package/dist/docs/00_project/ai_adapter/template/100_Python_Performance_Guide.md +0 -472
  18. package/dist/docs/00_project/ai_adapter/template/99_TDD_plan.md +0 -123
  19. package/dist/docs/00_project/ai_adapter/todolist/00_master_implementation_plan.md +0 -433
  20. package/dist/docs/00_project/ai_adapter/todolist/phase1_foundation_todolist.md +0 -726
  21. package/dist/docs/00_project/ai_adapter/todolist/phase2_core_refactoring_todolist.md +0 -974
  22. package/dist/docs/00_project/ai_adapter/todolist/phase3_handoff.md +0 -203
  23. package/dist/docs/00_project/ai_adapter/todolist/phase3_provider_extension_todolist.md +0 -1382
  24. package/dist/docs/00_project/ai_adapter/utility-migration.md +0 -237
  25. package/dist/docs/00_project/ai_adapter/working_history/.gitkeep +0 -0
  26. package/dist/docs/00_project/ai_adapter/working_history/Phase1_M1.0_/354/275/224/353/223/234/354/235/270/353/262/244/355/206/240/353/246/254_20260201.md +0 -197
  27. package/dist/docs/00_project/ai_adapter/working_history/Phase1_M1.1_/355/203/200/354/236/205/354/204/244/352/263/204_20260201.md +0 -185
  28. package/dist/docs/00_project/ai_adapter/working_history/Phase1_M1.2_Adapter/354/235/270/355/224/204/353/235/274_20260203.md +0 -378
  29. package/dist/docs/00_project/ai_adapter/working_history/Phase1_M1.3_Provider/354/204/240/355/203/235_20260206.md +0 -269
  30. package/dist/docs/00_project/ai_adapter/working_history/Phase1_M1.4_/354/234/240/355/213/270/353/246/254/355/213/260/353/247/210/354/235/264/352/267/270/353/240/210/354/235/264/354/205/230_20260206.md +0 -86
  31. package/dist/docs/00_project/ai_adapter/working_history/Phase2_ETC_/354/227/260/352/270/260/354/236/221/354/227/205/354/240/225/353/246/254_20260208.md +0 -157
  32. package/dist/docs/00_project/ai_adapter/working_history/Phase2_M2.0_/353/224/224/353/240/211/355/206/240/353/246/254/354/236/254/352/265/254/354/204/261_20260207.md +0 -107
  33. package/dist/docs/00_project/ai_adapter/working_history/Phase2_M2.1_ContentGenerator/354/235/270/355/204/260/355/216/230/354/235/264/354/212/244/354/236/254/354/240/225/354/235/230_20260207.md +0 -630
  34. package/dist/docs/00_project/ai_adapter/working_history/Phase2_M2.2_EventMapper/352/265/254/355/230/204_20260207.md +0 -372
  35. package/dist/docs/00_project/ai_adapter/working_history/Phase2_M2.3_GeminiAdapter/352/265/254/355/230/204_20260208.md +0 -205
  36. package/dist/docs/00_project/ai_adapter/working_history/Phase2_M2.4_ModelConfigService/355/230/270/355/231/230/353/240/210/354/235/264/354/226/264_20260208.md +0 -275
  37. package/dist/docs/00_project/ai_adapter/working_history/Phase2_M2.5_/354/234/240/355/213/270/353/246/254/355/213/260/353/240/210/354/235/264/354/226/264/353/246/254/355/214/251/355/206/240/353/247/201_20260208.md +0 -239
  38. package/dist/docs/00_project/ai_adapter/working_history/Phase2_M2.6_/353/235/274/354/232/260/355/214/205/353/240/210/354/235/264/354/226/264/355/203/200/354/236/205/353/217/205/353/246/275/355/231/224_20260208.md +0 -228
  39. package/dist/docs/00_project/ai_adapter/working_history/Phase3_ETC_/352/270/260/353/263/270/354/273/250/355/205/215/354/212/244/355/212/270/355/214/214/354/235/274/353/252/205AGENTS/354/240/204/355/231/230_20260211.md +0 -470
  40. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.0.1_Gemini/354/240/204/354/232/251/355/214/214/354/235/274/353/254/274/353/246/254/354/240/201/354/235/264/353/217/231_20260209.md +0 -271
  41. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.0.2_messageInspectors/353/247/210/354/235/264/352/267/270/353/240/210/354/235/264/354/205/230_20260209.md +0 -330
  42. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.0.3_/355/205/224/353/240/210/353/251/224/355/212/270/353/246/254Agent/353/217/205/353/246/275/355/231/224_20260209.md +0 -251
  43. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.0.4_/353/263/200/355/231/230/353/270/214/353/246/277/354/247/200/354/240/225/353/246/254_20260209.md +0 -136
  44. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.0.5_/353/237/260/355/203/200/354/236/204/354/213/244/355/226/211/352/262/275/353/241/234/354/227/260/352/262/260_20260209.md +0 -232
  45. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.1.0_Claude/354/202/254/354/240/204/354/244/200/353/271/204_20260209.md +0 -191
  46. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.1.1_ClaudeAdapter/352/265/254/355/230/204_20260209.md +0 -225
  47. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.1.2_ClaudeConverter/352/263/240/353/217/204/355/231/224_20260209.md +0 -171
  48. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.1.3_ClaudeStreamError/352/263/240/353/217/204/355/231/224_20260209.md +0 -198
  49. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.1.4_ClaudeErrorMapping_20260209.md +0 -98
  50. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.2.A_OpenAIAdapterCore_20260210.md +0 -264
  51. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.2.B_OpenAIStreamConverter_20260210.md +0 -204
  52. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.3.2_/353/252/250/353/215/270/355/205/234/355/224/214/353/246/277/355/233/205/353/263/264/354/231/204_20260211.md +0 -106
  53. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.3_OpenAICompatibleAdapter_20260211.md +0 -251
  54. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.4.2_E2E/355/205/214/354/212/244/355/212/270/354/213/234/353/202/230/353/246/254/354/230/244_20260210.md +0 -264
  55. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.4.3_/354/204/261/353/212/245/355/232/214/352/267/200/355/205/214/354/212/244/355/212/270_20260211.md +0 -176
  56. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.4.5_/354/225/210/354/240/225/355/231/224/354/236/221/354/227/205_20260211.md +0 -204
  57. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.4.A_CLI/355/206/265/355/225/251_3Provider/355/206/265/355/225/251/355/205/214/354/212/244/355/212/270_20260210.md +0 -316
  58. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.4.A_UI/354/203/201/355/203/234/353/260/224/354/210/230/354/240/225_20260210.md +0 -262
  59. package/dist/docs/00_project/ai_adapter/working_history/phase2_tradeoff_EventType/354/240/204/355/231/230_20260208.md +0 -286
  60. package/dist/docs/00_project/white_labeling/template/00_vibecoding_workflow.md +0 -627
  61. package/dist/docs/00_project/white_labeling/template/01_todolist_performance_template.md +0 -400
  62. package/dist/docs/00_project/white_labeling/template/02_code_review_template.md +0 -248
  63. package/dist/docs/00_project/white_labeling/template/03_work_result_report_template.md +0 -133
  64. package/dist/docs/00_project/white_labeling/template/100_Python_Performance_Guide.md +0 -472
  65. package/dist/docs/00_project/white_labeling/template/99_TDD_plan.md +0 -123
  66. package/dist/docs/00_project/white_labeling/todolist/Phase_CLI/355/214/250/355/202/244/354/247/200/353/252/205/353/263/200/352/262/275_todolist.md +0 -431
  67. package/dist/docs/00_project/white_labeling/working_history/Phase_CLI/355/214/250/355/202/244/354/247/200/353/252/205/353/263/200/352/262/275_20260214.md +0 -238
  68. package/dist/docs/00_project/white_labeling//354/225/261/352/265/254/354/241/260.md +0 -310
  69. package/dist/docs/CONTRIBUTING.md +0 -554
  70. package/dist/docs/ai_adapter/01-overview.md +0 -155
  71. package/dist/docs/ai_adapter/02-architecture.md +0 -452
  72. package/dist/docs/ai_adapter/03-technical-design.md +0 -1470
  73. package/dist/docs/ai_adapter/04-integration-design.md +0 -1904
  74. package/dist/docs/ai_adapter/05-implementation-plan.md +0 -312
  75. package/dist/docs/ai_adapter/06-didiaistudio-plan.md +0 -559
  76. package/dist/docs/ai_adapter/README.md +0 -118
  77. package/dist/docs/ai_adapter/agent_service_openapi.json +0 -1
  78. package/dist/docs/ai_adapter/didimStudi-AISTUDIO /341/204/213/341/205/254/341/204/207/341/205/256 /341/204/211/341/205/245/341/204/207/341/205/265/341/204/211/341/205/263 /341/204/221/341/205/263/341/206/257/341/204/205/341/205/251/341/204/213/341/205/256 /341/204/213/341/205/247/341/206/253/341/204/200/341/205/247/341/206/257 /341/204/207/341/205/241/341/206/274/341/204/211/341/205/265/341/206/250-100226-093925.pdf +0 -0
  79. package/dist/docs/ai_adapter/event-mapping-matrix.md +0 -140
  80. package/dist/docs/ai_adapter/migration-plan.md +0 -205
  81. package/dist/docs/ai_adapter/template/00_vibecoding_workflow.md +0 -636
  82. package/dist/docs/ai_adapter/template/01_todolist_performance_template.md +0 -372
  83. package/dist/docs/ai_adapter/template/02_code_review_template.md +0 -220
  84. package/dist/docs/ai_adapter/template/03_work_result_report_template.md +0 -120
  85. package/dist/docs/ai_adapter/template/100_Python_Performance_Guide.md +0 -453
  86. package/dist/docs/ai_adapter/template/99_TDD_plan.md +0 -111
  87. package/dist/docs/ai_adapter/todolist/00_master_implementation_plan.md +0 -433
  88. package/dist/docs/ai_adapter/todolist/phase1_foundation_todolist.md +0 -726
  89. package/dist/docs/ai_adapter/todolist/phase2_core_refactoring_todolist.md +0 -974
  90. package/dist/docs/ai_adapter/todolist/phase3_handoff.md +0 -203
  91. package/dist/docs/ai_adapter/todolist/phase3_provider_extension_todolist.md +0 -1382
  92. package/dist/docs/ai_adapter/utility-migration.md +0 -237
  93. package/dist/docs/ai_adapter/working_history/.gitkeep +0 -0
  94. package/dist/docs/ai_adapter/working_history/Phase1_M1.0_/354/275/224/353/223/234/354/235/270/353/262/244/355/206/240/353/246/254_20260201.md +0 -185
  95. package/dist/docs/ai_adapter/working_history/Phase1_M1.1_/355/203/200/354/236/205/354/204/244/352/263/204_20260201.md +0 -185
  96. package/dist/docs/ai_adapter/working_history/Phase1_M1.2_Adapter/354/235/270/355/224/204/353/235/274_20260203.md +0 -378
  97. package/dist/docs/ai_adapter/working_history/Phase1_M1.3_Provider/354/204/240/355/203/235_20260206.md +0 -269
  98. package/dist/docs/ai_adapter/working_history/Phase1_M1.4_/354/234/240/355/213/270/353/246/254/355/213/260/353/247/210/354/235/264/352/267/270/353/240/210/354/235/264/354/205/230_20260206.md +0 -86
  99. package/dist/docs/ai_adapter/working_history/Phase2_ETC_/354/227/260/352/270/260/354/236/221/354/227/205/354/240/225/353/246/254_20260208.md +0 -157
  100. package/dist/docs/ai_adapter/working_history/Phase2_M2.0_/353/224/224/353/240/211/355/206/240/353/246/254/354/236/254/352/265/254/354/204/261_20260207.md +0 -107
  101. package/dist/docs/ai_adapter/working_history/Phase2_M2.1_ContentGenerator/354/235/270/355/204/260/355/216/230/354/235/264/354/212/244/354/236/254/354/240/225/354/235/230_20260207.md +0 -630
  102. package/dist/docs/ai_adapter/working_history/Phase2_M2.2_EventMapper/352/265/254/355/230/204_20260207.md +0 -372
  103. package/dist/docs/ai_adapter/working_history/Phase2_M2.3_GeminiAdapter/352/265/254/355/230/204_20260208.md +0 -205
  104. package/dist/docs/ai_adapter/working_history/Phase2_M2.4_ModelConfigService/355/230/270/355/231/230/353/240/210/354/235/264/354/226/264_20260208.md +0 -275
  105. package/dist/docs/ai_adapter/working_history/Phase2_M2.5_/354/234/240/355/213/270/353/246/254/355/213/260/353/240/210/354/235/264/354/226/264/353/246/254/355/214/251/355/206/240/353/247/201_20260208.md +0 -239
  106. package/dist/docs/ai_adapter/working_history/Phase2_M2.6_/353/235/274/354/232/260/355/214/205/353/240/210/354/235/264/354/226/264/355/203/200/354/236/205/353/217/205/353/246/275/355/231/224_20260208.md +0 -228
  107. package/dist/docs/ai_adapter/working_history/Phase3_ETC_/352/270/260/353/263/270/354/273/250/355/205/215/354/212/244/355/212/270/355/214/214/354/235/274/353/252/205AGENTS/354/240/204/355/231/230_20260211.md +0 -367
  108. package/dist/docs/ai_adapter/working_history/Phase3_M3.0.1_Gemini/354/240/204/354/232/251/355/214/214/354/235/274/353/254/274/353/246/254/354/240/201/354/235/264/353/217/231_20260209.md +0 -271
  109. package/dist/docs/ai_adapter/working_history/Phase3_M3.0.2_messageInspectors/353/247/210/354/235/264/352/267/270/353/240/210/354/235/264/354/205/230_20260209.md +0 -330
  110. package/dist/docs/ai_adapter/working_history/Phase3_M3.0.3_/355/205/224/353/240/210/353/251/224/355/212/270/353/246/254Agent/353/217/205/353/246/275/355/231/224_20260209.md +0 -251
  111. package/dist/docs/ai_adapter/working_history/Phase3_M3.0.4_/353/263/200/355/231/230/353/270/214/353/246/277/354/247/200/354/240/225/353/246/254_20260209.md +0 -136
  112. package/dist/docs/ai_adapter/working_history/Phase3_M3.0.5_/353/237/260/355/203/200/354/236/204/354/213/244/355/226/211/352/262/275/353/241/234/354/227/260/352/262/260_20260209.md +0 -232
  113. package/dist/docs/ai_adapter/working_history/Phase3_M3.1.0_Claude/354/202/254/354/240/204/354/244/200/353/271/204_20260209.md +0 -191
  114. package/dist/docs/ai_adapter/working_history/Phase3_M3.1.1_ClaudeAdapter/352/265/254/355/230/204_20260209.md +0 -225
  115. package/dist/docs/ai_adapter/working_history/Phase3_M3.1.2_ClaudeConverter/352/263/240/353/217/204/355/231/224_20260209.md +0 -171
  116. package/dist/docs/ai_adapter/working_history/Phase3_M3.1.3_ClaudeStreamError/352/263/240/353/217/204/355/231/224_20260209.md +0 -198
  117. package/dist/docs/ai_adapter/working_history/Phase3_M3.1.4_ClaudeErrorMapping_20260209.md +0 -98
  118. package/dist/docs/ai_adapter/working_history/Phase3_M3.2.A_OpenAIAdapterCore_20260210.md +0 -264
  119. package/dist/docs/ai_adapter/working_history/Phase3_M3.2.B_OpenAIStreamConverter_20260210.md +0 -204
  120. package/dist/docs/ai_adapter/working_history/Phase3_M3.3.2_/353/252/250/353/215/270/355/205/234/355/224/214/353/246/277/355/233/205/353/263/264/354/231/204_20260211.md +0 -106
  121. package/dist/docs/ai_adapter/working_history/Phase3_M3.3_OpenAICompatibleAdapter_20260211.md +0 -251
  122. package/dist/docs/ai_adapter/working_history/Phase3_M3.4.2_E2E/355/205/214/354/212/244/355/212/270/354/213/234/353/202/230/353/246/254/354/230/244_20260210.md +0 -264
  123. package/dist/docs/ai_adapter/working_history/Phase3_M3.4.3_/354/204/261/353/212/245/355/232/214/352/267/200/355/205/214/354/212/244/355/212/270_20260211.md +0 -176
  124. package/dist/docs/ai_adapter/working_history/Phase3_M3.4.5_/354/225/210/354/240/225/355/231/224/354/236/221/354/227/205_20260211.md +0 -204
  125. package/dist/docs/ai_adapter/working_history/Phase3_M3.4.A_CLI/355/206/265/355/225/251_3Provider/355/206/265/355/225/251/355/205/214/354/212/244/355/212/270_20260210.md +0 -316
  126. package/dist/docs/ai_adapter/working_history/Phase3_M3.4.A_UI/354/203/201/355/203/234/353/260/224/354/210/230/354/240/225_20260210.md +0 -262
  127. package/dist/docs/ai_adapter/working_history/phase2_tradeoff_EventType/354/240/204/355/231/230_20260208.md +0 -286
  128. package/dist/docs/api/index.md +0 -5
  129. package/dist/docs/api/providers.md +0 -56
  130. package/dist/docs/architecture.md +0 -80
  131. package/dist/docs/assets/connected_devtools.png +0 -0
  132. package/dist/docs/assets/gemini-screenshot.png +0 -0
  133. package/dist/docs/assets/monitoring-dashboard-logs.png +0 -0
  134. package/dist/docs/assets/monitoring-dashboard-metrics.png +0 -0
  135. package/dist/docs/assets/monitoring-dashboard-overview.png +0 -0
  136. package/dist/docs/assets/release_patch.png +0 -0
  137. package/dist/docs/assets/theme-ansi-light.png +0 -0
  138. package/dist/docs/assets/theme-ansi.png +0 -0
  139. package/dist/docs/assets/theme-atom-one.png +0 -0
  140. package/dist/docs/assets/theme-ayu-light.png +0 -0
  141. package/dist/docs/assets/theme-ayu.png +0 -0
  142. package/dist/docs/assets/theme-custom.png +0 -0
  143. package/dist/docs/assets/theme-default-light.png +0 -0
  144. package/dist/docs/assets/theme-default.png +0 -0
  145. package/dist/docs/assets/theme-dracula.png +0 -0
  146. package/dist/docs/assets/theme-github-light.png +0 -0
  147. package/dist/docs/assets/theme-github.png +0 -0
  148. package/dist/docs/assets/theme-google-light.png +0 -0
  149. package/dist/docs/assets/theme-xcode-light.png +0 -0
  150. package/dist/docs/change_model/model_command_multi_provider_plan.md +0 -221
  151. package/dist/docs/change_model/model_command_multi_provider_todolist.md +0 -206
  152. package/dist/docs/changelogs/index.md +0 -726
  153. package/dist/docs/changelogs/latest.md +0 -370
  154. package/dist/docs/changelogs/preview.md +0 -332
  155. package/dist/docs/cli/authentication.md +0 -3
  156. package/dist/docs/cli/checkpointing.md +0 -94
  157. package/dist/docs/cli/commands.md +0 -375
  158. package/dist/docs/cli/custom-commands.md +0 -315
  159. package/dist/docs/cli/enterprise.md +0 -565
  160. package/dist/docs/cli/gemini-ignore.md +0 -71
  161. package/dist/docs/cli/gemini-md.md +0 -108
  162. package/dist/docs/cli/generation-settings.md +0 -210
  163. package/dist/docs/cli/headless.md +0 -388
  164. package/dist/docs/cli/index.md +0 -65
  165. package/dist/docs/cli/keyboard-shortcuts.md +0 -129
  166. package/dist/docs/cli/model-routing.md +0 -42
  167. package/dist/docs/cli/model.md +0 -62
  168. package/dist/docs/cli/sandbox.md +0 -171
  169. package/dist/docs/cli/session-management.md +0 -158
  170. package/dist/docs/cli/settings.md +0 -130
  171. package/dist/docs/cli/skills.md +0 -188
  172. package/dist/docs/cli/system-prompt.md +0 -125
  173. package/dist/docs/cli/telemetry.md +0 -826
  174. package/dist/docs/cli/themes.md +0 -235
  175. package/dist/docs/cli/token-caching.md +0 -20
  176. package/dist/docs/cli/trusted-folders.md +0 -95
  177. package/dist/docs/cli/tutorials/skills-getting-started.md +0 -124
  178. package/dist/docs/cli/tutorials.md +0 -87
  179. package/dist/docs/cli/uninstall.md +0 -65
  180. package/dist/docs/configuration.md +0 -108
  181. package/dist/docs/core/index.md +0 -105
  182. package/dist/docs/core/long-term-memory-design.md +0 -254
  183. package/dist/docs/core/long-term-memory-proposal.md +0 -112
  184. package/dist/docs/core/memport.md +0 -246
  185. package/dist/docs/core/policy-engine.md +0 -300
  186. package/dist/docs/core/tools-api.md +0 -131
  187. package/dist/docs/examples/proxy-script.md +0 -83
  188. package/dist/docs/extensions/best-practices.md +0 -139
  189. package/dist/docs/extensions/index.md +0 -44
  190. package/dist/docs/extensions/reference.md +0 -312
  191. package/dist/docs/extensions/releasing.md +0 -183
  192. package/dist/docs/extensions/writing-extensions.md +0 -283
  193. package/dist/docs/faq.md +0 -154
  194. package/dist/docs/get-started/authentication.md +0 -321
  195. package/dist/docs/get-started/configuration-v1.md +0 -888
  196. package/dist/docs/get-started/configuration.md +0 -1567
  197. package/dist/docs/get-started/examples.md +0 -219
  198. package/dist/docs/get-started/gemini-3.md +0 -101
  199. package/dist/docs/get-started/index.md +0 -71
  200. package/dist/docs/get-started/installation.md +0 -141
  201. package/dist/docs/hooks/best-practices.md +0 -677
  202. package/dist/docs/hooks/index.md +0 -178
  203. package/dist/docs/hooks/reference.md +0 -322
  204. package/dist/docs/hooks/writing-hooks.md +0 -450
  205. package/dist/docs/ide-integration/ide-companion-spec.md +0 -267
  206. package/dist/docs/ide-integration/index.md +0 -202
  207. package/dist/docs/index.md +0 -153
  208. package/dist/docs/integration-tests.md +0 -211
  209. package/dist/docs/issue-and-pr-automation.md +0 -134
  210. package/dist/docs/local-development.md +0 -128
  211. package/dist/docs/mermaid/context.mmd +0 -103
  212. package/dist/docs/mermaid/render-path.mmd +0 -64
  213. package/dist/docs/migration.md +0 -78
  214. package/dist/docs/npm.md +0 -62
  215. package/dist/docs/providers.md +0 -136
  216. package/dist/docs/quota-and-pricing.md +0 -158
  217. package/dist/docs/release-confidence.md +0 -164
  218. package/dist/docs/releases.md +0 -539
  219. package/dist/docs/sidebar.json +0 -140
  220. package/dist/docs/tools/file-system.md +0 -217
  221. package/dist/docs/tools/index.md +0 -98
  222. package/dist/docs/tools/mcp-server.md +0 -1068
  223. package/dist/docs/tools/memory.md +0 -54
  224. package/dist/docs/tools/shell.md +0 -260
  225. package/dist/docs/tools/todos.md +0 -57
  226. package/dist/docs/tools/web-fetch.md +0 -59
  227. package/dist/docs/tools/web-search.md +0 -42
  228. package/dist/docs/tos-privacy.md +0 -96
  229. package/dist/docs/troubleshooting.md +0 -173
  230. package/dist/src/agents/a2a-client-manager.test.d.ts +0 -6
  231. package/dist/src/agents/a2a-client-manager.test.js +0 -220
  232. package/dist/src/agents/a2a-client-manager.test.js.map +0 -1
  233. package/dist/src/agents/a2aUtils.test.d.ts +0 -6
  234. package/dist/src/agents/a2aUtils.test.js +0 -147
  235. package/dist/src/agents/a2aUtils.test.js.map +0 -1
  236. package/dist/src/agents/acknowledgedAgents.test.d.ts +0 -6
  237. package/dist/src/agents/acknowledgedAgents.test.js +0 -70
  238. package/dist/src/agents/acknowledgedAgents.test.js.map +0 -1
  239. package/dist/src/agents/agent-scheduler.test.d.ts +0 -6
  240. package/dist/src/agents/agent-scheduler.test.js +0 -56
  241. package/dist/src/agents/agent-scheduler.test.js.map +0 -1
  242. package/dist/src/agents/agentLoader.test.d.ts +0 -6
  243. package/dist/src/agents/agentLoader.test.js +0 -304
  244. package/dist/src/agents/agentLoader.test.js.map +0 -1
  245. package/dist/src/agents/cli-help-agent.test.d.ts +0 -6
  246. package/dist/src/agents/cli-help-agent.test.js +0 -67
  247. package/dist/src/agents/cli-help-agent.test.js.map +0 -1
  248. package/dist/src/agents/codebase-investigator.test.d.ts +0 -6
  249. package/dist/src/agents/codebase-investigator.test.js +0 -42
  250. package/dist/src/agents/codebase-investigator.test.js.map +0 -1
  251. package/dist/src/agents/generalist-agent.test.d.ts +0 -6
  252. package/dist/src/agents/generalist-agent.test.js +0 -31
  253. package/dist/src/agents/generalist-agent.test.js.map +0 -1
  254. package/dist/src/agents/local-executor.test.d.ts +0 -6
  255. package/dist/src/agents/local-executor.test.js +0 -1577
  256. package/dist/src/agents/local-executor.test.js.map +0 -1
  257. package/dist/src/agents/local-invocation.test.d.ts +0 -6
  258. package/dist/src/agents/local-invocation.test.js +0 -228
  259. package/dist/src/agents/local-invocation.test.js.map +0 -1
  260. package/dist/src/agents/registry.test.d.ts +0 -6
  261. package/dist/src/agents/registry.test.js +0 -773
  262. package/dist/src/agents/registry.test.js.map +0 -1
  263. package/dist/src/agents/registry_acknowledgement.test.d.ts +0 -6
  264. package/dist/src/agents/registry_acknowledgement.test.js +0 -130
  265. package/dist/src/agents/registry_acknowledgement.test.js.map +0 -1
  266. package/dist/src/agents/remote-invocation.test.d.ts +0 -6
  267. package/dist/src/agents/remote-invocation.test.js +0 -213
  268. package/dist/src/agents/remote-invocation.test.js.map +0 -1
  269. package/dist/src/agents/subagent-tool-wrapper.test.d.ts +0 -6
  270. package/dist/src/agents/subagent-tool-wrapper.test.js +0 -109
  271. package/dist/src/agents/subagent-tool-wrapper.test.js.map +0 -1
  272. package/dist/src/agents/utils.test.d.ts +0 -6
  273. package/dist/src/agents/utils.test.js +0 -87
  274. package/dist/src/agents/utils.test.js.map +0 -1
  275. package/dist/src/availability/fallbackIntegration.test.d.ts +0 -6
  276. package/dist/src/availability/fallbackIntegration.test.js +0 -58
  277. package/dist/src/availability/fallbackIntegration.test.js.map +0 -1
  278. package/dist/src/availability/modelAvailabilityService.test.d.ts +0 -6
  279. package/dist/src/availability/modelAvailabilityService.test.js +0 -140
  280. package/dist/src/availability/modelAvailabilityService.test.js.map +0 -1
  281. package/dist/src/availability/policyCatalog.test.d.ts +0 -6
  282. package/dist/src/availability/policyCatalog.test.js +0 -70
  283. package/dist/src/availability/policyCatalog.test.js.map +0 -1
  284. package/dist/src/availability/policyHelpers.test.d.ts +0 -6
  285. package/dist/src/availability/policyHelpers.test.js +0 -220
  286. package/dist/src/availability/policyHelpers.test.js.map +0 -1
  287. package/dist/src/code_assist/admin/admin_controls.test.d.ts +0 -6
  288. package/dist/src/code_assist/admin/admin_controls.test.js +0 -200
  289. package/dist/src/code_assist/admin/admin_controls.test.js.map +0 -1
  290. package/dist/src/code_assist/codeAssist.test.d.ts +0 -6
  291. package/dist/src/code_assist/codeAssist.test.js +0 -102
  292. package/dist/src/code_assist/codeAssist.test.js.map +0 -1
  293. package/dist/src/code_assist/converter.test.d.ts +0 -6
  294. package/dist/src/code_assist/converter.test.js +0 -391
  295. package/dist/src/code_assist/converter.test.js.map +0 -1
  296. package/dist/src/code_assist/experiments/client_metadata.test.d.ts +0 -6
  297. package/dist/src/code_assist/experiments/client_metadata.test.js +0 -96
  298. package/dist/src/code_assist/experiments/client_metadata.test.js.map +0 -1
  299. package/dist/src/code_assist/experiments/experiments.test.d.ts +0 -6
  300. package/dist/src/code_assist/experiments/experiments.test.js +0 -93
  301. package/dist/src/code_assist/experiments/experiments.test.js.map +0 -1
  302. package/dist/src/code_assist/experiments/experiments_local.test.d.ts +0 -6
  303. package/dist/src/code_assist/experiments/experiments_local.test.js +0 -115
  304. package/dist/src/code_assist/experiments/experiments_local.test.js.map +0 -1
  305. package/dist/src/code_assist/oauth-credential-storage.test.d.ts +0 -6
  306. package/dist/src/code_assist/oauth-credential-storage.test.js +0 -198
  307. package/dist/src/code_assist/oauth-credential-storage.test.js.map +0 -1
  308. package/dist/src/code_assist/oauth2.test.d.ts +0 -6
  309. package/dist/src/code_assist/oauth2.test.js +0 -1065
  310. package/dist/src/code_assist/oauth2.test.js.map +0 -1
  311. package/dist/src/code_assist/server.test.d.ts +0 -6
  312. package/dist/src/code_assist/server.test.js +0 -453
  313. package/dist/src/code_assist/server.test.js.map +0 -1
  314. package/dist/src/code_assist/setup.test.d.ts +0 -6
  315. package/dist/src/code_assist/setup.test.js +0 -517
  316. package/dist/src/code_assist/setup.test.js.map +0 -1
  317. package/dist/src/code_assist/telemetry.test.d.ts +0 -6
  318. package/dist/src/code_assist/telemetry.test.js +0 -301
  319. package/dist/src/code_assist/telemetry.test.js.map +0 -1
  320. package/dist/src/commands/extensions.test.d.ts +0 -6
  321. package/dist/src/commands/extensions.test.js +0 -19
  322. package/dist/src/commands/extensions.test.js.map +0 -1
  323. package/dist/src/commands/init.test.d.ts +0 -6
  324. package/dist/src/commands/init.test.js +0 -25
  325. package/dist/src/commands/init.test.js.map +0 -1
  326. package/dist/src/commands/memory.test.d.ts +0 -6
  327. package/dist/src/commands/memory.test.js +0 -182
  328. package/dist/src/commands/memory.test.js.map +0 -1
  329. package/dist/src/commands/restore.test.d.ts +0 -6
  330. package/dist/src/commands/restore.test.js +0 -137
  331. package/dist/src/commands/restore.test.js.map +0 -1
  332. package/dist/src/config/config.test.d.ts +0 -6
  333. package/dist/src/config/config.test.js +0 -1811
  334. package/dist/src/config/config.test.js.map +0 -1
  335. package/dist/src/config/flashFallback.test.d.ts +0 -6
  336. package/dist/src/config/flashFallback.test.js +0 -63
  337. package/dist/src/config/flashFallback.test.js.map +0 -1
  338. package/dist/src/config/models.test.d.ts +0 -6
  339. package/dist/src/config/models.test.js +0 -146
  340. package/dist/src/config/models.test.js.map +0 -1
  341. package/dist/src/config/storage.test.d.ts +0 -6
  342. package/dist/src/config/storage.test.js +0 -115
  343. package/dist/src/config/storage.test.js.map +0 -1
  344. package/dist/src/confirmation-bus/message-bus.test.d.ts +0 -6
  345. package/dist/src/confirmation-bus/message-bus.test.js +0 -170
  346. package/dist/src/confirmation-bus/message-bus.test.js.map +0 -1
  347. package/dist/src/core/apiKeyCredentialStorage.test.d.ts +0 -6
  348. package/dist/src/core/apiKeyCredentialStorage.test.js +0 -71
  349. package/dist/src/core/apiKeyCredentialStorage.test.js.map +0 -1
  350. package/dist/src/core/baseLlmClient.test.d.ts +0 -6
  351. package/dist/src/core/baseLlmClient.test.js +0 -569
  352. package/dist/src/core/baseLlmClient.test.js.map +0 -1
  353. package/dist/src/core/baseLlmClient_new_types.test.d.ts +0 -1
  354. package/dist/src/core/baseLlmClient_new_types.test.js +0 -387
  355. package/dist/src/core/baseLlmClient_new_types.test.js.map +0 -1
  356. package/dist/src/core/client.test.d.ts +0 -6
  357. package/dist/src/core/client.test.js +0 -2654
  358. package/dist/src/core/client.test.js.map +0 -1
  359. package/dist/src/core/contentGenerator.multiProvider.test.d.ts +0 -6
  360. package/dist/src/core/contentGenerator.multiProvider.test.js +0 -314
  361. package/dist/src/core/contentGenerator.multiProvider.test.js.map +0 -1
  362. package/dist/src/core/contentGenerator.test.d.ts +0 -6
  363. package/dist/src/core/contentGenerator.test.js +0 -299
  364. package/dist/src/core/contentGenerator.test.js.map +0 -1
  365. package/dist/src/core/contentGenerator_new_types.test.d.ts +0 -6
  366. package/dist/src/core/contentGenerator_new_types.test.js +0 -292
  367. package/dist/src/core/contentGenerator_new_types.test.js.map +0 -1
  368. package/dist/src/core/coreToolHookTriggers.test.d.ts +0 -6
  369. package/dist/src/core/coreToolHookTriggers.test.js +0 -159
  370. package/dist/src/core/coreToolHookTriggers.test.js.map +0 -1
  371. package/dist/src/core/coreToolScheduler.test.d.ts +0 -6
  372. package/dist/src/core/coreToolScheduler.test.js +0 -1684
  373. package/dist/src/core/coreToolScheduler.test.js.map +0 -1
  374. package/dist/src/core/fakeContentGenerator.test.d.ts +0 -6
  375. package/dist/src/core/fakeContentGenerator.test.js +0 -127
  376. package/dist/src/core/fakeContentGenerator.test.js.map +0 -1
  377. package/dist/src/core/geminiChat.test.d.ts +0 -6
  378. package/dist/src/core/geminiChat.test.js +0 -1773
  379. package/dist/src/core/geminiChat.test.js.map +0 -1
  380. package/dist/src/core/geminiChat_network_retry.test.d.ts +0 -6
  381. package/dist/src/core/geminiChat_network_retry.test.js +0 -201
  382. package/dist/src/core/geminiChat_network_retry.test.js.map +0 -1
  383. package/dist/src/core/logger.test.d.ts +0 -6
  384. package/dist/src/core/logger.test.js +0 -550
  385. package/dist/src/core/logger.test.js.map +0 -1
  386. package/dist/src/core/loggingContentGenerator.test.d.ts +0 -6
  387. package/dist/src/core/loggingContentGenerator.test.js +0 -221
  388. package/dist/src/core/loggingContentGenerator.test.js.map +0 -1
  389. package/dist/src/core/prompts-substitution.test.d.ts +0 -6
  390. package/dist/src/core/prompts-substitution.test.js +0 -101
  391. package/dist/src/core/prompts-substitution.test.js.map +0 -1
  392. package/dist/src/core/prompts.test.d.ts +0 -6
  393. package/dist/src/core/prompts.test.js +0 -391
  394. package/dist/src/core/prompts.test.js.map +0 -1
  395. package/dist/src/core/recordingContentGenerator.test.d.ts +0 -6
  396. package/dist/src/core/recordingContentGenerator.test.js +0 -101
  397. package/dist/src/core/recordingContentGenerator.test.js.map +0 -1
  398. package/dist/src/core/tokenLimits.test.d.ts +0 -6
  399. package/dist/src/core/tokenLimits.test.js +0 -30
  400. package/dist/src/core/tokenLimits.test.js.map +0 -1
  401. package/dist/src/core/turn.test.d.ts +0 -6
  402. package/dist/src/core/turn.test.js +0 -739
  403. package/dist/src/core/turn.test.js.map +0 -1
  404. package/dist/src/fallback/handler.test.d.ts +0 -6
  405. package/dist/src/fallback/handler.test.js +0 -242
  406. package/dist/src/fallback/handler.test.js.map +0 -1
  407. package/dist/src/hooks/hookAggregator.test.d.ts +0 -6
  408. package/dist/src/hooks/hookAggregator.test.js +0 -387
  409. package/dist/src/hooks/hookAggregator.test.js.map +0 -1
  410. package/dist/src/hooks/hookEventHandler.test.d.ts +0 -6
  411. package/dist/src/hooks/hookEventHandler.test.js +0 -603
  412. package/dist/src/hooks/hookEventHandler.test.js.map +0 -1
  413. package/dist/src/hooks/hookPlanner.test.d.ts +0 -6
  414. package/dist/src/hooks/hookPlanner.test.js +0 -315
  415. package/dist/src/hooks/hookPlanner.test.js.map +0 -1
  416. package/dist/src/hooks/hookRegistry.test.d.ts +0 -6
  417. package/dist/src/hooks/hookRegistry.test.js +0 -529
  418. package/dist/src/hooks/hookRegistry.test.js.map +0 -1
  419. package/dist/src/hooks/hookRunner.test.d.ts +0 -6
  420. package/dist/src/hooks/hookRunner.test.js +0 -606
  421. package/dist/src/hooks/hookRunner.test.js.map +0 -1
  422. package/dist/src/hooks/hookSystem.test.d.ts +0 -6
  423. package/dist/src/hooks/hookSystem.test.js +0 -330
  424. package/dist/src/hooks/hookSystem.test.js.map +0 -1
  425. package/dist/src/hooks/hookSystem_new_types.test.d.ts +0 -6
  426. package/dist/src/hooks/hookSystem_new_types.test.js +0 -243
  427. package/dist/src/hooks/hookSystem_new_types.test.js.map +0 -1
  428. package/dist/src/hooks/hookTranslator.test.d.ts +0 -6
  429. package/dist/src/hooks/hookTranslator.test.js +0 -192
  430. package/dist/src/hooks/hookTranslator.test.js.map +0 -1
  431. package/dist/src/hooks/trustedHooks.test.d.ts +0 -6
  432. package/dist/src/hooks/trustedHooks.test.js +0 -154
  433. package/dist/src/hooks/trustedHooks.test.js.map +0 -1
  434. package/dist/src/hooks/types.test.d.ts +0 -6
  435. package/dist/src/hooks/types.test.js +0 -278
  436. package/dist/src/hooks/types.test.js.map +0 -1
  437. package/dist/src/ide/detect-ide.test.d.ts +0 -6
  438. package/dist/src/ide/detect-ide.test.js +0 -195
  439. package/dist/src/ide/detect-ide.test.js.map +0 -1
  440. package/dist/src/ide/ide-client.test.d.ts +0 -6
  441. package/dist/src/ide/ide-client.test.js +0 -753
  442. package/dist/src/ide/ide-client.test.js.map +0 -1
  443. package/dist/src/ide/ide-installer.test.d.ts +0 -6
  444. package/dist/src/ide/ide-installer.test.js +0 -193
  445. package/dist/src/ide/ide-installer.test.js.map +0 -1
  446. package/dist/src/ide/ideContext.test.d.ts +0 -6
  447. package/dist/src/ide/ideContext.test.js +0 -393
  448. package/dist/src/ide/ideContext.test.js.map +0 -1
  449. package/dist/src/ide/process-utils.test.d.ts +0 -6
  450. package/dist/src/ide/process-utils.test.js +0 -151
  451. package/dist/src/ide/process-utils.test.js.map +0 -1
  452. package/dist/src/index.test.d.ts +0 -6
  453. package/dist/src/index.test.js +0 -53
  454. package/dist/src/index.test.js.map +0 -1
  455. package/dist/src/mcp/google-auth-provider.test.d.ts +0 -6
  456. package/dist/src/mcp/google-auth-provider.test.js +0 -167
  457. package/dist/src/mcp/google-auth-provider.test.js.map +0 -1
  458. package/dist/src/mcp/oauth-provider.test.d.ts +0 -6
  459. package/dist/src/mcp/oauth-provider.test.js +0 -1355
  460. package/dist/src/mcp/oauth-provider.test.js.map +0 -1
  461. package/dist/src/mcp/oauth-token-storage.test.d.ts +0 -6
  462. package/dist/src/mcp/oauth-token-storage.test.js +0 -305
  463. package/dist/src/mcp/oauth-token-storage.test.js.map +0 -1
  464. package/dist/src/mcp/oauth-utils.test.d.ts +0 -6
  465. package/dist/src/mcp/oauth-utils.test.js +0 -289
  466. package/dist/src/mcp/oauth-utils.test.js.map +0 -1
  467. package/dist/src/mcp/sa-impersonation-provider.test.d.ts +0 -6
  468. package/dist/src/mcp/sa-impersonation-provider.test.js +0 -117
  469. package/dist/src/mcp/sa-impersonation-provider.test.js.map +0 -1
  470. package/dist/src/mcp/token-storage/base-token-storage.test.d.ts +0 -6
  471. package/dist/src/mcp/token-storage/base-token-storage.test.js +0 -151
  472. package/dist/src/mcp/token-storage/base-token-storage.test.js.map +0 -1
  473. package/dist/src/mcp/token-storage/file-token-storage.test.d.ts +0 -6
  474. package/dist/src/mcp/token-storage/file-token-storage.test.js +0 -238
  475. package/dist/src/mcp/token-storage/file-token-storage.test.js.map +0 -1
  476. package/dist/src/mcp/token-storage/hybrid-token-storage.test.d.ts +0 -6
  477. package/dist/src/mcp/token-storage/hybrid-token-storage.test.js +0 -193
  478. package/dist/src/mcp/token-storage/hybrid-token-storage.test.js.map +0 -1
  479. package/dist/src/mcp/token-storage/keychain-token-storage.test.d.ts +0 -6
  480. package/dist/src/mcp/token-storage/keychain-token-storage.test.js +0 -305
  481. package/dist/src/mcp/token-storage/keychain-token-storage.test.js.map +0 -1
  482. package/dist/src/output/json-formatter.test.d.ts +0 -6
  483. package/dist/src/output/json-formatter.test.js +0 -294
  484. package/dist/src/output/json-formatter.test.js.map +0 -1
  485. package/dist/src/output/stream-json-formatter.test.d.ts +0 -6
  486. package/dist/src/output/stream-json-formatter.test.js +0 -477
  487. package/dist/src/output/stream-json-formatter.test.js.map +0 -1
  488. package/dist/src/policy/config.test.d.ts +0 -6
  489. package/dist/src/policy/config.test.js +0 -598
  490. package/dist/src/policy/config.test.js.map +0 -1
  491. package/dist/src/policy/persistence.test.d.ts +0 -6
  492. package/dist/src/policy/persistence.test.js +0 -154
  493. package/dist/src/policy/persistence.test.js.map +0 -1
  494. package/dist/src/policy/policy-engine.test.d.ts +0 -6
  495. package/dist/src/policy/policy-engine.test.js +0 -1299
  496. package/dist/src/policy/policy-engine.test.js.map +0 -1
  497. package/dist/src/policy/policy-updater.test.d.ts +0 -6
  498. package/dist/src/policy/policy-updater.test.js +0 -116
  499. package/dist/src/policy/policy-updater.test.js.map +0 -1
  500. package/dist/src/policy/shell-safety.test.d.ts +0 -6
  501. package/dist/src/policy/shell-safety.test.js +0 -438
  502. package/dist/src/policy/shell-safety.test.js.map +0 -1
  503. package/dist/src/policy/toml-loader.test.d.ts +0 -6
  504. package/dist/src/policy/toml-loader.test.js +0 -409
  505. package/dist/src/policy/toml-loader.test.js.map +0 -1
  506. package/dist/src/policy/utils.test.d.ts +0 -6
  507. package/dist/src/policy/utils.test.js +0 -92
  508. package/dist/src/policy/utils.test.js.map +0 -1
  509. package/dist/src/prompts/mcp-prompts.test.d.ts +0 -6
  510. package/dist/src/prompts/mcp-prompts.test.js +0 -39
  511. package/dist/src/prompts/mcp-prompts.test.js.map +0 -1
  512. package/dist/src/prompts/prompt-registry.test.d.ts +0 -6
  513. package/dist/src/prompts/prompt-registry.test.js +0 -96
  514. package/dist/src/prompts/prompt-registry.test.js.map +0 -1
  515. package/dist/src/providers/__tests__/bundleSize.test.d.ts +0 -6
  516. package/dist/src/providers/__tests__/bundleSize.test.js +0 -75
  517. package/dist/src/providers/__tests__/bundleSize.test.js.map +0 -1
  518. package/dist/src/providers/__tests__/errorHandling.integration.test.d.ts +0 -6
  519. package/dist/src/providers/__tests__/errorHandling.integration.test.js +0 -339
  520. package/dist/src/providers/__tests__/errorHandling.integration.test.js.map +0 -1
  521. package/dist/src/providers/__tests__/multiProvider.integration.test.d.ts +0 -6
  522. package/dist/src/providers/__tests__/multiProvider.integration.test.js +0 -419
  523. package/dist/src/providers/__tests__/multiProvider.integration.test.js.map +0 -1
  524. package/dist/src/providers/__tests__/performance.test.d.ts +0 -6
  525. package/dist/src/providers/__tests__/performance.test.js +0 -270
  526. package/dist/src/providers/__tests__/performance.test.js.map +0 -1
  527. package/dist/src/providers/__tests__/providerConfigIntegration.test.d.ts +0 -6
  528. package/dist/src/providers/__tests__/providerConfigIntegration.test.js +0 -245
  529. package/dist/src/providers/__tests__/providerConfigIntegration.test.js.map +0 -1
  530. package/dist/src/providers/baseAdapter.test.d.ts +0 -1
  531. package/dist/src/providers/baseAdapter.test.js +0 -142
  532. package/dist/src/providers/baseAdapter.test.js.map +0 -1
  533. package/dist/src/providers/claude/adapter.test.d.ts +0 -6
  534. package/dist/src/providers/claude/adapter.test.js +0 -628
  535. package/dist/src/providers/claude/adapter.test.js.map +0 -1
  536. package/dist/src/providers/claude/bootstrap.test.d.ts +0 -6
  537. package/dist/src/providers/claude/bootstrap.test.js +0 -74
  538. package/dist/src/providers/claude/bootstrap.test.js.map +0 -1
  539. package/dist/src/providers/claude/converter.test.d.ts +0 -6
  540. package/dist/src/providers/claude/converter.test.js +0 -1002
  541. package/dist/src/providers/claude/converter.test.js.map +0 -1
  542. package/dist/src/providers/claude/exports.test.d.ts +0 -6
  543. package/dist/src/providers/claude/exports.test.js +0 -40
  544. package/dist/src/providers/claude/exports.test.js.map +0 -1
  545. package/dist/src/providers/configAdapter.test.d.ts +0 -1
  546. package/dist/src/providers/configAdapter.test.js +0 -150
  547. package/dist/src/providers/configAdapter.test.js.map +0 -1
  548. package/dist/src/providers/contentResolver.test.d.ts +0 -1
  549. package/dist/src/providers/contentResolver.test.js +0 -89
  550. package/dist/src/providers/contentResolver.test.js.map +0 -1
  551. package/dist/src/providers/factory.test.d.ts +0 -1
  552. package/dist/src/providers/factory.test.js +0 -151
  553. package/dist/src/providers/factory.test.js.map +0 -1
  554. package/dist/src/providers/gemini/adapterBridge.test.d.ts +0 -6
  555. package/dist/src/providers/gemini/adapterBridge.test.js +0 -164
  556. package/dist/src/providers/gemini/adapterBridge.test.js.map +0 -1
  557. package/dist/src/providers/gemini/bootstrap.test.d.ts +0 -6
  558. package/dist/src/providers/gemini/bootstrap.test.js +0 -72
  559. package/dist/src/providers/gemini/bootstrap.test.js.map +0 -1
  560. package/dist/src/providers/gemini/configConverter.test.d.ts +0 -6
  561. package/dist/src/providers/gemini/configConverter.test.js +0 -218
  562. package/dist/src/providers/gemini/configConverter.test.js.map +0 -1
  563. package/dist/src/providers/gemini/errorClassifier.test.d.ts +0 -6
  564. package/dist/src/providers/gemini/errorClassifier.test.js +0 -83
  565. package/dist/src/providers/gemini/errorClassifier.test.js.map +0 -1
  566. package/dist/src/providers/gemini/eventMapper.test.d.ts +0 -6
  567. package/dist/src/providers/gemini/eventMapper.test.js +0 -502
  568. package/dist/src/providers/gemini/eventMapper.test.js.map +0 -1
  569. package/dist/src/providers/gemini/exports.test.d.ts +0 -6
  570. package/dist/src/providers/gemini/exports.test.js +0 -90
  571. package/dist/src/providers/gemini/exports.test.js.map +0 -1
  572. package/dist/src/providers/gemini/featureFlag.test.d.ts +0 -6
  573. package/dist/src/providers/gemini/featureFlag.test.js +0 -139
  574. package/dist/src/providers/gemini/featureFlag.test.js.map +0 -1
  575. package/dist/src/providers/gemini/geminiAdapter.test.d.ts +0 -6
  576. package/dist/src/providers/gemini/geminiAdapter.test.js +0 -279
  577. package/dist/src/providers/gemini/geminiAdapter.test.js.map +0 -1
  578. package/dist/src/providers/gemini/geminiConverter.test.d.ts +0 -6
  579. package/dist/src/providers/gemini/geminiConverter.test.js +0 -474
  580. package/dist/src/providers/gemini/geminiConverter.test.js.map +0 -1
  581. package/dist/src/providers/gemini/geminiParity.test.d.ts +0 -6
  582. package/dist/src/providers/gemini/geminiParity.test.js +0 -754
  583. package/dist/src/providers/gemini/geminiParity.test.js.map +0 -1
  584. package/dist/src/providers/gemini/geminiStream.test.d.ts +0 -6
  585. package/dist/src/providers/gemini/geminiStream.test.js +0 -391
  586. package/dist/src/providers/gemini/geminiStream.test.js.map +0 -1
  587. package/dist/src/providers/gemini/historyBuilder.test.d.ts +0 -6
  588. package/dist/src/providers/gemini/historyBuilder.test.js +0 -207
  589. package/dist/src/providers/gemini/historyBuilder.test.js.map +0 -1
  590. package/dist/src/providers/gemini/requestBuilder.test.d.ts +0 -6
  591. package/dist/src/providers/gemini/requestBuilder.test.js +0 -358
  592. package/dist/src/providers/gemini/requestBuilder.test.js.map +0 -1
  593. package/dist/src/providers/gemini/streamConverter.test.d.ts +0 -6
  594. package/dist/src/providers/gemini/streamConverter.test.js +0 -131
  595. package/dist/src/providers/gemini/streamConverter.test.js.map +0 -1
  596. package/dist/src/providers/modelSpec.test.d.ts +0 -1
  597. package/dist/src/providers/modelSpec.test.js +0 -119
  598. package/dist/src/providers/modelSpec.test.js.map +0 -1
  599. package/dist/src/providers/openai/adapter.test.d.ts +0 -6
  600. package/dist/src/providers/openai/adapter.test.js +0 -274
  601. package/dist/src/providers/openai/adapter.test.js.map +0 -1
  602. package/dist/src/providers/openai/bootstrap.test.d.ts +0 -6
  603. package/dist/src/providers/openai/bootstrap.test.js +0 -76
  604. package/dist/src/providers/openai/bootstrap.test.js.map +0 -1
  605. package/dist/src/providers/openai/converter.test.d.ts +0 -6
  606. package/dist/src/providers/openai/converter.test.js +0 -1133
  607. package/dist/src/providers/openai/converter.test.js.map +0 -1
  608. package/dist/src/providers/openai-compatible/__tests__/compatibility.test.d.ts +0 -6
  609. package/dist/src/providers/openai-compatible/__tests__/compatibility.test.js +0 -356
  610. package/dist/src/providers/openai-compatible/__tests__/compatibility.test.js.map +0 -1
  611. package/dist/src/providers/openai-compatible/adapter.test.d.ts +0 -6
  612. package/dist/src/providers/openai-compatible/adapter.test.js +0 -240
  613. package/dist/src/providers/openai-compatible/adapter.test.js.map +0 -1
  614. package/dist/src/providers/openai-compatible/bootstrap.test.d.ts +0 -6
  615. package/dist/src/providers/openai-compatible/bootstrap.test.js +0 -145
  616. package/dist/src/providers/openai-compatible/bootstrap.test.js.map +0 -1
  617. package/dist/src/providers/openai-compatible/promptBuilder.test.d.ts +0 -6
  618. package/dist/src/providers/openai-compatible/promptBuilder.test.js +0 -154
  619. package/dist/src/providers/openai-compatible/promptBuilder.test.js.map +0 -1
  620. package/dist/src/providers/providerConfig.test.d.ts +0 -1
  621. package/dist/src/providers/providerConfig.test.js +0 -145
  622. package/dist/src/providers/providerConfig.test.js.map +0 -1
  623. package/dist/src/providers/providerConfigIntegration.test.d.ts +0 -6
  624. package/dist/src/providers/providerConfigIntegration.test.js +0 -187
  625. package/dist/src/providers/providerConfigIntegration.test.js.map +0 -1
  626. package/dist/src/providers/providerSelector.test.d.ts +0 -1
  627. package/dist/src/providers/providerSelector.test.js +0 -199
  628. package/dist/src/providers/providerSelector.test.js.map +0 -1
  629. package/dist/src/providers/providerTypes.test.d.ts +0 -1
  630. package/dist/src/providers/providerTypes.test.js +0 -95
  631. package/dist/src/providers/providerTypes.test.js.map +0 -1
  632. package/dist/src/providers/registry.test.d.ts +0 -1
  633. package/dist/src/providers/registry.test.js +0 -207
  634. package/dist/src/providers/registry.test.js.map +0 -1
  635. package/dist/src/providers/streamAssembler.test.d.ts +0 -1
  636. package/dist/src/providers/streamAssembler.test.js +0 -247
  637. package/dist/src/providers/streamAssembler.test.js.map +0 -1
  638. package/dist/src/providers/telemetryBridge.test.d.ts +0 -6
  639. package/dist/src/providers/telemetryBridge.test.js +0 -235
  640. package/dist/src/providers/telemetryBridge.test.js.map +0 -1
  641. package/dist/src/providers/types.test.d.ts +0 -6
  642. package/dist/src/providers/types.test.js +0 -253
  643. package/dist/src/providers/types.test.js.map +0 -1
  644. package/dist/src/resources/resource-registry.test.d.ts +0 -6
  645. package/dist/src/resources/resource-registry.test.js +0 -54
  646. package/dist/src/resources/resource-registry.test.js.map +0 -1
  647. package/dist/src/routing/modelRouterService.test.d.ts +0 -6
  648. package/dist/src/routing/modelRouterService.test.js +0 -106
  649. package/dist/src/routing/modelRouterService.test.js.map +0 -1
  650. package/dist/src/routing/strategies/classifierStrategy.test.d.ts +0 -6
  651. package/dist/src/routing/strategies/classifierStrategy.test.js +0 -249
  652. package/dist/src/routing/strategies/classifierStrategy.test.js.map +0 -1
  653. package/dist/src/routing/strategies/compositeStrategy.test.d.ts +0 -6
  654. package/dist/src/routing/strategies/compositeStrategy.test.js +0 -124
  655. package/dist/src/routing/strategies/compositeStrategy.test.js.map +0 -1
  656. package/dist/src/routing/strategies/defaultStrategy.test.d.ts +0 -6
  657. package/dist/src/routing/strategies/defaultStrategy.test.js +0 -102
  658. package/dist/src/routing/strategies/defaultStrategy.test.js.map +0 -1
  659. package/dist/src/routing/strategies/fallbackStrategy.test.d.ts +0 -6
  660. package/dist/src/routing/strategies/fallbackStrategy.test.js +0 -96
  661. package/dist/src/routing/strategies/fallbackStrategy.test.js.map +0 -1
  662. package/dist/src/routing/strategies/numericalClassifierStrategy.test.d.ts +0 -6
  663. package/dist/src/routing/strategies/numericalClassifierStrategy.test.js +0 -367
  664. package/dist/src/routing/strategies/numericalClassifierStrategy.test.js.map +0 -1
  665. package/dist/src/routing/strategies/overrideStrategy.test.d.ts +0 -6
  666. package/dist/src/routing/strategies/overrideStrategy.test.js +0 -59
  667. package/dist/src/routing/strategies/overrideStrategy.test.js.map +0 -1
  668. package/dist/src/safety/built-in.test.d.ts +0 -6
  669. package/dist/src/safety/built-in.test.js +0 -199
  670. package/dist/src/safety/built-in.test.js.map +0 -1
  671. package/dist/src/safety/checker-runner.test.d.ts +0 -6
  672. package/dist/src/safety/checker-runner.test.js +0 -238
  673. package/dist/src/safety/checker-runner.test.js.map +0 -1
  674. package/dist/src/safety/context-builder.test.d.ts +0 -6
  675. package/dist/src/safety/context-builder.test.js +0 -49
  676. package/dist/src/safety/context-builder.test.js.map +0 -1
  677. package/dist/src/safety/registry.test.d.ts +0 -6
  678. package/dist/src/safety/registry.test.js +0 -31
  679. package/dist/src/safety/registry.test.js.map +0 -1
  680. package/dist/src/scheduler/confirmation.test.d.ts +0 -6
  681. package/dist/src/scheduler/confirmation.test.js +0 -325
  682. package/dist/src/scheduler/confirmation.test.js.map +0 -1
  683. package/dist/src/scheduler/policy.test.d.ts +0 -6
  684. package/dist/src/scheduler/policy.test.js +0 -299
  685. package/dist/src/scheduler/policy.test.js.map +0 -1
  686. package/dist/src/scheduler/scheduler.test.d.ts +0 -6
  687. package/dist/src/scheduler/scheduler.test.js +0 -822
  688. package/dist/src/scheduler/scheduler.test.js.map +0 -1
  689. package/dist/src/scheduler/state-manager.test.d.ts +0 -6
  690. package/dist/src/scheduler/state-manager.test.js +0 -429
  691. package/dist/src/scheduler/state-manager.test.js.map +0 -1
  692. package/dist/src/scheduler/tool-executor.test.d.ts +0 -6
  693. package/dist/src/scheduler/tool-executor.test.js +0 -232
  694. package/dist/src/scheduler/tool-executor.test.js.map +0 -1
  695. package/dist/src/scheduler/tool-modifier.test.d.ts +0 -6
  696. package/dist/src/scheduler/tool-modifier.test.js +0 -159
  697. package/dist/src/scheduler/tool-modifier.test.js.map +0 -1
  698. package/dist/src/services/chatCompressionService.test.d.ts +0 -6
  699. package/dist/src/services/chatCompressionService.test.js +0 -573
  700. package/dist/src/services/chatCompressionService.test.js.map +0 -1
  701. package/dist/src/services/chatRecordingService.test.d.ts +0 -6
  702. package/dist/src/services/chatRecordingService.test.js +0 -486
  703. package/dist/src/services/chatRecordingService.test.js.map +0 -1
  704. package/dist/src/services/contextManager.test.d.ts +0 -6
  705. package/dist/src/services/contextManager.test.js +0 -104
  706. package/dist/src/services/contextManager.test.js.map +0 -1
  707. package/dist/src/services/environmentSanitization.test.d.ts +0 -6
  708. package/dist/src/services/environmentSanitization.test.js +0 -284
  709. package/dist/src/services/environmentSanitization.test.js.map +0 -1
  710. package/dist/src/services/fileDiscoveryService.test.d.ts +0 -6
  711. package/dist/src/services/fileDiscoveryService.test.js +0 -223
  712. package/dist/src/services/fileDiscoveryService.test.js.map +0 -1
  713. package/dist/src/services/fileSystemService.test.d.ts +0 -6
  714. package/dist/src/services/fileSystemService.test.js +0 -41
  715. package/dist/src/services/fileSystemService.test.js.map +0 -1
  716. package/dist/src/services/gitService.test.d.ts +0 -6
  717. package/dist/src/services/gitService.test.js +0 -264
  718. package/dist/src/services/gitService.test.js.map +0 -1
  719. package/dist/src/services/loopDetectionService.test.d.ts +0 -6
  720. package/dist/src/services/loopDetectionService.test.js +0 -881
  721. package/dist/src/services/loopDetectionService.test.js.map +0 -1
  722. package/dist/src/services/modelConfig.golden.test.d.ts +0 -6
  723. package/dist/src/services/modelConfig.golden.test.js +0 -74
  724. package/dist/src/services/modelConfig.golden.test.js.map +0 -1
  725. package/dist/src/services/modelConfig.integration.test.d.ts +0 -6
  726. package/dist/src/services/modelConfig.integration.test.js +0 -247
  727. package/dist/src/services/modelConfig.integration.test.js.map +0 -1
  728. package/dist/src/services/modelConfigBridge.test.d.ts +0 -6
  729. package/dist/src/services/modelConfigBridge.test.js +0 -410
  730. package/dist/src/services/modelConfigBridge.test.js.map +0 -1
  731. package/dist/src/services/modelConfigService.test.d.ts +0 -6
  732. package/dist/src/services/modelConfigService.test.js +0 -868
  733. package/dist/src/services/modelConfigService.test.js.map +0 -1
  734. package/dist/src/services/sessionSummaryService.test.d.ts +0 -6
  735. package/dist/src/services/sessionSummaryService.test.js +0 -785
  736. package/dist/src/services/sessionSummaryService.test.js.map +0 -1
  737. package/dist/src/services/sessionSummaryUtils.test.d.ts +0 -6
  738. package/dist/src/services/sessionSummaryUtils.test.js +0 -160
  739. package/dist/src/services/sessionSummaryUtils.test.js.map +0 -1
  740. package/dist/src/services/shellExecutionService.test.d.ts +0 -6
  741. package/dist/src/services/shellExecutionService.test.js +0 -1080
  742. package/dist/src/services/shellExecutionService.test.js.map +0 -1
  743. package/dist/src/skills/skillLoader.test.d.ts +0 -6
  744. package/dist/src/skills/skillLoader.test.js +0 -185
  745. package/dist/src/skills/skillLoader.test.js.map +0 -1
  746. package/dist/src/skills/skillManager.test.d.ts +0 -6
  747. package/dist/src/skills/skillManager.test.js +0 -297
  748. package/dist/src/skills/skillManager.test.js.map +0 -1
  749. package/dist/src/telemetry/activity-detector.test.d.ts +0 -6
  750. package/dist/src/telemetry/activity-detector.test.js +0 -136
  751. package/dist/src/telemetry/activity-detector.test.js.map +0 -1
  752. package/dist/src/telemetry/activity-monitor.test.d.ts +0 -6
  753. package/dist/src/telemetry/activity-monitor.test.js +0 -251
  754. package/dist/src/telemetry/activity-monitor.test.js.map +0 -1
  755. package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.d.ts +0 -19
  756. package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.js +0 -964
  757. package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.js.map +0 -1
  758. package/dist/src/telemetry/config.test.d.ts +0 -6
  759. package/dist/src/telemetry/config.test.js +0 -149
  760. package/dist/src/telemetry/config.test.js.map +0 -1
  761. package/dist/src/telemetry/gcp-exporters.test.d.ts +0 -6
  762. package/dist/src/telemetry/gcp-exporters.test.js +0 -318
  763. package/dist/src/telemetry/gcp-exporters.test.js.map +0 -1
  764. package/dist/src/telemetry/high-water-mark-tracker.test.d.ts +0 -6
  765. package/dist/src/telemetry/high-water-mark-tracker.test.js +0 -152
  766. package/dist/src/telemetry/high-water-mark-tracker.test.js.map +0 -1
  767. package/dist/src/telemetry/integration.test.circular.d.ts +0 -6
  768. package/dist/src/telemetry/integration.test.circular.js +0 -54
  769. package/dist/src/telemetry/integration.test.circular.js.map +0 -1
  770. package/dist/src/telemetry/loggers.test.circular.d.ts +0 -6
  771. package/dist/src/telemetry/loggers.test.circular.js +0 -107
  772. package/dist/src/telemetry/loggers.test.circular.js.map +0 -1
  773. package/dist/src/telemetry/loggers.test.d.ts +0 -6
  774. package/dist/src/telemetry/loggers.test.js +0 -1618
  775. package/dist/src/telemetry/loggers.test.js.map +0 -1
  776. package/dist/src/telemetry/memory-monitor.test.d.ts +0 -6
  777. package/dist/src/telemetry/memory-monitor.test.js +0 -472
  778. package/dist/src/telemetry/memory-monitor.test.js.map +0 -1
  779. package/dist/src/telemetry/metrics.test.d.ts +0 -6
  780. package/dist/src/telemetry/metrics.test.js +0 -1176
  781. package/dist/src/telemetry/metrics.test.js.map +0 -1
  782. package/dist/src/telemetry/rate-limiter.test.d.ts +0 -6
  783. package/dist/src/telemetry/rate-limiter.test.js +0 -207
  784. package/dist/src/telemetry/rate-limiter.test.js.map +0 -1
  785. package/dist/src/telemetry/sanitize.test.d.ts +0 -6
  786. package/dist/src/telemetry/sanitize.test.js +0 -279
  787. package/dist/src/telemetry/sanitize.test.js.map +0 -1
  788. package/dist/src/telemetry/sdk.test.d.ts +0 -6
  789. package/dist/src/telemetry/sdk.test.js +0 -360
  790. package/dist/src/telemetry/sdk.test.js.map +0 -1
  791. package/dist/src/telemetry/semantic.test.d.ts +0 -6
  792. package/dist/src/telemetry/semantic.test.js +0 -387
  793. package/dist/src/telemetry/semantic.test.js.map +0 -1
  794. package/dist/src/telemetry/semantic.truncation.test.d.ts +0 -1
  795. package/dist/src/telemetry/semantic.truncation.test.js +0 -92
  796. package/dist/src/telemetry/semantic.truncation.test.js.map +0 -1
  797. package/dist/src/telemetry/startupProfiler.test.d.ts +0 -6
  798. package/dist/src/telemetry/startupProfiler.test.js +0 -285
  799. package/dist/src/telemetry/startupProfiler.test.js.map +0 -1
  800. package/dist/src/telemetry/telemetry-utils.test.d.ts +0 -6
  801. package/dist/src/telemetry/telemetry-utils.test.js +0 -41
  802. package/dist/src/telemetry/telemetry-utils.test.js.map +0 -1
  803. package/dist/src/telemetry/telemetry.test.d.ts +0 -6
  804. package/dist/src/telemetry/telemetry.test.js +0 -57
  805. package/dist/src/telemetry/telemetry.test.js.map +0 -1
  806. package/dist/src/telemetry/uiTelemetry.test.d.ts +0 -6
  807. package/dist/src/telemetry/uiTelemetry.test.js +0 -584
  808. package/dist/src/telemetry/uiTelemetry.test.js.map +0 -1
  809. package/dist/src/tools/activate-skill.test.d.ts +0 -6
  810. package/dist/src/tools/activate-skill.test.js +0 -113
  811. package/dist/src/tools/activate-skill.test.js.map +0 -1
  812. package/dist/src/tools/ask-user.test.d.ts +0 -6
  813. package/dist/src/tools/ask-user.test.js +0 -187
  814. package/dist/src/tools/ask-user.test.js.map +0 -1
  815. package/dist/src/tools/base-tool-invocation.test.d.ts +0 -6
  816. package/dist/src/tools/base-tool-invocation.test.js +0 -85
  817. package/dist/src/tools/base-tool-invocation.test.js.map +0 -1
  818. package/dist/src/tools/confirmation-policy.test.d.ts +0 -6
  819. package/dist/src/tools/confirmation-policy.test.js +0 -143
  820. package/dist/src/tools/confirmation-policy.test.js.map +0 -1
  821. package/dist/src/tools/diffOptions.test.d.ts +0 -6
  822. package/dist/src/tools/diffOptions.test.js +0 -172
  823. package/dist/src/tools/diffOptions.test.js.map +0 -1
  824. package/dist/src/tools/edit.test.d.ts +0 -6
  825. package/dist/src/tools/edit.test.js +0 -729
  826. package/dist/src/tools/edit.test.js.map +0 -1
  827. package/dist/src/tools/get-internal-docs.test.d.ts +0 -6
  828. package/dist/src/tools/get-internal-docs.test.js +0 -57
  829. package/dist/src/tools/get-internal-docs.test.js.map +0 -1
  830. package/dist/src/tools/glob.test.d.ts +0 -6
  831. package/dist/src/tools/glob.test.js +0 -433
  832. package/dist/src/tools/glob.test.js.map +0 -1
  833. package/dist/src/tools/grep.test.d.ts +0 -6
  834. package/dist/src/tools/grep.test.js +0 -328
  835. package/dist/src/tools/grep.test.js.map +0 -1
  836. package/dist/src/tools/ls.test.d.ts +0 -6
  837. package/dist/src/tools/ls.test.js +0 -242
  838. package/dist/src/tools/ls.test.js.map +0 -1
  839. package/dist/src/tools/mcp-client-manager.test.d.ts +0 -6
  840. package/dist/src/tools/mcp-client-manager.test.js +0 -251
  841. package/dist/src/tools/mcp-client-manager.test.js.map +0 -1
  842. package/dist/src/tools/mcp-client.test.d.ts +0 -6
  843. package/dist/src/tools/mcp-client.test.js +0 -1346
  844. package/dist/src/tools/mcp-client.test.js.map +0 -1
  845. package/dist/src/tools/mcp-tool.test.d.ts +0 -6
  846. package/dist/src/tools/mcp-tool.test.js +0 -657
  847. package/dist/src/tools/mcp-tool.test.js.map +0 -1
  848. package/dist/src/tools/memoryTool.test.d.ts +0 -6
  849. package/dist/src/tools/memoryTool.test.js +0 -302
  850. package/dist/src/tools/memoryTool.test.js.map +0 -1
  851. package/dist/src/tools/message-bus-integration.test.d.ts +0 -6
  852. package/dist/src/tools/message-bus-integration.test.js +0 -169
  853. package/dist/src/tools/message-bus-integration.test.js.map +0 -1
  854. package/dist/src/tools/modifiable-tool.test.d.ts +0 -6
  855. package/dist/src/tools/modifiable-tool.test.js +0 -237
  856. package/dist/src/tools/modifiable-tool.test.js.map +0 -1
  857. package/dist/src/tools/read-file.test.d.ts +0 -6
  858. package/dist/src/tools/read-file.test.js +0 -376
  859. package/dist/src/tools/read-file.test.js.map +0 -1
  860. package/dist/src/tools/read-many-files.test.d.ts +0 -6
  861. package/dist/src/tools/read-many-files.test.js +0 -567
  862. package/dist/src/tools/read-many-files.test.js.map +0 -1
  863. package/dist/src/tools/ripGrep.test.d.ts +0 -6
  864. package/dist/src/tools/ripGrep.test.js +0 -1139
  865. package/dist/src/tools/ripGrep.test.js.map +0 -1
  866. package/dist/src/tools/shell.test.d.ts +0 -6
  867. package/dist/src/tools/shell.test.js +0 -526
  868. package/dist/src/tools/shell.test.js.map +0 -1
  869. package/dist/src/tools/tool-names.test.d.ts +0 -6
  870. package/dist/src/tools/tool-names.test.js +0 -43
  871. package/dist/src/tools/tool-names.test.js.map +0 -1
  872. package/dist/src/tools/tool-registry.test.d.ts +0 -6
  873. package/dist/src/tools/tool-registry.test.js +0 -461
  874. package/dist/src/tools/tool-registry.test.js.map +0 -1
  875. package/dist/src/tools/tools.test.d.ts +0 -6
  876. package/dist/src/tools/tools.test.js +0 -207
  877. package/dist/src/tools/tools.test.js.map +0 -1
  878. package/dist/src/tools/web-fetch.test.d.ts +0 -6
  879. package/dist/src/tools/web-fetch.test.js +0 -442
  880. package/dist/src/tools/web-fetch.test.js.map +0 -1
  881. package/dist/src/tools/web-search.test.d.ts +0 -6
  882. package/dist/src/tools/web-search.test.js +0 -214
  883. package/dist/src/tools/web-search.test.js.map +0 -1
  884. package/dist/src/tools/write-file.test.d.ts +0 -6
  885. package/dist/src/tools/write-file.test.js +0 -681
  886. package/dist/src/tools/write-file.test.js.map +0 -1
  887. package/dist/src/tools/write-todos.test.d.ts +0 -6
  888. package/dist/src/tools/write-todos.test.js +0 -90
  889. package/dist/src/tools/write-todos.test.js.map +0 -1
  890. package/dist/src/utils/apiConversionUtils.test.d.ts +0 -6
  891. package/dist/src/utils/apiConversionUtils.test.js +0 -150
  892. package/dist/src/utils/apiConversionUtils.test.js.map +0 -1
  893. package/dist/src/utils/bfsFileSearch.test.d.ts +0 -6
  894. package/dist/src/utils/bfsFileSearch.test.js +0 -227
  895. package/dist/src/utils/bfsFileSearch.test.js.map +0 -1
  896. package/dist/src/utils/channel.test.d.ts +0 -6
  897. package/dist/src/utils/channel.test.js +0 -170
  898. package/dist/src/utils/channel.test.js.map +0 -1
  899. package/dist/src/utils/checkpointUtils.test.d.ts +0 -6
  900. package/dist/src/utils/checkpointUtils.test.js +0 -229
  901. package/dist/src/utils/checkpointUtils.test.js.map +0 -1
  902. package/dist/src/utils/customHeaderUtils.test.d.ts +0 -6
  903. package/dist/src/utils/customHeaderUtils.test.js +0 -77
  904. package/dist/src/utils/customHeaderUtils.test.js.map +0 -1
  905. package/dist/src/utils/debugLogger.test.d.ts +0 -6
  906. package/dist/src/utils/debugLogger.test.js +0 -69
  907. package/dist/src/utils/debugLogger.test.js.map +0 -1
  908. package/dist/src/utils/delay.test.d.ts +0 -6
  909. package/dist/src/utils/delay.test.js +0 -88
  910. package/dist/src/utils/delay.test.js.map +0 -1
  911. package/dist/src/utils/editCorrector.test.d.ts +0 -6
  912. package/dist/src/utils/editCorrector.test.js +0 -533
  913. package/dist/src/utils/editCorrector.test.js.map +0 -1
  914. package/dist/src/utils/editor.test.d.ts +0 -6
  915. package/dist/src/utils/editor.test.js +0 -429
  916. package/dist/src/utils/editor.test.js.map +0 -1
  917. package/dist/src/utils/environmentContext.test.d.ts +0 -6
  918. package/dist/src/utils/environmentContext.test.js +0 -114
  919. package/dist/src/utils/environmentContext.test.js.map +0 -1
  920. package/dist/src/utils/errorParsing.test.d.ts +0 -6
  921. package/dist/src/utils/errorParsing.test.js +0 -84
  922. package/dist/src/utils/errorParsing.test.js.map +0 -1
  923. package/dist/src/utils/errorReporting.test.d.ts +0 -6
  924. package/dist/src/utils/errorReporting.test.js +0 -133
  925. package/dist/src/utils/errorReporting.test.js.map +0 -1
  926. package/dist/src/utils/errors.test.d.ts +0 -6
  927. package/dist/src/utils/errors.test.js +0 -155
  928. package/dist/src/utils/errors.test.js.map +0 -1
  929. package/dist/src/utils/events.test.d.ts +0 -6
  930. package/dist/src/utils/events.test.js +0 -237
  931. package/dist/src/utils/events.test.js.map +0 -1
  932. package/dist/src/utils/extensionLoader.test.d.ts +0 -6
  933. package/dist/src/utils/extensionLoader.test.js +0 -176
  934. package/dist/src/utils/extensionLoader.test.js.map +0 -1
  935. package/dist/src/utils/fileDiffUtils.test.d.ts +0 -6
  936. package/dist/src/utils/fileDiffUtils.test.js +0 -84
  937. package/dist/src/utils/fileDiffUtils.test.js.map +0 -1
  938. package/dist/src/utils/fileUtils.test.d.ts +0 -6
  939. package/dist/src/utils/fileUtils.test.js +0 -780
  940. package/dist/src/utils/fileUtils.test.js.map +0 -1
  941. package/dist/src/utils/filesearch/crawlCache.test.d.ts +0 -6
  942. package/dist/src/utils/filesearch/crawlCache.test.js +0 -103
  943. package/dist/src/utils/filesearch/crawlCache.test.js.map +0 -1
  944. package/dist/src/utils/filesearch/crawler.test.d.ts +0 -6
  945. package/dist/src/utils/filesearch/crawler.test.js +0 -495
  946. package/dist/src/utils/filesearch/crawler.test.js.map +0 -1
  947. package/dist/src/utils/filesearch/fileSearch.test.d.ts +0 -6
  948. package/dist/src/utils/filesearch/fileSearch.test.js +0 -663
  949. package/dist/src/utils/filesearch/fileSearch.test.js.map +0 -1
  950. package/dist/src/utils/filesearch/ignore.test.d.ts +0 -6
  951. package/dist/src/utils/filesearch/ignore.test.js +0 -144
  952. package/dist/src/utils/filesearch/ignore.test.js.map +0 -1
  953. package/dist/src/utils/filesearch/result-cache.test.d.ts +0 -6
  954. package/dist/src/utils/filesearch/result-cache.test.js +0 -46
  955. package/dist/src/utils/filesearch/result-cache.test.js.map +0 -1
  956. package/dist/src/utils/flashFallback.test.d.ts +0 -6
  957. package/dist/src/utils/flashFallback.test.js +0 -103
  958. package/dist/src/utils/flashFallback.test.js.map +0 -1
  959. package/dist/src/utils/formatters.test.d.ts +0 -6
  960. package/dist/src/utils/formatters.test.js +0 -26
  961. package/dist/src/utils/formatters.test.js.map +0 -1
  962. package/dist/src/utils/geminiIgnoreParser.test.d.ts +0 -6
  963. package/dist/src/utils/geminiIgnoreParser.test.js +0 -98
  964. package/dist/src/utils/geminiIgnoreParser.test.js.map +0 -1
  965. package/dist/src/utils/geminiTypeConversion.test.d.ts +0 -6
  966. package/dist/src/utils/geminiTypeConversion.test.js +0 -310
  967. package/dist/src/utils/geminiTypeConversion.test.js.map +0 -1
  968. package/dist/src/utils/generateContentResponseUtilities.test.d.ts +0 -6
  969. package/dist/src/utils/generateContentResponseUtilities.test.js +0 -512
  970. package/dist/src/utils/generateContentResponseUtilities.test.js.map +0 -1
  971. package/dist/src/utils/getFolderStructure.test.d.ts +0 -6
  972. package/dist/src/utils/getFolderStructure.test.js +0 -283
  973. package/dist/src/utils/getFolderStructure.test.js.map +0 -1
  974. package/dist/src/utils/gitIgnoreParser.test.d.ts +0 -6
  975. package/dist/src/utils/gitIgnoreParser.test.js +0 -243
  976. package/dist/src/utils/gitIgnoreParser.test.js.map +0 -1
  977. package/dist/src/utils/googleErrors.test.d.ts +0 -6
  978. package/dist/src/utils/googleErrors.test.js +0 -309
  979. package/dist/src/utils/googleErrors.test.js.map +0 -1
  980. package/dist/src/utils/googleQuotaErrors.test.d.ts +0 -6
  981. package/dist/src/utils/googleQuotaErrors.test.js +0 -548
  982. package/dist/src/utils/googleQuotaErrors.test.js.map +0 -1
  983. package/dist/src/utils/ignorePatterns.test.d.ts +0 -6
  984. package/dist/src/utils/ignorePatterns.test.js +0 -246
  985. package/dist/src/utils/ignorePatterns.test.js.map +0 -1
  986. package/dist/src/utils/installationManager.test.d.ts +0 -6
  987. package/dist/src/utils/installationManager.test.js +0 -93
  988. package/dist/src/utils/installationManager.test.js.map +0 -1
  989. package/dist/src/utils/llm-edit-fixer.test.d.ts +0 -6
  990. package/dist/src/utils/llm-edit-fixer.test.js +0 -223
  991. package/dist/src/utils/llm-edit-fixer.test.js.map +0 -1
  992. package/dist/src/utils/llmUtils.test.d.ts +0 -6
  993. package/dist/src/utils/llmUtils.test.js +0 -196
  994. package/dist/src/utils/llmUtils.test.js.map +0 -1
  995. package/dist/src/utils/memoryDiscovery.test.d.ts +0 -6
  996. package/dist/src/utils/memoryDiscovery.test.js +0 -542
  997. package/dist/src/utils/memoryDiscovery.test.js.map +0 -1
  998. package/dist/src/utils/memoryImportProcessor.test.d.ts +0 -6
  999. package/dist/src/utils/memoryImportProcessor.test.js +0 -581
  1000. package/dist/src/utils/memoryImportProcessor.test.js.map +0 -1
  1001. package/dist/src/utils/nextSpeakerChecker.test.d.ts +0 -6
  1002. package/dist/src/utils/nextSpeakerChecker.test.js +0 -191
  1003. package/dist/src/utils/nextSpeakerChecker.test.js.map +0 -1
  1004. package/dist/src/utils/partUtils.test.d.ts +0 -6
  1005. package/dist/src/utils/partUtils.test.js +0 -397
  1006. package/dist/src/utils/partUtils.test.js.map +0 -1
  1007. package/dist/src/utils/pathCorrector.test.d.ts +0 -6
  1008. package/dist/src/utils/pathCorrector.test.js +0 -87
  1009. package/dist/src/utils/pathCorrector.test.js.map +0 -1
  1010. package/dist/src/utils/pathReader.test.d.ts +0 -6
  1011. package/dist/src/utils/pathReader.test.js +0 -406
  1012. package/dist/src/utils/pathReader.test.js.map +0 -1
  1013. package/dist/src/utils/paths.test.d.ts +0 -6
  1014. package/dist/src/utils/paths.test.js +0 -402
  1015. package/dist/src/utils/paths.test.js.map +0 -1
  1016. package/dist/src/utils/retry.test.d.ts +0 -6
  1017. package/dist/src/utils/retry.test.js +0 -548
  1018. package/dist/src/utils/retry.test.js.map +0 -1
  1019. package/dist/src/utils/retry_llm_error.test.d.ts +0 -6
  1020. package/dist/src/utils/retry_llm_error.test.js +0 -280
  1021. package/dist/src/utils/retry_llm_error.test.js.map +0 -1
  1022. package/dist/src/utils/safeJsonStringify.test.d.ts +0 -6
  1023. package/dist/src/utils/safeJsonStringify.test.js +0 -61
  1024. package/dist/src/utils/safeJsonStringify.test.js.map +0 -1
  1025. package/dist/src/utils/schemaValidator.test.d.ts +0 -6
  1026. package/dist/src/utils/schemaValidator.test.js +0 -113
  1027. package/dist/src/utils/schemaValidator.test.js.map +0 -1
  1028. package/dist/src/utils/secure-browser-launcher.test.d.ts +0 -6
  1029. package/dist/src/utils/secure-browser-launcher.test.js +0 -149
  1030. package/dist/src/utils/secure-browser-launcher.test.js.map +0 -1
  1031. package/dist/src/utils/security.test.d.ts +0 -1
  1032. package/dist/src/utils/security.test.js +0 -121
  1033. package/dist/src/utils/security.test.js.map +0 -1
  1034. package/dist/src/utils/shell-utils.integration.test.d.ts +0 -1
  1035. package/dist/src/utils/shell-utils.integration.test.js +0 -58
  1036. package/dist/src/utils/shell-utils.integration.test.js.map +0 -1
  1037. package/dist/src/utils/shell-utils.test.d.ts +0 -6
  1038. package/dist/src/utils/shell-utils.test.js +0 -437
  1039. package/dist/src/utils/shell-utils.test.js.map +0 -1
  1040. package/dist/src/utils/stdio.test.d.ts +0 -6
  1041. package/dist/src/utils/stdio.test.js +0 -47
  1042. package/dist/src/utils/stdio.test.js.map +0 -1
  1043. package/dist/src/utils/summarizer.test.d.ts +0 -6
  1044. package/dist/src/utils/summarizer.test.js +0 -152
  1045. package/dist/src/utils/summarizer.test.js.map +0 -1
  1046. package/dist/src/utils/systemEncoding.test.d.ts +0 -6
  1047. package/dist/src/utils/systemEncoding.test.js +0 -369
  1048. package/dist/src/utils/systemEncoding.test.js.map +0 -1
  1049. package/dist/src/utils/terminalSerializer.test.d.ts +0 -6
  1050. package/dist/src/utils/terminalSerializer.test.js +0 -193
  1051. package/dist/src/utils/terminalSerializer.test.js.map +0 -1
  1052. package/dist/src/utils/textUtils.test.d.ts +0 -6
  1053. package/dist/src/utils/textUtils.test.js +0 -76
  1054. package/dist/src/utils/textUtils.test.js.map +0 -1
  1055. package/dist/src/utils/thoughtUtils.test.d.ts +0 -6
  1056. package/dist/src/utils/thoughtUtils.test.js +0 -78
  1057. package/dist/src/utils/thoughtUtils.test.js.map +0 -1
  1058. package/dist/src/utils/tokenCalculation.test.d.ts +0 -6
  1059. package/dist/src/utils/tokenCalculation.test.js +0 -184
  1060. package/dist/src/utils/tokenCalculation.test.js.map +0 -1
  1061. package/dist/src/utils/tool-utils.test.d.ts +0 -6
  1062. package/dist/src/utils/tool-utils.test.js +0 -84
  1063. package/dist/src/utils/tool-utils.test.js.map +0 -1
  1064. package/dist/src/utils/toolCallContext.test.d.ts +0 -6
  1065. package/dist/src/utils/toolCallContext.test.js +0 -68
  1066. package/dist/src/utils/toolCallContext.test.js.map +0 -1
  1067. package/dist/src/utils/userAccountManager.test.d.ts +0 -6
  1068. package/dist/src/utils/userAccountManager.test.js +0 -225
  1069. package/dist/src/utils/userAccountManager.test.js.map +0 -1
  1070. package/dist/src/utils/version.test.d.ts +0 -6
  1071. package/dist/src/utils/version.test.js +0 -39
  1072. package/dist/src/utils/version.test.js.map +0 -1
  1073. package/dist/src/utils/workspaceContext.test.d.ts +0 -6
  1074. package/dist/src/utils/workspaceContext.test.js +0 -374
  1075. package/dist/src/utils/workspaceContext.test.js.map +0 -1
  1076. package/dist/tsconfig.tsbuildinfo +0 -1
@@ -1,1299 +0,0 @@
1
- /**
2
- * @license
3
- * Copyright 2025 Google LLC
4
- * SPDX-License-Identifier: Apache-2.0
5
- */
6
- import { describe, it, expect, beforeEach, beforeAll, vi } from 'vitest';
7
- import { PolicyEngine } from './policy-engine.js';
8
- import { PolicyDecision, InProcessCheckerType, ApprovalMode, } from './types.js';
9
- import { SafetyCheckDecision } from '../safety/protocol.js';
10
- import { initializeShellParsers } from '../utils/shell-utils.js';
11
- import { buildArgsPatterns } from './utils.js';
12
- // Mock shell-utils to ensure consistent behavior across platforms (especially Windows CI)
13
- // We want to test PolicyEngine logic, not the shell parser's ability to parse commands
14
- vi.mock('../utils/shell-utils.js', async (importOriginal) => {
15
- const actual = await importOriginal();
16
- return {
17
- ...actual,
18
- initializeShellParsers: vi.fn().mockResolvedValue(undefined),
19
- splitCommands: vi.fn().mockImplementation((command) => {
20
- // Simple mock splitting logic for test cases
21
- if (command.includes('&&')) {
22
- return command.split('&&').map((c) => c.trim());
23
- }
24
- return [command];
25
- }),
26
- hasRedirection: vi.fn().mockImplementation((command) =>
27
- // Simple mock: true if '>' is present, unless it looks like "-> arrow"
28
- command.includes('>') && !command.includes('-> arrow')),
29
- };
30
- });
31
- describe('PolicyEngine', () => {
32
- let engine;
33
- let mockCheckerRunner;
34
- beforeAll(async () => {
35
- await initializeShellParsers();
36
- });
37
- beforeEach(() => {
38
- mockCheckerRunner = {
39
- runChecker: vi.fn(),
40
- };
41
- engine = new PolicyEngine({ approvalMode: ApprovalMode.DEFAULT }, mockCheckerRunner);
42
- });
43
- describe('constructor', () => {
44
- it('should use default config when none provided', async () => {
45
- const { decision } = await engine.check({ name: 'test' }, undefined);
46
- expect(decision).toBe(PolicyDecision.ASK_USER);
47
- });
48
- it('should respect custom default decision', async () => {
49
- engine = new PolicyEngine({ defaultDecision: PolicyDecision.DENY });
50
- const { decision } = await engine.check({ name: 'test' }, undefined);
51
- expect(decision).toBe(PolicyDecision.DENY);
52
- });
53
- it('should sort rules by priority', () => {
54
- const rules = [
55
- { toolName: 'tool1', decision: PolicyDecision.DENY, priority: 1 },
56
- { toolName: 'tool2', decision: PolicyDecision.ALLOW, priority: 10 },
57
- { toolName: 'tool3', decision: PolicyDecision.ASK_USER, priority: 5 },
58
- ];
59
- engine = new PolicyEngine({ rules });
60
- const sortedRules = engine.getRules();
61
- expect(sortedRules[0].priority).toBe(10);
62
- expect(sortedRules[1].priority).toBe(5);
63
- expect(sortedRules[2].priority).toBe(1);
64
- });
65
- });
66
- describe('check', () => {
67
- it('should match tool by name', async () => {
68
- const rules = [
69
- { toolName: 'shell', decision: PolicyDecision.ALLOW },
70
- { toolName: 'edit', decision: PolicyDecision.DENY },
71
- ];
72
- engine = new PolicyEngine({ rules });
73
- expect((await engine.check({ name: 'shell' }, undefined)).decision).toBe(PolicyDecision.ALLOW);
74
- expect((await engine.check({ name: 'edit' }, undefined)).decision).toBe(PolicyDecision.DENY);
75
- expect((await engine.check({ name: 'other' }, undefined)).decision).toBe(PolicyDecision.ASK_USER);
76
- });
77
- it('should match unqualified tool names with qualified rules when serverName is provided', async () => {
78
- const rules = [
79
- {
80
- toolName: 'my-server__tool',
81
- decision: PolicyDecision.ALLOW,
82
- },
83
- ];
84
- engine = new PolicyEngine({ rules });
85
- // Match with qualified name (standard)
86
- expect((await engine.check({ name: 'my-server__tool' }, 'my-server')).decision).toBe(PolicyDecision.ALLOW);
87
- // Match with unqualified name + serverName (the fix)
88
- expect((await engine.check({ name: 'tool' }, 'my-server')).decision).toBe(PolicyDecision.ALLOW);
89
- // Should NOT match with unqualified name but NO serverName
90
- expect((await engine.check({ name: 'tool' }, undefined)).decision).toBe(PolicyDecision.ASK_USER);
91
- // Should NOT match with unqualified name but WRONG serverName
92
- expect((await engine.check({ name: 'tool' }, 'wrong-server')).decision).toBe(PolicyDecision.ASK_USER);
93
- });
94
- it('should match by args pattern', async () => {
95
- const rules = [
96
- {
97
- toolName: 'shell',
98
- argsPattern: /rm -rf/,
99
- decision: PolicyDecision.DENY,
100
- },
101
- {
102
- toolName: 'shell',
103
- decision: PolicyDecision.ALLOW,
104
- },
105
- ];
106
- engine = new PolicyEngine({ rules });
107
- const dangerousCall = {
108
- name: 'shell',
109
- args: { command: 'rm -rf /' },
110
- };
111
- const safeCall = {
112
- name: 'shell',
113
- args: { command: 'ls -la' },
114
- };
115
- expect((await engine.check(dangerousCall, undefined)).decision).toBe(PolicyDecision.DENY);
116
- expect((await engine.check(safeCall, undefined)).decision).toBe(PolicyDecision.ALLOW);
117
- });
118
- it('should apply rules by priority', async () => {
119
- const rules = [
120
- { toolName: 'shell', decision: PolicyDecision.DENY, priority: 1 },
121
- { toolName: 'shell', decision: PolicyDecision.ALLOW, priority: 10 },
122
- ];
123
- engine = new PolicyEngine({ rules });
124
- // Higher priority rule (ALLOW) should win
125
- expect((await engine.check({ name: 'shell' }, undefined)).decision).toBe(PolicyDecision.ALLOW);
126
- });
127
- it('should apply wildcard rules (no toolName)', async () => {
128
- const rules = [
129
- { decision: PolicyDecision.DENY }, // Applies to all tools
130
- { toolName: 'safe-tool', decision: PolicyDecision.ALLOW, priority: 10 },
131
- ];
132
- engine = new PolicyEngine({ rules });
133
- expect((await engine.check({ name: 'safe-tool' }, undefined)).decision).toBe(PolicyDecision.ALLOW);
134
- expect((await engine.check({ name: 'any-other-tool' }, undefined)).decision).toBe(PolicyDecision.DENY);
135
- });
136
- it('should handle non-interactive mode', async () => {
137
- const config = {
138
- nonInteractive: true,
139
- rules: [
140
- { toolName: 'interactive-tool', decision: PolicyDecision.ASK_USER },
141
- { toolName: 'allowed-tool', decision: PolicyDecision.ALLOW },
142
- ],
143
- };
144
- engine = new PolicyEngine(config);
145
- // ASK_USER should become DENY in non-interactive mode
146
- expect((await engine.check({ name: 'interactive-tool' }, undefined)).decision).toBe(PolicyDecision.DENY);
147
- // ALLOW should remain ALLOW
148
- expect((await engine.check({ name: 'allowed-tool' }, undefined)).decision).toBe(PolicyDecision.ALLOW);
149
- // Default ASK_USER should also become DENY
150
- expect((await engine.check({ name: 'unknown-tool' }, undefined)).decision).toBe(PolicyDecision.DENY);
151
- });
152
- it('should dynamically switch between modes and respect rule modes', async () => {
153
- const rules = [
154
- {
155
- toolName: 'edit',
156
- decision: PolicyDecision.ASK_USER,
157
- priority: 10,
158
- },
159
- {
160
- toolName: 'edit',
161
- decision: PolicyDecision.ALLOW,
162
- priority: 20,
163
- modes: [ApprovalMode.AUTO_EDIT],
164
- },
165
- ];
166
- engine = new PolicyEngine({ rules });
167
- // Default mode: priority 20 rule doesn't match, falls back to priority 10
168
- expect((await engine.check({ name: 'edit' }, undefined)).decision).toBe(PolicyDecision.ASK_USER);
169
- // Switch to autoEdit mode
170
- engine.setApprovalMode(ApprovalMode.AUTO_EDIT);
171
- expect((await engine.check({ name: 'edit' }, undefined)).decision).toBe(PolicyDecision.ALLOW);
172
- // Switch back to default
173
- engine.setApprovalMode(ApprovalMode.DEFAULT);
174
- expect((await engine.check({ name: 'edit' }, undefined)).decision).toBe(PolicyDecision.ASK_USER);
175
- });
176
- });
177
- describe('addRule', () => {
178
- it('should add a new rule and maintain priority order', () => {
179
- engine.addRule({
180
- toolName: 'tool1',
181
- decision: PolicyDecision.ALLOW,
182
- priority: 5,
183
- });
184
- engine.addRule({
185
- toolName: 'tool2',
186
- decision: PolicyDecision.DENY,
187
- priority: 10,
188
- });
189
- engine.addRule({
190
- toolName: 'tool3',
191
- decision: PolicyDecision.ASK_USER,
192
- priority: 1,
193
- });
194
- const rules = engine.getRules();
195
- expect(rules).toHaveLength(3);
196
- expect(rules[0].priority).toBe(10);
197
- expect(rules[1].priority).toBe(5);
198
- expect(rules[2].priority).toBe(1);
199
- });
200
- it('should apply newly added rules', async () => {
201
- expect((await engine.check({ name: 'new-tool' }, undefined)).decision).toBe(PolicyDecision.ASK_USER);
202
- engine.addRule({ toolName: 'new-tool', decision: PolicyDecision.ALLOW });
203
- expect((await engine.check({ name: 'new-tool' }, undefined)).decision).toBe(PolicyDecision.ALLOW);
204
- });
205
- });
206
- describe('removeRulesForTool', () => {
207
- it('should remove rules for specific tool', () => {
208
- engine.addRule({ toolName: 'tool1', decision: PolicyDecision.ALLOW });
209
- engine.addRule({ toolName: 'tool2', decision: PolicyDecision.DENY });
210
- engine.addRule({
211
- toolName: 'tool1',
212
- decision: PolicyDecision.ASK_USER,
213
- priority: 10,
214
- });
215
- expect(engine.getRules()).toHaveLength(3);
216
- engine.removeRulesForTool('tool1');
217
- const remainingRules = engine.getRules();
218
- expect(remainingRules).toHaveLength(1);
219
- expect(remainingRules.some((r) => r.toolName === 'tool1')).toBe(false);
220
- expect(remainingRules.some((r) => r.toolName === 'tool2')).toBe(true);
221
- });
222
- it('should handle removing non-existent tool', () => {
223
- engine.addRule({ toolName: 'existing', decision: PolicyDecision.ALLOW });
224
- expect(() => engine.removeRulesForTool('non-existent')).not.toThrow();
225
- expect(engine.getRules()).toHaveLength(1);
226
- });
227
- });
228
- describe('getRules', () => {
229
- it('should return readonly array of rules', () => {
230
- const rules = [
231
- { toolName: 'tool1', decision: PolicyDecision.ALLOW },
232
- { toolName: 'tool2', decision: PolicyDecision.DENY },
233
- ];
234
- engine = new PolicyEngine({ rules });
235
- const retrievedRules = engine.getRules();
236
- expect(retrievedRules).toHaveLength(2);
237
- expect(retrievedRules[0].toolName).toBe('tool1');
238
- expect(retrievedRules[1].toolName).toBe('tool2');
239
- });
240
- });
241
- describe('MCP server wildcard patterns', () => {
242
- it('should match MCP server wildcard patterns', async () => {
243
- const rules = [
244
- {
245
- toolName: 'my-server__*',
246
- decision: PolicyDecision.ALLOW,
247
- priority: 10,
248
- },
249
- {
250
- toolName: 'blocked-server__*',
251
- decision: PolicyDecision.DENY,
252
- priority: 20,
253
- },
254
- ];
255
- engine = new PolicyEngine({ rules });
256
- // Should match my-server tools
257
- expect((await engine.check({ name: 'my-server__tool1' }, undefined)).decision).toBe(PolicyDecision.ALLOW);
258
- expect((await engine.check({ name: 'my-server__another_tool' }, undefined))
259
- .decision).toBe(PolicyDecision.ALLOW);
260
- // Should match blocked-server tools
261
- expect((await engine.check({ name: 'blocked-server__tool1' }, undefined))
262
- .decision).toBe(PolicyDecision.DENY);
263
- expect((await engine.check({ name: 'blocked-server__dangerous' }, undefined))
264
- .decision).toBe(PolicyDecision.DENY);
265
- // Should not match other patterns
266
- expect((await engine.check({ name: 'other-server__tool' }, undefined))
267
- .decision).toBe(PolicyDecision.ASK_USER);
268
- expect((await engine.check({ name: 'my-server-tool' }, undefined)).decision).toBe(PolicyDecision.ASK_USER); // No __ separator
269
- expect((await engine.check({ name: 'my-server' }, undefined)).decision).toBe(PolicyDecision.ASK_USER); // No tool name
270
- });
271
- it('should prioritize specific tool rules over server wildcards', async () => {
272
- const rules = [
273
- {
274
- toolName: 'my-server__*',
275
- decision: PolicyDecision.ALLOW,
276
- priority: 10,
277
- },
278
- {
279
- toolName: 'my-server__dangerous-tool',
280
- decision: PolicyDecision.DENY,
281
- priority: 20,
282
- },
283
- ];
284
- engine = new PolicyEngine({ rules });
285
- // Specific tool deny should override server allow
286
- expect((await engine.check({ name: 'my-server__dangerous-tool' }, undefined))
287
- .decision).toBe(PolicyDecision.DENY);
288
- expect((await engine.check({ name: 'my-server__safe-tool' }, undefined))
289
- .decision).toBe(PolicyDecision.ALLOW);
290
- });
291
- it('should NOT match spoofed server names when using wildcards', async () => {
292
- // Vulnerability: A rule for 'prefix__*' matches 'prefix__suffix__tool'
293
- // effectively allowing a server named 'prefix__suffix' to spoof 'prefix'.
294
- const rules = [
295
- {
296
- toolName: 'safe_server__*',
297
- decision: PolicyDecision.ALLOW,
298
- },
299
- ];
300
- engine = new PolicyEngine({ rules });
301
- // A tool from a different server 'safe_server__malicious'
302
- const spoofedToolCall = { name: 'safe_server__malicious__tool' };
303
- // CURRENT BEHAVIOR (FIXED): Matches because it starts with 'safe_server__' BUT serverName doesn't match 'safe_server'
304
- // We expect this to FAIL matching the ALLOW rule, thus falling back to default (ASK_USER)
305
- expect((await engine.check(spoofedToolCall, 'safe_server__malicious'))
306
- .decision).toBe(PolicyDecision.ASK_USER);
307
- });
308
- it('should verify tool name prefix even if serverName matches', async () => {
309
- const rules = [
310
- {
311
- toolName: 'safe_server__*',
312
- decision: PolicyDecision.ALLOW,
313
- },
314
- ];
315
- engine = new PolicyEngine({ rules });
316
- // serverName matches, but tool name does not start with prefix
317
- const invalidToolCall = { name: 'other_server__tool' };
318
- expect((await engine.check(invalidToolCall, 'safe_server')).decision).toBe(PolicyDecision.ASK_USER);
319
- });
320
- it('should allow when both serverName and tool name prefix match', async () => {
321
- const rules = [
322
- {
323
- toolName: 'safe_server__*',
324
- decision: PolicyDecision.ALLOW,
325
- },
326
- ];
327
- engine = new PolicyEngine({ rules });
328
- const validToolCall = { name: 'safe_server__tool' };
329
- expect((await engine.check(validToolCall, 'safe_server')).decision).toBe(PolicyDecision.ALLOW);
330
- });
331
- });
332
- describe('complex scenarios', () => {
333
- it('should handle multiple matching rules with different priorities', async () => {
334
- const rules = [
335
- { decision: PolicyDecision.DENY, priority: 0 }, // Default deny all
336
- { toolName: 'shell', decision: PolicyDecision.ASK_USER, priority: 5 },
337
- {
338
- toolName: 'shell',
339
- argsPattern: /"command":"ls/,
340
- decision: PolicyDecision.ALLOW,
341
- priority: 10,
342
- },
343
- ];
344
- engine = new PolicyEngine({ rules });
345
- // Matches highest priority rule (ls command)
346
- expect((await engine.check({ name: 'shell', args: { command: 'ls -la' } }, undefined)).decision).toBe(PolicyDecision.ALLOW);
347
- // Matches middle priority rule (shell without ls)
348
- expect((await engine.check({ name: 'shell', args: { command: 'pwd' } }, undefined)).decision).toBe(PolicyDecision.ASK_USER);
349
- // Matches lowest priority rule (not shell)
350
- expect((await engine.check({ name: 'edit' }, undefined)).decision).toBe(PolicyDecision.DENY);
351
- });
352
- it('should correctly match commands with quotes in commandPrefix', async () => {
353
- const prefix = 'git commit -m "fix"';
354
- const patterns = buildArgsPatterns(undefined, prefix);
355
- const rules = [
356
- {
357
- toolName: 'run_shell_command',
358
- argsPattern: new RegExp(patterns[0]),
359
- decision: PolicyDecision.ALLOW,
360
- },
361
- ];
362
- engine = new PolicyEngine({ rules });
363
- const result = await engine.check({
364
- name: 'run_shell_command',
365
- args: { command: 'git commit -m "fix"' },
366
- }, undefined);
367
- expect(result.decision).toBe(PolicyDecision.ALLOW);
368
- });
369
- it('should handle tools with no args', async () => {
370
- const rules = [
371
- {
372
- toolName: 'read',
373
- argsPattern: /secret/,
374
- decision: PolicyDecision.DENY,
375
- },
376
- ];
377
- engine = new PolicyEngine({ rules });
378
- // Tool call without args should not match pattern
379
- expect((await engine.check({ name: 'read' }, undefined)).decision).toBe(PolicyDecision.ASK_USER);
380
- // Tool call with args not matching pattern
381
- expect((await engine.check({ name: 'read', args: { file: 'public.txt' } }, undefined)).decision).toBe(PolicyDecision.ASK_USER);
382
- // Tool call with args matching pattern
383
- expect((await engine.check({ name: 'read', args: { file: 'secret.txt' } }, undefined)).decision).toBe(PolicyDecision.DENY);
384
- });
385
- it('should match args pattern regardless of property order', async () => {
386
- const rules = [
387
- {
388
- toolName: 'shell',
389
- // Pattern matches the stable stringified format
390
- argsPattern: /"command":"rm[^"]*-rf/,
391
- decision: PolicyDecision.DENY,
392
- },
393
- ];
394
- engine = new PolicyEngine({ rules });
395
- // Same args with different property order should both match
396
- const args1 = { command: 'rm -rf /', path: '/home' };
397
- const args2 = { path: '/home', command: 'rm -rf /' };
398
- expect((await engine.check({ name: 'shell', args: args1 }, undefined))
399
- .decision).toBe(PolicyDecision.DENY);
400
- expect((await engine.check({ name: 'shell', args: args2 }, undefined))
401
- .decision).toBe(PolicyDecision.DENY);
402
- // Verify safe command doesn't match
403
- const safeArgs = { command: 'ls -la', path: '/home' };
404
- expect((await engine.check({ name: 'shell', args: safeArgs }, undefined))
405
- .decision).toBe(PolicyDecision.ASK_USER);
406
- });
407
- it('should handle nested objects in args with stable stringification', async () => {
408
- const rules = [
409
- {
410
- toolName: 'api',
411
- argsPattern: /"sensitive":true/,
412
- decision: PolicyDecision.DENY,
413
- },
414
- ];
415
- engine = new PolicyEngine({ rules });
416
- // Nested objects with different key orders should match consistently
417
- const args1 = {
418
- data: { sensitive: true, value: 'secret' },
419
- method: 'POST',
420
- };
421
- const args2 = {
422
- method: 'POST',
423
- data: { value: 'secret', sensitive: true },
424
- };
425
- expect((await engine.check({ name: 'api', args: args1 }, undefined)).decision).toBe(PolicyDecision.DENY);
426
- expect((await engine.check({ name: 'api', args: args2 }, undefined)).decision).toBe(PolicyDecision.DENY);
427
- });
428
- it('should handle circular references without stack overflow', async () => {
429
- const rules = [
430
- {
431
- toolName: 'test',
432
- argsPattern: /\[Circular\]/,
433
- decision: PolicyDecision.DENY,
434
- },
435
- ];
436
- engine = new PolicyEngine({ rules });
437
- const circularArgs = {
438
- name: 'test',
439
- data: {},
440
- };
441
- // Create circular reference - TypeScript allows this since data is Record<string, unknown>
442
- circularArgs.data['self'] =
443
- circularArgs.data;
444
- // Should not throw stack overflow error
445
- await expect(engine.check({ name: 'test', args: circularArgs }, undefined)).resolves.not.toThrow();
446
- // Should detect the circular reference pattern
447
- expect((await engine.check({ name: 'test', args: circularArgs }, undefined))
448
- .decision).toBe(PolicyDecision.DENY);
449
- // Non-circular object should not match
450
- const normalArgs = { name: 'test', data: { value: 'normal' } };
451
- expect((await engine.check({ name: 'test', args: normalArgs }, undefined))
452
- .decision).toBe(PolicyDecision.ASK_USER);
453
- });
454
- it('should handle deep circular references', async () => {
455
- const rules = [
456
- {
457
- toolName: 'deep',
458
- argsPattern: /\[Circular\]/,
459
- decision: PolicyDecision.DENY,
460
- },
461
- ];
462
- engine = new PolicyEngine({ rules });
463
- const deepCircular = {
464
- level1: {
465
- level2: {
466
- level3: {},
467
- },
468
- },
469
- };
470
- // Create circular reference with proper type assertions
471
- const level3 = deepCircular.level1.level2.level3;
472
- level3['back'] = deepCircular.level1;
473
- // Should handle without stack overflow
474
- await expect(engine.check({ name: 'deep', args: deepCircular }, undefined)).resolves.not.toThrow();
475
- // Should detect the circular reference
476
- expect((await engine.check({ name: 'deep', args: deepCircular }, undefined))
477
- .decision).toBe(PolicyDecision.DENY);
478
- });
479
- it('should handle repeated non-circular objects correctly', async () => {
480
- const rules = [
481
- {
482
- toolName: 'test',
483
- argsPattern: /\[Circular\]/,
484
- decision: PolicyDecision.DENY,
485
- },
486
- {
487
- toolName: 'test',
488
- argsPattern: /"value":"shared"/,
489
- decision: PolicyDecision.ALLOW,
490
- priority: 10,
491
- },
492
- ];
493
- engine = new PolicyEngine({ rules });
494
- // Create an object with repeated references but no cycles
495
- const sharedObj = { value: 'shared' };
496
- const args = {
497
- first: sharedObj,
498
- second: sharedObj,
499
- third: { nested: sharedObj },
500
- };
501
- // Should NOT mark repeated objects as circular, and should match the shared value pattern
502
- expect((await engine.check({ name: 'test', args }, undefined)).decision).toBe(PolicyDecision.ALLOW);
503
- });
504
- it('should omit undefined and function values from objects', async () => {
505
- const rules = [
506
- {
507
- toolName: 'test',
508
- argsPattern: /"definedValue":"test"/,
509
- decision: PolicyDecision.ALLOW,
510
- },
511
- ];
512
- engine = new PolicyEngine({ rules });
513
- const args = {
514
- definedValue: 'test',
515
- undefinedValue: undefined,
516
- functionValue: () => 'hello',
517
- nullValue: null,
518
- };
519
- // Should match pattern with defined value, undefined and functions omitted
520
- expect((await engine.check({ name: 'test', args }, undefined)).decision).toBe(PolicyDecision.ALLOW);
521
- // Check that the pattern would NOT match if undefined was included
522
- const rulesWithUndefined = [
523
- {
524
- toolName: 'test',
525
- argsPattern: /undefinedValue/,
526
- decision: PolicyDecision.DENY,
527
- },
528
- ];
529
- engine = new PolicyEngine({ rules: rulesWithUndefined });
530
- expect((await engine.check({ name: 'test', args }, undefined)).decision).toBe(PolicyDecision.ASK_USER);
531
- // Check that the pattern would NOT match if function was included
532
- const rulesWithFunction = [
533
- {
534
- toolName: 'test',
535
- argsPattern: /functionValue/,
536
- decision: PolicyDecision.DENY,
537
- },
538
- ];
539
- engine = new PolicyEngine({ rules: rulesWithFunction });
540
- expect((await engine.check({ name: 'test', args }, undefined)).decision).toBe(PolicyDecision.ASK_USER);
541
- });
542
- it('should convert undefined and functions to null in arrays', async () => {
543
- const rules = [
544
- {
545
- toolName: 'test',
546
- argsPattern: /\["value",null,null,null\]/,
547
- decision: PolicyDecision.ALLOW,
548
- },
549
- ];
550
- engine = new PolicyEngine({ rules });
551
- const args = {
552
- array: ['value', undefined, () => 'hello', null],
553
- };
554
- // Should match pattern with undefined and functions converted to null
555
- expect((await engine.check({ name: 'test', args }, undefined)).decision).toBe(PolicyDecision.ALLOW);
556
- });
557
- it('should produce valid JSON for all inputs', async () => {
558
- const testCases = [
559
- { input: { simple: 'string' }, desc: 'simple object' },
560
- {
561
- input: { nested: { deep: { value: 123 } } },
562
- desc: 'nested object',
563
- },
564
- { input: { data: [1, 2, 3] }, desc: 'simple array' },
565
- { input: { mixed: [1, { a: 'b' }, null] }, desc: 'mixed array' },
566
- {
567
- input: { undef: undefined, func: () => { }, normal: 'value' },
568
- desc: 'object with undefined and function',
569
- },
570
- {
571
- input: { data: ['a', undefined, () => { }, null] },
572
- desc: 'array with undefined and function',
573
- },
574
- ];
575
- for (const { input } of testCases) {
576
- const rules = [
577
- {
578
- toolName: 'test',
579
- argsPattern: /.*/,
580
- decision: PolicyDecision.ALLOW,
581
- },
582
- ];
583
- engine = new PolicyEngine({ rules });
584
- // Should not throw when checking (which internally uses stableStringify)
585
- await expect(engine.check({ name: 'test', args: input }, undefined)).resolves.not.toThrow();
586
- // The check should succeed
587
- expect((await engine.check({ name: 'test', args: input }, undefined))
588
- .decision).toBe(PolicyDecision.ALLOW);
589
- }
590
- });
591
- it('should respect toJSON methods on objects', async () => {
592
- const rules = [
593
- {
594
- toolName: 'test',
595
- argsPattern: /"sanitized":"safe"/,
596
- decision: PolicyDecision.ALLOW,
597
- },
598
- {
599
- toolName: 'test',
600
- argsPattern: /"dangerous":"data"/,
601
- decision: PolicyDecision.DENY,
602
- },
603
- ];
604
- engine = new PolicyEngine({ rules });
605
- // Object with toJSON that sanitizes output
606
- const args = {
607
- data: {
608
- dangerous: 'data',
609
- toJSON: () => ({ sanitized: 'safe' }),
610
- },
611
- };
612
- // Should match the sanitized pattern, not the dangerous one
613
- expect((await engine.check({ name: 'test', args }, undefined)).decision).toBe(PolicyDecision.ALLOW);
614
- });
615
- it('should handle toJSON that returns primitives', async () => {
616
- const rules = [
617
- {
618
- toolName: 'test',
619
- argsPattern: /"value":"string-value"/,
620
- decision: PolicyDecision.ALLOW,
621
- },
622
- ];
623
- engine = new PolicyEngine({ rules });
624
- const args = {
625
- value: {
626
- complex: 'object',
627
- toJSON: () => 'string-value',
628
- },
629
- };
630
- // toJSON returns a string, which should be properly stringified
631
- expect((await engine.check({ name: 'test', args }, undefined)).decision).toBe(PolicyDecision.ALLOW);
632
- });
633
- it('should handle toJSON that throws an error', async () => {
634
- const rules = [
635
- {
636
- toolName: 'test',
637
- argsPattern: /"fallback":"value"/,
638
- decision: PolicyDecision.ALLOW,
639
- },
640
- ];
641
- engine = new PolicyEngine({ rules });
642
- const args = {
643
- data: {
644
- fallback: 'value',
645
- toJSON: () => {
646
- throw new Error('toJSON error');
647
- },
648
- },
649
- };
650
- // Should fall back to regular object serialization when toJSON throws
651
- expect((await engine.check({ name: 'test', args }, undefined)).decision).toBe(PolicyDecision.ALLOW);
652
- });
653
- it('should downgrade ALLOW to ASK_USER for redirected shell commands', async () => {
654
- const rules = [
655
- {
656
- toolName: 'run_shell_command',
657
- // Matches "echo" prefix
658
- argsPattern: /"command":"echo/,
659
- decision: PolicyDecision.ALLOW,
660
- },
661
- ];
662
- engine = new PolicyEngine({ rules });
663
- // Safe command should be allowed
664
- expect((await engine.check({ name: 'run_shell_command', args: { command: 'echo "hello"' } }, undefined)).decision).toBe(PolicyDecision.ALLOW);
665
- // Redirected command should be downgraded to ASK_USER
666
- expect((await engine.check({
667
- name: 'run_shell_command',
668
- args: { command: 'echo "hello" > file.txt' },
669
- }, undefined)).decision).toBe(PolicyDecision.ASK_USER);
670
- });
671
- it('should allow redirected shell commands when allowRedirection is true', async () => {
672
- const rules = [
673
- {
674
- toolName: 'run_shell_command',
675
- // Matches "echo" prefix
676
- argsPattern: /"command":"echo/,
677
- decision: PolicyDecision.ALLOW,
678
- allowRedirection: true,
679
- },
680
- ];
681
- engine = new PolicyEngine({ rules });
682
- // Redirected command should stay ALLOW
683
- expect((await engine.check({
684
- name: 'run_shell_command',
685
- args: { command: 'echo "hello" > file.txt' },
686
- }, undefined)).decision).toBe(PolicyDecision.ALLOW);
687
- });
688
- it('should NOT downgrade ALLOW to ASK_USER for quoted redirection chars', async () => {
689
- const rules = [
690
- {
691
- toolName: 'run_shell_command',
692
- argsPattern: /"command":"echo/,
693
- decision: PolicyDecision.ALLOW,
694
- },
695
- ];
696
- engine = new PolicyEngine({ rules });
697
- // Should remain ALLOW because it's not a real redirection
698
- expect((await engine.check({
699
- name: 'run_shell_command',
700
- args: { command: 'echo "-> arrow"' },
701
- }, undefined)).decision).toBe(PolicyDecision.ALLOW);
702
- });
703
- it('should preserve dir_path during recursive shell command checks', async () => {
704
- const rules = [
705
- {
706
- toolName: 'run_shell_command',
707
- // Rule that only allows echo in a specific directory
708
- // Note: stableStringify sorts keys alphabetically and has no spaces: {"command":"echo hello","dir_path":"/safe/path"}
709
- argsPattern: /"command":"echo hello".*"dir_path":"\/safe\/path"/,
710
- decision: PolicyDecision.ALLOW,
711
- },
712
- {
713
- // Catch-all ALLOW for shell but with low priority
714
- toolName: 'run_shell_command',
715
- decision: PolicyDecision.ALLOW,
716
- priority: -100,
717
- },
718
- ];
719
- engine = new PolicyEngine({ rules });
720
- // Compound command. The decomposition will call check() for "echo hello"
721
- // which should match our specific high-priority rule IF dir_path is preserved.
722
- const result = await engine.check({
723
- name: 'run_shell_command',
724
- args: { command: 'echo hello && pwd', dir_path: '/safe/path' },
725
- }, undefined);
726
- expect(result.decision).toBe(PolicyDecision.ALLOW);
727
- });
728
- it('should upgrade ASK_USER to ALLOW if all sub-commands are allowed', async () => {
729
- const rules = [
730
- {
731
- toolName: 'run_shell_command',
732
- argsPattern: /"command":"git status/,
733
- decision: PolicyDecision.ALLOW,
734
- priority: 20,
735
- },
736
- {
737
- toolName: 'run_shell_command',
738
- argsPattern: /"command":"ls/,
739
- decision: PolicyDecision.ALLOW,
740
- priority: 20,
741
- },
742
- {
743
- // Catch-all ASK_USER for shell
744
- toolName: 'run_shell_command',
745
- decision: PolicyDecision.ASK_USER,
746
- priority: 10,
747
- },
748
- ];
749
- engine = new PolicyEngine({ rules });
750
- // "git status && ls" matches the catch-all ASK_USER rule initially.
751
- // But since both parts are explicitly ALLOWed, the result should be upgraded to ALLOW.
752
- const result = await engine.check({
753
- name: 'run_shell_command',
754
- args: { command: 'git status && ls' },
755
- }, undefined);
756
- expect(result.decision).toBe(PolicyDecision.ALLOW);
757
- });
758
- it('should respect explicit DENY for compound commands even if parts are allowed', async () => {
759
- const rules = [
760
- {
761
- // Explicitly DENY the compound command
762
- toolName: 'run_shell_command',
763
- argsPattern: /"command":"git status && ls"/,
764
- decision: PolicyDecision.DENY,
765
- priority: 30,
766
- },
767
- {
768
- toolName: 'run_shell_command',
769
- argsPattern: /"command":"git status/,
770
- decision: PolicyDecision.ALLOW,
771
- priority: 20,
772
- },
773
- {
774
- toolName: 'run_shell_command',
775
- argsPattern: /"command":"ls/,
776
- decision: PolicyDecision.ALLOW,
777
- priority: 20,
778
- },
779
- ];
780
- engine = new PolicyEngine({ rules });
781
- const result = await engine.check({
782
- name: 'run_shell_command',
783
- args: { command: 'git status && ls' },
784
- }, undefined);
785
- expect(result.decision).toBe(PolicyDecision.DENY);
786
- });
787
- it('should propagate DENY from any sub-command', async () => {
788
- const rules = [
789
- {
790
- toolName: 'run_shell_command',
791
- argsPattern: /"command":"rm/,
792
- decision: PolicyDecision.DENY,
793
- priority: 20,
794
- },
795
- {
796
- toolName: 'run_shell_command',
797
- argsPattern: /"command":"echo/,
798
- decision: PolicyDecision.ALLOW,
799
- priority: 20,
800
- },
801
- {
802
- toolName: 'run_shell_command',
803
- decision: PolicyDecision.ASK_USER,
804
- priority: 10,
805
- },
806
- ];
807
- engine = new PolicyEngine({ rules });
808
- // "echo hello && rm -rf /" -> echo is ALLOW, rm is DENY -> Result DENY
809
- const result = await engine.check({
810
- name: 'run_shell_command',
811
- args: { command: 'echo hello && rm -rf /' },
812
- }, undefined);
813
- expect(result.decision).toBe(PolicyDecision.DENY);
814
- });
815
- it('should DENY redirected shell commands in non-interactive mode', async () => {
816
- const config = {
817
- nonInteractive: true,
818
- rules: [
819
- {
820
- toolName: 'run_shell_command',
821
- decision: PolicyDecision.ALLOW,
822
- },
823
- ],
824
- };
825
- engine = new PolicyEngine(config);
826
- // Redirected command should be DENIED in non-interactive mode
827
- // (Normally ASK_USER, but ASK_USER -> DENY in non-interactive)
828
- expect((await engine.check({
829
- name: 'run_shell_command',
830
- args: { command: 'echo "hello" > file.txt' },
831
- }, undefined)).decision).toBe(PolicyDecision.DENY);
832
- });
833
- it('should default to ASK_USER for atomic commands when matching a wildcard ASK_USER rule', async () => {
834
- // Regression test: atomic commands were auto-allowing because of optimistic initialization
835
- const rules = [
836
- {
837
- toolName: 'run_shell_command',
838
- decision: PolicyDecision.ASK_USER,
839
- },
840
- ];
841
- engine = new PolicyEngine({ rules });
842
- // Atomic command "whoami" matches the wildcard rule (ASK_USER).
843
- // It should NOT be upgraded to ALLOW.
844
- expect((await engine.check({
845
- name: 'run_shell_command',
846
- args: { command: 'whoami' },
847
- }, undefined)).decision).toBe(PolicyDecision.ASK_USER);
848
- });
849
- it('should allow redirected shell commands in non-interactive mode if allowRedirection is true', async () => {
850
- const config = {
851
- nonInteractive: true,
852
- rules: [
853
- {
854
- toolName: 'run_shell_command',
855
- decision: PolicyDecision.ALLOW,
856
- allowRedirection: true,
857
- },
858
- ],
859
- };
860
- engine = new PolicyEngine(config);
861
- // Redirected command should stay ALLOW even in non-interactive mode
862
- expect((await engine.check({
863
- name: 'run_shell_command',
864
- args: { command: 'echo "hello" > file.txt' },
865
- }, undefined)).decision).toBe(PolicyDecision.ALLOW);
866
- });
867
- it('should avoid infinite recursion for commands with substitution', async () => {
868
- const rules = [
869
- {
870
- toolName: 'run_shell_command',
871
- decision: PolicyDecision.ALLOW,
872
- },
873
- ];
874
- engine = new PolicyEngine({ rules });
875
- // Command with substitution triggers splitCommands returning the same command as its first element.
876
- // This verifies the fix for the infinite recursion bug.
877
- const result = await engine.check({
878
- name: 'run_shell_command',
879
- args: { command: 'echo $(ls)' },
880
- }, undefined);
881
- expect(result.decision).toBe(PolicyDecision.ALLOW);
882
- });
883
- it('should require confirmation for a compound command with redirection even if individual commands are allowed', async () => {
884
- const rules = [
885
- {
886
- toolName: 'run_shell_command',
887
- argsPattern: /"command":"mkdir\b/,
888
- decision: PolicyDecision.ALLOW,
889
- priority: 20,
890
- },
891
- {
892
- toolName: 'run_shell_command',
893
- argsPattern: /"command":"echo\b/,
894
- decision: PolicyDecision.ALLOW,
895
- priority: 20,
896
- },
897
- ];
898
- engine = new PolicyEngine({ rules });
899
- // The full command has redirection, even if the individual split commands do not.
900
- // splitCommands will return ['mkdir -p "bar"', 'echo "hello"']
901
- // The redirection '> bar/test.md' is stripped by splitCommands.
902
- const result = await engine.check({
903
- name: 'run_shell_command',
904
- args: { command: 'mkdir -p "bar" && echo "hello" > bar/test.md' },
905
- }, undefined);
906
- expect(result.decision).toBe(PolicyDecision.ASK_USER);
907
- });
908
- it('should report redirection when a sub-command specifically has redirection', async () => {
909
- const rules = [
910
- {
911
- toolName: 'run_shell_command',
912
- argsPattern: /"command":"mkdir\b/,
913
- decision: PolicyDecision.ALLOW,
914
- priority: 20,
915
- },
916
- {
917
- toolName: 'run_shell_command',
918
- argsPattern: /"command":"echo\b/,
919
- decision: PolicyDecision.ALLOW,
920
- priority: 20,
921
- },
922
- ];
923
- engine = new PolicyEngine({ rules });
924
- // In this case, we mock splitCommands to keep the redirection in the sub-command
925
- vi.mocked(initializeShellParsers).mockResolvedValue(undefined);
926
- const { splitCommands } = await import('../utils/shell-utils.js');
927
- vi.mocked(splitCommands).mockReturnValueOnce([
928
- 'mkdir bar',
929
- 'echo hello > bar/test.md',
930
- ]);
931
- const result = await engine.check({
932
- name: 'run_shell_command',
933
- args: { command: 'mkdir bar && echo hello > bar/test.md' },
934
- }, undefined);
935
- expect(result.decision).toBe(PolicyDecision.ASK_USER);
936
- });
937
- it('should allow redirected shell commands in AUTO_EDIT mode if individual commands are allowed', async () => {
938
- const rules = [
939
- {
940
- toolName: 'run_shell_command',
941
- argsPattern: /"command":"echo\b/,
942
- decision: PolicyDecision.ALLOW,
943
- priority: 20,
944
- },
945
- ];
946
- engine = new PolicyEngine({ rules });
947
- engine.setApprovalMode(ApprovalMode.AUTO_EDIT);
948
- const result = await engine.check({
949
- name: 'run_shell_command',
950
- args: { command: 'echo "hello" > test.txt' },
951
- }, undefined);
952
- expect(result.decision).toBe(PolicyDecision.ALLOW);
953
- });
954
- it('should allow compound commands with safe operators (&&, ||) if individual commands are allowed', async () => {
955
- const rules = [
956
- {
957
- toolName: 'run_shell_command',
958
- argsPattern: /"command":"echo\b/,
959
- decision: PolicyDecision.ALLOW,
960
- priority: 20,
961
- },
962
- ];
963
- engine = new PolicyEngine({ rules });
964
- // "echo hello && echo world" should be allowed since both parts are ALLOW and no redirection is present.
965
- const result = await engine.check({
966
- name: 'run_shell_command',
967
- args: { command: 'echo hello && echo world' },
968
- }, undefined);
969
- expect(result.decision).toBe(PolicyDecision.ALLOW);
970
- });
971
- });
972
- describe('safety checker integration', () => {
973
- it('should call checker when rule allows and has safety_checker', async () => {
974
- const rules = [
975
- {
976
- toolName: 'test-tool',
977
- decision: PolicyDecision.ALLOW,
978
- },
979
- ];
980
- const checkers = [
981
- {
982
- toolName: 'test-tool',
983
- checker: {
984
- type: 'external',
985
- name: 'test-checker',
986
- config: { content: 'test-content' },
987
- },
988
- },
989
- ];
990
- engine = new PolicyEngine({ rules, checkers }, mockCheckerRunner);
991
- vi.mocked(mockCheckerRunner.runChecker).mockResolvedValue({
992
- decision: SafetyCheckDecision.ALLOW,
993
- });
994
- const result = await engine.check({ name: 'test-tool', args: { foo: 'bar' } }, undefined);
995
- expect(result.decision).toBe(PolicyDecision.ALLOW);
996
- expect(mockCheckerRunner.runChecker).toHaveBeenCalledWith({ name: 'test-tool', args: { foo: 'bar' } }, {
997
- type: 'external',
998
- name: 'test-checker',
999
- config: { content: 'test-content' },
1000
- });
1001
- });
1002
- it('should handle checker errors as DENY', async () => {
1003
- const rules = [
1004
- {
1005
- toolName: 'test',
1006
- decision: PolicyDecision.ALLOW,
1007
- },
1008
- ];
1009
- const checkers = [
1010
- {
1011
- toolName: 'test',
1012
- checker: {
1013
- type: 'in-process',
1014
- name: InProcessCheckerType.ALLOWED_PATH,
1015
- },
1016
- },
1017
- ];
1018
- mockCheckerRunner.runChecker = vi
1019
- .fn()
1020
- .mockRejectedValue(new Error('Checker failed'));
1021
- engine = new PolicyEngine({ rules, checkers }, mockCheckerRunner);
1022
- const { decision } = await engine.check({ name: 'test' }, undefined);
1023
- expect(decision).toBe(PolicyDecision.DENY);
1024
- });
1025
- it('should return DENY when checker denies', async () => {
1026
- const rules = [
1027
- {
1028
- toolName: 'test-tool',
1029
- decision: PolicyDecision.ALLOW,
1030
- },
1031
- ];
1032
- const checkers = [
1033
- {
1034
- toolName: 'test-tool',
1035
- checker: {
1036
- type: 'external',
1037
- name: 'test-checker',
1038
- config: { content: 'test-content' },
1039
- },
1040
- },
1041
- ];
1042
- engine = new PolicyEngine({ rules, checkers }, mockCheckerRunner);
1043
- vi.mocked(mockCheckerRunner.runChecker).mockResolvedValue({
1044
- decision: SafetyCheckDecision.DENY,
1045
- reason: 'test reason',
1046
- });
1047
- const result = await engine.check({ name: 'test-tool', args: { foo: 'bar' } }, undefined);
1048
- expect(result.decision).toBe(PolicyDecision.DENY);
1049
- expect(mockCheckerRunner.runChecker).toHaveBeenCalled();
1050
- });
1051
- it('should not call checker if decision is not ALLOW', async () => {
1052
- const rules = [
1053
- {
1054
- toolName: 'test-tool',
1055
- decision: PolicyDecision.ASK_USER,
1056
- },
1057
- ];
1058
- const checkers = [
1059
- {
1060
- toolName: 'test-tool',
1061
- checker: {
1062
- type: 'external',
1063
- name: 'test-checker',
1064
- config: { content: 'test-content' },
1065
- },
1066
- },
1067
- ];
1068
- engine = new PolicyEngine({ rules, checkers }, mockCheckerRunner);
1069
- vi.mocked(mockCheckerRunner.runChecker).mockResolvedValue({
1070
- decision: SafetyCheckDecision.ALLOW,
1071
- });
1072
- const result = await engine.check({ name: 'test-tool', args: { foo: 'bar' } }, undefined);
1073
- expect(result.decision).toBe(PolicyDecision.ASK_USER);
1074
- expect(mockCheckerRunner.runChecker).toHaveBeenCalled();
1075
- });
1076
- it('should run checkers when rule allows', async () => {
1077
- const rules = [
1078
- {
1079
- toolName: 'test',
1080
- decision: PolicyDecision.ALLOW,
1081
- },
1082
- ];
1083
- const checkers = [
1084
- {
1085
- toolName: 'test',
1086
- checker: {
1087
- type: 'in-process',
1088
- name: InProcessCheckerType.ALLOWED_PATH,
1089
- },
1090
- },
1091
- ];
1092
- mockCheckerRunner.runChecker = vi.fn().mockResolvedValue({
1093
- decision: SafetyCheckDecision.ALLOW,
1094
- });
1095
- engine = new PolicyEngine({ rules, checkers }, mockCheckerRunner);
1096
- const { decision } = await engine.check({ name: 'test' }, undefined);
1097
- expect(decision).toBe(PolicyDecision.ALLOW);
1098
- expect(mockCheckerRunner.runChecker).toHaveBeenCalledTimes(1);
1099
- });
1100
- it('should not call checker if rule has no safety_checker', async () => {
1101
- const rules = [
1102
- {
1103
- toolName: 'test-tool',
1104
- decision: PolicyDecision.ALLOW,
1105
- },
1106
- ];
1107
- engine = new PolicyEngine({ rules }, mockCheckerRunner);
1108
- const result = await engine.check({ name: 'test-tool', args: { foo: 'bar' } }, undefined);
1109
- expect(result.decision).toBe(PolicyDecision.ALLOW);
1110
- expect(mockCheckerRunner.runChecker).not.toHaveBeenCalled();
1111
- });
1112
- });
1113
- describe('serverName requirement', () => {
1114
- it('should require serverName for checks', async () => {
1115
- // @ts-expect-error - intentionally testing missing serverName
1116
- expect((await engine.check({ name: 'test' })).decision).toBe(PolicyDecision.ASK_USER);
1117
- // When serverName is provided (even undefined), it should work
1118
- expect((await engine.check({ name: 'test' }, undefined)).decision).toBe(PolicyDecision.ASK_USER);
1119
- expect((await engine.check({ name: 'test' }, 'some-server')).decision).toBe(PolicyDecision.ASK_USER);
1120
- });
1121
- it('should run multiple checkers in priority order and stop at first denial', async () => {
1122
- const rules = [
1123
- {
1124
- toolName: 'test',
1125
- decision: PolicyDecision.ALLOW,
1126
- },
1127
- ];
1128
- const checkers = [
1129
- {
1130
- toolName: 'test',
1131
- priority: 10,
1132
- checker: { type: 'external', name: 'checker1' },
1133
- },
1134
- {
1135
- toolName: 'test',
1136
- priority: 20, // Should run first
1137
- checker: { type: 'external', name: 'checker2' },
1138
- },
1139
- ];
1140
- mockCheckerRunner.runChecker = vi
1141
- .fn()
1142
- .mockImplementation(async (_toolCall, config) => {
1143
- if (config.name === 'checker2') {
1144
- return {
1145
- decision: SafetyCheckDecision.DENY,
1146
- reason: 'checker2 denied',
1147
- };
1148
- }
1149
- return { decision: SafetyCheckDecision.ALLOW };
1150
- });
1151
- engine = new PolicyEngine({ rules, checkers }, mockCheckerRunner);
1152
- const { decision, rule } = await engine.check({ name: 'test' }, undefined);
1153
- expect(decision).toBe(PolicyDecision.DENY);
1154
- expect(rule).toBeDefined();
1155
- expect(mockCheckerRunner.runChecker).toHaveBeenCalledTimes(1);
1156
- expect(mockCheckerRunner.runChecker).toHaveBeenCalledWith(expect.anything(), expect.objectContaining({ name: 'checker2' }));
1157
- });
1158
- });
1159
- describe('addChecker', () => {
1160
- it('should add a new checker and maintain priority order', () => {
1161
- const checker1 = {
1162
- checker: { type: 'external', name: 'checker1' },
1163
- priority: 5,
1164
- };
1165
- const checker2 = {
1166
- checker: { type: 'external', name: 'checker2' },
1167
- priority: 10,
1168
- };
1169
- engine.addChecker(checker1);
1170
- engine.addChecker(checker2);
1171
- const checkers = engine.getCheckers();
1172
- expect(checkers).toHaveLength(2);
1173
- expect(checkers[0].priority).toBe(10);
1174
- expect(checkers[0].checker.name).toBe('checker2');
1175
- expect(checkers[1].priority).toBe(5);
1176
- expect(checkers[1].checker.name).toBe('checker1');
1177
- });
1178
- });
1179
- describe('checker matching logic', () => {
1180
- it('should match checkers using toolName and argsPattern', async () => {
1181
- const rules = [
1182
- { toolName: 'tool', decision: PolicyDecision.ALLOW },
1183
- ];
1184
- const matchingChecker = {
1185
- checker: { type: 'external', name: 'matching' },
1186
- toolName: 'tool',
1187
- argsPattern: /"safe":true/,
1188
- };
1189
- const nonMatchingChecker = {
1190
- checker: { type: 'external', name: 'non-matching' },
1191
- toolName: 'other',
1192
- };
1193
- engine = new PolicyEngine({ rules, checkers: [matchingChecker, nonMatchingChecker] }, mockCheckerRunner);
1194
- vi.mocked(mockCheckerRunner.runChecker).mockResolvedValue({
1195
- decision: SafetyCheckDecision.ALLOW,
1196
- });
1197
- await engine.check({ name: 'tool', args: { safe: true } }, undefined);
1198
- expect(mockCheckerRunner.runChecker).toHaveBeenCalledWith(expect.anything(), expect.objectContaining({ name: 'matching' }));
1199
- expect(mockCheckerRunner.runChecker).not.toHaveBeenCalledWith(expect.anything(), expect.objectContaining({ name: 'non-matching' }));
1200
- });
1201
- it('should support wildcard patterns for checkers', async () => {
1202
- const rules = [
1203
- { toolName: 'server__tool', decision: PolicyDecision.ALLOW },
1204
- ];
1205
- const wildcardChecker = {
1206
- checker: { type: 'external', name: 'wildcard' },
1207
- toolName: 'server__*',
1208
- };
1209
- engine = new PolicyEngine({ rules, checkers: [wildcardChecker] }, mockCheckerRunner);
1210
- vi.mocked(mockCheckerRunner.runChecker).mockResolvedValue({
1211
- decision: SafetyCheckDecision.ALLOW,
1212
- });
1213
- await engine.check({ name: 'server__tool' }, 'server');
1214
- expect(mockCheckerRunner.runChecker).toHaveBeenCalledWith(expect.anything(), expect.objectContaining({ name: 'wildcard' }));
1215
- });
1216
- it('should run safety checkers when decision is ASK_USER and downgrade to DENY on failure', async () => {
1217
- const rules = [
1218
- { toolName: 'tool', decision: PolicyDecision.ASK_USER },
1219
- ];
1220
- const checkers = [
1221
- {
1222
- checker: {
1223
- type: 'in-process',
1224
- name: InProcessCheckerType.ALLOWED_PATH,
1225
- },
1226
- },
1227
- ];
1228
- engine = new PolicyEngine({ rules, checkers }, mockCheckerRunner);
1229
- vi.mocked(mockCheckerRunner.runChecker).mockResolvedValue({
1230
- decision: SafetyCheckDecision.DENY,
1231
- reason: 'Safety check failed',
1232
- });
1233
- const result = await engine.check({ name: 'tool' }, undefined);
1234
- expect(result.decision).toBe(PolicyDecision.DENY);
1235
- expect(mockCheckerRunner.runChecker).toHaveBeenCalled();
1236
- });
1237
- it('should run safety checkers when decision is ASK_USER and keep ASK_USER on success', async () => {
1238
- const rules = [
1239
- { toolName: 'tool', decision: PolicyDecision.ASK_USER },
1240
- ];
1241
- const checkers = [
1242
- {
1243
- checker: {
1244
- type: 'in-process',
1245
- name: InProcessCheckerType.ALLOWED_PATH,
1246
- },
1247
- },
1248
- ];
1249
- engine = new PolicyEngine({ rules, checkers }, mockCheckerRunner);
1250
- vi.mocked(mockCheckerRunner.runChecker).mockResolvedValue({
1251
- decision: SafetyCheckDecision.ALLOW,
1252
- });
1253
- const result = await engine.check({ name: 'tool' }, undefined);
1254
- expect(result.decision).toBe(PolicyDecision.ASK_USER);
1255
- expect(mockCheckerRunner.runChecker).toHaveBeenCalled();
1256
- });
1257
- it('should downgrade ALLOW to ASK_USER if checker returns ASK_USER', async () => {
1258
- const rules = [
1259
- { toolName: 'tool', decision: PolicyDecision.ALLOW },
1260
- ];
1261
- const checkers = [
1262
- {
1263
- checker: {
1264
- type: 'in-process',
1265
- name: InProcessCheckerType.ALLOWED_PATH,
1266
- },
1267
- },
1268
- ];
1269
- engine = new PolicyEngine({ rules, checkers }, mockCheckerRunner);
1270
- vi.mocked(mockCheckerRunner.runChecker).mockResolvedValue({
1271
- decision: SafetyCheckDecision.ASK_USER,
1272
- reason: 'Suspicious path',
1273
- });
1274
- const result = await engine.check({ name: 'tool' }, undefined);
1275
- expect(result.decision).toBe(PolicyDecision.ASK_USER);
1276
- });
1277
- it('should DENY if checker returns ASK_USER in non-interactive mode', async () => {
1278
- const rules = [
1279
- { toolName: 'tool', decision: PolicyDecision.ALLOW },
1280
- ];
1281
- const checkers = [
1282
- {
1283
- checker: {
1284
- type: 'in-process',
1285
- name: InProcessCheckerType.ALLOWED_PATH,
1286
- },
1287
- },
1288
- ];
1289
- engine = new PolicyEngine({ rules, checkers, nonInteractive: true }, mockCheckerRunner);
1290
- vi.mocked(mockCheckerRunner.runChecker).mockResolvedValue({
1291
- decision: SafetyCheckDecision.ASK_USER,
1292
- reason: 'Suspicious path',
1293
- });
1294
- const result = await engine.check({ name: 'tool' }, undefined);
1295
- expect(result.decision).toBe(PolicyDecision.DENY);
1296
- });
1297
- });
1298
- });
1299
- //# sourceMappingURL=policy-engine.test.js.map