@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,1080 +0,0 @@
1
- /**
2
- * @license
3
- * Copyright 2025 Google LLC
4
- * SPDX-License-Identifier: Apache-2.0
5
- */
6
- import { vi, describe, it, expect, beforeEach, afterEach, } from 'vitest';
7
- import EventEmitter from 'node:events';
8
- import {} from 'node:child_process';
9
- import { ShellExecutionService } from './shellExecutionService.js';
10
- // Hoisted Mocks
11
- const mockPtySpawn = vi.hoisted(() => vi.fn());
12
- const mockCpSpawn = vi.hoisted(() => vi.fn());
13
- const mockIsBinary = vi.hoisted(() => vi.fn());
14
- const mockPlatform = vi.hoisted(() => vi.fn());
15
- const mockGetPty = vi.hoisted(() => vi.fn());
16
- const mockSerializeTerminalToObject = vi.hoisted(() => vi.fn());
17
- const mockResolveExecutable = vi.hoisted(() => vi.fn());
18
- // Top-level Mocks
19
- vi.mock('@lydell/node-pty', () => ({
20
- spawn: mockPtySpawn,
21
- }));
22
- vi.mock('../utils/shell-utils.js', async (importOriginal) => {
23
- const actual = await importOriginal();
24
- return {
25
- ...actual,
26
- resolveExecutable: mockResolveExecutable,
27
- };
28
- });
29
- vi.mock('node:child_process', async (importOriginal) => {
30
- const actual = await importOriginal();
31
- return {
32
- ...actual,
33
- spawn: mockCpSpawn,
34
- };
35
- });
36
- vi.mock('../utils/textUtils.js', () => ({
37
- isBinary: mockIsBinary,
38
- }));
39
- vi.mock('node:os', () => ({
40
- default: {
41
- platform: mockPlatform,
42
- constants: {
43
- signals: {
44
- SIGTERM: 15,
45
- SIGKILL: 9,
46
- },
47
- },
48
- },
49
- platform: mockPlatform,
50
- constants: {
51
- signals: {
52
- SIGTERM: 15,
53
- SIGKILL: 9,
54
- },
55
- },
56
- }));
57
- vi.mock('../utils/getPty.js', () => ({
58
- getPty: mockGetPty,
59
- }));
60
- vi.mock('../utils/terminalSerializer.js', () => ({
61
- serializeTerminalToObject: mockSerializeTerminalToObject,
62
- }));
63
- vi.mock('../utils/systemEncoding.js', () => ({
64
- getCachedEncodingForBuffer: vi.fn().mockReturnValue('utf-8'),
65
- }));
66
- const mockProcessKill = vi
67
- .spyOn(process, 'kill')
68
- .mockImplementation(() => true);
69
- const shellExecutionConfig = {
70
- terminalWidth: 80,
71
- terminalHeight: 24,
72
- pager: 'cat',
73
- showColor: false,
74
- disableDynamicLineTrimming: true,
75
- sanitizationConfig: {
76
- enableEnvironmentVariableRedaction: false,
77
- allowedEnvironmentVariables: [],
78
- blockedEnvironmentVariables: [],
79
- },
80
- };
81
- const createMockSerializeTerminalToObjectReturnValue = (text) => {
82
- const lines = Array.isArray(text) ? text : text.split('\n');
83
- const len = shellExecutionConfig.terminalHeight ?? 24;
84
- const expected = Array.from({ length: len }, (_, i) => [
85
- {
86
- text: (lines[i] || '').trim(),
87
- bold: false,
88
- italic: false,
89
- underline: false,
90
- dim: false,
91
- inverse: false,
92
- fg: '#ffffff',
93
- bg: '#000000',
94
- },
95
- ]);
96
- return expected;
97
- };
98
- const createExpectedAnsiOutput = (text) => {
99
- const lines = Array.isArray(text) ? text : text.split('\n');
100
- const len = shellExecutionConfig.terminalHeight ?? 24;
101
- const expected = Array.from({ length: len }, (_, i) => [
102
- {
103
- text: expect.stringMatching((lines[i] || '').trim()),
104
- bold: false,
105
- italic: false,
106
- underline: false,
107
- dim: false,
108
- inverse: false,
109
- fg: '',
110
- bg: '',
111
- },
112
- ]);
113
- return expected;
114
- };
115
- describe('ShellExecutionService', () => {
116
- let mockPtyProcess;
117
- let mockHeadlessTerminal;
118
- let onOutputEventMock;
119
- beforeEach(() => {
120
- vi.clearAllMocks();
121
- mockSerializeTerminalToObject.mockReturnValue([]);
122
- mockIsBinary.mockReturnValue(false);
123
- mockPlatform.mockReturnValue('linux');
124
- mockResolveExecutable.mockImplementation(async (exe) => exe);
125
- process.env['PATH'] = '/test/path';
126
- mockGetPty.mockResolvedValue({
127
- module: { spawn: mockPtySpawn },
128
- name: 'mock-pty',
129
- });
130
- onOutputEventMock = vi.fn();
131
- mockPtyProcess = new EventEmitter();
132
- mockPtyProcess.pid = 12345;
133
- mockPtyProcess.kill = vi.fn();
134
- mockPtyProcess.onData = vi.fn();
135
- mockPtyProcess.onExit = vi.fn();
136
- mockPtyProcess.write = vi.fn();
137
- mockPtyProcess.resize = vi.fn();
138
- mockPtyProcess.destroy = vi.fn();
139
- mockHeadlessTerminal = {
140
- resize: vi.fn(),
141
- scrollLines: vi.fn(),
142
- buffer: {
143
- active: {
144
- viewportY: 0,
145
- },
146
- },
147
- };
148
- mockPtySpawn.mockReturnValue(mockPtyProcess);
149
- });
150
- // Helper function to run a standard execution simulation
151
- const simulateExecution = async (command, simulation, config = shellExecutionConfig) => {
152
- const abortController = new AbortController();
153
- const handle = await ShellExecutionService.execute(command, '/test/dir', onOutputEventMock, abortController.signal, true, config);
154
- await new Promise((resolve) => process.nextTick(resolve));
155
- await simulation(mockPtyProcess, abortController);
156
- const result = await handle.result;
157
- return { result, handle, abortController };
158
- };
159
- describe('Successful Execution', () => {
160
- it('should execute a command and capture output', async () => {
161
- mockSerializeTerminalToObject.mockReturnValue(createMockSerializeTerminalToObjectReturnValue('file1.txt'));
162
- const { result, handle } = await simulateExecution('ls -l', (pty) => {
163
- pty.onData.mock.calls[0][0]('file1.txt\n');
164
- pty.onExit.mock.calls[0][0]({ exitCode: 0, signal: null });
165
- });
166
- expect(mockPtySpawn).toHaveBeenCalledWith('bash', [
167
- '-c',
168
- 'shopt -u promptvars nullglob extglob nocaseglob dotglob; ls -l',
169
- ], expect.any(Object));
170
- expect(result.exitCode).toBe(0);
171
- expect(result.signal).toBeNull();
172
- expect(result.error).toBeNull();
173
- expect(result.aborted).toBe(false);
174
- expect(result.output.trim()).toBe('file1.txt');
175
- expect(handle.pid).toBe(12345);
176
- expect(onOutputEventMock).toHaveBeenCalledWith({
177
- type: 'data',
178
- chunk: createExpectedAnsiOutput('file1.txt'),
179
- });
180
- });
181
- it('should strip ANSI color codes from output', async () => {
182
- mockSerializeTerminalToObject.mockReturnValue(createMockSerializeTerminalToObjectReturnValue('aredword'));
183
- const { result } = await simulateExecution('ls --color=auto', (pty) => {
184
- pty.onData.mock.calls[0][0]('a\u001b[31mred\u001b[0mword');
185
- pty.onExit.mock.calls[0][0]({ exitCode: 0, signal: null });
186
- });
187
- expect(result.output.trim()).toBe('aredword');
188
- expect(onOutputEventMock).toHaveBeenCalledWith(expect.objectContaining({
189
- type: 'data',
190
- chunk: createExpectedAnsiOutput('aredword'),
191
- }));
192
- });
193
- it('should correctly decode multi-byte characters split across chunks', async () => {
194
- const { result } = await simulateExecution('echo "你好"', (pty) => {
195
- const multiByteChar = '你好';
196
- pty.onData.mock.calls[0][0](multiByteChar.slice(0, 1));
197
- pty.onData.mock.calls[0][0](multiByteChar.slice(1));
198
- pty.onExit.mock.calls[0][0]({ exitCode: 0, signal: null });
199
- });
200
- expect(result.output.trim()).toBe('你好');
201
- });
202
- it('should handle commands with no output', async () => {
203
- mockSerializeTerminalToObject.mockReturnValue(createMockSerializeTerminalToObjectReturnValue(''));
204
- await simulateExecution('touch file', (pty) => {
205
- pty.onExit.mock.calls[0][0]({ exitCode: 0, signal: null });
206
- });
207
- expect(onOutputEventMock).toHaveBeenCalledWith(expect.objectContaining({
208
- chunk: createExpectedAnsiOutput(''),
209
- }));
210
- });
211
- it('should capture large output (10000 lines)', async () => {
212
- const lineCount = 10000;
213
- const lines = Array.from({ length: lineCount }, (_, i) => `line ${i}`);
214
- const expectedOutput = lines.join('\n');
215
- const { result } = await simulateExecution('large-output-command', (pty) => {
216
- // Send data in chunks to simulate realistic streaming
217
- // Use \r\n to ensure the terminal moves the cursor to the start of the line
218
- const chunkSize = 1000;
219
- for (let i = 0; i < lineCount; i += chunkSize) {
220
- const chunk = lines.slice(i, i + chunkSize).join('\r\n') + '\r\n';
221
- pty.onData.mock.calls[0][0](chunk);
222
- }
223
- pty.onExit.mock.calls[0][0]({ exitCode: 0, signal: null });
224
- });
225
- expect(result.exitCode).toBe(0);
226
- // The terminal buffer output includes trailing spaces for each line (up to terminal width).
227
- // We trim each line to match our expected simple string.
228
- const processedOutput = result.output
229
- .split('\n')
230
- .map((l) => l.trimEnd())
231
- .join('\n')
232
- .trim();
233
- expect(processedOutput).toBe(expectedOutput);
234
- expect(result.output.split('\n').length).toBeGreaterThanOrEqual(lineCount);
235
- });
236
- it('should not wrap long lines in the final output', async () => {
237
- // Set a small width to force wrapping
238
- const narrowConfig = { ...shellExecutionConfig, terminalWidth: 10 };
239
- const longString = '123456789012345'; // 15 chars, should wrap at 10
240
- const { result } = await simulateExecution('long-line-command', (pty) => {
241
- pty.onData.mock.calls[0][0](longString);
242
- pty.onExit.mock.calls[0][0]({ exitCode: 0, signal: null });
243
- }, narrowConfig);
244
- expect(result.exitCode).toBe(0);
245
- expect(result.output.trim()).toBe(longString);
246
- });
247
- it('should not add extra padding but preserve explicit trailing whitespace', async () => {
248
- const { result } = await simulateExecution('cmd', (pty) => {
249
- // "value" should not get terminal-width padding
250
- // "value2 " should keep its spaces
251
- pty.onData.mock.calls[0][0]('value\r\nvalue2 ');
252
- pty.onExit.mock.calls[0][0]({ exitCode: 0, signal: null });
253
- });
254
- expect(result.output).toBe('value\nvalue2 ');
255
- });
256
- it('should truncate output exceeding the scrollback limit', async () => {
257
- const scrollbackLimit = 100;
258
- const totalLines = 150;
259
- // Generate lines: "line 0", "line 1", ...
260
- const lines = Array.from({ length: totalLines }, (_, i) => `line ${i}`);
261
- const { result } = await simulateExecution('overflow-command', (pty) => {
262
- const chunk = lines.join('\r\n') + '\r\n';
263
- pty.onData.mock.calls[0][0](chunk);
264
- pty.onExit.mock.calls[0][0]({ exitCode: 0, signal: null });
265
- }, { ...shellExecutionConfig, scrollback: scrollbackLimit });
266
- expect(result.exitCode).toBe(0);
267
- // The terminal should keep the *last* 'scrollbackLimit' lines + lines in the viewport.
268
- // xterm.js scrollback is the number of lines *above* the viewport.
269
- // So total lines retained = scrollback + rows.
270
- // However, our `getFullBufferText` implementation iterates the *active* buffer.
271
- // In headless xterm, the buffer length grows.
272
- // Let's verify that we have fewer lines than totalLines.
273
- const outputLines = result.output
274
- .trim()
275
- .split('\n')
276
- .map((l) => l.trimEnd());
277
- // We expect the *start* of the output to be truncated.
278
- // The first retained line should be > "line 0".
279
- // Specifically, if we sent 150 lines and have space for roughly 100 + viewport(24),
280
- // we should miss the first ~26 lines.
281
- // Check that we lost some lines from the beginning
282
- expect(outputLines.length).toBeLessThan(totalLines);
283
- expect(outputLines[0]).not.toBe('line 0');
284
- // Check that we have the *last* lines
285
- expect(outputLines[outputLines.length - 1]).toBe(`line ${totalLines - 1}`);
286
- });
287
- it('should call onPid with the process id', async () => {
288
- const abortController = new AbortController();
289
- const handle = await ShellExecutionService.execute('ls -l', '/test/dir', onOutputEventMock, abortController.signal, true, shellExecutionConfig);
290
- mockPtyProcess.onExit.mock.calls[0][0]({ exitCode: 0, signal: null });
291
- await handle.result;
292
- expect(handle.pid).toBe(12345);
293
- });
294
- });
295
- describe('pty interaction', () => {
296
- beforeEach(() => {
297
- vi.spyOn(ShellExecutionService['activePtys'], 'get').mockReturnValue({
298
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
299
- ptyProcess: mockPtyProcess,
300
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
301
- headlessTerminal: mockHeadlessTerminal,
302
- });
303
- });
304
- it('should write to the pty and trigger a render', async () => {
305
- vi.useFakeTimers();
306
- await simulateExecution('interactive-app', (pty) => {
307
- ShellExecutionService.writeToPty(pty.pid, 'input');
308
- pty.onExit.mock.calls[0][0]({ exitCode: 0, signal: null });
309
- });
310
- expect(mockPtyProcess.write).toHaveBeenCalledWith('input');
311
- // Use fake timers to check for the delayed render
312
- await vi.advanceTimersByTimeAsync(17);
313
- // The render will cause an output event
314
- expect(onOutputEventMock).toHaveBeenCalled();
315
- vi.useRealTimers();
316
- });
317
- it('should resize the pty and the headless terminal', async () => {
318
- await simulateExecution('ls -l', (pty) => {
319
- pty.onData.mock.calls[0][0]('file1.txt\n');
320
- ShellExecutionService.resizePty(pty.pid, 100, 40);
321
- pty.onExit.mock.calls[0][0]({ exitCode: 0, signal: null });
322
- });
323
- expect(mockPtyProcess.resize).toHaveBeenCalledWith(100, 40);
324
- expect(mockHeadlessTerminal.resize).toHaveBeenCalledWith(100, 40);
325
- });
326
- it('should not resize the pty if it is not active', async () => {
327
- const isPtyActiveSpy = vi
328
- .spyOn(ShellExecutionService, 'isPtyActive')
329
- .mockReturnValue(false);
330
- await simulateExecution('ls -l', (pty) => {
331
- ShellExecutionService.resizePty(pty.pid, 100, 40);
332
- pty.onExit.mock.calls[0][0]({ exitCode: 0, signal: null });
333
- });
334
- expect(mockPtyProcess.resize).not.toHaveBeenCalled();
335
- expect(mockHeadlessTerminal.resize).not.toHaveBeenCalled();
336
- isPtyActiveSpy.mockRestore();
337
- });
338
- it('should ignore errors when resizing an exited pty', async () => {
339
- const resizeError = new Error('Cannot resize a pty that has already exited');
340
- mockPtyProcess.resize.mockImplementation(() => {
341
- throw resizeError;
342
- });
343
- // We don't expect this test to throw an error
344
- await expect(simulateExecution('ls -l', (pty) => {
345
- ShellExecutionService.resizePty(pty.pid, 100, 40);
346
- pty.onExit.mock.calls[0][0]({ exitCode: 0, signal: null });
347
- })).resolves.not.toThrow();
348
- expect(mockPtyProcess.resize).toHaveBeenCalledWith(100, 40);
349
- });
350
- it('should re-throw other errors during resize', async () => {
351
- const otherError = new Error('Some other error');
352
- mockPtyProcess.resize.mockImplementation(() => {
353
- throw otherError;
354
- });
355
- await expect(simulateExecution('ls -l', (pty) => {
356
- ShellExecutionService.resizePty(pty.pid, 100, 40);
357
- pty.onExit.mock.calls[0][0]({ exitCode: 0, signal: null });
358
- })).rejects.toThrow('Some other error');
359
- });
360
- it('should scroll the headless terminal', async () => {
361
- await simulateExecution('ls -l', (pty) => {
362
- pty.onData.mock.calls[0][0]('file1.txt\n');
363
- ShellExecutionService.scrollPty(pty.pid, 10);
364
- pty.onExit.mock.calls[0][0]({ exitCode: 0, signal: null });
365
- });
366
- expect(mockHeadlessTerminal.scrollLines).toHaveBeenCalledWith(10);
367
- });
368
- it('should not throw when resizing a pty that has already exited (Windows)', () => {
369
- const resizeError = new Error('Cannot resize a pty that has already exited');
370
- mockPtyProcess.resize.mockImplementation(() => {
371
- throw resizeError;
372
- });
373
- // This should catch the specific error and not re-throw it.
374
- expect(() => {
375
- ShellExecutionService.resizePty(mockPtyProcess.pid, 100, 40);
376
- }).not.toThrow();
377
- expect(mockPtyProcess.resize).toHaveBeenCalledWith(100, 40);
378
- expect(mockHeadlessTerminal.resize).not.toHaveBeenCalled();
379
- });
380
- });
381
- describe('Failed Execution', () => {
382
- it('should capture a non-zero exit code', async () => {
383
- const { result } = await simulateExecution('a-bad-command', (pty) => {
384
- pty.onData.mock.calls[0][0]('command not found');
385
- pty.onExit.mock.calls[0][0]({ exitCode: 127, signal: null });
386
- });
387
- expect(result.exitCode).toBe(127);
388
- expect(result.output.trim()).toBe('command not found');
389
- expect(result.error).toBeNull();
390
- });
391
- it('should capture a termination signal', async () => {
392
- const { result } = await simulateExecution('long-process', (pty) => {
393
- pty.onExit.mock.calls[0][0]({ exitCode: 0, signal: 15 });
394
- });
395
- expect(result.exitCode).toBe(0);
396
- expect(result.signal).toBe(15);
397
- });
398
- it('should handle a synchronous spawn error', async () => {
399
- mockGetPty.mockImplementation(() => null);
400
- mockCpSpawn.mockImplementation(() => {
401
- throw new Error('Simulated PTY spawn error');
402
- });
403
- const handle = await ShellExecutionService.execute('any-command', '/test/dir', onOutputEventMock, new AbortController().signal, true, {
404
- sanitizationConfig: {
405
- enableEnvironmentVariableRedaction: true,
406
- allowedEnvironmentVariables: [],
407
- blockedEnvironmentVariables: [],
408
- },
409
- });
410
- const result = await handle.result;
411
- expect(result.error).toBeInstanceOf(Error);
412
- expect(result.error?.message).toContain('Simulated PTY spawn error');
413
- expect(result.exitCode).toBe(1);
414
- expect(result.output).toBe('');
415
- expect(handle.pid).toBeUndefined();
416
- });
417
- });
418
- describe('Aborting Commands', () => {
419
- it('should abort a running process and set the aborted flag', async () => {
420
- const { result } = await simulateExecution('sleep 10', (pty, abortController) => {
421
- abortController.abort();
422
- pty.onExit.mock.calls[0][0]({ exitCode: 1, signal: null });
423
- });
424
- expect(result.aborted).toBe(true);
425
- // The process kill is mocked, so we just check that the flag is set.
426
- });
427
- it('should send SIGTERM and then SIGKILL on abort', async () => {
428
- const sigkillPromise = new Promise((resolve) => {
429
- mockProcessKill.mockImplementation((pid, signal) => {
430
- if (signal === 'SIGKILL' && pid === -mockPtyProcess.pid) {
431
- resolve();
432
- }
433
- return true;
434
- });
435
- });
436
- const { result } = await simulateExecution('long-running-process', async (pty, abortController) => {
437
- abortController.abort();
438
- await sigkillPromise; // Wait for SIGKILL to be sent before exiting.
439
- pty.onExit.mock.calls[0][0]({ exitCode: 0, signal: 9 });
440
- });
441
- expect(result.aborted).toBe(true);
442
- // Verify the calls were made in the correct order.
443
- const killCalls = mockProcessKill.mock.calls;
444
- const sigtermCallIndex = killCalls.findIndex((call) => call[0] === -mockPtyProcess.pid && call[1] === 'SIGTERM');
445
- const sigkillCallIndex = killCalls.findIndex((call) => call[0] === -mockPtyProcess.pid && call[1] === 'SIGKILL');
446
- expect(sigtermCallIndex).toBe(0);
447
- expect(sigkillCallIndex).toBe(1);
448
- expect(sigtermCallIndex).toBeLessThan(sigkillCallIndex);
449
- expect(result.signal).toBe(9);
450
- });
451
- it('should resolve without waiting for the processing chain on abort', async () => {
452
- const { result } = await simulateExecution('long-output', (pty, abortController) => {
453
- // Simulate a lot of data being in the queue to be processed
454
- for (let i = 0; i < 1000; i++) {
455
- pty.onData.mock.calls[0][0]('some data');
456
- }
457
- abortController.abort();
458
- pty.onExit.mock.calls[0][0]({ exitCode: 1, signal: null });
459
- });
460
- // The main assertion here is implicit: the `await` for the result above
461
- // should complete without timing out. This proves that the resolution
462
- // was not blocked by the long chain of data processing promises,
463
- // which is the desired behavior on abort.
464
- expect(result.aborted).toBe(true);
465
- });
466
- });
467
- describe('Binary Output', () => {
468
- it('should detect binary output and switch to progress events', async () => {
469
- mockIsBinary.mockReturnValueOnce(true);
470
- const binaryChunk1 = Buffer.from([0x89, 0x50, 0x4e, 0x47]);
471
- const binaryChunk2 = Buffer.from([0x0d, 0x0a, 0x1a, 0x0a]);
472
- const { result } = await simulateExecution('cat image.png', (pty) => {
473
- pty.onData.mock.calls[0][0](binaryChunk1);
474
- pty.onData.mock.calls[0][0](binaryChunk2);
475
- pty.onExit.mock.calls[0][0]({ exitCode: 0, signal: null });
476
- });
477
- expect(result.rawOutput).toEqual(Buffer.concat([binaryChunk1, binaryChunk2]));
478
- expect(onOutputEventMock).toHaveBeenCalledTimes(3);
479
- expect(onOutputEventMock.mock.calls[0][0]).toEqual({
480
- type: 'binary_detected',
481
- });
482
- expect(onOutputEventMock.mock.calls[1][0]).toEqual({
483
- type: 'binary_progress',
484
- bytesReceived: 4,
485
- });
486
- expect(onOutputEventMock.mock.calls[2][0]).toEqual({
487
- type: 'binary_progress',
488
- bytesReceived: 8,
489
- });
490
- });
491
- it('should not emit data events after binary is detected', async () => {
492
- mockIsBinary.mockImplementation((buffer) => buffer.includes(0x00));
493
- await simulateExecution('cat mixed_file', (pty) => {
494
- pty.onData.mock.calls[0][0](Buffer.from([0x00, 0x01, 0x02]));
495
- pty.onData.mock.calls[0][0](Buffer.from('more text'));
496
- pty.onExit.mock.calls[0][0]({ exitCode: 0, signal: null });
497
- });
498
- const eventTypes = onOutputEventMock.mock.calls.map((call) => call[0].type);
499
- expect(eventTypes).toEqual([
500
- 'binary_detected',
501
- 'binary_progress',
502
- 'binary_progress',
503
- ]);
504
- });
505
- });
506
- describe('Platform-Specific Behavior', () => {
507
- it('should use powershell.exe on Windows', async () => {
508
- mockPlatform.mockReturnValue('win32');
509
- await simulateExecution('dir "foo bar"', (pty) => pty.onExit.mock.calls[0][0]({ exitCode: 0, signal: null }));
510
- expect(mockPtySpawn).toHaveBeenCalledWith('powershell.exe', ['-NoProfile', '-Command', 'dir "foo bar"'], expect.any(Object));
511
- });
512
- it('should use bash on Linux', async () => {
513
- mockPlatform.mockReturnValue('linux');
514
- await simulateExecution('ls "foo bar"', (pty) => pty.onExit.mock.calls[0][0]({ exitCode: 0, signal: null }));
515
- expect(mockPtySpawn).toHaveBeenCalledWith('bash', [
516
- '-c',
517
- 'shopt -u promptvars nullglob extglob nocaseglob dotglob; ls "foo bar"',
518
- ], expect.any(Object));
519
- });
520
- });
521
- describe('AnsiOutput rendering', () => {
522
- it('should call onOutputEvent with AnsiOutput when showColor is true', async () => {
523
- const coloredShellExecutionConfig = {
524
- ...shellExecutionConfig,
525
- showColor: true,
526
- defaultFg: '#ffffff',
527
- defaultBg: '#000000',
528
- disableDynamicLineTrimming: true,
529
- };
530
- const mockAnsiOutput = [
531
- [{ text: 'hello', fg: '#ffffff', bg: '#000000' }],
532
- ];
533
- mockSerializeTerminalToObject.mockReturnValue(mockAnsiOutput);
534
- await simulateExecution('ls --color=auto', (pty) => {
535
- pty.onData.mock.calls[0][0]('a\u001b[31mred\u001b[0mword');
536
- pty.onExit.mock.calls[0][0]({ exitCode: 0, signal: null });
537
- }, coloredShellExecutionConfig);
538
- expect(mockSerializeTerminalToObject).toHaveBeenCalledWith(expect.anything());
539
- expect(onOutputEventMock).toHaveBeenCalledWith(expect.objectContaining({
540
- type: 'data',
541
- chunk: mockAnsiOutput,
542
- }));
543
- });
544
- it('should call onOutputEvent with AnsiOutput when showColor is false', async () => {
545
- mockSerializeTerminalToObject.mockReturnValue(createMockSerializeTerminalToObjectReturnValue('aredword'));
546
- await simulateExecution('ls --color=auto', (pty) => {
547
- pty.onData.mock.calls[0][0]('a\u001b[31mred\u001b[0mword');
548
- pty.onExit.mock.calls[0][0]({ exitCode: 0, signal: null });
549
- }, {
550
- ...shellExecutionConfig,
551
- showColor: false,
552
- disableDynamicLineTrimming: true,
553
- });
554
- const expected = createExpectedAnsiOutput('aredword');
555
- expect(onOutputEventMock).toHaveBeenCalledWith(expect.objectContaining({
556
- type: 'data',
557
- chunk: expected,
558
- }));
559
- });
560
- it('should handle multi-line output correctly when showColor is false', async () => {
561
- mockSerializeTerminalToObject.mockReturnValue(createMockSerializeTerminalToObjectReturnValue([
562
- 'line 1',
563
- 'line 2',
564
- 'line 3',
565
- ]));
566
- await simulateExecution('ls --color=auto', (pty) => {
567
- pty.onData.mock.calls[0][0]('line 1\n\u001b[32mline 2\u001b[0m\nline 3');
568
- pty.onExit.mock.calls[0][0]({ exitCode: 0, signal: null });
569
- }, {
570
- ...shellExecutionConfig,
571
- showColor: false,
572
- disableDynamicLineTrimming: true,
573
- });
574
- const expected = createExpectedAnsiOutput(['line 1', 'line 2', 'line 3']);
575
- expect(onOutputEventMock).toHaveBeenCalledWith(expect.objectContaining({
576
- type: 'data',
577
- chunk: expected,
578
- }));
579
- });
580
- });
581
- describe('Resource Management', () => {
582
- it('should destroy the PTY process and clear activePtys on exit', async () => {
583
- await simulateExecution('ls -l', (pty) => {
584
- pty.onExit.mock.calls[0][0]({ exitCode: 0, signal: null });
585
- });
586
- expect(mockPtyProcess.destroy).toHaveBeenCalled();
587
- expect(ShellExecutionService['activePtys'].size).toBe(0);
588
- });
589
- it('should destroy the PTY process even if destroy throws', async () => {
590
- mockPtyProcess.destroy.mockImplementation(() => {
591
- throw new Error('Destroy failed');
592
- });
593
- await expect(simulateExecution('ls -l', (pty) => {
594
- pty.onExit.mock.calls[0][0]({ exitCode: 0, signal: null });
595
- })).resolves.not.toThrow();
596
- expect(ShellExecutionService['activePtys'].size).toBe(0);
597
- });
598
- });
599
- });
600
- describe('ShellExecutionService child_process fallback', () => {
601
- let mockChildProcess;
602
- let onOutputEventMock;
603
- beforeEach(() => {
604
- vi.clearAllMocks();
605
- mockIsBinary.mockReturnValue(false);
606
- mockPlatform.mockReturnValue('linux');
607
- mockGetPty.mockResolvedValue(null);
608
- onOutputEventMock = vi.fn();
609
- mockChildProcess = new EventEmitter();
610
- mockChildProcess.stdout = new EventEmitter();
611
- mockChildProcess.stderr = new EventEmitter();
612
- mockChildProcess.kill = vi.fn();
613
- Object.defineProperty(mockChildProcess, 'pid', {
614
- value: 12345,
615
- configurable: true,
616
- });
617
- mockCpSpawn.mockReturnValue(mockChildProcess);
618
- });
619
- // Helper function to run a standard execution simulation
620
- const simulateExecution = async (command, simulation) => {
621
- const abortController = new AbortController();
622
- const handle = await ShellExecutionService.execute(command, '/test/dir', onOutputEventMock, abortController.signal, true, shellExecutionConfig);
623
- await new Promise((resolve) => process.nextTick(resolve));
624
- simulation(mockChildProcess, abortController);
625
- const result = await handle.result;
626
- return { result, handle, abortController };
627
- };
628
- describe('Successful Execution', () => {
629
- it('should execute a command and capture stdout and stderr', async () => {
630
- const { result, handle } = await simulateExecution('ls -l', (cp) => {
631
- cp.stdout?.emit('data', Buffer.from('file1.txt\n'));
632
- cp.stderr?.emit('data', Buffer.from('a warning'));
633
- cp.emit('exit', 0, null);
634
- cp.emit('close', 0, null);
635
- });
636
- expect(mockCpSpawn).toHaveBeenCalledWith('bash', [
637
- '-c',
638
- 'shopt -u promptvars nullglob extglob nocaseglob dotglob; ls -l',
639
- ], expect.objectContaining({ shell: false, detached: true }));
640
- expect(result.exitCode).toBe(0);
641
- expect(result.signal).toBeNull();
642
- expect(result.error).toBeNull();
643
- expect(result.aborted).toBe(false);
644
- expect(result.output).toBe('file1.txt\na warning');
645
- expect(handle.pid).toBe(undefined);
646
- expect(onOutputEventMock).toHaveBeenCalledWith({
647
- type: 'data',
648
- chunk: 'file1.txt\na warning',
649
- });
650
- });
651
- it('should strip ANSI color codes from output', async () => {
652
- const { result } = await simulateExecution('ls --color=auto', (cp) => {
653
- cp.stdout?.emit('data', Buffer.from('a\u001b[31mred\u001b[0mword'));
654
- cp.emit('exit', 0, null);
655
- cp.emit('close', 0, null);
656
- });
657
- expect(result.output.trim()).toBe('aredword');
658
- expect(onOutputEventMock).toHaveBeenCalledWith(expect.objectContaining({
659
- type: 'data',
660
- chunk: 'aredword',
661
- }));
662
- });
663
- it('should correctly decode multi-byte characters split across chunks', async () => {
664
- const { result } = await simulateExecution('echo "你好"', (cp) => {
665
- const multiByteChar = Buffer.from('你好', 'utf-8');
666
- cp.stdout?.emit('data', multiByteChar.slice(0, 2));
667
- cp.stdout?.emit('data', multiByteChar.slice(2));
668
- cp.emit('exit', 0, null);
669
- cp.emit('close', 0, null);
670
- });
671
- expect(result.output.trim()).toBe('你好');
672
- });
673
- it('should handle commands with no output', async () => {
674
- const { result } = await simulateExecution('touch file', (cp) => {
675
- cp.emit('exit', 0, null);
676
- cp.emit('close', 0, null);
677
- });
678
- expect(result.output.trim()).toBe('');
679
- expect(onOutputEventMock).not.toHaveBeenCalled();
680
- });
681
- it.skip('should truncate stdout using a sliding window and show a warning', async () => {
682
- const MAX_SIZE = 16 * 1024 * 1024;
683
- const chunk1 = 'a'.repeat(MAX_SIZE / 2 - 5);
684
- const chunk2 = 'b'.repeat(MAX_SIZE / 2 - 5);
685
- const chunk3 = 'c'.repeat(20);
686
- const { result } = await simulateExecution('large-output', (cp) => {
687
- cp.stdout?.emit('data', Buffer.from(chunk1));
688
- cp.stdout?.emit('data', Buffer.from(chunk2));
689
- cp.stdout?.emit('data', Buffer.from(chunk3));
690
- cp.emit('exit', 0, null);
691
- });
692
- const truncationMessage = '[GEMINI_CLI_WARNING: Output truncated. The buffer is limited to 16MB.]';
693
- expect(result.output).toContain(truncationMessage);
694
- const outputWithoutMessage = result.output
695
- .substring(0, result.output.indexOf(truncationMessage))
696
- .trimEnd();
697
- expect(outputWithoutMessage.length).toBe(MAX_SIZE);
698
- const expectedStart = (chunk1 + chunk2 + chunk3).slice(-MAX_SIZE);
699
- expect(outputWithoutMessage.startsWith(expectedStart.substring(0, 10))).toBe(true);
700
- expect(outputWithoutMessage.endsWith('c'.repeat(20))).toBe(true);
701
- }, 120000);
702
- });
703
- describe('Failed Execution', () => {
704
- it('should capture a non-zero exit code and format output correctly', async () => {
705
- const { result } = await simulateExecution('a-bad-command', (cp) => {
706
- cp.stderr?.emit('data', Buffer.from('command not found'));
707
- cp.emit('exit', 127, null);
708
- cp.emit('close', 127, null);
709
- });
710
- expect(result.exitCode).toBe(127);
711
- expect(result.output.trim()).toBe('command not found');
712
- expect(result.error).toBeNull();
713
- });
714
- it('should capture a termination signal', async () => {
715
- const { result } = await simulateExecution('long-process', (cp) => {
716
- cp.emit('exit', null, 'SIGTERM');
717
- cp.emit('close', null, 'SIGTERM');
718
- });
719
- expect(result.exitCode).toBeNull();
720
- expect(result.signal).toBe(15);
721
- });
722
- it('should handle a spawn error', async () => {
723
- const spawnError = new Error('spawn EACCES');
724
- const { result } = await simulateExecution('protected-cmd', (cp) => {
725
- cp.emit('error', spawnError);
726
- cp.emit('exit', 1, null);
727
- cp.emit('close', 1, null);
728
- });
729
- expect(result.error).toBe(spawnError);
730
- expect(result.exitCode).toBe(1);
731
- });
732
- it('handles errors that do not fire the exit event', async () => {
733
- const error = new Error('spawn abc ENOENT');
734
- const { result } = await simulateExecution('touch cat.jpg', (cp) => {
735
- cp.emit('error', error); // No exit event is fired.
736
- cp.emit('close', 1, null);
737
- });
738
- expect(result.error).toBe(error);
739
- expect(result.exitCode).toBe(1);
740
- });
741
- });
742
- describe('Aborting Commands', () => {
743
- describe.each([
744
- {
745
- platform: 'linux',
746
- expectedSignal: 'SIGTERM',
747
- expectedExit: { signal: 'SIGKILL' },
748
- },
749
- {
750
- platform: 'win32',
751
- expectedCommand: 'taskkill',
752
- expectedExit: { code: 1 },
753
- },
754
- ])('on $platform', ({ platform, expectedSignal, expectedCommand, expectedExit }) => {
755
- it('should abort a running process and set the aborted flag', async () => {
756
- mockPlatform.mockReturnValue(platform);
757
- const { result } = await simulateExecution('sleep 10', (cp, abortController) => {
758
- abortController.abort();
759
- if (expectedExit.signal) {
760
- cp.emit('exit', null, expectedExit.signal);
761
- cp.emit('close', null, expectedExit.signal);
762
- }
763
- if (typeof expectedExit.code === 'number') {
764
- cp.emit('exit', expectedExit.code, null);
765
- cp.emit('close', expectedExit.code, null);
766
- }
767
- });
768
- expect(result.aborted).toBe(true);
769
- if (platform === 'linux') {
770
- expect(mockProcessKill).toHaveBeenCalledWith(-mockChildProcess.pid, expectedSignal);
771
- }
772
- else {
773
- expect(mockCpSpawn).toHaveBeenCalledWith(expectedCommand, [
774
- '/pid',
775
- String(mockChildProcess.pid),
776
- '/f',
777
- '/t',
778
- ]);
779
- }
780
- });
781
- });
782
- it('should gracefully attempt SIGKILL on linux if SIGTERM fails', async () => {
783
- mockPlatform.mockReturnValue('linux');
784
- vi.useFakeTimers();
785
- // Don't await the result inside the simulation block for this specific test.
786
- // We need to control the timeline manually.
787
- const abortController = new AbortController();
788
- const handle = await ShellExecutionService.execute('unresponsive_process', '/test/dir', onOutputEventMock, abortController.signal, true, {
789
- sanitizationConfig: {
790
- enableEnvironmentVariableRedaction: true,
791
- allowedEnvironmentVariables: [],
792
- blockedEnvironmentVariables: [],
793
- },
794
- });
795
- abortController.abort();
796
- // Check the first kill signal
797
- expect(mockProcessKill).toHaveBeenCalledWith(-mockChildProcess.pid, 'SIGTERM');
798
- // Now, advance time past the timeout
799
- await vi.advanceTimersByTimeAsync(250);
800
- // Check the second kill signal
801
- expect(mockProcessKill).toHaveBeenCalledWith(-mockChildProcess.pid, 'SIGKILL');
802
- // Finally, simulate the process exiting and await the result
803
- mockChildProcess.emit('exit', null, 'SIGKILL');
804
- mockChildProcess.emit('close', null, 'SIGKILL');
805
- const result = await handle.result;
806
- vi.useRealTimers();
807
- expect(result.aborted).toBe(true);
808
- expect(result.signal).toBe(9);
809
- });
810
- });
811
- describe('Binary Output', () => {
812
- it('should detect binary output and switch to progress events', async () => {
813
- mockIsBinary.mockReturnValueOnce(true);
814
- const binaryChunk1 = Buffer.from([0x89, 0x50, 0x4e, 0x47]);
815
- const binaryChunk2 = Buffer.from([0x0d, 0x0a, 0x1a, 0x0a]);
816
- const { result } = await simulateExecution('cat image.png', (cp) => {
817
- cp.stdout?.emit('data', binaryChunk1);
818
- cp.stdout?.emit('data', binaryChunk2);
819
- cp.emit('exit', 0, null);
820
- });
821
- expect(result.rawOutput).toEqual(Buffer.concat([binaryChunk1, binaryChunk2]));
822
- expect(onOutputEventMock).toHaveBeenCalledTimes(1);
823
- expect(onOutputEventMock.mock.calls[0][0]).toEqual({
824
- type: 'binary_detected',
825
- });
826
- });
827
- it('should not emit data events after binary is detected', async () => {
828
- mockIsBinary.mockImplementation((buffer) => buffer.includes(0x00));
829
- await simulateExecution('cat mixed_file', (cp) => {
830
- cp.stdout?.emit('data', Buffer.from('some text'));
831
- cp.stdout?.emit('data', Buffer.from([0x00, 0x01, 0x02]));
832
- cp.stdout?.emit('data', Buffer.from('more text'));
833
- cp.emit('exit', 0, null);
834
- });
835
- const eventTypes = onOutputEventMock.mock.calls.map((call) => call[0].type);
836
- expect(eventTypes).toEqual(['binary_detected']);
837
- });
838
- });
839
- describe('Platform-Specific Behavior', () => {
840
- it('should use powershell.exe on Windows', async () => {
841
- mockPlatform.mockReturnValue('win32');
842
- await simulateExecution('dir "foo bar"', (cp) => cp.emit('exit', 0, null));
843
- expect(mockCpSpawn).toHaveBeenCalledWith('powershell.exe', ['-NoProfile', '-Command', 'dir "foo bar"'], expect.objectContaining({
844
- shell: false,
845
- detached: false,
846
- windowsVerbatimArguments: false,
847
- }));
848
- });
849
- it('should use bash and detached process group on Linux', async () => {
850
- mockPlatform.mockReturnValue('linux');
851
- await simulateExecution('ls "foo bar"', (cp) => cp.emit('exit', 0, null));
852
- expect(mockCpSpawn).toHaveBeenCalledWith('bash', [
853
- '-c',
854
- 'shopt -u promptvars nullglob extglob nocaseglob dotglob; ls "foo bar"',
855
- ], expect.objectContaining({
856
- shell: false,
857
- detached: true,
858
- }));
859
- });
860
- });
861
- });
862
- describe('ShellExecutionService execution method selection', () => {
863
- let onOutputEventMock;
864
- let mockPtyProcess;
865
- let mockChildProcess;
866
- beforeEach(() => {
867
- vi.clearAllMocks();
868
- onOutputEventMock = vi.fn();
869
- // Mock for pty
870
- mockPtyProcess = new EventEmitter();
871
- mockPtyProcess.pid = 12345;
872
- mockPtyProcess.kill = vi.fn();
873
- mockPtyProcess.onData = vi.fn();
874
- mockPtyProcess.onExit = vi.fn();
875
- mockPtyProcess.write = vi.fn();
876
- mockPtyProcess.resize = vi.fn();
877
- mockPtySpawn.mockReturnValue(mockPtyProcess);
878
- mockGetPty.mockResolvedValue({
879
- module: { spawn: mockPtySpawn },
880
- name: 'mock-pty',
881
- });
882
- // Mock for child_process
883
- mockChildProcess = new EventEmitter();
884
- mockChildProcess.stdout = new EventEmitter();
885
- mockChildProcess.stderr = new EventEmitter();
886
- mockChildProcess.kill = vi.fn();
887
- Object.defineProperty(mockChildProcess, 'pid', {
888
- value: 54321,
889
- configurable: true,
890
- });
891
- mockCpSpawn.mockReturnValue(mockChildProcess);
892
- });
893
- it('should use node-pty when shouldUseNodePty is true and pty is available', async () => {
894
- mockSerializeTerminalToObject.mockReturnValue([]);
895
- const abortController = new AbortController();
896
- const handle = await ShellExecutionService.execute('test command', '/test/dir', onOutputEventMock, abortController.signal, true, // shouldUseNodePty
897
- shellExecutionConfig);
898
- // Simulate exit to allow promise to resolve
899
- mockPtyProcess.onExit.mock.calls[0][0]({ exitCode: 0, signal: null });
900
- const result = await handle.result;
901
- expect(mockGetPty).toHaveBeenCalled();
902
- expect(mockPtySpawn).toHaveBeenCalled();
903
- expect(mockCpSpawn).not.toHaveBeenCalled();
904
- expect(result.executionMethod).toBe('mock-pty');
905
- });
906
- it('should use child_process when shouldUseNodePty is false', async () => {
907
- const abortController = new AbortController();
908
- const handle = await ShellExecutionService.execute('test command', '/test/dir', onOutputEventMock, abortController.signal, false, // shouldUseNodePty
909
- {
910
- sanitizationConfig: {
911
- enableEnvironmentVariableRedaction: true,
912
- allowedEnvironmentVariables: [],
913
- blockedEnvironmentVariables: [],
914
- },
915
- });
916
- // Simulate exit to allow promise to resolve
917
- mockChildProcess.emit('exit', 0, null);
918
- const result = await handle.result;
919
- expect(mockGetPty).not.toHaveBeenCalled();
920
- expect(mockPtySpawn).not.toHaveBeenCalled();
921
- expect(mockCpSpawn).toHaveBeenCalled();
922
- expect(result.executionMethod).toBe('child_process');
923
- });
924
- it('should fall back to child_process if pty is not available even if shouldUseNodePty is true', async () => {
925
- mockGetPty.mockResolvedValue(null);
926
- const abortController = new AbortController();
927
- const handle = await ShellExecutionService.execute('test command', '/test/dir', onOutputEventMock, abortController.signal, true, // shouldUseNodePty
928
- shellExecutionConfig);
929
- // Simulate exit to allow promise to resolve
930
- mockChildProcess.emit('exit', 0, null);
931
- const result = await handle.result;
932
- expect(mockGetPty).toHaveBeenCalled();
933
- expect(mockPtySpawn).not.toHaveBeenCalled();
934
- expect(mockCpSpawn).toHaveBeenCalled();
935
- expect(result.executionMethod).toBe('child_process');
936
- });
937
- });
938
- describe('ShellExecutionService environment variables', () => {
939
- let mockPtyProcess;
940
- let mockChildProcess;
941
- beforeEach(() => {
942
- vi.clearAllMocks();
943
- vi.resetModules(); // Reset modules to ensure process.env changes are fresh
944
- // Mock for pty
945
- mockPtyProcess = new EventEmitter();
946
- mockPtyProcess.pid = 12345;
947
- mockPtyProcess.kill = vi.fn();
948
- mockPtyProcess.onData = vi.fn();
949
- mockPtyProcess.onExit = vi.fn();
950
- mockPtyProcess.write = vi.fn();
951
- mockPtyProcess.resize = vi.fn();
952
- mockPtySpawn.mockReturnValue(mockPtyProcess);
953
- mockGetPty.mockResolvedValue({
954
- module: { spawn: mockPtySpawn },
955
- name: 'mock-pty',
956
- });
957
- // Mock for child_process
958
- mockChildProcess = new EventEmitter();
959
- mockChildProcess.stdout = new EventEmitter();
960
- mockChildProcess.stderr = new EventEmitter();
961
- mockChildProcess.kill = vi.fn();
962
- Object.defineProperty(mockChildProcess, 'pid', {
963
- value: 54321,
964
- configurable: true,
965
- });
966
- mockCpSpawn.mockReturnValue(mockChildProcess);
967
- // Default exit behavior for mocks
968
- mockPtyProcess.onExit.mockImplementationOnce(({ exitCode, signal }) => {
969
- // Small delay to allow async ops to complete
970
- setTimeout(() => mockPtyProcess.emit('exit', { exitCode, signal }), 0);
971
- });
972
- mockChildProcess.on('exit', (code, signal) => {
973
- // Small delay to allow async ops to complete
974
- setTimeout(() => mockChildProcess.emit('close', code, signal), 0);
975
- });
976
- });
977
- afterEach(() => {
978
- // Clean up process.env after each test
979
- vi.unstubAllEnvs();
980
- });
981
- it('should use a sanitized environment when in a GitHub run', async () => {
982
- // Mock the environment to simulate a GitHub Actions run
983
- vi.stubEnv('GITHUB_SHA', 'test-sha');
984
- vi.stubEnv('MY_SENSITIVE_VAR', 'secret-value'); // This should be stripped out
985
- vi.stubEnv('PATH', '/test/path'); // An essential var that should be kept
986
- vi.stubEnv('GEMINI_CLI_TEST_VAR', 'test-value'); // A test var that should be kept
987
- vi.resetModules();
988
- const { ShellExecutionService } = await import('./shellExecutionService.js');
989
- // Test pty path
990
- await ShellExecutionService.execute('test-pty-command', '/', vi.fn(), new AbortController().signal, true, shellExecutionConfig);
991
- const ptyEnv = mockPtySpawn.mock.calls[0][2].env;
992
- expect(ptyEnv).not.toHaveProperty('MY_SENSITIVE_VAR');
993
- expect(ptyEnv).toHaveProperty('PATH', '/test/path');
994
- expect(ptyEnv).toHaveProperty('GEMINI_CLI_TEST_VAR', 'test-value');
995
- // Ensure pty process exits for next test
996
- mockPtyProcess.onExit.mock.calls[0][0]({ exitCode: 0, signal: null });
997
- await new Promise(process.nextTick);
998
- // Test child_process path
999
- mockGetPty.mockResolvedValue(null); // Force fallback
1000
- await ShellExecutionService.execute('test-cp-command', '/', vi.fn(), new AbortController().signal, true, {
1001
- sanitizationConfig: {
1002
- enableEnvironmentVariableRedaction: false,
1003
- allowedEnvironmentVariables: [],
1004
- blockedEnvironmentVariables: [],
1005
- },
1006
- });
1007
- const cpEnv = mockCpSpawn.mock.calls[0][2].env;
1008
- expect(cpEnv).not.toHaveProperty('MY_SENSITIVE_VAR');
1009
- expect(cpEnv).toHaveProperty('PATH', '/test/path');
1010
- expect(cpEnv).toHaveProperty('GEMINI_CLI_TEST_VAR', 'test-value');
1011
- // Ensure child_process exits
1012
- mockChildProcess.emit('exit', 0, null);
1013
- mockChildProcess.emit('close', 0, null);
1014
- await new Promise(process.nextTick);
1015
- });
1016
- it('should use a sanitized environment when in a GitHub run (SURFACE=Github)', async () => {
1017
- // Mock the environment to simulate a GitHub Actions run via SURFACE variable
1018
- vi.stubEnv('SURFACE', 'Github');
1019
- vi.stubEnv('MY_SENSITIVE_VAR', 'secret-value'); // This should be stripped out
1020
- vi.stubEnv('PATH', '/test/path'); // An essential var that should be kept
1021
- vi.stubEnv('GEMINI_CLI_TEST_VAR', 'test-value'); // A test var that should be kept
1022
- vi.resetModules();
1023
- const { ShellExecutionService } = await import('./shellExecutionService.js');
1024
- // Test pty path
1025
- await ShellExecutionService.execute('test-pty-command-surface', '/', vi.fn(), new AbortController().signal, true, shellExecutionConfig);
1026
- const ptyEnv = mockPtySpawn.mock.calls[0][2].env;
1027
- expect(ptyEnv).not.toHaveProperty('MY_SENSITIVE_VAR');
1028
- expect(ptyEnv).toHaveProperty('PATH', '/test/path');
1029
- expect(ptyEnv).toHaveProperty('GEMINI_CLI_TEST_VAR', 'test-value');
1030
- // Ensure pty process exits for next test
1031
- mockPtyProcess.onExit.mock.calls[0][0]({ exitCode: 0, signal: null });
1032
- await new Promise(process.nextTick);
1033
- // Test child_process path
1034
- mockGetPty.mockResolvedValue(null); // Force fallback
1035
- await ShellExecutionService.execute('test-cp-command-surface', '/', vi.fn(), new AbortController().signal, true, {
1036
- sanitizationConfig: {
1037
- enableEnvironmentVariableRedaction: false,
1038
- allowedEnvironmentVariables: [],
1039
- blockedEnvironmentVariables: [],
1040
- },
1041
- });
1042
- const cpEnv = mockCpSpawn.mock.calls[0][2].env;
1043
- expect(cpEnv).not.toHaveProperty('MY_SENSITIVE_VAR');
1044
- expect(cpEnv).toHaveProperty('PATH', '/test/path');
1045
- expect(cpEnv).toHaveProperty('GEMINI_CLI_TEST_VAR', 'test-value');
1046
- // Ensure child_process exits
1047
- mockChildProcess.emit('exit', 0, null);
1048
- mockChildProcess.emit('close', 0, null);
1049
- await new Promise(process.nextTick);
1050
- });
1051
- it('should include the full process.env when not in a GitHub run', async () => {
1052
- vi.stubEnv('MY_TEST_VAR', 'test-value');
1053
- vi.stubEnv('GITHUB_SHA', '');
1054
- vi.stubEnv('SURFACE', '');
1055
- vi.resetModules();
1056
- const { ShellExecutionService } = await import('./shellExecutionService.js');
1057
- // Test pty path
1058
- await ShellExecutionService.execute('test-pty-command-no-github', '/', vi.fn(), new AbortController().signal, true, shellExecutionConfig);
1059
- expect(mockPtySpawn).toHaveBeenCalled();
1060
- const ptyEnv = mockPtySpawn.mock.calls[0][2].env;
1061
- expect(ptyEnv).toHaveProperty('MY_TEST_VAR', 'test-value');
1062
- expect(ptyEnv).toHaveProperty('GEMINI_CLI', '1');
1063
- // Ensure pty process exits
1064
- mockPtyProcess.onExit.mock.calls[0][0]({ exitCode: 0, signal: null });
1065
- await new Promise(process.nextTick);
1066
- // Test child_process path (forcing fallback by making pty unavailable)
1067
- mockGetPty.mockResolvedValue(null);
1068
- await ShellExecutionService.execute('test-cp-command-no-github', '/', vi.fn(), new AbortController().signal, true, // Still tries pty, but it will fall back
1069
- shellExecutionConfig);
1070
- expect(mockCpSpawn).toHaveBeenCalled();
1071
- const cpEnv = mockCpSpawn.mock.calls[0][2].env;
1072
- expect(cpEnv).toHaveProperty('MY_TEST_VAR', 'test-value');
1073
- expect(cpEnv).toHaveProperty('GEMINI_CLI', '1');
1074
- // Ensure child_process exits
1075
- mockChildProcess.emit('exit', 0, null);
1076
- mockChildProcess.emit('close', 0, null);
1077
- await new Promise(process.nextTick);
1078
- });
1079
- });
1080
- //# sourceMappingURL=shellExecutionService.test.js.map