@nimrobo/mcporter-remote 0.1.0

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 (741) hide show
  1. package/.claude/settings.local.json +7 -0
  2. package/.gitattributes +2 -0
  3. package/.github/workflows/ci.yml +26 -0
  4. package/AGENTS.md +109 -0
  5. package/CHANGELOG.md +361 -0
  6. package/LICENSE +21 -0
  7. package/README.md +449 -0
  8. package/bin/git +180 -0
  9. package/biome.json +43 -0
  10. package/config/mcporter.json +134 -0
  11. package/dist/cli/adhoc-server.d.ts +21 -0
  12. package/dist/cli/adhoc-server.d.ts.map +1 -0
  13. package/dist/cli/adhoc-server.js +228 -0
  14. package/dist/cli/adhoc-server.js.map +1 -0
  15. package/dist/cli/auth-command.d.ts +6 -0
  16. package/dist/cli/auth-command.d.ts.map +1 -0
  17. package/dist/cli/auth-command.js +257 -0
  18. package/dist/cli/auth-command.js.map +1 -0
  19. package/dist/cli/call-argument-expression.d.ts +5 -0
  20. package/dist/cli/call-argument-expression.d.ts.map +1 -0
  21. package/dist/cli/call-argument-expression.js +57 -0
  22. package/dist/cli/call-argument-expression.js.map +1 -0
  23. package/dist/cli/call-argument-values.d.ts +10 -0
  24. package/dist/cli/call-argument-values.d.ts.map +1 -0
  25. package/dist/cli/call-argument-values.js +83 -0
  26. package/dist/cli/call-argument-values.js.map +1 -0
  27. package/dist/cli/call-arguments.d.ts +17 -0
  28. package/dist/cli/call-arguments.d.ts.map +1 -0
  29. package/dist/cli/call-arguments.js +183 -0
  30. package/dist/cli/call-arguments.js.map +1 -0
  31. package/dist/cli/call-command.d.ts +5 -0
  32. package/dist/cli/call-command.d.ts.map +1 -0
  33. package/dist/cli/call-command.js +371 -0
  34. package/dist/cli/call-command.js.map +1 -0
  35. package/dist/cli/call-expression-parser.d.ts +9 -0
  36. package/dist/cli/call-expression-parser.d.ts.map +1 -0
  37. package/dist/cli/call-expression-parser.js +177 -0
  38. package/dist/cli/call-expression-parser.js.map +1 -0
  39. package/dist/cli/cli-factory.d.ts +16 -0
  40. package/dist/cli/cli-factory.d.ts.map +1 -0
  41. package/dist/cli/cli-factory.js +37 -0
  42. package/dist/cli/cli-factory.js.map +1 -0
  43. package/dist/cli/command-inference.d.ts +12 -0
  44. package/dist/cli/command-inference.d.ts.map +1 -0
  45. package/dist/cli/command-inference.js +75 -0
  46. package/dist/cli/command-inference.js.map +1 -0
  47. package/dist/cli/config/add.d.ts +23 -0
  48. package/dist/cli/config/add.d.ts.map +1 -0
  49. package/dist/cli/config/add.js +267 -0
  50. package/dist/cli/config/add.js.map +1 -0
  51. package/dist/cli/config/auth.d.ts +4 -0
  52. package/dist/cli/config/auth.d.ts.map +1 -0
  53. package/dist/cli/config/auth.js +21 -0
  54. package/dist/cli/config/auth.js.map +1 -0
  55. package/dist/cli/config/doctor.d.ts +3 -0
  56. package/dist/cli/config/doctor.d.ts.map +1 -0
  57. package/dist/cli/config/doctor.js +26 -0
  58. package/dist/cli/config/doctor.js.map +1 -0
  59. package/dist/cli/config/get.d.ts +3 -0
  60. package/dist/cli/config/get.d.ts.map +1 -0
  61. package/dist/cli/config/get.js +45 -0
  62. package/dist/cli/config/get.js.map +1 -0
  63. package/dist/cli/config/help.d.ts +18 -0
  64. package/dist/cli/config/help.d.ts.map +1 -0
  65. package/dist/cli/config/help.js +193 -0
  66. package/dist/cli/config/help.js.map +1 -0
  67. package/dist/cli/config/import.d.ts +9 -0
  68. package/dist/cli/config/import.d.ts.map +1 -0
  69. package/dist/cli/config/import.js +88 -0
  70. package/dist/cli/config/import.js.map +1 -0
  71. package/dist/cli/config/index.d.ts +2 -0
  72. package/dist/cli/config/index.d.ts.map +1 -0
  73. package/dist/cli/config/index.js +2 -0
  74. package/dist/cli/config/index.js.map +1 -0
  75. package/dist/cli/config/list.d.ts +7 -0
  76. package/dist/cli/config/list.d.ts.map +1 -0
  77. package/dist/cli/config/list.js +71 -0
  78. package/dist/cli/config/list.js.map +1 -0
  79. package/dist/cli/config/remove.d.ts +3 -0
  80. package/dist/cli/config/remove.d.ts.map +1 -0
  81. package/dist/cli/config/remove.js +19 -0
  82. package/dist/cli/config/remove.js.map +1 -0
  83. package/dist/cli/config/render.d.ts +26 -0
  84. package/dist/cli/config/render.d.ts.map +1 -0
  85. package/dist/cli/config/render.js +99 -0
  86. package/dist/cli/config/render.js.map +1 -0
  87. package/dist/cli/config/shared.d.ts +21 -0
  88. package/dist/cli/config/shared.d.ts.map +1 -0
  89. package/dist/cli/config/shared.js +130 -0
  90. package/dist/cli/config/shared.js.map +1 -0
  91. package/dist/cli/config/types.d.ts +7 -0
  92. package/dist/cli/config/types.d.ts.map +1 -0
  93. package/dist/cli/config/types.js +2 -0
  94. package/dist/cli/config/types.js.map +1 -0
  95. package/dist/cli/config-command.d.ts +7 -0
  96. package/dist/cli/config-command.d.ts.map +1 -0
  97. package/dist/cli/config-command.js +67 -0
  98. package/dist/cli/config-command.js.map +1 -0
  99. package/dist/cli/daemon-command.d.ts +8 -0
  100. package/dist/cli/daemon-command.d.ts.map +1 -0
  101. package/dist/cli/daemon-command.js +219 -0
  102. package/dist/cli/daemon-command.js.map +1 -0
  103. package/dist/cli/emit-ts-command.d.ts +31 -0
  104. package/dist/cli/emit-ts-command.d.ts.map +1 -0
  105. package/dist/cli/emit-ts-command.js +217 -0
  106. package/dist/cli/emit-ts-command.js.map +1 -0
  107. package/dist/cli/emit-ts-templates.d.ts +23 -0
  108. package/dist/cli/emit-ts-templates.d.ts.map +1 -0
  109. package/dist/cli/emit-ts-templates.js +130 -0
  110. package/dist/cli/emit-ts-templates.js.map +1 -0
  111. package/dist/cli/ephemeral-flags.d.ts +7 -0
  112. package/dist/cli/ephemeral-flags.d.ts.map +1 -0
  113. package/dist/cli/ephemeral-flags.js +108 -0
  114. package/dist/cli/ephemeral-flags.js.map +1 -0
  115. package/dist/cli/ephemeral-target.d.ts +16 -0
  116. package/dist/cli/ephemeral-target.d.ts.map +1 -0
  117. package/dist/cli/ephemeral-target.js +105 -0
  118. package/dist/cli/ephemeral-target.js.map +1 -0
  119. package/dist/cli/errors.d.ts +4 -0
  120. package/dist/cli/errors.d.ts.map +1 -0
  121. package/dist/cli/errors.js +7 -0
  122. package/dist/cli/errors.js.map +1 -0
  123. package/dist/cli/flag-utils.d.ts +4 -0
  124. package/dist/cli/flag-utils.d.ts.map +1 -0
  125. package/dist/cli/flag-utils.js +27 -0
  126. package/dist/cli/flag-utils.js.map +1 -0
  127. package/dist/cli/generate/artifacts.d.ts +15 -0
  128. package/dist/cli/generate/artifacts.d.ts.map +1 -0
  129. package/dist/cli/generate/artifacts.js +247 -0
  130. package/dist/cli/generate/artifacts.js.map +1 -0
  131. package/dist/cli/generate/definition.d.ts +22 -0
  132. package/dist/cli/generate/definition.d.ts.map +1 -0
  133. package/dist/cli/generate/definition.js +265 -0
  134. package/dist/cli/generate/definition.js.map +1 -0
  135. package/dist/cli/generate/flag-parser.d.ts +11 -0
  136. package/dist/cli/generate/flag-parser.d.ts.map +1 -0
  137. package/dist/cli/generate/flag-parser.js +41 -0
  138. package/dist/cli/generate/flag-parser.js.map +1 -0
  139. package/dist/cli/generate/flags.d.ts +20 -0
  140. package/dist/cli/generate/flags.d.ts.map +1 -0
  141. package/dist/cli/generate/flags.js +220 -0
  142. package/dist/cli/generate/flags.js.map +1 -0
  143. package/dist/cli/generate/fs-helpers.d.ts +3 -0
  144. package/dist/cli/generate/fs-helpers.d.ts.map +1 -0
  145. package/dist/cli/generate/fs-helpers.js +34 -0
  146. package/dist/cli/generate/fs-helpers.js.map +1 -0
  147. package/dist/cli/generate/name-utils.d.ts +5 -0
  148. package/dist/cli/generate/name-utils.d.ts.map +1 -0
  149. package/dist/cli/generate/name-utils.js +170 -0
  150. package/dist/cli/generate/name-utils.js.map +1 -0
  151. package/dist/cli/generate/output.d.ts +5 -0
  152. package/dist/cli/generate/output.d.ts.map +1 -0
  153. package/dist/cli/generate/output.js +24 -0
  154. package/dist/cli/generate/output.js.map +1 -0
  155. package/dist/cli/generate/runtime.d.ts +3 -0
  156. package/dist/cli/generate/runtime.d.ts.map +1 -0
  157. package/dist/cli/generate/runtime.js +34 -0
  158. package/dist/cli/generate/runtime.js.map +1 -0
  159. package/dist/cli/generate/server-utils.d.ts +3 -0
  160. package/dist/cli/generate/server-utils.d.ts.map +1 -0
  161. package/dist/cli/generate/server-utils.js +33 -0
  162. package/dist/cli/generate/server-utils.js.map +1 -0
  163. package/dist/cli/generate/template-data.d.ts +25 -0
  164. package/dist/cli/generate/template-data.d.ts.map +1 -0
  165. package/dist/cli/generate/template-data.js +90 -0
  166. package/dist/cli/generate/template-data.js.map +1 -0
  167. package/dist/cli/generate/template-help.d.ts +2 -0
  168. package/dist/cli/generate/template-help.d.ts.map +1 -0
  169. package/dist/cli/generate/template-help.js +113 -0
  170. package/dist/cli/generate/template-help.js.map +1 -0
  171. package/dist/cli/generate/template.d.ts +30 -0
  172. package/dist/cli/generate/template.d.ts.map +1 -0
  173. package/dist/cli/generate/template.js +366 -0
  174. package/dist/cli/generate/template.js.map +1 -0
  175. package/dist/cli/generate/tools.d.ts +46 -0
  176. package/dist/cli/generate/tools.d.ts.map +1 -0
  177. package/dist/cli/generate/tools.js +304 -0
  178. package/dist/cli/generate/tools.js.map +1 -0
  179. package/dist/cli/generate/types.d.ts +5 -0
  180. package/dist/cli/generate/types.d.ts.map +1 -0
  181. package/dist/cli/generate/types.js +2 -0
  182. package/dist/cli/generate/types.js.map +1 -0
  183. package/dist/cli/generate-cli-runner.d.ts +3 -0
  184. package/dist/cli/generate-cli-runner.d.ts.map +1 -0
  185. package/dist/cli/generate-cli-runner.js +72 -0
  186. package/dist/cli/generate-cli-runner.js.map +1 -0
  187. package/dist/cli/help-output.d.ts +6 -0
  188. package/dist/cli/help-output.d.ts.map +1 -0
  189. package/dist/cli/help-output.js +186 -0
  190. package/dist/cli/help-output.js.map +1 -0
  191. package/dist/cli/http-utils.d.ts +9 -0
  192. package/dist/cli/http-utils.d.ts.map +1 -0
  193. package/dist/cli/http-utils.js +88 -0
  194. package/dist/cli/http-utils.js.map +1 -0
  195. package/dist/cli/identifier-helpers.d.ts +20 -0
  196. package/dist/cli/identifier-helpers.d.ts.map +1 -0
  197. package/dist/cli/identifier-helpers.js +84 -0
  198. package/dist/cli/identifier-helpers.js.map +1 -0
  199. package/dist/cli/image-output.d.ts +3 -0
  200. package/dist/cli/image-output.d.ts.map +1 -0
  201. package/dist/cli/image-output.js +57 -0
  202. package/dist/cli/image-output.js.map +1 -0
  203. package/dist/cli/inspect-cli-command.d.ts +11 -0
  204. package/dist/cli/inspect-cli-command.d.ts.map +1 -0
  205. package/dist/cli/inspect-cli-command.js +78 -0
  206. package/dist/cli/inspect-cli-command.js.map +1 -0
  207. package/dist/cli/json-output.d.ts +23 -0
  208. package/dist/cli/json-output.d.ts.map +1 -0
  209. package/dist/cli/json-output.js +38 -0
  210. package/dist/cli/json-output.js.map +1 -0
  211. package/dist/cli/list-command.d.ts +15 -0
  212. package/dist/cli/list-command.d.ts.map +1 -0
  213. package/dist/cli/list-command.js +372 -0
  214. package/dist/cli/list-command.js.map +1 -0
  215. package/dist/cli/list-detail-helpers.d.ts +41 -0
  216. package/dist/cli/list-detail-helpers.d.ts.map +1 -0
  217. package/dist/cli/list-detail-helpers.js +99 -0
  218. package/dist/cli/list-detail-helpers.js.map +1 -0
  219. package/dist/cli/list-doc-comments.d.ts +6 -0
  220. package/dist/cli/list-doc-comments.d.ts.map +1 -0
  221. package/dist/cli/list-doc-comments.js +114 -0
  222. package/dist/cli/list-doc-comments.js.map +1 -0
  223. package/dist/cli/list-format.d.ts +38 -0
  224. package/dist/cli/list-format.d.ts.map +1 -0
  225. package/dist/cli/list-format.js +98 -0
  226. package/dist/cli/list-format.js.map +1 -0
  227. package/dist/cli/list-output.d.ts +39 -0
  228. package/dist/cli/list-output.d.ts.map +1 -0
  229. package/dist/cli/list-output.js +159 -0
  230. package/dist/cli/list-output.js.map +1 -0
  231. package/dist/cli/list-signature.d.ts +26 -0
  232. package/dist/cli/list-signature.d.ts.map +1 -0
  233. package/dist/cli/list-signature.js +176 -0
  234. package/dist/cli/list-signature.js.map +1 -0
  235. package/dist/cli/logger-context.d.ts +9 -0
  236. package/dist/cli/logger-context.d.ts.map +1 -0
  237. package/dist/cli/logger-context.js +29 -0
  238. package/dist/cli/logger-context.js.map +1 -0
  239. package/dist/cli/output-format.d.ts +11 -0
  240. package/dist/cli/output-format.d.ts.map +1 -0
  241. package/dist/cli/output-format.js +51 -0
  242. package/dist/cli/output-format.js.map +1 -0
  243. package/dist/cli/output-utils.d.ts +5 -0
  244. package/dist/cli/output-utils.d.ts.map +1 -0
  245. package/dist/cli/output-utils.js +143 -0
  246. package/dist/cli/output-utils.js.map +1 -0
  247. package/dist/cli/path-utils.d.ts +2 -0
  248. package/dist/cli/path-utils.d.ts.map +1 -0
  249. package/dist/cli/path-utils.js +12 -0
  250. package/dist/cli/path-utils.js.map +1 -0
  251. package/dist/cli/runtime-debug.d.ts +4 -0
  252. package/dist/cli/runtime-debug.d.ts.map +1 -0
  253. package/dist/cli/runtime-debug.js +134 -0
  254. package/dist/cli/runtime-debug.js.map +1 -0
  255. package/dist/cli/server-lookup.d.ts +3 -0
  256. package/dist/cli/server-lookup.d.ts.map +1 -0
  257. package/dist/cli/server-lookup.js +21 -0
  258. package/dist/cli/server-lookup.js.map +1 -0
  259. package/dist/cli/terminal.d.ts +10 -0
  260. package/dist/cli/terminal.d.ts.map +1 -0
  261. package/dist/cli/terminal.js +33 -0
  262. package/dist/cli/terminal.js.map +1 -0
  263. package/dist/cli/timeouts.d.ts +9 -0
  264. package/dist/cli/timeouts.d.ts.map +1 -0
  265. package/dist/cli/timeouts.js +55 -0
  266. package/dist/cli/timeouts.js.map +1 -0
  267. package/dist/cli/tool-cache.d.ts +9 -0
  268. package/dist/cli/tool-cache.d.ts.map +1 -0
  269. package/dist/cli/tool-cache.js +31 -0
  270. package/dist/cli/tool-cache.js.map +1 -0
  271. package/dist/cli/transport-utils.d.ts +3 -0
  272. package/dist/cli/transport-utils.d.ts.map +1 -0
  273. package/dist/cli/transport-utils.js +9 -0
  274. package/dist/cli/transport-utils.js.map +1 -0
  275. package/dist/cli-metadata.d.ts +57 -0
  276. package/dist/cli-metadata.d.ts.map +1 -0
  277. package/dist/cli-metadata.js +92 -0
  278. package/dist/cli-metadata.js.map +1 -0
  279. package/dist/cli.d.ts +10 -0
  280. package/dist/cli.d.ts.map +1 -0
  281. package/dist/cli.js +217 -0
  282. package/dist/cli.js.map +1 -0
  283. package/dist/config/imports/external.d.ts +8 -0
  284. package/dist/config/imports/external.d.ts.map +1 -0
  285. package/dist/config/imports/external.js +231 -0
  286. package/dist/config/imports/external.js.map +1 -0
  287. package/dist/config/imports/paths-utils.d.ts +3 -0
  288. package/dist/config/imports/paths-utils.d.ts.map +1 -0
  289. package/dist/config/imports/paths-utils.js +27 -0
  290. package/dist/config/imports/paths-utils.js.map +1 -0
  291. package/dist/config/imports/paths.d.ts +3 -0
  292. package/dist/config/imports/paths.d.ts.map +1 -0
  293. package/dist/config/imports/paths.js +135 -0
  294. package/dist/config/imports/paths.js.map +1 -0
  295. package/dist/config/imports/shared.d.ts +4 -0
  296. package/dist/config/imports/shared.d.ts.map +1 -0
  297. package/dist/config/imports/shared.js +25 -0
  298. package/dist/config/imports/shared.js.map +1 -0
  299. package/dist/config/path-discovery.d.ts +11 -0
  300. package/dist/config/path-discovery.d.ts.map +1 -0
  301. package/dist/config/path-discovery.js +65 -0
  302. package/dist/config/path-discovery.js.map +1 -0
  303. package/dist/config/read-config.d.ts +9 -0
  304. package/dist/config/read-config.d.ts.map +1 -0
  305. package/dist/config/read-config.js +74 -0
  306. package/dist/config/read-config.js.map +1 -0
  307. package/dist/config-imports.d.ts +7 -0
  308. package/dist/config-imports.d.ts.map +1 -0
  309. package/dist/config-imports.js +8 -0
  310. package/dist/config-imports.js.map +1 -0
  311. package/dist/config-normalize.d.ts +8 -0
  312. package/dist/config-normalize.d.ts.map +1 -0
  313. package/dist/config-normalize.js +184 -0
  314. package/dist/config-normalize.js.map +1 -0
  315. package/dist/config-schema.d.ts +164 -0
  316. package/dist/config-schema.d.ts.map +1 -0
  317. package/dist/config-schema.js +103 -0
  318. package/dist/config-schema.js.map +1 -0
  319. package/dist/config.d.ts +17 -0
  320. package/dist/config.d.ts.map +1 -0
  321. package/dist/config.js +91 -0
  322. package/dist/config.js.map +1 -0
  323. package/dist/daemon/client.d.ts +34 -0
  324. package/dist/daemon/client.d.ts.map +1 -0
  325. package/dist/daemon/client.js +291 -0
  326. package/dist/daemon/client.js.map +1 -0
  327. package/dist/daemon/config-layers.d.ts +7 -0
  328. package/dist/daemon/config-layers.d.ts.map +1 -0
  329. package/dist/daemon/config-layers.js +20 -0
  330. package/dist/daemon/config-layers.js.map +1 -0
  331. package/dist/daemon/host.d.ts +32 -0
  332. package/dist/daemon/host.d.ts.map +1 -0
  333. package/dist/daemon/host.js +345 -0
  334. package/dist/daemon/host.js.map +1 -0
  335. package/dist/daemon/launch.d.ts +10 -0
  336. package/dist/daemon/launch.d.ts.map +1 -0
  337. package/dist/daemon/launch.js +35 -0
  338. package/dist/daemon/launch.js.map +1 -0
  339. package/dist/daemon/log-context.d.ts +18 -0
  340. package/dist/daemon/log-context.d.ts.map +1 -0
  341. package/dist/daemon/log-context.js +64 -0
  342. package/dist/daemon/log-context.js.map +1 -0
  343. package/dist/daemon/paths.d.ts +5 -0
  344. package/dist/daemon/paths.d.ts.map +1 -0
  345. package/dist/daemon/paths.js +30 -0
  346. package/dist/daemon/paths.js.map +1 -0
  347. package/dist/daemon/protocol.d.ts +51 -0
  348. package/dist/daemon/protocol.d.ts.map +1 -0
  349. package/dist/daemon/protocol.js +2 -0
  350. package/dist/daemon/protocol.js.map +1 -0
  351. package/dist/daemon/request-utils.d.ts +12 -0
  352. package/dist/daemon/request-utils.d.ts.map +1 -0
  353. package/dist/daemon/request-utils.js +52 -0
  354. package/dist/daemon/request-utils.js.map +1 -0
  355. package/dist/daemon/runtime-wrapper.d.ts +9 -0
  356. package/dist/daemon/runtime-wrapper.d.ts.map +1 -0
  357. package/dist/daemon/runtime-wrapper.js +110 -0
  358. package/dist/daemon/runtime-wrapper.js.map +1 -0
  359. package/dist/env.d.ts +5 -0
  360. package/dist/env.d.ts.map +1 -0
  361. package/dist/env.js +93 -0
  362. package/dist/env.js.map +1 -0
  363. package/dist/error-classifier.d.ts +11 -0
  364. package/dist/error-classifier.d.ts.map +1 -0
  365. package/dist/error-classifier.js +141 -0
  366. package/dist/error-classifier.js.map +1 -0
  367. package/dist/fs-json.d.ts +3 -0
  368. package/dist/fs-json.d.ts.map +1 -0
  369. package/dist/fs-json.js +21 -0
  370. package/dist/fs-json.js.map +1 -0
  371. package/dist/generate-cli.d.ts +32 -0
  372. package/dist/generate-cli.d.ts.map +1 -0
  373. package/dist/generate-cli.js +155 -0
  374. package/dist/generate-cli.js.map +1 -0
  375. package/dist/index.d.ts +9 -0
  376. package/dist/index.d.ts.map +1 -0
  377. package/dist/index.js +5 -0
  378. package/dist/index.js.map +1 -0
  379. package/dist/lifecycle.d.ts +8 -0
  380. package/dist/lifecycle.d.ts.map +1 -0
  381. package/dist/lifecycle.js +106 -0
  382. package/dist/lifecycle.js.map +1 -0
  383. package/dist/logging.d.ts +19 -0
  384. package/dist/logging.d.ts.map +1 -0
  385. package/dist/logging.js +76 -0
  386. package/dist/logging.js.map +1 -0
  387. package/dist/oauth-manual.d.ts +9 -0
  388. package/dist/oauth-manual.d.ts.map +1 -0
  389. package/dist/oauth-manual.js +84 -0
  390. package/dist/oauth-manual.js.map +1 -0
  391. package/dist/oauth-persistence.d.ts +20 -0
  392. package/dist/oauth-persistence.d.ts.map +1 -0
  393. package/dist/oauth-persistence.js +254 -0
  394. package/dist/oauth-persistence.js.map +1 -0
  395. package/dist/oauth-vault.d.ts +19 -0
  396. package/dist/oauth-vault.d.ts.map +1 -0
  397. package/dist/oauth-vault.js +100 -0
  398. package/dist/oauth-vault.js.map +1 -0
  399. package/dist/oauth.d.ts +31 -0
  400. package/dist/oauth.d.ts.map +1 -0
  401. package/dist/oauth.js +414 -0
  402. package/dist/oauth.js.map +1 -0
  403. package/dist/result-utils.d.ts +22 -0
  404. package/dist/result-utils.d.ts.map +1 -0
  405. package/dist/result-utils.js +229 -0
  406. package/dist/result-utils.js.map +1 -0
  407. package/dist/runtime/errors.d.ts +2 -0
  408. package/dist/runtime/errors.d.ts.map +1 -0
  409. package/dist/runtime/errors.js +16 -0
  410. package/dist/runtime/errors.js.map +1 -0
  411. package/dist/runtime/http-transport.d.ts +15 -0
  412. package/dist/runtime/http-transport.d.ts.map +1 -0
  413. package/dist/runtime/http-transport.js +91 -0
  414. package/dist/runtime/http-transport.js.map +1 -0
  415. package/dist/runtime/manual-oauth.d.ts +8 -0
  416. package/dist/runtime/manual-oauth.d.ts.map +1 -0
  417. package/dist/runtime/manual-oauth.js +81 -0
  418. package/dist/runtime/manual-oauth.js.map +1 -0
  419. package/dist/runtime/oauth.d.ts +22 -0
  420. package/dist/runtime/oauth.d.ts.map +1 -0
  421. package/dist/runtime/oauth.js +83 -0
  422. package/dist/runtime/oauth.js.map +1 -0
  423. package/dist/runtime/transport.d.ts +24 -0
  424. package/dist/runtime/transport.d.ts.map +1 -0
  425. package/dist/runtime/transport.js +165 -0
  426. package/dist/runtime/transport.js.map +1 -0
  427. package/dist/runtime/utils.d.ts +5 -0
  428. package/dist/runtime/utils.d.ts.map +1 -0
  429. package/dist/runtime/utils.js +47 -0
  430. package/dist/runtime/utils.js.map +1 -0
  431. package/dist/runtime-header-utils.d.ts +2 -0
  432. package/dist/runtime-header-utils.d.ts.map +1 -0
  433. package/dist/runtime-header-utils.js +19 -0
  434. package/dist/runtime-header-utils.js.map +1 -0
  435. package/dist/runtime-oauth-support.d.ts +5 -0
  436. package/dist/runtime-oauth-support.d.ts.map +1 -0
  437. package/dist/runtime-oauth-support.js +21 -0
  438. package/dist/runtime-oauth-support.js.map +1 -0
  439. package/dist/runtime-process-utils.d.ts +11 -0
  440. package/dist/runtime-process-utils.d.ts.map +1 -0
  441. package/dist/runtime-process-utils.js +299 -0
  442. package/dist/runtime-process-utils.js.map +1 -0
  443. package/dist/runtime.d.ts +55 -0
  444. package/dist/runtime.d.ts.map +1 -0
  445. package/dist/runtime.js +245 -0
  446. package/dist/runtime.js.map +1 -0
  447. package/dist/schema-cache.d.ts +10 -0
  448. package/dist/schema-cache.d.ts.map +1 -0
  449. package/dist/schema-cache.js +40 -0
  450. package/dist/schema-cache.js.map +1 -0
  451. package/dist/sdk-patches.d.ts +5 -0
  452. package/dist/sdk-patches.d.ts.map +1 -0
  453. package/dist/sdk-patches.js +399 -0
  454. package/dist/sdk-patches.js.map +1 -0
  455. package/dist/server-proxy.d.ts +17 -0
  456. package/dist/server-proxy.d.ts.map +1 -0
  457. package/dist/server-proxy.js +342 -0
  458. package/dist/server-proxy.js.map +1 -0
  459. package/docs/RELEASE.md +96 -0
  460. package/docs/adhoc.md +76 -0
  461. package/docs/call-heuristic.md +31 -0
  462. package/docs/call-syntax.md +75 -0
  463. package/docs/cli-generator.md +116 -0
  464. package/docs/cli-reference.md +76 -0
  465. package/docs/config.md +208 -0
  466. package/docs/daemon.md +95 -0
  467. package/docs/emit-ts.md +98 -0
  468. package/docs/hang-debug.md +88 -0
  469. package/docs/import.md +59 -0
  470. package/docs/known-issues.md +33 -0
  471. package/docs/livetests.md +31 -0
  472. package/docs/local.md +73 -0
  473. package/docs/logging.md +67 -0
  474. package/docs/manual-testing.md +78 -0
  475. package/docs/mcp.md +44 -0
  476. package/docs/migration.md +77 -0
  477. package/docs/pnpm-mcp-migration.md +15 -0
  478. package/docs/refactor.md +76 -0
  479. package/docs/shortcuts.md +31 -0
  480. package/docs/spec.md +86 -0
  481. package/docs/subagent.md +39 -0
  482. package/docs/supabase-auth-issue.md +53 -0
  483. package/docs/tmux.md +30 -0
  484. package/docs/tool-calling.md +73 -0
  485. package/docs/windows.md +25 -0
  486. package/examples/context7-headlines.ts +72 -0
  487. package/git +3 -0
  488. package/mcporter.png +0 -0
  489. package/mcporter.schema.json +263 -0
  490. package/package.json +105 -0
  491. package/pnpm-workspace.yaml +2 -0
  492. package/runner +13 -0
  493. package/scripts/agent-send.ts +179 -0
  494. package/scripts/build-bun.ts +125 -0
  495. package/scripts/committer +53 -0
  496. package/scripts/docs-list.ts +132 -0
  497. package/scripts/generate-json-schema.ts +50 -0
  498. package/scripts/git-policy.ts +165 -0
  499. package/scripts/mcp_signoz_retry_patch.cjs +9 -0
  500. package/scripts/release.sh +86 -0
  501. package/scripts/runner.ts +1556 -0
  502. package/scripts/test-runner.js +39 -0
  503. package/src/cli/adhoc-server.ts +263 -0
  504. package/src/cli/auth-command.ts +290 -0
  505. package/src/cli/call-argument-expression.ts +61 -0
  506. package/src/cli/call-argument-values.ts +95 -0
  507. package/src/cli/call-arguments.ts +246 -0
  508. package/src/cli/call-command.ts +478 -0
  509. package/src/cli/call-expression-parser.ts +210 -0
  510. package/src/cli/cli-factory.ts +51 -0
  511. package/src/cli/command-inference.ts +99 -0
  512. package/src/cli/config/add.ts +308 -0
  513. package/src/cli/config/auth.ts +23 -0
  514. package/src/cli/config/doctor.ts +27 -0
  515. package/src/cli/config/get.ts +47 -0
  516. package/src/cli/config/help.ts +213 -0
  517. package/src/cli/config/import.ts +97 -0
  518. package/src/cli/config/index.ts +1 -0
  519. package/src/cli/config/list.ts +81 -0
  520. package/src/cli/config/remove.ts +20 -0
  521. package/src/cli/config/render.ts +119 -0
  522. package/src/cli/config/shared.ts +159 -0
  523. package/src/cli/config/types.ts +8 -0
  524. package/src/cli/config-command.ts +72 -0
  525. package/src/cli/daemon-command.ts +260 -0
  526. package/src/cli/emit-ts-command.ts +260 -0
  527. package/src/cli/emit-ts-templates.ts +161 -0
  528. package/src/cli/ephemeral-flags.ts +128 -0
  529. package/src/cli/ephemeral-target.ts +134 -0
  530. package/src/cli/errors.ts +6 -0
  531. package/src/cli/flag-utils.ts +29 -0
  532. package/src/cli/generate/artifacts.ts +308 -0
  533. package/src/cli/generate/definition.ts +325 -0
  534. package/src/cli/generate/flag-parser.ts +50 -0
  535. package/src/cli/generate/flags.ts +248 -0
  536. package/src/cli/generate/fs-helpers.ts +34 -0
  537. package/src/cli/generate/name-utils.ts +176 -0
  538. package/src/cli/generate/output.ts +27 -0
  539. package/src/cli/generate/runtime.ts +38 -0
  540. package/src/cli/generate/server-utils.ts +38 -0
  541. package/src/cli/generate/template-data.ts +126 -0
  542. package/src/cli/generate/template-help.ts +112 -0
  543. package/src/cli/generate/template.ts +407 -0
  544. package/src/cli/generate/tools.ts +354 -0
  545. package/src/cli/generate/types.ts +1 -0
  546. package/src/cli/generate-cli-runner.ts +82 -0
  547. package/src/cli/help-output.ts +207 -0
  548. package/src/cli/http-utils.ts +89 -0
  549. package/src/cli/identifier-helpers.ts +107 -0
  550. package/src/cli/image-output.ts +62 -0
  551. package/src/cli/inspect-cli-command.ts +89 -0
  552. package/src/cli/json-output.ts +60 -0
  553. package/src/cli/list-command.ts +432 -0
  554. package/src/cli/list-detail-helpers.ts +179 -0
  555. package/src/cli/list-doc-comments.ts +129 -0
  556. package/src/cli/list-format.ts +150 -0
  557. package/src/cli/list-output.ts +224 -0
  558. package/src/cli/list-signature.ts +217 -0
  559. package/src/cli/logger-context.ts +36 -0
  560. package/src/cli/output-format.ts +63 -0
  561. package/src/cli/output-utils.ts +161 -0
  562. package/src/cli/path-utils.ts +13 -0
  563. package/src/cli/runtime-debug.ts +141 -0
  564. package/src/cli/server-lookup.ts +22 -0
  565. package/src/cli/terminal.ts +41 -0
  566. package/src/cli/timeouts.ts +67 -0
  567. package/src/cli/tool-cache.ts +43 -0
  568. package/src/cli/transport-utils.ts +10 -0
  569. package/src/cli-metadata.ts +164 -0
  570. package/src/cli.ts +234 -0
  571. package/src/config/imports/external.ts +284 -0
  572. package/src/config/imports/paths-utils.ts +29 -0
  573. package/src/config/imports/paths.ts +145 -0
  574. package/src/config/imports/shared.ts +27 -0
  575. package/src/config/path-discovery.ts +79 -0
  576. package/src/config/read-config.ts +91 -0
  577. package/src/config-imports.ts +12 -0
  578. package/src/config-normalize.ts +220 -0
  579. package/src/config-schema.ts +175 -0
  580. package/src/config.ts +136 -0
  581. package/src/daemon/client.ts +350 -0
  582. package/src/daemon/config-layers.ts +23 -0
  583. package/src/daemon/host.ts +455 -0
  584. package/src/daemon/launch.ts +45 -0
  585. package/src/daemon/log-context.ts +78 -0
  586. package/src/daemon/paths.ts +35 -0
  587. package/src/daemon/protocol.ts +57 -0
  588. package/src/daemon/request-utils.ts +67 -0
  589. package/src/daemon/runtime-wrapper.ts +135 -0
  590. package/src/env.ts +107 -0
  591. package/src/error-classifier.ts +158 -0
  592. package/src/fs-json.ts +21 -0
  593. package/src/generate-cli.ts +211 -0
  594. package/src/index.ts +14 -0
  595. package/src/lifecycle.ts +138 -0
  596. package/src/logging.ts +93 -0
  597. package/src/oauth-manual.ts +103 -0
  598. package/src/oauth-persistence.ts +316 -0
  599. package/src/oauth-vault.ts +128 -0
  600. package/src/oauth.ts +494 -0
  601. package/src/result-utils.ts +278 -0
  602. package/src/runtime/errors.ts +17 -0
  603. package/src/runtime/oauth.ts +112 -0
  604. package/src/runtime/transport.ts +198 -0
  605. package/src/runtime/utils.ts +54 -0
  606. package/src/runtime-header-utils.ts +23 -0
  607. package/src/runtime-oauth-support.ts +24 -0
  608. package/src/runtime-process-utils.ts +324 -0
  609. package/src/runtime.ts +321 -0
  610. package/src/schema-cache.ts +49 -0
  611. package/src/sdk-patches.ts +498 -0
  612. package/src/server-proxy.ts +407 -0
  613. package/tests/adhoc-server.test.ts +49 -0
  614. package/tests/call-arguments.test.ts +111 -0
  615. package/tests/cli-auth-help.test.ts +43 -0
  616. package/tests/cli-auth-retry.test.ts +41 -0
  617. package/tests/cli-auth.test.ts +96 -0
  618. package/tests/cli-call-args.test.ts +69 -0
  619. package/tests/cli-call-errors.test.ts +27 -0
  620. package/tests/cli-call-execution.test.ts +279 -0
  621. package/tests/cli-call-help.test.ts +43 -0
  622. package/tests/cli-command-inference.test.ts +73 -0
  623. package/tests/cli-config-command.test.ts +371 -0
  624. package/tests/cli-config-fallback.test.ts +259 -0
  625. package/tests/cli-config-routing.test.ts +20 -0
  626. package/tests/cli-ephemeral-flags.test.ts +54 -0
  627. package/tests/cli-flag-utils.test.ts +17 -0
  628. package/tests/cli-generate-artifacts.test.ts +52 -0
  629. package/tests/cli-generate-cli.integration.test.ts +675 -0
  630. package/tests/cli-generate-runner.test.ts +156 -0
  631. package/tests/cli-global-flags.test.ts +61 -0
  632. package/tests/cli-help-shortcuts.test.ts +42 -0
  633. package/tests/cli-image-output.test.ts +65 -0
  634. package/tests/cli-inspect-command.test.ts +15 -0
  635. package/tests/cli-list-classification.test.ts +291 -0
  636. package/tests/cli-list-flags.test.ts +83 -0
  637. package/tests/cli-list-formatting.test.ts +358 -0
  638. package/tests/cli-list-help.test.ts +43 -0
  639. package/tests/cli-list-json.test.ts +55 -0
  640. package/tests/cli-list-stdio-logs.test.ts +108 -0
  641. package/tests/cli-list-verbose-e2e.test.ts +83 -0
  642. package/tests/cli-oauth-timeout-flag.test.ts +94 -0
  643. package/tests/cli-output-utils.test.ts +129 -0
  644. package/tests/cli-regenerate.test.ts +261 -0
  645. package/tests/cli-version.test.ts +24 -0
  646. package/tests/config-add-dry-run.test.ts +45 -0
  647. package/tests/config-add-flags.test.ts +61 -0
  648. package/tests/config-add-imports.test.ts +28 -0
  649. package/tests/config-add-persist.test.ts +27 -0
  650. package/tests/config-add-scope-behavior.test.ts +46 -0
  651. package/tests/config-add-scope.test.ts +101 -0
  652. package/tests/config-add-sse.test.ts +23 -0
  653. package/tests/config-command-string.test.ts +96 -0
  654. package/tests/config-doctor.test.ts +45 -0
  655. package/tests/config-get-json.test.ts +24 -0
  656. package/tests/config-import-dedupe.test.ts +27 -0
  657. package/tests/config-import-paths.test.ts +49 -0
  658. package/tests/config-import.test.ts +64 -0
  659. package/tests/config-imports-unit.test.ts +337 -0
  660. package/tests/config-imports.test.ts +417 -0
  661. package/tests/config-layered.test.ts +178 -0
  662. package/tests/config-list-text-footer.test.ts +33 -0
  663. package/tests/config-list.test.ts +62 -0
  664. package/tests/config-missing.test.ts +140 -0
  665. package/tests/config-normalize.test.ts +71 -0
  666. package/tests/config-remove.test.ts +44 -0
  667. package/tests/config-render.test.ts +61 -0
  668. package/tests/config-resolution.test.ts +94 -0
  669. package/tests/config-schema-file.test.ts +29 -0
  670. package/tests/config-shared.test.ts +41 -0
  671. package/tests/config-sources.test.ts +58 -0
  672. package/tests/daemon-cli-command.test.ts +112 -0
  673. package/tests/daemon-client-config-stale.test.ts +222 -0
  674. package/tests/daemon-client-timeout.test.ts +114 -0
  675. package/tests/daemon-client.test.ts +61 -0
  676. package/tests/daemon-host.test.ts +33 -0
  677. package/tests/daemon.integration.test.ts +175 -0
  678. package/tests/emit-ts.test.ts +125 -0
  679. package/tests/ephemeral-target.test.ts +26 -0
  680. package/tests/error-classifier.test.ts +46 -0
  681. package/tests/fixtures/ansi.ts +18 -0
  682. package/tests/fixtures/cli-list-fixtures.ts +43 -0
  683. package/tests/fixtures/config-fixture.ts +29 -0
  684. package/tests/fixtures/imports/.claude/mcp.json +8 -0
  685. package/tests/fixtures/imports/.claude/settings.json +10 -0
  686. package/tests/fixtures/imports/.claude/settings.local.json +10 -0
  687. package/tests/fixtures/imports/.codeium/windsurf/mcp_config.json +14 -0
  688. package/tests/fixtures/imports/.codex/config.toml +7 -0
  689. package/tests/fixtures/imports/.config/opencode/opencode.jsonc +10 -0
  690. package/tests/fixtures/imports/.cursor/mcp.json +14 -0
  691. package/tests/fixtures/imports/Library/Application Support/Code/User/mcp.json +11 -0
  692. package/tests/fixtures/imports/config/mcporter.json +11 -0
  693. package/tests/fixtures/imports/home/.claude/settings.json +7 -0
  694. package/tests/fixtures/imports/home/.codeium/windsurf/mcp_config.json +14 -0
  695. package/tests/fixtures/imports/home/.codex/config.toml +7 -0
  696. package/tests/fixtures/imports/home/Library/Application Support/Code/User/mcp.json +11 -0
  697. package/tests/fixtures/imports/opencode.jsonc +11 -0
  698. package/tests/fixtures/mcporter.json +64 -0
  699. package/tests/fixtures/stdio-filesystem-server.mjs +63 -0
  700. package/tests/fixtures/stdio-memory-server.mjs +58 -0
  701. package/tests/fixtures/test-helpers.ts +24 -0
  702. package/tests/fixtures/tool-fixtures.ts +35 -0
  703. package/tests/fs-json.test.ts +35 -0
  704. package/tests/generate-cli-helpers.test.ts +162 -0
  705. package/tests/generate-cli.test.ts +595 -0
  706. package/tests/generate-definition.test.ts +25 -0
  707. package/tests/generator-flag-parser.test.ts +19 -0
  708. package/tests/index-api.test.ts +136 -0
  709. package/tests/keep-alive-runtime.test.ts +152 -0
  710. package/tests/lifecycle.test.ts +29 -0
  711. package/tests/list-detail-helpers.test.ts +204 -0
  712. package/tests/list-format.test.ts +40 -0
  713. package/tests/list-inline-stdio.test.ts +71 -0
  714. package/tests/list-output.test.ts +138 -0
  715. package/tests/live/deepwiki-live.test.ts +53 -0
  716. package/tests/oauth-callback.test.ts +108 -0
  717. package/tests/oauth-open-external.test.ts +29 -0
  718. package/tests/oauth-persistence.test.ts +146 -0
  719. package/tests/oauth-session.test.ts +216 -0
  720. package/tests/result-utils.test.ts +254 -0
  721. package/tests/runtime-call-timeout.test.ts +75 -0
  722. package/tests/runtime-compose.test.ts +298 -0
  723. package/tests/runtime-error-reset.test.ts +65 -0
  724. package/tests/runtime-header-utils.test.ts +36 -0
  725. package/tests/runtime-integration.test.ts +113 -0
  726. package/tests/runtime-oauth-connect.test.ts +72 -0
  727. package/tests/runtime-oauth-detection.test.ts +72 -0
  728. package/tests/runtime-oauth-timeout.test.ts +60 -0
  729. package/tests/runtime-oauth-utils.test.ts +14 -0
  730. package/tests/runtime-process-utils.test.ts +53 -0
  731. package/tests/runtime-transport.test.ts +69 -0
  732. package/tests/runtime-utils.test.ts +31 -0
  733. package/tests/runtime.test.ts +94 -0
  734. package/tests/sdk-patches.test.ts +24 -0
  735. package/tests/server-proxy.test.ts +336 -0
  736. package/tests/stdio-servers.integration.test.ts +139 -0
  737. package/tests/tool-cache.test.ts +42 -0
  738. package/tests/version-consistency.test.ts +11 -0
  739. package/tsconfig.build.json +11 -0
  740. package/tsconfig.json +17 -0
  741. package/vitest.config.ts +18 -0
@@ -0,0 +1,83 @@
1
+ import { describe, expect, it, vi } from 'vitest';
2
+ import type { ServerDefinition } from '../src/config.js';
3
+ import { cliModulePromise } from './fixtures/cli-list-fixtures.js';
4
+
5
+ describe('CLI list flag parsing', () => {
6
+ it('parses --timeout flag into list flags', async () => {
7
+ const { extractListFlags } = await cliModulePromise;
8
+ const args = ['--timeout', '7500', '--schema', 'server'];
9
+ const flags = extractListFlags(args);
10
+ expect(flags).toEqual({
11
+ schema: true,
12
+ timeoutMs: 7500,
13
+ requiredOnly: true,
14
+ includeSources: false,
15
+ verbose: false,
16
+ ephemeral: undefined,
17
+ format: 'text',
18
+ });
19
+ expect(args).toEqual(['server']);
20
+ });
21
+
22
+ it('parses --all-parameters flag and removes it from args', async () => {
23
+ const { extractListFlags } = await cliModulePromise;
24
+ const args = ['--all-parameters', 'server'];
25
+ const flags = extractListFlags(args);
26
+ expect(flags).toEqual({
27
+ schema: false,
28
+ timeoutMs: undefined,
29
+ requiredOnly: false,
30
+ includeSources: false,
31
+ verbose: false,
32
+ ephemeral: undefined,
33
+ format: 'text',
34
+ });
35
+ expect(args).toEqual(['server']);
36
+ });
37
+
38
+ it('parses --json flag and removes it from args', async () => {
39
+ const { extractListFlags } = await cliModulePromise;
40
+ const args = ['--json', 'server'];
41
+ const flags = extractListFlags(args);
42
+ expect(flags.format).toBe('json');
43
+ expect(args).toEqual(['server']);
44
+ });
45
+
46
+ it('treats --sse as a hidden alias for --http-url in ad-hoc mode', async () => {
47
+ const { extractListFlags } = await cliModulePromise;
48
+ const args = ['--sse', 'https://mcp.example.com/sse', 'list'];
49
+ const flags = extractListFlags(args);
50
+ expect(flags.ephemeral).toEqual({ httpUrl: 'https://mcp.example.com/sse' });
51
+ expect(args).toEqual(['list']);
52
+ });
53
+
54
+ it('honors --timeout when listing a single server', async () => {
55
+ const { handleList } = await cliModulePromise;
56
+ const definition: ServerDefinition = {
57
+ name: 'slow-server',
58
+ command: { kind: 'stdio', command: 'noop', args: [], cwd: process.cwd() },
59
+ source: { kind: 'local', path: '/tmp/config.json' },
60
+ };
61
+
62
+ const runtime = {
63
+ getDefinitions: () => [definition],
64
+ getDefinition: () => definition,
65
+ listTools: () =>
66
+ new Promise((resolve) => {
67
+ setTimeout(() => resolve([{ name: 'ok' }]), 50);
68
+ }),
69
+ } as unknown as Awaited<ReturnType<typeof import('../src/runtime.js')['createRuntime']>>;
70
+
71
+ const logSpy = vi.spyOn(console, 'log').mockImplementation(() => {});
72
+ const warnSpy = vi.spyOn(console, 'warn').mockImplementation(() => {});
73
+
74
+ await handleList(runtime, ['--timeout', '10', 'slow-server']);
75
+
76
+ const warningLines = warnSpy.mock.calls.map((call) => call[0]);
77
+ expect(warningLines).toContain(' Tools: <timed out after 10ms>');
78
+ expect(warningLines).toContain(' Reason: Timeout');
79
+
80
+ logSpy.mockRestore();
81
+ warnSpy.mockRestore();
82
+ });
83
+ });
@@ -0,0 +1,358 @@
1
+ import { describe, expect, it, vi } from 'vitest';
2
+ import type { ServerDefinition } from '../src/config.js';
3
+ import { stripAnsi } from './fixtures/ansi.js';
4
+ import { buildLinearDocumentsTool, cliModulePromise, linearDefinition } from './fixtures/cli-list-fixtures.js';
5
+
6
+ describe('CLI list formatting', () => {
7
+ it('prints detailed usage for single server listings', async () => {
8
+ const { handleList } = await cliModulePromise;
9
+ const listToolsSpy = vi.fn((_name: string, options?: { includeSchema?: boolean }) =>
10
+ Promise.resolve([
11
+ {
12
+ name: 'add',
13
+ description: 'Add two numbers',
14
+ inputSchema: options?.includeSchema
15
+ ? {
16
+ type: 'object',
17
+ properties: {
18
+ a: { type: 'number', description: 'First operand' },
19
+ format: { type: 'string', enum: ['json', 'markdown'], description: 'Output serialization format' },
20
+ dueBefore: { type: 'string', format: 'date-time', description: 'ISO 8601 timestamp' },
21
+ },
22
+ required: ['a'],
23
+ }
24
+ : undefined,
25
+ outputSchema: options?.includeSchema
26
+ ? {
27
+ type: 'object',
28
+ properties: {
29
+ result: { type: 'array', description: 'List of calculation results' },
30
+ total: { type: 'number', description: 'Total results returned' },
31
+ },
32
+ }
33
+ : undefined,
34
+ },
35
+ ])
36
+ );
37
+ const runtime = {
38
+ getDefinition: (name: string) => ({
39
+ name,
40
+ description: 'Test integration server',
41
+ command: { kind: 'http', url: new URL('https://example.com/mcp') },
42
+ }),
43
+ listTools: listToolsSpy,
44
+ } as unknown as Awaited<ReturnType<typeof import('../src/runtime.js')['createRuntime']>>;
45
+
46
+ const logSpy = vi.spyOn(console, 'log').mockImplementation(() => {});
47
+
48
+ await handleList(runtime, ['calculator']);
49
+
50
+ const rawLines = logSpy.mock.calls.map((call) => call.join(' '));
51
+ const lines = rawLines.map(stripAnsi);
52
+
53
+ const headerLine = lines.find((line) => line.trim().startsWith('calculator -'));
54
+ expect(headerLine).toBeDefined();
55
+ const summaryLine = lines.find((line) => line.includes('HTTP https://example.com/mcp'));
56
+ expect(summaryLine).toBeDefined();
57
+ expect(summaryLine).toMatch(/1 tool/);
58
+ expect(summaryLine).toMatch(/ms/);
59
+ expect(summaryLine).toContain('HTTP https://example.com/mcp');
60
+ expect(lines.some((line) => line.includes('/**'))).toBe(true);
61
+ const paramLineIndex = lines.findIndex((line) => line.includes('@param a'));
62
+ expect(paramLineIndex).toBeGreaterThan(1);
63
+ expect(lines[paramLineIndex - 1]?.trim()).toBe('*');
64
+ expect(lines.some((line) => line.includes('@param a') && line.includes('First operand'))).toBe(true);
65
+ expect(lines.some((line) => line.includes('function add('))).toBe(true);
66
+ expect(lines.some((line) => line.includes('format?: "json" | "markdown"'))).toBe(true);
67
+ expect(lines.some((line) => line.includes('dueBefore?: string'))).toBe(true);
68
+ expect(lines.some((line) => line.includes('Examples:'))).toBe(true);
69
+ expect(lines.some((line) => line.includes('mcporter call calculator.add(a: 1'))).toBe(true);
70
+ expect(
71
+ lines.some((line) => line.includes('Optional parameters hidden; run with --all-parameters to view all fields'))
72
+ ).toBe(false);
73
+ expect(listToolsSpy).toHaveBeenCalledWith('calculator', expect.objectContaining({ includeSchema: true }));
74
+
75
+ logSpy.mockRestore();
76
+ });
77
+
78
+ it('emits JSON summaries for multi-server listings when --json is provided', async () => {
79
+ const { handleList } = await cliModulePromise;
80
+ const originalCI = process.env.CI;
81
+ process.env.CI = '1';
82
+ const definitions: ServerDefinition[] = [
83
+ linearDefinition,
84
+ {
85
+ name: 'github',
86
+ command: { kind: 'http', url: new URL('https://example.com/mcp') },
87
+ },
88
+ ];
89
+ const runtime = {
90
+ getDefinitions: () => definitions,
91
+ listTools: (name: string) => {
92
+ if (name === 'linear') {
93
+ return Promise.resolve([{ name: 'list_documents' }]);
94
+ }
95
+ return Promise.reject(new Error('HTTP error 500: upstream unavailable'));
96
+ },
97
+ } as unknown as Awaited<ReturnType<typeof import('../src/runtime.js')['createRuntime']>>;
98
+ const logSpy = vi.spyOn(console, 'log').mockImplementation(() => {});
99
+ await handleList(runtime, ['--json']);
100
+ const payload = JSON.parse(logSpy.mock.calls.at(-1)?.[0] ?? '{}');
101
+ expect(payload.mode).toBe('list');
102
+ expect(payload.servers).toHaveLength(2);
103
+ const github = payload.servers.find((entry: { name: string }) => entry.name === 'github');
104
+ expect(github.status).toBe('http');
105
+ const linear = payload.servers.find((entry: { name: string }) => entry.name === 'linear');
106
+ expect(linear.tools[0].name).toBe('list_documents');
107
+ logSpy.mockRestore();
108
+ process.env.CI = originalCI;
109
+ });
110
+
111
+ it('emits JSON payloads for single server listings when --json is provided', async () => {
112
+ const { handleList } = await cliModulePromise;
113
+ const toolCache = await import('../src/cli/tool-cache.js');
114
+ const metadata = [
115
+ {
116
+ tool: {
117
+ name: 'add',
118
+ description: 'Add numbers',
119
+ inputSchema: { type: 'object', properties: { a: { type: 'number' } }, required: ['a'] },
120
+ outputSchema: { type: 'number' },
121
+ },
122
+ methodName: 'add',
123
+ options: [],
124
+ },
125
+ ];
126
+ const metadataSpy = vi.spyOn(toolCache, 'loadToolMetadata').mockResolvedValue(metadata as never);
127
+ const definition: ServerDefinition = {
128
+ name: 'linear',
129
+ description: 'Hosted Linear MCP',
130
+ command: { kind: 'http', url: new URL('https://example.com/mcp') },
131
+ };
132
+ const runtime = {
133
+ getDefinitions: () => [definition],
134
+ getDefinition: () => definition,
135
+ registerDefinition: vi.fn(),
136
+ } as unknown as Awaited<ReturnType<typeof import('../src/runtime.js')['createRuntime']>>;
137
+
138
+ const logSpy = vi.spyOn(console, 'log').mockImplementation(() => {});
139
+
140
+ await handleList(runtime, ['--json', 'linear']);
141
+
142
+ const payload = JSON.parse(logSpy.mock.calls.at(-1)?.[0] ?? '{}');
143
+ expect(payload.mode).toBe('server');
144
+ expect(payload.status).toBe('ok');
145
+ expect(payload.tools[0].name).toBe('add');
146
+
147
+ logSpy.mockRestore();
148
+ metadataSpy.mockRestore();
149
+ });
150
+
151
+ it('summarizes hidden optional parameters and hints include flag', async () => {
152
+ const { handleList } = await cliModulePromise;
153
+ const listToolsSpy = vi.fn((_name: string, options?: { includeSchema?: boolean }) =>
154
+ Promise.resolve([buildLinearDocumentsTool(options?.includeSchema)])
155
+ );
156
+ const runtime = {
157
+ getDefinition: () => linearDefinition,
158
+ listTools: listToolsSpy,
159
+ } as unknown as Awaited<ReturnType<typeof import('../src/runtime.js')['createRuntime']>>;
160
+
161
+ const logSpy = vi.spyOn(console, 'log').mockImplementation(() => {});
162
+
163
+ await handleList(runtime, ['linear']);
164
+
165
+ const lines = logSpy.mock.calls.map((call) => stripAnsi(call.join(' ')));
166
+ expect(lines.some((line) => line.includes('function list_documents('))).toBe(true);
167
+ expect(
168
+ lines.some((line) => line.includes('// optional (4): projectId, initiativeId, creatorId, includeArchived'))
169
+ ).toBe(true);
170
+ expect(
171
+ lines.some((line) => line.includes('Optional parameters hidden; run with --all-parameters to view all fields'))
172
+ ).toBe(true);
173
+ expect(listToolsSpy).toHaveBeenCalledWith('linear', expect.objectContaining({ includeSchema: true }));
174
+
175
+ logSpy.mockRestore();
176
+ });
177
+
178
+ it('truncates long examples for readability', async () => {
179
+ const { handleList } = await cliModulePromise;
180
+ const listToolsSpy = vi.fn((_name: string, options?: { includeSchema?: boolean }) =>
181
+ Promise.resolve([buildLinearDocumentsTool(options?.includeSchema)])
182
+ );
183
+ const runtime = {
184
+ getDefinition: () => linearDefinition,
185
+ listTools: listToolsSpy,
186
+ } as unknown as Awaited<ReturnType<typeof import('../src/runtime.js')['createRuntime']>>;
187
+
188
+ const logSpy = vi.spyOn(console, 'log').mockImplementation(() => {});
189
+
190
+ await handleList(runtime, ['linear']);
191
+
192
+ const lines = logSpy.mock.calls.map((call) => stripAnsi(call.join(' ')));
193
+ const exampleLines = lines.filter((line) => line.includes('mcporter call linear.'));
194
+ expect(exampleLines).toHaveLength(1);
195
+ const exampleLine = exampleLines[0] as string;
196
+ expect(exampleLine.length).toBeLessThanOrEqual(90);
197
+ expect(exampleLine).toMatch(/, ...\)$/);
198
+
199
+ logSpy.mockRestore();
200
+ });
201
+
202
+ it('indents multi-line parameter docs beneath the @param label', async () => {
203
+ const { handleList } = await cliModulePromise;
204
+ const listToolsSpy = vi.fn((_name: string, options?: { includeSchema?: boolean }) =>
205
+ Promise.resolve([
206
+ {
207
+ name: 'list_projects',
208
+ description: 'List Vercel projects',
209
+ inputSchema: options?.includeSchema
210
+ ? {
211
+ type: 'object',
212
+ properties: {
213
+ teamId: {
214
+ type: 'string',
215
+ description: `The team ID to target.\nTeam IDs start with "team_".\n- Read the file .vercel/project.json\n- Use the list_teams tool`,
216
+ },
217
+ },
218
+ required: ['teamId'],
219
+ }
220
+ : undefined,
221
+ },
222
+ ])
223
+ );
224
+ const runtime = {
225
+ getDefinition: () => linearDefinition,
226
+ listTools: listToolsSpy,
227
+ } as unknown as Awaited<ReturnType<typeof import('../src/runtime.js')['createRuntime']>>;
228
+
229
+ const logSpy = vi.spyOn(console, 'log').mockImplementation(() => {});
230
+
231
+ await handleList(runtime, ['linear']);
232
+
233
+ const lines = logSpy.mock.calls.map((call) => stripAnsi(call.join(' ')));
234
+ expect(lines.some((line) => line.includes('@param teamId'))).toBe(true);
235
+ const continuationLine = lines.find((line) => line.includes('Team IDs start with "team_"'));
236
+ expect(continuationLine).toBeDefined();
237
+ expect(continuationLine?.includes('* Team IDs start with "team_"')).toBe(true);
238
+
239
+ logSpy.mockRestore();
240
+ });
241
+
242
+ it('includes optional parameters when --all-parameters is set', async () => {
243
+ const { handleList } = await cliModulePromise;
244
+ const listToolsSpy = vi.fn((_name: string, options?: { includeSchema?: boolean }) =>
245
+ Promise.resolve([buildLinearDocumentsTool(options?.includeSchema)])
246
+ );
247
+ const runtime = {
248
+ getDefinition: () => linearDefinition,
249
+ listTools: listToolsSpy,
250
+ } as unknown as Awaited<ReturnType<typeof import('../src/runtime.js')['createRuntime']>>;
251
+
252
+ const logSpy = vi.spyOn(console, 'log').mockImplementation(() => {});
253
+
254
+ await handleList(runtime, ['--all-parameters', 'linear']);
255
+
256
+ const lines = logSpy.mock.calls.map((call) => stripAnsi(call.join(' ')));
257
+
258
+ const headerLine = lines.find((line) => line.trim().startsWith('linear -'));
259
+ expect(headerLine).toBeDefined();
260
+ const summaryLine = lines.find((line) => line.includes('HTTP https://example.com/mcp'));
261
+ expect(summaryLine).toBeDefined();
262
+ expect(summaryLine).toMatch(/1 tool/);
263
+ expect(summaryLine).toMatch(/ms/);
264
+ expect(summaryLine).toContain('HTTP https://example.com/mcp');
265
+ expect(lines.some((line) => line.includes('/**'))).toBe(true);
266
+ expect(lines.some((line) => line.includes('@param limit?') && line.includes('Maximum number of documents'))).toBe(
267
+ true
268
+ );
269
+ expect(lines.some((line) => line.includes('function list_documents('))).toBe(true);
270
+ expect(lines.some((line) => line.includes('limit?: number'))).toBe(true);
271
+ expect(lines.some((line) => line.includes('orderBy?: "createdAt" | "updatedAt"'))).toBe(true);
272
+ expect(lines.some((line) => line.includes('includeArchived?: boolean'))).toBe(true);
273
+ expect(listToolsSpy).toHaveBeenCalledWith('linear', expect.objectContaining({ includeSchema: true }));
274
+
275
+ logSpy.mockRestore();
276
+ });
277
+
278
+ it('matches the expected formatted snapshot for a complex server', async () => {
279
+ const { handleList } = await cliModulePromise;
280
+ const listToolsSpy = vi.fn((_name: string, options?: { includeSchema?: boolean }) =>
281
+ Promise.resolve([
282
+ buildLinearDocumentsTool(options?.includeSchema),
283
+ {
284
+ name: 'create_comment',
285
+ description: 'Create a comment on a specific Linear issue',
286
+ inputSchema: options?.includeSchema
287
+ ? {
288
+ type: 'object',
289
+ properties: {
290
+ issueId: { type: 'string', description: 'The issue ID' },
291
+ parentId: { type: 'string', description: 'Optional parent comment ID' },
292
+ body: { type: 'string', description: 'Comment body as Markdown' },
293
+ },
294
+ required: ['issueId', 'body'],
295
+ }
296
+ : undefined,
297
+ outputSchema: options?.includeSchema
298
+ ? {
299
+ title: 'Comment',
300
+ type: 'object',
301
+ }
302
+ : undefined,
303
+ },
304
+ ])
305
+ );
306
+ const runtime = {
307
+ getDefinition: () => linearDefinition,
308
+ listTools: listToolsSpy,
309
+ } as unknown as Awaited<ReturnType<typeof import('../src/runtime.js')['createRuntime']>>;
310
+
311
+ const logSpy = vi.spyOn(console, 'log').mockImplementation(() => {});
312
+ const nowSpy = vi.spyOn(Date, 'now').mockReturnValue(1_700_000_000_000);
313
+
314
+ await handleList(runtime, ['linear']);
315
+
316
+ nowSpy.mockRestore();
317
+
318
+ const lines = logSpy.mock.calls.map((call) => stripAnsi(call.join(' ')));
319
+ expect(lines.join('\n')).toMatchInlineSnapshot(`
320
+ "linear - Hosted Linear MCP
321
+
322
+ /**
323
+ * List documents in the user's Linear workspace
324
+ *
325
+ * @param query The search query
326
+ * @param limit? Maximum number of documents to return
327
+ * @param before? Cursor to page backwards
328
+ * @param after? Cursor to page forwards
329
+ * @param orderBy? Sort order for the documents
330
+ * @param projectId? Filter by project
331
+ * @param initiativeId? Filter by initiative
332
+ * @param creatorId? Filter by creator
333
+ * @param includeArchived? Whether to include archived documents
334
+ */
335
+ function list_documents(query: string, limit?: number, before?: string, after?: string, orderBy?: "createdAt" | "updatedAt"): DocumentConnection;
336
+ // optional (4): projectId, initiativeId, creatorId, includeArchived
337
+
338
+ /**
339
+ * Create a comment on a specific Linear issue
340
+ *
341
+ * @param issueId The issue ID
342
+ * @param parentId? Optional parent comment ID
343
+ * @param body Comment body as Markdown
344
+ */
345
+ function create_comment(issueId: string, parentId?: string, body: string): Comment;
346
+
347
+ Examples:
348
+ mcporter call linear.list_documents(query: "value", limit: 1, orderBy: "cr, ...)
349
+
350
+ Optional parameters hidden; run with --all-parameters to view all fields.
351
+
352
+ 2 tools · 0ms · HTTP https://example.com/mcp
353
+ "
354
+ `);
355
+
356
+ logSpy.mockRestore();
357
+ });
358
+ });
@@ -0,0 +1,43 @@
1
+ import { afterEach, beforeEach, describe, expect, it, vi } from 'vitest';
2
+
3
+ process.env.MCPORTER_DISABLE_AUTORUN = '1';
4
+ const cliModulePromise = import('../src/cli.js');
5
+
6
+ describe('mcporter list help shortcut', () => {
7
+ let previousNoForceExit: string | undefined;
8
+
9
+ beforeEach(() => {
10
+ previousNoForceExit = process.env.MCPORTER_NO_FORCE_EXIT;
11
+ process.env.MCPORTER_NO_FORCE_EXIT = '1';
12
+ });
13
+
14
+ afterEach(() => {
15
+ vi.restoreAllMocks();
16
+ process.exitCode = undefined;
17
+ if (previousNoForceExit === undefined) {
18
+ delete process.env.MCPORTER_NO_FORCE_EXIT;
19
+ } else {
20
+ process.env.MCPORTER_NO_FORCE_EXIT = previousNoForceExit;
21
+ }
22
+ });
23
+
24
+ it('prints list-specific help when --help is used', async () => {
25
+ const { runCli } = await cliModulePromise;
26
+ const errorSpy = vi.spyOn(console, 'error').mockImplementation(() => {});
27
+
28
+ await runCli(['list', '--help']);
29
+
30
+ expect(errorSpy).toHaveBeenCalledWith(expect.stringContaining('Usage: mcporter list'));
31
+ expect(process.exitCode).toBe(0);
32
+ });
33
+
34
+ it('prints list-specific help when the bare help token follows the command', async () => {
35
+ const { runCli } = await cliModulePromise;
36
+ const errorSpy = vi.spyOn(console, 'error').mockImplementation(() => {});
37
+
38
+ await runCli(['list', 'help']);
39
+
40
+ expect(errorSpy).toHaveBeenCalledWith(expect.stringContaining('Usage: mcporter list'));
41
+ expect(process.exitCode).toBe(0);
42
+ });
43
+ });
@@ -0,0 +1,55 @@
1
+ import { describe, expect, it, vi } from 'vitest';
2
+ import { handleList as runHandleList } from '../src/cli/list-command.js';
3
+ import type { ServerDefinition } from '../src/config.js';
4
+ import type { Runtime } from '../src/runtime.js';
5
+
6
+ const healthyDefinition: ServerDefinition = {
7
+ name: 'healthy',
8
+ command: { kind: 'http', url: new URL('https://healthy.example.com/mcp') },
9
+ };
10
+
11
+ const authDefinition: ServerDefinition = {
12
+ name: 'auth-server',
13
+ command: { kind: 'http', url: new URL('https://auth.example.com/mcp') },
14
+ };
15
+
16
+ function createRuntime(): Runtime {
17
+ const definitions = [healthyDefinition, authDefinition];
18
+ return {
19
+ getDefinitions: () => definitions,
20
+ getDefinition: (name: string) => {
21
+ const definition = definitions.find((entry) => entry.name === name);
22
+ if (!definition) {
23
+ throw new Error(`Unknown server '${name}'`);
24
+ }
25
+ return definition;
26
+ },
27
+ registerDefinition: vi.fn(),
28
+ listTools: vi.fn((name: string) => {
29
+ if (name === 'healthy') {
30
+ return Promise.resolve([{ name: 'list_documents' }]);
31
+ }
32
+ return Promise.reject(new Error('HTTP error 401: auth required'));
33
+ }),
34
+ } as unknown as Runtime;
35
+ }
36
+
37
+ describe('handleList JSON output', () => {
38
+ it('emits aggregated status counts', async () => {
39
+ const runtime = createRuntime();
40
+ const logSpy = vi.spyOn(console, 'log').mockImplementation(() => {});
41
+
42
+ await runHandleList(runtime, ['--json']);
43
+
44
+ const payload = JSON.parse(logSpy.mock.calls.at(-1)?.[0] ?? '{}');
45
+ expect(payload.mode).toBe('list');
46
+ expect(payload.counts.auth).toBe(1);
47
+ const healthyEntry = payload.servers.find((entry: { name: string }) => entry.name === 'healthy');
48
+ expect(healthyEntry.status).toBe('ok');
49
+ const authEntry = payload.servers.find((entry: { name: string }) => entry.name === 'auth-server');
50
+ expect(authEntry.status).toBe('auth');
51
+ expect(authEntry.issue.kind).toBe('auth');
52
+
53
+ logSpy.mockRestore();
54
+ });
55
+ });
@@ -0,0 +1,108 @@
1
+ import { afterEach, beforeEach, describe, expect, it, vi } from 'vitest';
2
+ import { handleList } from '../src/cli/list-command.js';
3
+ import type { ServerDefinition } from '../src/config.js';
4
+ import type { Runtime, ServerToolInfo } from '../src/runtime.js';
5
+ import * as sdkPatches from '../src/sdk-patches.js';
6
+
7
+ function buildServerDefinition(name: string): ServerDefinition {
8
+ return {
9
+ name,
10
+ description: `${name} server`,
11
+ command: { kind: 'stdio', command: name, args: [], cwd: '/tmp' },
12
+ source: { kind: 'local', path: '/tmp/mcporter.json' },
13
+ };
14
+ }
15
+
16
+ function createRuntime(definitions: ServerDefinition[]) {
17
+ const listTools = vi.fn(
18
+ async (_name: string, _options?: unknown): Promise<ServerToolInfo[]> => [
19
+ {
20
+ name: 'doctor',
21
+ description: 'Runs diagnostics',
22
+ inputSchema: undefined,
23
+ outputSchema: undefined,
24
+ },
25
+ ]
26
+ );
27
+ const runtime: Runtime = {
28
+ listServers: () => definitions.map((entry) => entry.name),
29
+ getDefinitions: () => definitions,
30
+ getDefinition: (name: string): ServerDefinition => {
31
+ const found = definitions.find((entry) => entry.name === name);
32
+ if (!found) {
33
+ throw new Error(`Unknown MCP server '${name}'.`);
34
+ }
35
+ return found;
36
+ },
37
+ registerDefinition: vi.fn(),
38
+ listTools,
39
+ callTool: vi.fn(async () => undefined),
40
+ listResources: vi.fn(async () => undefined),
41
+ connect: vi.fn(async () => {
42
+ throw new Error('connect not implemented');
43
+ }),
44
+ close: vi.fn(async () => undefined),
45
+ };
46
+ return { runtime, listTools };
47
+ }
48
+
49
+ const originalCI = process.env.CI;
50
+
51
+ describe('handleList STDIO log policy', () => {
52
+ beforeEach(() => {
53
+ process.env.CI = '1';
54
+ sdkPatches.setStdioLogMode('auto');
55
+ });
56
+
57
+ afterEach(() => {
58
+ vi.restoreAllMocks();
59
+ process.env.CI = originalCI;
60
+ sdkPatches.setStdioLogMode('auto');
61
+ });
62
+
63
+ it('silences STDIO stderr when listing all servers', async () => {
64
+ const definitions = [buildServerDefinition('alpha'), buildServerDefinition('beta')];
65
+ const { runtime, listTools } = createRuntime(definitions);
66
+ const setModeSpy = vi.spyOn(sdkPatches, 'setStdioLogMode');
67
+ const observedModes: sdkPatches.StdioLogMode[] = [];
68
+ listTools.mockImplementation(async (_name: string, _options?: unknown) => {
69
+ observedModes.push(sdkPatches.getStdioLogMode());
70
+ return [
71
+ {
72
+ name: 'doctor',
73
+ description: 'Runs diagnostics',
74
+ inputSchema: undefined,
75
+ outputSchema: undefined,
76
+ },
77
+ ];
78
+ });
79
+ const logSpy = vi.spyOn(console, 'log').mockImplementation(() => {});
80
+ const warnSpy = vi.spyOn(console, 'warn').mockImplementation(() => {});
81
+ try {
82
+ await handleList(runtime, []);
83
+ } finally {
84
+ logSpy.mockRestore();
85
+ warnSpy.mockRestore();
86
+ }
87
+ expect(setModeSpy).toHaveBeenCalledWith('silent');
88
+ const lastCall = setModeSpy.mock.calls.at(-1);
89
+ expect(lastCall?.[0]).toBe('auto');
90
+ expect(observedModes.length).toBeGreaterThan(0);
91
+ expect(observedModes.every((mode) => mode === 'silent')).toBe(true);
92
+ });
93
+
94
+ it('leaves STDIO stderr in auto mode for targeted listings', async () => {
95
+ const definitions = [buildServerDefinition('alpha')];
96
+ const { runtime } = createRuntime(definitions);
97
+ const setModeSpy = vi.spyOn(sdkPatches, 'setStdioLogMode');
98
+ const logSpy = vi.spyOn(console, 'log').mockImplementation(() => {});
99
+ const warnSpy = vi.spyOn(console, 'warn').mockImplementation(() => {});
100
+ try {
101
+ await handleList(runtime, ['alpha']);
102
+ } finally {
103
+ logSpy.mockRestore();
104
+ warnSpy.mockRestore();
105
+ }
106
+ expect(setModeSpy).not.toHaveBeenCalled();
107
+ });
108
+ });