@hubspot/cli 8.3.0 → 8.4.0-beta.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (522) 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.d.ts +4 -0
  78. package/commands/project/info.js +67 -0
  79. package/commands/project/installDeps.js +9 -6
  80. package/commands/project/lint.js +11 -8
  81. package/commands/project/list.js +14 -14
  82. package/commands/project/listBuilds.js +8 -6
  83. package/commands/project/logs.js +5 -6
  84. package/commands/project/migrate.js +8 -8
  85. package/commands/project/open.js +5 -6
  86. package/commands/project/profile/add.js +12 -8
  87. package/commands/project/profile/delete.js +15 -11
  88. package/commands/project/updateDeps.js +9 -6
  89. package/commands/project/upload.js +31 -17
  90. package/commands/project/validate.js +11 -11
  91. package/commands/project/watch.js +20 -20
  92. package/commands/project.js +4 -0
  93. package/commands/sandbox/create.js +15 -15
  94. package/commands/sandbox/delete.js +13 -14
  95. package/commands/secret/addSecret.js +6 -7
  96. package/commands/secret/deleteSecret.js +5 -6
  97. package/commands/secret/listSecret.js +2 -3
  98. package/commands/secret/updateSecret.js +4 -5
  99. package/commands/testAccount/create.d.ts +1 -1
  100. package/commands/testAccount/create.js +20 -16
  101. package/commands/testAccount/createConfig.js +7 -8
  102. package/commands/testAccount/delete.js +27 -18
  103. package/commands/testAccount/importData.js +6 -7
  104. package/commands/upgrade.js +9 -10
  105. package/lang/en.d.ts +114 -5
  106. package/lang/en.js +111 -5
  107. package/lib/accountAuth.js +2 -2
  108. package/lib/buildAccount.js +3 -3
  109. package/lib/doctor/Diagnosis.js +5 -5
  110. package/lib/errorHandlers/index.js +4 -3
  111. package/lib/errorHandlers/suppressError.js +4 -0
  112. package/lib/errors/PromptExitError.d.ts +4 -2
  113. package/lib/errors/PromptExitError.js +3 -0
  114. package/lib/process.d.ts +1 -1
  115. package/lib/process.js +10 -3
  116. package/lib/projects/delete.d.ts +13 -0
  117. package/lib/projects/delete.js +193 -0
  118. package/lib/projects/localDev/AppDevModeInterface.js +11 -11
  119. package/lib/projects/localDev/DevServerManager_DEPRECATED.d.ts +3 -1
  120. package/lib/projects/localDev/DevServerManager_DEPRECATED.js +2 -2
  121. package/lib/projects/localDev/DevSessionManager.d.ts +6 -3
  122. package/lib/projects/localDev/DevSessionManager.js +31 -19
  123. package/lib/projects/localDev/LocalDevManager_DEPRECATED.d.ts +3 -0
  124. package/lib/projects/localDev/LocalDevManager_DEPRECATED.js +16 -12
  125. package/lib/projects/localDev/LocalDevProcess.js +6 -5
  126. package/lib/projects/localDev/LocalDevState.d.ts +3 -2
  127. package/lib/projects/localDev/LocalDevState.js +3 -1
  128. package/lib/projects/localDev/helpers/account.d.ts +4 -3
  129. package/lib/projects/localDev/helpers/account.js +16 -19
  130. package/lib/projects/localDev/helpers/process.d.ts +1 -1
  131. package/lib/projects/localDev/helpers/process.js +4 -10
  132. package/lib/projects/localDev/helpers/project.d.ts +4 -3
  133. package/lib/projects/localDev/helpers/project.js +31 -15
  134. package/lib/projects/projectInfo.d.ts +5 -0
  135. package/lib/projects/projectInfo.js +82 -0
  136. package/lib/projects/projectProfiles.d.ts +1 -2
  137. package/lib/projects/projectProfiles.js +5 -17
  138. package/lib/prompts/createApiSamplePrompt.js +4 -0
  139. package/lib/prompts/projectProfilePrompt.d.ts +2 -0
  140. package/lib/prompts/projectProfilePrompt.js +46 -0
  141. package/lib/prompts/promptUtils.js +3 -2
  142. package/lib/prompts/selectHubDBTablePrompt.js +2 -2
  143. package/lib/prompts/selectPublicAppForMigrationPrompt.js +2 -2
  144. package/lib/theme/cmsDevServerProcess.d.ts +2 -0
  145. package/lib/theme/cmsDevServerProcess.js +7 -6
  146. package/lib/ui/SpinniesManager.d.ts +1 -0
  147. package/lib/ui/SpinniesManager.js +20 -6
  148. package/lib/ui/spinniesUtils.d.ts +0 -1
  149. package/lib/ui/spinniesUtils.js +6 -16
  150. package/lib/usageTracking.d.ts +3 -4
  151. package/lib/yargs/makeYargsBuilder.d.ts +13 -0
  152. package/lib/yargs/makeYargsBuilder.js +33 -0
  153. package/lib/yargs/makeYargsHandlerWithUsageTracking.d.ts +3 -0
  154. package/lib/yargs/makeYargsHandlerWithUsageTracking.js +95 -0
  155. package/lib/yargs/strictEnforceBoolean.d.ts +1 -0
  156. package/lib/yargs/strictEnforceBoolean.js +13 -0
  157. package/lib/yargsUtils.d.ts +3 -16
  158. package/lib/yargsUtils.js +3 -48
  159. package/package.json +9 -4
  160. package/types/LocalDev.d.ts +5 -0
  161. package/types/Projects.d.ts +19 -0
  162. package/types/Yargs.d.ts +18 -1
  163. package/api/__tests__/migrate.test.d.ts +0 -1
  164. package/api/__tests__/migrate.test.js +0 -199
  165. package/commands/__tests__/account.test.d.ts +0 -1
  166. package/commands/__tests__/account.test.js +0 -69
  167. package/commands/__tests__/auth.test.d.ts +0 -1
  168. package/commands/__tests__/auth.test.js +0 -43
  169. package/commands/__tests__/cms.test.d.ts +0 -1
  170. package/commands/__tests__/cms.test.js +0 -87
  171. package/commands/__tests__/config.test.d.ts +0 -1
  172. package/commands/__tests__/config.test.js +0 -44
  173. package/commands/__tests__/customObject.test.d.ts +0 -1
  174. package/commands/__tests__/customObject.test.js +0 -68
  175. package/commands/__tests__/doctor.test.d.ts +0 -1
  176. package/commands/__tests__/doctor.test.js +0 -132
  177. package/commands/__tests__/feedback.test.d.ts +0 -1
  178. package/commands/__tests__/feedback.test.js +0 -24
  179. package/commands/__tests__/filemanager.test.d.ts +0 -1
  180. package/commands/__tests__/filemanager.test.js +0 -45
  181. package/commands/__tests__/getStarted.test.d.ts +0 -1
  182. package/commands/__tests__/getStarted.test.js +0 -173
  183. package/commands/__tests__/hubdb.test.d.ts +0 -1
  184. package/commands/__tests__/hubdb.test.js +0 -50
  185. package/commands/__tests__/init.test.d.ts +0 -1
  186. package/commands/__tests__/init.test.js +0 -42
  187. package/commands/__tests__/mcp.test.d.ts +0 -1
  188. package/commands/__tests__/mcp.test.js +0 -46
  189. package/commands/__tests__/open.test.d.ts +0 -1
  190. package/commands/__tests__/open.test.js +0 -58
  191. package/commands/__tests__/project.test.d.ts +0 -1
  192. package/commands/__tests__/project.test.js +0 -125
  193. package/commands/__tests__/sandbox.test.d.ts +0 -1
  194. package/commands/__tests__/sandbox.test.js +0 -44
  195. package/commands/__tests__/secret.test.d.ts +0 -1
  196. package/commands/__tests__/secret.test.js +0 -49
  197. package/commands/__tests__/testAccount.test.d.ts +0 -1
  198. package/commands/__tests__/testAccount.test.js +0 -57
  199. package/commands/__tests__/upgrade.test.d.ts +0 -1
  200. package/commands/__tests__/upgrade.test.js +0 -309
  201. package/commands/account/__tests__/auth.test.d.ts +0 -1
  202. package/commands/account/__tests__/auth.test.js +0 -206
  203. package/commands/account/__tests__/clean.test.d.ts +0 -1
  204. package/commands/account/__tests__/clean.test.js +0 -28
  205. package/commands/account/__tests__/createOverride.test.d.ts +0 -1
  206. package/commands/account/__tests__/createOverride.test.js +0 -32
  207. package/commands/account/__tests__/info.test.d.ts +0 -1
  208. package/commands/account/__tests__/info.test.js +0 -28
  209. package/commands/account/__tests__/list.test.d.ts +0 -1
  210. package/commands/account/__tests__/list.test.js +0 -153
  211. package/commands/account/__tests__/remove.test.d.ts +0 -1
  212. package/commands/account/__tests__/remove.test.js +0 -36
  213. package/commands/account/__tests__/removeOverride.d.ts +0 -1
  214. package/commands/account/__tests__/removeOverride.js +0 -25
  215. package/commands/account/__tests__/rename.test.d.ts +0 -1
  216. package/commands/account/__tests__/rename.test.js +0 -82
  217. package/commands/account/__tests__/use.test.d.ts +0 -1
  218. package/commands/account/__tests__/use.test.js +0 -170
  219. package/commands/app/__tests__/migrate.test.d.ts +0 -1
  220. package/commands/app/__tests__/migrate.test.js +0 -111
  221. package/commands/app/secret/__tests__/add.test.d.ts +0 -1
  222. package/commands/app/secret/__tests__/add.test.js +0 -140
  223. package/commands/app/secret/__tests__/delete.test.d.ts +0 -1
  224. package/commands/app/secret/__tests__/delete.test.js +0 -28
  225. package/commands/app/secret/__tests__/list.test.d.ts +0 -1
  226. package/commands/app/secret/__tests__/list.test.js +0 -25
  227. package/commands/app/secret/__tests__/update.test.d.ts +0 -1
  228. package/commands/app/secret/__tests__/update.test.js +0 -28
  229. package/commands/cms/__tests__/delete.test.d.ts +0 -1
  230. package/commands/cms/__tests__/delete.test.js +0 -39
  231. package/commands/cms/__tests__/fetch.test.d.ts +0 -1
  232. package/commands/cms/__tests__/fetch.test.js +0 -156
  233. package/commands/cms/__tests__/function.test.d.ts +0 -1
  234. package/commands/cms/__tests__/function.test.js +0 -50
  235. package/commands/cms/__tests__/lint.test.d.ts +0 -1
  236. package/commands/cms/__tests__/lint.test.js +0 -33
  237. package/commands/cms/__tests__/list.test.d.ts +0 -1
  238. package/commands/cms/__tests__/list.test.js +0 -42
  239. package/commands/cms/__tests__/module.test.d.ts +0 -1
  240. package/commands/cms/__tests__/module.test.js +0 -45
  241. package/commands/cms/__tests__/mv.test.d.ts +0 -1
  242. package/commands/cms/__tests__/mv.test.js +0 -46
  243. package/commands/cms/__tests__/theme.test.d.ts +0 -1
  244. package/commands/cms/__tests__/theme.test.js +0 -54
  245. package/commands/cms/__tests__/upload.test.d.ts +0 -1
  246. package/commands/cms/__tests__/upload.test.js +0 -312
  247. package/commands/cms/__tests__/watch.test.d.ts +0 -1
  248. package/commands/cms/__tests__/watch.test.js +0 -204
  249. package/commands/cms/function/__tests__/logs.test.d.ts +0 -1
  250. package/commands/cms/function/__tests__/logs.test.js +0 -70
  251. package/commands/cms/theme/__tests__/generate-selectors.test.d.ts +0 -1
  252. package/commands/cms/theme/__tests__/generate-selectors.test.js +0 -28
  253. package/commands/cms/theme/__tests__/marketplace-validate.test.d.ts +0 -1
  254. package/commands/cms/theme/__tests__/marketplace-validate.test.js +0 -36
  255. package/commands/cms/theme/__tests__/preview.test.d.ts +0 -1
  256. package/commands/cms/theme/__tests__/preview.test.js +0 -54
  257. package/commands/customObject/__tests__/create.test.d.ts +0 -1
  258. package/commands/customObject/__tests__/create.test.js +0 -40
  259. package/commands/customObject/__tests__/createSchema.test.d.ts +0 -1
  260. package/commands/customObject/__tests__/createSchema.test.js +0 -28
  261. package/commands/customObject/__tests__/deleteSchema.test.d.ts +0 -1
  262. package/commands/customObject/__tests__/deleteSchema.test.js +0 -42
  263. package/commands/customObject/__tests__/fetch-all-schemas.test.d.ts +0 -1
  264. package/commands/customObject/__tests__/fetch-all-schemas.test.js +0 -41
  265. package/commands/customObject/__tests__/fetchSchema.test.d.ts +0 -1
  266. package/commands/customObject/__tests__/fetchSchema.test.js +0 -45
  267. package/commands/customObject/__tests__/listSchemas.test.d.ts +0 -1
  268. package/commands/customObject/__tests__/listSchemas.test.js +0 -29
  269. package/commands/customObject/__tests__/updateSchema.test.d.ts +0 -1
  270. package/commands/customObject/__tests__/updateSchema.test.js +0 -40
  271. package/commands/filemanager/__tests__/fetch.test.d.ts +0 -1
  272. package/commands/filemanager/__tests__/fetch.test.js +0 -32
  273. package/commands/filemanager/__tests__/upload.test.d.ts +0 -1
  274. package/commands/filemanager/__tests__/upload.test.js +0 -191
  275. package/commands/hubdb/__tests__/clear.test.d.ts +0 -1
  276. package/commands/hubdb/__tests__/clear.test.js +0 -28
  277. package/commands/hubdb/__tests__/create.test.d.ts +0 -1
  278. package/commands/hubdb/__tests__/create.test.js +0 -28
  279. package/commands/hubdb/__tests__/delete.test.d.ts +0 -1
  280. package/commands/hubdb/__tests__/delete.test.js +0 -28
  281. package/commands/hubdb/__tests__/fetch.test.d.ts +0 -1
  282. package/commands/hubdb/__tests__/fetch.test.js +0 -28
  283. package/commands/hubdb/__tests__/list.test.d.ts +0 -1
  284. package/commands/hubdb/__tests__/list.test.js +0 -88
  285. package/commands/mcp/__tests__/setup.test.d.ts +0 -1
  286. package/commands/mcp/__tests__/setup.test.js +0 -26
  287. package/commands/mcp/__tests__/start.test.d.ts +0 -1
  288. package/commands/mcp/__tests__/start.test.js +0 -144
  289. package/commands/project/__tests__/add.test.d.ts +0 -1
  290. package/commands/project/__tests__/add.test.js +0 -107
  291. package/commands/project/__tests__/create.test.d.ts +0 -1
  292. package/commands/project/__tests__/create.test.js +0 -97
  293. package/commands/project/__tests__/deploy.test.d.ts +0 -1
  294. package/commands/project/__tests__/deploy.test.js +0 -307
  295. package/commands/project/__tests__/dev.test.d.ts +0 -1
  296. package/commands/project/__tests__/dev.test.js +0 -273
  297. package/commands/project/__tests__/devUnifiedFlow.test.d.ts +0 -1
  298. package/commands/project/__tests__/devUnifiedFlow.test.js +0 -434
  299. package/commands/project/__tests__/download.test.d.ts +0 -1
  300. package/commands/project/__tests__/download.test.js +0 -39
  301. package/commands/project/__tests__/installDeps.test.d.ts +0 -1
  302. package/commands/project/__tests__/installDeps.test.js +0 -140
  303. package/commands/project/__tests__/lint.test.d.ts +0 -1
  304. package/commands/project/__tests__/lint.test.js +0 -704
  305. package/commands/project/__tests__/list.test.d.ts +0 -1
  306. package/commands/project/__tests__/list.test.js +0 -31
  307. package/commands/project/__tests__/listBuilds.test.d.ts +0 -1
  308. package/commands/project/__tests__/listBuilds.test.js +0 -38
  309. package/commands/project/__tests__/logs.test.d.ts +0 -1
  310. package/commands/project/__tests__/logs.test.js +0 -202
  311. package/commands/project/__tests__/migrate.test.d.ts +0 -1
  312. package/commands/project/__tests__/migrate.test.js +0 -106
  313. package/commands/project/__tests__/open.test.d.ts +0 -1
  314. package/commands/project/__tests__/open.test.js +0 -39
  315. package/commands/project/__tests__/profile.test.d.ts +0 -1
  316. package/commands/project/__tests__/profile.test.js +0 -42
  317. package/commands/project/__tests__/updateDeps.test.d.ts +0 -1
  318. package/commands/project/__tests__/updateDeps.test.js +0 -140
  319. package/commands/project/__tests__/upload.test.d.ts +0 -1
  320. package/commands/project/__tests__/upload.test.js +0 -234
  321. package/commands/project/__tests__/validate.test.d.ts +0 -1
  322. package/commands/project/__tests__/validate.test.js +0 -381
  323. package/commands/project/__tests__/watch.test.d.ts +0 -1
  324. package/commands/project/__tests__/watch.test.js +0 -35
  325. package/commands/sandbox/__tests__/create.test.d.ts +0 -1
  326. package/commands/sandbox/__tests__/create.test.js +0 -198
  327. package/commands/sandbox/__tests__/delete.test.d.ts +0 -1
  328. package/commands/sandbox/__tests__/delete.test.js +0 -31
  329. package/commands/secret/__tests__/addSecret.test.d.ts +0 -1
  330. package/commands/secret/__tests__/addSecret.test.js +0 -162
  331. package/commands/secret/__tests__/deleteSecret.test.d.ts +0 -1
  332. package/commands/secret/__tests__/deleteSecret.test.js +0 -41
  333. package/commands/secret/__tests__/listSecret.test.d.ts +0 -1
  334. package/commands/secret/__tests__/listSecret.test.js +0 -29
  335. package/commands/secret/__tests__/updateSecret.test.d.ts +0 -1
  336. package/commands/secret/__tests__/updateSecret.test.js +0 -29
  337. package/commands/testAccount/__tests__/create.test.d.ts +0 -1
  338. package/commands/testAccount/__tests__/create.test.js +0 -106
  339. package/commands/testAccount/__tests__/createConfig.test.d.ts +0 -1
  340. package/commands/testAccount/__tests__/createConfig.test.js +0 -32
  341. package/commands/testAccount/__tests__/delete.test.d.ts +0 -1
  342. package/commands/testAccount/__tests__/delete.test.js +0 -29
  343. package/commands/testAccount/__tests__/importData.test.d.ts +0 -1
  344. package/commands/testAccount/__tests__/importData.test.js +0 -92
  345. package/lib/__tests__/CLIWebSocketServer.test.d.ts +0 -1
  346. package/lib/__tests__/CLIWebSocketServer.test.js +0 -252
  347. package/lib/__tests__/accountAuth.test.d.ts +0 -1
  348. package/lib/__tests__/accountAuth.test.js +0 -258
  349. package/lib/__tests__/accountTypes.test.d.ts +0 -1
  350. package/lib/__tests__/accountTypes.test.js +0 -98
  351. package/lib/__tests__/buildAccount.test.d.ts +0 -1
  352. package/lib/__tests__/buildAccount.test.js +0 -211
  353. package/lib/__tests__/cliUpgradeUtils.test.d.ts +0 -1
  354. package/lib/__tests__/cliUpgradeUtils.test.js +0 -131
  355. package/lib/__tests__/commandSuggestion.test.d.ts +0 -1
  356. package/lib/__tests__/commandSuggestion.test.js +0 -121
  357. package/lib/__tests__/commonOpts.test.d.ts +0 -1
  358. package/lib/__tests__/commonOpts.test.js +0 -80
  359. package/lib/__tests__/dependencyManagement.test.d.ts +0 -1
  360. package/lib/__tests__/dependencyManagement.test.js +0 -1067
  361. package/lib/__tests__/developerTestAccounts.test.d.ts +0 -1
  362. package/lib/__tests__/developerTestAccounts.test.js +0 -156
  363. package/lib/__tests__/hasFeature.test.d.ts +0 -1
  364. package/lib/__tests__/hasFeature.test.js +0 -167
  365. package/lib/__tests__/http.test.d.ts +0 -1
  366. package/lib/__tests__/http.test.js +0 -40
  367. package/lib/__tests__/importData.test.d.ts +0 -1
  368. package/lib/__tests__/importData.test.js +0 -98
  369. package/lib/__tests__/npmCli.test.d.ts +0 -1
  370. package/lib/__tests__/npmCli.test.js +0 -84
  371. package/lib/__tests__/oauth.test.d.ts +0 -1
  372. package/lib/__tests__/oauth.test.js +0 -109
  373. package/lib/__tests__/parsing.test.d.ts +0 -1
  374. package/lib/__tests__/parsing.test.js +0 -34
  375. package/lib/__tests__/polling.test.d.ts +0 -1
  376. package/lib/__tests__/polling.test.js +0 -76
  377. package/lib/__tests__/process.test.d.ts +0 -1
  378. package/lib/__tests__/process.test.js +0 -89
  379. package/lib/__tests__/sandboxes.test.d.ts +0 -1
  380. package/lib/__tests__/sandboxes.test.js +0 -128
  381. package/lib/__tests__/serverlessLogs.test.d.ts +0 -1
  382. package/lib/__tests__/serverlessLogs.test.js +0 -163
  383. package/lib/__tests__/usageTracking.test.d.ts +0 -1
  384. package/lib/__tests__/usageTracking.test.js +0 -197
  385. package/lib/__tests__/validation.test.d.ts +0 -1
  386. package/lib/__tests__/validation.test.js +0 -143
  387. package/lib/__tests__/yargsUtils.test.d.ts +0 -1
  388. package/lib/__tests__/yargsUtils.test.js +0 -124
  389. package/lib/app/__tests__/migrate.test.d.ts +0 -1
  390. package/lib/app/__tests__/migrate.test.js +0 -638
  391. package/lib/doctor/__tests__/Diagnosis.test.d.ts +0 -1
  392. package/lib/doctor/__tests__/Diagnosis.test.js +0 -84
  393. package/lib/doctor/__tests__/DiagnosticInfoBuilder.test.d.ts +0 -1
  394. package/lib/doctor/__tests__/DiagnosticInfoBuilder.test.js +0 -177
  395. package/lib/doctor/__tests__/Doctor.test.d.ts +0 -1
  396. package/lib/doctor/__tests__/Doctor.test.js +0 -560
  397. package/lib/errorHandlers/__tests__/index.test.d.ts +0 -1
  398. package/lib/errorHandlers/__tests__/index.test.js +0 -278
  399. package/lib/mcp/__tests__/setup.test.d.ts +0 -1
  400. package/lib/mcp/__tests__/setup.test.js +0 -523
  401. package/lib/middleware/__tests__/commandTargetingUtils.test.d.ts +0 -1
  402. package/lib/middleware/__tests__/commandTargetingUtils.test.js +0 -99
  403. package/lib/middleware/__tests__/configMiddleware.test.d.ts +0 -1
  404. package/lib/middleware/__tests__/configMiddleware.test.js +0 -118
  405. package/lib/middleware/__tests__/gitMiddleware.test.d.ts +0 -1
  406. package/lib/middleware/__tests__/gitMiddleware.test.js +0 -43
  407. package/lib/middleware/__tests__/requestMiddleware.test.d.ts +0 -1
  408. package/lib/middleware/__tests__/requestMiddleware.test.js +0 -15
  409. package/lib/middleware/__tests__/usageTrackingMiddleware.test.d.ts +0 -1
  410. package/lib/middleware/__tests__/usageTrackingMiddleware.test.js +0 -44
  411. package/lib/middleware/__tests__/yargsChecksMiddleware.test.d.ts +0 -1
  412. package/lib/middleware/__tests__/yargsChecksMiddleware.test.js +0 -39
  413. package/lib/projects/__tests__/AppDevModeInterface.test.d.ts +0 -1
  414. package/lib/projects/__tests__/AppDevModeInterface.test.js +0 -541
  415. package/lib/projects/__tests__/DevServerManager.test.d.ts +0 -1
  416. package/lib/projects/__tests__/DevServerManager.test.js +0 -185
  417. package/lib/projects/__tests__/DevSessionManager.test.d.ts +0 -1
  418. package/lib/projects/__tests__/DevSessionManager.test.js +0 -250
  419. package/lib/projects/__tests__/LocalDevProcess.test.d.ts +0 -1
  420. package/lib/projects/__tests__/LocalDevProcess.test.js +0 -481
  421. package/lib/projects/__tests__/LocalDevWebsocketServer.test.d.ts +0 -1
  422. package/lib/projects/__tests__/LocalDevWebsocketServer.test.js +0 -231
  423. package/lib/projects/__tests__/ProjectLogsManager.test.d.ts +0 -1
  424. package/lib/projects/__tests__/ProjectLogsManager.test.js +0 -302
  425. package/lib/projects/__tests__/UIExtensionsDevModeInterface.test.d.ts +0 -1
  426. package/lib/projects/__tests__/UIExtensionsDevModeInterface.test.js +0 -160
  427. package/lib/projects/__tests__/components.test.d.ts +0 -1
  428. package/lib/projects/__tests__/components.test.js +0 -440
  429. package/lib/projects/__tests__/deploy.test.d.ts +0 -1
  430. package/lib/projects/__tests__/deploy.test.js +0 -231
  431. package/lib/projects/__tests__/localDevProjectHelpers.test.d.ts +0 -1
  432. package/lib/projects/__tests__/localDevProjectHelpers.test.js +0 -120
  433. package/lib/projects/__tests__/platformVersion.test.d.ts +0 -1
  434. package/lib/projects/__tests__/platformVersion.test.js +0 -63
  435. package/lib/projects/__tests__/pollProjectBuildAndDeploy.test.d.ts +0 -1
  436. package/lib/projects/__tests__/pollProjectBuildAndDeploy.test.js +0 -328
  437. package/lib/projects/__tests__/projectProfiles.test.d.ts +0 -1
  438. package/lib/projects/__tests__/projectProfiles.test.js +0 -441
  439. package/lib/projects/__tests__/projects.test.d.ts +0 -1
  440. package/lib/projects/__tests__/projects.test.js +0 -58
  441. package/lib/projects/__tests__/structure.test.d.ts +0 -1
  442. package/lib/projects/__tests__/structure.test.js +0 -210
  443. package/lib/projects/__tests__/uieLinting.test.d.ts +0 -1
  444. package/lib/projects/__tests__/uieLinting.test.js +0 -631
  445. package/lib/projects/__tests__/upload.test.d.ts +0 -1
  446. package/lib/projects/__tests__/upload.test.js +0 -183
  447. package/lib/projects/add/__tests__/legacyAddComponent.test.d.ts +0 -1
  448. package/lib/projects/add/__tests__/legacyAddComponent.test.js +0 -245
  449. package/lib/projects/add/__tests__/v2AddComponent.test.d.ts +0 -1
  450. package/lib/projects/add/__tests__/v2AddComponent.test.js +0 -343
  451. package/lib/projects/create/__tests__/legacy.test.d.ts +0 -1
  452. package/lib/projects/create/__tests__/legacy.test.js +0 -72
  453. package/lib/projects/create/__tests__/v2.test.d.ts +0 -1
  454. package/lib/projects/create/__tests__/v2.test.js +0 -257
  455. package/lib/prompts/__tests__/createDeveloperTestAccountConfigPrompt.test.d.ts +0 -1
  456. package/lib/prompts/__tests__/createDeveloperTestAccountConfigPrompt.test.js +0 -157
  457. package/lib/prompts/__tests__/createFunctionPrompt.test.d.ts +0 -1
  458. package/lib/prompts/__tests__/createFunctionPrompt.test.js +0 -129
  459. package/lib/prompts/__tests__/createModulePrompt.test.d.ts +0 -1
  460. package/lib/prompts/__tests__/createModulePrompt.test.js +0 -187
  461. package/lib/prompts/__tests__/createTemplatePrompt.test.d.ts +0 -1
  462. package/lib/prompts/__tests__/createTemplatePrompt.test.js +0 -102
  463. package/lib/prompts/__tests__/downloadProjectPrompt.test.d.ts +0 -1
  464. package/lib/prompts/__tests__/downloadProjectPrompt.test.js +0 -31
  465. package/lib/prompts/__tests__/projectAddPrompt.test.d.ts +0 -1
  466. package/lib/prompts/__tests__/projectAddPrompt.test.js +0 -143
  467. package/lib/prompts/__tests__/projectsLogsPrompt.test.d.ts +0 -1
  468. package/lib/prompts/__tests__/projectsLogsPrompt.test.js +0 -37
  469. package/lib/prompts/__tests__/selectProjectTemplatePrompt.test.d.ts +0 -1
  470. package/lib/prompts/__tests__/selectProjectTemplatePrompt.test.js +0 -160
  471. package/lib/theme/__tests__/migrate.test.d.ts +0 -1
  472. package/lib/theme/__tests__/migrate.test.js +0 -247
  473. package/lib/ui/__tests__/SpinniesManager.test.d.ts +0 -1
  474. package/lib/ui/__tests__/SpinniesManager.test.js +0 -488
  475. package/lib/ui/__tests__/removeAnsiCodes.test.d.ts +0 -1
  476. package/lib/ui/__tests__/removeAnsiCodes.test.js +0 -84
  477. package/mcp-server/tools/cms/__tests__/HsCreateFunctionTool.test.d.ts +0 -1
  478. package/mcp-server/tools/cms/__tests__/HsCreateFunctionTool.test.js +0 -254
  479. package/mcp-server/tools/cms/__tests__/HsCreateModuleTool.test.d.ts +0 -1
  480. package/mcp-server/tools/cms/__tests__/HsCreateModuleTool.test.js +0 -227
  481. package/mcp-server/tools/cms/__tests__/HsCreateTemplateTool.test.d.ts +0 -1
  482. package/mcp-server/tools/cms/__tests__/HsCreateTemplateTool.test.js +0 -208
  483. package/mcp-server/tools/cms/__tests__/HsFunctionLogsTool.test.d.ts +0 -1
  484. package/mcp-server/tools/cms/__tests__/HsFunctionLogsTool.test.js +0 -186
  485. package/mcp-server/tools/cms/__tests__/HsListFunctionsTool.test.d.ts +0 -1
  486. package/mcp-server/tools/cms/__tests__/HsListFunctionsTool.test.js +0 -124
  487. package/mcp-server/tools/cms/__tests__/HsListTool.test.d.ts +0 -1
  488. package/mcp-server/tools/cms/__tests__/HsListTool.test.js +0 -124
  489. package/mcp-server/tools/project/__tests__/AddFeatureToProjectTool.test.d.ts +0 -1
  490. package/mcp-server/tools/project/__tests__/AddFeatureToProjectTool.test.js +0 -157
  491. package/mcp-server/tools/project/__tests__/CreateProjectTool.test.d.ts +0 -1
  492. package/mcp-server/tools/project/__tests__/CreateProjectTool.test.js +0 -131
  493. package/mcp-server/tools/project/__tests__/CreateTestAccountTool.test.d.ts +0 -1
  494. package/mcp-server/tools/project/__tests__/CreateTestAccountTool.test.js +0 -461
  495. package/mcp-server/tools/project/__tests__/DeployProjectTool.test.d.ts +0 -1
  496. package/mcp-server/tools/project/__tests__/DeployProjectTool.test.js +0 -125
  497. package/mcp-server/tools/project/__tests__/DocFetchTool.test.d.ts +0 -1
  498. package/mcp-server/tools/project/__tests__/DocFetchTool.test.js +0 -125
  499. package/mcp-server/tools/project/__tests__/DocsSearchTool.test.d.ts +0 -1
  500. package/mcp-server/tools/project/__tests__/DocsSearchTool.test.js +0 -210
  501. package/mcp-server/tools/project/__tests__/GetApiUsagePatternsByAppIdTool.test.d.ts +0 -1
  502. package/mcp-server/tools/project/__tests__/GetApiUsagePatternsByAppIdTool.test.js +0 -146
  503. package/mcp-server/tools/project/__tests__/GetApplicationInfoTool.test.d.ts +0 -1
  504. package/mcp-server/tools/project/__tests__/GetApplicationInfoTool.test.js +0 -124
  505. package/mcp-server/tools/project/__tests__/GetBuildLogsTool.test.d.ts +0 -1
  506. package/mcp-server/tools/project/__tests__/GetBuildLogsTool.test.js +0 -307
  507. package/mcp-server/tools/project/__tests__/GetBuildStatusTool.test.d.ts +0 -1
  508. package/mcp-server/tools/project/__tests__/GetBuildStatusTool.test.js +0 -242
  509. package/mcp-server/tools/project/__tests__/GetConfigValuesTool.test.d.ts +0 -1
  510. package/mcp-server/tools/project/__tests__/GetConfigValuesTool.test.js +0 -209
  511. package/mcp-server/tools/project/__tests__/GuidedWalkthroughTool.test.d.ts +0 -1
  512. package/mcp-server/tools/project/__tests__/GuidedWalkthroughTool.test.js +0 -158
  513. package/mcp-server/tools/project/__tests__/UploadProjectTools.test.d.ts +0 -1
  514. package/mcp-server/tools/project/__tests__/UploadProjectTools.test.js +0 -187
  515. package/mcp-server/tools/project/__tests__/ValidateProjectTool.test.d.ts +0 -1
  516. package/mcp-server/tools/project/__tests__/ValidateProjectTool.test.js +0 -118
  517. package/mcp-server/utils/__tests__/command.test.d.ts +0 -1
  518. package/mcp-server/utils/__tests__/command.test.js +0 -275
  519. package/mcp-server/utils/__tests__/content.test.d.ts +0 -1
  520. package/mcp-server/utils/__tests__/content.test.js +0 -164
  521. package/mcp-server/utils/__tests__/feedbackTracking.test.d.ts +0 -1
  522. package/mcp-server/utils/__tests__/feedbackTracking.test.js +0 -69
@@ -1,234 +0,0 @@
1
- import yargs from 'yargs';
2
- import { addAccountOptions, addConfigOptions, addUseEnvironmentOptions, addJSONOutputOptions, } from '../../../lib/commonOpts.js';
3
- import * as configUtils from '@hubspot/local-dev-lib/config';
4
- import * as errorsLib from '@hubspot/local-dev-lib/errors/index';
5
- import { uiLogger } from '../../../lib/ui/logger.js';
6
- import * as platformVersionLib from '../../../lib/projects/platformVersion.js';
7
- import * as usageTrackingLib from '../../../lib/usageTracking.js';
8
- import * as projectConfigLib from '../../../lib/projects/config.js';
9
- import * as projectProfilesLib from '../../../lib/projects/projectProfiles.js';
10
- import * as pollProjectLib from '../../../lib/projects/pollProjectBuildAndDeploy.js';
11
- import * as uploadLib from '../../../lib/projects/upload.js';
12
- import * as uiLib from '../../../lib/projects/ui.js';
13
- import * as errorHandlers from '../../../lib/errorHandlers/index.js';
14
- import { EXIT_CODES } from '../../../lib/enums/exitCodes.js';
15
- import { PROJECT_ERROR_TYPES } from '../../../lib/constants.js';
16
- import projectUploadCommand from '../upload.js';
17
- vi.mock('../../../lib/commonOpts');
18
- vi.mock('@hubspot/local-dev-lib/config');
19
- vi.mock('@hubspot/local-dev-lib/errors/index');
20
- vi.mock('../../../lib/projects/platformVersion.js');
21
- vi.mock('../../../lib/projects/config.js');
22
- vi.mock('../../../lib/projects/projectProfiles.js');
23
- vi.mock('../../../lib/projects/pollProjectBuildAndDeploy.js');
24
- vi.mock('../../../lib/projects/upload.js');
25
- vi.mock('../../../lib/projects/ui.js');
26
- vi.mock('../../../lib/errorHandlers/index.js');
27
- const optionsSpy = vi.spyOn(yargs, 'options');
28
- const exampleSpy = vi.spyOn(yargs, 'example');
29
- const conflictsSpy = vi.spyOn(yargs, 'conflicts');
30
- const getProjectConfigSpy = vi.spyOn(projectConfigLib, 'getProjectConfig');
31
- const validateProjectConfigSpy = vi.spyOn(projectConfigLib, 'validateProjectConfig');
32
- const isV2ProjectSpy = vi.spyOn(platformVersionLib, 'isV2Project');
33
- const loadAndValidateProfileSpy = vi.spyOn(projectProfilesLib, 'loadAndValidateProfile');
34
- const getConfigAccountByIdSpy = vi.spyOn(configUtils, 'getConfigAccountById');
35
- const trackCommandUsageSpy = vi.spyOn(usageTrackingLib, 'trackCommandUsage');
36
- const handleProjectUploadSpy = vi.spyOn(uploadLib, 'handleProjectUpload');
37
- const pollProjectBuildAndDeploySpy = vi.spyOn(pollProjectLib, 'pollProjectBuildAndDeploy');
38
- const displayWarnLogsSpy = vi.spyOn(pollProjectLib, 'displayWarnLogs');
39
- const logFeedbackMessageSpy = vi.spyOn(uiLib, 'logFeedbackMessage');
40
- const isSpecifiedErrorSpy = vi.spyOn(errorsLib, 'isSpecifiedError');
41
- const processExitSpy = vi.spyOn(process, 'exit');
42
- const logErrorSpy = vi.spyOn(errorHandlers, 'logError');
43
- describe('commands/project/upload', () => {
44
- beforeEach(() => {
45
- // @ts-expect-error Mock implementation
46
- processExitSpy.mockImplementation(() => { });
47
- getProjectConfigSpy.mockResolvedValue({
48
- projectConfig: {
49
- name: 'test-project',
50
- srcDir: 'src',
51
- platformVersion: '2024.1',
52
- },
53
- projectDir: '/test/project',
54
- });
55
- validateProjectConfigSpy.mockImplementation(() => { });
56
- isV2ProjectSpy.mockReturnValue(false);
57
- // @ts-expect-error Mock config account doesn't need full type implementation
58
- getConfigAccountByIdSpy.mockReturnValue({
59
- accountId: 123456,
60
- accountType: 'STANDARD',
61
- });
62
- handleProjectUploadSpy.mockResolvedValue({
63
- result: {
64
- succeeded: true,
65
- buildId: 123,
66
- buildResult: { isAutoDeployEnabled: true },
67
- },
68
- uploadError: null,
69
- });
70
- });
71
- describe('command', () => {
72
- it('should have the correct command structure', () => {
73
- expect(projectUploadCommand.command).toEqual('upload');
74
- });
75
- });
76
- describe('describe', () => {
77
- it('should provide a description', () => {
78
- expect(projectUploadCommand.describe).toBeDefined();
79
- });
80
- });
81
- describe('builder', () => {
82
- it('should support the correct options', () => {
83
- projectUploadCommand.builder(yargs);
84
- expect(conflictsSpy).toHaveBeenCalledTimes(1);
85
- expect(conflictsSpy).toHaveBeenCalledWith('profile', 'account');
86
- expect(addAccountOptions).toHaveBeenCalledTimes(1);
87
- expect(addAccountOptions).toHaveBeenCalledWith(yargs);
88
- expect(addConfigOptions).toHaveBeenCalledTimes(1);
89
- expect(addConfigOptions).toHaveBeenCalledWith(yargs);
90
- expect(addUseEnvironmentOptions).toHaveBeenCalledTimes(1);
91
- expect(addUseEnvironmentOptions).toHaveBeenCalledWith(yargs);
92
- expect(addJSONOutputOptions).toHaveBeenCalledTimes(1);
93
- expect(addJSONOutputOptions).toHaveBeenCalledWith(yargs);
94
- });
95
- it('should define force-create, message, and skip-validation options', () => {
96
- projectUploadCommand.builder(yargs);
97
- expect(optionsSpy).toHaveBeenCalledWith(expect.objectContaining({
98
- 'force-create': expect.any(Object),
99
- message: expect.any(Object),
100
- 'skip-validation': expect.any(Object),
101
- }));
102
- expect(exampleSpy).toHaveBeenCalled();
103
- });
104
- });
105
- describe('handler', () => {
106
- let args;
107
- beforeEach(() => {
108
- args = {
109
- forceCreate: false,
110
- message: 'Test upload',
111
- derivedAccountId: 123456,
112
- skipValidation: false,
113
- formatOutputAsJson: false,
114
- };
115
- });
116
- it('should get and validate project config', async () => {
117
- await projectUploadCommand.handler(args);
118
- expect(getProjectConfigSpy).toHaveBeenCalled();
119
- expect(validateProjectConfigSpy).toHaveBeenCalledWith(expect.objectContaining({ name: 'test-project' }), '/test/project');
120
- });
121
- it('should exit if project config validation fails', async () => {
122
- const error = new Error('Invalid config');
123
- validateProjectConfigSpy.mockImplementation(() => {
124
- throw error;
125
- });
126
- await projectUploadCommand.handler(args);
127
- expect(logErrorSpy).toHaveBeenCalledWith(error);
128
- expect(processExitSpy).toHaveBeenCalledWith(EXIT_CODES.ERROR);
129
- });
130
- it('should load and validate profile for v2 projects', async () => {
131
- isV2ProjectSpy.mockReturnValue(true);
132
- args.profile = 'test-profile';
133
- loadAndValidateProfileSpy.mockResolvedValue(789012);
134
- await projectUploadCommand.handler(args);
135
- expect(isV2ProjectSpy).toHaveBeenCalled();
136
- expect(loadAndValidateProfileSpy).toHaveBeenCalledWith(expect.objectContaining({ name: 'test-project' }), '/test/project', 'test-profile');
137
- });
138
- it('should exit if profile validation fails', async () => {
139
- isV2ProjectSpy.mockReturnValue(true);
140
- const error = new Error('Invalid profile');
141
- loadAndValidateProfileSpy.mockRejectedValue(error);
142
- await projectUploadCommand.handler(args);
143
- expect(logErrorSpy).toHaveBeenCalledWith(error);
144
- expect(processExitSpy).toHaveBeenCalledWith(EXIT_CODES.ERROR);
145
- });
146
- it('should track command usage', async () => {
147
- await projectUploadCommand.handler(args);
148
- expect(trackCommandUsageSpy).toHaveBeenCalledWith('project-upload', { type: 'STANDARD', assetType: '2024.1' }, 123456);
149
- });
150
- it('should handle project upload', async () => {
151
- await projectUploadCommand.handler(args);
152
- expect(handleProjectUploadSpy).toHaveBeenCalledWith({
153
- accountId: 123456,
154
- projectConfig: expect.objectContaining({ name: 'test-project' }),
155
- projectDir: '/test/project',
156
- callbackFunc: pollProjectBuildAndDeploySpy,
157
- uploadMessage: 'Test upload',
158
- forceCreate: false,
159
- isUploadCommand: true,
160
- sendIR: false,
161
- skipValidation: false,
162
- profile: undefined,
163
- });
164
- });
165
- it('should handle project locked error', async () => {
166
- const error = new Error('Project locked');
167
- isSpecifiedErrorSpy.mockReturnValue(true);
168
- handleProjectUploadSpy.mockResolvedValue({
169
- result: null,
170
- uploadError: error,
171
- });
172
- await projectUploadCommand.handler(args);
173
- expect(isSpecifiedErrorSpy).toHaveBeenCalledWith(error, {
174
- subCategory: PROJECT_ERROR_TYPES.PROJECT_LOCKED,
175
- });
176
- expect(uiLogger.error).toHaveBeenCalledWith(expect.stringContaining('locked'));
177
- expect(processExitSpy).toHaveBeenCalledWith(EXIT_CODES.ERROR);
178
- });
179
- it('should handle upload errors', async () => {
180
- const error = new Error('Upload failed');
181
- isSpecifiedErrorSpy.mockReturnValue(false);
182
- handleProjectUploadSpy.mockResolvedValue({
183
- result: null,
184
- uploadError: error,
185
- });
186
- await projectUploadCommand.handler(args);
187
- expect(logErrorSpy).toHaveBeenCalledWith(error, expect.any(errorHandlers.ApiErrorContext));
188
- expect(processExitSpy).toHaveBeenCalledWith(EXIT_CODES.ERROR);
189
- });
190
- it('should handle successful build with auto-deploy disabled', async () => {
191
- handleProjectUploadSpy.mockResolvedValue({
192
- result: {
193
- succeeded: true,
194
- buildId: 456,
195
- buildResult: { isAutoDeployEnabled: false },
196
- },
197
- uploadError: null,
198
- });
199
- await projectUploadCommand.handler(args);
200
- expect(uiLogger.log).toHaveBeenCalledWith(expect.stringContaining('456'));
201
- expect(uiLogger.log).toHaveBeenCalledWith(expect.stringContaining('deploy'));
202
- expect(logFeedbackMessageSpy).toHaveBeenCalledWith(456);
203
- expect(displayWarnLogsSpy).toHaveBeenCalledWith(123456, 'test-project', 456);
204
- });
205
- it('should output JSON when formatOutputAsJson is true', async () => {
206
- args.formatOutputAsJson = true;
207
- handleProjectUploadSpy.mockResolvedValue({
208
- result: {
209
- succeeded: true,
210
- buildId: 789,
211
- buildResult: { isAutoDeployEnabled: true },
212
- deployResult: { deployId: 101112 },
213
- },
214
- uploadError: null,
215
- });
216
- await projectUploadCommand.handler(args);
217
- expect(uiLogger.json).toHaveBeenCalledWith({
218
- buildId: 789,
219
- deployId: 101112,
220
- });
221
- });
222
- it('should exit with SUCCESS code when complete', async () => {
223
- await projectUploadCommand.handler(args);
224
- expect(processExitSpy).toHaveBeenCalledWith(EXIT_CODES.SUCCESS);
225
- });
226
- it('should handle exceptions during upload', async () => {
227
- const error = new Error('Unexpected error');
228
- handleProjectUploadSpy.mockRejectedValue(error);
229
- await projectUploadCommand.handler(args);
230
- expect(logErrorSpy).toHaveBeenCalledWith(error, expect.any(errorHandlers.ApiErrorContext));
231
- expect(processExitSpy).toHaveBeenCalledWith(EXIT_CODES.ERROR);
232
- });
233
- });
234
- });
@@ -1 +0,0 @@
1
- export {};
@@ -1,381 +0,0 @@
1
- import path from 'path';
2
- import { vi } from 'vitest';
3
- import { validateSourceDirectory } from '../../../lib/projects/upload.js';
4
- import { getProjectConfig, validateProjectConfig, } from '../../../lib/projects/config.js';
5
- import { uiLogger } from '../../../lib/ui/logger.js';
6
- import { commands } from '../../../lang/en.js';
7
- import { isV2Project } from '../../../lib/projects/platformVersion.js';
8
- import { validateProjectForProfile } from '../../../lib/projects/projectProfiles.js';
9
- import { trackCommandUsage } from '../../../lib/usageTracking.js';
10
- import { getConfigAccountById } from '@hubspot/local-dev-lib/config';
11
- import { handleTranslate } from '../../../lib/projects/upload.js';
12
- import projectValidateCommand from '../validate.js';
13
- import { getAllHsProfiles } from '@hubspot/project-parsing-lib/profiles';
14
- import SpinniesManager from '../../../lib/ui/SpinniesManager.js';
15
- import { logError } from '../../../lib/errorHandlers/index.js';
16
- // Mock dependencies
17
- vi.mock('../../../lib/projects/upload.js');
18
- vi.mock('../../../lib/projects/config.js');
19
- vi.mock('../../../lib/projects/projectProfiles.js');
20
- vi.mock('../../../lib/errorHandlers/index.js');
21
- vi.mock('@hubspot/local-dev-lib/config');
22
- vi.mock('../../../lib/projects/platformVersion.js');
23
- vi.mock('@hubspot/project-parsing-lib/profiles');
24
- vi.mock('../../../lib/ui/SpinniesManager.js');
25
- describe('commands/project/validate', () => {
26
- const projectDir = '/test/project';
27
- let exitSpy;
28
- const mockProjectConfig = {
29
- name: 'test-project',
30
- srcDir: 'src',
31
- platformVersion: '2025.2',
32
- };
33
- const mockAccountConfig = {
34
- accountType: 'STANDARD',
35
- accountId: 123,
36
- env: 'prod',
37
- };
38
- beforeEach(() => {
39
- // Mock process.exit to throw to stop execution
40
- exitSpy = vi.spyOn(process, 'exit').mockImplementation(code => {
41
- throw new Error(`Process exited with code ${code}`);
42
- });
43
- // Set up default mocks
44
- vi.mocked(getConfigAccountById).mockReturnValue(mockAccountConfig);
45
- vi.mocked(trackCommandUsage);
46
- vi.mocked(SpinniesManager.init);
47
- vi.mocked(SpinniesManager.add);
48
- vi.mocked(SpinniesManager.succeed);
49
- vi.mocked(SpinniesManager.fail);
50
- vi.mocked(validateProjectForProfile).mockResolvedValue([]);
51
- });
52
- afterEach(() => {
53
- exitSpy.mockRestore();
54
- });
55
- describe('project configuration validation', () => {
56
- it('should exit with error when project config is null', async () => {
57
- vi.mocked(getProjectConfig).mockResolvedValue({
58
- projectConfig: null,
59
- projectDir: null,
60
- });
61
- await expect(
62
- // @ts-expect-error partial mock
63
- projectValidateCommand.handler({
64
- derivedAccountId: 123,
65
- d: false,
66
- debug: false,
67
- })).rejects.toThrow('Process exited with code 1');
68
- expect(uiLogger.error).toHaveBeenCalledWith(commands.project.validate.mustBeRanWithinAProject);
69
- });
70
- it('should exit with error when project directory is null', async () => {
71
- vi.mocked(getProjectConfig).mockResolvedValue({
72
- projectConfig: {
73
- name: 'test',
74
- srcDir: 'src',
75
- platformVersion: '2025.2',
76
- },
77
- projectDir: null,
78
- });
79
- await expect(
80
- // @ts-expect-error partial mock
81
- projectValidateCommand.handler({
82
- derivedAccountId: 123,
83
- d: false,
84
- debug: false,
85
- })).rejects.toThrow('Process exited with code 1');
86
- expect(uiLogger.error).toHaveBeenCalledWith(commands.project.validate.mustBeRanWithinAProject);
87
- });
88
- it('should exit with error for non-V2 projects', async () => {
89
- vi.mocked(getProjectConfig).mockResolvedValue({
90
- projectConfig: {
91
- name: 'test',
92
- srcDir: 'src',
93
- platformVersion: '2024.1',
94
- },
95
- projectDir,
96
- });
97
- vi.mocked(isV2Project).mockReturnValue(false);
98
- await expect(
99
- // @ts-expect-error partial mock
100
- projectValidateCommand.handler({
101
- derivedAccountId: 123,
102
- d: false,
103
- debug: false,
104
- })).rejects.toThrow('Process exited with code 1');
105
- expect(uiLogger.error).toHaveBeenCalledWith(commands.project.validate.badVersion);
106
- });
107
- it('should exit with error when validateProjectConfig throws', async () => {
108
- vi.mocked(getProjectConfig).mockResolvedValue({
109
- projectConfig: mockProjectConfig,
110
- projectDir,
111
- });
112
- vi.mocked(isV2Project).mockReturnValue(true);
113
- const error = new Error('Invalid project config');
114
- vi.mocked(validateProjectConfig).mockImplementation(() => {
115
- throw error;
116
- });
117
- await expect(
118
- // @ts-expect-error partial mock
119
- projectValidateCommand.handler({
120
- derivedAccountId: 123,
121
- d: false,
122
- debug: false,
123
- })).rejects.toThrow('Process exited with code 1');
124
- expect(logError).toHaveBeenCalledWith(error);
125
- });
126
- });
127
- describe('profile validation', () => {
128
- describe('when a specific profile is provided', () => {
129
- it('should validate only the specified profile', async () => {
130
- vi.mocked(getProjectConfig).mockResolvedValue({
131
- projectConfig: mockProjectConfig,
132
- projectDir,
133
- });
134
- vi.mocked(isV2Project).mockReturnValue(true);
135
- vi.mocked(validateProjectConfig).mockReturnValue(undefined);
136
- vi.mocked(getAllHsProfiles).mockResolvedValue(['dev', 'prod', 'qa']);
137
- vi.mocked(validateProjectForProfile).mockResolvedValue([]);
138
- vi.mocked(validateSourceDirectory).mockResolvedValue(undefined);
139
- await expect(projectValidateCommand.handler({
140
- derivedAccountId: 123,
141
- profile: 'dev',
142
- d: false,
143
- debug: false,
144
- })).rejects.toThrow('Process exited with code 0');
145
- // Should call validateProjectForProfile for the specified profile
146
- expect(validateProjectForProfile).toHaveBeenCalledWith({
147
- projectConfig: mockProjectConfig,
148
- projectDir,
149
- profileName: 'dev',
150
- derivedAccountId: 123,
151
- });
152
- expect(uiLogger.success).toHaveBeenCalledWith(commands.project.validate.success(mockProjectConfig.name));
153
- });
154
- it('should handle profile validation failure', async () => {
155
- vi.mocked(getProjectConfig).mockResolvedValue({
156
- projectConfig: mockProjectConfig,
157
- projectDir,
158
- });
159
- vi.mocked(isV2Project).mockReturnValue(true);
160
- vi.mocked(validateProjectConfig).mockReturnValue(undefined);
161
- vi.mocked(getAllHsProfiles).mockResolvedValue(['dev', 'prod']);
162
- const errorMessage = 'Profile not found';
163
- vi.mocked(validateProjectForProfile).mockResolvedValue([errorMessage]);
164
- await expect(projectValidateCommand.handler({
165
- derivedAccountId: 123,
166
- profile: 'dev',
167
- d: false,
168
- debug: false,
169
- })).rejects.toThrow('Process exited with code 1');
170
- // The error message is logged as a string
171
- expect(uiLogger.log).toHaveBeenCalledWith(errorMessage);
172
- });
173
- it('should handle translate failure for a profile', async () => {
174
- vi.mocked(getProjectConfig).mockResolvedValue({
175
- projectConfig: mockProjectConfig,
176
- projectDir,
177
- });
178
- vi.mocked(isV2Project).mockReturnValue(true);
179
- vi.mocked(validateProjectConfig).mockReturnValue(undefined);
180
- vi.mocked(getAllHsProfiles).mockResolvedValue(['dev', 'prod']);
181
- const error = new Error('Translation failed');
182
- vi.mocked(validateProjectForProfile).mockResolvedValue([
183
- commands.project.validate.failure('prod'),
184
- error,
185
- ]);
186
- await expect(projectValidateCommand.handler({
187
- derivedAccountId: 123,
188
- profile: 'dev',
189
- d: false,
190
- debug: false,
191
- })).rejects.toThrow('Process exited with code 1');
192
- // The error object is logged via logError
193
- expect(logError).toHaveBeenCalledWith(error);
194
- });
195
- });
196
- describe('when no profile is provided and project has profiles', () => {
197
- it('should validate all profiles', async () => {
198
- vi.mocked(getProjectConfig).mockResolvedValue({
199
- projectConfig: mockProjectConfig,
200
- projectDir,
201
- });
202
- vi.mocked(isV2Project).mockReturnValue(true);
203
- vi.mocked(validateProjectConfig).mockReturnValue(undefined);
204
- vi.mocked(getAllHsProfiles).mockResolvedValue(['dev', 'prod', 'qa']);
205
- vi.mocked(validateProjectForProfile).mockResolvedValue([]);
206
- vi.mocked(validateSourceDirectory).mockResolvedValue(undefined);
207
- await expect(projectValidateCommand.handler({
208
- derivedAccountId: 123,
209
- d: false,
210
- debug: false,
211
- })).rejects.toThrow('Process exited with code 0');
212
- // Should validate all three profiles
213
- expect(validateProjectForProfile).toHaveBeenCalledTimes(3);
214
- expect(validateProjectForProfile).toHaveBeenCalledWith({
215
- projectConfig: mockProjectConfig,
216
- projectDir,
217
- profileName: 'dev',
218
- derivedAccountId: 123,
219
- indentSpinners: true,
220
- });
221
- expect(validateProjectForProfile).toHaveBeenCalledWith({
222
- projectConfig: mockProjectConfig,
223
- projectDir,
224
- profileName: 'prod',
225
- derivedAccountId: 123,
226
- indentSpinners: true,
227
- });
228
- expect(validateProjectForProfile).toHaveBeenCalledWith({
229
- projectConfig: mockProjectConfig,
230
- projectDir,
231
- profileName: 'qa',
232
- derivedAccountId: 123,
233
- indentSpinners: true,
234
- });
235
- // Should show success for all profiles
236
- expect(SpinniesManager.succeed).toHaveBeenCalledWith('validatingAllProfiles', expect.any(Object));
237
- expect(uiLogger.success).toHaveBeenCalledWith(commands.project.validate.success(mockProjectConfig.name));
238
- });
239
- it('should handle failure when validating multiple profiles', async () => {
240
- vi.mocked(getProjectConfig).mockResolvedValue({
241
- projectConfig: mockProjectConfig,
242
- projectDir,
243
- });
244
- vi.mocked(isV2Project).mockReturnValue(true);
245
- vi.mocked(validateProjectConfig).mockReturnValue(undefined);
246
- vi.mocked(getAllHsProfiles).mockResolvedValue(['dev', 'prod']);
247
- vi.mocked(validateProjectForProfile)
248
- .mockResolvedValueOnce([]) // dev succeeds
249
- .mockResolvedValueOnce(['Profile not found']); // prod fails
250
- await expect(projectValidateCommand.handler({
251
- derivedAccountId: 123,
252
- d: false,
253
- debug: false,
254
- })).rejects.toThrow('Process exited with code 1');
255
- expect(SpinniesManager.fail).toHaveBeenCalledWith('validatingAllProfiles', expect.any(Object));
256
- });
257
- it('should continue validating remaining profiles after one fails', async () => {
258
- vi.mocked(getProjectConfig).mockResolvedValue({
259
- projectConfig: mockProjectConfig,
260
- projectDir,
261
- });
262
- vi.mocked(isV2Project).mockReturnValue(true);
263
- vi.mocked(validateProjectConfig).mockReturnValue(undefined);
264
- vi.mocked(getAllHsProfiles).mockResolvedValue(['dev', 'prod', 'qa']);
265
- vi.mocked(validateProjectForProfile)
266
- .mockResolvedValueOnce([]) // dev succeeds
267
- .mockResolvedValueOnce(['Profile not found']) // prod fails
268
- .mockResolvedValueOnce([]); // qa succeeds
269
- vi.mocked(validateSourceDirectory).mockResolvedValue(undefined);
270
- await expect(projectValidateCommand.handler({
271
- derivedAccountId: 123,
272
- d: false,
273
- debug: false,
274
- })).rejects.toThrow('Process exited with code 1');
275
- // All three profiles should be attempted
276
- expect(validateProjectForProfile).toHaveBeenCalledTimes(3);
277
- });
278
- });
279
- describe('when no profile is provided and project has no profiles', () => {
280
- it('should validate without a profile', async () => {
281
- vi.mocked(getProjectConfig).mockResolvedValue({
282
- projectConfig: mockProjectConfig,
283
- projectDir,
284
- });
285
- vi.mocked(isV2Project).mockReturnValue(true);
286
- vi.mocked(validateProjectConfig).mockReturnValue(undefined);
287
- vi.mocked(getAllHsProfiles).mockResolvedValue([]);
288
- vi.mocked(handleTranslate).mockResolvedValue(undefined);
289
- vi.mocked(validateSourceDirectory).mockResolvedValue(undefined);
290
- await expect(projectValidateCommand.handler({
291
- derivedAccountId: 123,
292
- d: false,
293
- debug: false,
294
- })).rejects.toThrow('Process exited with code 0');
295
- // Should call handleTranslate without a profile
296
- expect(handleTranslate).toHaveBeenCalledWith({
297
- projectDir,
298
- projectConfig: mockProjectConfig,
299
- accountId: 123,
300
- skipValidation: false,
301
- });
302
- expect(uiLogger.success).toHaveBeenCalledWith(commands.project.validate.success(mockProjectConfig.name));
303
- });
304
- it('should handle validation failure when no profiles exist', async () => {
305
- vi.mocked(getProjectConfig).mockResolvedValue({
306
- projectConfig: mockProjectConfig,
307
- projectDir,
308
- });
309
- vi.mocked(isV2Project).mockReturnValue(true);
310
- vi.mocked(validateProjectConfig).mockReturnValue(undefined);
311
- vi.mocked(getAllHsProfiles).mockResolvedValue([]);
312
- const error = new Error('Translation failed');
313
- vi.mocked(handleTranslate).mockRejectedValue(error);
314
- await expect(projectValidateCommand.handler({
315
- derivedAccountId: 123,
316
- d: false,
317
- debug: false,
318
- })).rejects.toThrow('Process exited with code 1');
319
- expect(uiLogger.error).toHaveBeenCalledWith(commands.project.validate.failure(mockProjectConfig.name));
320
- expect(logError).toHaveBeenCalledWith(error);
321
- });
322
- });
323
- });
324
- describe('source directory validation', () => {
325
- it('should call validateSourceDirectory with correct parameters', async () => {
326
- vi.mocked(getProjectConfig).mockResolvedValue({
327
- projectConfig: mockProjectConfig,
328
- projectDir,
329
- });
330
- vi.mocked(isV2Project).mockReturnValue(true);
331
- vi.mocked(validateProjectConfig).mockReturnValue(undefined);
332
- vi.mocked(getAllHsProfiles).mockResolvedValue([]);
333
- vi.mocked(handleTranslate).mockResolvedValue(undefined);
334
- vi.mocked(validateSourceDirectory).mockResolvedValue(undefined);
335
- await expect(projectValidateCommand.handler({
336
- derivedAccountId: 123,
337
- d: false,
338
- debug: false,
339
- })).rejects.toThrow('Process exited with code 0');
340
- const expectedSrcDir = path.resolve(projectDir, mockProjectConfig.srcDir);
341
- expect(validateSourceDirectory).toHaveBeenCalledWith(expectedSrcDir, mockProjectConfig, projectDir);
342
- });
343
- it('should exit with error when validateSourceDirectory throws', async () => {
344
- vi.mocked(getProjectConfig).mockResolvedValue({
345
- projectConfig: mockProjectConfig,
346
- projectDir,
347
- });
348
- vi.mocked(isV2Project).mockReturnValue(true);
349
- vi.mocked(validateProjectConfig).mockReturnValue(undefined);
350
- vi.mocked(getAllHsProfiles).mockResolvedValue([]);
351
- vi.mocked(handleTranslate).mockResolvedValue(undefined);
352
- const error = new Error('Invalid source directory');
353
- vi.mocked(validateSourceDirectory).mockRejectedValue(error);
354
- await expect(projectValidateCommand.handler({
355
- derivedAccountId: 123,
356
- d: false,
357
- debug: false,
358
- })).rejects.toThrow('Process exited with code 1');
359
- expect(logError).toHaveBeenCalledWith(error);
360
- });
361
- });
362
- describe('command usage tracking', () => {
363
- it('should track command usage with account type', async () => {
364
- vi.mocked(getProjectConfig).mockResolvedValue({
365
- projectConfig: mockProjectConfig,
366
- projectDir,
367
- });
368
- vi.mocked(isV2Project).mockReturnValue(true);
369
- vi.mocked(validateProjectConfig).mockReturnValue(undefined);
370
- vi.mocked(getAllHsProfiles).mockResolvedValue([]);
371
- vi.mocked(handleTranslate).mockResolvedValue(undefined);
372
- vi.mocked(validateSourceDirectory).mockResolvedValue(undefined);
373
- await expect(projectValidateCommand.handler({
374
- derivedAccountId: 123,
375
- d: false,
376
- debug: false,
377
- })).rejects.toThrow('Process exited with code 0');
378
- expect(trackCommandUsage).toHaveBeenCalledWith('project-validate', { type: 'STANDARD' }, 123);
379
- });
380
- });
381
- });
@@ -1 +0,0 @@
1
- export {};
@@ -1,35 +0,0 @@
1
- import yargs from 'yargs';
2
- import { addAccountOptions, addConfigOptions, addUseEnvironmentOptions, } from '../../../lib/commonOpts.js';
3
- import projectWatchCommand from '../watch.js';
4
- vi.mock('../../../lib/commonOpts');
5
- describe('commands/project/watch', () => {
6
- const yargsMock = yargs;
7
- describe('command', () => {
8
- it('should have the correct command structure', () => {
9
- expect(projectWatchCommand.command).toEqual('watch');
10
- });
11
- });
12
- describe('describe', () => {
13
- it('should provide a description', () => {
14
- expect(projectWatchCommand.describe).toBeDefined();
15
- });
16
- });
17
- describe('builder', () => {
18
- it('should support the correct options', () => {
19
- projectWatchCommand.builder(yargsMock);
20
- expect(addAccountOptions).toHaveBeenCalledTimes(1);
21
- expect(addAccountOptions).toHaveBeenCalledWith(yargsMock);
22
- expect(addConfigOptions).toHaveBeenCalledTimes(1);
23
- expect(addConfigOptions).toHaveBeenCalledWith(yargsMock);
24
- expect(addUseEnvironmentOptions).toHaveBeenCalledTimes(1);
25
- expect(addUseEnvironmentOptions).toHaveBeenCalledWith(yargsMock);
26
- });
27
- it('should define options', () => {
28
- const optionSpy = vi.spyOn(yargsMock, 'option');
29
- const exampleSpy = vi.spyOn(yargsMock, 'example');
30
- projectWatchCommand.builder(yargsMock);
31
- expect(optionSpy).toHaveBeenCalledWith('initial-upload', expect.any(Object));
32
- expect(exampleSpy).toHaveBeenCalled();
33
- });
34
- });
35
- });
@@ -1 +0,0 @@
1
- export {};