@didim365/agent-cli-core 0.1.1 → 0.1.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (1081) hide show
  1. package/dist/src/core/apiKeyCredentialStorage.d.ts +23 -3
  2. package/dist/src/core/apiKeyCredentialStorage.js +56 -16
  3. package/dist/src/core/apiKeyCredentialStorage.js.map +1 -1
  4. package/dist/src/generated/git-commit.d.ts +1 -1
  5. package/dist/src/generated/git-commit.js +1 -1
  6. package/package.json +6 -2
  7. package/dist/docs/00_project/ai_adapter/01-overview.md +0 -172
  8. package/dist/docs/00_project/ai_adapter/02-architecture.md +0 -448
  9. package/dist/docs/00_project/ai_adapter/03-technical-design.md +0 -1470
  10. package/dist/docs/00_project/ai_adapter/04-integration-design.md +0 -1934
  11. package/dist/docs/00_project/ai_adapter/05-implementation-plan.md +0 -336
  12. package/dist/docs/00_project/ai_adapter/06-didiaistudio-plan.md +0 -559
  13. package/dist/docs/00_project/ai_adapter/README.md +0 -145
  14. package/dist/docs/00_project/ai_adapter/agent_service_openapi.json +0 -1
  15. package/dist/docs/00_project/ai_adapter/didimStudi-AISTUDIO /341/204/213/341/205/254/341/204/207/341/205/256 /341/204/211/341/205/245/341/204/207/341/205/265/341/204/211/341/205/263 /341/204/221/341/205/263/341/206/257/341/204/205/341/205/251/341/204/213/341/205/256 /341/204/213/341/205/247/341/206/253/341/204/200/341/205/247/341/206/257 /341/204/207/341/205/241/341/206/274/341/204/211/341/205/265/341/206/250-100226-093925.pdf +0 -0
  16. package/dist/docs/00_project/ai_adapter/event-mapping-matrix.md +0 -148
  17. package/dist/docs/00_project/ai_adapter/migration-plan.md +0 -205
  18. package/dist/docs/00_project/ai_adapter/template/00_vibecoding_workflow.md +0 -627
  19. package/dist/docs/00_project/ai_adapter/template/01_todolist_performance_template.md +0 -436
  20. package/dist/docs/00_project/ai_adapter/template/02_code_review_template.md +0 -248
  21. package/dist/docs/00_project/ai_adapter/template/03_work_result_report_template.md +0 -133
  22. package/dist/docs/00_project/ai_adapter/template/100_Python_Performance_Guide.md +0 -472
  23. package/dist/docs/00_project/ai_adapter/template/99_TDD_plan.md +0 -123
  24. package/dist/docs/00_project/ai_adapter/todolist/00_master_implementation_plan.md +0 -433
  25. package/dist/docs/00_project/ai_adapter/todolist/phase1_foundation_todolist.md +0 -726
  26. package/dist/docs/00_project/ai_adapter/todolist/phase2_core_refactoring_todolist.md +0 -974
  27. package/dist/docs/00_project/ai_adapter/todolist/phase3_handoff.md +0 -203
  28. package/dist/docs/00_project/ai_adapter/todolist/phase3_provider_extension_todolist.md +0 -1382
  29. package/dist/docs/00_project/ai_adapter/utility-migration.md +0 -237
  30. package/dist/docs/00_project/ai_adapter/working_history/.gitkeep +0 -0
  31. package/dist/docs/00_project/ai_adapter/working_history/Phase1_M1.0_/354/275/224/353/223/234/354/235/270/353/262/244/355/206/240/353/246/254_20260201.md +0 -197
  32. package/dist/docs/00_project/ai_adapter/working_history/Phase1_M1.1_/355/203/200/354/236/205/354/204/244/352/263/204_20260201.md +0 -185
  33. package/dist/docs/00_project/ai_adapter/working_history/Phase1_M1.2_Adapter/354/235/270/355/224/204/353/235/274_20260203.md +0 -378
  34. package/dist/docs/00_project/ai_adapter/working_history/Phase1_M1.3_Provider/354/204/240/355/203/235_20260206.md +0 -269
  35. package/dist/docs/00_project/ai_adapter/working_history/Phase1_M1.4_/354/234/240/355/213/270/353/246/254/355/213/260/353/247/210/354/235/264/352/267/270/353/240/210/354/235/264/354/205/230_20260206.md +0 -86
  36. package/dist/docs/00_project/ai_adapter/working_history/Phase2_ETC_/354/227/260/352/270/260/354/236/221/354/227/205/354/240/225/353/246/254_20260208.md +0 -157
  37. package/dist/docs/00_project/ai_adapter/working_history/Phase2_M2.0_/353/224/224/353/240/211/355/206/240/353/246/254/354/236/254/352/265/254/354/204/261_20260207.md +0 -107
  38. package/dist/docs/00_project/ai_adapter/working_history/Phase2_M2.1_ContentGenerator/354/235/270/355/204/260/355/216/230/354/235/264/354/212/244/354/236/254/354/240/225/354/235/230_20260207.md +0 -630
  39. package/dist/docs/00_project/ai_adapter/working_history/Phase2_M2.2_EventMapper/352/265/254/355/230/204_20260207.md +0 -372
  40. package/dist/docs/00_project/ai_adapter/working_history/Phase2_M2.3_GeminiAdapter/352/265/254/355/230/204_20260208.md +0 -205
  41. package/dist/docs/00_project/ai_adapter/working_history/Phase2_M2.4_ModelConfigService/355/230/270/355/231/230/353/240/210/354/235/264/354/226/264_20260208.md +0 -275
  42. package/dist/docs/00_project/ai_adapter/working_history/Phase2_M2.5_/354/234/240/355/213/270/353/246/254/355/213/260/353/240/210/354/235/264/354/226/264/353/246/254/355/214/251/355/206/240/353/247/201_20260208.md +0 -239
  43. package/dist/docs/00_project/ai_adapter/working_history/Phase2_M2.6_/353/235/274/354/232/260/355/214/205/353/240/210/354/235/264/354/226/264/355/203/200/354/236/205/353/217/205/353/246/275/355/231/224_20260208.md +0 -228
  44. package/dist/docs/00_project/ai_adapter/working_history/Phase3_ETC_/352/270/260/353/263/270/354/273/250/355/205/215/354/212/244/355/212/270/355/214/214/354/235/274/353/252/205AGENTS/354/240/204/355/231/230_20260211.md +0 -470
  45. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.0.1_Gemini/354/240/204/354/232/251/355/214/214/354/235/274/353/254/274/353/246/254/354/240/201/354/235/264/353/217/231_20260209.md +0 -271
  46. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.0.2_messageInspectors/353/247/210/354/235/264/352/267/270/353/240/210/354/235/264/354/205/230_20260209.md +0 -330
  47. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.0.3_/355/205/224/353/240/210/353/251/224/355/212/270/353/246/254Agent/353/217/205/353/246/275/355/231/224_20260209.md +0 -251
  48. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.0.4_/353/263/200/355/231/230/353/270/214/353/246/277/354/247/200/354/240/225/353/246/254_20260209.md +0 -136
  49. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.0.5_/353/237/260/355/203/200/354/236/204/354/213/244/355/226/211/352/262/275/353/241/234/354/227/260/352/262/260_20260209.md +0 -232
  50. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.1.0_Claude/354/202/254/354/240/204/354/244/200/353/271/204_20260209.md +0 -191
  51. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.1.1_ClaudeAdapter/352/265/254/355/230/204_20260209.md +0 -225
  52. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.1.2_ClaudeConverter/352/263/240/353/217/204/355/231/224_20260209.md +0 -171
  53. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.1.3_ClaudeStreamError/352/263/240/353/217/204/355/231/224_20260209.md +0 -198
  54. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.1.4_ClaudeErrorMapping_20260209.md +0 -98
  55. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.2.A_OpenAIAdapterCore_20260210.md +0 -264
  56. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.2.B_OpenAIStreamConverter_20260210.md +0 -204
  57. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.3.2_/353/252/250/353/215/270/355/205/234/355/224/214/353/246/277/355/233/205/353/263/264/354/231/204_20260211.md +0 -106
  58. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.3_OpenAICompatibleAdapter_20260211.md +0 -251
  59. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.4.2_E2E/355/205/214/354/212/244/355/212/270/354/213/234/353/202/230/353/246/254/354/230/244_20260210.md +0 -264
  60. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.4.3_/354/204/261/353/212/245/355/232/214/352/267/200/355/205/214/354/212/244/355/212/270_20260211.md +0 -176
  61. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.4.5_/354/225/210/354/240/225/355/231/224/354/236/221/354/227/205_20260211.md +0 -204
  62. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.4.A_CLI/355/206/265/355/225/251_3Provider/355/206/265/355/225/251/355/205/214/354/212/244/355/212/270_20260210.md +0 -316
  63. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.4.A_UI/354/203/201/355/203/234/353/260/224/354/210/230/354/240/225_20260210.md +0 -262
  64. package/dist/docs/00_project/ai_adapter/working_history/phase2_tradeoff_EventType/354/240/204/355/231/230_20260208.md +0 -286
  65. package/dist/docs/00_project/white_labeling/template/00_vibecoding_workflow.md +0 -627
  66. package/dist/docs/00_project/white_labeling/template/01_todolist_performance_template.md +0 -400
  67. package/dist/docs/00_project/white_labeling/template/02_code_review_template.md +0 -248
  68. package/dist/docs/00_project/white_labeling/template/03_work_result_report_template.md +0 -133
  69. package/dist/docs/00_project/white_labeling/template/100_Python_Performance_Guide.md +0 -472
  70. package/dist/docs/00_project/white_labeling/template/99_TDD_plan.md +0 -123
  71. package/dist/docs/00_project/white_labeling/todolist/Phase_CLI/355/214/250/355/202/244/354/247/200/353/252/205/353/263/200/352/262/275_todolist.md +0 -431
  72. package/dist/docs/00_project/white_labeling/working_history/Phase_CLI/355/214/250/355/202/244/354/247/200/353/252/205/353/263/200/352/262/275_20260214.md +0 -238
  73. package/dist/docs/00_project/white_labeling//354/225/261/352/265/254/354/241/260.md +0 -310
  74. package/dist/docs/CONTRIBUTING.md +0 -554
  75. package/dist/docs/ai_adapter/01-overview.md +0 -155
  76. package/dist/docs/ai_adapter/02-architecture.md +0 -452
  77. package/dist/docs/ai_adapter/03-technical-design.md +0 -1470
  78. package/dist/docs/ai_adapter/04-integration-design.md +0 -1904
  79. package/dist/docs/ai_adapter/05-implementation-plan.md +0 -312
  80. package/dist/docs/ai_adapter/06-didiaistudio-plan.md +0 -559
  81. package/dist/docs/ai_adapter/README.md +0 -118
  82. package/dist/docs/ai_adapter/agent_service_openapi.json +0 -1
  83. package/dist/docs/ai_adapter/didimStudi-AISTUDIO /341/204/213/341/205/254/341/204/207/341/205/256 /341/204/211/341/205/245/341/204/207/341/205/265/341/204/211/341/205/263 /341/204/221/341/205/263/341/206/257/341/204/205/341/205/251/341/204/213/341/205/256 /341/204/213/341/205/247/341/206/253/341/204/200/341/205/247/341/206/257 /341/204/207/341/205/241/341/206/274/341/204/211/341/205/265/341/206/250-100226-093925.pdf +0 -0
  84. package/dist/docs/ai_adapter/event-mapping-matrix.md +0 -140
  85. package/dist/docs/ai_adapter/migration-plan.md +0 -205
  86. package/dist/docs/ai_adapter/template/00_vibecoding_workflow.md +0 -636
  87. package/dist/docs/ai_adapter/template/01_todolist_performance_template.md +0 -372
  88. package/dist/docs/ai_adapter/template/02_code_review_template.md +0 -220
  89. package/dist/docs/ai_adapter/template/03_work_result_report_template.md +0 -120
  90. package/dist/docs/ai_adapter/template/100_Python_Performance_Guide.md +0 -453
  91. package/dist/docs/ai_adapter/template/99_TDD_plan.md +0 -111
  92. package/dist/docs/ai_adapter/todolist/00_master_implementation_plan.md +0 -433
  93. package/dist/docs/ai_adapter/todolist/phase1_foundation_todolist.md +0 -726
  94. package/dist/docs/ai_adapter/todolist/phase2_core_refactoring_todolist.md +0 -974
  95. package/dist/docs/ai_adapter/todolist/phase3_handoff.md +0 -203
  96. package/dist/docs/ai_adapter/todolist/phase3_provider_extension_todolist.md +0 -1382
  97. package/dist/docs/ai_adapter/utility-migration.md +0 -237
  98. package/dist/docs/ai_adapter/working_history/.gitkeep +0 -0
  99. package/dist/docs/ai_adapter/working_history/Phase1_M1.0_/354/275/224/353/223/234/354/235/270/353/262/244/355/206/240/353/246/254_20260201.md +0 -185
  100. package/dist/docs/ai_adapter/working_history/Phase1_M1.1_/355/203/200/354/236/205/354/204/244/352/263/204_20260201.md +0 -185
  101. package/dist/docs/ai_adapter/working_history/Phase1_M1.2_Adapter/354/235/270/355/224/204/353/235/274_20260203.md +0 -378
  102. package/dist/docs/ai_adapter/working_history/Phase1_M1.3_Provider/354/204/240/355/203/235_20260206.md +0 -269
  103. package/dist/docs/ai_adapter/working_history/Phase1_M1.4_/354/234/240/355/213/270/353/246/254/355/213/260/353/247/210/354/235/264/352/267/270/353/240/210/354/235/264/354/205/230_20260206.md +0 -86
  104. package/dist/docs/ai_adapter/working_history/Phase2_ETC_/354/227/260/352/270/260/354/236/221/354/227/205/354/240/225/353/246/254_20260208.md +0 -157
  105. package/dist/docs/ai_adapter/working_history/Phase2_M2.0_/353/224/224/353/240/211/355/206/240/353/246/254/354/236/254/352/265/254/354/204/261_20260207.md +0 -107
  106. package/dist/docs/ai_adapter/working_history/Phase2_M2.1_ContentGenerator/354/235/270/355/204/260/355/216/230/354/235/264/354/212/244/354/236/254/354/240/225/354/235/230_20260207.md +0 -630
  107. package/dist/docs/ai_adapter/working_history/Phase2_M2.2_EventMapper/352/265/254/355/230/204_20260207.md +0 -372
  108. package/dist/docs/ai_adapter/working_history/Phase2_M2.3_GeminiAdapter/352/265/254/355/230/204_20260208.md +0 -205
  109. package/dist/docs/ai_adapter/working_history/Phase2_M2.4_ModelConfigService/355/230/270/355/231/230/353/240/210/354/235/264/354/226/264_20260208.md +0 -275
  110. package/dist/docs/ai_adapter/working_history/Phase2_M2.5_/354/234/240/355/213/270/353/246/254/355/213/260/353/240/210/354/235/264/354/226/264/353/246/254/355/214/251/355/206/240/353/247/201_20260208.md +0 -239
  111. package/dist/docs/ai_adapter/working_history/Phase2_M2.6_/353/235/274/354/232/260/355/214/205/353/240/210/354/235/264/354/226/264/355/203/200/354/236/205/353/217/205/353/246/275/355/231/224_20260208.md +0 -228
  112. package/dist/docs/ai_adapter/working_history/Phase3_ETC_/352/270/260/353/263/270/354/273/250/355/205/215/354/212/244/355/212/270/355/214/214/354/235/274/353/252/205AGENTS/354/240/204/355/231/230_20260211.md +0 -367
  113. package/dist/docs/ai_adapter/working_history/Phase3_M3.0.1_Gemini/354/240/204/354/232/251/355/214/214/354/235/274/353/254/274/353/246/254/354/240/201/354/235/264/353/217/231_20260209.md +0 -271
  114. package/dist/docs/ai_adapter/working_history/Phase3_M3.0.2_messageInspectors/353/247/210/354/235/264/352/267/270/353/240/210/354/235/264/354/205/230_20260209.md +0 -330
  115. package/dist/docs/ai_adapter/working_history/Phase3_M3.0.3_/355/205/224/353/240/210/353/251/224/355/212/270/353/246/254Agent/353/217/205/353/246/275/355/231/224_20260209.md +0 -251
  116. package/dist/docs/ai_adapter/working_history/Phase3_M3.0.4_/353/263/200/355/231/230/353/270/214/353/246/277/354/247/200/354/240/225/353/246/254_20260209.md +0 -136
  117. package/dist/docs/ai_adapter/working_history/Phase3_M3.0.5_/353/237/260/355/203/200/354/236/204/354/213/244/355/226/211/352/262/275/353/241/234/354/227/260/352/262/260_20260209.md +0 -232
  118. package/dist/docs/ai_adapter/working_history/Phase3_M3.1.0_Claude/354/202/254/354/240/204/354/244/200/353/271/204_20260209.md +0 -191
  119. package/dist/docs/ai_adapter/working_history/Phase3_M3.1.1_ClaudeAdapter/352/265/254/355/230/204_20260209.md +0 -225
  120. package/dist/docs/ai_adapter/working_history/Phase3_M3.1.2_ClaudeConverter/352/263/240/353/217/204/355/231/224_20260209.md +0 -171
  121. package/dist/docs/ai_adapter/working_history/Phase3_M3.1.3_ClaudeStreamError/352/263/240/353/217/204/355/231/224_20260209.md +0 -198
  122. package/dist/docs/ai_adapter/working_history/Phase3_M3.1.4_ClaudeErrorMapping_20260209.md +0 -98
  123. package/dist/docs/ai_adapter/working_history/Phase3_M3.2.A_OpenAIAdapterCore_20260210.md +0 -264
  124. package/dist/docs/ai_adapter/working_history/Phase3_M3.2.B_OpenAIStreamConverter_20260210.md +0 -204
  125. package/dist/docs/ai_adapter/working_history/Phase3_M3.3.2_/353/252/250/353/215/270/355/205/234/355/224/214/353/246/277/355/233/205/353/263/264/354/231/204_20260211.md +0 -106
  126. package/dist/docs/ai_adapter/working_history/Phase3_M3.3_OpenAICompatibleAdapter_20260211.md +0 -251
  127. package/dist/docs/ai_adapter/working_history/Phase3_M3.4.2_E2E/355/205/214/354/212/244/355/212/270/354/213/234/353/202/230/353/246/254/354/230/244_20260210.md +0 -264
  128. package/dist/docs/ai_adapter/working_history/Phase3_M3.4.3_/354/204/261/353/212/245/355/232/214/352/267/200/355/205/214/354/212/244/355/212/270_20260211.md +0 -176
  129. package/dist/docs/ai_adapter/working_history/Phase3_M3.4.5_/354/225/210/354/240/225/355/231/224/354/236/221/354/227/205_20260211.md +0 -204
  130. package/dist/docs/ai_adapter/working_history/Phase3_M3.4.A_CLI/355/206/265/355/225/251_3Provider/355/206/265/355/225/251/355/205/214/354/212/244/355/212/270_20260210.md +0 -316
  131. package/dist/docs/ai_adapter/working_history/Phase3_M3.4.A_UI/354/203/201/355/203/234/353/260/224/354/210/230/354/240/225_20260210.md +0 -262
  132. package/dist/docs/ai_adapter/working_history/phase2_tradeoff_EventType/354/240/204/355/231/230_20260208.md +0 -286
  133. package/dist/docs/api/index.md +0 -5
  134. package/dist/docs/api/providers.md +0 -56
  135. package/dist/docs/architecture.md +0 -80
  136. package/dist/docs/assets/connected_devtools.png +0 -0
  137. package/dist/docs/assets/gemini-screenshot.png +0 -0
  138. package/dist/docs/assets/monitoring-dashboard-logs.png +0 -0
  139. package/dist/docs/assets/monitoring-dashboard-metrics.png +0 -0
  140. package/dist/docs/assets/monitoring-dashboard-overview.png +0 -0
  141. package/dist/docs/assets/release_patch.png +0 -0
  142. package/dist/docs/assets/theme-ansi-light.png +0 -0
  143. package/dist/docs/assets/theme-ansi.png +0 -0
  144. package/dist/docs/assets/theme-atom-one.png +0 -0
  145. package/dist/docs/assets/theme-ayu-light.png +0 -0
  146. package/dist/docs/assets/theme-ayu.png +0 -0
  147. package/dist/docs/assets/theme-custom.png +0 -0
  148. package/dist/docs/assets/theme-default-light.png +0 -0
  149. package/dist/docs/assets/theme-default.png +0 -0
  150. package/dist/docs/assets/theme-dracula.png +0 -0
  151. package/dist/docs/assets/theme-github-light.png +0 -0
  152. package/dist/docs/assets/theme-github.png +0 -0
  153. package/dist/docs/assets/theme-google-light.png +0 -0
  154. package/dist/docs/assets/theme-xcode-light.png +0 -0
  155. package/dist/docs/change_model/model_command_multi_provider_plan.md +0 -221
  156. package/dist/docs/change_model/model_command_multi_provider_todolist.md +0 -206
  157. package/dist/docs/changelogs/index.md +0 -726
  158. package/dist/docs/changelogs/latest.md +0 -370
  159. package/dist/docs/changelogs/preview.md +0 -332
  160. package/dist/docs/cli/authentication.md +0 -3
  161. package/dist/docs/cli/checkpointing.md +0 -94
  162. package/dist/docs/cli/commands.md +0 -375
  163. package/dist/docs/cli/custom-commands.md +0 -315
  164. package/dist/docs/cli/enterprise.md +0 -565
  165. package/dist/docs/cli/gemini-ignore.md +0 -71
  166. package/dist/docs/cli/gemini-md.md +0 -108
  167. package/dist/docs/cli/generation-settings.md +0 -210
  168. package/dist/docs/cli/headless.md +0 -388
  169. package/dist/docs/cli/index.md +0 -65
  170. package/dist/docs/cli/keyboard-shortcuts.md +0 -129
  171. package/dist/docs/cli/model-routing.md +0 -42
  172. package/dist/docs/cli/model.md +0 -62
  173. package/dist/docs/cli/sandbox.md +0 -171
  174. package/dist/docs/cli/session-management.md +0 -158
  175. package/dist/docs/cli/settings.md +0 -130
  176. package/dist/docs/cli/skills.md +0 -188
  177. package/dist/docs/cli/system-prompt.md +0 -125
  178. package/dist/docs/cli/telemetry.md +0 -826
  179. package/dist/docs/cli/themes.md +0 -235
  180. package/dist/docs/cli/token-caching.md +0 -20
  181. package/dist/docs/cli/trusted-folders.md +0 -95
  182. package/dist/docs/cli/tutorials/skills-getting-started.md +0 -124
  183. package/dist/docs/cli/tutorials.md +0 -87
  184. package/dist/docs/cli/uninstall.md +0 -65
  185. package/dist/docs/configuration.md +0 -108
  186. package/dist/docs/core/index.md +0 -105
  187. package/dist/docs/core/long-term-memory-design.md +0 -254
  188. package/dist/docs/core/long-term-memory-proposal.md +0 -112
  189. package/dist/docs/core/memport.md +0 -246
  190. package/dist/docs/core/policy-engine.md +0 -300
  191. package/dist/docs/core/tools-api.md +0 -131
  192. package/dist/docs/examples/proxy-script.md +0 -83
  193. package/dist/docs/extensions/best-practices.md +0 -139
  194. package/dist/docs/extensions/index.md +0 -44
  195. package/dist/docs/extensions/reference.md +0 -312
  196. package/dist/docs/extensions/releasing.md +0 -183
  197. package/dist/docs/extensions/writing-extensions.md +0 -283
  198. package/dist/docs/faq.md +0 -154
  199. package/dist/docs/get-started/authentication.md +0 -321
  200. package/dist/docs/get-started/configuration-v1.md +0 -888
  201. package/dist/docs/get-started/configuration.md +0 -1567
  202. package/dist/docs/get-started/examples.md +0 -219
  203. package/dist/docs/get-started/gemini-3.md +0 -101
  204. package/dist/docs/get-started/index.md +0 -71
  205. package/dist/docs/get-started/installation.md +0 -141
  206. package/dist/docs/hooks/best-practices.md +0 -677
  207. package/dist/docs/hooks/index.md +0 -178
  208. package/dist/docs/hooks/reference.md +0 -322
  209. package/dist/docs/hooks/writing-hooks.md +0 -450
  210. package/dist/docs/ide-integration/ide-companion-spec.md +0 -267
  211. package/dist/docs/ide-integration/index.md +0 -202
  212. package/dist/docs/index.md +0 -153
  213. package/dist/docs/integration-tests.md +0 -211
  214. package/dist/docs/issue-and-pr-automation.md +0 -134
  215. package/dist/docs/local-development.md +0 -128
  216. package/dist/docs/mermaid/context.mmd +0 -103
  217. package/dist/docs/mermaid/render-path.mmd +0 -64
  218. package/dist/docs/migration.md +0 -78
  219. package/dist/docs/npm.md +0 -62
  220. package/dist/docs/providers.md +0 -136
  221. package/dist/docs/quota-and-pricing.md +0 -158
  222. package/dist/docs/release-confidence.md +0 -164
  223. package/dist/docs/releases.md +0 -539
  224. package/dist/docs/sidebar.json +0 -140
  225. package/dist/docs/tools/file-system.md +0 -217
  226. package/dist/docs/tools/index.md +0 -98
  227. package/dist/docs/tools/mcp-server.md +0 -1068
  228. package/dist/docs/tools/memory.md +0 -54
  229. package/dist/docs/tools/shell.md +0 -260
  230. package/dist/docs/tools/todos.md +0 -57
  231. package/dist/docs/tools/web-fetch.md +0 -59
  232. package/dist/docs/tools/web-search.md +0 -42
  233. package/dist/docs/tos-privacy.md +0 -96
  234. package/dist/docs/troubleshooting.md +0 -173
  235. package/dist/src/agents/a2a-client-manager.test.d.ts +0 -6
  236. package/dist/src/agents/a2a-client-manager.test.js +0 -220
  237. package/dist/src/agents/a2a-client-manager.test.js.map +0 -1
  238. package/dist/src/agents/a2aUtils.test.d.ts +0 -6
  239. package/dist/src/agents/a2aUtils.test.js +0 -147
  240. package/dist/src/agents/a2aUtils.test.js.map +0 -1
  241. package/dist/src/agents/acknowledgedAgents.test.d.ts +0 -6
  242. package/dist/src/agents/acknowledgedAgents.test.js +0 -70
  243. package/dist/src/agents/acknowledgedAgents.test.js.map +0 -1
  244. package/dist/src/agents/agent-scheduler.test.d.ts +0 -6
  245. package/dist/src/agents/agent-scheduler.test.js +0 -56
  246. package/dist/src/agents/agent-scheduler.test.js.map +0 -1
  247. package/dist/src/agents/agentLoader.test.d.ts +0 -6
  248. package/dist/src/agents/agentLoader.test.js +0 -304
  249. package/dist/src/agents/agentLoader.test.js.map +0 -1
  250. package/dist/src/agents/cli-help-agent.test.d.ts +0 -6
  251. package/dist/src/agents/cli-help-agent.test.js +0 -67
  252. package/dist/src/agents/cli-help-agent.test.js.map +0 -1
  253. package/dist/src/agents/codebase-investigator.test.d.ts +0 -6
  254. package/dist/src/agents/codebase-investigator.test.js +0 -42
  255. package/dist/src/agents/codebase-investigator.test.js.map +0 -1
  256. package/dist/src/agents/generalist-agent.test.d.ts +0 -6
  257. package/dist/src/agents/generalist-agent.test.js +0 -31
  258. package/dist/src/agents/generalist-agent.test.js.map +0 -1
  259. package/dist/src/agents/local-executor.test.d.ts +0 -6
  260. package/dist/src/agents/local-executor.test.js +0 -1577
  261. package/dist/src/agents/local-executor.test.js.map +0 -1
  262. package/dist/src/agents/local-invocation.test.d.ts +0 -6
  263. package/dist/src/agents/local-invocation.test.js +0 -228
  264. package/dist/src/agents/local-invocation.test.js.map +0 -1
  265. package/dist/src/agents/registry.test.d.ts +0 -6
  266. package/dist/src/agents/registry.test.js +0 -773
  267. package/dist/src/agents/registry.test.js.map +0 -1
  268. package/dist/src/agents/registry_acknowledgement.test.d.ts +0 -6
  269. package/dist/src/agents/registry_acknowledgement.test.js +0 -130
  270. package/dist/src/agents/registry_acknowledgement.test.js.map +0 -1
  271. package/dist/src/agents/remote-invocation.test.d.ts +0 -6
  272. package/dist/src/agents/remote-invocation.test.js +0 -213
  273. package/dist/src/agents/remote-invocation.test.js.map +0 -1
  274. package/dist/src/agents/subagent-tool-wrapper.test.d.ts +0 -6
  275. package/dist/src/agents/subagent-tool-wrapper.test.js +0 -109
  276. package/dist/src/agents/subagent-tool-wrapper.test.js.map +0 -1
  277. package/dist/src/agents/utils.test.d.ts +0 -6
  278. package/dist/src/agents/utils.test.js +0 -87
  279. package/dist/src/agents/utils.test.js.map +0 -1
  280. package/dist/src/availability/fallbackIntegration.test.d.ts +0 -6
  281. package/dist/src/availability/fallbackIntegration.test.js +0 -58
  282. package/dist/src/availability/fallbackIntegration.test.js.map +0 -1
  283. package/dist/src/availability/modelAvailabilityService.test.d.ts +0 -6
  284. package/dist/src/availability/modelAvailabilityService.test.js +0 -140
  285. package/dist/src/availability/modelAvailabilityService.test.js.map +0 -1
  286. package/dist/src/availability/policyCatalog.test.d.ts +0 -6
  287. package/dist/src/availability/policyCatalog.test.js +0 -70
  288. package/dist/src/availability/policyCatalog.test.js.map +0 -1
  289. package/dist/src/availability/policyHelpers.test.d.ts +0 -6
  290. package/dist/src/availability/policyHelpers.test.js +0 -220
  291. package/dist/src/availability/policyHelpers.test.js.map +0 -1
  292. package/dist/src/code_assist/admin/admin_controls.test.d.ts +0 -6
  293. package/dist/src/code_assist/admin/admin_controls.test.js +0 -200
  294. package/dist/src/code_assist/admin/admin_controls.test.js.map +0 -1
  295. package/dist/src/code_assist/codeAssist.test.d.ts +0 -6
  296. package/dist/src/code_assist/codeAssist.test.js +0 -102
  297. package/dist/src/code_assist/codeAssist.test.js.map +0 -1
  298. package/dist/src/code_assist/converter.test.d.ts +0 -6
  299. package/dist/src/code_assist/converter.test.js +0 -391
  300. package/dist/src/code_assist/converter.test.js.map +0 -1
  301. package/dist/src/code_assist/experiments/client_metadata.test.d.ts +0 -6
  302. package/dist/src/code_assist/experiments/client_metadata.test.js +0 -96
  303. package/dist/src/code_assist/experiments/client_metadata.test.js.map +0 -1
  304. package/dist/src/code_assist/experiments/experiments.test.d.ts +0 -6
  305. package/dist/src/code_assist/experiments/experiments.test.js +0 -93
  306. package/dist/src/code_assist/experiments/experiments.test.js.map +0 -1
  307. package/dist/src/code_assist/experiments/experiments_local.test.d.ts +0 -6
  308. package/dist/src/code_assist/experiments/experiments_local.test.js +0 -115
  309. package/dist/src/code_assist/experiments/experiments_local.test.js.map +0 -1
  310. package/dist/src/code_assist/oauth-credential-storage.test.d.ts +0 -6
  311. package/dist/src/code_assist/oauth-credential-storage.test.js +0 -198
  312. package/dist/src/code_assist/oauth-credential-storage.test.js.map +0 -1
  313. package/dist/src/code_assist/oauth2.test.d.ts +0 -6
  314. package/dist/src/code_assist/oauth2.test.js +0 -1065
  315. package/dist/src/code_assist/oauth2.test.js.map +0 -1
  316. package/dist/src/code_assist/server.test.d.ts +0 -6
  317. package/dist/src/code_assist/server.test.js +0 -453
  318. package/dist/src/code_assist/server.test.js.map +0 -1
  319. package/dist/src/code_assist/setup.test.d.ts +0 -6
  320. package/dist/src/code_assist/setup.test.js +0 -517
  321. package/dist/src/code_assist/setup.test.js.map +0 -1
  322. package/dist/src/code_assist/telemetry.test.d.ts +0 -6
  323. package/dist/src/code_assist/telemetry.test.js +0 -301
  324. package/dist/src/code_assist/telemetry.test.js.map +0 -1
  325. package/dist/src/commands/extensions.test.d.ts +0 -6
  326. package/dist/src/commands/extensions.test.js +0 -19
  327. package/dist/src/commands/extensions.test.js.map +0 -1
  328. package/dist/src/commands/init.test.d.ts +0 -6
  329. package/dist/src/commands/init.test.js +0 -25
  330. package/dist/src/commands/init.test.js.map +0 -1
  331. package/dist/src/commands/memory.test.d.ts +0 -6
  332. package/dist/src/commands/memory.test.js +0 -182
  333. package/dist/src/commands/memory.test.js.map +0 -1
  334. package/dist/src/commands/restore.test.d.ts +0 -6
  335. package/dist/src/commands/restore.test.js +0 -137
  336. package/dist/src/commands/restore.test.js.map +0 -1
  337. package/dist/src/config/config.test.d.ts +0 -6
  338. package/dist/src/config/config.test.js +0 -1811
  339. package/dist/src/config/config.test.js.map +0 -1
  340. package/dist/src/config/flashFallback.test.d.ts +0 -6
  341. package/dist/src/config/flashFallback.test.js +0 -63
  342. package/dist/src/config/flashFallback.test.js.map +0 -1
  343. package/dist/src/config/models.test.d.ts +0 -6
  344. package/dist/src/config/models.test.js +0 -146
  345. package/dist/src/config/models.test.js.map +0 -1
  346. package/dist/src/config/storage.test.d.ts +0 -6
  347. package/dist/src/config/storage.test.js +0 -115
  348. package/dist/src/config/storage.test.js.map +0 -1
  349. package/dist/src/confirmation-bus/message-bus.test.d.ts +0 -6
  350. package/dist/src/confirmation-bus/message-bus.test.js +0 -170
  351. package/dist/src/confirmation-bus/message-bus.test.js.map +0 -1
  352. package/dist/src/core/apiKeyCredentialStorage.test.d.ts +0 -6
  353. package/dist/src/core/apiKeyCredentialStorage.test.js +0 -71
  354. package/dist/src/core/apiKeyCredentialStorage.test.js.map +0 -1
  355. package/dist/src/core/baseLlmClient.test.d.ts +0 -6
  356. package/dist/src/core/baseLlmClient.test.js +0 -569
  357. package/dist/src/core/baseLlmClient.test.js.map +0 -1
  358. package/dist/src/core/baseLlmClient_new_types.test.d.ts +0 -1
  359. package/dist/src/core/baseLlmClient_new_types.test.js +0 -387
  360. package/dist/src/core/baseLlmClient_new_types.test.js.map +0 -1
  361. package/dist/src/core/client.test.d.ts +0 -6
  362. package/dist/src/core/client.test.js +0 -2654
  363. package/dist/src/core/client.test.js.map +0 -1
  364. package/dist/src/core/contentGenerator.multiProvider.test.d.ts +0 -6
  365. package/dist/src/core/contentGenerator.multiProvider.test.js +0 -314
  366. package/dist/src/core/contentGenerator.multiProvider.test.js.map +0 -1
  367. package/dist/src/core/contentGenerator.test.d.ts +0 -6
  368. package/dist/src/core/contentGenerator.test.js +0 -299
  369. package/dist/src/core/contentGenerator.test.js.map +0 -1
  370. package/dist/src/core/contentGenerator_new_types.test.d.ts +0 -6
  371. package/dist/src/core/contentGenerator_new_types.test.js +0 -292
  372. package/dist/src/core/contentGenerator_new_types.test.js.map +0 -1
  373. package/dist/src/core/coreToolHookTriggers.test.d.ts +0 -6
  374. package/dist/src/core/coreToolHookTriggers.test.js +0 -159
  375. package/dist/src/core/coreToolHookTriggers.test.js.map +0 -1
  376. package/dist/src/core/coreToolScheduler.test.d.ts +0 -6
  377. package/dist/src/core/coreToolScheduler.test.js +0 -1684
  378. package/dist/src/core/coreToolScheduler.test.js.map +0 -1
  379. package/dist/src/core/fakeContentGenerator.test.d.ts +0 -6
  380. package/dist/src/core/fakeContentGenerator.test.js +0 -127
  381. package/dist/src/core/fakeContentGenerator.test.js.map +0 -1
  382. package/dist/src/core/geminiChat.test.d.ts +0 -6
  383. package/dist/src/core/geminiChat.test.js +0 -1773
  384. package/dist/src/core/geminiChat.test.js.map +0 -1
  385. package/dist/src/core/geminiChat_network_retry.test.d.ts +0 -6
  386. package/dist/src/core/geminiChat_network_retry.test.js +0 -201
  387. package/dist/src/core/geminiChat_network_retry.test.js.map +0 -1
  388. package/dist/src/core/logger.test.d.ts +0 -6
  389. package/dist/src/core/logger.test.js +0 -550
  390. package/dist/src/core/logger.test.js.map +0 -1
  391. package/dist/src/core/loggingContentGenerator.test.d.ts +0 -6
  392. package/dist/src/core/loggingContentGenerator.test.js +0 -221
  393. package/dist/src/core/loggingContentGenerator.test.js.map +0 -1
  394. package/dist/src/core/prompts-substitution.test.d.ts +0 -6
  395. package/dist/src/core/prompts-substitution.test.js +0 -101
  396. package/dist/src/core/prompts-substitution.test.js.map +0 -1
  397. package/dist/src/core/prompts.test.d.ts +0 -6
  398. package/dist/src/core/prompts.test.js +0 -391
  399. package/dist/src/core/prompts.test.js.map +0 -1
  400. package/dist/src/core/recordingContentGenerator.test.d.ts +0 -6
  401. package/dist/src/core/recordingContentGenerator.test.js +0 -101
  402. package/dist/src/core/recordingContentGenerator.test.js.map +0 -1
  403. package/dist/src/core/tokenLimits.test.d.ts +0 -6
  404. package/dist/src/core/tokenLimits.test.js +0 -30
  405. package/dist/src/core/tokenLimits.test.js.map +0 -1
  406. package/dist/src/core/turn.test.d.ts +0 -6
  407. package/dist/src/core/turn.test.js +0 -739
  408. package/dist/src/core/turn.test.js.map +0 -1
  409. package/dist/src/fallback/handler.test.d.ts +0 -6
  410. package/dist/src/fallback/handler.test.js +0 -242
  411. package/dist/src/fallback/handler.test.js.map +0 -1
  412. package/dist/src/hooks/hookAggregator.test.d.ts +0 -6
  413. package/dist/src/hooks/hookAggregator.test.js +0 -387
  414. package/dist/src/hooks/hookAggregator.test.js.map +0 -1
  415. package/dist/src/hooks/hookEventHandler.test.d.ts +0 -6
  416. package/dist/src/hooks/hookEventHandler.test.js +0 -603
  417. package/dist/src/hooks/hookEventHandler.test.js.map +0 -1
  418. package/dist/src/hooks/hookPlanner.test.d.ts +0 -6
  419. package/dist/src/hooks/hookPlanner.test.js +0 -315
  420. package/dist/src/hooks/hookPlanner.test.js.map +0 -1
  421. package/dist/src/hooks/hookRegistry.test.d.ts +0 -6
  422. package/dist/src/hooks/hookRegistry.test.js +0 -529
  423. package/dist/src/hooks/hookRegistry.test.js.map +0 -1
  424. package/dist/src/hooks/hookRunner.test.d.ts +0 -6
  425. package/dist/src/hooks/hookRunner.test.js +0 -606
  426. package/dist/src/hooks/hookRunner.test.js.map +0 -1
  427. package/dist/src/hooks/hookSystem.test.d.ts +0 -6
  428. package/dist/src/hooks/hookSystem.test.js +0 -330
  429. package/dist/src/hooks/hookSystem.test.js.map +0 -1
  430. package/dist/src/hooks/hookSystem_new_types.test.d.ts +0 -6
  431. package/dist/src/hooks/hookSystem_new_types.test.js +0 -243
  432. package/dist/src/hooks/hookSystem_new_types.test.js.map +0 -1
  433. package/dist/src/hooks/hookTranslator.test.d.ts +0 -6
  434. package/dist/src/hooks/hookTranslator.test.js +0 -192
  435. package/dist/src/hooks/hookTranslator.test.js.map +0 -1
  436. package/dist/src/hooks/trustedHooks.test.d.ts +0 -6
  437. package/dist/src/hooks/trustedHooks.test.js +0 -154
  438. package/dist/src/hooks/trustedHooks.test.js.map +0 -1
  439. package/dist/src/hooks/types.test.d.ts +0 -6
  440. package/dist/src/hooks/types.test.js +0 -278
  441. package/dist/src/hooks/types.test.js.map +0 -1
  442. package/dist/src/ide/detect-ide.test.d.ts +0 -6
  443. package/dist/src/ide/detect-ide.test.js +0 -195
  444. package/dist/src/ide/detect-ide.test.js.map +0 -1
  445. package/dist/src/ide/ide-client.test.d.ts +0 -6
  446. package/dist/src/ide/ide-client.test.js +0 -753
  447. package/dist/src/ide/ide-client.test.js.map +0 -1
  448. package/dist/src/ide/ide-installer.test.d.ts +0 -6
  449. package/dist/src/ide/ide-installer.test.js +0 -193
  450. package/dist/src/ide/ide-installer.test.js.map +0 -1
  451. package/dist/src/ide/ideContext.test.d.ts +0 -6
  452. package/dist/src/ide/ideContext.test.js +0 -393
  453. package/dist/src/ide/ideContext.test.js.map +0 -1
  454. package/dist/src/ide/process-utils.test.d.ts +0 -6
  455. package/dist/src/ide/process-utils.test.js +0 -151
  456. package/dist/src/ide/process-utils.test.js.map +0 -1
  457. package/dist/src/index.test.d.ts +0 -6
  458. package/dist/src/index.test.js +0 -53
  459. package/dist/src/index.test.js.map +0 -1
  460. package/dist/src/mcp/google-auth-provider.test.d.ts +0 -6
  461. package/dist/src/mcp/google-auth-provider.test.js +0 -167
  462. package/dist/src/mcp/google-auth-provider.test.js.map +0 -1
  463. package/dist/src/mcp/oauth-provider.test.d.ts +0 -6
  464. package/dist/src/mcp/oauth-provider.test.js +0 -1355
  465. package/dist/src/mcp/oauth-provider.test.js.map +0 -1
  466. package/dist/src/mcp/oauth-token-storage.test.d.ts +0 -6
  467. package/dist/src/mcp/oauth-token-storage.test.js +0 -305
  468. package/dist/src/mcp/oauth-token-storage.test.js.map +0 -1
  469. package/dist/src/mcp/oauth-utils.test.d.ts +0 -6
  470. package/dist/src/mcp/oauth-utils.test.js +0 -289
  471. package/dist/src/mcp/oauth-utils.test.js.map +0 -1
  472. package/dist/src/mcp/sa-impersonation-provider.test.d.ts +0 -6
  473. package/dist/src/mcp/sa-impersonation-provider.test.js +0 -117
  474. package/dist/src/mcp/sa-impersonation-provider.test.js.map +0 -1
  475. package/dist/src/mcp/token-storage/base-token-storage.test.d.ts +0 -6
  476. package/dist/src/mcp/token-storage/base-token-storage.test.js +0 -151
  477. package/dist/src/mcp/token-storage/base-token-storage.test.js.map +0 -1
  478. package/dist/src/mcp/token-storage/file-token-storage.test.d.ts +0 -6
  479. package/dist/src/mcp/token-storage/file-token-storage.test.js +0 -238
  480. package/dist/src/mcp/token-storage/file-token-storage.test.js.map +0 -1
  481. package/dist/src/mcp/token-storage/hybrid-token-storage.test.d.ts +0 -6
  482. package/dist/src/mcp/token-storage/hybrid-token-storage.test.js +0 -193
  483. package/dist/src/mcp/token-storage/hybrid-token-storage.test.js.map +0 -1
  484. package/dist/src/mcp/token-storage/keychain-token-storage.test.d.ts +0 -6
  485. package/dist/src/mcp/token-storage/keychain-token-storage.test.js +0 -305
  486. package/dist/src/mcp/token-storage/keychain-token-storage.test.js.map +0 -1
  487. package/dist/src/output/json-formatter.test.d.ts +0 -6
  488. package/dist/src/output/json-formatter.test.js +0 -294
  489. package/dist/src/output/json-formatter.test.js.map +0 -1
  490. package/dist/src/output/stream-json-formatter.test.d.ts +0 -6
  491. package/dist/src/output/stream-json-formatter.test.js +0 -477
  492. package/dist/src/output/stream-json-formatter.test.js.map +0 -1
  493. package/dist/src/policy/config.test.d.ts +0 -6
  494. package/dist/src/policy/config.test.js +0 -598
  495. package/dist/src/policy/config.test.js.map +0 -1
  496. package/dist/src/policy/persistence.test.d.ts +0 -6
  497. package/dist/src/policy/persistence.test.js +0 -154
  498. package/dist/src/policy/persistence.test.js.map +0 -1
  499. package/dist/src/policy/policy-engine.test.d.ts +0 -6
  500. package/dist/src/policy/policy-engine.test.js +0 -1299
  501. package/dist/src/policy/policy-engine.test.js.map +0 -1
  502. package/dist/src/policy/policy-updater.test.d.ts +0 -6
  503. package/dist/src/policy/policy-updater.test.js +0 -116
  504. package/dist/src/policy/policy-updater.test.js.map +0 -1
  505. package/dist/src/policy/shell-safety.test.d.ts +0 -6
  506. package/dist/src/policy/shell-safety.test.js +0 -438
  507. package/dist/src/policy/shell-safety.test.js.map +0 -1
  508. package/dist/src/policy/toml-loader.test.d.ts +0 -6
  509. package/dist/src/policy/toml-loader.test.js +0 -409
  510. package/dist/src/policy/toml-loader.test.js.map +0 -1
  511. package/dist/src/policy/utils.test.d.ts +0 -6
  512. package/dist/src/policy/utils.test.js +0 -92
  513. package/dist/src/policy/utils.test.js.map +0 -1
  514. package/dist/src/prompts/mcp-prompts.test.d.ts +0 -6
  515. package/dist/src/prompts/mcp-prompts.test.js +0 -39
  516. package/dist/src/prompts/mcp-prompts.test.js.map +0 -1
  517. package/dist/src/prompts/prompt-registry.test.d.ts +0 -6
  518. package/dist/src/prompts/prompt-registry.test.js +0 -96
  519. package/dist/src/prompts/prompt-registry.test.js.map +0 -1
  520. package/dist/src/providers/__tests__/bundleSize.test.d.ts +0 -6
  521. package/dist/src/providers/__tests__/bundleSize.test.js +0 -75
  522. package/dist/src/providers/__tests__/bundleSize.test.js.map +0 -1
  523. package/dist/src/providers/__tests__/errorHandling.integration.test.d.ts +0 -6
  524. package/dist/src/providers/__tests__/errorHandling.integration.test.js +0 -339
  525. package/dist/src/providers/__tests__/errorHandling.integration.test.js.map +0 -1
  526. package/dist/src/providers/__tests__/multiProvider.integration.test.d.ts +0 -6
  527. package/dist/src/providers/__tests__/multiProvider.integration.test.js +0 -419
  528. package/dist/src/providers/__tests__/multiProvider.integration.test.js.map +0 -1
  529. package/dist/src/providers/__tests__/performance.test.d.ts +0 -6
  530. package/dist/src/providers/__tests__/performance.test.js +0 -270
  531. package/dist/src/providers/__tests__/performance.test.js.map +0 -1
  532. package/dist/src/providers/__tests__/providerConfigIntegration.test.d.ts +0 -6
  533. package/dist/src/providers/__tests__/providerConfigIntegration.test.js +0 -245
  534. package/dist/src/providers/__tests__/providerConfigIntegration.test.js.map +0 -1
  535. package/dist/src/providers/baseAdapter.test.d.ts +0 -1
  536. package/dist/src/providers/baseAdapter.test.js +0 -142
  537. package/dist/src/providers/baseAdapter.test.js.map +0 -1
  538. package/dist/src/providers/claude/adapter.test.d.ts +0 -6
  539. package/dist/src/providers/claude/adapter.test.js +0 -628
  540. package/dist/src/providers/claude/adapter.test.js.map +0 -1
  541. package/dist/src/providers/claude/bootstrap.test.d.ts +0 -6
  542. package/dist/src/providers/claude/bootstrap.test.js +0 -74
  543. package/dist/src/providers/claude/bootstrap.test.js.map +0 -1
  544. package/dist/src/providers/claude/converter.test.d.ts +0 -6
  545. package/dist/src/providers/claude/converter.test.js +0 -1002
  546. package/dist/src/providers/claude/converter.test.js.map +0 -1
  547. package/dist/src/providers/claude/exports.test.d.ts +0 -6
  548. package/dist/src/providers/claude/exports.test.js +0 -40
  549. package/dist/src/providers/claude/exports.test.js.map +0 -1
  550. package/dist/src/providers/configAdapter.test.d.ts +0 -1
  551. package/dist/src/providers/configAdapter.test.js +0 -150
  552. package/dist/src/providers/configAdapter.test.js.map +0 -1
  553. package/dist/src/providers/contentResolver.test.d.ts +0 -1
  554. package/dist/src/providers/contentResolver.test.js +0 -89
  555. package/dist/src/providers/contentResolver.test.js.map +0 -1
  556. package/dist/src/providers/factory.test.d.ts +0 -1
  557. package/dist/src/providers/factory.test.js +0 -151
  558. package/dist/src/providers/factory.test.js.map +0 -1
  559. package/dist/src/providers/gemini/adapterBridge.test.d.ts +0 -6
  560. package/dist/src/providers/gemini/adapterBridge.test.js +0 -164
  561. package/dist/src/providers/gemini/adapterBridge.test.js.map +0 -1
  562. package/dist/src/providers/gemini/bootstrap.test.d.ts +0 -6
  563. package/dist/src/providers/gemini/bootstrap.test.js +0 -72
  564. package/dist/src/providers/gemini/bootstrap.test.js.map +0 -1
  565. package/dist/src/providers/gemini/configConverter.test.d.ts +0 -6
  566. package/dist/src/providers/gemini/configConverter.test.js +0 -218
  567. package/dist/src/providers/gemini/configConverter.test.js.map +0 -1
  568. package/dist/src/providers/gemini/errorClassifier.test.d.ts +0 -6
  569. package/dist/src/providers/gemini/errorClassifier.test.js +0 -83
  570. package/dist/src/providers/gemini/errorClassifier.test.js.map +0 -1
  571. package/dist/src/providers/gemini/eventMapper.test.d.ts +0 -6
  572. package/dist/src/providers/gemini/eventMapper.test.js +0 -502
  573. package/dist/src/providers/gemini/eventMapper.test.js.map +0 -1
  574. package/dist/src/providers/gemini/exports.test.d.ts +0 -6
  575. package/dist/src/providers/gemini/exports.test.js +0 -90
  576. package/dist/src/providers/gemini/exports.test.js.map +0 -1
  577. package/dist/src/providers/gemini/featureFlag.test.d.ts +0 -6
  578. package/dist/src/providers/gemini/featureFlag.test.js +0 -139
  579. package/dist/src/providers/gemini/featureFlag.test.js.map +0 -1
  580. package/dist/src/providers/gemini/geminiAdapter.test.d.ts +0 -6
  581. package/dist/src/providers/gemini/geminiAdapter.test.js +0 -279
  582. package/dist/src/providers/gemini/geminiAdapter.test.js.map +0 -1
  583. package/dist/src/providers/gemini/geminiConverter.test.d.ts +0 -6
  584. package/dist/src/providers/gemini/geminiConverter.test.js +0 -474
  585. package/dist/src/providers/gemini/geminiConverter.test.js.map +0 -1
  586. package/dist/src/providers/gemini/geminiParity.test.d.ts +0 -6
  587. package/dist/src/providers/gemini/geminiParity.test.js +0 -754
  588. package/dist/src/providers/gemini/geminiParity.test.js.map +0 -1
  589. package/dist/src/providers/gemini/geminiStream.test.d.ts +0 -6
  590. package/dist/src/providers/gemini/geminiStream.test.js +0 -391
  591. package/dist/src/providers/gemini/geminiStream.test.js.map +0 -1
  592. package/dist/src/providers/gemini/historyBuilder.test.d.ts +0 -6
  593. package/dist/src/providers/gemini/historyBuilder.test.js +0 -207
  594. package/dist/src/providers/gemini/historyBuilder.test.js.map +0 -1
  595. package/dist/src/providers/gemini/requestBuilder.test.d.ts +0 -6
  596. package/dist/src/providers/gemini/requestBuilder.test.js +0 -358
  597. package/dist/src/providers/gemini/requestBuilder.test.js.map +0 -1
  598. package/dist/src/providers/gemini/streamConverter.test.d.ts +0 -6
  599. package/dist/src/providers/gemini/streamConverter.test.js +0 -131
  600. package/dist/src/providers/gemini/streamConverter.test.js.map +0 -1
  601. package/dist/src/providers/modelSpec.test.d.ts +0 -1
  602. package/dist/src/providers/modelSpec.test.js +0 -119
  603. package/dist/src/providers/modelSpec.test.js.map +0 -1
  604. package/dist/src/providers/openai/adapter.test.d.ts +0 -6
  605. package/dist/src/providers/openai/adapter.test.js +0 -274
  606. package/dist/src/providers/openai/adapter.test.js.map +0 -1
  607. package/dist/src/providers/openai/bootstrap.test.d.ts +0 -6
  608. package/dist/src/providers/openai/bootstrap.test.js +0 -76
  609. package/dist/src/providers/openai/bootstrap.test.js.map +0 -1
  610. package/dist/src/providers/openai/converter.test.d.ts +0 -6
  611. package/dist/src/providers/openai/converter.test.js +0 -1133
  612. package/dist/src/providers/openai/converter.test.js.map +0 -1
  613. package/dist/src/providers/openai-compatible/__tests__/compatibility.test.d.ts +0 -6
  614. package/dist/src/providers/openai-compatible/__tests__/compatibility.test.js +0 -356
  615. package/dist/src/providers/openai-compatible/__tests__/compatibility.test.js.map +0 -1
  616. package/dist/src/providers/openai-compatible/adapter.test.d.ts +0 -6
  617. package/dist/src/providers/openai-compatible/adapter.test.js +0 -240
  618. package/dist/src/providers/openai-compatible/adapter.test.js.map +0 -1
  619. package/dist/src/providers/openai-compatible/bootstrap.test.d.ts +0 -6
  620. package/dist/src/providers/openai-compatible/bootstrap.test.js +0 -145
  621. package/dist/src/providers/openai-compatible/bootstrap.test.js.map +0 -1
  622. package/dist/src/providers/openai-compatible/promptBuilder.test.d.ts +0 -6
  623. package/dist/src/providers/openai-compatible/promptBuilder.test.js +0 -154
  624. package/dist/src/providers/openai-compatible/promptBuilder.test.js.map +0 -1
  625. package/dist/src/providers/providerConfig.test.d.ts +0 -1
  626. package/dist/src/providers/providerConfig.test.js +0 -145
  627. package/dist/src/providers/providerConfig.test.js.map +0 -1
  628. package/dist/src/providers/providerConfigIntegration.test.d.ts +0 -6
  629. package/dist/src/providers/providerConfigIntegration.test.js +0 -187
  630. package/dist/src/providers/providerConfigIntegration.test.js.map +0 -1
  631. package/dist/src/providers/providerSelector.test.d.ts +0 -1
  632. package/dist/src/providers/providerSelector.test.js +0 -199
  633. package/dist/src/providers/providerSelector.test.js.map +0 -1
  634. package/dist/src/providers/providerTypes.test.d.ts +0 -1
  635. package/dist/src/providers/providerTypes.test.js +0 -95
  636. package/dist/src/providers/providerTypes.test.js.map +0 -1
  637. package/dist/src/providers/registry.test.d.ts +0 -1
  638. package/dist/src/providers/registry.test.js +0 -207
  639. package/dist/src/providers/registry.test.js.map +0 -1
  640. package/dist/src/providers/streamAssembler.test.d.ts +0 -1
  641. package/dist/src/providers/streamAssembler.test.js +0 -247
  642. package/dist/src/providers/streamAssembler.test.js.map +0 -1
  643. package/dist/src/providers/telemetryBridge.test.d.ts +0 -6
  644. package/dist/src/providers/telemetryBridge.test.js +0 -235
  645. package/dist/src/providers/telemetryBridge.test.js.map +0 -1
  646. package/dist/src/providers/types.test.d.ts +0 -6
  647. package/dist/src/providers/types.test.js +0 -253
  648. package/dist/src/providers/types.test.js.map +0 -1
  649. package/dist/src/resources/resource-registry.test.d.ts +0 -6
  650. package/dist/src/resources/resource-registry.test.js +0 -54
  651. package/dist/src/resources/resource-registry.test.js.map +0 -1
  652. package/dist/src/routing/modelRouterService.test.d.ts +0 -6
  653. package/dist/src/routing/modelRouterService.test.js +0 -106
  654. package/dist/src/routing/modelRouterService.test.js.map +0 -1
  655. package/dist/src/routing/strategies/classifierStrategy.test.d.ts +0 -6
  656. package/dist/src/routing/strategies/classifierStrategy.test.js +0 -249
  657. package/dist/src/routing/strategies/classifierStrategy.test.js.map +0 -1
  658. package/dist/src/routing/strategies/compositeStrategy.test.d.ts +0 -6
  659. package/dist/src/routing/strategies/compositeStrategy.test.js +0 -124
  660. package/dist/src/routing/strategies/compositeStrategy.test.js.map +0 -1
  661. package/dist/src/routing/strategies/defaultStrategy.test.d.ts +0 -6
  662. package/dist/src/routing/strategies/defaultStrategy.test.js +0 -102
  663. package/dist/src/routing/strategies/defaultStrategy.test.js.map +0 -1
  664. package/dist/src/routing/strategies/fallbackStrategy.test.d.ts +0 -6
  665. package/dist/src/routing/strategies/fallbackStrategy.test.js +0 -96
  666. package/dist/src/routing/strategies/fallbackStrategy.test.js.map +0 -1
  667. package/dist/src/routing/strategies/numericalClassifierStrategy.test.d.ts +0 -6
  668. package/dist/src/routing/strategies/numericalClassifierStrategy.test.js +0 -367
  669. package/dist/src/routing/strategies/numericalClassifierStrategy.test.js.map +0 -1
  670. package/dist/src/routing/strategies/overrideStrategy.test.d.ts +0 -6
  671. package/dist/src/routing/strategies/overrideStrategy.test.js +0 -59
  672. package/dist/src/routing/strategies/overrideStrategy.test.js.map +0 -1
  673. package/dist/src/safety/built-in.test.d.ts +0 -6
  674. package/dist/src/safety/built-in.test.js +0 -199
  675. package/dist/src/safety/built-in.test.js.map +0 -1
  676. package/dist/src/safety/checker-runner.test.d.ts +0 -6
  677. package/dist/src/safety/checker-runner.test.js +0 -238
  678. package/dist/src/safety/checker-runner.test.js.map +0 -1
  679. package/dist/src/safety/context-builder.test.d.ts +0 -6
  680. package/dist/src/safety/context-builder.test.js +0 -49
  681. package/dist/src/safety/context-builder.test.js.map +0 -1
  682. package/dist/src/safety/registry.test.d.ts +0 -6
  683. package/dist/src/safety/registry.test.js +0 -31
  684. package/dist/src/safety/registry.test.js.map +0 -1
  685. package/dist/src/scheduler/confirmation.test.d.ts +0 -6
  686. package/dist/src/scheduler/confirmation.test.js +0 -325
  687. package/dist/src/scheduler/confirmation.test.js.map +0 -1
  688. package/dist/src/scheduler/policy.test.d.ts +0 -6
  689. package/dist/src/scheduler/policy.test.js +0 -299
  690. package/dist/src/scheduler/policy.test.js.map +0 -1
  691. package/dist/src/scheduler/scheduler.test.d.ts +0 -6
  692. package/dist/src/scheduler/scheduler.test.js +0 -822
  693. package/dist/src/scheduler/scheduler.test.js.map +0 -1
  694. package/dist/src/scheduler/state-manager.test.d.ts +0 -6
  695. package/dist/src/scheduler/state-manager.test.js +0 -429
  696. package/dist/src/scheduler/state-manager.test.js.map +0 -1
  697. package/dist/src/scheduler/tool-executor.test.d.ts +0 -6
  698. package/dist/src/scheduler/tool-executor.test.js +0 -232
  699. package/dist/src/scheduler/tool-executor.test.js.map +0 -1
  700. package/dist/src/scheduler/tool-modifier.test.d.ts +0 -6
  701. package/dist/src/scheduler/tool-modifier.test.js +0 -159
  702. package/dist/src/scheduler/tool-modifier.test.js.map +0 -1
  703. package/dist/src/services/chatCompressionService.test.d.ts +0 -6
  704. package/dist/src/services/chatCompressionService.test.js +0 -573
  705. package/dist/src/services/chatCompressionService.test.js.map +0 -1
  706. package/dist/src/services/chatRecordingService.test.d.ts +0 -6
  707. package/dist/src/services/chatRecordingService.test.js +0 -486
  708. package/dist/src/services/chatRecordingService.test.js.map +0 -1
  709. package/dist/src/services/contextManager.test.d.ts +0 -6
  710. package/dist/src/services/contextManager.test.js +0 -104
  711. package/dist/src/services/contextManager.test.js.map +0 -1
  712. package/dist/src/services/environmentSanitization.test.d.ts +0 -6
  713. package/dist/src/services/environmentSanitization.test.js +0 -284
  714. package/dist/src/services/environmentSanitization.test.js.map +0 -1
  715. package/dist/src/services/fileDiscoveryService.test.d.ts +0 -6
  716. package/dist/src/services/fileDiscoveryService.test.js +0 -223
  717. package/dist/src/services/fileDiscoveryService.test.js.map +0 -1
  718. package/dist/src/services/fileSystemService.test.d.ts +0 -6
  719. package/dist/src/services/fileSystemService.test.js +0 -41
  720. package/dist/src/services/fileSystemService.test.js.map +0 -1
  721. package/dist/src/services/gitService.test.d.ts +0 -6
  722. package/dist/src/services/gitService.test.js +0 -264
  723. package/dist/src/services/gitService.test.js.map +0 -1
  724. package/dist/src/services/loopDetectionService.test.d.ts +0 -6
  725. package/dist/src/services/loopDetectionService.test.js +0 -881
  726. package/dist/src/services/loopDetectionService.test.js.map +0 -1
  727. package/dist/src/services/modelConfig.golden.test.d.ts +0 -6
  728. package/dist/src/services/modelConfig.golden.test.js +0 -74
  729. package/dist/src/services/modelConfig.golden.test.js.map +0 -1
  730. package/dist/src/services/modelConfig.integration.test.d.ts +0 -6
  731. package/dist/src/services/modelConfig.integration.test.js +0 -247
  732. package/dist/src/services/modelConfig.integration.test.js.map +0 -1
  733. package/dist/src/services/modelConfigBridge.test.d.ts +0 -6
  734. package/dist/src/services/modelConfigBridge.test.js +0 -410
  735. package/dist/src/services/modelConfigBridge.test.js.map +0 -1
  736. package/dist/src/services/modelConfigService.test.d.ts +0 -6
  737. package/dist/src/services/modelConfigService.test.js +0 -868
  738. package/dist/src/services/modelConfigService.test.js.map +0 -1
  739. package/dist/src/services/sessionSummaryService.test.d.ts +0 -6
  740. package/dist/src/services/sessionSummaryService.test.js +0 -785
  741. package/dist/src/services/sessionSummaryService.test.js.map +0 -1
  742. package/dist/src/services/sessionSummaryUtils.test.d.ts +0 -6
  743. package/dist/src/services/sessionSummaryUtils.test.js +0 -160
  744. package/dist/src/services/sessionSummaryUtils.test.js.map +0 -1
  745. package/dist/src/services/shellExecutionService.test.d.ts +0 -6
  746. package/dist/src/services/shellExecutionService.test.js +0 -1080
  747. package/dist/src/services/shellExecutionService.test.js.map +0 -1
  748. package/dist/src/skills/skillLoader.test.d.ts +0 -6
  749. package/dist/src/skills/skillLoader.test.js +0 -185
  750. package/dist/src/skills/skillLoader.test.js.map +0 -1
  751. package/dist/src/skills/skillManager.test.d.ts +0 -6
  752. package/dist/src/skills/skillManager.test.js +0 -297
  753. package/dist/src/skills/skillManager.test.js.map +0 -1
  754. package/dist/src/telemetry/activity-detector.test.d.ts +0 -6
  755. package/dist/src/telemetry/activity-detector.test.js +0 -136
  756. package/dist/src/telemetry/activity-detector.test.js.map +0 -1
  757. package/dist/src/telemetry/activity-monitor.test.d.ts +0 -6
  758. package/dist/src/telemetry/activity-monitor.test.js +0 -251
  759. package/dist/src/telemetry/activity-monitor.test.js.map +0 -1
  760. package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.d.ts +0 -19
  761. package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.js +0 -964
  762. package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.js.map +0 -1
  763. package/dist/src/telemetry/config.test.d.ts +0 -6
  764. package/dist/src/telemetry/config.test.js +0 -149
  765. package/dist/src/telemetry/config.test.js.map +0 -1
  766. package/dist/src/telemetry/gcp-exporters.test.d.ts +0 -6
  767. package/dist/src/telemetry/gcp-exporters.test.js +0 -318
  768. package/dist/src/telemetry/gcp-exporters.test.js.map +0 -1
  769. package/dist/src/telemetry/high-water-mark-tracker.test.d.ts +0 -6
  770. package/dist/src/telemetry/high-water-mark-tracker.test.js +0 -152
  771. package/dist/src/telemetry/high-water-mark-tracker.test.js.map +0 -1
  772. package/dist/src/telemetry/integration.test.circular.d.ts +0 -6
  773. package/dist/src/telemetry/integration.test.circular.js +0 -54
  774. package/dist/src/telemetry/integration.test.circular.js.map +0 -1
  775. package/dist/src/telemetry/loggers.test.circular.d.ts +0 -6
  776. package/dist/src/telemetry/loggers.test.circular.js +0 -107
  777. package/dist/src/telemetry/loggers.test.circular.js.map +0 -1
  778. package/dist/src/telemetry/loggers.test.d.ts +0 -6
  779. package/dist/src/telemetry/loggers.test.js +0 -1618
  780. package/dist/src/telemetry/loggers.test.js.map +0 -1
  781. package/dist/src/telemetry/memory-monitor.test.d.ts +0 -6
  782. package/dist/src/telemetry/memory-monitor.test.js +0 -472
  783. package/dist/src/telemetry/memory-monitor.test.js.map +0 -1
  784. package/dist/src/telemetry/metrics.test.d.ts +0 -6
  785. package/dist/src/telemetry/metrics.test.js +0 -1176
  786. package/dist/src/telemetry/metrics.test.js.map +0 -1
  787. package/dist/src/telemetry/rate-limiter.test.d.ts +0 -6
  788. package/dist/src/telemetry/rate-limiter.test.js +0 -207
  789. package/dist/src/telemetry/rate-limiter.test.js.map +0 -1
  790. package/dist/src/telemetry/sanitize.test.d.ts +0 -6
  791. package/dist/src/telemetry/sanitize.test.js +0 -279
  792. package/dist/src/telemetry/sanitize.test.js.map +0 -1
  793. package/dist/src/telemetry/sdk.test.d.ts +0 -6
  794. package/dist/src/telemetry/sdk.test.js +0 -360
  795. package/dist/src/telemetry/sdk.test.js.map +0 -1
  796. package/dist/src/telemetry/semantic.test.d.ts +0 -6
  797. package/dist/src/telemetry/semantic.test.js +0 -387
  798. package/dist/src/telemetry/semantic.test.js.map +0 -1
  799. package/dist/src/telemetry/semantic.truncation.test.d.ts +0 -1
  800. package/dist/src/telemetry/semantic.truncation.test.js +0 -92
  801. package/dist/src/telemetry/semantic.truncation.test.js.map +0 -1
  802. package/dist/src/telemetry/startupProfiler.test.d.ts +0 -6
  803. package/dist/src/telemetry/startupProfiler.test.js +0 -285
  804. package/dist/src/telemetry/startupProfiler.test.js.map +0 -1
  805. package/dist/src/telemetry/telemetry-utils.test.d.ts +0 -6
  806. package/dist/src/telemetry/telemetry-utils.test.js +0 -41
  807. package/dist/src/telemetry/telemetry-utils.test.js.map +0 -1
  808. package/dist/src/telemetry/telemetry.test.d.ts +0 -6
  809. package/dist/src/telemetry/telemetry.test.js +0 -57
  810. package/dist/src/telemetry/telemetry.test.js.map +0 -1
  811. package/dist/src/telemetry/uiTelemetry.test.d.ts +0 -6
  812. package/dist/src/telemetry/uiTelemetry.test.js +0 -584
  813. package/dist/src/telemetry/uiTelemetry.test.js.map +0 -1
  814. package/dist/src/tools/activate-skill.test.d.ts +0 -6
  815. package/dist/src/tools/activate-skill.test.js +0 -113
  816. package/dist/src/tools/activate-skill.test.js.map +0 -1
  817. package/dist/src/tools/ask-user.test.d.ts +0 -6
  818. package/dist/src/tools/ask-user.test.js +0 -187
  819. package/dist/src/tools/ask-user.test.js.map +0 -1
  820. package/dist/src/tools/base-tool-invocation.test.d.ts +0 -6
  821. package/dist/src/tools/base-tool-invocation.test.js +0 -85
  822. package/dist/src/tools/base-tool-invocation.test.js.map +0 -1
  823. package/dist/src/tools/confirmation-policy.test.d.ts +0 -6
  824. package/dist/src/tools/confirmation-policy.test.js +0 -143
  825. package/dist/src/tools/confirmation-policy.test.js.map +0 -1
  826. package/dist/src/tools/diffOptions.test.d.ts +0 -6
  827. package/dist/src/tools/diffOptions.test.js +0 -172
  828. package/dist/src/tools/diffOptions.test.js.map +0 -1
  829. package/dist/src/tools/edit.test.d.ts +0 -6
  830. package/dist/src/tools/edit.test.js +0 -729
  831. package/dist/src/tools/edit.test.js.map +0 -1
  832. package/dist/src/tools/get-internal-docs.test.d.ts +0 -6
  833. package/dist/src/tools/get-internal-docs.test.js +0 -57
  834. package/dist/src/tools/get-internal-docs.test.js.map +0 -1
  835. package/dist/src/tools/glob.test.d.ts +0 -6
  836. package/dist/src/tools/glob.test.js +0 -433
  837. package/dist/src/tools/glob.test.js.map +0 -1
  838. package/dist/src/tools/grep.test.d.ts +0 -6
  839. package/dist/src/tools/grep.test.js +0 -328
  840. package/dist/src/tools/grep.test.js.map +0 -1
  841. package/dist/src/tools/ls.test.d.ts +0 -6
  842. package/dist/src/tools/ls.test.js +0 -242
  843. package/dist/src/tools/ls.test.js.map +0 -1
  844. package/dist/src/tools/mcp-client-manager.test.d.ts +0 -6
  845. package/dist/src/tools/mcp-client-manager.test.js +0 -251
  846. package/dist/src/tools/mcp-client-manager.test.js.map +0 -1
  847. package/dist/src/tools/mcp-client.test.d.ts +0 -6
  848. package/dist/src/tools/mcp-client.test.js +0 -1346
  849. package/dist/src/tools/mcp-client.test.js.map +0 -1
  850. package/dist/src/tools/mcp-tool.test.d.ts +0 -6
  851. package/dist/src/tools/mcp-tool.test.js +0 -657
  852. package/dist/src/tools/mcp-tool.test.js.map +0 -1
  853. package/dist/src/tools/memoryTool.test.d.ts +0 -6
  854. package/dist/src/tools/memoryTool.test.js +0 -302
  855. package/dist/src/tools/memoryTool.test.js.map +0 -1
  856. package/dist/src/tools/message-bus-integration.test.d.ts +0 -6
  857. package/dist/src/tools/message-bus-integration.test.js +0 -169
  858. package/dist/src/tools/message-bus-integration.test.js.map +0 -1
  859. package/dist/src/tools/modifiable-tool.test.d.ts +0 -6
  860. package/dist/src/tools/modifiable-tool.test.js +0 -237
  861. package/dist/src/tools/modifiable-tool.test.js.map +0 -1
  862. package/dist/src/tools/read-file.test.d.ts +0 -6
  863. package/dist/src/tools/read-file.test.js +0 -376
  864. package/dist/src/tools/read-file.test.js.map +0 -1
  865. package/dist/src/tools/read-many-files.test.d.ts +0 -6
  866. package/dist/src/tools/read-many-files.test.js +0 -567
  867. package/dist/src/tools/read-many-files.test.js.map +0 -1
  868. package/dist/src/tools/ripGrep.test.d.ts +0 -6
  869. package/dist/src/tools/ripGrep.test.js +0 -1139
  870. package/dist/src/tools/ripGrep.test.js.map +0 -1
  871. package/dist/src/tools/shell.test.d.ts +0 -6
  872. package/dist/src/tools/shell.test.js +0 -526
  873. package/dist/src/tools/shell.test.js.map +0 -1
  874. package/dist/src/tools/tool-names.test.d.ts +0 -6
  875. package/dist/src/tools/tool-names.test.js +0 -43
  876. package/dist/src/tools/tool-names.test.js.map +0 -1
  877. package/dist/src/tools/tool-registry.test.d.ts +0 -6
  878. package/dist/src/tools/tool-registry.test.js +0 -461
  879. package/dist/src/tools/tool-registry.test.js.map +0 -1
  880. package/dist/src/tools/tools.test.d.ts +0 -6
  881. package/dist/src/tools/tools.test.js +0 -207
  882. package/dist/src/tools/tools.test.js.map +0 -1
  883. package/dist/src/tools/web-fetch.test.d.ts +0 -6
  884. package/dist/src/tools/web-fetch.test.js +0 -442
  885. package/dist/src/tools/web-fetch.test.js.map +0 -1
  886. package/dist/src/tools/web-search.test.d.ts +0 -6
  887. package/dist/src/tools/web-search.test.js +0 -214
  888. package/dist/src/tools/web-search.test.js.map +0 -1
  889. package/dist/src/tools/write-file.test.d.ts +0 -6
  890. package/dist/src/tools/write-file.test.js +0 -681
  891. package/dist/src/tools/write-file.test.js.map +0 -1
  892. package/dist/src/tools/write-todos.test.d.ts +0 -6
  893. package/dist/src/tools/write-todos.test.js +0 -90
  894. package/dist/src/tools/write-todos.test.js.map +0 -1
  895. package/dist/src/utils/apiConversionUtils.test.d.ts +0 -6
  896. package/dist/src/utils/apiConversionUtils.test.js +0 -150
  897. package/dist/src/utils/apiConversionUtils.test.js.map +0 -1
  898. package/dist/src/utils/bfsFileSearch.test.d.ts +0 -6
  899. package/dist/src/utils/bfsFileSearch.test.js +0 -227
  900. package/dist/src/utils/bfsFileSearch.test.js.map +0 -1
  901. package/dist/src/utils/channel.test.d.ts +0 -6
  902. package/dist/src/utils/channel.test.js +0 -170
  903. package/dist/src/utils/channel.test.js.map +0 -1
  904. package/dist/src/utils/checkpointUtils.test.d.ts +0 -6
  905. package/dist/src/utils/checkpointUtils.test.js +0 -229
  906. package/dist/src/utils/checkpointUtils.test.js.map +0 -1
  907. package/dist/src/utils/customHeaderUtils.test.d.ts +0 -6
  908. package/dist/src/utils/customHeaderUtils.test.js +0 -77
  909. package/dist/src/utils/customHeaderUtils.test.js.map +0 -1
  910. package/dist/src/utils/debugLogger.test.d.ts +0 -6
  911. package/dist/src/utils/debugLogger.test.js +0 -69
  912. package/dist/src/utils/debugLogger.test.js.map +0 -1
  913. package/dist/src/utils/delay.test.d.ts +0 -6
  914. package/dist/src/utils/delay.test.js +0 -88
  915. package/dist/src/utils/delay.test.js.map +0 -1
  916. package/dist/src/utils/editCorrector.test.d.ts +0 -6
  917. package/dist/src/utils/editCorrector.test.js +0 -533
  918. package/dist/src/utils/editCorrector.test.js.map +0 -1
  919. package/dist/src/utils/editor.test.d.ts +0 -6
  920. package/dist/src/utils/editor.test.js +0 -429
  921. package/dist/src/utils/editor.test.js.map +0 -1
  922. package/dist/src/utils/environmentContext.test.d.ts +0 -6
  923. package/dist/src/utils/environmentContext.test.js +0 -114
  924. package/dist/src/utils/environmentContext.test.js.map +0 -1
  925. package/dist/src/utils/errorParsing.test.d.ts +0 -6
  926. package/dist/src/utils/errorParsing.test.js +0 -84
  927. package/dist/src/utils/errorParsing.test.js.map +0 -1
  928. package/dist/src/utils/errorReporting.test.d.ts +0 -6
  929. package/dist/src/utils/errorReporting.test.js +0 -133
  930. package/dist/src/utils/errorReporting.test.js.map +0 -1
  931. package/dist/src/utils/errors.test.d.ts +0 -6
  932. package/dist/src/utils/errors.test.js +0 -155
  933. package/dist/src/utils/errors.test.js.map +0 -1
  934. package/dist/src/utils/events.test.d.ts +0 -6
  935. package/dist/src/utils/events.test.js +0 -237
  936. package/dist/src/utils/events.test.js.map +0 -1
  937. package/dist/src/utils/extensionLoader.test.d.ts +0 -6
  938. package/dist/src/utils/extensionLoader.test.js +0 -176
  939. package/dist/src/utils/extensionLoader.test.js.map +0 -1
  940. package/dist/src/utils/fileDiffUtils.test.d.ts +0 -6
  941. package/dist/src/utils/fileDiffUtils.test.js +0 -84
  942. package/dist/src/utils/fileDiffUtils.test.js.map +0 -1
  943. package/dist/src/utils/fileUtils.test.d.ts +0 -6
  944. package/dist/src/utils/fileUtils.test.js +0 -780
  945. package/dist/src/utils/fileUtils.test.js.map +0 -1
  946. package/dist/src/utils/filesearch/crawlCache.test.d.ts +0 -6
  947. package/dist/src/utils/filesearch/crawlCache.test.js +0 -103
  948. package/dist/src/utils/filesearch/crawlCache.test.js.map +0 -1
  949. package/dist/src/utils/filesearch/crawler.test.d.ts +0 -6
  950. package/dist/src/utils/filesearch/crawler.test.js +0 -495
  951. package/dist/src/utils/filesearch/crawler.test.js.map +0 -1
  952. package/dist/src/utils/filesearch/fileSearch.test.d.ts +0 -6
  953. package/dist/src/utils/filesearch/fileSearch.test.js +0 -663
  954. package/dist/src/utils/filesearch/fileSearch.test.js.map +0 -1
  955. package/dist/src/utils/filesearch/ignore.test.d.ts +0 -6
  956. package/dist/src/utils/filesearch/ignore.test.js +0 -144
  957. package/dist/src/utils/filesearch/ignore.test.js.map +0 -1
  958. package/dist/src/utils/filesearch/result-cache.test.d.ts +0 -6
  959. package/dist/src/utils/filesearch/result-cache.test.js +0 -46
  960. package/dist/src/utils/filesearch/result-cache.test.js.map +0 -1
  961. package/dist/src/utils/flashFallback.test.d.ts +0 -6
  962. package/dist/src/utils/flashFallback.test.js +0 -103
  963. package/dist/src/utils/flashFallback.test.js.map +0 -1
  964. package/dist/src/utils/formatters.test.d.ts +0 -6
  965. package/dist/src/utils/formatters.test.js +0 -26
  966. package/dist/src/utils/formatters.test.js.map +0 -1
  967. package/dist/src/utils/geminiIgnoreParser.test.d.ts +0 -6
  968. package/dist/src/utils/geminiIgnoreParser.test.js +0 -98
  969. package/dist/src/utils/geminiIgnoreParser.test.js.map +0 -1
  970. package/dist/src/utils/geminiTypeConversion.test.d.ts +0 -6
  971. package/dist/src/utils/geminiTypeConversion.test.js +0 -310
  972. package/dist/src/utils/geminiTypeConversion.test.js.map +0 -1
  973. package/dist/src/utils/generateContentResponseUtilities.test.d.ts +0 -6
  974. package/dist/src/utils/generateContentResponseUtilities.test.js +0 -512
  975. package/dist/src/utils/generateContentResponseUtilities.test.js.map +0 -1
  976. package/dist/src/utils/getFolderStructure.test.d.ts +0 -6
  977. package/dist/src/utils/getFolderStructure.test.js +0 -283
  978. package/dist/src/utils/getFolderStructure.test.js.map +0 -1
  979. package/dist/src/utils/gitIgnoreParser.test.d.ts +0 -6
  980. package/dist/src/utils/gitIgnoreParser.test.js +0 -243
  981. package/dist/src/utils/gitIgnoreParser.test.js.map +0 -1
  982. package/dist/src/utils/googleErrors.test.d.ts +0 -6
  983. package/dist/src/utils/googleErrors.test.js +0 -309
  984. package/dist/src/utils/googleErrors.test.js.map +0 -1
  985. package/dist/src/utils/googleQuotaErrors.test.d.ts +0 -6
  986. package/dist/src/utils/googleQuotaErrors.test.js +0 -548
  987. package/dist/src/utils/googleQuotaErrors.test.js.map +0 -1
  988. package/dist/src/utils/ignorePatterns.test.d.ts +0 -6
  989. package/dist/src/utils/ignorePatterns.test.js +0 -246
  990. package/dist/src/utils/ignorePatterns.test.js.map +0 -1
  991. package/dist/src/utils/installationManager.test.d.ts +0 -6
  992. package/dist/src/utils/installationManager.test.js +0 -93
  993. package/dist/src/utils/installationManager.test.js.map +0 -1
  994. package/dist/src/utils/llm-edit-fixer.test.d.ts +0 -6
  995. package/dist/src/utils/llm-edit-fixer.test.js +0 -223
  996. package/dist/src/utils/llm-edit-fixer.test.js.map +0 -1
  997. package/dist/src/utils/llmUtils.test.d.ts +0 -6
  998. package/dist/src/utils/llmUtils.test.js +0 -196
  999. package/dist/src/utils/llmUtils.test.js.map +0 -1
  1000. package/dist/src/utils/memoryDiscovery.test.d.ts +0 -6
  1001. package/dist/src/utils/memoryDiscovery.test.js +0 -542
  1002. package/dist/src/utils/memoryDiscovery.test.js.map +0 -1
  1003. package/dist/src/utils/memoryImportProcessor.test.d.ts +0 -6
  1004. package/dist/src/utils/memoryImportProcessor.test.js +0 -581
  1005. package/dist/src/utils/memoryImportProcessor.test.js.map +0 -1
  1006. package/dist/src/utils/nextSpeakerChecker.test.d.ts +0 -6
  1007. package/dist/src/utils/nextSpeakerChecker.test.js +0 -191
  1008. package/dist/src/utils/nextSpeakerChecker.test.js.map +0 -1
  1009. package/dist/src/utils/partUtils.test.d.ts +0 -6
  1010. package/dist/src/utils/partUtils.test.js +0 -397
  1011. package/dist/src/utils/partUtils.test.js.map +0 -1
  1012. package/dist/src/utils/pathCorrector.test.d.ts +0 -6
  1013. package/dist/src/utils/pathCorrector.test.js +0 -87
  1014. package/dist/src/utils/pathCorrector.test.js.map +0 -1
  1015. package/dist/src/utils/pathReader.test.d.ts +0 -6
  1016. package/dist/src/utils/pathReader.test.js +0 -406
  1017. package/dist/src/utils/pathReader.test.js.map +0 -1
  1018. package/dist/src/utils/paths.test.d.ts +0 -6
  1019. package/dist/src/utils/paths.test.js +0 -402
  1020. package/dist/src/utils/paths.test.js.map +0 -1
  1021. package/dist/src/utils/retry.test.d.ts +0 -6
  1022. package/dist/src/utils/retry.test.js +0 -548
  1023. package/dist/src/utils/retry.test.js.map +0 -1
  1024. package/dist/src/utils/retry_llm_error.test.d.ts +0 -6
  1025. package/dist/src/utils/retry_llm_error.test.js +0 -280
  1026. package/dist/src/utils/retry_llm_error.test.js.map +0 -1
  1027. package/dist/src/utils/safeJsonStringify.test.d.ts +0 -6
  1028. package/dist/src/utils/safeJsonStringify.test.js +0 -61
  1029. package/dist/src/utils/safeJsonStringify.test.js.map +0 -1
  1030. package/dist/src/utils/schemaValidator.test.d.ts +0 -6
  1031. package/dist/src/utils/schemaValidator.test.js +0 -113
  1032. package/dist/src/utils/schemaValidator.test.js.map +0 -1
  1033. package/dist/src/utils/secure-browser-launcher.test.d.ts +0 -6
  1034. package/dist/src/utils/secure-browser-launcher.test.js +0 -149
  1035. package/dist/src/utils/secure-browser-launcher.test.js.map +0 -1
  1036. package/dist/src/utils/security.test.d.ts +0 -1
  1037. package/dist/src/utils/security.test.js +0 -121
  1038. package/dist/src/utils/security.test.js.map +0 -1
  1039. package/dist/src/utils/shell-utils.integration.test.d.ts +0 -1
  1040. package/dist/src/utils/shell-utils.integration.test.js +0 -58
  1041. package/dist/src/utils/shell-utils.integration.test.js.map +0 -1
  1042. package/dist/src/utils/shell-utils.test.d.ts +0 -6
  1043. package/dist/src/utils/shell-utils.test.js +0 -437
  1044. package/dist/src/utils/shell-utils.test.js.map +0 -1
  1045. package/dist/src/utils/stdio.test.d.ts +0 -6
  1046. package/dist/src/utils/stdio.test.js +0 -47
  1047. package/dist/src/utils/stdio.test.js.map +0 -1
  1048. package/dist/src/utils/summarizer.test.d.ts +0 -6
  1049. package/dist/src/utils/summarizer.test.js +0 -152
  1050. package/dist/src/utils/summarizer.test.js.map +0 -1
  1051. package/dist/src/utils/systemEncoding.test.d.ts +0 -6
  1052. package/dist/src/utils/systemEncoding.test.js +0 -369
  1053. package/dist/src/utils/systemEncoding.test.js.map +0 -1
  1054. package/dist/src/utils/terminalSerializer.test.d.ts +0 -6
  1055. package/dist/src/utils/terminalSerializer.test.js +0 -193
  1056. package/dist/src/utils/terminalSerializer.test.js.map +0 -1
  1057. package/dist/src/utils/textUtils.test.d.ts +0 -6
  1058. package/dist/src/utils/textUtils.test.js +0 -76
  1059. package/dist/src/utils/textUtils.test.js.map +0 -1
  1060. package/dist/src/utils/thoughtUtils.test.d.ts +0 -6
  1061. package/dist/src/utils/thoughtUtils.test.js +0 -78
  1062. package/dist/src/utils/thoughtUtils.test.js.map +0 -1
  1063. package/dist/src/utils/tokenCalculation.test.d.ts +0 -6
  1064. package/dist/src/utils/tokenCalculation.test.js +0 -184
  1065. package/dist/src/utils/tokenCalculation.test.js.map +0 -1
  1066. package/dist/src/utils/tool-utils.test.d.ts +0 -6
  1067. package/dist/src/utils/tool-utils.test.js +0 -84
  1068. package/dist/src/utils/tool-utils.test.js.map +0 -1
  1069. package/dist/src/utils/toolCallContext.test.d.ts +0 -6
  1070. package/dist/src/utils/toolCallContext.test.js +0 -68
  1071. package/dist/src/utils/toolCallContext.test.js.map +0 -1
  1072. package/dist/src/utils/userAccountManager.test.d.ts +0 -6
  1073. package/dist/src/utils/userAccountManager.test.js +0 -225
  1074. package/dist/src/utils/userAccountManager.test.js.map +0 -1
  1075. package/dist/src/utils/version.test.d.ts +0 -6
  1076. package/dist/src/utils/version.test.js +0 -39
  1077. package/dist/src/utils/version.test.js.map +0 -1
  1078. package/dist/src/utils/workspaceContext.test.d.ts +0 -6
  1079. package/dist/src/utils/workspaceContext.test.js +0 -374
  1080. package/dist/src/utils/workspaceContext.test.js.map +0 -1
  1081. package/dist/tsconfig.tsbuildinfo +0 -1
@@ -1,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