@hubspot/cli 8.0.10-experimental.5 → 8.0.10-experimental.7

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 (368) hide show
  1. package/commands/getStarted.js +1 -1
  2. package/lang/en.js +1 -1
  3. package/lib/app/migrate.js +10 -5
  4. package/lib/getStartedV2Actions.js +1 -1
  5. package/lib/projects/components.js +3 -2
  6. package/lib/projects/create/v2.js +1 -1
  7. package/lib/ui/SpinniesManager.js +2 -0
  8. package/package.json +6 -2
  9. package/api/__tests__/migrate.test.d.ts +0 -1
  10. package/api/__tests__/migrate.test.js +0 -199
  11. package/commands/__tests__/account.test.d.ts +0 -1
  12. package/commands/__tests__/account.test.js +0 -69
  13. package/commands/__tests__/auth.test.d.ts +0 -1
  14. package/commands/__tests__/auth.test.js +0 -43
  15. package/commands/__tests__/cms.test.d.ts +0 -1
  16. package/commands/__tests__/cms.test.js +0 -87
  17. package/commands/__tests__/config.test.d.ts +0 -1
  18. package/commands/__tests__/config.test.js +0 -44
  19. package/commands/__tests__/customObject.test.d.ts +0 -1
  20. package/commands/__tests__/customObject.test.js +0 -68
  21. package/commands/__tests__/doctor.test.d.ts +0 -1
  22. package/commands/__tests__/doctor.test.js +0 -132
  23. package/commands/__tests__/feedback.test.d.ts +0 -1
  24. package/commands/__tests__/feedback.test.js +0 -24
  25. package/commands/__tests__/filemanager.test.d.ts +0 -1
  26. package/commands/__tests__/filemanager.test.js +0 -45
  27. package/commands/__tests__/getStarted.test.d.ts +0 -1
  28. package/commands/__tests__/getStarted.test.js +0 -173
  29. package/commands/__tests__/hubdb.test.d.ts +0 -1
  30. package/commands/__tests__/hubdb.test.js +0 -50
  31. package/commands/__tests__/init.test.d.ts +0 -1
  32. package/commands/__tests__/init.test.js +0 -42
  33. package/commands/__tests__/mcp.test.d.ts +0 -1
  34. package/commands/__tests__/mcp.test.js +0 -46
  35. package/commands/__tests__/open.test.d.ts +0 -1
  36. package/commands/__tests__/open.test.js +0 -58
  37. package/commands/__tests__/project.test.d.ts +0 -1
  38. package/commands/__tests__/project.test.js +0 -125
  39. package/commands/__tests__/sandbox.test.d.ts +0 -1
  40. package/commands/__tests__/sandbox.test.js +0 -44
  41. package/commands/__tests__/secret.test.d.ts +0 -1
  42. package/commands/__tests__/secret.test.js +0 -49
  43. package/commands/__tests__/testAccount.test.d.ts +0 -1
  44. package/commands/__tests__/testAccount.test.js +0 -57
  45. package/commands/__tests__/upgrade.test.d.ts +0 -1
  46. package/commands/__tests__/upgrade.test.js +0 -309
  47. package/commands/account/__tests__/auth.test.d.ts +0 -1
  48. package/commands/account/__tests__/auth.test.js +0 -206
  49. package/commands/account/__tests__/clean.test.d.ts +0 -1
  50. package/commands/account/__tests__/clean.test.js +0 -28
  51. package/commands/account/__tests__/createOverride.test.d.ts +0 -1
  52. package/commands/account/__tests__/createOverride.test.js +0 -32
  53. package/commands/account/__tests__/info.test.d.ts +0 -1
  54. package/commands/account/__tests__/info.test.js +0 -28
  55. package/commands/account/__tests__/list.test.d.ts +0 -1
  56. package/commands/account/__tests__/list.test.js +0 -153
  57. package/commands/account/__tests__/remove.test.d.ts +0 -1
  58. package/commands/account/__tests__/remove.test.js +0 -36
  59. package/commands/account/__tests__/removeOverride.d.ts +0 -1
  60. package/commands/account/__tests__/removeOverride.js +0 -25
  61. package/commands/account/__tests__/rename.test.d.ts +0 -1
  62. package/commands/account/__tests__/rename.test.js +0 -82
  63. package/commands/account/__tests__/use.test.d.ts +0 -1
  64. package/commands/account/__tests__/use.test.js +0 -170
  65. package/commands/app/__tests__/migrate.test.d.ts +0 -1
  66. package/commands/app/__tests__/migrate.test.js +0 -111
  67. package/commands/app/secret/__tests__/add.test.d.ts +0 -1
  68. package/commands/app/secret/__tests__/add.test.js +0 -140
  69. package/commands/app/secret/__tests__/delete.test.d.ts +0 -1
  70. package/commands/app/secret/__tests__/delete.test.js +0 -28
  71. package/commands/app/secret/__tests__/list.test.d.ts +0 -1
  72. package/commands/app/secret/__tests__/list.test.js +0 -25
  73. package/commands/app/secret/__tests__/update.test.d.ts +0 -1
  74. package/commands/app/secret/__tests__/update.test.js +0 -28
  75. package/commands/cms/__tests__/delete.test.d.ts +0 -1
  76. package/commands/cms/__tests__/delete.test.js +0 -39
  77. package/commands/cms/__tests__/fetch.test.d.ts +0 -1
  78. package/commands/cms/__tests__/fetch.test.js +0 -156
  79. package/commands/cms/__tests__/function.test.d.ts +0 -1
  80. package/commands/cms/__tests__/function.test.js +0 -50
  81. package/commands/cms/__tests__/lint.test.d.ts +0 -1
  82. package/commands/cms/__tests__/lint.test.js +0 -33
  83. package/commands/cms/__tests__/list.test.d.ts +0 -1
  84. package/commands/cms/__tests__/list.test.js +0 -42
  85. package/commands/cms/__tests__/module.test.d.ts +0 -1
  86. package/commands/cms/__tests__/module.test.js +0 -45
  87. package/commands/cms/__tests__/mv.test.d.ts +0 -1
  88. package/commands/cms/__tests__/mv.test.js +0 -46
  89. package/commands/cms/__tests__/theme.test.d.ts +0 -1
  90. package/commands/cms/__tests__/theme.test.js +0 -54
  91. package/commands/cms/__tests__/upload.test.d.ts +0 -1
  92. package/commands/cms/__tests__/upload.test.js +0 -312
  93. package/commands/cms/__tests__/watch.test.d.ts +0 -1
  94. package/commands/cms/__tests__/watch.test.js +0 -204
  95. package/commands/cms/function/__tests__/logs.test.d.ts +0 -1
  96. package/commands/cms/function/__tests__/logs.test.js +0 -70
  97. package/commands/cms/theme/__tests__/generate-selectors.test.d.ts +0 -1
  98. package/commands/cms/theme/__tests__/generate-selectors.test.js +0 -28
  99. package/commands/cms/theme/__tests__/marketplace-validate.test.d.ts +0 -1
  100. package/commands/cms/theme/__tests__/marketplace-validate.test.js +0 -36
  101. package/commands/cms/theme/__tests__/preview.test.d.ts +0 -1
  102. package/commands/cms/theme/__tests__/preview.test.js +0 -54
  103. package/commands/customObject/__tests__/create.test.d.ts +0 -1
  104. package/commands/customObject/__tests__/create.test.js +0 -40
  105. package/commands/customObject/__tests__/createSchema.test.d.ts +0 -1
  106. package/commands/customObject/__tests__/createSchema.test.js +0 -28
  107. package/commands/customObject/__tests__/deleteSchema.test.d.ts +0 -1
  108. package/commands/customObject/__tests__/deleteSchema.test.js +0 -42
  109. package/commands/customObject/__tests__/fetch-all-schemas.test.d.ts +0 -1
  110. package/commands/customObject/__tests__/fetch-all-schemas.test.js +0 -41
  111. package/commands/customObject/__tests__/fetchSchema.test.d.ts +0 -1
  112. package/commands/customObject/__tests__/fetchSchema.test.js +0 -45
  113. package/commands/customObject/__tests__/listSchemas.test.d.ts +0 -1
  114. package/commands/customObject/__tests__/listSchemas.test.js +0 -29
  115. package/commands/customObject/__tests__/updateSchema.test.d.ts +0 -1
  116. package/commands/customObject/__tests__/updateSchema.test.js +0 -40
  117. package/commands/filemanager/__tests__/fetch.test.d.ts +0 -1
  118. package/commands/filemanager/__tests__/fetch.test.js +0 -32
  119. package/commands/filemanager/__tests__/upload.test.d.ts +0 -1
  120. package/commands/filemanager/__tests__/upload.test.js +0 -191
  121. package/commands/hubdb/__tests__/clear.test.d.ts +0 -1
  122. package/commands/hubdb/__tests__/clear.test.js +0 -28
  123. package/commands/hubdb/__tests__/create.test.d.ts +0 -1
  124. package/commands/hubdb/__tests__/create.test.js +0 -28
  125. package/commands/hubdb/__tests__/delete.test.d.ts +0 -1
  126. package/commands/hubdb/__tests__/delete.test.js +0 -28
  127. package/commands/hubdb/__tests__/fetch.test.d.ts +0 -1
  128. package/commands/hubdb/__tests__/fetch.test.js +0 -28
  129. package/commands/hubdb/__tests__/list.test.d.ts +0 -1
  130. package/commands/hubdb/__tests__/list.test.js +0 -88
  131. package/commands/mcp/__tests__/setup.test.d.ts +0 -1
  132. package/commands/mcp/__tests__/setup.test.js +0 -26
  133. package/commands/mcp/__tests__/start.test.d.ts +0 -1
  134. package/commands/mcp/__tests__/start.test.js +0 -144
  135. package/commands/project/__tests__/add.test.d.ts +0 -1
  136. package/commands/project/__tests__/add.test.js +0 -107
  137. package/commands/project/__tests__/create.test.d.ts +0 -1
  138. package/commands/project/__tests__/create.test.js +0 -97
  139. package/commands/project/__tests__/deploy.test.d.ts +0 -1
  140. package/commands/project/__tests__/deploy.test.js +0 -307
  141. package/commands/project/__tests__/dev.test.d.ts +0 -1
  142. package/commands/project/__tests__/dev.test.js +0 -273
  143. package/commands/project/__tests__/devUnifiedFlow.test.d.ts +0 -1
  144. package/commands/project/__tests__/devUnifiedFlow.test.js +0 -434
  145. package/commands/project/__tests__/download.test.d.ts +0 -1
  146. package/commands/project/__tests__/download.test.js +0 -39
  147. package/commands/project/__tests__/installDeps.test.d.ts +0 -1
  148. package/commands/project/__tests__/installDeps.test.js +0 -140
  149. package/commands/project/__tests__/lint.test.d.ts +0 -1
  150. package/commands/project/__tests__/lint.test.js +0 -704
  151. package/commands/project/__tests__/list.test.d.ts +0 -1
  152. package/commands/project/__tests__/list.test.js +0 -31
  153. package/commands/project/__tests__/listBuilds.test.d.ts +0 -1
  154. package/commands/project/__tests__/listBuilds.test.js +0 -38
  155. package/commands/project/__tests__/logs.test.d.ts +0 -1
  156. package/commands/project/__tests__/logs.test.js +0 -202
  157. package/commands/project/__tests__/migrate.test.d.ts +0 -1
  158. package/commands/project/__tests__/migrate.test.js +0 -106
  159. package/commands/project/__tests__/open.test.d.ts +0 -1
  160. package/commands/project/__tests__/open.test.js +0 -39
  161. package/commands/project/__tests__/profile.test.d.ts +0 -1
  162. package/commands/project/__tests__/profile.test.js +0 -42
  163. package/commands/project/__tests__/updateDeps.test.d.ts +0 -1
  164. package/commands/project/__tests__/updateDeps.test.js +0 -140
  165. package/commands/project/__tests__/upload.test.d.ts +0 -1
  166. package/commands/project/__tests__/upload.test.js +0 -234
  167. package/commands/project/__tests__/validate.test.d.ts +0 -1
  168. package/commands/project/__tests__/validate.test.js +0 -381
  169. package/commands/project/__tests__/watch.test.d.ts +0 -1
  170. package/commands/project/__tests__/watch.test.js +0 -35
  171. package/commands/sandbox/__tests__/create.test.d.ts +0 -1
  172. package/commands/sandbox/__tests__/create.test.js +0 -198
  173. package/commands/sandbox/__tests__/delete.test.d.ts +0 -1
  174. package/commands/sandbox/__tests__/delete.test.js +0 -31
  175. package/commands/secret/__tests__/addSecret.test.d.ts +0 -1
  176. package/commands/secret/__tests__/addSecret.test.js +0 -162
  177. package/commands/secret/__tests__/deleteSecret.test.d.ts +0 -1
  178. package/commands/secret/__tests__/deleteSecret.test.js +0 -41
  179. package/commands/secret/__tests__/listSecret.test.d.ts +0 -1
  180. package/commands/secret/__tests__/listSecret.test.js +0 -29
  181. package/commands/secret/__tests__/updateSecret.test.d.ts +0 -1
  182. package/commands/secret/__tests__/updateSecret.test.js +0 -29
  183. package/commands/testAccount/__tests__/create.test.d.ts +0 -1
  184. package/commands/testAccount/__tests__/create.test.js +0 -106
  185. package/commands/testAccount/__tests__/createConfig.test.d.ts +0 -1
  186. package/commands/testAccount/__tests__/createConfig.test.js +0 -32
  187. package/commands/testAccount/__tests__/delete.test.d.ts +0 -1
  188. package/commands/testAccount/__tests__/delete.test.js +0 -29
  189. package/commands/testAccount/__tests__/importData.test.d.ts +0 -1
  190. package/commands/testAccount/__tests__/importData.test.js +0 -92
  191. package/lib/__tests__/CLIWebSocketServer.test.d.ts +0 -1
  192. package/lib/__tests__/CLIWebSocketServer.test.js +0 -252
  193. package/lib/__tests__/accountAuth.test.d.ts +0 -1
  194. package/lib/__tests__/accountAuth.test.js +0 -258
  195. package/lib/__tests__/accountTypes.test.d.ts +0 -1
  196. package/lib/__tests__/accountTypes.test.js +0 -98
  197. package/lib/__tests__/buildAccount.test.d.ts +0 -1
  198. package/lib/__tests__/buildAccount.test.js +0 -211
  199. package/lib/__tests__/cliUpgradeUtils.test.d.ts +0 -1
  200. package/lib/__tests__/cliUpgradeUtils.test.js +0 -131
  201. package/lib/__tests__/commandSuggestion.test.d.ts +0 -1
  202. package/lib/__tests__/commandSuggestion.test.js +0 -121
  203. package/lib/__tests__/commonOpts.test.d.ts +0 -1
  204. package/lib/__tests__/commonOpts.test.js +0 -80
  205. package/lib/__tests__/dependencyManagement.test.d.ts +0 -1
  206. package/lib/__tests__/dependencyManagement.test.js +0 -1067
  207. package/lib/__tests__/developerTestAccounts.test.d.ts +0 -1
  208. package/lib/__tests__/developerTestAccounts.test.js +0 -156
  209. package/lib/__tests__/hasFeature.test.d.ts +0 -1
  210. package/lib/__tests__/hasFeature.test.js +0 -167
  211. package/lib/__tests__/http.test.d.ts +0 -1
  212. package/lib/__tests__/http.test.js +0 -40
  213. package/lib/__tests__/importData.test.d.ts +0 -1
  214. package/lib/__tests__/importData.test.js +0 -98
  215. package/lib/__tests__/npmCli.test.d.ts +0 -1
  216. package/lib/__tests__/npmCli.test.js +0 -84
  217. package/lib/__tests__/oauth.test.d.ts +0 -1
  218. package/lib/__tests__/oauth.test.js +0 -109
  219. package/lib/__tests__/parsing.test.d.ts +0 -1
  220. package/lib/__tests__/parsing.test.js +0 -34
  221. package/lib/__tests__/polling.test.d.ts +0 -1
  222. package/lib/__tests__/polling.test.js +0 -76
  223. package/lib/__tests__/process.test.d.ts +0 -1
  224. package/lib/__tests__/process.test.js +0 -89
  225. package/lib/__tests__/sandboxes.test.d.ts +0 -1
  226. package/lib/__tests__/sandboxes.test.js +0 -128
  227. package/lib/__tests__/serverlessLogs.test.d.ts +0 -1
  228. package/lib/__tests__/serverlessLogs.test.js +0 -163
  229. package/lib/__tests__/usageTracking.test.d.ts +0 -1
  230. package/lib/__tests__/usageTracking.test.js +0 -197
  231. package/lib/__tests__/validation.test.d.ts +0 -1
  232. package/lib/__tests__/validation.test.js +0 -143
  233. package/lib/__tests__/yargsUtils.test.d.ts +0 -1
  234. package/lib/__tests__/yargsUtils.test.js +0 -124
  235. package/lib/app/__tests__/migrate.test.d.ts +0 -1
  236. package/lib/app/__tests__/migrate.test.js +0 -638
  237. package/lib/doctor/__tests__/Diagnosis.test.d.ts +0 -1
  238. package/lib/doctor/__tests__/Diagnosis.test.js +0 -84
  239. package/lib/doctor/__tests__/DiagnosticInfoBuilder.test.d.ts +0 -1
  240. package/lib/doctor/__tests__/DiagnosticInfoBuilder.test.js +0 -177
  241. package/lib/doctor/__tests__/Doctor.test.d.ts +0 -1
  242. package/lib/doctor/__tests__/Doctor.test.js +0 -560
  243. package/lib/errorHandlers/__tests__/index.test.d.ts +0 -1
  244. package/lib/errorHandlers/__tests__/index.test.js +0 -278
  245. package/lib/mcp/__tests__/setup.test.d.ts +0 -1
  246. package/lib/mcp/__tests__/setup.test.js +0 -523
  247. package/lib/middleware/__tests__/commandTargetingUtils.test.d.ts +0 -1
  248. package/lib/middleware/__tests__/commandTargetingUtils.test.js +0 -99
  249. package/lib/middleware/__tests__/configMiddleware.test.d.ts +0 -1
  250. package/lib/middleware/__tests__/configMiddleware.test.js +0 -118
  251. package/lib/middleware/__tests__/gitMiddleware.test.d.ts +0 -1
  252. package/lib/middleware/__tests__/gitMiddleware.test.js +0 -43
  253. package/lib/middleware/__tests__/requestMiddleware.test.d.ts +0 -1
  254. package/lib/middleware/__tests__/requestMiddleware.test.js +0 -15
  255. package/lib/middleware/__tests__/usageTrackingMiddleware.test.d.ts +0 -1
  256. package/lib/middleware/__tests__/usageTrackingMiddleware.test.js +0 -44
  257. package/lib/middleware/__tests__/yargsChecksMiddleware.test.d.ts +0 -1
  258. package/lib/middleware/__tests__/yargsChecksMiddleware.test.js +0 -39
  259. package/lib/projects/__tests__/AppDevModeInterface.test.d.ts +0 -1
  260. package/lib/projects/__tests__/AppDevModeInterface.test.js +0 -541
  261. package/lib/projects/__tests__/DevServerManager.test.d.ts +0 -1
  262. package/lib/projects/__tests__/DevServerManager.test.js +0 -185
  263. package/lib/projects/__tests__/DevSessionManager.test.d.ts +0 -1
  264. package/lib/projects/__tests__/DevSessionManager.test.js +0 -250
  265. package/lib/projects/__tests__/LocalDevProcess.test.d.ts +0 -1
  266. package/lib/projects/__tests__/LocalDevProcess.test.js +0 -481
  267. package/lib/projects/__tests__/LocalDevWebsocketServer.test.d.ts +0 -1
  268. package/lib/projects/__tests__/LocalDevWebsocketServer.test.js +0 -231
  269. package/lib/projects/__tests__/ProjectLogsManager.test.d.ts +0 -1
  270. package/lib/projects/__tests__/ProjectLogsManager.test.js +0 -302
  271. package/lib/projects/__tests__/UIExtensionsDevModeInterface.test.d.ts +0 -1
  272. package/lib/projects/__tests__/UIExtensionsDevModeInterface.test.js +0 -160
  273. package/lib/projects/__tests__/components.test.d.ts +0 -1
  274. package/lib/projects/__tests__/components.test.js +0 -440
  275. package/lib/projects/__tests__/deploy.test.d.ts +0 -1
  276. package/lib/projects/__tests__/deploy.test.js +0 -231
  277. package/lib/projects/__tests__/localDevProjectHelpers.test.d.ts +0 -1
  278. package/lib/projects/__tests__/localDevProjectHelpers.test.js +0 -120
  279. package/lib/projects/__tests__/platformVersion.test.d.ts +0 -1
  280. package/lib/projects/__tests__/platformVersion.test.js +0 -63
  281. package/lib/projects/__tests__/pollProjectBuildAndDeploy.test.d.ts +0 -1
  282. package/lib/projects/__tests__/pollProjectBuildAndDeploy.test.js +0 -328
  283. package/lib/projects/__tests__/projectProfiles.test.d.ts +0 -1
  284. package/lib/projects/__tests__/projectProfiles.test.js +0 -441
  285. package/lib/projects/__tests__/projects.test.d.ts +0 -1
  286. package/lib/projects/__tests__/projects.test.js +0 -58
  287. package/lib/projects/__tests__/structure.test.d.ts +0 -1
  288. package/lib/projects/__tests__/structure.test.js +0 -210
  289. package/lib/projects/__tests__/uieLinting.test.d.ts +0 -1
  290. package/lib/projects/__tests__/uieLinting.test.js +0 -631
  291. package/lib/projects/__tests__/upload.test.d.ts +0 -1
  292. package/lib/projects/__tests__/upload.test.js +0 -183
  293. package/lib/projects/add/__tests__/legacyAddComponent.test.d.ts +0 -1
  294. package/lib/projects/add/__tests__/legacyAddComponent.test.js +0 -245
  295. package/lib/projects/add/__tests__/v2AddComponent.test.d.ts +0 -1
  296. package/lib/projects/add/__tests__/v2AddComponent.test.js +0 -343
  297. package/lib/projects/create/__tests__/legacy.test.d.ts +0 -1
  298. package/lib/projects/create/__tests__/legacy.test.js +0 -72
  299. package/lib/projects/create/__tests__/v2.test.d.ts +0 -1
  300. package/lib/projects/create/__tests__/v2.test.js +0 -257
  301. package/lib/prompts/__tests__/createDeveloperTestAccountConfigPrompt.test.d.ts +0 -1
  302. package/lib/prompts/__tests__/createDeveloperTestAccountConfigPrompt.test.js +0 -157
  303. package/lib/prompts/__tests__/createFunctionPrompt.test.d.ts +0 -1
  304. package/lib/prompts/__tests__/createFunctionPrompt.test.js +0 -129
  305. package/lib/prompts/__tests__/createModulePrompt.test.d.ts +0 -1
  306. package/lib/prompts/__tests__/createModulePrompt.test.js +0 -187
  307. package/lib/prompts/__tests__/createTemplatePrompt.test.d.ts +0 -1
  308. package/lib/prompts/__tests__/createTemplatePrompt.test.js +0 -102
  309. package/lib/prompts/__tests__/downloadProjectPrompt.test.d.ts +0 -1
  310. package/lib/prompts/__tests__/downloadProjectPrompt.test.js +0 -31
  311. package/lib/prompts/__tests__/projectAddPrompt.test.d.ts +0 -1
  312. package/lib/prompts/__tests__/projectAddPrompt.test.js +0 -143
  313. package/lib/prompts/__tests__/projectsLogsPrompt.test.d.ts +0 -1
  314. package/lib/prompts/__tests__/projectsLogsPrompt.test.js +0 -37
  315. package/lib/prompts/__tests__/selectProjectTemplatePrompt.test.d.ts +0 -1
  316. package/lib/prompts/__tests__/selectProjectTemplatePrompt.test.js +0 -160
  317. package/lib/theme/__tests__/migrate.test.d.ts +0 -1
  318. package/lib/theme/__tests__/migrate.test.js +0 -247
  319. package/lib/ui/__tests__/SpinniesManager.test.d.ts +0 -1
  320. package/lib/ui/__tests__/SpinniesManager.test.js +0 -488
  321. package/lib/ui/__tests__/removeAnsiCodes.test.d.ts +0 -1
  322. package/lib/ui/__tests__/removeAnsiCodes.test.js +0 -84
  323. package/mcp-server/tools/cms/__tests__/HsCreateFunctionTool.test.d.ts +0 -1
  324. package/mcp-server/tools/cms/__tests__/HsCreateFunctionTool.test.js +0 -254
  325. package/mcp-server/tools/cms/__tests__/HsCreateModuleTool.test.d.ts +0 -1
  326. package/mcp-server/tools/cms/__tests__/HsCreateModuleTool.test.js +0 -227
  327. package/mcp-server/tools/cms/__tests__/HsCreateTemplateTool.test.d.ts +0 -1
  328. package/mcp-server/tools/cms/__tests__/HsCreateTemplateTool.test.js +0 -208
  329. package/mcp-server/tools/cms/__tests__/HsFunctionLogsTool.test.d.ts +0 -1
  330. package/mcp-server/tools/cms/__tests__/HsFunctionLogsTool.test.js +0 -186
  331. package/mcp-server/tools/cms/__tests__/HsListFunctionsTool.test.d.ts +0 -1
  332. package/mcp-server/tools/cms/__tests__/HsListFunctionsTool.test.js +0 -124
  333. package/mcp-server/tools/cms/__tests__/HsListTool.test.d.ts +0 -1
  334. package/mcp-server/tools/cms/__tests__/HsListTool.test.js +0 -124
  335. package/mcp-server/tools/project/__tests__/AddFeatureToProjectTool.test.d.ts +0 -1
  336. package/mcp-server/tools/project/__tests__/AddFeatureToProjectTool.test.js +0 -157
  337. package/mcp-server/tools/project/__tests__/CreateProjectTool.test.d.ts +0 -1
  338. package/mcp-server/tools/project/__tests__/CreateProjectTool.test.js +0 -131
  339. package/mcp-server/tools/project/__tests__/CreateTestAccountTool.test.d.ts +0 -1
  340. package/mcp-server/tools/project/__tests__/CreateTestAccountTool.test.js +0 -461
  341. package/mcp-server/tools/project/__tests__/DeployProjectTool.test.d.ts +0 -1
  342. package/mcp-server/tools/project/__tests__/DeployProjectTool.test.js +0 -125
  343. package/mcp-server/tools/project/__tests__/DocFetchTool.test.d.ts +0 -1
  344. package/mcp-server/tools/project/__tests__/DocFetchTool.test.js +0 -125
  345. package/mcp-server/tools/project/__tests__/DocsSearchTool.test.d.ts +0 -1
  346. package/mcp-server/tools/project/__tests__/DocsSearchTool.test.js +0 -210
  347. package/mcp-server/tools/project/__tests__/GetApiUsagePatternsByAppIdTool.test.d.ts +0 -1
  348. package/mcp-server/tools/project/__tests__/GetApiUsagePatternsByAppIdTool.test.js +0 -146
  349. package/mcp-server/tools/project/__tests__/GetApplicationInfoTool.test.d.ts +0 -1
  350. package/mcp-server/tools/project/__tests__/GetApplicationInfoTool.test.js +0 -124
  351. package/mcp-server/tools/project/__tests__/GetBuildLogsTool.test.d.ts +0 -1
  352. package/mcp-server/tools/project/__tests__/GetBuildLogsTool.test.js +0 -307
  353. package/mcp-server/tools/project/__tests__/GetBuildStatusTool.test.d.ts +0 -1
  354. package/mcp-server/tools/project/__tests__/GetBuildStatusTool.test.js +0 -242
  355. package/mcp-server/tools/project/__tests__/GetConfigValuesTool.test.d.ts +0 -1
  356. package/mcp-server/tools/project/__tests__/GetConfigValuesTool.test.js +0 -209
  357. package/mcp-server/tools/project/__tests__/GuidedWalkthroughTool.test.d.ts +0 -1
  358. package/mcp-server/tools/project/__tests__/GuidedWalkthroughTool.test.js +0 -158
  359. package/mcp-server/tools/project/__tests__/UploadProjectTools.test.d.ts +0 -1
  360. package/mcp-server/tools/project/__tests__/UploadProjectTools.test.js +0 -187
  361. package/mcp-server/tools/project/__tests__/ValidateProjectTool.test.d.ts +0 -1
  362. package/mcp-server/tools/project/__tests__/ValidateProjectTool.test.js +0 -118
  363. package/mcp-server/utils/__tests__/command.test.d.ts +0 -1
  364. package/mcp-server/utils/__tests__/command.test.js +0 -275
  365. package/mcp-server/utils/__tests__/content.test.d.ts +0 -1
  366. package/mcp-server/utils/__tests__/content.test.js +0 -164
  367. package/mcp-server/utils/__tests__/feedbackTracking.test.d.ts +0 -1
  368. package/mcp-server/utils/__tests__/feedbackTracking.test.js +0 -69
@@ -1,209 +0,0 @@
1
- import { GetConfigValuesTool } from '../GetConfigValuesTool.js';
2
- import { getIntermediateRepresentationSchema } from '@hubspot/project-parsing-lib/schema';
3
- import { mapToInternalType } from '@hubspot/project-parsing-lib/transform';
4
- import { getConfigDefaultAccountIfExists } from '@hubspot/local-dev-lib/config';
5
- import { mcpFeedbackRequest } from '../../../utils/feedbackTracking.js';
6
- import { trackToolUsage } from '../../../utils/toolUsageTracking.js';
7
- vi.mock('@modelcontextprotocol/sdk/server/mcp.js');
8
- vi.mock('@hubspot/project-parsing-lib/schema');
9
- vi.mock('@hubspot/project-parsing-lib/transform');
10
- vi.mock('@hubspot/local-dev-lib/config');
11
- vi.mock('../../../utils/toolUsageTracking');
12
- vi.mock('../../../utils/feedbackTracking');
13
- const mockTrackToolUsage = trackToolUsage;
14
- const mockMcpFeedbackRequest = mcpFeedbackRequest;
15
- const mockGetIntermediateRepresentationSchema = getIntermediateRepresentationSchema;
16
- const mockMapToInternalType = mapToInternalType;
17
- const mockGetConfigDefaultAccountIfExists = getConfigDefaultAccountIfExists;
18
- describe('mcp-server/tools/project/GetConfigValuesTool', () => {
19
- let mockMcpServer;
20
- let tool;
21
- let mockRegisteredTool;
22
- beforeEach(() => {
23
- // @ts-expect-error Not mocking the whole thing
24
- mockMcpServer = {
25
- registerTool: vi.fn(),
26
- };
27
- mockRegisteredTool = {};
28
- mockMcpServer.registerTool.mockReturnValue(mockRegisteredTool);
29
- mockMcpFeedbackRequest.mockResolvedValue('');
30
- mockTrackToolUsage.mockResolvedValue(undefined);
31
- tool = new GetConfigValuesTool(mockMcpServer);
32
- });
33
- describe('register', () => {
34
- it('should register tool with correct parameters', () => {
35
- const result = tool.register();
36
- expect(mockMcpServer.registerTool).toHaveBeenCalledWith('get-feature-config-schema', expect.objectContaining({
37
- title: 'Fetch the JSON Schema for component',
38
- description: expect.stringContaining('Fetches and returns the JSON schema for the provided feature'),
39
- inputSchema: expect.objectContaining({
40
- platformVersion: expect.objectContaining({
41
- describe: expect.any(Function),
42
- }),
43
- featureType: expect.objectContaining({
44
- describe: expect.any(Function),
45
- }),
46
- }),
47
- }), expect.any(Function));
48
- expect(result).toBe(mockRegisteredTool);
49
- });
50
- });
51
- describe('handler', () => {
52
- const input = {
53
- platformVersion: '2025.2',
54
- featureType: 'card',
55
- absoluteCurrentWorkingDirectory: '/foo',
56
- };
57
- beforeEach(() => {
58
- mockGetConfigDefaultAccountIfExists.mockReturnValue({
59
- accountId: 123456789,
60
- });
61
- });
62
- it('should return config schema when component type exists', async () => {
63
- const mockSchema = {
64
- 'internal-card-type': {
65
- type: 'object',
66
- properties: {
67
- title: { type: 'string' },
68
- description: { type: 'string' },
69
- },
70
- },
71
- };
72
- mockGetIntermediateRepresentationSchema.mockResolvedValue(mockSchema);
73
- mockMapToInternalType.mockReturnValue('internal-card-type');
74
- const result = await tool.handler(input);
75
- expect(mockGetConfigDefaultAccountIfExists).toHaveBeenCalled();
76
- expect(mockGetIntermediateRepresentationSchema).toHaveBeenCalledWith({
77
- platformVersion: '2025.2',
78
- projectSourceDir: '',
79
- accountId: 123456789,
80
- });
81
- expect(mockMapToInternalType).toHaveBeenCalledWith('card');
82
- expect(result).toEqual({
83
- content: [
84
- {
85
- type: 'text',
86
- text: JSON.stringify({
87
- config: {
88
- type: 'object',
89
- properties: {
90
- title: { type: 'string' },
91
- description: { type: 'string' },
92
- },
93
- },
94
- }),
95
- },
96
- ],
97
- });
98
- });
99
- it('should return error message when component type does not exist in schema', async () => {
100
- const mockSchema = {
101
- 'other-type': {
102
- type: 'object',
103
- properties: {},
104
- },
105
- };
106
- mockGetIntermediateRepresentationSchema.mockResolvedValue(mockSchema);
107
- mockMapToInternalType.mockReturnValue('internal-card-type');
108
- const result = await tool.handler(input);
109
- expect(result).toEqual({
110
- content: [
111
- {
112
- type: 'text',
113
- text: 'Unable to locate JSON schema for type card',
114
- },
115
- ],
116
- });
117
- });
118
- it('should return error message when getIntermediateRepresentationSchema throws', async () => {
119
- mockGetIntermediateRepresentationSchema.mockRejectedValue(new Error('Schema fetch failed'));
120
- mockMapToInternalType.mockReturnValue('internal-card-type');
121
- const result = await tool.handler(input);
122
- expect(result).toEqual({
123
- content: [
124
- {
125
- type: 'text',
126
- text: 'Unable to locate JSON schema for type card',
127
- },
128
- ],
129
- });
130
- });
131
- it('should return error message when mapToInternalType throws', async () => {
132
- const mockSchema = {};
133
- mockGetIntermediateRepresentationSchema.mockResolvedValue(mockSchema);
134
- mockMapToInternalType.mockImplementation(() => {
135
- throw new Error('Mapping failed');
136
- });
137
- const result = await tool.handler(input);
138
- expect(result).toEqual({
139
- content: [
140
- {
141
- type: 'text',
142
- text: 'Unable to locate JSON schema for type card',
143
- },
144
- ],
145
- });
146
- });
147
- it('should handle null account id', async () => {
148
- mockGetConfigDefaultAccountIfExists.mockReturnValue(undefined);
149
- const result = await tool.handler(input);
150
- expect(result).toEqual({
151
- content: [
152
- {
153
- type: 'text',
154
- text: 'No account ID found. Please run `hs account auth` to configure an account, or set a default account with `hs account use <account>`',
155
- },
156
- ],
157
- });
158
- });
159
- it('should handle empty schema object', async () => {
160
- const mockSchema = {};
161
- mockGetIntermediateRepresentationSchema.mockResolvedValue(mockSchema);
162
- mockMapToInternalType.mockReturnValue('internal-card-type');
163
- const result = await tool.handler(input);
164
- expect(result).toEqual({
165
- content: [
166
- {
167
- type: 'text',
168
- text: 'Unable to locate JSON schema for type card',
169
- },
170
- ],
171
- });
172
- });
173
- it('should handle complex nested schema structures', async () => {
174
- const complexSchema = {
175
- 'internal-card-type': {
176
- type: 'object',
177
- properties: {
178
- title: { type: 'string', maxLength: 100 },
179
- metadata: {
180
- type: 'object',
181
- properties: {
182
- author: { type: 'string' },
183
- tags: {
184
- type: 'array',
185
- items: { type: 'string' },
186
- },
187
- },
188
- required: ['author'],
189
- },
190
- },
191
- required: ['title'],
192
- },
193
- };
194
- mockGetIntermediateRepresentationSchema.mockResolvedValue(complexSchema);
195
- mockMapToInternalType.mockReturnValue('internal-card-type');
196
- const result = await tool.handler(input);
197
- expect(result).toEqual({
198
- content: [
199
- {
200
- type: 'text',
201
- text: JSON.stringify({
202
- config: complexSchema['internal-card-type'],
203
- }),
204
- },
205
- ],
206
- });
207
- });
208
- });
209
- });
@@ -1,158 +0,0 @@
1
- import { GuidedWalkthroughTool } from '../GuidedWalkthroughTool.js';
2
- import { execAsync } from '../../../utils/command.js';
3
- import { mcpFeedbackRequest } from '../../../utils/feedbackTracking.js';
4
- import { trackToolUsage } from '../../../utils/toolUsageTracking.js';
5
- vi.mock('@modelcontextprotocol/sdk/server/mcp.js');
6
- vi.mock('../../../utils/command');
7
- vi.mock('../../../utils/toolUsageTracking');
8
- vi.mock('../../../utils/feedbackTracking');
9
- const mockTrackToolUsage = trackToolUsage;
10
- const mockExecAsync = execAsync;
11
- const mockMcpFeedbackRequest = mcpFeedbackRequest;
12
- describe('mcp-server/tools/project/GuidedWalkthroughTool', () => {
13
- let mockMcpServer;
14
- let tool;
15
- let mockRegisteredTool;
16
- beforeEach(() => {
17
- // @ts-expect-error Not mocking whole server
18
- mockMcpServer = {
19
- registerTool: vi.fn(),
20
- };
21
- mockRegisteredTool = {};
22
- mockMcpServer.registerTool.mockReturnValue(mockRegisteredTool);
23
- mockMcpFeedbackRequest.mockResolvedValue('');
24
- mockTrackToolUsage.mockResolvedValue(undefined);
25
- tool = new GuidedWalkthroughTool(mockMcpServer);
26
- });
27
- describe('register', () => {
28
- it('should register tool with correct parameters and enhanced description', () => {
29
- const result = tool.register();
30
- expect(mockMcpServer.registerTool).toHaveBeenCalledWith('guided-walkthrough-cli', expect.objectContaining({
31
- title: 'Guided walkthrough of the CLI',
32
- description: expect.stringContaining('Give the user a guided walkthrough of the HubSpot CLI'),
33
- inputSchema: expect.any(Object),
34
- }), expect.any(Function));
35
- expect(result).toBe(mockRegisteredTool);
36
- });
37
- });
38
- describe('handler', () => {
39
- it('should show help for hs init command', async () => {
40
- const helpOutput = 'Usage: hs init [options]\nInitialize HubSpot CLI';
41
- mockExecAsync.mockResolvedValue({
42
- stdout: helpOutput,
43
- stderr: '',
44
- });
45
- const result = await tool.handler({
46
- absoluteCurrentWorkingDirectory: '/test/dir',
47
- command: 'hs init',
48
- });
49
- expect(mockExecAsync).toHaveBeenCalledWith('hs init --help');
50
- expect(result.content).toHaveLength(1);
51
- expect(result.content[0].text).toContain(helpOutput);
52
- expect(result.content[0].text).toContain('hs auth');
53
- });
54
- it('should show help for hs auth command', async () => {
55
- const helpOutput = 'Usage: hs auth [options]\nAuthenticate with HubSpot';
56
- mockExecAsync.mockResolvedValue({
57
- stdout: helpOutput,
58
- stderr: '',
59
- });
60
- const result = await tool.handler({
61
- absoluteCurrentWorkingDirectory: '/test/dir',
62
- command: 'hs auth',
63
- });
64
- expect(mockExecAsync).toHaveBeenCalledWith('hs auth --help');
65
- expect(result.content[0].text).toContain(helpOutput);
66
- expect(result.content[0].text).toContain('hs project create');
67
- });
68
- it('should show help for hs project create command', async () => {
69
- const helpOutput = 'Usage: hs project create [options]\nCreate a new project';
70
- mockExecAsync.mockResolvedValue({
71
- stdout: helpOutput,
72
- stderr: '',
73
- });
74
- const result = await tool.handler({
75
- absoluteCurrentWorkingDirectory: '/test/dir',
76
- command: 'hs project create',
77
- });
78
- expect(mockExecAsync).toHaveBeenCalledWith('hs project create --help');
79
- expect(result.content[0].text).toContain(helpOutput);
80
- expect(result.content[0].text).toContain('hs project upload');
81
- });
82
- it('should show help for hs project upload command', async () => {
83
- const helpOutput = 'Usage: hs project upload [options]\nUpload project to HubSpot';
84
- mockExecAsync.mockResolvedValue({
85
- stdout: helpOutput,
86
- stderr: '',
87
- });
88
- const result = await tool.handler({
89
- absoluteCurrentWorkingDirectory: '/test/dir',
90
- command: 'hs project upload',
91
- });
92
- expect(mockExecAsync).toHaveBeenCalledWith('hs project upload --help');
93
- expect(result.content[0].text).toContain(helpOutput);
94
- expect(result.content[0].text).toContain('hs project dev');
95
- });
96
- it('should handle command without next step', async () => {
97
- const helpOutput = 'Usage: hs project dev [options]\nStart development server';
98
- mockExecAsync.mockResolvedValue({
99
- stdout: helpOutput,
100
- stderr: '',
101
- });
102
- // Test with a command that doesn't have a next command
103
- const result = await tool.handler({
104
- absoluteCurrentWorkingDirectory: '/test/dir',
105
- command: 'hs project upload',
106
- });
107
- expect(result.content[0].text).toContain(helpOutput);
108
- expect(result.content[0].text).toContain('hs project dev');
109
- });
110
- it('should handle no command provided', async () => {
111
- const result = await tool.handler({
112
- absoluteCurrentWorkingDirectory: '/test/dir',
113
- });
114
- expect(mockExecAsync).not.toHaveBeenCalled();
115
- expect(result.content).toEqual([
116
- {
117
- type: 'text',
118
- text: 'Is there another command you would like to learn more about?',
119
- },
120
- ]);
121
- });
122
- it('should handle undefined command', async () => {
123
- const result = await tool.handler({
124
- absoluteCurrentWorkingDirectory: '/test/dir',
125
- command: undefined,
126
- });
127
- expect(mockExecAsync).not.toHaveBeenCalled();
128
- expect(result.content).toEqual([
129
- {
130
- type: 'text',
131
- text: 'Is there another command you would like to learn more about?',
132
- },
133
- ]);
134
- });
135
- it('should handle execAsync errors', async () => {
136
- const error = new Error('Command not found');
137
- mockExecAsync.mockRejectedValue(error);
138
- await expect(tool.handler({
139
- absoluteCurrentWorkingDirectory: '/test/dir',
140
- command: 'hs init',
141
- })).rejects.toThrow('Command not found');
142
- });
143
- it('should format help text with proper instructions', async () => {
144
- const helpOutput = 'Usage: hs init\nOptions:\n --help Show help';
145
- mockExecAsync.mockResolvedValue({
146
- stdout: helpOutput,
147
- stderr: '',
148
- });
149
- const result = await tool.handler({
150
- absoluteCurrentWorkingDirectory: '/test/dir',
151
- command: 'hs init',
152
- });
153
- expect(result.content[0].text).toContain('Display this help output for the user amd wait for them to acknowledge:');
154
- expect(result.content[0].text).toContain(helpOutput);
155
- expect(result.content[0].text).toContain('Once they are ready, A good command to look at next is hs auth');
156
- });
157
- });
158
- });
@@ -1,187 +0,0 @@
1
- import { UploadProjectTools } from '../UploadProjectTools.js';
2
- import { getAllHsProfiles } from '@hubspot/project-parsing-lib/profiles';
3
- import { getProjectConfig } from '../../../../lib/projects/config.js';
4
- import { runCommandInDir } from '../../../utils/command.js';
5
- import { mcpFeedbackRequest } from '../../../utils/feedbackTracking.js';
6
- import { trackToolUsage } from '../../../utils/toolUsageTracking.js';
7
- vi.mock('@modelcontextprotocol/sdk/server/mcp.js');
8
- vi.mock('@hubspot/project-parsing-lib/profiles');
9
- vi.mock('../../../../lib/projects/config.js');
10
- vi.mock('../../../utils/command', () => ({
11
- runCommandInDir: vi.fn(),
12
- addFlag: vi.fn((command, flagName, value) => {
13
- if (Array.isArray(value)) {
14
- return `${command} --${flagName} ${value.map(item => `"${item}"`).join(' ')}`;
15
- }
16
- return `${command} --${flagName} "${value}"`;
17
- }),
18
- }));
19
- vi.mock('../../../utils/toolUsageTracking');
20
- vi.mock('../../../utils/feedbackTracking');
21
- const mockTrackToolUsage = trackToolUsage;
22
- const mockMcpFeedbackRequest = mcpFeedbackRequest;
23
- const mockRunCommandInDir = runCommandInDir;
24
- const mockGetProjectConfig = getProjectConfig;
25
- const mockGetAllHsProfiles = getAllHsProfiles;
26
- describe('mcp-server/tools/project/UploadProjectTools', () => {
27
- let mockMcpServer;
28
- let tool;
29
- let mockRegisteredTool;
30
- beforeEach(() => {
31
- // @ts-expect-error noy mocking whole server
32
- mockMcpServer = {
33
- registerTool: vi.fn(),
34
- };
35
- mockRegisteredTool = {};
36
- mockMcpServer.registerTool.mockReturnValue(mockRegisteredTool);
37
- mockMcpFeedbackRequest.mockResolvedValue('');
38
- mockTrackToolUsage.mockResolvedValue(undefined);
39
- mockGetProjectConfig.mockResolvedValue({
40
- projectConfig: {
41
- srcDir: 'src',
42
- name: 'test-project',
43
- platformVersion: '2025.2',
44
- },
45
- projectDir: '/test/project',
46
- });
47
- mockGetAllHsProfiles.mockResolvedValue([]);
48
- tool = new UploadProjectTools(mockMcpServer);
49
- });
50
- describe('register', () => {
51
- it('should register tool with correct parameters', () => {
52
- const result = tool.register();
53
- expect(mockMcpServer.registerTool).toHaveBeenCalledWith('upload-project', expect.objectContaining({
54
- title: 'Upload HubSpot Project',
55
- description: expect.stringContaining('Uploads the HubSpot project in current working directory.'),
56
- inputSchema: expect.any(Object),
57
- }), expect.any(Function));
58
- expect(result).toBe(mockRegisteredTool);
59
- });
60
- });
61
- describe('handler', () => {
62
- const input = {
63
- absoluteCurrentWorkingDirectory: '/test/dir',
64
- absoluteProjectPath: '/test/project',
65
- uploadMessage: 'Test upload message',
66
- };
67
- it('should upload project successfully', async () => {
68
- mockRunCommandInDir.mockResolvedValue({
69
- stdout: 'Project uploaded successfully',
70
- stderr: '',
71
- });
72
- const result = await tool.handler(input);
73
- expect(mockRunCommandInDir).toHaveBeenCalledWith('/test/project', expect.stringContaining('hs project upload'));
74
- expect(mockRunCommandInDir).toHaveBeenCalledWith('/test/project', expect.stringContaining('--force-create'));
75
- expect(mockRunCommandInDir).toHaveBeenCalledWith('/test/project', expect.stringContaining('--message "Test upload message"'));
76
- expect(result).toEqual({
77
- content: [
78
- { type: 'text', text: 'Project uploaded successfully' },
79
- { type: 'text', text: '' },
80
- {
81
- type: 'text',
82
- text: '\nIMPORTANT: If this project contains cards, remember that uploading does NOT make them live automatically. Cards must be manually added to a view in HubSpot to become visible to users.',
83
- },
84
- ],
85
- });
86
- });
87
- it('should handle upload with warnings', async () => {
88
- mockRunCommandInDir.mockResolvedValue({
89
- stdout: 'Project uploaded with warnings',
90
- stderr: 'Warning: some files were ignored',
91
- });
92
- const result = await tool.handler(input);
93
- expect(result.content).toEqual([
94
- { type: 'text', text: 'Project uploaded with warnings' },
95
- { type: 'text', text: 'Warning: some files were ignored' },
96
- {
97
- type: 'text',
98
- text: '\nIMPORTANT: If this project contains cards, remember that uploading does NOT make them live automatically. Cards must be manually added to a view in HubSpot to become visible to users.',
99
- },
100
- ]);
101
- });
102
- it('should handle upload errors', async () => {
103
- const error = new Error('Upload failed');
104
- mockRunCommandInDir.mockRejectedValue(error);
105
- await expect(tool.handler(input)).rejects.toThrow('Upload failed');
106
- });
107
- it('should use force-create and message flags', async () => {
108
- mockRunCommandInDir.mockResolvedValue({
109
- stdout: 'Project created and uploaded',
110
- stderr: '',
111
- });
112
- await tool.handler(input);
113
- expect(mockRunCommandInDir).toHaveBeenCalledWith('/test/project', expect.stringContaining('hs project upload'));
114
- expect(mockRunCommandInDir).toHaveBeenCalledWith('/test/project', expect.stringContaining('--force-create'));
115
- expect(mockRunCommandInDir).toHaveBeenCalledWith('/test/project', expect.stringContaining('--message "Test upload message"'));
116
- });
117
- it('should use profiles', async () => {
118
- mockRunCommandInDir.mockResolvedValue({
119
- stdout: 'Project created and uploaded',
120
- stderr: '',
121
- });
122
- await tool.handler({
123
- ...input,
124
- profile: 'dev',
125
- });
126
- expect(mockRunCommandInDir).toHaveBeenCalledWith('/test/project', expect.stringContaining('hs project upload'));
127
- expect(mockRunCommandInDir).toHaveBeenCalledWith('/test/project', expect.stringContaining('--force-create'));
128
- expect(mockRunCommandInDir).toHaveBeenCalledWith('/test/project', expect.stringContaining('--message "Test upload message"'));
129
- expect(mockRunCommandInDir).toHaveBeenCalledWith('/test/project', expect.stringContaining('--profile "dev"'));
130
- });
131
- it('should prompt for profile if not specified and the project requires them', async () => {
132
- mockGetAllHsProfiles.mockResolvedValue(['prod', 'dev']);
133
- mockRunCommandInDir.mockResolvedValue({
134
- stdout: 'Project created and uploaded',
135
- stderr: '',
136
- });
137
- const result = await tool.handler(input);
138
- expect(mockRunCommandInDir).not.toHaveBeenCalled();
139
- expect(result.content).toEqual([
140
- {
141
- type: 'text',
142
- text: 'Ask the user which profile they would like to use for the upload.',
143
- },
144
- ]);
145
- });
146
- it('should handle empty stdout and stderr', async () => {
147
- mockRunCommandInDir.mockResolvedValue({
148
- stdout: '',
149
- stderr: '',
150
- });
151
- const result = await tool.handler(input);
152
- expect(result.content).toEqual([
153
- { type: 'text', text: '' },
154
- { type: 'text', text: '' },
155
- {
156
- type: 'text',
157
- text: '\nIMPORTANT: If this project contains cards, remember that uploading does NOT make them live automatically. Cards must be manually added to a view in HubSpot to become visible to users.',
158
- },
159
- ]);
160
- });
161
- it('should work with different project paths', async () => {
162
- mockRunCommandInDir.mockResolvedValue({
163
- stdout: 'Upload complete',
164
- stderr: '',
165
- });
166
- const differentInput = {
167
- absoluteCurrentWorkingDirectory: '/test/dir',
168
- absoluteProjectPath: '/different/path/to/project',
169
- uploadMessage: 'Different test upload message',
170
- };
171
- await tool.handler(differentInput);
172
- expect(mockRunCommandInDir).toHaveBeenCalledWith('/different/path/to/project', expect.stringContaining('hs project upload'));
173
- expect(mockRunCommandInDir).toHaveBeenCalledWith('/different/path/to/project', expect.stringContaining('--force-create'));
174
- expect(mockRunCommandInDir).toHaveBeenCalledWith('/different/path/to/project', expect.stringContaining('--message "Different test upload message"'));
175
- });
176
- it('should handle very long output', async () => {
177
- const longOutput = 'A'.repeat(10000);
178
- mockRunCommandInDir.mockResolvedValue({
179
- stdout: longOutput,
180
- stderr: 'Long stderr output',
181
- });
182
- const result = await tool.handler(input);
183
- expect(result.content[0].text).toBe(longOutput);
184
- expect(result.content[1].text).toBe('Long stderr output');
185
- });
186
- });
187
- });