@hubspot/cli 8.1.0 → 8.1.1-experimental.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 (676) hide show
  1. package/api/migrate.js +8 -4
  2. package/bin/cli.js +12 -6
  3. package/commands/account/auth.js +7 -7
  4. package/commands/account/clean.js +7 -6
  5. package/commands/account/createOverride.js +10 -7
  6. package/commands/account/info.js +36 -17
  7. package/commands/account/link.d.ts +4 -0
  8. package/commands/account/link.js +89 -0
  9. package/commands/account/list.js +32 -76
  10. package/commands/account/remove.js +4 -3
  11. package/commands/account/removeOverride.js +11 -10
  12. package/commands/account/rename.js +5 -6
  13. package/commands/account/unlink.d.ts +4 -0
  14. package/commands/account/unlink.js +70 -0
  15. package/commands/account/use.js +75 -6
  16. package/commands/account.js +4 -0
  17. package/commands/api.d.ts +10 -0
  18. package/commands/api.js +164 -0
  19. package/commands/app/migrate.js +13 -13
  20. package/commands/app/secret/add.js +6 -7
  21. package/commands/app/secret/delete.js +9 -10
  22. package/commands/app/secret/list.js +6 -7
  23. package/commands/app/secret/update.js +8 -9
  24. package/commands/auth.js +19 -15
  25. package/commands/cms/app/create.js +9 -5
  26. package/commands/cms/convertFields.js +8 -8
  27. package/commands/cms/delete.js +2 -3
  28. package/commands/cms/fetch.js +7 -7
  29. package/commands/cms/function/create.js +9 -5
  30. package/commands/cms/function/deploy.js +2 -3
  31. package/commands/cms/function/list.js +11 -7
  32. package/commands/cms/function/logs.js +17 -22
  33. package/commands/cms/function/server.js +2 -3
  34. package/commands/cms/getReactModule.js +7 -8
  35. package/commands/cms/lighthouseScore.js +25 -24
  36. package/commands/cms/lint.js +4 -5
  37. package/commands/cms/list.js +5 -6
  38. package/commands/cms/module/create.js +9 -5
  39. package/commands/cms/module/marketplace-validate.js +7 -8
  40. package/commands/cms/mv.js +2 -3
  41. package/commands/cms/template/create.js +10 -6
  42. package/commands/cms/theme/create.js +5 -5
  43. package/commands/cms/theme/generate-selectors.js +5 -4
  44. package/commands/cms/theme/marketplace-validate.js +8 -9
  45. package/commands/cms/theme/preview.js +23 -70
  46. package/commands/cms/upload.js +15 -12
  47. package/commands/cms/watch.d.ts +0 -1
  48. package/commands/cms/watch.js +6 -12
  49. package/commands/cms/webpack/create.js +5 -5
  50. package/commands/completion.js +3 -5
  51. package/commands/config/migrate.js +6 -7
  52. package/commands/config/set.js +5 -6
  53. package/commands/customObject/create.js +4 -5
  54. package/commands/customObject/createSchema.js +4 -5
  55. package/commands/customObject/deleteSchema.js +4 -5
  56. package/commands/customObject/fetchAllSchemas.js +2 -3
  57. package/commands/customObject/fetchSchema.js +2 -3
  58. package/commands/customObject/listSchemas.js +2 -3
  59. package/commands/customObject/updateSchema.js +4 -5
  60. package/commands/doctor.js +8 -8
  61. package/commands/feedback.js +7 -5
  62. package/commands/filemanager/fetch.js +5 -6
  63. package/commands/filemanager/upload.js +5 -5
  64. package/commands/getStarted.js +17 -19
  65. package/commands/hubdb/clear.js +6 -3
  66. package/commands/hubdb/create.js +4 -5
  67. package/commands/hubdb/delete.js +9 -6
  68. package/commands/hubdb/fetch.js +6 -3
  69. package/commands/hubdb/list.js +16 -14
  70. package/commands/init.js +15 -14
  71. package/commands/mcp/setup.js +5 -14
  72. package/commands/mcp/start.js +2 -4
  73. package/commands/open.js +4 -5
  74. package/commands/project/add.js +13 -8
  75. package/commands/project/appInstallStatus.d.ts +4 -0
  76. package/commands/project/appInstallStatus.js +132 -0
  77. package/commands/project/create.js +28 -17
  78. package/commands/project/delete.d.ts +7 -0
  79. package/commands/project/delete.js +74 -0
  80. package/commands/project/deploy.js +39 -36
  81. package/commands/project/dev/deprecatedFlow.js +62 -17
  82. package/commands/project/dev/index.d.ts +3 -3
  83. package/commands/project/dev/index.js +59 -48
  84. package/commands/project/dev/unifiedFlow.js +70 -21
  85. package/commands/project/download.js +12 -9
  86. package/commands/project/info.d.ts +4 -0
  87. package/commands/project/info.js +67 -0
  88. package/commands/project/installDeps.js +9 -6
  89. package/commands/project/lint.js +31 -10
  90. package/commands/project/list.d.ts +2 -2
  91. package/commands/project/list.js +15 -14
  92. package/commands/project/listBuilds.js +8 -6
  93. package/commands/project/logs.js +5 -6
  94. package/commands/project/migrate.js +18 -18
  95. package/commands/project/open.js +5 -6
  96. package/commands/project/profile/add.js +12 -8
  97. package/commands/project/profile/delete.js +15 -11
  98. package/commands/project/updateDeps.js +9 -6
  99. package/commands/project/upload.d.ts +1 -0
  100. package/commands/project/upload.js +39 -19
  101. package/commands/project/validate.js +12 -12
  102. package/commands/project/watch.js +32 -19
  103. package/commands/project.js +12 -3
  104. package/commands/sandbox/create.js +18 -45
  105. package/commands/sandbox/delete.js +13 -14
  106. package/commands/secret/addSecret.js +6 -7
  107. package/commands/secret/deleteSecret.js +5 -6
  108. package/commands/secret/listSecret.js +2 -3
  109. package/commands/secret/updateSecret.js +4 -5
  110. package/commands/testAccount/create.d.ts +1 -1
  111. package/commands/testAccount/create.js +25 -17
  112. package/commands/testAccount/createConfig.js +7 -8
  113. package/commands/testAccount/delete.js +27 -18
  114. package/commands/testAccount/importData.js +6 -7
  115. package/commands/upgrade.js +9 -10
  116. package/lang/en.d.ts +258 -14
  117. package/lang/en.js +275 -28
  118. package/lib/accountAuth.js +4 -0
  119. package/lib/api/usageTracking.d.ts +29 -0
  120. package/lib/api/usageTracking.js +28 -0
  121. package/lib/app/migrate.js +18 -5
  122. package/lib/buildAccount.d.ts +1 -6
  123. package/lib/buildAccount.js +9 -42
  124. package/lib/commandSuggestion.js +1 -7
  125. package/lib/constants.d.ts +2 -4
  126. package/lib/constants.js +4 -4
  127. package/lib/doctor/Diagnosis.js +5 -5
  128. package/lib/doctor/Doctor.js +7 -7
  129. package/lib/errorHandlers/index.js +4 -3
  130. package/lib/errorHandlers/suppressError.js +4 -0
  131. package/lib/errors/PromptExitError.d.ts +6 -0
  132. package/lib/errors/PromptExitError.js +11 -0
  133. package/lib/generateSelectors.js +1 -2
  134. package/lib/getStartedV2Actions.d.ts +13 -0
  135. package/lib/getStartedV2Actions.js +56 -3
  136. package/lib/hasFeature.js +1 -2
  137. package/lib/link/accountTableUtils.d.ts +10 -0
  138. package/lib/link/accountTableUtils.js +39 -0
  139. package/lib/link/index.d.ts +18 -0
  140. package/lib/link/index.js +185 -0
  141. package/lib/link/linkUtils.d.ts +5 -0
  142. package/lib/link/linkUtils.js +49 -0
  143. package/lib/link/prompts.d.ts +7 -0
  144. package/lib/link/prompts.js +126 -0
  145. package/lib/link/renderLinkedAccountsTable.d.ts +2 -0
  146. package/lib/link/renderLinkedAccountsTable.js +14 -0
  147. package/lib/link/warnIfLinkedDirectory.d.ts +1 -0
  148. package/lib/link/warnIfLinkedDirectory.js +9 -0
  149. package/lib/mcp/setup.d.ts +1 -0
  150. package/lib/mcp/setup.js +77 -30
  151. package/lib/middleware/autoUpdateMiddleware.js +6 -3
  152. package/lib/process.d.ts +1 -1
  153. package/lib/process.js +10 -3
  154. package/lib/projects/ProjectLogsManager.js +6 -3
  155. package/lib/projects/components.js +15 -4
  156. package/lib/projects/create/index.js +3 -6
  157. package/lib/projects/create/legacy.js +5 -10
  158. package/lib/projects/create/v2.js +5 -14
  159. package/lib/projects/delete.d.ts +13 -0
  160. package/lib/projects/delete.js +193 -0
  161. package/lib/projects/deploy.d.ts +1 -1
  162. package/lib/projects/deploy.js +2 -2
  163. package/lib/projects/ensureProjectExists.js +1 -2
  164. package/lib/projects/localDev/AppDevModeInterface.js +13 -9
  165. package/lib/projects/localDev/DevServerManager_DEPRECATED.d.ts +4 -1
  166. package/lib/projects/localDev/DevServerManager_DEPRECATED.js +3 -3
  167. package/lib/projects/localDev/DevSessionManager.d.ts +6 -3
  168. package/lib/projects/localDev/DevSessionManager.js +31 -19
  169. package/lib/projects/localDev/LocalDevManager_DEPRECATED.d.ts +5 -0
  170. package/lib/projects/localDev/LocalDevManager_DEPRECATED.js +21 -10
  171. package/lib/projects/localDev/LocalDevProcess.js +6 -5
  172. package/lib/projects/localDev/LocalDevState.d.ts +3 -2
  173. package/lib/projects/localDev/LocalDevState.js +3 -1
  174. package/lib/projects/localDev/helpers/account.d.ts +4 -3
  175. package/lib/projects/localDev/helpers/account.js +21 -30
  176. package/lib/projects/localDev/helpers/process.d.ts +1 -1
  177. package/lib/projects/localDev/helpers/process.js +4 -10
  178. package/lib/projects/localDev/helpers/project.d.ts +4 -3
  179. package/lib/projects/localDev/helpers/project.js +31 -15
  180. package/lib/projects/npmAuditOnUpload.d.ts +10 -0
  181. package/lib/projects/npmAuditOnUpload.js +73 -0
  182. package/lib/projects/pollProjectBuildAndDeploy.js +90 -85
  183. package/lib/projects/projectInfo.d.ts +5 -0
  184. package/lib/projects/projectInfo.js +82 -0
  185. package/lib/projects/projectProfiles.d.ts +1 -2
  186. package/lib/projects/projectProfiles.js +5 -17
  187. package/lib/projects/uieLinting.d.ts +17 -3
  188. package/lib/projects/uieLinting.js +93 -28
  189. package/lib/projects/upload.d.ts +3 -1
  190. package/lib/projects/upload.js +70 -50
  191. package/lib/projects/watch.d.ts +2 -1
  192. package/lib/projects/watch.js +32 -24
  193. package/lib/projects/workspaces.d.ts +42 -0
  194. package/lib/projects/workspaces.js +350 -0
  195. package/lib/prompts/createApiSamplePrompt.js +4 -0
  196. package/lib/prompts/downloadProjectPrompt.js +11 -10
  197. package/lib/prompts/installAppPrompt.js +3 -2
  198. package/lib/prompts/personalAccessKeyPrompt.js +3 -2
  199. package/lib/prompts/projectDevTargetAccountPrompt.d.ts +1 -0
  200. package/lib/prompts/projectDevTargetAccountPrompt.js +23 -16
  201. package/lib/prompts/projectProfilePrompt.d.ts +2 -0
  202. package/lib/prompts/projectProfilePrompt.js +46 -0
  203. package/lib/prompts/projectsLogsPrompt.js +3 -0
  204. package/lib/prompts/promptUtils.js +4 -2
  205. package/lib/prompts/selectHubDBTablePrompt.js +8 -4
  206. package/lib/prompts/selectPublicAppForMigrationPrompt.js +12 -6
  207. package/lib/sandboxes.d.ts +1 -9
  208. package/lib/sandboxes.js +0 -21
  209. package/lib/serverlessLogs.js +50 -44
  210. package/lib/theme/cmsDevServerProcess.d.ts +14 -0
  211. package/lib/theme/cmsDevServerProcess.js +149 -0
  212. package/lib/theme/cmsDevServerRunner.d.ts +14 -0
  213. package/lib/theme/cmsDevServerRunner.js +90 -0
  214. package/lib/theme/migrate.d.ts +1 -1
  215. package/lib/theme/migrate.js +1 -5
  216. package/lib/ui/SpinniesManager.d.ts +1 -0
  217. package/lib/ui/SpinniesManager.js +22 -6
  218. package/lib/ui/accountTable.d.ts +8 -0
  219. package/lib/ui/accountTable.js +67 -0
  220. package/lib/ui/spinniesUtils.d.ts +0 -1
  221. package/lib/ui/spinniesUtils.js +6 -16
  222. package/lib/usageTracking.d.ts +9 -20
  223. package/lib/usageTracking.js +51 -34
  224. package/lib/yargs/makeYargsBuilder.d.ts +13 -0
  225. package/lib/yargs/makeYargsBuilder.js +33 -0
  226. package/lib/yargs/makeYargsHandlerWithUsageTracking.d.ts +3 -0
  227. package/lib/yargs/makeYargsHandlerWithUsageTracking.js +121 -0
  228. package/lib/yargs/parseYargsOrExit.d.ts +4 -0
  229. package/lib/yargs/parseYargsOrExit.js +25 -0
  230. package/lib/yargs/strictEnforceBoolean.d.ts +1 -0
  231. package/lib/yargs/strictEnforceBoolean.js +13 -0
  232. package/lib/yargsUtils.d.ts +3 -16
  233. package/lib/yargsUtils.js +3 -48
  234. package/mcp-server/Tool.d.ts +15 -0
  235. package/mcp-server/Tool.js +53 -0
  236. package/mcp-server/server.js +43 -3
  237. package/mcp-server/tools/cms/HsCreateFunctionTool.d.ts +4 -2
  238. package/mcp-server/tools/cms/HsCreateFunctionTool.js +9 -7
  239. package/mcp-server/tools/cms/HsCreateModuleTool.d.ts +4 -2
  240. package/mcp-server/tools/cms/HsCreateModuleTool.js +9 -7
  241. package/mcp-server/tools/cms/HsCreateTemplateTool.d.ts +4 -2
  242. package/mcp-server/tools/cms/HsCreateTemplateTool.js +9 -7
  243. package/mcp-server/tools/cms/HsFunctionLogsTool.d.ts +4 -2
  244. package/mcp-server/tools/cms/HsFunctionLogsTool.js +9 -7
  245. package/mcp-server/tools/cms/HsListFunctionsTool.d.ts +4 -2
  246. package/mcp-server/tools/cms/HsListFunctionsTool.js +9 -7
  247. package/mcp-server/tools/cms/HsListTool.d.ts +4 -2
  248. package/mcp-server/tools/cms/HsListTool.js +9 -7
  249. package/mcp-server/tools/index.d.ts +3 -2
  250. package/mcp-server/tools/index.js +24 -22
  251. package/mcp-server/tools/project/AddFeatureToProjectTool.d.ts +25 -5
  252. package/mcp-server/tools/project/AddFeatureToProjectTool.js +16 -18
  253. package/mcp-server/tools/project/CreateProjectTool.d.ts +29 -6
  254. package/mcp-server/tools/project/CreateProjectTool.js +16 -18
  255. package/mcp-server/tools/project/CreateTestAccountTool.d.ts +4 -2
  256. package/mcp-server/tools/project/CreateTestAccountTool.js +22 -10
  257. package/mcp-server/tools/project/DeployProjectTool.d.ts +4 -2
  258. package/mcp-server/tools/project/DeployProjectTool.js +6 -8
  259. package/mcp-server/tools/project/DocFetchTool.d.ts +4 -2
  260. package/mcp-server/tools/project/DocFetchTool.js +8 -6
  261. package/mcp-server/tools/project/DocsSearchTool.d.ts +9 -3
  262. package/mcp-server/tools/project/DocsSearchTool.js +32 -9
  263. package/mcp-server/tools/project/FindProjectsTool.d.ts +15 -0
  264. package/mcp-server/tools/project/FindProjectsTool.js +60 -0
  265. package/mcp-server/tools/project/GetApiUsagePatternsByAppIdTool.d.ts +4 -2
  266. package/mcp-server/tools/project/GetApiUsagePatternsByAppIdTool.js +13 -14
  267. package/mcp-server/tools/project/GetApplicationInfoTool.d.ts +4 -2
  268. package/mcp-server/tools/project/GetApplicationInfoTool.js +8 -6
  269. package/mcp-server/tools/project/GetBuildLogsTool.d.ts +6 -4
  270. package/mcp-server/tools/project/GetBuildLogsTool.js +15 -14
  271. package/mcp-server/tools/project/GetBuildStatusTool.d.ts +5 -3
  272. package/mcp-server/tools/project/GetBuildStatusTool.js +12 -11
  273. package/mcp-server/tools/project/GetConfigValuesTool.d.ts +4 -2
  274. package/mcp-server/tools/project/GetConfigValuesTool.js +12 -7
  275. package/mcp-server/tools/project/GuidedWalkthroughTool.d.ts +10 -3
  276. package/mcp-server/tools/project/GuidedWalkthroughTool.js +5 -12
  277. package/mcp-server/tools/project/UploadProjectTools.d.ts +4 -2
  278. package/mcp-server/tools/project/UploadProjectTools.js +11 -9
  279. package/mcp-server/tools/project/ValidateProjectTool.d.ts +4 -2
  280. package/mcp-server/tools/project/ValidateProjectTool.js +10 -8
  281. package/mcp-server/tools/project/constants.d.ts +13 -1
  282. package/mcp-server/tools/project/constants.js +13 -16
  283. package/mcp-server/types.d.ts +0 -7
  284. package/mcp-server/types.js +1 -13
  285. package/mcp-server/utils/command.d.ts +5 -0
  286. package/mcp-server/utils/command.js +24 -0
  287. package/mcp-server/utils/feedbackTracking.js +2 -17
  288. package/mcp-server/utils/logger.d.ts +10 -0
  289. package/mcp-server/utils/logger.js +29 -0
  290. package/mcp-server/utils/toolUsageTracking.js +10 -8
  291. package/package.json +15 -11
  292. package/types/Link.d.ts +32 -0
  293. package/types/Link.js +5 -0
  294. package/types/LocalDev.d.ts +5 -0
  295. package/types/PackageJson.d.ts +1 -0
  296. package/types/Projects.d.ts +19 -0
  297. package/types/Prompts.d.ts +1 -0
  298. package/types/Yargs.d.ts +19 -1
  299. package/ui/components/getStarted/GetStartedFlow.js +79 -2
  300. package/ui/components/getStarted/reducer.d.ts +20 -0
  301. package/ui/components/getStarted/reducer.js +36 -0
  302. package/ui/components/getStarted/screens/InstallationScreen.d.ts +7 -0
  303. package/ui/components/getStarted/screens/InstallationScreen.js +16 -0
  304. package/ui/components/getStarted/screens/ProjectSetupScreen.js +2 -1
  305. package/ui/lib/constants.d.ts +1 -0
  306. package/ui/lib/constants.js +1 -0
  307. package/api/__tests__/migrate.test.d.ts +0 -1
  308. package/api/__tests__/migrate.test.js +0 -199
  309. package/commands/__tests__/account.test.d.ts +0 -1
  310. package/commands/__tests__/account.test.js +0 -69
  311. package/commands/__tests__/auth.test.d.ts +0 -1
  312. package/commands/__tests__/auth.test.js +0 -43
  313. package/commands/__tests__/cms.test.d.ts +0 -1
  314. package/commands/__tests__/cms.test.js +0 -87
  315. package/commands/__tests__/config.test.d.ts +0 -1
  316. package/commands/__tests__/config.test.js +0 -44
  317. package/commands/__tests__/customObject.test.d.ts +0 -1
  318. package/commands/__tests__/customObject.test.js +0 -68
  319. package/commands/__tests__/doctor.test.d.ts +0 -1
  320. package/commands/__tests__/doctor.test.js +0 -132
  321. package/commands/__tests__/feedback.test.d.ts +0 -1
  322. package/commands/__tests__/feedback.test.js +0 -24
  323. package/commands/__tests__/filemanager.test.d.ts +0 -1
  324. package/commands/__tests__/filemanager.test.js +0 -45
  325. package/commands/__tests__/getStarted.test.d.ts +0 -1
  326. package/commands/__tests__/getStarted.test.js +0 -173
  327. package/commands/__tests__/hubdb.test.d.ts +0 -1
  328. package/commands/__tests__/hubdb.test.js +0 -50
  329. package/commands/__tests__/init.test.d.ts +0 -1
  330. package/commands/__tests__/init.test.js +0 -42
  331. package/commands/__tests__/mcp.test.d.ts +0 -1
  332. package/commands/__tests__/mcp.test.js +0 -46
  333. package/commands/__tests__/open.test.d.ts +0 -1
  334. package/commands/__tests__/open.test.js +0 -58
  335. package/commands/__tests__/project.test.d.ts +0 -1
  336. package/commands/__tests__/project.test.js +0 -125
  337. package/commands/__tests__/sandbox.test.d.ts +0 -1
  338. package/commands/__tests__/sandbox.test.js +0 -44
  339. package/commands/__tests__/secret.test.d.ts +0 -1
  340. package/commands/__tests__/secret.test.js +0 -49
  341. package/commands/__tests__/testAccount.test.d.ts +0 -1
  342. package/commands/__tests__/testAccount.test.js +0 -57
  343. package/commands/__tests__/upgrade.test.d.ts +0 -1
  344. package/commands/__tests__/upgrade.test.js +0 -309
  345. package/commands/account/__tests__/auth.test.d.ts +0 -1
  346. package/commands/account/__tests__/auth.test.js +0 -206
  347. package/commands/account/__tests__/clean.test.d.ts +0 -1
  348. package/commands/account/__tests__/clean.test.js +0 -28
  349. package/commands/account/__tests__/createOverride.test.d.ts +0 -1
  350. package/commands/account/__tests__/createOverride.test.js +0 -32
  351. package/commands/account/__tests__/info.test.d.ts +0 -1
  352. package/commands/account/__tests__/info.test.js +0 -28
  353. package/commands/account/__tests__/list.test.d.ts +0 -1
  354. package/commands/account/__tests__/list.test.js +0 -153
  355. package/commands/account/__tests__/remove.test.d.ts +0 -1
  356. package/commands/account/__tests__/remove.test.js +0 -36
  357. package/commands/account/__tests__/removeOverride.d.ts +0 -1
  358. package/commands/account/__tests__/removeOverride.js +0 -25
  359. package/commands/account/__tests__/rename.test.d.ts +0 -1
  360. package/commands/account/__tests__/rename.test.js +0 -82
  361. package/commands/account/__tests__/use.test.d.ts +0 -1
  362. package/commands/account/__tests__/use.test.js +0 -170
  363. package/commands/app/__tests__/migrate.test.d.ts +0 -1
  364. package/commands/app/__tests__/migrate.test.js +0 -111
  365. package/commands/app/secret/__tests__/add.test.d.ts +0 -1
  366. package/commands/app/secret/__tests__/add.test.js +0 -140
  367. package/commands/app/secret/__tests__/delete.test.d.ts +0 -1
  368. package/commands/app/secret/__tests__/delete.test.js +0 -28
  369. package/commands/app/secret/__tests__/list.test.d.ts +0 -1
  370. package/commands/app/secret/__tests__/list.test.js +0 -25
  371. package/commands/app/secret/__tests__/update.test.d.ts +0 -1
  372. package/commands/app/secret/__tests__/update.test.js +0 -28
  373. package/commands/cms/__tests__/delete.test.d.ts +0 -1
  374. package/commands/cms/__tests__/delete.test.js +0 -39
  375. package/commands/cms/__tests__/fetch.test.d.ts +0 -1
  376. package/commands/cms/__tests__/fetch.test.js +0 -156
  377. package/commands/cms/__tests__/function.test.d.ts +0 -1
  378. package/commands/cms/__tests__/function.test.js +0 -50
  379. package/commands/cms/__tests__/lint.test.d.ts +0 -1
  380. package/commands/cms/__tests__/lint.test.js +0 -33
  381. package/commands/cms/__tests__/list.test.d.ts +0 -1
  382. package/commands/cms/__tests__/list.test.js +0 -42
  383. package/commands/cms/__tests__/module.test.d.ts +0 -1
  384. package/commands/cms/__tests__/module.test.js +0 -45
  385. package/commands/cms/__tests__/mv.test.d.ts +0 -1
  386. package/commands/cms/__tests__/mv.test.js +0 -46
  387. package/commands/cms/__tests__/theme.test.d.ts +0 -1
  388. package/commands/cms/__tests__/theme.test.js +0 -54
  389. package/commands/cms/__tests__/upload.test.d.ts +0 -1
  390. package/commands/cms/__tests__/upload.test.js +0 -308
  391. package/commands/cms/__tests__/watch.test.d.ts +0 -1
  392. package/commands/cms/__tests__/watch.test.js +0 -212
  393. package/commands/cms/function/__tests__/logs.test.d.ts +0 -1
  394. package/commands/cms/function/__tests__/logs.test.js +0 -70
  395. package/commands/cms/theme/__tests__/generate-selectors.test.d.ts +0 -1
  396. package/commands/cms/theme/__tests__/generate-selectors.test.js +0 -28
  397. package/commands/cms/theme/__tests__/marketplace-validate.test.d.ts +0 -1
  398. package/commands/cms/theme/__tests__/marketplace-validate.test.js +0 -36
  399. package/commands/cms/theme/__tests__/preview.test.d.ts +0 -1
  400. package/commands/cms/theme/__tests__/preview.test.js +0 -54
  401. package/commands/customObject/__tests__/create.test.d.ts +0 -1
  402. package/commands/customObject/__tests__/create.test.js +0 -40
  403. package/commands/customObject/__tests__/createSchema.test.d.ts +0 -1
  404. package/commands/customObject/__tests__/createSchema.test.js +0 -28
  405. package/commands/customObject/__tests__/deleteSchema.test.d.ts +0 -1
  406. package/commands/customObject/__tests__/deleteSchema.test.js +0 -42
  407. package/commands/customObject/__tests__/fetch-all-schemas.test.d.ts +0 -1
  408. package/commands/customObject/__tests__/fetch-all-schemas.test.js +0 -41
  409. package/commands/customObject/__tests__/fetchSchema.test.d.ts +0 -1
  410. package/commands/customObject/__tests__/fetchSchema.test.js +0 -45
  411. package/commands/customObject/__tests__/listSchemas.test.d.ts +0 -1
  412. package/commands/customObject/__tests__/listSchemas.test.js +0 -29
  413. package/commands/customObject/__tests__/updateSchema.test.d.ts +0 -1
  414. package/commands/customObject/__tests__/updateSchema.test.js +0 -40
  415. package/commands/filemanager/__tests__/fetch.test.d.ts +0 -1
  416. package/commands/filemanager/__tests__/fetch.test.js +0 -32
  417. package/commands/filemanager/__tests__/upload.test.d.ts +0 -1
  418. package/commands/filemanager/__tests__/upload.test.js +0 -191
  419. package/commands/hubdb/__tests__/clear.test.d.ts +0 -1
  420. package/commands/hubdb/__tests__/clear.test.js +0 -28
  421. package/commands/hubdb/__tests__/create.test.d.ts +0 -1
  422. package/commands/hubdb/__tests__/create.test.js +0 -28
  423. package/commands/hubdb/__tests__/delete.test.d.ts +0 -1
  424. package/commands/hubdb/__tests__/delete.test.js +0 -28
  425. package/commands/hubdb/__tests__/fetch.test.d.ts +0 -1
  426. package/commands/hubdb/__tests__/fetch.test.js +0 -28
  427. package/commands/hubdb/__tests__/list.test.d.ts +0 -1
  428. package/commands/hubdb/__tests__/list.test.js +0 -88
  429. package/commands/mcp/__tests__/setup.test.d.ts +0 -1
  430. package/commands/mcp/__tests__/setup.test.js +0 -26
  431. package/commands/mcp/__tests__/start.test.d.ts +0 -1
  432. package/commands/mcp/__tests__/start.test.js +0 -137
  433. package/commands/project/__tests__/add.test.d.ts +0 -1
  434. package/commands/project/__tests__/add.test.js +0 -107
  435. package/commands/project/__tests__/create.test.d.ts +0 -1
  436. package/commands/project/__tests__/create.test.js +0 -97
  437. package/commands/project/__tests__/deploy.test.d.ts +0 -1
  438. package/commands/project/__tests__/deploy.test.js +0 -307
  439. package/commands/project/__tests__/dev.test.d.ts +0 -1
  440. package/commands/project/__tests__/dev.test.js +0 -273
  441. package/commands/project/__tests__/devUnifiedFlow.test.d.ts +0 -1
  442. package/commands/project/__tests__/devUnifiedFlow.test.js +0 -434
  443. package/commands/project/__tests__/download.test.d.ts +0 -1
  444. package/commands/project/__tests__/download.test.js +0 -39
  445. package/commands/project/__tests__/installDeps.test.d.ts +0 -1
  446. package/commands/project/__tests__/installDeps.test.js +0 -140
  447. package/commands/project/__tests__/lint.test.d.ts +0 -1
  448. package/commands/project/__tests__/lint.test.js +0 -704
  449. package/commands/project/__tests__/list.test.d.ts +0 -1
  450. package/commands/project/__tests__/list.test.js +0 -31
  451. package/commands/project/__tests__/listBuilds.test.d.ts +0 -1
  452. package/commands/project/__tests__/listBuilds.test.js +0 -38
  453. package/commands/project/__tests__/logs.test.d.ts +0 -1
  454. package/commands/project/__tests__/logs.test.js +0 -202
  455. package/commands/project/__tests__/migrate.test.d.ts +0 -1
  456. package/commands/project/__tests__/migrate.test.js +0 -106
  457. package/commands/project/__tests__/open.test.d.ts +0 -1
  458. package/commands/project/__tests__/open.test.js +0 -39
  459. package/commands/project/__tests__/profile.test.d.ts +0 -1
  460. package/commands/project/__tests__/profile.test.js +0 -42
  461. package/commands/project/__tests__/updateDeps.test.d.ts +0 -1
  462. package/commands/project/__tests__/updateDeps.test.js +0 -140
  463. package/commands/project/__tests__/upload.test.d.ts +0 -1
  464. package/commands/project/__tests__/upload.test.js +0 -234
  465. package/commands/project/__tests__/validate.test.d.ts +0 -1
  466. package/commands/project/__tests__/validate.test.js +0 -381
  467. package/commands/project/__tests__/watch.test.d.ts +0 -1
  468. package/commands/project/__tests__/watch.test.js +0 -35
  469. package/commands/sandbox/__tests__/create.test.d.ts +0 -1
  470. package/commands/sandbox/__tests__/create.test.js +0 -245
  471. package/commands/sandbox/__tests__/delete.test.d.ts +0 -1
  472. package/commands/sandbox/__tests__/delete.test.js +0 -31
  473. package/commands/secret/__tests__/addSecret.test.d.ts +0 -1
  474. package/commands/secret/__tests__/addSecret.test.js +0 -162
  475. package/commands/secret/__tests__/deleteSecret.test.d.ts +0 -1
  476. package/commands/secret/__tests__/deleteSecret.test.js +0 -41
  477. package/commands/secret/__tests__/listSecret.test.d.ts +0 -1
  478. package/commands/secret/__tests__/listSecret.test.js +0 -29
  479. package/commands/secret/__tests__/updateSecret.test.d.ts +0 -1
  480. package/commands/secret/__tests__/updateSecret.test.js +0 -29
  481. package/commands/testAccount/__tests__/create.test.d.ts +0 -1
  482. package/commands/testAccount/__tests__/create.test.js +0 -106
  483. package/commands/testAccount/__tests__/createConfig.test.d.ts +0 -1
  484. package/commands/testAccount/__tests__/createConfig.test.js +0 -32
  485. package/commands/testAccount/__tests__/delete.test.d.ts +0 -1
  486. package/commands/testAccount/__tests__/delete.test.js +0 -29
  487. package/commands/testAccount/__tests__/importData.test.d.ts +0 -1
  488. package/commands/testAccount/__tests__/importData.test.js +0 -92
  489. package/lib/__tests__/CLIWebSocketServer.test.d.ts +0 -1
  490. package/lib/__tests__/CLIWebSocketServer.test.js +0 -252
  491. package/lib/__tests__/accountAuth.test.d.ts +0 -1
  492. package/lib/__tests__/accountAuth.test.js +0 -258
  493. package/lib/__tests__/accountTypes.test.d.ts +0 -1
  494. package/lib/__tests__/accountTypes.test.js +0 -98
  495. package/lib/__tests__/buildAccount.test.d.ts +0 -1
  496. package/lib/__tests__/buildAccount.test.js +0 -262
  497. package/lib/__tests__/cliUpgradeUtils.test.d.ts +0 -1
  498. package/lib/__tests__/cliUpgradeUtils.test.js +0 -131
  499. package/lib/__tests__/commandSuggestion.test.d.ts +0 -1
  500. package/lib/__tests__/commandSuggestion.test.js +0 -119
  501. package/lib/__tests__/commonOpts.test.d.ts +0 -1
  502. package/lib/__tests__/commonOpts.test.js +0 -80
  503. package/lib/__tests__/dependencyManagement.test.d.ts +0 -1
  504. package/lib/__tests__/dependencyManagement.test.js +0 -1067
  505. package/lib/__tests__/developerTestAccounts.test.d.ts +0 -1
  506. package/lib/__tests__/developerTestAccounts.test.js +0 -156
  507. package/lib/__tests__/hasFeature.test.d.ts +0 -1
  508. package/lib/__tests__/hasFeature.test.js +0 -167
  509. package/lib/__tests__/http.test.d.ts +0 -1
  510. package/lib/__tests__/http.test.js +0 -40
  511. package/lib/__tests__/importData.test.d.ts +0 -1
  512. package/lib/__tests__/importData.test.js +0 -98
  513. package/lib/__tests__/npmCli.test.d.ts +0 -1
  514. package/lib/__tests__/npmCli.test.js +0 -84
  515. package/lib/__tests__/oauth.test.d.ts +0 -1
  516. package/lib/__tests__/oauth.test.js +0 -109
  517. package/lib/__tests__/parsing.test.d.ts +0 -1
  518. package/lib/__tests__/parsing.test.js +0 -34
  519. package/lib/__tests__/polling.test.d.ts +0 -1
  520. package/lib/__tests__/polling.test.js +0 -76
  521. package/lib/__tests__/process.test.d.ts +0 -1
  522. package/lib/__tests__/process.test.js +0 -89
  523. package/lib/__tests__/sandboxSync.test.d.ts +0 -1
  524. package/lib/__tests__/sandboxSync.test.js +0 -147
  525. package/lib/__tests__/sandboxes.test.d.ts +0 -1
  526. package/lib/__tests__/sandboxes.test.js +0 -156
  527. package/lib/__tests__/serverlessLogs.test.d.ts +0 -1
  528. package/lib/__tests__/serverlessLogs.test.js +0 -148
  529. package/lib/__tests__/usageTracking.test.d.ts +0 -1
  530. package/lib/__tests__/usageTracking.test.js +0 -197
  531. package/lib/__tests__/validation.test.d.ts +0 -1
  532. package/lib/__tests__/validation.test.js +0 -143
  533. package/lib/__tests__/yargsUtils.test.d.ts +0 -1
  534. package/lib/__tests__/yargsUtils.test.js +0 -124
  535. package/lib/app/__tests__/migrate.test.d.ts +0 -1
  536. package/lib/app/__tests__/migrate.test.js +0 -638
  537. package/lib/doctor/__tests__/Diagnosis.test.d.ts +0 -1
  538. package/lib/doctor/__tests__/Diagnosis.test.js +0 -84
  539. package/lib/doctor/__tests__/DiagnosticInfoBuilder.test.d.ts +0 -1
  540. package/lib/doctor/__tests__/DiagnosticInfoBuilder.test.js +0 -177
  541. package/lib/doctor/__tests__/Doctor.test.d.ts +0 -1
  542. package/lib/doctor/__tests__/Doctor.test.js +0 -560
  543. package/lib/errorHandlers/__tests__/index.test.d.ts +0 -1
  544. package/lib/errorHandlers/__tests__/index.test.js +0 -278
  545. package/lib/mcp/__tests__/setup.test.d.ts +0 -1
  546. package/lib/mcp/__tests__/setup.test.js +0 -194
  547. package/lib/middleware/__tests__/commandTargetingUtils.test.d.ts +0 -1
  548. package/lib/middleware/__tests__/commandTargetingUtils.test.js +0 -99
  549. package/lib/middleware/__tests__/configMiddleware.test.d.ts +0 -1
  550. package/lib/middleware/__tests__/configMiddleware.test.js +0 -118
  551. package/lib/middleware/__tests__/gitMiddleware.test.d.ts +0 -1
  552. package/lib/middleware/__tests__/gitMiddleware.test.js +0 -43
  553. package/lib/middleware/__tests__/requestMiddleware.test.d.ts +0 -1
  554. package/lib/middleware/__tests__/requestMiddleware.test.js +0 -15
  555. package/lib/middleware/__tests__/usageTrackingMiddleware.test.d.ts +0 -1
  556. package/lib/middleware/__tests__/usageTrackingMiddleware.test.js +0 -44
  557. package/lib/middleware/__tests__/yargsChecksMiddleware.test.d.ts +0 -1
  558. package/lib/middleware/__tests__/yargsChecksMiddleware.test.js +0 -39
  559. package/lib/projects/__tests__/AppDevModeInterface.test.d.ts +0 -1
  560. package/lib/projects/__tests__/AppDevModeInterface.test.js +0 -541
  561. package/lib/projects/__tests__/DevServerManager.test.d.ts +0 -1
  562. package/lib/projects/__tests__/DevServerManager.test.js +0 -185
  563. package/lib/projects/__tests__/DevSessionManager.test.d.ts +0 -1
  564. package/lib/projects/__tests__/DevSessionManager.test.js +0 -250
  565. package/lib/projects/__tests__/LocalDevProcess.test.d.ts +0 -1
  566. package/lib/projects/__tests__/LocalDevProcess.test.js +0 -481
  567. package/lib/projects/__tests__/LocalDevWebsocketServer.test.d.ts +0 -1
  568. package/lib/projects/__tests__/LocalDevWebsocketServer.test.js +0 -231
  569. package/lib/projects/__tests__/ProjectLogsManager.test.d.ts +0 -1
  570. package/lib/projects/__tests__/ProjectLogsManager.test.js +0 -302
  571. package/lib/projects/__tests__/UIExtensionsDevModeInterface.test.d.ts +0 -1
  572. package/lib/projects/__tests__/UIExtensionsDevModeInterface.test.js +0 -160
  573. package/lib/projects/__tests__/components.test.d.ts +0 -1
  574. package/lib/projects/__tests__/components.test.js +0 -426
  575. package/lib/projects/__tests__/deploy.test.d.ts +0 -1
  576. package/lib/projects/__tests__/deploy.test.js +0 -231
  577. package/lib/projects/__tests__/localDevProjectHelpers.test.d.ts +0 -1
  578. package/lib/projects/__tests__/localDevProjectHelpers.test.js +0 -120
  579. package/lib/projects/__tests__/platformVersion.test.d.ts +0 -1
  580. package/lib/projects/__tests__/platformVersion.test.js +0 -63
  581. package/lib/projects/__tests__/pollProjectBuildAndDeploy.test.d.ts +0 -1
  582. package/lib/projects/__tests__/pollProjectBuildAndDeploy.test.js +0 -328
  583. package/lib/projects/__tests__/projectProfiles.test.d.ts +0 -1
  584. package/lib/projects/__tests__/projectProfiles.test.js +0 -441
  585. package/lib/projects/__tests__/projects.test.d.ts +0 -1
  586. package/lib/projects/__tests__/projects.test.js +0 -58
  587. package/lib/projects/__tests__/structure.test.d.ts +0 -1
  588. package/lib/projects/__tests__/structure.test.js +0 -210
  589. package/lib/projects/__tests__/uieLinting.test.d.ts +0 -1
  590. package/lib/projects/__tests__/uieLinting.test.js +0 -631
  591. package/lib/projects/__tests__/upload.test.d.ts +0 -1
  592. package/lib/projects/__tests__/upload.test.js +0 -183
  593. package/lib/projects/add/__tests__/legacyAddComponent.test.d.ts +0 -1
  594. package/lib/projects/add/__tests__/legacyAddComponent.test.js +0 -245
  595. package/lib/projects/add/__tests__/v2AddComponent.test.d.ts +0 -1
  596. package/lib/projects/add/__tests__/v2AddComponent.test.js +0 -343
  597. package/lib/projects/create/__tests__/legacy.test.d.ts +0 -1
  598. package/lib/projects/create/__tests__/legacy.test.js +0 -90
  599. package/lib/projects/create/__tests__/v2.test.d.ts +0 -1
  600. package/lib/projects/create/__tests__/v2.test.js +0 -257
  601. package/lib/projects/platformVersion.d.ts +0 -9
  602. package/lib/projects/platformVersion.js +0 -39
  603. package/lib/prompts/__tests__/createDeveloperTestAccountConfigPrompt.test.d.ts +0 -1
  604. package/lib/prompts/__tests__/createDeveloperTestAccountConfigPrompt.test.js +0 -157
  605. package/lib/prompts/__tests__/createFunctionPrompt.test.d.ts +0 -1
  606. package/lib/prompts/__tests__/createFunctionPrompt.test.js +0 -129
  607. package/lib/prompts/__tests__/createModulePrompt.test.d.ts +0 -1
  608. package/lib/prompts/__tests__/createModulePrompt.test.js +0 -187
  609. package/lib/prompts/__tests__/createTemplatePrompt.test.d.ts +0 -1
  610. package/lib/prompts/__tests__/createTemplatePrompt.test.js +0 -102
  611. package/lib/prompts/__tests__/downloadProjectPrompt.test.d.ts +0 -1
  612. package/lib/prompts/__tests__/downloadProjectPrompt.test.js +0 -31
  613. package/lib/prompts/__tests__/projectAddPrompt.test.d.ts +0 -1
  614. package/lib/prompts/__tests__/projectAddPrompt.test.js +0 -143
  615. package/lib/prompts/__tests__/projectsLogsPrompt.test.d.ts +0 -1
  616. package/lib/prompts/__tests__/projectsLogsPrompt.test.js +0 -37
  617. package/lib/prompts/__tests__/selectProjectTemplatePrompt.test.d.ts +0 -1
  618. package/lib/prompts/__tests__/selectProjectTemplatePrompt.test.js +0 -160
  619. package/lib/sandboxSync.d.ts +0 -4
  620. package/lib/sandboxSync.js +0 -102
  621. package/lib/theme/__tests__/migrate.test.d.ts +0 -1
  622. package/lib/theme/__tests__/migrate.test.js +0 -256
  623. package/lib/ui/__tests__/SpinniesManager.test.d.ts +0 -1
  624. package/lib/ui/__tests__/SpinniesManager.test.js +0 -488
  625. package/lib/ui/__tests__/removeAnsiCodes.test.d.ts +0 -1
  626. package/lib/ui/__tests__/removeAnsiCodes.test.js +0 -84
  627. package/mcp-server/tools/cms/__tests__/HsCreateFunctionTool.test.d.ts +0 -1
  628. package/mcp-server/tools/cms/__tests__/HsCreateFunctionTool.test.js +0 -255
  629. package/mcp-server/tools/cms/__tests__/HsCreateModuleTool.test.d.ts +0 -1
  630. package/mcp-server/tools/cms/__tests__/HsCreateModuleTool.test.js +0 -228
  631. package/mcp-server/tools/cms/__tests__/HsCreateTemplateTool.test.d.ts +0 -1
  632. package/mcp-server/tools/cms/__tests__/HsCreateTemplateTool.test.js +0 -209
  633. package/mcp-server/tools/cms/__tests__/HsFunctionLogsTool.test.d.ts +0 -1
  634. package/mcp-server/tools/cms/__tests__/HsFunctionLogsTool.test.js +0 -187
  635. package/mcp-server/tools/cms/__tests__/HsListFunctionsTool.test.d.ts +0 -1
  636. package/mcp-server/tools/cms/__tests__/HsListFunctionsTool.test.js +0 -125
  637. package/mcp-server/tools/cms/__tests__/HsListTool.test.d.ts +0 -1
  638. package/mcp-server/tools/cms/__tests__/HsListTool.test.js +0 -125
  639. package/mcp-server/tools/project/__tests__/AddFeatureToProjectTool.test.d.ts +0 -1
  640. package/mcp-server/tools/project/__tests__/AddFeatureToProjectTool.test.js +0 -158
  641. package/mcp-server/tools/project/__tests__/CreateProjectTool.test.d.ts +0 -1
  642. package/mcp-server/tools/project/__tests__/CreateProjectTool.test.js +0 -133
  643. package/mcp-server/tools/project/__tests__/CreateTestAccountTool.test.d.ts +0 -1
  644. package/mcp-server/tools/project/__tests__/CreateTestAccountTool.test.js +0 -462
  645. package/mcp-server/tools/project/__tests__/DeployProjectTool.test.d.ts +0 -1
  646. package/mcp-server/tools/project/__tests__/DeployProjectTool.test.js +0 -126
  647. package/mcp-server/tools/project/__tests__/DocFetchTool.test.d.ts +0 -1
  648. package/mcp-server/tools/project/__tests__/DocFetchTool.test.js +0 -125
  649. package/mcp-server/tools/project/__tests__/DocsSearchTool.test.d.ts +0 -1
  650. package/mcp-server/tools/project/__tests__/DocsSearchTool.test.js +0 -210
  651. package/mcp-server/tools/project/__tests__/GetApiUsagePatternsByAppIdTool.test.d.ts +0 -1
  652. package/mcp-server/tools/project/__tests__/GetApiUsagePatternsByAppIdTool.test.js +0 -178
  653. package/mcp-server/tools/project/__tests__/GetApplicationInfoTool.test.d.ts +0 -1
  654. package/mcp-server/tools/project/__tests__/GetApplicationInfoTool.test.js +0 -124
  655. package/mcp-server/tools/project/__tests__/GetBuildLogsTool.test.d.ts +0 -1
  656. package/mcp-server/tools/project/__tests__/GetBuildLogsTool.test.js +0 -307
  657. package/mcp-server/tools/project/__tests__/GetBuildStatusTool.test.d.ts +0 -1
  658. package/mcp-server/tools/project/__tests__/GetBuildStatusTool.test.js +0 -242
  659. package/mcp-server/tools/project/__tests__/GetConfigValuesTool.test.d.ts +0 -1
  660. package/mcp-server/tools/project/__tests__/GetConfigValuesTool.test.js +0 -209
  661. package/mcp-server/tools/project/__tests__/GuidedWalkthroughTool.test.d.ts +0 -1
  662. package/mcp-server/tools/project/__tests__/GuidedWalkthroughTool.test.js +0 -158
  663. package/mcp-server/tools/project/__tests__/UploadProjectTools.test.d.ts +0 -1
  664. package/mcp-server/tools/project/__tests__/UploadProjectTools.test.js +0 -179
  665. package/mcp-server/tools/project/__tests__/ValidateProjectTool.test.d.ts +0 -1
  666. package/mcp-server/tools/project/__tests__/ValidateProjectTool.test.js +0 -118
  667. package/mcp-server/utils/__tests__/command.test.d.ts +0 -1
  668. package/mcp-server/utils/__tests__/command.test.js +0 -45
  669. package/mcp-server/utils/__tests__/content.test.d.ts +0 -1
  670. package/mcp-server/utils/__tests__/content.test.js +0 -164
  671. package/mcp-server/utils/__tests__/feedbackTracking.test.d.ts +0 -1
  672. package/mcp-server/utils/__tests__/feedbackTracking.test.js +0 -124
  673. package/mcp-server/utils/__tests__/project.test.d.ts +0 -1
  674. package/mcp-server/utils/__tests__/project.test.js +0 -140
  675. package/mcp-server/utils/project.d.ts +0 -5
  676. package/mcp-server/utils/project.js +0 -18
@@ -1,258 +0,0 @@
1
- import { updateConfigAccount, createEmptyConfigFile, getConfigFilePath, localConfigFileExists, globalConfigFileExists, setConfigAccountAsDefault, } from '@hubspot/local-dev-lib/config';
2
- import { getAccessToken, updateConfigWithAccessToken, } from '@hubspot/local-dev-lib/personalAccessKey';
3
- import { toKebabCase } from '@hubspot/local-dev-lib/text';
4
- import { PERSONAL_ACCESS_KEY_AUTH_METHOD } from '@hubspot/local-dev-lib/constants/auth';
5
- import { handleMerge, handleMigration } from '../configMigrate.js';
6
- import { personalAccessKeyPrompt } from '../prompts/personalAccessKeyPrompt.js';
7
- import { cliAccountNamePrompt } from '../prompts/accountNamePrompt.js';
8
- import { setAsDefaultAccountPrompt } from '../prompts/setAsDefaultAccountPrompt.js';
9
- import { authenticateNewAccount } from '../accountAuth.js';
10
- vi.mock('@hubspot/local-dev-lib/config');
11
- vi.mock('@hubspot/local-dev-lib/personalAccessKey');
12
- vi.mock('@hubspot/local-dev-lib/text');
13
- vi.mock('../configMigrate.js');
14
- vi.mock('../errorHandlers/index.js');
15
- vi.mock('../prompts/personalAccessKeyPrompt.js');
16
- vi.mock('../prompts/accountNamePrompt.js');
17
- vi.mock('../prompts/setAsDefaultAccountPrompt.js');
18
- vi.mock('../ui/logger.js', () => ({
19
- uiLogger: {
20
- log: vi.fn(),
21
- error: vi.fn(),
22
- success: vi.fn(),
23
- },
24
- }));
25
- const mockedUpdateConfigAccount = updateConfigAccount;
26
- const mockedCreateEmptyConfigFile = createEmptyConfigFile;
27
- const mockedGetConfigFilePath = getConfigFilePath;
28
- const mockedLocalConfigFileExists = localConfigFileExists;
29
- const mockedGlobalConfigFileExists = globalConfigFileExists;
30
- const mockedSetConfigAccountAsDefault = setConfigAccountAsDefault;
31
- const mockedGetAccessToken = getAccessToken;
32
- const mockedUpdateConfigWithAccessToken = updateConfigWithAccessToken;
33
- const mockedToKebabCase = toKebabCase;
34
- const mockedHandleMerge = handleMerge;
35
- const mockedHandleMigration = handleMigration;
36
- const mockedPersonalAccessKeyPrompt = personalAccessKeyPrompt;
37
- const mockedCliAccountNamePrompt = cliAccountNamePrompt;
38
- const mockedSetAsDefaultAccountPrompt = setAsDefaultAccountPrompt;
39
- describe('lib/accountAuth', () => {
40
- describe('authenticateNewAccount()', () => {
41
- const mockAccessToken = {
42
- portalId: 123456,
43
- accessToken: 'test-token',
44
- expiresAt: '2025-01-01',
45
- scopeGroups: ['test-scope'],
46
- enabledFeatures: { 'test-feature': 1 },
47
- encodedOAuthRefreshToken: 'test-refresh-token',
48
- hubName: 'Test Hub',
49
- accountType: 'STANDARD',
50
- };
51
- const mockAccountConfig = {
52
- name: 'test-hub',
53
- accountId: 123456,
54
- env: 'prod',
55
- accountType: 'STANDARD',
56
- authType: PERSONAL_ACCESS_KEY_AUTH_METHOD.value,
57
- personalAccessKey: 'test-key',
58
- auth: {
59
- tokenInfo: {
60
- accessToken: 'test-token',
61
- expiresAt: '2025-01-01',
62
- },
63
- },
64
- };
65
- beforeEach(() => {
66
- vi.clearAllMocks();
67
- mockedLocalConfigFileExists.mockReturnValue(false);
68
- mockedGlobalConfigFileExists.mockReturnValue(false);
69
- mockedGetAccessToken.mockResolvedValue(mockAccessToken);
70
- mockedUpdateConfigWithAccessToken.mockResolvedValue(mockAccountConfig);
71
- mockedToKebabCase.mockReturnValue('test-hub');
72
- mockedCliAccountNamePrompt.mockResolvedValue({ name: 'test-hub' });
73
- mockedGetConfigFilePath.mockReturnValue('/path/to/config');
74
- mockedPersonalAccessKeyPrompt.mockResolvedValue({
75
- personalAccessKey: 'test-key',
76
- });
77
- });
78
- it('should create config file if it does not exist', async () => {
79
- mockedGlobalConfigFileExists.mockReturnValue(false);
80
- await authenticateNewAccount({
81
- env: 'prod',
82
- providedPersonalAccessKey: 'test-key',
83
- accountId: 123456,
84
- });
85
- expect(mockedCreateEmptyConfigFile).toHaveBeenCalledWith(true);
86
- });
87
- it('should not create config file if it already exists', async () => {
88
- mockedGlobalConfigFileExists.mockReturnValue(true);
89
- await authenticateNewAccount({
90
- env: 'prod',
91
- providedPersonalAccessKey: 'test-key',
92
- accountId: 123456,
93
- });
94
- expect(mockedCreateEmptyConfigFile).not.toHaveBeenCalled();
95
- });
96
- it('should use provided personal access key without prompting', async () => {
97
- await authenticateNewAccount({
98
- env: 'prod',
99
- providedPersonalAccessKey: 'test-key',
100
- accountId: 123456,
101
- });
102
- expect(mockedPersonalAccessKeyPrompt).not.toHaveBeenCalled();
103
- expect(mockedGetAccessToken).toHaveBeenCalledWith('test-key', 'prod');
104
- });
105
- it('should prompt for personal access key if not provided', async () => {
106
- await authenticateNewAccount({
107
- env: 'prod',
108
- accountId: 123456,
109
- });
110
- expect(mockedPersonalAccessKeyPrompt).toHaveBeenCalledWith({
111
- env: 'prod',
112
- account: 123456,
113
- });
114
- expect(mockedGetAccessToken).toHaveBeenCalledWith('test-key', 'prod');
115
- });
116
- it('should prompt for account name if config does not exist', async () => {
117
- mockedGlobalConfigFileExists.mockReturnValue(false);
118
- await authenticateNewAccount({
119
- env: 'prod',
120
- providedPersonalAccessKey: 'test-key',
121
- accountId: 123456,
122
- });
123
- expect(mockedCliAccountNamePrompt).toHaveBeenCalledWith('test-hub');
124
- });
125
- it('should not prompt for account name if config already exists', async () => {
126
- mockedGlobalConfigFileExists.mockReturnValue(true);
127
- await authenticateNewAccount({
128
- env: 'prod',
129
- providedPersonalAccessKey: 'test-key',
130
- accountId: 123456,
131
- });
132
- expect(mockedCliAccountNamePrompt).not.toHaveBeenCalled();
133
- });
134
- it('should set account as default when setAsDefaultAccount is true', async () => {
135
- mockedGlobalConfigFileExists.mockReturnValue(true);
136
- await authenticateNewAccount({
137
- env: 'prod',
138
- providedPersonalAccessKey: 'test-key',
139
- accountId: 123456,
140
- setAsDefaultAccount: true,
141
- });
142
- expect(mockedSetConfigAccountAsDefault).toHaveBeenCalledWith('test-hub');
143
- });
144
- it('should prompt to set as default when setAsDefaultAccount is not provided and config exists', async () => {
145
- mockedGlobalConfigFileExists.mockReturnValue(true);
146
- await authenticateNewAccount({
147
- env: 'prod',
148
- providedPersonalAccessKey: 'test-key',
149
- accountId: 123456,
150
- });
151
- expect(mockedSetAsDefaultAccountPrompt).toHaveBeenCalledWith('test-hub');
152
- });
153
- it('should return the updated account config on success', async () => {
154
- const result = await authenticateNewAccount({
155
- env: 'prod',
156
- providedPersonalAccessKey: 'test-key',
157
- accountId: 123456,
158
- });
159
- expect(result).toEqual(mockAccountConfig);
160
- });
161
- it('should return null if access token fetch fails', async () => {
162
- mockedGetAccessToken.mockRejectedValue(new Error('Invalid token'));
163
- const result = await authenticateNewAccount({
164
- env: 'prod',
165
- providedPersonalAccessKey: 'test-key',
166
- accountId: 123456,
167
- });
168
- expect(result).toBeNull();
169
- });
170
- it('should return null if config update fails', async () => {
171
- mockedUpdateConfigWithAccessToken.mockResolvedValue(null);
172
- const result = await authenticateNewAccount({
173
- env: 'prod',
174
- providedPersonalAccessKey: 'test-key',
175
- accountId: 123456,
176
- });
177
- expect(result).toBeNull();
178
- });
179
- it('should handle missing account name and prompt for it', async () => {
180
- mockedGlobalConfigFileExists.mockReturnValue(true);
181
- mockedUpdateConfigWithAccessToken.mockResolvedValue({
182
- ...mockAccountConfig,
183
- name: undefined,
184
- });
185
- mockedCliAccountNamePrompt.mockResolvedValue({
186
- name: 'new-account-name',
187
- });
188
- await authenticateNewAccount({
189
- env: 'prod',
190
- providedPersonalAccessKey: 'test-key',
191
- accountId: 123456,
192
- });
193
- expect(mockedCliAccountNamePrompt).toHaveBeenCalledWith('test-hub');
194
- expect(mockedUpdateConfigAccount).toHaveBeenCalledWith(expect.objectContaining({
195
- name: 'new-account-name',
196
- }));
197
- });
198
- describe('config migration', () => {
199
- it('should handle migration when local config exists and global does not', async () => {
200
- mockedLocalConfigFileExists.mockReturnValue(true);
201
- mockedGlobalConfigFileExists.mockReturnValue(false);
202
- mockedHandleMigration.mockResolvedValue(true);
203
- await authenticateNewAccount({
204
- env: 'prod',
205
- providedPersonalAccessKey: 'test-key',
206
- accountId: 123456,
207
- });
208
- expect(mockedHandleMigration).toHaveBeenCalled();
209
- expect(mockedHandleMerge).not.toHaveBeenCalled();
210
- });
211
- it('should handle merge when both local and global configs exist', async () => {
212
- mockedLocalConfigFileExists.mockReturnValue(true);
213
- mockedGlobalConfigFileExists.mockReturnValue(true);
214
- mockedHandleMerge.mockResolvedValue(true);
215
- await authenticateNewAccount({
216
- env: 'prod',
217
- providedPersonalAccessKey: 'test-key',
218
- accountId: 123456,
219
- });
220
- expect(mockedHandleMerge).toHaveBeenCalled();
221
- expect(mockedHandleMigration).not.toHaveBeenCalled();
222
- });
223
- it('should return null if migration is not confirmed', async () => {
224
- mockedLocalConfigFileExists.mockReturnValue(true);
225
- mockedGlobalConfigFileExists.mockReturnValue(false);
226
- mockedHandleMigration.mockResolvedValue(false);
227
- const result = await authenticateNewAccount({
228
- env: 'prod',
229
- providedPersonalAccessKey: 'test-key',
230
- accountId: 123456,
231
- });
232
- expect(result).toBeNull();
233
- });
234
- it('should return null if merge is not confirmed', async () => {
235
- mockedLocalConfigFileExists.mockReturnValue(true);
236
- mockedGlobalConfigFileExists.mockReturnValue(true);
237
- mockedHandleMerge.mockResolvedValue(false);
238
- const result = await authenticateNewAccount({
239
- env: 'prod',
240
- providedPersonalAccessKey: 'test-key',
241
- accountId: 123456,
242
- });
243
- expect(result).toBeNull();
244
- });
245
- it('should return null if migration throws error', async () => {
246
- mockedLocalConfigFileExists.mockReturnValue(true);
247
- mockedGlobalConfigFileExists.mockReturnValue(false);
248
- mockedHandleMigration.mockRejectedValue(new Error('Migration failed'));
249
- const result = await authenticateNewAccount({
250
- env: 'prod',
251
- providedPersonalAccessKey: 'test-key',
252
- accountId: 123456,
253
- });
254
- expect(result).toBeNull();
255
- });
256
- });
257
- });
258
- });
@@ -1 +0,0 @@
1
- export {};
@@ -1,98 +0,0 @@
1
- import { HUBSPOT_ACCOUNT_TYPES } from '@hubspot/local-dev-lib/constants/config';
2
- import { isStandardAccount, isSandbox, isStandardSandbox, isDevelopmentSandbox, isDeveloperTestAccount, isAppDeveloperAccount, } from '../accountTypes.js';
3
- const STANDARD_ACCOUNT = {
4
- name: 'standard-account',
5
- accountId: 123,
6
- accountType: HUBSPOT_ACCOUNT_TYPES.STANDARD,
7
- env: 'prod',
8
- };
9
- const DEVELOPMENT_SANDBOX_ACCOUNT = {
10
- name: 'development-sandbox-account',
11
- accountId: 456,
12
- accountType: HUBSPOT_ACCOUNT_TYPES.DEVELOPMENT_SANDBOX,
13
- env: 'prod',
14
- };
15
- const STANDARD_SANDBOX_ACCOUNT = {
16
- name: 'sandbox-account',
17
- accountId: 456,
18
- accountType: HUBSPOT_ACCOUNT_TYPES.STANDARD_SANDBOX,
19
- env: 'prod',
20
- };
21
- const DEVELOPER_TEST_ACCOUNT = {
22
- name: 'developer-test-account',
23
- accountId: 789,
24
- accountType: HUBSPOT_ACCOUNT_TYPES.DEVELOPER_TEST,
25
- env: 'prod',
26
- };
27
- const APP_DEVELOPER_ACCOUNT = {
28
- name: 'app-developer-account',
29
- accountId: 1011,
30
- accountType: HUBSPOT_ACCOUNT_TYPES.APP_DEVELOPER,
31
- env: 'prod',
32
- };
33
- describe('lib/accountTypes', () => {
34
- describe('isStandardAccount()', () => {
35
- it('should return true if the account is a standard account', () => {
36
- const result = isStandardAccount(STANDARD_ACCOUNT);
37
- expect(result).toBe(true);
38
- });
39
- it('should return false if the account is not a standard account', () => {
40
- const result = isStandardAccount(DEVELOPER_TEST_ACCOUNT);
41
- expect(result).toBe(false);
42
- });
43
- });
44
- describe('isSandbox()', () => {
45
- it('should return true if the account is a standard sandbox account', () => {
46
- const result = isSandbox(STANDARD_SANDBOX_ACCOUNT);
47
- expect(result).toBe(true);
48
- });
49
- it('should return true if the account is a development sandbox account', () => {
50
- const result = isSandbox(DEVELOPMENT_SANDBOX_ACCOUNT);
51
- expect(result).toBe(true);
52
- });
53
- it('should return false if the account is not a sandbox account', () => {
54
- const result = isSandbox(STANDARD_ACCOUNT);
55
- expect(result).toBe(false);
56
- });
57
- });
58
- describe('isStandardSandbox()', () => {
59
- it('should return true if the account is a standard sandbox account', () => {
60
- const result = isStandardSandbox(STANDARD_SANDBOX_ACCOUNT);
61
- expect(result).toBe(true);
62
- });
63
- it('should return false if the account is not a standard sandbox account', () => {
64
- const result = isStandardSandbox(DEVELOPMENT_SANDBOX_ACCOUNT);
65
- expect(result).toBe(false);
66
- });
67
- });
68
- describe('isDevelopmentSandbox()', () => {
69
- it('should return true if the account is a development sandbox account', () => {
70
- const result = isDevelopmentSandbox(DEVELOPMENT_SANDBOX_ACCOUNT);
71
- expect(result).toBe(true);
72
- });
73
- it('should return false if the account is not a development sandbox account', () => {
74
- const result = isDevelopmentSandbox(STANDARD_ACCOUNT);
75
- expect(result).toBe(false);
76
- });
77
- });
78
- describe('isDeveloperTestAccount()', () => {
79
- it('should return true if the account is a developer test account', () => {
80
- const result = isDeveloperTestAccount(DEVELOPER_TEST_ACCOUNT);
81
- expect(result).toBe(true);
82
- });
83
- it('should return false if the account is not a developer test account', () => {
84
- const result = isDeveloperTestAccount(STANDARD_ACCOUNT);
85
- expect(result).toBe(false);
86
- });
87
- });
88
- describe('isAppDeveloperAccount()', () => {
89
- it('should return true if the account is an app developer account', () => {
90
- const result = isAppDeveloperAccount(APP_DEVELOPER_ACCOUNT);
91
- expect(result).toBe(true);
92
- });
93
- it('should return false if the account is not an app developer account', () => {
94
- const result = isAppDeveloperAccount(STANDARD_ACCOUNT);
95
- expect(result).toBe(false);
96
- });
97
- });
98
- });
@@ -1 +0,0 @@
1
- export {};
@@ -1,262 +0,0 @@
1
- import { getAccessToken, updateConfigWithAccessToken, } from '@hubspot/local-dev-lib/personalAccessKey';
2
- import { getConfigAccountIfExists, updateConfigAccount, } from '@hubspot/local-dev-lib/config';
3
- import { createDeveloperTestAccount, fetchDeveloperTestAccountGateSyncStatus, generateDeveloperTestAccountPersonalAccessKey, } from '@hubspot/local-dev-lib/api/developerTestAccounts';
4
- import { createSandbox, createV2Sandbox, getSandboxPersonalAccessKey, } from '@hubspot/local-dev-lib/api/sandboxHubs';
5
- import { HUBSPOT_ACCOUNT_TYPES } from '@hubspot/local-dev-lib/constants/config';
6
- import { personalAccessKeyPrompt } from '../prompts/personalAccessKeyPrompt.js';
7
- import { cliAccountNamePrompt } from '../prompts/accountNamePrompt.js';
8
- import * as buildAccount from '../buildAccount.js';
9
- import { poll } from '../polling.js';
10
- vi.mock('@hubspot/local-dev-lib/personalAccessKey');
11
- vi.mock('@hubspot/local-dev-lib/config');
12
- vi.mock('@hubspot/local-dev-lib/api/developerTestAccounts');
13
- vi.mock('@hubspot/local-dev-lib/api/sandboxHubs');
14
- vi.mock('../errorHandlers/index.js');
15
- vi.mock('../prompts/personalAccessKeyPrompt');
16
- vi.mock('../prompts/accountNamePrompt');
17
- vi.mock('../polling.js');
18
- vi.mock('../ui/SpinniesManager', () => ({
19
- default: {
20
- init: vi.fn(),
21
- add: vi.fn(),
22
- succeed: vi.fn(),
23
- fail: vi.fn(),
24
- },
25
- }));
26
- const mockedPersonalAccessKeyPrompt = personalAccessKeyPrompt;
27
- const mockedGetAccessToken = getAccessToken;
28
- const mockedUpdateConfigWithAccessToken = updateConfigWithAccessToken;
29
- const mockedGetConfigAccountIfExists = getConfigAccountIfExists;
30
- const mockedUpdateConfigAccount = updateConfigAccount;
31
- const mockedCliAccountNamePrompt = cliAccountNamePrompt;
32
- const mockedCreateDeveloperTestAccount = createDeveloperTestAccount;
33
- const mockedFetchDeveloperTestAccountGateSyncStatus = fetchDeveloperTestAccountGateSyncStatus;
34
- const mockedGenerateDeveloperTestAccountPersonalAccessKey = generateDeveloperTestAccountPersonalAccessKey;
35
- const mockedCreateSandbox = createSandbox;
36
- const mockedCreateV2Sandbox = createV2Sandbox;
37
- const mockedGetPersonalAccessKey = getSandboxPersonalAccessKey;
38
- const mockedPoll = poll;
39
- describe('lib/buildAccount', () => {
40
- describe('saveAccountToConfig()', () => {
41
- const mockAccountConfig = {
42
- name: 'Test Account',
43
- accountId: 123456,
44
- accountType: HUBSPOT_ACCOUNT_TYPES.APP_DEVELOPER,
45
- env: 'prod',
46
- };
47
- const accessToken = {
48
- portalId: 123456,
49
- accessToken: 'test-token',
50
- expiresAt: '2025-01-01',
51
- scopeGroups: ['test-scope'],
52
- enabledFeatures: { 'test-feature': 1 },
53
- encodedOAuthRefreshToken: 'test-refresh-token',
54
- hubName: 'test-hub',
55
- accountType: HUBSPOT_ACCOUNT_TYPES.STANDARD,
56
- };
57
- beforeEach(() => {
58
- mockedPersonalAccessKeyPrompt.mockResolvedValue({
59
- personalAccessKey: 'test-key',
60
- env: 'prod',
61
- });
62
- mockedGetAccessToken.mockResolvedValue(accessToken);
63
- mockedUpdateConfigWithAccessToken.mockResolvedValue(mockAccountConfig);
64
- mockedGetConfigAccountIfExists.mockResolvedValue(undefined);
65
- mockedUpdateConfigAccount.mockReturnValue(undefined);
66
- });
67
- it('should save account with provided personal access key', async () => {
68
- const result = await buildAccount.saveAccountToConfig(mockAccountConfig.accountId, mockAccountConfig.name, mockAccountConfig.env, 'test-key');
69
- expect(mockedPersonalAccessKeyPrompt).not.toHaveBeenCalled();
70
- expect(mockedUpdateConfigWithAccessToken).toHaveBeenCalledWith(accessToken, 'test-key', mockAccountConfig.env);
71
- expect(mockedUpdateConfigAccount).toHaveBeenCalledWith(expect.objectContaining(mockAccountConfig));
72
- expect(result).toBe(mockAccountConfig.name);
73
- });
74
- it('should prompt for personal access key if not provided', async () => {
75
- const result = await buildAccount.saveAccountToConfig(mockAccountConfig.accountId, mockAccountConfig.name, mockAccountConfig.env);
76
- expect(mockedPersonalAccessKeyPrompt).toHaveBeenCalledWith({
77
- env: mockAccountConfig.env,
78
- account: mockAccountConfig.accountId,
79
- });
80
- expect(mockedUpdateConfigWithAccessToken).toHaveBeenCalledWith(accessToken, 'test-key', mockAccountConfig.env);
81
- expect(mockedUpdateConfigAccount).toHaveBeenCalledWith(expect.objectContaining(mockAccountConfig));
82
- expect(result).toBe(mockAccountConfig.name);
83
- });
84
- it('should handle duplicate account names', async () => {
85
- const mockAccountConfigWithNoName = {
86
- ...mockAccountConfig,
87
- name: undefined,
88
- };
89
- mockedUpdateConfigWithAccessToken.mockResolvedValue(mockAccountConfigWithNoName);
90
- mockedGetConfigAccountIfExists.mockResolvedValue({ accountId: 123 });
91
- mockedCliAccountNamePrompt.mockResolvedValue({
92
- name: 'test-account-with-new-name',
93
- });
94
- const result = await buildAccount.saveAccountToConfig(mockAccountConfig.accountId, mockAccountConfig.name, mockAccountConfig.env, 'test-key');
95
- expect(mockedCliAccountNamePrompt).toHaveBeenCalled();
96
- expect(result).toBe('test-account-with-new-name');
97
- });
98
- });
99
- describe('createDeveloperTestAccountV2()', () => {
100
- const parentAccountId = 123456;
101
- const mockDeveoperTestAccountConfig = {
102
- accountName: 'Developer Test Account',
103
- description: 'Test Account created by the HubSpot CLI',
104
- };
105
- beforeEach(() => {
106
- vi.useFakeTimers();
107
- mockedCreateDeveloperTestAccount.mockResolvedValue({
108
- data: { id: 123456 },
109
- });
110
- mockedFetchDeveloperTestAccountGateSyncStatus.mockResolvedValue({
111
- data: { status: 'SUCCESS' },
112
- });
113
- mockedGenerateDeveloperTestAccountPersonalAccessKey.mockResolvedValue({
114
- data: { personalAccessKey: 'test-key' },
115
- });
116
- // Mock poll to resolve immediately with the success status
117
- mockedPoll.mockResolvedValue({ status: 'SUCCESS' });
118
- });
119
- afterEach(() => {
120
- vi.useRealTimers();
121
- });
122
- it('should create a developer test account successfully', async () => {
123
- const resultPromise = buildAccount.createDeveloperTestAccountV2(parentAccountId, mockDeveoperTestAccountConfig);
124
- // Fast-forward the 5 second setTimeout
125
- await vi.advanceTimersByTimeAsync(5000);
126
- const result = await resultPromise;
127
- expect(result).toEqual({
128
- accountName: mockDeveoperTestAccountConfig.accountName,
129
- accountId: 123456,
130
- personalAccessKey: 'test-key',
131
- });
132
- });
133
- });
134
- describe('buildDeveloperTestAccount()', () => {
135
- const mockParentAccountConfig = {
136
- name: 'Developer Account',
137
- accountId: 123456,
138
- accountType: HUBSPOT_ACCOUNT_TYPES.APP_DEVELOPER,
139
- env: 'prod',
140
- };
141
- const mockDeveloperTestAccount = {
142
- testPortalId: 56789,
143
- parentPortalId: 123456,
144
- accountName: 'Developer Test Account',
145
- createdAt: '2025-01-01',
146
- updatedAt: '2025-01-01',
147
- status: 'active',
148
- id: 56789,
149
- };
150
- beforeEach(() => {
151
- vi.spyOn(buildAccount, 'saveAccountToConfig').mockResolvedValue(mockParentAccountConfig.name);
152
- mockedCreateDeveloperTestAccount.mockResolvedValue({
153
- data: mockDeveloperTestAccount,
154
- });
155
- });
156
- it('should create a developer test account successfully', async () => {
157
- const result = await buildAccount.buildDeveloperTestAccount(mockDeveloperTestAccount.accountName, mockParentAccountConfig, mockParentAccountConfig.env, 10);
158
- expect(result).toEqual(mockDeveloperTestAccount.id);
159
- });
160
- it('should handle API errors when creating developer test account', async () => {
161
- mockedCreateDeveloperTestAccount.mockRejectedValue(new Error('test-error'));
162
- await expect(buildAccount.buildDeveloperTestAccount(mockDeveloperTestAccount.accountName, mockParentAccountConfig, mockParentAccountConfig.env, 10)).rejects.toThrow();
163
- });
164
- });
165
- describe('buildSandbox()', () => {
166
- const mockParentAccountConfig = {
167
- name: 'Prod account',
168
- accountId: 123456,
169
- accountType: HUBSPOT_ACCOUNT_TYPES.STANDARD,
170
- env: 'prod',
171
- };
172
- const mockSandbox = {
173
- sandboxHubId: 56789,
174
- parentHubId: 123456,
175
- createdAt: '2025-01-01',
176
- type: 'STANDARD',
177
- version: 'V1',
178
- archived: false,
179
- name: 'Test Sandbox',
180
- domain: 'test-sandbox.hubspot.com',
181
- createdByUser: {
182
- id: 123456,
183
- email: 'test@test.com',
184
- firstName: 'Test',
185
- lastName: 'User',
186
- },
187
- };
188
- beforeEach(() => {
189
- vi.spyOn(buildAccount, 'saveAccountToConfig').mockResolvedValue(mockParentAccountConfig.name);
190
- mockedCreateSandbox.mockResolvedValue({
191
- data: { sandbox: mockSandbox, personalAccessKey: 'test-key' },
192
- });
193
- });
194
- it('should create a standard sandbox successfully', async () => {
195
- const result = await buildAccount.buildSandbox(mockSandbox.name, mockParentAccountConfig, HUBSPOT_ACCOUNT_TYPES.STANDARD_SANDBOX, mockParentAccountConfig.env, false);
196
- expect(result).toEqual({
197
- name: mockSandbox.name,
198
- personalAccessKey: 'test-key',
199
- sandbox: mockSandbox,
200
- });
201
- });
202
- it('should create a development sandbox successfully', async () => {
203
- const result = await buildAccount.buildSandbox(mockSandbox.name, mockParentAccountConfig, HUBSPOT_ACCOUNT_TYPES.DEVELOPMENT_SANDBOX, mockParentAccountConfig.env);
204
- expect(result).toEqual({
205
- name: mockSandbox.name,
206
- personalAccessKey: 'test-key',
207
- sandbox: mockSandbox,
208
- });
209
- });
210
- it('should handle API errors when creating sandbox', async () => {
211
- mockedCreateSandbox.mockRejectedValue(new Error('test-error'));
212
- await expect(buildAccount.buildSandbox(mockSandbox.name, mockParentAccountConfig, HUBSPOT_ACCOUNT_TYPES.STANDARD_SANDBOX, mockParentAccountConfig.env, false)).rejects.toThrow();
213
- });
214
- });
215
- describe('buildV2Sandbox()', () => {
216
- const mockParentAccountConfig = {
217
- name: 'Prod account',
218
- accountId: 123456,
219
- accountType: HUBSPOT_ACCOUNT_TYPES.STANDARD,
220
- env: 'prod',
221
- };
222
- const mockSandbox = {
223
- sandboxHubId: 56789,
224
- parentHubId: 123456,
225
- createdAt: '2025-01-01',
226
- type: 'STANDARD',
227
- archived: false,
228
- version: 'V2',
229
- name: 'Test v2 Sandbox',
230
- domain: 'test-v2-sandbox.hubspot.com',
231
- createdByUser: {
232
- id: 123456,
233
- email: 'test@test.com',
234
- firstName: 'Test',
235
- lastName: 'User',
236
- },
237
- };
238
- beforeEach(() => {
239
- vi.spyOn(buildAccount, 'saveAccountToConfig').mockResolvedValue(mockParentAccountConfig.name);
240
- mockedCreateV2Sandbox.mockResolvedValue({
241
- data: mockSandbox,
242
- });
243
- mockedGetPersonalAccessKey.mockResolvedValue({
244
- data: { personalAccessKey: { encodedOAuthRefreshToken: 'test-key' } },
245
- });
246
- });
247
- it('should create a v2 standard sandbox successfully and fetch a personal access key', async () => {
248
- const result = await buildAccount.buildV2Sandbox(mockSandbox.name, mockParentAccountConfig, HUBSPOT_ACCOUNT_TYPES.STANDARD_SANDBOX, false, mockParentAccountConfig.env, false);
249
- expect(result).toEqual({ sandbox: mockSandbox });
250
- expect(mockedGetPersonalAccessKey).toHaveBeenCalledWith(mockParentAccountConfig.accountId, mockSandbox.sandboxHubId);
251
- });
252
- it('should create a development sandbox successfully and fetch a personal access key', async () => {
253
- const result = await buildAccount.buildV2Sandbox(mockSandbox.name, mockParentAccountConfig, HUBSPOT_ACCOUNT_TYPES.DEVELOPMENT_SANDBOX, false, mockParentAccountConfig.env, false);
254
- expect(result).toEqual({ sandbox: mockSandbox });
255
- expect(mockedGetPersonalAccessKey).toHaveBeenCalledWith(mockParentAccountConfig.accountId, mockSandbox.sandboxHubId);
256
- });
257
- it('should handle API errors when creating sandbox', async () => {
258
- mockedCreateV2Sandbox.mockRejectedValue(new Error('test-error'));
259
- await expect(buildAccount.buildV2Sandbox(mockSandbox.name, mockParentAccountConfig, HUBSPOT_ACCOUNT_TYPES.STANDARD_SANDBOX, false, mockParentAccountConfig.env, false)).rejects.toThrow();
260
- });
261
- });
262
- });
@@ -1 +0,0 @@
1
- export {};