@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,231 +0,0 @@
1
- import { WebSocketServer } from 'ws';
2
- import { isPortManagerServerRunning, requestPorts, } from '@hubspot/local-dev-lib/portManager';
3
- import { LOCAL_DEV_UI_MESSAGE_RECEIVE_TYPES, LOCAL_DEV_UI_MESSAGE_SEND_TYPES, LOCAL_DEV_SERVER_MESSAGE_TYPES, } from '../../constants.js';
4
- import LocalDevWebsocketServer from '../localDev/LocalDevWebsocketServer.js';
5
- vi.mock('ws');
6
- vi.mock('@hubspot/local-dev-lib/portManager');
7
- describe('LocalDevWebsocketServer', () => {
8
- let mockLocalDevProcess;
9
- let mockWebSocket;
10
- let mockWebSocketServer;
11
- let server;
12
- beforeEach(() => {
13
- mockWebSocket = {
14
- on: vi.fn(),
15
- send: vi.fn(),
16
- close: vi.fn(),
17
- };
18
- mockWebSocketServer = {
19
- on: vi.fn(),
20
- close: vi.fn(),
21
- };
22
- mockLocalDevProcess = {
23
- addStateListener: vi.fn(),
24
- removeStateListener: vi.fn(),
25
- uploadProject: vi.fn().mockResolvedValue({}),
26
- sendDevServerMessage: vi.fn(),
27
- projectData: {
28
- name: 'test-project',
29
- id: 123,
30
- latestBuild: { id: 'build-1', status: 'SUCCESS' },
31
- deployedBuild: { id: 'build-1', status: 'SUCCESS' },
32
- },
33
- targetProjectAccountId: 456,
34
- targetTestingAccountId: 789,
35
- };
36
- WebSocketServer.mockImplementation(() => mockWebSocketServer);
37
- server = new LocalDevWebsocketServer(mockLocalDevProcess, true);
38
- });
39
- function startServerAndConnect(ws) {
40
- const connectionCallback = mockWebSocketServer.on.mock.calls[0][1];
41
- connectionCallback(ws ?? mockWebSocket, {
42
- headers: { origin: 'https://app.hubspot.com' },
43
- });
44
- }
45
- describe('start()', () => {
46
- beforeEach(async () => {
47
- isPortManagerServerRunning.mockResolvedValue(true);
48
- requestPorts.mockResolvedValue({
49
- 'local-dev-ui-websocket-server': 1234,
50
- });
51
- await server.start();
52
- });
53
- it('should send WEBSOCKET_SERVER_CONNECTED message when valid connection is established', () => {
54
- startServerAndConnect();
55
- expect(mockLocalDevProcess.sendDevServerMessage).toHaveBeenCalledWith(LOCAL_DEV_SERVER_MESSAGE_TYPES.WEBSOCKET_SERVER_CONNECTED);
56
- });
57
- it('should send project data on connection', () => {
58
- startServerAndConnect();
59
- expect(mockWebSocket.send).toHaveBeenCalledWith(JSON.stringify({
60
- type: LOCAL_DEV_UI_MESSAGE_SEND_TYPES.UPDATE_PROJECT_DATA,
61
- data: {
62
- projectName: 'test-project',
63
- projectId: 123,
64
- latestBuild: { id: 'build-1', status: 'SUCCESS' },
65
- deployedBuild: { id: 'build-1', status: 'SUCCESS' },
66
- targetProjectAccountId: 456,
67
- targetTestingAccountId: 789,
68
- },
69
- }));
70
- });
71
- it('should setup state listeners on connection', () => {
72
- startServerAndConnect();
73
- expect(mockLocalDevProcess.addStateListener).toHaveBeenCalledWith('projectNodes', expect.any(Function));
74
- expect(mockLocalDevProcess.addStateListener).toHaveBeenCalledWith('appData', expect.any(Function));
75
- expect(mockLocalDevProcess.addStateListener).toHaveBeenCalledWith('uploadWarnings', expect.any(Function));
76
- expect(mockLocalDevProcess.addStateListener).toHaveBeenCalledWith('devServersStarted', expect.any(Function));
77
- });
78
- });
79
- describe('message handling', () => {
80
- beforeEach(async () => {
81
- isPortManagerServerRunning.mockResolvedValue(true);
82
- requestPorts.mockResolvedValue({
83
- 'local-dev-ui-websocket-server': 1234,
84
- });
85
- await server.start();
86
- startServerAndConnect();
87
- });
88
- it('should handle UPLOAD message type', () => {
89
- const messageCallback = mockWebSocket.on.mock.calls.find(call => call[0] === 'message')[1];
90
- messageCallback(JSON.stringify({ type: LOCAL_DEV_UI_MESSAGE_RECEIVE_TYPES.UPLOAD }));
91
- expect(mockLocalDevProcess.uploadProject).toHaveBeenCalled();
92
- });
93
- });
94
- describe('shutdown()', () => {
95
- it('should close the websocket server', async () => {
96
- isPortManagerServerRunning.mockResolvedValue(true);
97
- requestPorts.mockResolvedValue({
98
- 'local-dev-ui-websocket-server': 1234,
99
- });
100
- await server.start();
101
- server.shutdown();
102
- expect(mockWebSocketServer.close).toHaveBeenCalled();
103
- });
104
- });
105
- describe('multiple connections', () => {
106
- let mockWebSocket1;
107
- let mockWebSocket2;
108
- let mockWebSocket3;
109
- let connectionCallback;
110
- beforeEach(async () => {
111
- mockWebSocket1 = {
112
- on: vi.fn(),
113
- send: vi.fn(),
114
- close: vi.fn(),
115
- };
116
- mockWebSocket2 = {
117
- on: vi.fn(),
118
- send: vi.fn(),
119
- close: vi.fn(),
120
- };
121
- mockWebSocket3 = {
122
- on: vi.fn(),
123
- send: vi.fn(),
124
- close: vi.fn(),
125
- };
126
- isPortManagerServerRunning.mockResolvedValue(true);
127
- requestPorts.mockResolvedValue({
128
- 'local-dev-ui-websocket-server': 1234,
129
- });
130
- await server.start();
131
- connectionCallback = mockWebSocketServer.on.mock.calls[0][1];
132
- });
133
- it('should handle multiple valid connections simultaneously', () => {
134
- connectionCallback(mockWebSocket1, {
135
- headers: { origin: 'https://app.hubspot.com' },
136
- });
137
- connectionCallback(mockWebSocket2, {
138
- headers: { origin: 'https://app-na2.hubspotqa.com' },
139
- });
140
- connectionCallback(mockWebSocket3, {
141
- headers: { origin: 'https://local.hubspot.com' },
142
- });
143
- expect(mockWebSocket1.on).toHaveBeenCalledWith('message', expect.any(Function));
144
- expect(mockWebSocket2.on).toHaveBeenCalledWith('message', expect.any(Function));
145
- expect(mockWebSocket3.on).toHaveBeenCalledWith('message', expect.any(Function));
146
- expect(mockLocalDevProcess.addStateListener).toHaveBeenCalledTimes(12);
147
- expect(mockLocalDevProcess.sendDevServerMessage).toHaveBeenCalledTimes(3);
148
- expect(mockLocalDevProcess.sendDevServerMessage).toHaveBeenCalledWith(LOCAL_DEV_SERVER_MESSAGE_TYPES.WEBSOCKET_SERVER_CONNECTED);
149
- expect(mockWebSocket1.close).not.toHaveBeenCalled();
150
- expect(mockWebSocket2.close).not.toHaveBeenCalled();
151
- expect(mockWebSocket3.close).not.toHaveBeenCalled();
152
- });
153
- it('should send project data to each connection independently', () => {
154
- connectionCallback(mockWebSocket1, {
155
- headers: { origin: 'https://app.hubspot.com' },
156
- });
157
- connectionCallback(mockWebSocket2, {
158
- headers: { origin: 'https://app-eu1.hubspotqa.com' },
159
- });
160
- const expectedProjectData = JSON.stringify({
161
- type: LOCAL_DEV_UI_MESSAGE_SEND_TYPES.UPDATE_PROJECT_DATA,
162
- data: {
163
- projectName: 'test-project',
164
- projectId: 123,
165
- latestBuild: { id: 'build-1', status: 'SUCCESS' },
166
- deployedBuild: { id: 'build-1', status: 'SUCCESS' },
167
- targetProjectAccountId: 456,
168
- targetTestingAccountId: 789,
169
- },
170
- });
171
- expect(mockWebSocket1.send).toHaveBeenCalledWith(expectedProjectData);
172
- expect(mockWebSocket2.send).toHaveBeenCalledWith(expectedProjectData);
173
- });
174
- it('should properly cleanup listeners when connections close', () => {
175
- connectionCallback(mockWebSocket1, {
176
- headers: { origin: 'https://app.hubspot.com' },
177
- });
178
- connectionCallback(mockWebSocket2, {
179
- headers: { origin: 'https://app-ap1.hubspotqa.com' },
180
- });
181
- const closeCallbacks1 = mockWebSocket1.on.mock.calls
182
- .filter(call => call[0] === 'close')
183
- .map(call => call[1]);
184
- const closeCallbacks2 = mockWebSocket2.on.mock.calls
185
- .filter(call => call[0] === 'close')
186
- .map(call => call[1]);
187
- expect(closeCallbacks1).toHaveLength(4);
188
- expect(closeCallbacks2).toHaveLength(4);
189
- closeCallbacks1.forEach(callback => callback());
190
- expect(mockLocalDevProcess.removeStateListener).toHaveBeenCalledTimes(4);
191
- closeCallbacks2.forEach(callback => callback());
192
- expect(mockLocalDevProcess.removeStateListener).toHaveBeenCalledTimes(8);
193
- });
194
- it('should broadcast state changes to all connected clients', () => {
195
- connectionCallback(mockWebSocket1, {
196
- headers: { origin: 'https://app.hubspot.com' },
197
- });
198
- connectionCallback(mockWebSocket2, {
199
- headers: { origin: 'https://local.hubspotqa.com' },
200
- });
201
- const projectNodesListeners = mockLocalDevProcess.addStateListener.mock.calls
202
- .filter(call => call[0] === 'projectNodes')
203
- .map(call => call[1]);
204
- expect(projectNodesListeners).toHaveLength(2);
205
- const mockProjectNodes = {
206
- component1: {
207
- uid: 'component1',
208
- componentType: 'APP',
209
- localDev: {
210
- componentRoot: '/test/path',
211
- componentConfigPath: '/test/path/config.json',
212
- configUpdatedSinceLastUpload: false,
213
- removed: false,
214
- parsingErrors: [],
215
- },
216
- componentDeps: {},
217
- metaFilePath: '/test/path',
218
- config: {},
219
- files: [],
220
- },
221
- };
222
- projectNodesListeners.forEach(listener => listener(mockProjectNodes));
223
- const expectedMessage = JSON.stringify({
224
- type: LOCAL_DEV_UI_MESSAGE_SEND_TYPES.UPDATE_PROJECT_NODES,
225
- data: mockProjectNodes,
226
- });
227
- expect(mockWebSocket1.send).toHaveBeenCalledWith(expectedMessage);
228
- expect(mockWebSocket2.send).toHaveBeenCalledWith(expectedMessage);
229
- });
230
- });
231
- });
@@ -1 +0,0 @@
1
- export {};
@@ -1,302 +0,0 @@
1
- import { ProjectLogsManager } from '../ProjectLogsManager.js';
2
- import { getProjectConfig } from '../config.js';
3
- import { ensureProjectExists } from '../ensureProjectExists.js';
4
- import { fetchProjectComponentsMetadata } from '@hubspot/local-dev-lib/api/projects';
5
- import { fetchAppMetadataBySourceId } from '@hubspot/local-dev-lib/api/appsDev';
6
- import { getDeployedProjectNodes } from '../localDev/helpers/project.js';
7
- import { isV2Project } from '../platformVersion.js';
8
- const SUBCOMPONENT_TYPES = {
9
- APP_ID: 'APP_ID',
10
- PACKAGE_LOCK_FILE: 'PACKAGE_LOCK_FILE',
11
- CRM_CARD_V2: 'CRM_CARD_V2',
12
- CARD_V2: 'CARD_V2',
13
- SERVERLESS_PKG: 'SERVERLESS_PKG',
14
- SERVERLESS_ROUTE: 'SERVERLESS_ROUTE',
15
- SERVERLESS_FUNCTION: 'SERVERLESS_FUNCTION',
16
- APP_FUNCTION: 'APP_FUNCTION',
17
- AUTOMATION_ACTION: 'AUTOMATION_ACTION',
18
- REACT_EXTENSION: 'REACT_EXTENSION',
19
- };
20
- vi.mock('../../projects/config');
21
- vi.mock('../../projects/ensureProjectExists');
22
- vi.mock('@hubspot/local-dev-lib/api/projects');
23
- vi.mock('@hubspot/local-dev-lib/api/appsDev');
24
- vi.mock('../../projects/localDev/helpers/project');
25
- vi.mock('../../projects/platformVersion');
26
- describe('lib/projects/ProjectLogsManager', () => {
27
- const accountId = 12345678;
28
- const appId = 999999;
29
- const projectName = 'super cool test project';
30
- const projectConfig = {
31
- projectConfig: {
32
- name: projectName,
33
- srcDir: 'src',
34
- platformVersion: '2024.1',
35
- },
36
- };
37
- const projectId = 987654321;
38
- const projectDetails = {
39
- project: {
40
- id: projectId,
41
- deployedBuild: {
42
- subbuildStatuses: {},
43
- },
44
- },
45
- };
46
- const function1 = {
47
- componentName: 'function1',
48
- appId,
49
- };
50
- const functions = [
51
- function1,
52
- {
53
- componentName: 'function2',
54
- appId,
55
- },
56
- ];
57
- const legacyApiFunctions = [
58
- {
59
- componentName: 'function1',
60
- type: {
61
- name: SUBCOMPONENT_TYPES.APP_FUNCTION,
62
- },
63
- deployOutput: {
64
- appId,
65
- appFunctionName: 'function1',
66
- },
67
- },
68
- {
69
- componentName: 'function2',
70
- type: {
71
- name: SUBCOMPONENT_TYPES.APP_FUNCTION,
72
- },
73
- deployOutput: {
74
- appId,
75
- appFunctionName: 'function2',
76
- },
77
- },
78
- ];
79
- beforeEach(() => {
80
- ProjectLogsManager.reset();
81
- isV2Project.mockReturnValue(false);
82
- getProjectConfig.mockResolvedValue(projectConfig);
83
- ensureProjectExists.mockResolvedValue(projectDetails);
84
- fetchProjectComponentsMetadata.mockResolvedValue({
85
- data: {
86
- topLevelComponentMetadata: [
87
- {
88
- type: {
89
- name: 'PRIVATE_APP',
90
- },
91
- deployOutput: {
92
- appId,
93
- },
94
- featureComponents: [
95
- ...legacyApiFunctions,
96
- {
97
- type: {
98
- name: 'NOT_AN_APP_FUNCTION',
99
- },
100
- },
101
- ],
102
- },
103
- ],
104
- },
105
- });
106
- });
107
- describe('init', () => {
108
- it('should load the project config', async () => {
109
- await ProjectLogsManager.init(accountId);
110
- expect(getProjectConfig).toHaveBeenCalledTimes(1);
111
- });
112
- it('should throw an error if there is a problem with the config', async () => {
113
- getProjectConfig.mockResolvedValue({});
114
- await expect(async () => ProjectLogsManager.init(accountId)).rejects.toThrow('No project detected. Run this command again from a project directory.');
115
- expect(getProjectConfig).toHaveBeenCalledTimes(1);
116
- });
117
- it('should ensure the project exists', async () => {
118
- await ProjectLogsManager.init(accountId);
119
- expect(ensureProjectExists).toHaveBeenCalledTimes(1);
120
- expect(ensureProjectExists).toHaveBeenCalledWith(accountId, projectName, {
121
- allowCreate: false,
122
- });
123
- });
124
- it('should throw an error if there is data missing from the project details', async () => {
125
- ensureProjectExists.mockResolvedValue({});
126
- await expect(async () => ProjectLogsManager.init(accountId)).rejects.toThrow(/There was an error fetching project details/);
127
- });
128
- it('should set all of the expected fields correctly', async () => {
129
- await ProjectLogsManager.init(accountId);
130
- expect(ProjectLogsManager.projectId).toEqual(projectId);
131
- expect(ProjectLogsManager.projectName).toEqual(projectName);
132
- expect(ProjectLogsManager.accountId).toEqual(accountId);
133
- expect(ProjectLogsManager.functions).toEqual(functions);
134
- });
135
- });
136
- describe('fetchFunctionDetails', () => {
137
- it('should throw an error if the projectId is null when the method is called', async () => {
138
- await expect(async () => ProjectLogsManager.fetchFunctionDetails()).rejects.toThrow('No project detected. Run this command again from a project directory.');
139
- });
140
- it('should fetch the component metadata', async () => {
141
- ProjectLogsManager.projectId = projectId;
142
- ProjectLogsManager.accountId = accountId;
143
- await ProjectLogsManager.fetchFunctionDetails();
144
- expect(fetchProjectComponentsMetadata).toHaveBeenCalledTimes(1);
145
- expect(fetchProjectComponentsMetadata).toHaveBeenCalledWith(accountId, projectId);
146
- });
147
- it('should set the functions correctly', async () => {
148
- ProjectLogsManager.projectId = projectId;
149
- ProjectLogsManager.accountId = accountId;
150
- await ProjectLogsManager.fetchFunctionDetails();
151
- expect(ProjectLogsManager.functions).toEqual(functions);
152
- });
153
- });
154
- describe('v2 project init', () => {
155
- const v2ProjectConfig = {
156
- projectConfig: {
157
- name: projectName,
158
- srcDir: 'src',
159
- platformVersion: '2025.2',
160
- },
161
- };
162
- const deployedBuildId = 555;
163
- const v2ProjectDetails = {
164
- project: {
165
- id: projectId,
166
- deployedBuild: {
167
- buildId: deployedBuildId,
168
- subbuildStatuses: {},
169
- },
170
- },
171
- };
172
- const appUid = 'my-app';
173
- const fnUid1 = 'my-app/app.functions/function1';
174
- const fnUid2 = 'my-app/app.functions/function2';
175
- const deployedNodes = {
176
- [appUid]: {
177
- componentType: 'APPLICATION',
178
- componentDeps: {},
179
- metaFilePath: 'src/app/app-hsmeta.json',
180
- uid: appUid,
181
- config: {},
182
- files: {},
183
- },
184
- [fnUid1]: {
185
- componentType: 'APP_FUNCTION',
186
- componentDeps: { app: appUid },
187
- metaFilePath: 'src/app/app.functions/function1.functions/function-hsmeta.json',
188
- uid: fnUid1,
189
- config: { endpoint: { path: '/my-endpoint' } },
190
- files: {},
191
- },
192
- [fnUid2]: {
193
- componentType: 'APP_FUNCTION',
194
- componentDeps: { app: appUid },
195
- metaFilePath: 'src/app/app.functions/function2.functions/function-hsmeta.json',
196
- uid: fnUid2,
197
- config: {},
198
- files: {},
199
- },
200
- };
201
- beforeEach(() => {
202
- getProjectConfig.mockResolvedValue(v2ProjectConfig);
203
- ensureProjectExists.mockResolvedValue(v2ProjectDetails);
204
- isV2Project.mockReturnValue(true);
205
- getDeployedProjectNodes.mockResolvedValue(deployedNodes);
206
- fetchAppMetadataBySourceId.mockResolvedValue({
207
- data: { id: appId },
208
- });
209
- });
210
- it('should populate functions correctly for v2 projects', async () => {
211
- await ProjectLogsManager.init(accountId);
212
- expect(getDeployedProjectNodes).toHaveBeenCalledWith(v2ProjectConfig.projectConfig, accountId, deployedBuildId);
213
- expect(fetchAppMetadataBySourceId).toHaveBeenCalledWith(projectId, appUid, accountId);
214
- expect(ProjectLogsManager.functions).toEqual([
215
- {
216
- componentName: fnUid1,
217
- appId,
218
- endpoint: { path: '/my-endpoint' },
219
- },
220
- {
221
- componentName: fnUid2,
222
- appId,
223
- endpoint: undefined,
224
- },
225
- ]);
226
- });
227
- it('should throw noDeployedBuild when buildId is missing', async () => {
228
- ensureProjectExists.mockResolvedValue({
229
- project: {
230
- id: projectId,
231
- deployedBuild: {
232
- buildId: undefined,
233
- subbuildStatuses: {},
234
- },
235
- },
236
- });
237
- await expect(async () => ProjectLogsManager.init(accountId)).rejects.toThrow('This project has not been deployed yet. Deploy the project first, then try again.');
238
- });
239
- it('should throw noFunctionsInProject when no function nodes exist', async () => {
240
- getDeployedProjectNodes.mockResolvedValue({
241
- [appUid]: deployedNodes[appUid],
242
- });
243
- await expect(async () => ProjectLogsManager.init(accountId)).rejects.toThrow(/There aren't any functions in this project/);
244
- });
245
- it('should throw a user-friendly error when getDeployedProjectNodes fails', async () => {
246
- getDeployedProjectNodes.mockRejectedValue(new Error('download failed'));
247
- await expect(async () => ProjectLogsManager.init(accountId)).rejects.toThrow(/There was an error fetching project details/);
248
- });
249
- });
250
- describe('getFunctionNames', () => {
251
- it('should return an empty array if functions is empty', async () => {
252
- ProjectLogsManager.functions = [];
253
- expect(ProjectLogsManager.getFunctionNames()).toEqual([]);
254
- });
255
- it('should return an array of the componentNames', async () => {
256
- ProjectLogsManager.functions = functions;
257
- expect(ProjectLogsManager.getFunctionNames()).toEqual([
258
- 'function1',
259
- 'function2',
260
- ]);
261
- });
262
- });
263
- describe('setFunction', () => {
264
- it('should throw an error when functions is empty', async () => {
265
- ProjectLogsManager.functions = [];
266
- expect(() => ProjectLogsManager.setFunction('foo')).toThrow(`There aren't any functions in this project`);
267
- });
268
- it('should throw an error when the provided function is invalid', async () => {
269
- ProjectLogsManager.functions = functions;
270
- const badName = 'foo';
271
- expect(() => ProjectLogsManager.setFunction(badName)).toThrow(`No function with name "${badName}"`);
272
- });
273
- it('should set the data correctly for public functions', async () => {
274
- const functionToChoose = {
275
- componentName: 'function1',
276
- appId: 123,
277
- endpoint: { path: 'yooooooo' },
278
- };
279
- ProjectLogsManager.functions = [functionToChoose];
280
- ProjectLogsManager.setFunction('function1');
281
- expect(ProjectLogsManager.functionName).toEqual('function1');
282
- expect(ProjectLogsManager.endpointName).toEqual('yooooooo');
283
- expect(ProjectLogsManager.selectedFunction).toEqual(functionToChoose);
284
- expect(ProjectLogsManager.isPublicFunction).toEqual(true);
285
- });
286
- it('should set the data correctly for private functions', async () => {
287
- ProjectLogsManager.functions = functions;
288
- ProjectLogsManager.setFunction('function1');
289
- expect(ProjectLogsManager.selectedFunction).toEqual(function1);
290
- expect(ProjectLogsManager.functionName).toEqual('function1');
291
- expect(ProjectLogsManager.isPublicFunction).toEqual(false);
292
- });
293
- });
294
- describe('reset', () => {
295
- it('should reset all the values', async () => {
296
- ProjectLogsManager.projectName = 'value';
297
- expect(ProjectLogsManager.projectName).toBeDefined();
298
- ProjectLogsManager.reset();
299
- expect(ProjectLogsManager.projectName).toBeUndefined();
300
- });
301
- });
302
- });