@hubspot/cli 8.0.11-experimental.0 → 8.0.11-experimental.1

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 (534) hide show
  1. package/bin/cli.js +2 -0
  2. package/commands/account/auth.js +12 -22
  3. package/commands/account/clean.js +5 -6
  4. package/commands/account/createOverride.js +7 -7
  5. package/commands/account/info.js +2 -1
  6. package/commands/account/list.js +3 -5
  7. package/commands/account/remove.js +2 -3
  8. package/commands/account/removeOverride.js +8 -10
  9. package/commands/account/rename.js +5 -6
  10. package/commands/account/use.js +8 -19
  11. package/commands/api.d.ts +10 -0
  12. package/commands/api.js +164 -0
  13. package/commands/app/migrate.js +8 -8
  14. package/commands/app/secret/add.js +6 -7
  15. package/commands/app/secret/delete.js +9 -10
  16. package/commands/app/secret/list.js +6 -7
  17. package/commands/app/secret/update.js +8 -9
  18. package/commands/auth.js +12 -12
  19. package/commands/cms/app/create.js +9 -5
  20. package/commands/cms/convertFields.js +8 -8
  21. package/commands/cms/delete.js +2 -3
  22. package/commands/cms/fetch.js +7 -7
  23. package/commands/cms/function/create.js +9 -5
  24. package/commands/cms/function/deploy.js +2 -3
  25. package/commands/cms/function/list.js +11 -7
  26. package/commands/cms/function/logs.js +17 -23
  27. package/commands/cms/function/server.js +2 -3
  28. package/commands/cms/getReactModule.js +7 -8
  29. package/commands/cms/lighthouseScore.js +25 -24
  30. package/commands/cms/lint.js +4 -5
  31. package/commands/cms/list.js +5 -6
  32. package/commands/cms/module/create.js +9 -5
  33. package/commands/cms/module/marketplace-validate.js +7 -8
  34. package/commands/cms/mv.js +2 -3
  35. package/commands/cms/template/create.js +10 -6
  36. package/commands/cms/theme/create.js +5 -5
  37. package/commands/cms/theme/generate-selectors.js +5 -4
  38. package/commands/cms/theme/marketplace-validate.js +8 -9
  39. package/commands/cms/theme/preview.js +16 -8
  40. package/commands/cms/upload.js +15 -12
  41. package/commands/cms/watch.js +5 -5
  42. package/commands/cms/webpack/create.js +5 -5
  43. package/commands/completion.js +3 -5
  44. package/commands/config/migrate.js +6 -7
  45. package/commands/config/set.js +5 -6
  46. package/commands/customObject/create.js +4 -5
  47. package/commands/customObject/createSchema.js +4 -5
  48. package/commands/customObject/deleteSchema.js +4 -5
  49. package/commands/customObject/fetchAllSchemas.js +2 -3
  50. package/commands/customObject/fetchSchema.js +2 -3
  51. package/commands/customObject/listSchemas.js +2 -3
  52. package/commands/customObject/updateSchema.js +4 -5
  53. package/commands/doctor.js +8 -8
  54. package/commands/feedback.js +6 -4
  55. package/commands/filemanager/fetch.js +5 -6
  56. package/commands/filemanager/upload.js +5 -5
  57. package/commands/getStarted.js +14 -16
  58. package/commands/hubdb/clear.js +5 -6
  59. package/commands/hubdb/create.js +4 -5
  60. package/commands/hubdb/delete.js +8 -9
  61. package/commands/hubdb/fetch.js +5 -6
  62. package/commands/hubdb/list.js +16 -14
  63. package/commands/init.js +14 -17
  64. package/commands/mcp/setup.js +5 -6
  65. package/commands/mcp/start.js +2 -3
  66. package/commands/open.js +4 -5
  67. package/commands/project/add.js +10 -5
  68. package/commands/project/create.js +10 -10
  69. package/commands/project/delete.d.ts +7 -0
  70. package/commands/project/delete.js +74 -0
  71. package/commands/project/deploy.js +36 -34
  72. package/commands/project/dev/deprecatedFlow.js +42 -15
  73. package/commands/project/dev/index.d.ts +3 -3
  74. package/commands/project/dev/index.js +24 -30
  75. package/commands/project/dev/unifiedFlow.js +37 -14
  76. package/commands/project/download.js +10 -11
  77. package/commands/project/info.js +17 -17
  78. package/commands/project/installDeps.js +9 -6
  79. package/commands/project/lint.js +11 -8
  80. package/commands/project/list.js +14 -14
  81. package/commands/project/listBuilds.js +8 -6
  82. package/commands/project/logs.js +5 -6
  83. package/commands/project/migrate.js +8 -8
  84. package/commands/project/open.js +5 -6
  85. package/commands/project/profile/add.js +12 -8
  86. package/commands/project/profile/delete.js +15 -11
  87. package/commands/project/updateDeps.js +9 -6
  88. package/commands/project/upload.js +31 -17
  89. package/commands/project/validate.js +11 -11
  90. package/commands/project/watch.js +20 -20
  91. package/commands/project.js +2 -0
  92. package/commands/sandbox/create.js +15 -15
  93. package/commands/sandbox/delete.js +13 -14
  94. package/commands/secret/addSecret.js +6 -7
  95. package/commands/secret/deleteSecret.js +5 -6
  96. package/commands/secret/listSecret.js +2 -3
  97. package/commands/secret/updateSecret.js +4 -5
  98. package/commands/testAccount/create.d.ts +1 -1
  99. package/commands/testAccount/create.js +20 -16
  100. package/commands/testAccount/createConfig.js +7 -8
  101. package/commands/testAccount/delete.js +27 -18
  102. package/commands/testAccount/importData.js +6 -7
  103. package/commands/upgrade.js +9 -10
  104. package/lang/en.d.ts +94 -7
  105. package/lang/en.js +94 -10
  106. package/lib/accountAuth.js +2 -2
  107. package/lib/buildAccount.js +3 -3
  108. package/lib/constants.d.ts +0 -1
  109. package/lib/constants.js +0 -1
  110. package/lib/doctor/Diagnosis.js +5 -5
  111. package/lib/errorHandlers/index.js +4 -3
  112. package/lib/errorHandlers/suppressError.js +4 -0
  113. package/lib/errors/PromptExitError.d.ts +4 -2
  114. package/lib/errors/PromptExitError.js +3 -0
  115. package/lib/hasFeature.js +1 -2
  116. package/lib/middleware/autoUpdateMiddleware.js +6 -3
  117. package/lib/process.d.ts +1 -1
  118. package/lib/process.js +10 -3
  119. package/lib/projects/create/v2.js +1 -2
  120. package/lib/projects/delete.d.ts +13 -0
  121. package/lib/projects/delete.js +193 -0
  122. package/lib/projects/localDev/AppDevModeInterface.js +11 -11
  123. package/lib/projects/localDev/DevServerManager_DEPRECATED.d.ts +3 -1
  124. package/lib/projects/localDev/DevServerManager_DEPRECATED.js +2 -2
  125. package/lib/projects/localDev/DevSessionManager.d.ts +6 -3
  126. package/lib/projects/localDev/DevSessionManager.js +31 -19
  127. package/lib/projects/localDev/LocalDevManager_DEPRECATED.d.ts +3 -0
  128. package/lib/projects/localDev/LocalDevManager_DEPRECATED.js +16 -12
  129. package/lib/projects/localDev/LocalDevProcess.js +6 -5
  130. package/lib/projects/localDev/LocalDevState.d.ts +3 -2
  131. package/lib/projects/localDev/LocalDevState.js +3 -1
  132. package/lib/projects/localDev/helpers/account.d.ts +4 -3
  133. package/lib/projects/localDev/helpers/account.js +16 -19
  134. package/lib/projects/localDev/helpers/process.d.ts +1 -1
  135. package/lib/projects/localDev/helpers/process.js +4 -10
  136. package/lib/projects/localDev/helpers/project.d.ts +4 -3
  137. package/lib/projects/localDev/helpers/project.js +31 -15
  138. package/lib/projects/projectInfo.d.ts +3 -20
  139. package/lib/projects/projectInfo.js +32 -54
  140. package/lib/projects/projectProfiles.d.ts +1 -2
  141. package/lib/projects/projectProfiles.js +5 -17
  142. package/lib/projects/upload.js +19 -0
  143. package/lib/projects/workspaces.d.ts +42 -0
  144. package/lib/projects/workspaces.js +350 -0
  145. package/lib/prompts/createApiSamplePrompt.js +4 -0
  146. package/lib/prompts/projectProfilePrompt.d.ts +2 -0
  147. package/lib/prompts/projectProfilePrompt.js +46 -0
  148. package/lib/prompts/promptUtils.js +3 -2
  149. package/lib/prompts/selectHubDBTablePrompt.js +2 -2
  150. package/lib/prompts/selectPublicAppForMigrationPrompt.js +2 -2
  151. package/lib/theme/cmsDevServerProcess.d.ts +2 -0
  152. package/lib/theme/cmsDevServerProcess.js +7 -6
  153. package/lib/ui/SpinniesManager.d.ts +1 -0
  154. package/lib/ui/SpinniesManager.js +20 -6
  155. package/lib/ui/spinniesUtils.d.ts +0 -1
  156. package/lib/ui/spinniesUtils.js +6 -16
  157. package/lib/usageTracking.d.ts +3 -4
  158. package/lib/yargs/makeYargsBuilder.d.ts +13 -0
  159. package/lib/yargs/makeYargsBuilder.js +33 -0
  160. package/lib/yargs/makeYargsHandlerWithUsageTracking.d.ts +3 -0
  161. package/lib/yargs/makeYargsHandlerWithUsageTracking.js +95 -0
  162. package/lib/yargs/strictEnforceBoolean.d.ts +1 -0
  163. package/lib/yargs/strictEnforceBoolean.js +13 -0
  164. package/lib/yargsUtils.d.ts +3 -16
  165. package/lib/yargsUtils.js +3 -48
  166. package/mcp-server/tools/cms/HsCreateTemplateTool.d.ts +1 -1
  167. package/package.json +10 -5
  168. package/types/LocalDev.d.ts +5 -0
  169. package/types/Projects.d.ts +19 -0
  170. package/types/Yargs.d.ts +18 -1
  171. package/api/__tests__/migrate.test.d.ts +0 -1
  172. package/api/__tests__/migrate.test.js +0 -199
  173. package/commands/__tests__/account.test.d.ts +0 -1
  174. package/commands/__tests__/account.test.js +0 -69
  175. package/commands/__tests__/auth.test.d.ts +0 -1
  176. package/commands/__tests__/auth.test.js +0 -43
  177. package/commands/__tests__/cms.test.d.ts +0 -1
  178. package/commands/__tests__/cms.test.js +0 -87
  179. package/commands/__tests__/config.test.d.ts +0 -1
  180. package/commands/__tests__/config.test.js +0 -44
  181. package/commands/__tests__/customObject.test.d.ts +0 -1
  182. package/commands/__tests__/customObject.test.js +0 -68
  183. package/commands/__tests__/doctor.test.d.ts +0 -1
  184. package/commands/__tests__/doctor.test.js +0 -132
  185. package/commands/__tests__/feedback.test.d.ts +0 -1
  186. package/commands/__tests__/feedback.test.js +0 -24
  187. package/commands/__tests__/filemanager.test.d.ts +0 -1
  188. package/commands/__tests__/filemanager.test.js +0 -45
  189. package/commands/__tests__/getStarted.test.d.ts +0 -1
  190. package/commands/__tests__/getStarted.test.js +0 -173
  191. package/commands/__tests__/hubdb.test.d.ts +0 -1
  192. package/commands/__tests__/hubdb.test.js +0 -50
  193. package/commands/__tests__/init.test.d.ts +0 -1
  194. package/commands/__tests__/init.test.js +0 -42
  195. package/commands/__tests__/mcp.test.d.ts +0 -1
  196. package/commands/__tests__/mcp.test.js +0 -46
  197. package/commands/__tests__/open.test.d.ts +0 -1
  198. package/commands/__tests__/open.test.js +0 -58
  199. package/commands/__tests__/project.test.d.ts +0 -1
  200. package/commands/__tests__/project.test.js +0 -125
  201. package/commands/__tests__/sandbox.test.d.ts +0 -1
  202. package/commands/__tests__/sandbox.test.js +0 -44
  203. package/commands/__tests__/secret.test.d.ts +0 -1
  204. package/commands/__tests__/secret.test.js +0 -49
  205. package/commands/__tests__/testAccount.test.d.ts +0 -1
  206. package/commands/__tests__/testAccount.test.js +0 -57
  207. package/commands/__tests__/upgrade.test.d.ts +0 -1
  208. package/commands/__tests__/upgrade.test.js +0 -309
  209. package/commands/account/__tests__/auth.test.d.ts +0 -1
  210. package/commands/account/__tests__/auth.test.js +0 -206
  211. package/commands/account/__tests__/clean.test.d.ts +0 -1
  212. package/commands/account/__tests__/clean.test.js +0 -28
  213. package/commands/account/__tests__/createOverride.test.d.ts +0 -1
  214. package/commands/account/__tests__/createOverride.test.js +0 -32
  215. package/commands/account/__tests__/info.test.d.ts +0 -1
  216. package/commands/account/__tests__/info.test.js +0 -28
  217. package/commands/account/__tests__/list.test.d.ts +0 -1
  218. package/commands/account/__tests__/list.test.js +0 -153
  219. package/commands/account/__tests__/remove.test.d.ts +0 -1
  220. package/commands/account/__tests__/remove.test.js +0 -36
  221. package/commands/account/__tests__/removeOverride.d.ts +0 -1
  222. package/commands/account/__tests__/removeOverride.js +0 -25
  223. package/commands/account/__tests__/rename.test.d.ts +0 -1
  224. package/commands/account/__tests__/rename.test.js +0 -82
  225. package/commands/account/__tests__/use.test.d.ts +0 -1
  226. package/commands/account/__tests__/use.test.js +0 -170
  227. package/commands/app/__tests__/migrate.test.d.ts +0 -1
  228. package/commands/app/__tests__/migrate.test.js +0 -111
  229. package/commands/app/secret/__tests__/add.test.d.ts +0 -1
  230. package/commands/app/secret/__tests__/add.test.js +0 -140
  231. package/commands/app/secret/__tests__/delete.test.d.ts +0 -1
  232. package/commands/app/secret/__tests__/delete.test.js +0 -28
  233. package/commands/app/secret/__tests__/list.test.d.ts +0 -1
  234. package/commands/app/secret/__tests__/list.test.js +0 -25
  235. package/commands/app/secret/__tests__/update.test.d.ts +0 -1
  236. package/commands/app/secret/__tests__/update.test.js +0 -28
  237. package/commands/cms/__tests__/delete.test.d.ts +0 -1
  238. package/commands/cms/__tests__/delete.test.js +0 -39
  239. package/commands/cms/__tests__/fetch.test.d.ts +0 -1
  240. package/commands/cms/__tests__/fetch.test.js +0 -156
  241. package/commands/cms/__tests__/function.test.d.ts +0 -1
  242. package/commands/cms/__tests__/function.test.js +0 -50
  243. package/commands/cms/__tests__/lint.test.d.ts +0 -1
  244. package/commands/cms/__tests__/lint.test.js +0 -33
  245. package/commands/cms/__tests__/list.test.d.ts +0 -1
  246. package/commands/cms/__tests__/list.test.js +0 -42
  247. package/commands/cms/__tests__/module.test.d.ts +0 -1
  248. package/commands/cms/__tests__/module.test.js +0 -45
  249. package/commands/cms/__tests__/mv.test.d.ts +0 -1
  250. package/commands/cms/__tests__/mv.test.js +0 -46
  251. package/commands/cms/__tests__/theme.test.d.ts +0 -1
  252. package/commands/cms/__tests__/theme.test.js +0 -54
  253. package/commands/cms/__tests__/upload.test.d.ts +0 -1
  254. package/commands/cms/__tests__/upload.test.js +0 -312
  255. package/commands/cms/__tests__/watch.test.d.ts +0 -1
  256. package/commands/cms/__tests__/watch.test.js +0 -204
  257. package/commands/cms/function/__tests__/logs.test.d.ts +0 -1
  258. package/commands/cms/function/__tests__/logs.test.js +0 -70
  259. package/commands/cms/theme/__tests__/generate-selectors.test.d.ts +0 -1
  260. package/commands/cms/theme/__tests__/generate-selectors.test.js +0 -28
  261. package/commands/cms/theme/__tests__/marketplace-validate.test.d.ts +0 -1
  262. package/commands/cms/theme/__tests__/marketplace-validate.test.js +0 -36
  263. package/commands/cms/theme/__tests__/preview.test.d.ts +0 -1
  264. package/commands/cms/theme/__tests__/preview.test.js +0 -54
  265. package/commands/customObject/__tests__/create.test.d.ts +0 -1
  266. package/commands/customObject/__tests__/create.test.js +0 -40
  267. package/commands/customObject/__tests__/createSchema.test.d.ts +0 -1
  268. package/commands/customObject/__tests__/createSchema.test.js +0 -28
  269. package/commands/customObject/__tests__/deleteSchema.test.d.ts +0 -1
  270. package/commands/customObject/__tests__/deleteSchema.test.js +0 -42
  271. package/commands/customObject/__tests__/fetch-all-schemas.test.d.ts +0 -1
  272. package/commands/customObject/__tests__/fetch-all-schemas.test.js +0 -41
  273. package/commands/customObject/__tests__/fetchSchema.test.d.ts +0 -1
  274. package/commands/customObject/__tests__/fetchSchema.test.js +0 -45
  275. package/commands/customObject/__tests__/listSchemas.test.d.ts +0 -1
  276. package/commands/customObject/__tests__/listSchemas.test.js +0 -29
  277. package/commands/customObject/__tests__/updateSchema.test.d.ts +0 -1
  278. package/commands/customObject/__tests__/updateSchema.test.js +0 -40
  279. package/commands/filemanager/__tests__/fetch.test.d.ts +0 -1
  280. package/commands/filemanager/__tests__/fetch.test.js +0 -32
  281. package/commands/filemanager/__tests__/upload.test.d.ts +0 -1
  282. package/commands/filemanager/__tests__/upload.test.js +0 -191
  283. package/commands/hubdb/__tests__/clear.test.d.ts +0 -1
  284. package/commands/hubdb/__tests__/clear.test.js +0 -28
  285. package/commands/hubdb/__tests__/create.test.d.ts +0 -1
  286. package/commands/hubdb/__tests__/create.test.js +0 -28
  287. package/commands/hubdb/__tests__/delete.test.d.ts +0 -1
  288. package/commands/hubdb/__tests__/delete.test.js +0 -28
  289. package/commands/hubdb/__tests__/fetch.test.d.ts +0 -1
  290. package/commands/hubdb/__tests__/fetch.test.js +0 -28
  291. package/commands/hubdb/__tests__/list.test.d.ts +0 -1
  292. package/commands/hubdb/__tests__/list.test.js +0 -88
  293. package/commands/mcp/__tests__/setup.test.d.ts +0 -1
  294. package/commands/mcp/__tests__/setup.test.js +0 -26
  295. package/commands/mcp/__tests__/start.test.d.ts +0 -1
  296. package/commands/mcp/__tests__/start.test.js +0 -144
  297. package/commands/project/__tests__/add.test.d.ts +0 -1
  298. package/commands/project/__tests__/add.test.js +0 -107
  299. package/commands/project/__tests__/create.test.d.ts +0 -1
  300. package/commands/project/__tests__/create.test.js +0 -97
  301. package/commands/project/__tests__/deploy.test.d.ts +0 -1
  302. package/commands/project/__tests__/deploy.test.js +0 -307
  303. package/commands/project/__tests__/dev.test.d.ts +0 -1
  304. package/commands/project/__tests__/dev.test.js +0 -273
  305. package/commands/project/__tests__/devUnifiedFlow.test.d.ts +0 -1
  306. package/commands/project/__tests__/devUnifiedFlow.test.js +0 -434
  307. package/commands/project/__tests__/download.test.d.ts +0 -1
  308. package/commands/project/__tests__/download.test.js +0 -39
  309. package/commands/project/__tests__/info.test.d.ts +0 -1
  310. package/commands/project/__tests__/info.test.js +0 -145
  311. package/commands/project/__tests__/installDeps.test.d.ts +0 -1
  312. package/commands/project/__tests__/installDeps.test.js +0 -140
  313. package/commands/project/__tests__/lint.test.d.ts +0 -1
  314. package/commands/project/__tests__/lint.test.js +0 -704
  315. package/commands/project/__tests__/list.test.d.ts +0 -1
  316. package/commands/project/__tests__/list.test.js +0 -31
  317. package/commands/project/__tests__/listBuilds.test.d.ts +0 -1
  318. package/commands/project/__tests__/listBuilds.test.js +0 -38
  319. package/commands/project/__tests__/logs.test.d.ts +0 -1
  320. package/commands/project/__tests__/logs.test.js +0 -202
  321. package/commands/project/__tests__/migrate.test.d.ts +0 -1
  322. package/commands/project/__tests__/migrate.test.js +0 -106
  323. package/commands/project/__tests__/open.test.d.ts +0 -1
  324. package/commands/project/__tests__/open.test.js +0 -39
  325. package/commands/project/__tests__/profile.test.d.ts +0 -1
  326. package/commands/project/__tests__/profile.test.js +0 -42
  327. package/commands/project/__tests__/updateDeps.test.d.ts +0 -1
  328. package/commands/project/__tests__/updateDeps.test.js +0 -140
  329. package/commands/project/__tests__/upload.test.d.ts +0 -1
  330. package/commands/project/__tests__/upload.test.js +0 -234
  331. package/commands/project/__tests__/validate.test.d.ts +0 -1
  332. package/commands/project/__tests__/validate.test.js +0 -381
  333. package/commands/project/__tests__/watch.test.d.ts +0 -1
  334. package/commands/project/__tests__/watch.test.js +0 -35
  335. package/commands/sandbox/__tests__/create.test.d.ts +0 -1
  336. package/commands/sandbox/__tests__/create.test.js +0 -198
  337. package/commands/sandbox/__tests__/delete.test.d.ts +0 -1
  338. package/commands/sandbox/__tests__/delete.test.js +0 -31
  339. package/commands/secret/__tests__/addSecret.test.d.ts +0 -1
  340. package/commands/secret/__tests__/addSecret.test.js +0 -162
  341. package/commands/secret/__tests__/deleteSecret.test.d.ts +0 -1
  342. package/commands/secret/__tests__/deleteSecret.test.js +0 -41
  343. package/commands/secret/__tests__/listSecret.test.d.ts +0 -1
  344. package/commands/secret/__tests__/listSecret.test.js +0 -29
  345. package/commands/secret/__tests__/updateSecret.test.d.ts +0 -1
  346. package/commands/secret/__tests__/updateSecret.test.js +0 -29
  347. package/commands/testAccount/__tests__/create.test.d.ts +0 -1
  348. package/commands/testAccount/__tests__/create.test.js +0 -106
  349. package/commands/testAccount/__tests__/createConfig.test.d.ts +0 -1
  350. package/commands/testAccount/__tests__/createConfig.test.js +0 -32
  351. package/commands/testAccount/__tests__/delete.test.d.ts +0 -1
  352. package/commands/testAccount/__tests__/delete.test.js +0 -29
  353. package/commands/testAccount/__tests__/importData.test.d.ts +0 -1
  354. package/commands/testAccount/__tests__/importData.test.js +0 -92
  355. package/lib/__tests__/CLIWebSocketServer.test.d.ts +0 -1
  356. package/lib/__tests__/CLIWebSocketServer.test.js +0 -252
  357. package/lib/__tests__/accountAuth.test.d.ts +0 -1
  358. package/lib/__tests__/accountAuth.test.js +0 -258
  359. package/lib/__tests__/accountTypes.test.d.ts +0 -1
  360. package/lib/__tests__/accountTypes.test.js +0 -98
  361. package/lib/__tests__/buildAccount.test.d.ts +0 -1
  362. package/lib/__tests__/buildAccount.test.js +0 -211
  363. package/lib/__tests__/cliUpgradeUtils.test.d.ts +0 -1
  364. package/lib/__tests__/cliUpgradeUtils.test.js +0 -131
  365. package/lib/__tests__/commandSuggestion.test.d.ts +0 -1
  366. package/lib/__tests__/commandSuggestion.test.js +0 -121
  367. package/lib/__tests__/commonOpts.test.d.ts +0 -1
  368. package/lib/__tests__/commonOpts.test.js +0 -80
  369. package/lib/__tests__/dependencyManagement.test.d.ts +0 -1
  370. package/lib/__tests__/dependencyManagement.test.js +0 -1067
  371. package/lib/__tests__/developerTestAccounts.test.d.ts +0 -1
  372. package/lib/__tests__/developerTestAccounts.test.js +0 -156
  373. package/lib/__tests__/hasFeature.test.d.ts +0 -1
  374. package/lib/__tests__/hasFeature.test.js +0 -167
  375. package/lib/__tests__/http.test.d.ts +0 -1
  376. package/lib/__tests__/http.test.js +0 -40
  377. package/lib/__tests__/importData.test.d.ts +0 -1
  378. package/lib/__tests__/importData.test.js +0 -98
  379. package/lib/__tests__/npmCli.test.d.ts +0 -1
  380. package/lib/__tests__/npmCli.test.js +0 -84
  381. package/lib/__tests__/oauth.test.d.ts +0 -1
  382. package/lib/__tests__/oauth.test.js +0 -109
  383. package/lib/__tests__/parsing.test.d.ts +0 -1
  384. package/lib/__tests__/parsing.test.js +0 -34
  385. package/lib/__tests__/polling.test.d.ts +0 -1
  386. package/lib/__tests__/polling.test.js +0 -76
  387. package/lib/__tests__/process.test.d.ts +0 -1
  388. package/lib/__tests__/process.test.js +0 -89
  389. package/lib/__tests__/sandboxes.test.d.ts +0 -1
  390. package/lib/__tests__/sandboxes.test.js +0 -128
  391. package/lib/__tests__/serverlessLogs.test.d.ts +0 -1
  392. package/lib/__tests__/serverlessLogs.test.js +0 -163
  393. package/lib/__tests__/usageTracking.test.d.ts +0 -1
  394. package/lib/__tests__/usageTracking.test.js +0 -197
  395. package/lib/__tests__/validation.test.d.ts +0 -1
  396. package/lib/__tests__/validation.test.js +0 -143
  397. package/lib/__tests__/yargsUtils.test.d.ts +0 -1
  398. package/lib/__tests__/yargsUtils.test.js +0 -124
  399. package/lib/app/__tests__/migrate.test.d.ts +0 -1
  400. package/lib/app/__tests__/migrate.test.js +0 -638
  401. package/lib/doctor/__tests__/Diagnosis.test.d.ts +0 -1
  402. package/lib/doctor/__tests__/Diagnosis.test.js +0 -84
  403. package/lib/doctor/__tests__/DiagnosticInfoBuilder.test.d.ts +0 -1
  404. package/lib/doctor/__tests__/DiagnosticInfoBuilder.test.js +0 -177
  405. package/lib/doctor/__tests__/Doctor.test.d.ts +0 -1
  406. package/lib/doctor/__tests__/Doctor.test.js +0 -560
  407. package/lib/errorHandlers/__tests__/index.test.d.ts +0 -1
  408. package/lib/errorHandlers/__tests__/index.test.js +0 -278
  409. package/lib/mcp/__tests__/setup.test.d.ts +0 -1
  410. package/lib/mcp/__tests__/setup.test.js +0 -523
  411. package/lib/middleware/__tests__/commandTargetingUtils.test.d.ts +0 -1
  412. package/lib/middleware/__tests__/commandTargetingUtils.test.js +0 -99
  413. package/lib/middleware/__tests__/configMiddleware.test.d.ts +0 -1
  414. package/lib/middleware/__tests__/configMiddleware.test.js +0 -118
  415. package/lib/middleware/__tests__/gitMiddleware.test.d.ts +0 -1
  416. package/lib/middleware/__tests__/gitMiddleware.test.js +0 -43
  417. package/lib/middleware/__tests__/requestMiddleware.test.d.ts +0 -1
  418. package/lib/middleware/__tests__/requestMiddleware.test.js +0 -15
  419. package/lib/middleware/__tests__/usageTrackingMiddleware.test.d.ts +0 -1
  420. package/lib/middleware/__tests__/usageTrackingMiddleware.test.js +0 -44
  421. package/lib/middleware/__tests__/yargsChecksMiddleware.test.d.ts +0 -1
  422. package/lib/middleware/__tests__/yargsChecksMiddleware.test.js +0 -39
  423. package/lib/projects/__tests__/AppDevModeInterface.test.d.ts +0 -1
  424. package/lib/projects/__tests__/AppDevModeInterface.test.js +0 -541
  425. package/lib/projects/__tests__/DevServerManager.test.d.ts +0 -1
  426. package/lib/projects/__tests__/DevServerManager.test.js +0 -185
  427. package/lib/projects/__tests__/DevSessionManager.test.d.ts +0 -1
  428. package/lib/projects/__tests__/DevSessionManager.test.js +0 -250
  429. package/lib/projects/__tests__/LocalDevProcess.test.d.ts +0 -1
  430. package/lib/projects/__tests__/LocalDevProcess.test.js +0 -481
  431. package/lib/projects/__tests__/LocalDevWebsocketServer.test.d.ts +0 -1
  432. package/lib/projects/__tests__/LocalDevWebsocketServer.test.js +0 -231
  433. package/lib/projects/__tests__/ProjectLogsManager.test.d.ts +0 -1
  434. package/lib/projects/__tests__/ProjectLogsManager.test.js +0 -302
  435. package/lib/projects/__tests__/UIExtensionsDevModeInterface.test.d.ts +0 -1
  436. package/lib/projects/__tests__/UIExtensionsDevModeInterface.test.js +0 -160
  437. package/lib/projects/__tests__/components.test.d.ts +0 -1
  438. package/lib/projects/__tests__/components.test.js +0 -440
  439. package/lib/projects/__tests__/deploy.test.d.ts +0 -1
  440. package/lib/projects/__tests__/deploy.test.js +0 -231
  441. package/lib/projects/__tests__/localDevProjectHelpers.test.d.ts +0 -1
  442. package/lib/projects/__tests__/localDevProjectHelpers.test.js +0 -120
  443. package/lib/projects/__tests__/platformVersion.test.d.ts +0 -1
  444. package/lib/projects/__tests__/platformVersion.test.js +0 -63
  445. package/lib/projects/__tests__/pollProjectBuildAndDeploy.test.d.ts +0 -1
  446. package/lib/projects/__tests__/pollProjectBuildAndDeploy.test.js +0 -328
  447. package/lib/projects/__tests__/projectInfo.test.d.ts +0 -1
  448. package/lib/projects/__tests__/projectInfo.test.js +0 -114
  449. package/lib/projects/__tests__/projectProfiles.test.d.ts +0 -1
  450. package/lib/projects/__tests__/projectProfiles.test.js +0 -441
  451. package/lib/projects/__tests__/projects.test.d.ts +0 -1
  452. package/lib/projects/__tests__/projects.test.js +0 -58
  453. package/lib/projects/__tests__/structure.test.d.ts +0 -1
  454. package/lib/projects/__tests__/structure.test.js +0 -210
  455. package/lib/projects/__tests__/uieLinting.test.d.ts +0 -1
  456. package/lib/projects/__tests__/uieLinting.test.js +0 -631
  457. package/lib/projects/__tests__/upload.test.d.ts +0 -1
  458. package/lib/projects/__tests__/upload.test.js +0 -183
  459. package/lib/projects/add/__tests__/legacyAddComponent.test.d.ts +0 -1
  460. package/lib/projects/add/__tests__/legacyAddComponent.test.js +0 -245
  461. package/lib/projects/add/__tests__/v2AddComponent.test.d.ts +0 -1
  462. package/lib/projects/add/__tests__/v2AddComponent.test.js +0 -343
  463. package/lib/projects/create/__tests__/legacy.test.d.ts +0 -1
  464. package/lib/projects/create/__tests__/legacy.test.js +0 -72
  465. package/lib/projects/create/__tests__/v2.test.d.ts +0 -1
  466. package/lib/projects/create/__tests__/v2.test.js +0 -257
  467. package/lib/prompts/__tests__/createDeveloperTestAccountConfigPrompt.test.d.ts +0 -1
  468. package/lib/prompts/__tests__/createDeveloperTestAccountConfigPrompt.test.js +0 -157
  469. package/lib/prompts/__tests__/createFunctionPrompt.test.d.ts +0 -1
  470. package/lib/prompts/__tests__/createFunctionPrompt.test.js +0 -129
  471. package/lib/prompts/__tests__/createModulePrompt.test.d.ts +0 -1
  472. package/lib/prompts/__tests__/createModulePrompt.test.js +0 -187
  473. package/lib/prompts/__tests__/createTemplatePrompt.test.d.ts +0 -1
  474. package/lib/prompts/__tests__/createTemplatePrompt.test.js +0 -102
  475. package/lib/prompts/__tests__/downloadProjectPrompt.test.d.ts +0 -1
  476. package/lib/prompts/__tests__/downloadProjectPrompt.test.js +0 -31
  477. package/lib/prompts/__tests__/projectAddPrompt.test.d.ts +0 -1
  478. package/lib/prompts/__tests__/projectAddPrompt.test.js +0 -143
  479. package/lib/prompts/__tests__/projectsLogsPrompt.test.d.ts +0 -1
  480. package/lib/prompts/__tests__/projectsLogsPrompt.test.js +0 -37
  481. package/lib/prompts/__tests__/selectProjectTemplatePrompt.test.d.ts +0 -1
  482. package/lib/prompts/__tests__/selectProjectTemplatePrompt.test.js +0 -160
  483. package/lib/theme/__tests__/migrate.test.d.ts +0 -1
  484. package/lib/theme/__tests__/migrate.test.js +0 -247
  485. package/lib/ui/__tests__/SpinniesManager.test.d.ts +0 -1
  486. package/lib/ui/__tests__/SpinniesManager.test.js +0 -488
  487. package/lib/ui/__tests__/removeAnsiCodes.test.d.ts +0 -1
  488. package/lib/ui/__tests__/removeAnsiCodes.test.js +0 -84
  489. package/mcp-server/tools/cms/__tests__/HsCreateFunctionTool.test.d.ts +0 -1
  490. package/mcp-server/tools/cms/__tests__/HsCreateFunctionTool.test.js +0 -254
  491. package/mcp-server/tools/cms/__tests__/HsCreateModuleTool.test.d.ts +0 -1
  492. package/mcp-server/tools/cms/__tests__/HsCreateModuleTool.test.js +0 -227
  493. package/mcp-server/tools/cms/__tests__/HsCreateTemplateTool.test.d.ts +0 -1
  494. package/mcp-server/tools/cms/__tests__/HsCreateTemplateTool.test.js +0 -208
  495. package/mcp-server/tools/cms/__tests__/HsFunctionLogsTool.test.d.ts +0 -1
  496. package/mcp-server/tools/cms/__tests__/HsFunctionLogsTool.test.js +0 -186
  497. package/mcp-server/tools/cms/__tests__/HsListFunctionsTool.test.d.ts +0 -1
  498. package/mcp-server/tools/cms/__tests__/HsListFunctionsTool.test.js +0 -124
  499. package/mcp-server/tools/cms/__tests__/HsListTool.test.d.ts +0 -1
  500. package/mcp-server/tools/cms/__tests__/HsListTool.test.js +0 -124
  501. package/mcp-server/tools/project/__tests__/AddFeatureToProjectTool.test.d.ts +0 -1
  502. package/mcp-server/tools/project/__tests__/AddFeatureToProjectTool.test.js +0 -157
  503. package/mcp-server/tools/project/__tests__/CreateProjectTool.test.d.ts +0 -1
  504. package/mcp-server/tools/project/__tests__/CreateProjectTool.test.js +0 -131
  505. package/mcp-server/tools/project/__tests__/CreateTestAccountTool.test.d.ts +0 -1
  506. package/mcp-server/tools/project/__tests__/CreateTestAccountTool.test.js +0 -461
  507. package/mcp-server/tools/project/__tests__/DeployProjectTool.test.d.ts +0 -1
  508. package/mcp-server/tools/project/__tests__/DeployProjectTool.test.js +0 -125
  509. package/mcp-server/tools/project/__tests__/DocFetchTool.test.d.ts +0 -1
  510. package/mcp-server/tools/project/__tests__/DocFetchTool.test.js +0 -125
  511. package/mcp-server/tools/project/__tests__/DocsSearchTool.test.d.ts +0 -1
  512. package/mcp-server/tools/project/__tests__/DocsSearchTool.test.js +0 -210
  513. package/mcp-server/tools/project/__tests__/GetApiUsagePatternsByAppIdTool.test.d.ts +0 -1
  514. package/mcp-server/tools/project/__tests__/GetApiUsagePatternsByAppIdTool.test.js +0 -146
  515. package/mcp-server/tools/project/__tests__/GetApplicationInfoTool.test.d.ts +0 -1
  516. package/mcp-server/tools/project/__tests__/GetApplicationInfoTool.test.js +0 -124
  517. package/mcp-server/tools/project/__tests__/GetBuildLogsTool.test.d.ts +0 -1
  518. package/mcp-server/tools/project/__tests__/GetBuildLogsTool.test.js +0 -307
  519. package/mcp-server/tools/project/__tests__/GetBuildStatusTool.test.d.ts +0 -1
  520. package/mcp-server/tools/project/__tests__/GetBuildStatusTool.test.js +0 -242
  521. package/mcp-server/tools/project/__tests__/GetConfigValuesTool.test.d.ts +0 -1
  522. package/mcp-server/tools/project/__tests__/GetConfigValuesTool.test.js +0 -209
  523. package/mcp-server/tools/project/__tests__/GuidedWalkthroughTool.test.d.ts +0 -1
  524. package/mcp-server/tools/project/__tests__/GuidedWalkthroughTool.test.js +0 -158
  525. package/mcp-server/tools/project/__tests__/UploadProjectTools.test.d.ts +0 -1
  526. package/mcp-server/tools/project/__tests__/UploadProjectTools.test.js +0 -187
  527. package/mcp-server/tools/project/__tests__/ValidateProjectTool.test.d.ts +0 -1
  528. package/mcp-server/tools/project/__tests__/ValidateProjectTool.test.js +0 -118
  529. package/mcp-server/utils/__tests__/command.test.d.ts +0 -1
  530. package/mcp-server/utils/__tests__/command.test.js +0 -275
  531. package/mcp-server/utils/__tests__/content.test.d.ts +0 -1
  532. package/mcp-server/utils/__tests__/content.test.js +0 -164
  533. package/mcp-server/utils/__tests__/feedbackTracking.test.d.ts +0 -1
  534. package/mcp-server/utils/__tests__/feedbackTracking.test.js +0 -69
@@ -1,57 +0,0 @@
1
- import yargs from 'yargs';
2
- import testAccountCreateCommand from '../testAccount/create.js';
3
- import testAccountCreateConfigCommand from '../testAccount/createConfig.js';
4
- import testAccountDeleteCommand from '../testAccount/delete.js';
5
- import testAccountImportDataCommand from '../testAccount/importData.js';
6
- import testAccountCommands from '../testAccount.js';
7
- vi.mock('../testAccount/create');
8
- vi.mock('../testAccount/createConfig');
9
- vi.mock('../testAccount/delete');
10
- vi.mock('../../lib/commonOpts');
11
- const commandSpy = vi
12
- .spyOn(yargs, 'command')
13
- .mockReturnValue(yargs);
14
- const demandCommandSpy = vi
15
- .spyOn(yargs, 'demandCommand')
16
- .mockReturnValue(yargs);
17
- describe('commands/testAccount', () => {
18
- describe('command', () => {
19
- it('should have the correct command structure', () => {
20
- expect(testAccountCommands.command).toEqual([
21
- 'test-account',
22
- 'test-accounts',
23
- ]);
24
- });
25
- });
26
- // This is commented out because the description is undefined rn
27
- // describe('describe', () => {
28
- // it('should provide a description', () => {
29
- // expect(testAccountCommands.describe).toBeDefined();
30
- // });
31
- // });
32
- describe('builder', () => {
33
- beforeEach(() => {
34
- commandSpy.mockClear();
35
- demandCommandSpy.mockClear();
36
- });
37
- const subcommands = [
38
- testAccountCreateCommand,
39
- testAccountCreateConfigCommand,
40
- testAccountDeleteCommand,
41
- testAccountImportDataCommand,
42
- ];
43
- it('should demand the command takes one positional argument', () => {
44
- testAccountCommands.builder(yargs);
45
- expect(demandCommandSpy).toHaveBeenCalledTimes(1);
46
- expect(demandCommandSpy).toHaveBeenCalledWith(1, '');
47
- });
48
- it('should add the correct number of sub commands', () => {
49
- testAccountCommands.builder(yargs);
50
- expect(commandSpy).toHaveBeenCalledTimes(subcommands.length);
51
- });
52
- it.each(subcommands)('should attach the %s subcommand', module => {
53
- testAccountCommands.builder(yargs);
54
- expect(commandSpy).toHaveBeenCalledWith(module);
55
- });
56
- });
57
- });
@@ -1 +0,0 @@
1
- export {};
@@ -1,309 +0,0 @@
1
- import { EXIT_CODES } from '../../lib/enums/exitCodes.js';
2
- import yargs from 'yargs';
3
- import upgradeCommand from '../upgrade.js';
4
- import { trackCommandUsage } from '../../lib/usageTracking.js';
5
- import { canCliBeAutoUpgraded, getLatestCliVersion, installCliVersion, } from '../../lib/cliUpgradeUtils.js';
6
- import { confirmPrompt } from '../../lib/prompts/promptUtils.js';
7
- import { uiLogger } from '../../lib/ui/logger.js';
8
- import { pkg } from '../../lib/jsonLoader.js';
9
- import SpinniesManager from '../../lib/ui/SpinniesManager.js';
10
- import { debugError } from '../../lib/errorHandlers/index.js';
11
- import { commands } from '../../lang/en.js';
12
- import { isConfigFlagEnabled } from '@hubspot/local-dev-lib/config';
13
- vi.mock('../../lib/usageTracking');
14
- vi.mock('@hubspot/local-dev-lib/config');
15
- vi.mock('../../lib/cliUpgradeUtils');
16
- vi.mock('../../lib/prompts/promptUtils');
17
- vi.mock('../../lib/ui/logger.js');
18
- vi.mock('../../lib/jsonLoader.js');
19
- vi.mock('../../lib/ui/SpinniesManager');
20
- vi.mock('../../lib/errorHandlers/index.js');
21
- const mockedTrackCommandUsage = vi.mocked(trackCommandUsage);
22
- const mockedCanCliBeAutoUpgraded = vi.mocked(canCliBeAutoUpgraded);
23
- const mockedGetLatestCliVersion = vi.mocked(getLatestCliVersion);
24
- const mockedInstallCliVersion = vi.mocked(installCliVersion);
25
- const mockedConfirmPrompt = vi.mocked(confirmPrompt);
26
- const mockedDebugError = vi.mocked(debugError);
27
- const mockedIsConfigFlagEnabled = vi.mocked(isConfigFlagEnabled);
28
- const optionSpy = vi
29
- .spyOn(yargs, 'option')
30
- .mockReturnValue(yargs);
31
- const positionalSpy = vi
32
- .spyOn(yargs, 'positional')
33
- .mockReturnValue(yargs);
34
- describe('commands/upgrade', () => {
35
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
36
- let processExitSpy;
37
- const accountId = 123456;
38
- const currentVersion = '7.11.2';
39
- const latestVersion = '7.12.0';
40
- beforeEach(() => {
41
- vi.clearAllMocks();
42
- // @ts-expect-error Doesn't match the actual signature because then the linter complains about unused variables
43
- processExitSpy = vi.spyOn(process, 'exit').mockImplementation(() => { });
44
- vi.mocked(pkg).version = currentVersion;
45
- vi.mocked(SpinniesManager.init).mockReturnValue(undefined);
46
- vi.mocked(SpinniesManager.add).mockReturnValue(undefined);
47
- vi.mocked(SpinniesManager.succeed).mockReturnValue(undefined);
48
- vi.mocked(SpinniesManager.fail).mockReturnValue(undefined);
49
- // Default mock for isConfigFlagEnabled - can be overridden in individual tests
50
- mockedIsConfigFlagEnabled.mockReturnValue(false);
51
- // Reset mock implementations to ensure clean state
52
- mockedGetLatestCliVersion.mockReset();
53
- mockedCanCliBeAutoUpgraded.mockReset();
54
- mockedInstallCliVersion.mockReset();
55
- mockedConfirmPrompt.mockReset();
56
- });
57
- describe('command', () => {
58
- it('should have the proper command names', () => {
59
- expect(upgradeCommand.command).toEqual([
60
- 'upgrade [version]',
61
- 'update [version]',
62
- ]);
63
- });
64
- });
65
- describe('describe', () => {
66
- it('should have a description', () => {
67
- expect(upgradeCommand.describe).toBeDefined();
68
- expect(upgradeCommand.describe).toContain('Install');
69
- });
70
- });
71
- describe('builder', () => {
72
- it('should apply the correct options', async () => {
73
- await upgradeCommand.builder(yargs);
74
- expect(positionalSpy).toHaveBeenCalledWith('[version]', {
75
- describe: commands.upgrade.options.version,
76
- type: 'string',
77
- });
78
- expect(optionSpy).toHaveBeenCalledWith('force', {
79
- alias: 'f',
80
- describe: commands.upgrade.options.force,
81
- type: 'boolean',
82
- default: false,
83
- });
84
- expect(optionSpy).toHaveBeenCalledWith('beta', {
85
- alias: 'next',
86
- describe: commands.upgrade.options.beta,
87
- type: 'boolean',
88
- default: false,
89
- });
90
- });
91
- });
92
- describe('handler', () => {
93
- it('should track the command usage', async () => {
94
- mockedGetLatestCliVersion.mockResolvedValueOnce({
95
- latest: latestVersion,
96
- next: '7.12.0-beta.1',
97
- });
98
- mockedCanCliBeAutoUpgraded.mockResolvedValueOnce(false);
99
- await upgradeCommand.handler({
100
- derivedAccountId: accountId,
101
- });
102
- expect(mockedTrackCommandUsage).toHaveBeenCalledTimes(1);
103
- expect(mockedTrackCommandUsage).toHaveBeenCalledWith('upgrade', {}, accountId);
104
- });
105
- it('should exit successfully when already on latest version', async () => {
106
- mockedGetLatestCliVersion.mockResolvedValueOnce({
107
- latest: currentVersion,
108
- next: '7.11.2-beta.1',
109
- });
110
- await upgradeCommand.handler({});
111
- expect(uiLogger.log).toHaveBeenCalledWith(commands.upgrade.alreadyLatest(currentVersion));
112
- expect(processExitSpy).toHaveBeenCalledWith(EXIT_CODES.SUCCESS);
113
- expect(mockedInstallCliVersion).not.toHaveBeenCalled();
114
- });
115
- it('should exit successfully when already on requested version', async () => {
116
- const requestedVersion = currentVersion;
117
- mockedGetLatestCliVersion.mockResolvedValueOnce({
118
- latest: latestVersion,
119
- next: '7.12.0-beta.1',
120
- });
121
- await upgradeCommand.handler({
122
- version: requestedVersion,
123
- });
124
- expect(uiLogger.log).toHaveBeenCalledWith(commands.upgrade.alreadyOnVersion(currentVersion));
125
- expect(processExitSpy).toHaveBeenCalledWith(EXIT_CODES.SUCCESS);
126
- expect(mockedInstallCliVersion).not.toHaveBeenCalled();
127
- });
128
- it('should show message when CLI is not globally installed', async () => {
129
- mockedGetLatestCliVersion.mockResolvedValueOnce({
130
- latest: latestVersion,
131
- next: '7.12.0-beta.1',
132
- });
133
- mockedCanCliBeAutoUpgraded.mockResolvedValueOnce(false);
134
- await upgradeCommand.handler({});
135
- expect(uiLogger.log).toHaveBeenCalledWith(commands.upgrade.autoUpgradeNotAvailable(latestVersion));
136
- expect(processExitSpy).toHaveBeenCalledWith(EXIT_CODES.SUCCESS);
137
- expect(mockedInstallCliVersion).not.toHaveBeenCalled();
138
- });
139
- it('should cancel upgrade when user declines confirmation', async () => {
140
- mockedGetLatestCliVersion.mockResolvedValueOnce({
141
- latest: latestVersion,
142
- next: '7.12.0-beta.1',
143
- });
144
- mockedCanCliBeAutoUpgraded.mockResolvedValueOnce(true);
145
- mockedConfirmPrompt.mockResolvedValueOnce(false);
146
- await upgradeCommand.handler({});
147
- expect(mockedConfirmPrompt).toHaveBeenCalledWith(commands.upgrade.confirmPrompt(currentVersion, latestVersion), { defaultAnswer: true });
148
- expect(uiLogger.log).toHaveBeenCalledWith(commands.upgrade.cancelled);
149
- expect(processExitSpy).toHaveBeenCalledWith(EXIT_CODES.SUCCESS);
150
- expect(mockedInstallCliVersion).not.toHaveBeenCalled();
151
- });
152
- it('should upgrade successfully when user confirms', async () => {
153
- mockedGetLatestCliVersion.mockResolvedValueOnce({
154
- latest: latestVersion,
155
- next: '7.12.0-beta.1',
156
- });
157
- mockedCanCliBeAutoUpgraded.mockResolvedValueOnce(true);
158
- mockedConfirmPrompt.mockResolvedValueOnce(true);
159
- mockedInstallCliVersion.mockResolvedValueOnce(undefined);
160
- await upgradeCommand.handler({});
161
- expect(mockedConfirmPrompt).toHaveBeenCalled();
162
- expect(SpinniesManager.add).toHaveBeenCalledWith('upgrade', {
163
- text: commands.upgrade.installing(latestVersion),
164
- });
165
- expect(mockedInstallCliVersion).toHaveBeenCalledWith(latestVersion);
166
- expect(SpinniesManager.succeed).toHaveBeenCalledWith('upgrade', {
167
- text: commands.upgrade.success(latestVersion),
168
- });
169
- expect(processExitSpy).toHaveBeenCalledWith(EXIT_CODES.SUCCESS);
170
- });
171
- it('should upgrade without confirmation when --force is used', async () => {
172
- mockedGetLatestCliVersion.mockResolvedValueOnce({
173
- latest: latestVersion,
174
- next: '7.12.0-beta.1',
175
- });
176
- mockedCanCliBeAutoUpgraded.mockResolvedValueOnce(true);
177
- mockedInstallCliVersion.mockResolvedValueOnce(undefined);
178
- await upgradeCommand.handler({
179
- force: true,
180
- });
181
- expect(mockedConfirmPrompt).not.toHaveBeenCalled();
182
- expect(mockedInstallCliVersion).toHaveBeenCalledWith(latestVersion);
183
- expect(processExitSpy).toHaveBeenCalledWith(EXIT_CODES.SUCCESS);
184
- });
185
- it('should install specific version when provided', async () => {
186
- const specificVersion = '7.10.0';
187
- mockedGetLatestCliVersion.mockResolvedValueOnce({
188
- latest: latestVersion,
189
- next: '7.12.0',
190
- });
191
- mockedCanCliBeAutoUpgraded.mockResolvedValueOnce(true);
192
- mockedConfirmPrompt.mockResolvedValueOnce(true);
193
- mockedInstallCliVersion.mockResolvedValueOnce(undefined);
194
- await upgradeCommand.handler({
195
- version: specificVersion,
196
- });
197
- expect(mockedInstallCliVersion).toHaveBeenCalledWith(specificVersion);
198
- expect(SpinniesManager.add).toHaveBeenCalledWith('upgrade', {
199
- text: commands.upgrade.installing(specificVersion),
200
- });
201
- expect(processExitSpy).toHaveBeenCalledWith(EXIT_CODES.SUCCESS);
202
- });
203
- it('should handle installation errors', async () => {
204
- const error = new Error('Installation failed');
205
- mockedGetLatestCliVersion.mockResolvedValueOnce({
206
- latest: latestVersion,
207
- next: '7.12.0-beta.1',
208
- });
209
- mockedCanCliBeAutoUpgraded.mockResolvedValueOnce(true);
210
- mockedConfirmPrompt.mockResolvedValueOnce(true);
211
- mockedInstallCliVersion.mockRejectedValueOnce(error);
212
- await upgradeCommand.handler({});
213
- expect(mockedDebugError).toHaveBeenCalledWith(error);
214
- expect(SpinniesManager.fail).toHaveBeenCalledWith('upgrade', {
215
- text: commands.upgrade.errors.installFailed,
216
- });
217
- expect(uiLogger.error).toHaveBeenCalledWith(commands.upgrade.errors.generic);
218
- expect(processExitSpy).toHaveBeenCalledWith(EXIT_CODES.ERROR);
219
- });
220
- it('should install beta version when --beta flag is used', async () => {
221
- const betaVersion = '7.13.0-beta.1';
222
- mockedGetLatestCliVersion.mockResolvedValueOnce({
223
- latest: latestVersion,
224
- next: betaVersion,
225
- });
226
- mockedCanCliBeAutoUpgraded.mockResolvedValueOnce(true);
227
- mockedConfirmPrompt.mockResolvedValueOnce(true);
228
- mockedInstallCliVersion.mockResolvedValueOnce(undefined);
229
- await upgradeCommand.handler({
230
- beta: true,
231
- });
232
- expect(mockedGetLatestCliVersion).toHaveBeenCalled();
233
- expect(mockedInstallCliVersion).toHaveBeenCalledWith(betaVersion);
234
- expect(SpinniesManager.add).toHaveBeenCalledWith('upgrade', {
235
- text: commands.upgrade.installing(betaVersion),
236
- });
237
- expect(SpinniesManager.succeed).toHaveBeenCalledWith('upgrade', {
238
- text: commands.upgrade.success(betaVersion),
239
- });
240
- expect(processExitSpy).toHaveBeenCalledWith(EXIT_CODES.SUCCESS);
241
- });
242
- it('should error when beta is requested but next version is not available', async () => {
243
- mockedGetLatestCliVersion.mockResolvedValueOnce({
244
- latest: latestVersion,
245
- next: null,
246
- });
247
- mockedIsConfigFlagEnabled.mockReturnValue(false);
248
- await upgradeCommand.handler({
249
- beta: true,
250
- });
251
- expect(mockedGetLatestCliVersion).toHaveBeenCalled();
252
- expect(uiLogger.error).toHaveBeenCalledWith(commands.upgrade.errors.unableToDetermineLatestVersion);
253
- expect(processExitSpy).toHaveBeenCalledWith(EXIT_CODES.ERROR);
254
- expect(mockedInstallCliVersion).not.toHaveBeenCalled();
255
- expect(mockedCanCliBeAutoUpgraded).not.toHaveBeenCalled();
256
- });
257
- it('should show already on latest beta version message', async () => {
258
- const betaVersion = '7.12.0-beta.1';
259
- vi.mocked(pkg).version = betaVersion;
260
- mockedGetLatestCliVersion.mockResolvedValueOnce({
261
- latest: latestVersion,
262
- next: betaVersion,
263
- });
264
- await upgradeCommand.handler({
265
- beta: true,
266
- });
267
- expect(uiLogger.log).toHaveBeenCalledWith(commands.upgrade.alreadyLatest(betaVersion, true));
268
- expect(processExitSpy).toHaveBeenCalledWith(EXIT_CODES.SUCCESS);
269
- expect(mockedInstallCliVersion).not.toHaveBeenCalled();
270
- });
271
- it('should not show auto-upgrade message when beta flag is used', async () => {
272
- const betaVersion = '7.12.0-beta.1';
273
- mockedGetLatestCliVersion.mockResolvedValueOnce({
274
- latest: latestVersion,
275
- next: betaVersion,
276
- });
277
- mockedCanCliBeAutoUpgraded.mockResolvedValueOnce(true);
278
- mockedConfirmPrompt.mockResolvedValueOnce(true);
279
- mockedInstallCliVersion.mockResolvedValueOnce(undefined);
280
- mockedIsConfigFlagEnabled.mockReturnValue(false);
281
- await upgradeCommand.handler({
282
- beta: true,
283
- });
284
- // Verify the auto-upgrade message was not logged
285
- const logCalls = vi.mocked(uiLogger.log).mock.calls;
286
- const autoUpgradeMessageCall = logCalls.find(call => call[0]?.includes('automatic updates'));
287
- expect(autoUpgradeMessageCall).toBeUndefined();
288
- // Should succeed even though auto-updates are disabled when beta is used
289
- expect(processExitSpy).toHaveBeenCalledWith(EXIT_CODES.SUCCESS);
290
- expect(mockedInstallCliVersion).toHaveBeenCalledWith(betaVersion);
291
- });
292
- it('should upgrade to beta without confirmation when --force and --beta are used', async () => {
293
- const betaVersion = '7.12.0-beta.1';
294
- mockedGetLatestCliVersion.mockResolvedValueOnce({
295
- latest: latestVersion,
296
- next: betaVersion,
297
- });
298
- mockedCanCliBeAutoUpgraded.mockResolvedValueOnce(true);
299
- mockedInstallCliVersion.mockResolvedValueOnce(undefined);
300
- await upgradeCommand.handler({
301
- force: true,
302
- beta: true,
303
- });
304
- expect(mockedConfirmPrompt).not.toHaveBeenCalled();
305
- expect(mockedInstallCliVersion).toHaveBeenCalledWith(betaVersion);
306
- expect(processExitSpy).toHaveBeenCalledWith(EXIT_CODES.SUCCESS);
307
- });
308
- });
309
- });
@@ -1 +0,0 @@
1
- export {};
@@ -1,206 +0,0 @@
1
- import yargs from 'yargs';
2
- import * as configLib from '@hubspot/local-dev-lib/config';
3
- import * as personalAccessKeyLib from '@hubspot/local-dev-lib/personalAccessKey';
4
- import { ENVIRONMENTS } from '@hubspot/local-dev-lib/constants/environments';
5
- import { addGlobalOptions, addTestingOptions, } from '../../../lib/commonOpts.js';
6
- import * as configMigrate from '../../../lib/configMigrate.js';
7
- import * as processLib from '../../../lib/process.js';
8
- import * as usageTrackingLib from '../../../lib/usageTracking.js';
9
- import * as personalAccessKeyPromptLib from '../../../lib/prompts/personalAccessKeyPrompt.js';
10
- import * as accountNamePromptLib from '../../../lib/prompts/accountNamePrompt.js';
11
- import * as setAsDefaultPromptLib from '../../../lib/prompts/setAsDefaultAccountPrompt.js';
12
- import * as parsingLib from '../../../lib/parsing.js';
13
- import { uiLogger } from '../../../lib/ui/logger.js';
14
- import { EXIT_CODES } from '../../../lib/enums/exitCodes.js';
15
- import accountAuthCommand from '../auth.js';
16
- vi.mock('../../../lib/commonOpts');
17
- vi.mock('@hubspot/local-dev-lib/config');
18
- vi.mock('@hubspot/local-dev-lib/personalAccessKey');
19
- vi.mock('../../../lib/configMigrate.js');
20
- vi.mock('../../../lib/process.js');
21
- vi.mock('../../../lib/prompts/personalAccessKeyPrompt.js');
22
- vi.mock('../../../lib/prompts/accountNamePrompt.js');
23
- vi.mock('../../../lib/prompts/setAsDefaultAccountPrompt.js');
24
- vi.mock('../../../lib/parsing.js');
25
- vi.mock('../../../lib/ui/index.js');
26
- vi.mock('../../../lib/errorHandlers/index.js');
27
- const localConfigFileExistsSpy = vi.spyOn(configLib, 'localConfigFileExists');
28
- const globalConfigFileExistsSpy = vi.spyOn(configLib, 'globalConfigFileExists');
29
- const createEmptyConfigFileSpy = vi.spyOn(configLib, 'createEmptyConfigFile');
30
- const getAccessTokenSpy = vi.spyOn(personalAccessKeyLib, 'getAccessToken');
31
- const updateConfigWithAccessTokenSpy = vi.spyOn(personalAccessKeyLib, 'updateConfigWithAccessToken');
32
- const handleMergeSpy = vi.spyOn(configMigrate, 'handleMerge');
33
- const handleMigrationSpy = vi.spyOn(configMigrate, 'handleMigration');
34
- const handleExitSpy = vi.spyOn(processLib, 'handleExit');
35
- const trackCommandUsageSpy = vi.spyOn(usageTrackingLib, 'trackCommandUsage');
36
- const trackAuthActionSpy = vi.spyOn(usageTrackingLib, 'trackAuthAction');
37
- const personalAccessKeyPromptSpy = vi.spyOn(personalAccessKeyPromptLib, 'personalAccessKeyPrompt');
38
- const cliAccountNamePromptSpy = vi.spyOn(accountNamePromptLib, 'cliAccountNamePrompt');
39
- const setAsDefaultAccountPromptSpy = vi.spyOn(setAsDefaultPromptLib, 'setAsDefaultAccountPrompt');
40
- const parseStringToNumberSpy = vi.spyOn(parsingLib, 'parseStringToNumber');
41
- const processExitSpy = vi.spyOn(process, 'exit');
42
- describe('commands/account/auth', () => {
43
- const yargsMock = yargs;
44
- beforeEach(() => {
45
- // @ts-expect-error Mock implementation
46
- processExitSpy.mockImplementation(() => { });
47
- localConfigFileExistsSpy.mockReturnValue(false);
48
- globalConfigFileExistsSpy.mockReturnValue(true);
49
- createEmptyConfigFileSpy.mockImplementation(() => { });
50
- handleExitSpy.mockImplementation(async () => { });
51
- trackCommandUsageSpy.mockImplementation(async () => { });
52
- trackAuthActionSpy.mockResolvedValue(undefined);
53
- personalAccessKeyPromptSpy.mockResolvedValue({
54
- personalAccessKey: 'test-key',
55
- env: 'prod',
56
- });
57
- getAccessTokenSpy.mockResolvedValue({
58
- portalId: 456789,
59
- accessToken: 'test-access-token',
60
- expiresAt: '2025-01-01T00:00:00.000Z',
61
- scopeGroups: ['content'],
62
- encodedOAuthRefreshToken: 'encoded-token',
63
- hubName: 'Test Hub',
64
- accountType: 'STANDARD',
65
- });
66
- cliAccountNamePromptSpy.mockResolvedValue({ name: 'test-account' });
67
- updateConfigWithAccessTokenSpy.mockResolvedValue({
68
- accountId: 456789,
69
- name: 'test-account',
70
- authType: 'personalaccesskey',
71
- env: 'prod',
72
- auth: { tokenInfo: { accessToken: 'test-token' } },
73
- personalAccessKey: 'test-key',
74
- });
75
- setAsDefaultAccountPromptSpy.mockResolvedValue(true);
76
- });
77
- describe('command', () => {
78
- it('should have the correct command structure', () => {
79
- expect(accountAuthCommand.command).toEqual('auth');
80
- });
81
- });
82
- describe('describe', () => {
83
- it('should provide a description', () => {
84
- expect(accountAuthCommand.describe).toBeDefined();
85
- });
86
- });
87
- describe('builder', () => {
88
- it('should support the correct options', () => {
89
- accountAuthCommand.builder(yargsMock);
90
- expect(addTestingOptions).toHaveBeenCalledTimes(1);
91
- expect(addTestingOptions).toHaveBeenCalledWith(yargsMock);
92
- expect(addGlobalOptions).toHaveBeenCalledTimes(1);
93
- expect(addGlobalOptions).toHaveBeenCalledWith(yargsMock);
94
- });
95
- });
96
- describe('handler', () => {
97
- let args;
98
- beforeEach(() => {
99
- args = {
100
- derivedAccountId: 0,
101
- d: false,
102
- debug: false,
103
- _: [],
104
- $0: '',
105
- };
106
- });
107
- it('should track command usage', async () => {
108
- await accountAuthCommand.handler(args);
109
- expect(trackCommandUsageSpy).toHaveBeenCalledWith('account-auth', {}, undefined);
110
- expect(trackAuthActionSpy).toHaveBeenCalledWith('account-auth', 'personalaccesskey', 'started');
111
- });
112
- it('should not track when tracking is disabled', async () => {
113
- args.disableTracking = true;
114
- await accountAuthCommand.handler(args);
115
- expect(trackCommandUsageSpy).not.toHaveBeenCalled();
116
- expect(trackAuthActionSpy).not.toHaveBeenCalled();
117
- expect(updateConfigWithAccessTokenSpy).toHaveBeenCalled();
118
- });
119
- it('should parse user provided account ID', async () => {
120
- args.userProvidedAccount = '123456';
121
- parseStringToNumberSpy.mockReturnValue(123456);
122
- await accountAuthCommand.handler(args);
123
- expect(parseStringToNumberSpy).toHaveBeenCalledWith('123456');
124
- expect(trackCommandUsageSpy).toHaveBeenCalledWith('account-auth', {}, 123456);
125
- });
126
- it('should error on invalid account ID', async () => {
127
- args.userProvidedAccount = 'invalid';
128
- parseStringToNumberSpy.mockImplementation(() => {
129
- throw new Error('Invalid');
130
- });
131
- await accountAuthCommand.handler(args);
132
- expect(uiLogger.error).toHaveBeenCalledWith('--account must be a number.');
133
- expect(processExitSpy).toHaveBeenCalledWith(EXIT_CODES.ERROR);
134
- });
135
- it('should handle merge when both configs exist', async () => {
136
- localConfigFileExistsSpy.mockReturnValue(true);
137
- globalConfigFileExistsSpy.mockReturnValue(true);
138
- handleMergeSpy.mockResolvedValue(true);
139
- await accountAuthCommand.handler(args);
140
- expect(handleMergeSpy).toHaveBeenCalled();
141
- });
142
- it('should exit if merge is not confirmed', async () => {
143
- localConfigFileExistsSpy.mockReturnValue(true);
144
- globalConfigFileExistsSpy.mockReturnValue(true);
145
- handleMergeSpy.mockResolvedValue(false);
146
- await accountAuthCommand.handler(args);
147
- expect(uiLogger.log).toHaveBeenCalled();
148
- expect(trackAuthActionSpy).toHaveBeenCalledWith('account-auth', 'personalaccesskey', 'error');
149
- expect(processExitSpy).toHaveBeenCalledWith(EXIT_CODES.ERROR);
150
- });
151
- it('should handle migration when only local config exists', async () => {
152
- localConfigFileExistsSpy.mockReturnValue(true);
153
- globalConfigFileExistsSpy.mockReturnValue(false);
154
- handleMigrationSpy.mockResolvedValue(true);
155
- await accountAuthCommand.handler(args);
156
- expect(handleMigrationSpy).toHaveBeenCalled();
157
- });
158
- it('should create config file if it does not exist', async () => {
159
- globalConfigFileExistsSpy.mockReturnValue(false);
160
- await accountAuthCommand.handler(args);
161
- expect(createEmptyConfigFileSpy).toHaveBeenCalledWith(true);
162
- });
163
- it('should prompt for personal access key', async () => {
164
- await accountAuthCommand.handler(args);
165
- expect(personalAccessKeyPromptSpy).toHaveBeenCalledWith({
166
- env: ENVIRONMENTS.PROD,
167
- account: undefined,
168
- });
169
- });
170
- it('should use provided personal access key', async () => {
171
- args.personalAccessKey = 'provided-key';
172
- await accountAuthCommand.handler(args);
173
- expect(personalAccessKeyPromptSpy).not.toHaveBeenCalled();
174
- expect(getAccessTokenSpy).toHaveBeenCalledWith('provided-key', ENVIRONMENTS.PROD);
175
- });
176
- it('should use QA environment when qa flag is set', async () => {
177
- args.qa = true;
178
- await accountAuthCommand.handler(args);
179
- expect(getAccessTokenSpy).toHaveBeenCalledWith('test-key', ENVIRONMENTS.QA);
180
- });
181
- it('should prompt for account name for new config', async () => {
182
- globalConfigFileExistsSpy.mockReturnValue(false);
183
- await accountAuthCommand.handler(args);
184
- expect(cliAccountNamePromptSpy).toHaveBeenCalledWith('test-hub');
185
- });
186
- it('should not prompt for account name for existing config', async () => {
187
- globalConfigFileExistsSpy.mockReturnValue(true);
188
- await accountAuthCommand.handler(args);
189
- expect(setAsDefaultAccountPromptSpy).toHaveBeenCalledWith('test-account');
190
- });
191
- it('should exit with error if config update fails', async () => {
192
- getAccessTokenSpy.mockRejectedValue(new Error('Invalid key'));
193
- await accountAuthCommand.handler(args);
194
- expect(uiLogger.error).toHaveBeenCalledWith(expect.stringContaining('Failed'));
195
- expect(trackAuthActionSpy).toHaveBeenCalledWith('account-auth', 'personalaccesskey', 'error');
196
- expect(processExitSpy).toHaveBeenCalledWith(EXIT_CODES.ERROR);
197
- });
198
- it('should log success for new config', async () => {
199
- globalConfigFileExistsSpy.mockReturnValue(false);
200
- await accountAuthCommand.handler(args);
201
- expect(uiLogger.success).toHaveBeenCalled();
202
- expect(trackAuthActionSpy).toHaveBeenCalledWith('account-auth', 'personalaccesskey', 'complete', 456789);
203
- expect(processExitSpy).toHaveBeenCalledWith(EXIT_CODES.SUCCESS);
204
- });
205
- });
206
- });
@@ -1 +0,0 @@
1
- export {};
@@ -1,28 +0,0 @@
1
- import yargs from 'yargs';
2
- import { addConfigOptions } from '../../../lib/commonOpts.js';
3
- import { addTestingOptions } from '../../../lib/commonOpts.js';
4
- import accountCleanCommand from '../clean.js';
5
- vi.mock('../../../lib/commonOpts');
6
- describe('commands/account/clean', () => {
7
- const yargsMock = yargs;
8
- describe('command', () => {
9
- it('should have the correct command structure', () => {
10
- expect(accountCleanCommand.command).toEqual('clean');
11
- });
12
- });
13
- describe('describe', () => {
14
- it('should provide a description', () => {
15
- expect(accountCleanCommand.describe).toBeDefined();
16
- });
17
- });
18
- describe('builder', () => {
19
- it('should support the correct options', () => {
20
- accountCleanCommand.builder(yargsMock);
21
- expect(yargsMock.example).toHaveBeenCalledTimes(1);
22
- expect(addConfigOptions).toHaveBeenCalledTimes(1);
23
- expect(addConfigOptions).toHaveBeenCalledWith(yargsMock);
24
- expect(addTestingOptions).toHaveBeenCalledTimes(1);
25
- expect(addTestingOptions).toHaveBeenCalledWith(yargsMock);
26
- });
27
- });
28
- });
@@ -1 +0,0 @@
1
- export {};
@@ -1,32 +0,0 @@
1
- import yargs from 'yargs';
2
- import accountCreateOverrideCommand from '../createOverride.js';
3
- const positionalSpy = vi
4
- .spyOn(yargs, 'positional')
5
- .mockReturnValue(yargs);
6
- const exampleSpy = vi
7
- .spyOn(yargs, 'example')
8
- .mockReturnValue(yargs);
9
- describe('commands/account/createOverride', () => {
10
- const yargsMock = yargs;
11
- describe('command', () => {
12
- it('should have the correct command structure', () => {
13
- expect(accountCreateOverrideCommand.command).toEqual('create-override [account]');
14
- });
15
- });
16
- describe('describe', () => {
17
- it('should provide a description', () => {
18
- expect(accountCreateOverrideCommand.describe).toBeDefined();
19
- });
20
- });
21
- describe('builder', () => {
22
- it('should support the correct options', () => {
23
- accountCreateOverrideCommand.builder(yargsMock);
24
- expect(exampleSpy).toHaveBeenCalledTimes(1);
25
- expect(positionalSpy).toHaveBeenCalledTimes(1);
26
- expect(positionalSpy).toHaveBeenCalledWith('account', {
27
- describe: expect.any(String),
28
- type: 'string',
29
- });
30
- });
31
- });
32
- });
@@ -1 +0,0 @@
1
- export {};