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

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 (595) hide show
  1. package/api/migrate.js +3 -3
  2. package/bin/cli.js +5 -0
  3. package/commands/account/auth.js +12 -22
  4. package/commands/account/clean.js +5 -6
  5. package/commands/account/createOverride.js +7 -7
  6. package/commands/account/info.js +2 -1
  7. package/commands/account/list.js +3 -5
  8. package/commands/account/remove.js +2 -3
  9. package/commands/account/removeOverride.js +8 -10
  10. package/commands/account/rename.js +5 -6
  11. package/commands/account/use.js +8 -19
  12. package/commands/api.d.ts +10 -0
  13. package/commands/api.js +164 -0
  14. package/commands/app/migrate.js +12 -12
  15. package/commands/app/secret/add.js +6 -7
  16. package/commands/app/secret/delete.js +9 -10
  17. package/commands/app/secret/list.js +6 -7
  18. package/commands/app/secret/update.js +8 -9
  19. package/commands/auth.js +12 -12
  20. package/commands/cms/app/create.js +9 -5
  21. package/commands/cms/convertFields.js +8 -8
  22. package/commands/cms/delete.js +2 -3
  23. package/commands/cms/fetch.js +7 -7
  24. package/commands/cms/function/create.js +9 -5
  25. package/commands/cms/function/deploy.js +2 -3
  26. package/commands/cms/function/list.js +11 -7
  27. package/commands/cms/function/logs.js +17 -23
  28. package/commands/cms/function/server.js +2 -3
  29. package/commands/cms/getReactModule.js +7 -8
  30. package/commands/cms/lighthouseScore.js +25 -24
  31. package/commands/cms/lint.js +4 -5
  32. package/commands/cms/list.js +5 -6
  33. package/commands/cms/module/create.js +9 -5
  34. package/commands/cms/module/marketplace-validate.js +7 -8
  35. package/commands/cms/mv.js +2 -3
  36. package/commands/cms/template/create.js +10 -6
  37. package/commands/cms/theme/create.js +5 -5
  38. package/commands/cms/theme/generate-selectors.js +5 -4
  39. package/commands/cms/theme/marketplace-validate.js +8 -9
  40. package/commands/cms/theme/preview.js +16 -8
  41. package/commands/cms/upload.js +15 -12
  42. package/commands/cms/watch.js +5 -5
  43. package/commands/cms/webpack/create.js +5 -5
  44. package/commands/completion.js +3 -5
  45. package/commands/config/migrate.js +6 -7
  46. package/commands/config/set.js +5 -6
  47. package/commands/customObject/create.js +4 -5
  48. package/commands/customObject/createSchema.js +4 -5
  49. package/commands/customObject/deleteSchema.js +4 -5
  50. package/commands/customObject/fetchAllSchemas.js +2 -3
  51. package/commands/customObject/fetchSchema.js +2 -3
  52. package/commands/customObject/listSchemas.js +2 -3
  53. package/commands/customObject/updateSchema.js +4 -5
  54. package/commands/doctor.js +8 -8
  55. package/commands/feedback.js +6 -4
  56. package/commands/filemanager/fetch.js +5 -6
  57. package/commands/filemanager/upload.js +5 -5
  58. package/commands/getStarted.js +16 -18
  59. package/commands/hubdb/clear.js +5 -6
  60. package/commands/hubdb/create.js +4 -5
  61. package/commands/hubdb/delete.js +8 -9
  62. package/commands/hubdb/fetch.js +5 -6
  63. package/commands/hubdb/list.js +16 -14
  64. package/commands/init.js +14 -17
  65. package/commands/mcp/setup.js +5 -6
  66. package/commands/mcp/start.js +2 -3
  67. package/commands/open.js +4 -5
  68. package/commands/project/add.js +13 -8
  69. package/commands/project/create.js +20 -17
  70. package/commands/project/delete.d.ts +7 -0
  71. package/commands/project/delete.js +74 -0
  72. package/commands/project/deploy.js +39 -36
  73. package/commands/project/dev/deprecatedFlow.js +42 -15
  74. package/commands/project/dev/index.d.ts +3 -3
  75. package/commands/project/dev/index.js +29 -34
  76. package/commands/project/dev/unifiedFlow.js +37 -14
  77. package/commands/project/download.js +10 -11
  78. package/commands/project/info.js +19 -19
  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 +13 -13
  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 +33 -19
  90. package/commands/project/validate.js +12 -12
  91. package/commands/project/watch.js +22 -22
  92. package/commands/project.js +8 -3
  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 +24 -20
  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 +95 -7
  106. package/lang/en.js +98 -13
  107. package/lib/accountAuth.js +2 -2
  108. package/lib/app/migrate.js +7 -0
  109. package/lib/buildAccount.js +3 -3
  110. package/lib/constants.d.ts +0 -1
  111. package/lib/constants.js +0 -1
  112. package/lib/doctor/Diagnosis.js +5 -5
  113. package/lib/doctor/Doctor.js +2 -2
  114. package/lib/errorHandlers/index.js +4 -3
  115. package/lib/errorHandlers/suppressError.js +4 -0
  116. package/lib/errors/PromptExitError.d.ts +4 -2
  117. package/lib/errors/PromptExitError.js +3 -0
  118. package/lib/getStartedV2Actions.js +2 -2
  119. package/lib/hasFeature.js +1 -2
  120. package/lib/middleware/autoUpdateMiddleware.js +6 -3
  121. package/lib/process.d.ts +1 -1
  122. package/lib/process.js +10 -3
  123. package/lib/projects/ProjectLogsManager.js +2 -2
  124. package/lib/projects/create/index.js +2 -2
  125. package/lib/projects/create/legacy.js +2 -2
  126. package/lib/projects/create/v2.js +3 -4
  127. package/lib/projects/delete.d.ts +13 -0
  128. package/lib/projects/delete.js +193 -0
  129. package/lib/projects/deploy.d.ts +1 -1
  130. package/lib/projects/deploy.js +2 -2
  131. package/lib/projects/localDev/AppDevModeInterface.js +11 -11
  132. package/lib/projects/localDev/DevServerManager_DEPRECATED.d.ts +3 -1
  133. package/lib/projects/localDev/DevServerManager_DEPRECATED.js +2 -2
  134. package/lib/projects/localDev/DevSessionManager.d.ts +6 -3
  135. package/lib/projects/localDev/DevSessionManager.js +31 -19
  136. package/lib/projects/localDev/LocalDevManager_DEPRECATED.d.ts +3 -0
  137. package/lib/projects/localDev/LocalDevManager_DEPRECATED.js +16 -12
  138. package/lib/projects/localDev/LocalDevProcess.js +6 -5
  139. package/lib/projects/localDev/LocalDevState.d.ts +3 -2
  140. package/lib/projects/localDev/LocalDevState.js +3 -1
  141. package/lib/projects/localDev/helpers/account.d.ts +4 -3
  142. package/lib/projects/localDev/helpers/account.js +16 -19
  143. package/lib/projects/localDev/helpers/process.d.ts +1 -1
  144. package/lib/projects/localDev/helpers/process.js +4 -10
  145. package/lib/projects/localDev/helpers/project.d.ts +4 -3
  146. package/lib/projects/localDev/helpers/project.js +31 -15
  147. package/lib/projects/projectInfo.d.ts +3 -20
  148. package/lib/projects/projectInfo.js +32 -54
  149. package/lib/projects/projectProfiles.d.ts +1 -2
  150. package/lib/projects/projectProfiles.js +5 -17
  151. package/lib/projects/upload.js +22 -3
  152. package/lib/projects/workspaces.d.ts +42 -0
  153. package/lib/projects/workspaces.js +350 -0
  154. package/lib/prompts/createApiSamplePrompt.js +4 -0
  155. package/lib/prompts/projectProfilePrompt.d.ts +2 -0
  156. package/lib/prompts/projectProfilePrompt.js +46 -0
  157. package/lib/prompts/promptUtils.js +3 -2
  158. package/lib/prompts/selectHubDBTablePrompt.js +2 -2
  159. package/lib/prompts/selectPublicAppForMigrationPrompt.js +2 -2
  160. package/lib/theme/cmsDevServerProcess.d.ts +2 -0
  161. package/lib/theme/cmsDevServerProcess.js +8 -7
  162. package/lib/ui/SpinniesManager.d.ts +1 -0
  163. package/lib/ui/SpinniesManager.js +20 -6
  164. package/lib/ui/spinniesUtils.d.ts +0 -1
  165. package/lib/ui/spinniesUtils.js +6 -16
  166. package/lib/usageTracking.d.ts +3 -4
  167. package/lib/yargs/makeYargsBuilder.d.ts +13 -0
  168. package/lib/yargs/makeYargsBuilder.js +33 -0
  169. package/lib/yargs/makeYargsHandlerWithUsageTracking.d.ts +3 -0
  170. package/lib/yargs/makeYargsHandlerWithUsageTracking.js +95 -0
  171. package/lib/yargs/strictEnforceBoolean.d.ts +1 -0
  172. package/lib/yargs/strictEnforceBoolean.js +13 -0
  173. package/lib/yargsUtils.d.ts +3 -16
  174. package/lib/yargsUtils.js +3 -48
  175. package/mcp-server/Tool.d.ts +15 -0
  176. package/mcp-server/Tool.js +53 -0
  177. package/mcp-server/server.js +5 -3
  178. package/mcp-server/tools/cms/HsCreateFunctionTool.d.ts +4 -2
  179. package/mcp-server/tools/cms/HsCreateFunctionTool.js +8 -6
  180. package/mcp-server/tools/cms/HsCreateModuleTool.d.ts +4 -2
  181. package/mcp-server/tools/cms/HsCreateModuleTool.js +8 -6
  182. package/mcp-server/tools/cms/HsCreateTemplateTool.d.ts +5 -3
  183. package/mcp-server/tools/cms/HsCreateTemplateTool.js +8 -6
  184. package/mcp-server/tools/cms/HsFunctionLogsTool.d.ts +4 -2
  185. package/mcp-server/tools/cms/HsFunctionLogsTool.js +8 -6
  186. package/mcp-server/tools/cms/HsListFunctionsTool.d.ts +4 -2
  187. package/mcp-server/tools/cms/HsListFunctionsTool.js +8 -6
  188. package/mcp-server/tools/cms/HsListTool.d.ts +4 -2
  189. package/mcp-server/tools/cms/HsListTool.js +8 -6
  190. package/mcp-server/tools/index.d.ts +3 -2
  191. package/mcp-server/tools/index.js +22 -22
  192. package/mcp-server/tools/project/AddFeatureToProjectTool.d.ts +6 -4
  193. package/mcp-server/tools/project/AddFeatureToProjectTool.js +8 -6
  194. package/mcp-server/tools/project/CreateProjectTool.d.ts +6 -4
  195. package/mcp-server/tools/project/CreateProjectTool.js +9 -7
  196. package/mcp-server/tools/project/CreateTestAccountTool.d.ts +4 -2
  197. package/mcp-server/tools/project/CreateTestAccountTool.js +20 -8
  198. package/mcp-server/tools/project/DeployProjectTool.d.ts +4 -2
  199. package/mcp-server/tools/project/DeployProjectTool.js +4 -6
  200. package/mcp-server/tools/project/DocFetchTool.d.ts +4 -2
  201. package/mcp-server/tools/project/DocFetchTool.js +8 -6
  202. package/mcp-server/tools/project/DocsSearchTool.d.ts +9 -3
  203. package/mcp-server/tools/project/DocsSearchTool.js +32 -9
  204. package/mcp-server/tools/project/GetApiUsagePatternsByAppIdTool.d.ts +4 -2
  205. package/mcp-server/tools/project/GetApiUsagePatternsByAppIdTool.js +8 -6
  206. package/mcp-server/tools/project/GetApplicationInfoTool.d.ts +4 -2
  207. package/mcp-server/tools/project/GetApplicationInfoTool.js +8 -6
  208. package/mcp-server/tools/project/GetBuildLogsTool.d.ts +4 -2
  209. package/mcp-server/tools/project/GetBuildLogsTool.js +8 -6
  210. package/mcp-server/tools/project/GetBuildStatusTool.d.ts +4 -2
  211. package/mcp-server/tools/project/GetBuildStatusTool.js +8 -6
  212. package/mcp-server/tools/project/GetConfigValuesTool.d.ts +4 -2
  213. package/mcp-server/tools/project/GetConfigValuesTool.js +12 -7
  214. package/mcp-server/tools/project/GuidedWalkthroughTool.d.ts +4 -2
  215. package/mcp-server/tools/project/GuidedWalkthroughTool.js +4 -6
  216. package/mcp-server/tools/project/UploadProjectTools.d.ts +4 -2
  217. package/mcp-server/tools/project/UploadProjectTools.js +9 -7
  218. package/mcp-server/tools/project/ValidateProjectTool.d.ts +4 -2
  219. package/mcp-server/tools/project/ValidateProjectTool.js +8 -6
  220. package/mcp-server/tools/project/constants.d.ts +2 -2
  221. package/mcp-server/types.d.ts +0 -7
  222. package/mcp-server/types.js +1 -13
  223. package/mcp-server/utils/logger.d.ts +10 -0
  224. package/mcp-server/utils/logger.js +29 -0
  225. package/mcp-server/utils/toolUsageTracking.js +0 -2
  226. package/package.json +12 -7
  227. package/types/LocalDev.d.ts +5 -0
  228. package/types/Projects.d.ts +19 -0
  229. package/types/Yargs.d.ts +18 -1
  230. package/api/__tests__/migrate.test.d.ts +0 -1
  231. package/api/__tests__/migrate.test.js +0 -199
  232. package/commands/__tests__/account.test.d.ts +0 -1
  233. package/commands/__tests__/account.test.js +0 -69
  234. package/commands/__tests__/auth.test.d.ts +0 -1
  235. package/commands/__tests__/auth.test.js +0 -43
  236. package/commands/__tests__/cms.test.d.ts +0 -1
  237. package/commands/__tests__/cms.test.js +0 -87
  238. package/commands/__tests__/config.test.d.ts +0 -1
  239. package/commands/__tests__/config.test.js +0 -44
  240. package/commands/__tests__/customObject.test.d.ts +0 -1
  241. package/commands/__tests__/customObject.test.js +0 -68
  242. package/commands/__tests__/doctor.test.d.ts +0 -1
  243. package/commands/__tests__/doctor.test.js +0 -132
  244. package/commands/__tests__/feedback.test.d.ts +0 -1
  245. package/commands/__tests__/feedback.test.js +0 -24
  246. package/commands/__tests__/filemanager.test.d.ts +0 -1
  247. package/commands/__tests__/filemanager.test.js +0 -45
  248. package/commands/__tests__/getStarted.test.d.ts +0 -1
  249. package/commands/__tests__/getStarted.test.js +0 -173
  250. package/commands/__tests__/hubdb.test.d.ts +0 -1
  251. package/commands/__tests__/hubdb.test.js +0 -50
  252. package/commands/__tests__/init.test.d.ts +0 -1
  253. package/commands/__tests__/init.test.js +0 -42
  254. package/commands/__tests__/mcp.test.d.ts +0 -1
  255. package/commands/__tests__/mcp.test.js +0 -46
  256. package/commands/__tests__/open.test.d.ts +0 -1
  257. package/commands/__tests__/open.test.js +0 -58
  258. package/commands/__tests__/project.test.d.ts +0 -1
  259. package/commands/__tests__/project.test.js +0 -125
  260. package/commands/__tests__/sandbox.test.d.ts +0 -1
  261. package/commands/__tests__/sandbox.test.js +0 -44
  262. package/commands/__tests__/secret.test.d.ts +0 -1
  263. package/commands/__tests__/secret.test.js +0 -49
  264. package/commands/__tests__/testAccount.test.d.ts +0 -1
  265. package/commands/__tests__/testAccount.test.js +0 -57
  266. package/commands/__tests__/upgrade.test.d.ts +0 -1
  267. package/commands/__tests__/upgrade.test.js +0 -309
  268. package/commands/account/__tests__/auth.test.d.ts +0 -1
  269. package/commands/account/__tests__/auth.test.js +0 -206
  270. package/commands/account/__tests__/clean.test.d.ts +0 -1
  271. package/commands/account/__tests__/clean.test.js +0 -28
  272. package/commands/account/__tests__/createOverride.test.d.ts +0 -1
  273. package/commands/account/__tests__/createOverride.test.js +0 -32
  274. package/commands/account/__tests__/info.test.d.ts +0 -1
  275. package/commands/account/__tests__/info.test.js +0 -28
  276. package/commands/account/__tests__/list.test.d.ts +0 -1
  277. package/commands/account/__tests__/list.test.js +0 -153
  278. package/commands/account/__tests__/remove.test.d.ts +0 -1
  279. package/commands/account/__tests__/remove.test.js +0 -36
  280. package/commands/account/__tests__/removeOverride.d.ts +0 -1
  281. package/commands/account/__tests__/removeOverride.js +0 -25
  282. package/commands/account/__tests__/rename.test.d.ts +0 -1
  283. package/commands/account/__tests__/rename.test.js +0 -82
  284. package/commands/account/__tests__/use.test.d.ts +0 -1
  285. package/commands/account/__tests__/use.test.js +0 -170
  286. package/commands/app/__tests__/migrate.test.d.ts +0 -1
  287. package/commands/app/__tests__/migrate.test.js +0 -111
  288. package/commands/app/secret/__tests__/add.test.d.ts +0 -1
  289. package/commands/app/secret/__tests__/add.test.js +0 -140
  290. package/commands/app/secret/__tests__/delete.test.d.ts +0 -1
  291. package/commands/app/secret/__tests__/delete.test.js +0 -28
  292. package/commands/app/secret/__tests__/list.test.d.ts +0 -1
  293. package/commands/app/secret/__tests__/list.test.js +0 -25
  294. package/commands/app/secret/__tests__/update.test.d.ts +0 -1
  295. package/commands/app/secret/__tests__/update.test.js +0 -28
  296. package/commands/cms/__tests__/delete.test.d.ts +0 -1
  297. package/commands/cms/__tests__/delete.test.js +0 -39
  298. package/commands/cms/__tests__/fetch.test.d.ts +0 -1
  299. package/commands/cms/__tests__/fetch.test.js +0 -156
  300. package/commands/cms/__tests__/function.test.d.ts +0 -1
  301. package/commands/cms/__tests__/function.test.js +0 -50
  302. package/commands/cms/__tests__/lint.test.d.ts +0 -1
  303. package/commands/cms/__tests__/lint.test.js +0 -33
  304. package/commands/cms/__tests__/list.test.d.ts +0 -1
  305. package/commands/cms/__tests__/list.test.js +0 -42
  306. package/commands/cms/__tests__/module.test.d.ts +0 -1
  307. package/commands/cms/__tests__/module.test.js +0 -45
  308. package/commands/cms/__tests__/mv.test.d.ts +0 -1
  309. package/commands/cms/__tests__/mv.test.js +0 -46
  310. package/commands/cms/__tests__/theme.test.d.ts +0 -1
  311. package/commands/cms/__tests__/theme.test.js +0 -54
  312. package/commands/cms/__tests__/upload.test.d.ts +0 -1
  313. package/commands/cms/__tests__/upload.test.js +0 -312
  314. package/commands/cms/__tests__/watch.test.d.ts +0 -1
  315. package/commands/cms/__tests__/watch.test.js +0 -204
  316. package/commands/cms/function/__tests__/logs.test.d.ts +0 -1
  317. package/commands/cms/function/__tests__/logs.test.js +0 -70
  318. package/commands/cms/theme/__tests__/generate-selectors.test.d.ts +0 -1
  319. package/commands/cms/theme/__tests__/generate-selectors.test.js +0 -28
  320. package/commands/cms/theme/__tests__/marketplace-validate.test.d.ts +0 -1
  321. package/commands/cms/theme/__tests__/marketplace-validate.test.js +0 -36
  322. package/commands/cms/theme/__tests__/preview.test.d.ts +0 -1
  323. package/commands/cms/theme/__tests__/preview.test.js +0 -54
  324. package/commands/customObject/__tests__/create.test.d.ts +0 -1
  325. package/commands/customObject/__tests__/create.test.js +0 -40
  326. package/commands/customObject/__tests__/createSchema.test.d.ts +0 -1
  327. package/commands/customObject/__tests__/createSchema.test.js +0 -28
  328. package/commands/customObject/__tests__/deleteSchema.test.d.ts +0 -1
  329. package/commands/customObject/__tests__/deleteSchema.test.js +0 -42
  330. package/commands/customObject/__tests__/fetch-all-schemas.test.d.ts +0 -1
  331. package/commands/customObject/__tests__/fetch-all-schemas.test.js +0 -41
  332. package/commands/customObject/__tests__/fetchSchema.test.d.ts +0 -1
  333. package/commands/customObject/__tests__/fetchSchema.test.js +0 -45
  334. package/commands/customObject/__tests__/listSchemas.test.d.ts +0 -1
  335. package/commands/customObject/__tests__/listSchemas.test.js +0 -29
  336. package/commands/customObject/__tests__/updateSchema.test.d.ts +0 -1
  337. package/commands/customObject/__tests__/updateSchema.test.js +0 -40
  338. package/commands/filemanager/__tests__/fetch.test.d.ts +0 -1
  339. package/commands/filemanager/__tests__/fetch.test.js +0 -32
  340. package/commands/filemanager/__tests__/upload.test.d.ts +0 -1
  341. package/commands/filemanager/__tests__/upload.test.js +0 -191
  342. package/commands/hubdb/__tests__/clear.test.d.ts +0 -1
  343. package/commands/hubdb/__tests__/clear.test.js +0 -28
  344. package/commands/hubdb/__tests__/create.test.d.ts +0 -1
  345. package/commands/hubdb/__tests__/create.test.js +0 -28
  346. package/commands/hubdb/__tests__/delete.test.d.ts +0 -1
  347. package/commands/hubdb/__tests__/delete.test.js +0 -28
  348. package/commands/hubdb/__tests__/fetch.test.d.ts +0 -1
  349. package/commands/hubdb/__tests__/fetch.test.js +0 -28
  350. package/commands/hubdb/__tests__/list.test.d.ts +0 -1
  351. package/commands/hubdb/__tests__/list.test.js +0 -88
  352. package/commands/mcp/__tests__/setup.test.d.ts +0 -1
  353. package/commands/mcp/__tests__/setup.test.js +0 -26
  354. package/commands/mcp/__tests__/start.test.d.ts +0 -1
  355. package/commands/mcp/__tests__/start.test.js +0 -144
  356. package/commands/project/__tests__/add.test.d.ts +0 -1
  357. package/commands/project/__tests__/add.test.js +0 -107
  358. package/commands/project/__tests__/create.test.d.ts +0 -1
  359. package/commands/project/__tests__/create.test.js +0 -97
  360. package/commands/project/__tests__/deploy.test.d.ts +0 -1
  361. package/commands/project/__tests__/deploy.test.js +0 -307
  362. package/commands/project/__tests__/dev.test.d.ts +0 -1
  363. package/commands/project/__tests__/dev.test.js +0 -273
  364. package/commands/project/__tests__/devUnifiedFlow.test.d.ts +0 -1
  365. package/commands/project/__tests__/devUnifiedFlow.test.js +0 -434
  366. package/commands/project/__tests__/download.test.d.ts +0 -1
  367. package/commands/project/__tests__/download.test.js +0 -39
  368. package/commands/project/__tests__/info.test.d.ts +0 -1
  369. package/commands/project/__tests__/info.test.js +0 -145
  370. package/commands/project/__tests__/installDeps.test.d.ts +0 -1
  371. package/commands/project/__tests__/installDeps.test.js +0 -140
  372. package/commands/project/__tests__/lint.test.d.ts +0 -1
  373. package/commands/project/__tests__/lint.test.js +0 -704
  374. package/commands/project/__tests__/list.test.d.ts +0 -1
  375. package/commands/project/__tests__/list.test.js +0 -31
  376. package/commands/project/__tests__/listBuilds.test.d.ts +0 -1
  377. package/commands/project/__tests__/listBuilds.test.js +0 -38
  378. package/commands/project/__tests__/logs.test.d.ts +0 -1
  379. package/commands/project/__tests__/logs.test.js +0 -202
  380. package/commands/project/__tests__/migrate.test.d.ts +0 -1
  381. package/commands/project/__tests__/migrate.test.js +0 -106
  382. package/commands/project/__tests__/open.test.d.ts +0 -1
  383. package/commands/project/__tests__/open.test.js +0 -39
  384. package/commands/project/__tests__/profile.test.d.ts +0 -1
  385. package/commands/project/__tests__/profile.test.js +0 -42
  386. package/commands/project/__tests__/updateDeps.test.d.ts +0 -1
  387. package/commands/project/__tests__/updateDeps.test.js +0 -140
  388. package/commands/project/__tests__/upload.test.d.ts +0 -1
  389. package/commands/project/__tests__/upload.test.js +0 -234
  390. package/commands/project/__tests__/validate.test.d.ts +0 -1
  391. package/commands/project/__tests__/validate.test.js +0 -381
  392. package/commands/project/__tests__/watch.test.d.ts +0 -1
  393. package/commands/project/__tests__/watch.test.js +0 -35
  394. package/commands/sandbox/__tests__/create.test.d.ts +0 -1
  395. package/commands/sandbox/__tests__/create.test.js +0 -198
  396. package/commands/sandbox/__tests__/delete.test.d.ts +0 -1
  397. package/commands/sandbox/__tests__/delete.test.js +0 -31
  398. package/commands/secret/__tests__/addSecret.test.d.ts +0 -1
  399. package/commands/secret/__tests__/addSecret.test.js +0 -162
  400. package/commands/secret/__tests__/deleteSecret.test.d.ts +0 -1
  401. package/commands/secret/__tests__/deleteSecret.test.js +0 -41
  402. package/commands/secret/__tests__/listSecret.test.d.ts +0 -1
  403. package/commands/secret/__tests__/listSecret.test.js +0 -29
  404. package/commands/secret/__tests__/updateSecret.test.d.ts +0 -1
  405. package/commands/secret/__tests__/updateSecret.test.js +0 -29
  406. package/commands/testAccount/__tests__/create.test.d.ts +0 -1
  407. package/commands/testAccount/__tests__/create.test.js +0 -106
  408. package/commands/testAccount/__tests__/createConfig.test.d.ts +0 -1
  409. package/commands/testAccount/__tests__/createConfig.test.js +0 -32
  410. package/commands/testAccount/__tests__/delete.test.d.ts +0 -1
  411. package/commands/testAccount/__tests__/delete.test.js +0 -29
  412. package/commands/testAccount/__tests__/importData.test.d.ts +0 -1
  413. package/commands/testAccount/__tests__/importData.test.js +0 -92
  414. package/lib/__tests__/CLIWebSocketServer.test.d.ts +0 -1
  415. package/lib/__tests__/CLIWebSocketServer.test.js +0 -252
  416. package/lib/__tests__/accountAuth.test.d.ts +0 -1
  417. package/lib/__tests__/accountAuth.test.js +0 -258
  418. package/lib/__tests__/accountTypes.test.d.ts +0 -1
  419. package/lib/__tests__/accountTypes.test.js +0 -98
  420. package/lib/__tests__/buildAccount.test.d.ts +0 -1
  421. package/lib/__tests__/buildAccount.test.js +0 -211
  422. package/lib/__tests__/cliUpgradeUtils.test.d.ts +0 -1
  423. package/lib/__tests__/cliUpgradeUtils.test.js +0 -131
  424. package/lib/__tests__/commandSuggestion.test.d.ts +0 -1
  425. package/lib/__tests__/commandSuggestion.test.js +0 -121
  426. package/lib/__tests__/commonOpts.test.d.ts +0 -1
  427. package/lib/__tests__/commonOpts.test.js +0 -80
  428. package/lib/__tests__/dependencyManagement.test.d.ts +0 -1
  429. package/lib/__tests__/dependencyManagement.test.js +0 -1067
  430. package/lib/__tests__/developerTestAccounts.test.d.ts +0 -1
  431. package/lib/__tests__/developerTestAccounts.test.js +0 -156
  432. package/lib/__tests__/hasFeature.test.d.ts +0 -1
  433. package/lib/__tests__/hasFeature.test.js +0 -167
  434. package/lib/__tests__/http.test.d.ts +0 -1
  435. package/lib/__tests__/http.test.js +0 -40
  436. package/lib/__tests__/importData.test.d.ts +0 -1
  437. package/lib/__tests__/importData.test.js +0 -98
  438. package/lib/__tests__/npmCli.test.d.ts +0 -1
  439. package/lib/__tests__/npmCli.test.js +0 -84
  440. package/lib/__tests__/oauth.test.d.ts +0 -1
  441. package/lib/__tests__/oauth.test.js +0 -109
  442. package/lib/__tests__/parsing.test.d.ts +0 -1
  443. package/lib/__tests__/parsing.test.js +0 -34
  444. package/lib/__tests__/polling.test.d.ts +0 -1
  445. package/lib/__tests__/polling.test.js +0 -76
  446. package/lib/__tests__/process.test.d.ts +0 -1
  447. package/lib/__tests__/process.test.js +0 -89
  448. package/lib/__tests__/sandboxes.test.d.ts +0 -1
  449. package/lib/__tests__/sandboxes.test.js +0 -128
  450. package/lib/__tests__/serverlessLogs.test.d.ts +0 -1
  451. package/lib/__tests__/serverlessLogs.test.js +0 -163
  452. package/lib/__tests__/usageTracking.test.d.ts +0 -1
  453. package/lib/__tests__/usageTracking.test.js +0 -197
  454. package/lib/__tests__/validation.test.d.ts +0 -1
  455. package/lib/__tests__/validation.test.js +0 -143
  456. package/lib/__tests__/yargsUtils.test.d.ts +0 -1
  457. package/lib/__tests__/yargsUtils.test.js +0 -124
  458. package/lib/app/__tests__/migrate.test.d.ts +0 -1
  459. package/lib/app/__tests__/migrate.test.js +0 -638
  460. package/lib/doctor/__tests__/Diagnosis.test.d.ts +0 -1
  461. package/lib/doctor/__tests__/Diagnosis.test.js +0 -84
  462. package/lib/doctor/__tests__/DiagnosticInfoBuilder.test.d.ts +0 -1
  463. package/lib/doctor/__tests__/DiagnosticInfoBuilder.test.js +0 -177
  464. package/lib/doctor/__tests__/Doctor.test.d.ts +0 -1
  465. package/lib/doctor/__tests__/Doctor.test.js +0 -560
  466. package/lib/errorHandlers/__tests__/index.test.d.ts +0 -1
  467. package/lib/errorHandlers/__tests__/index.test.js +0 -278
  468. package/lib/mcp/__tests__/setup.test.d.ts +0 -1
  469. package/lib/mcp/__tests__/setup.test.js +0 -523
  470. package/lib/middleware/__tests__/commandTargetingUtils.test.d.ts +0 -1
  471. package/lib/middleware/__tests__/commandTargetingUtils.test.js +0 -99
  472. package/lib/middleware/__tests__/configMiddleware.test.d.ts +0 -1
  473. package/lib/middleware/__tests__/configMiddleware.test.js +0 -118
  474. package/lib/middleware/__tests__/gitMiddleware.test.d.ts +0 -1
  475. package/lib/middleware/__tests__/gitMiddleware.test.js +0 -43
  476. package/lib/middleware/__tests__/requestMiddleware.test.d.ts +0 -1
  477. package/lib/middleware/__tests__/requestMiddleware.test.js +0 -15
  478. package/lib/middleware/__tests__/usageTrackingMiddleware.test.d.ts +0 -1
  479. package/lib/middleware/__tests__/usageTrackingMiddleware.test.js +0 -44
  480. package/lib/middleware/__tests__/yargsChecksMiddleware.test.d.ts +0 -1
  481. package/lib/middleware/__tests__/yargsChecksMiddleware.test.js +0 -39
  482. package/lib/projects/__tests__/AppDevModeInterface.test.d.ts +0 -1
  483. package/lib/projects/__tests__/AppDevModeInterface.test.js +0 -541
  484. package/lib/projects/__tests__/DevServerManager.test.d.ts +0 -1
  485. package/lib/projects/__tests__/DevServerManager.test.js +0 -185
  486. package/lib/projects/__tests__/DevSessionManager.test.d.ts +0 -1
  487. package/lib/projects/__tests__/DevSessionManager.test.js +0 -250
  488. package/lib/projects/__tests__/LocalDevProcess.test.d.ts +0 -1
  489. package/lib/projects/__tests__/LocalDevProcess.test.js +0 -481
  490. package/lib/projects/__tests__/LocalDevWebsocketServer.test.d.ts +0 -1
  491. package/lib/projects/__tests__/LocalDevWebsocketServer.test.js +0 -231
  492. package/lib/projects/__tests__/ProjectLogsManager.test.d.ts +0 -1
  493. package/lib/projects/__tests__/ProjectLogsManager.test.js +0 -302
  494. package/lib/projects/__tests__/UIExtensionsDevModeInterface.test.d.ts +0 -1
  495. package/lib/projects/__tests__/UIExtensionsDevModeInterface.test.js +0 -160
  496. package/lib/projects/__tests__/components.test.d.ts +0 -1
  497. package/lib/projects/__tests__/components.test.js +0 -440
  498. package/lib/projects/__tests__/deploy.test.d.ts +0 -1
  499. package/lib/projects/__tests__/deploy.test.js +0 -231
  500. package/lib/projects/__tests__/localDevProjectHelpers.test.d.ts +0 -1
  501. package/lib/projects/__tests__/localDevProjectHelpers.test.js +0 -120
  502. package/lib/projects/__tests__/platformVersion.test.d.ts +0 -1
  503. package/lib/projects/__tests__/platformVersion.test.js +0 -63
  504. package/lib/projects/__tests__/pollProjectBuildAndDeploy.test.d.ts +0 -1
  505. package/lib/projects/__tests__/pollProjectBuildAndDeploy.test.js +0 -328
  506. package/lib/projects/__tests__/projectInfo.test.d.ts +0 -1
  507. package/lib/projects/__tests__/projectInfo.test.js +0 -114
  508. package/lib/projects/__tests__/projectProfiles.test.d.ts +0 -1
  509. package/lib/projects/__tests__/projectProfiles.test.js +0 -441
  510. package/lib/projects/__tests__/projects.test.d.ts +0 -1
  511. package/lib/projects/__tests__/projects.test.js +0 -58
  512. package/lib/projects/__tests__/structure.test.d.ts +0 -1
  513. package/lib/projects/__tests__/structure.test.js +0 -210
  514. package/lib/projects/__tests__/uieLinting.test.d.ts +0 -1
  515. package/lib/projects/__tests__/uieLinting.test.js +0 -631
  516. package/lib/projects/__tests__/upload.test.d.ts +0 -1
  517. package/lib/projects/__tests__/upload.test.js +0 -183
  518. package/lib/projects/add/__tests__/legacyAddComponent.test.d.ts +0 -1
  519. package/lib/projects/add/__tests__/legacyAddComponent.test.js +0 -245
  520. package/lib/projects/add/__tests__/v2AddComponent.test.d.ts +0 -1
  521. package/lib/projects/add/__tests__/v2AddComponent.test.js +0 -343
  522. package/lib/projects/create/__tests__/legacy.test.d.ts +0 -1
  523. package/lib/projects/create/__tests__/legacy.test.js +0 -72
  524. package/lib/projects/create/__tests__/v2.test.d.ts +0 -1
  525. package/lib/projects/create/__tests__/v2.test.js +0 -257
  526. package/lib/projects/platformVersion.d.ts +0 -9
  527. package/lib/projects/platformVersion.js +0 -39
  528. package/lib/prompts/__tests__/createDeveloperTestAccountConfigPrompt.test.d.ts +0 -1
  529. package/lib/prompts/__tests__/createDeveloperTestAccountConfigPrompt.test.js +0 -157
  530. package/lib/prompts/__tests__/createFunctionPrompt.test.d.ts +0 -1
  531. package/lib/prompts/__tests__/createFunctionPrompt.test.js +0 -129
  532. package/lib/prompts/__tests__/createModulePrompt.test.d.ts +0 -1
  533. package/lib/prompts/__tests__/createModulePrompt.test.js +0 -187
  534. package/lib/prompts/__tests__/createTemplatePrompt.test.d.ts +0 -1
  535. package/lib/prompts/__tests__/createTemplatePrompt.test.js +0 -102
  536. package/lib/prompts/__tests__/downloadProjectPrompt.test.d.ts +0 -1
  537. package/lib/prompts/__tests__/downloadProjectPrompt.test.js +0 -31
  538. package/lib/prompts/__tests__/projectAddPrompt.test.d.ts +0 -1
  539. package/lib/prompts/__tests__/projectAddPrompt.test.js +0 -143
  540. package/lib/prompts/__tests__/projectsLogsPrompt.test.d.ts +0 -1
  541. package/lib/prompts/__tests__/projectsLogsPrompt.test.js +0 -37
  542. package/lib/prompts/__tests__/selectProjectTemplatePrompt.test.d.ts +0 -1
  543. package/lib/prompts/__tests__/selectProjectTemplatePrompt.test.js +0 -160
  544. package/lib/theme/__tests__/migrate.test.d.ts +0 -1
  545. package/lib/theme/__tests__/migrate.test.js +0 -247
  546. package/lib/ui/__tests__/SpinniesManager.test.d.ts +0 -1
  547. package/lib/ui/__tests__/SpinniesManager.test.js +0 -488
  548. package/lib/ui/__tests__/removeAnsiCodes.test.d.ts +0 -1
  549. package/lib/ui/__tests__/removeAnsiCodes.test.js +0 -84
  550. package/mcp-server/tools/cms/__tests__/HsCreateFunctionTool.test.d.ts +0 -1
  551. package/mcp-server/tools/cms/__tests__/HsCreateFunctionTool.test.js +0 -254
  552. package/mcp-server/tools/cms/__tests__/HsCreateModuleTool.test.d.ts +0 -1
  553. package/mcp-server/tools/cms/__tests__/HsCreateModuleTool.test.js +0 -227
  554. package/mcp-server/tools/cms/__tests__/HsCreateTemplateTool.test.d.ts +0 -1
  555. package/mcp-server/tools/cms/__tests__/HsCreateTemplateTool.test.js +0 -208
  556. package/mcp-server/tools/cms/__tests__/HsFunctionLogsTool.test.d.ts +0 -1
  557. package/mcp-server/tools/cms/__tests__/HsFunctionLogsTool.test.js +0 -186
  558. package/mcp-server/tools/cms/__tests__/HsListFunctionsTool.test.d.ts +0 -1
  559. package/mcp-server/tools/cms/__tests__/HsListFunctionsTool.test.js +0 -124
  560. package/mcp-server/tools/cms/__tests__/HsListTool.test.d.ts +0 -1
  561. package/mcp-server/tools/cms/__tests__/HsListTool.test.js +0 -124
  562. package/mcp-server/tools/project/__tests__/AddFeatureToProjectTool.test.d.ts +0 -1
  563. package/mcp-server/tools/project/__tests__/AddFeatureToProjectTool.test.js +0 -157
  564. package/mcp-server/tools/project/__tests__/CreateProjectTool.test.d.ts +0 -1
  565. package/mcp-server/tools/project/__tests__/CreateProjectTool.test.js +0 -131
  566. package/mcp-server/tools/project/__tests__/CreateTestAccountTool.test.d.ts +0 -1
  567. package/mcp-server/tools/project/__tests__/CreateTestAccountTool.test.js +0 -461
  568. package/mcp-server/tools/project/__tests__/DeployProjectTool.test.d.ts +0 -1
  569. package/mcp-server/tools/project/__tests__/DeployProjectTool.test.js +0 -125
  570. package/mcp-server/tools/project/__tests__/DocFetchTool.test.d.ts +0 -1
  571. package/mcp-server/tools/project/__tests__/DocFetchTool.test.js +0 -125
  572. package/mcp-server/tools/project/__tests__/DocsSearchTool.test.d.ts +0 -1
  573. package/mcp-server/tools/project/__tests__/DocsSearchTool.test.js +0 -210
  574. package/mcp-server/tools/project/__tests__/GetApiUsagePatternsByAppIdTool.test.d.ts +0 -1
  575. package/mcp-server/tools/project/__tests__/GetApiUsagePatternsByAppIdTool.test.js +0 -146
  576. package/mcp-server/tools/project/__tests__/GetApplicationInfoTool.test.d.ts +0 -1
  577. package/mcp-server/tools/project/__tests__/GetApplicationInfoTool.test.js +0 -124
  578. package/mcp-server/tools/project/__tests__/GetBuildLogsTool.test.d.ts +0 -1
  579. package/mcp-server/tools/project/__tests__/GetBuildLogsTool.test.js +0 -307
  580. package/mcp-server/tools/project/__tests__/GetBuildStatusTool.test.d.ts +0 -1
  581. package/mcp-server/tools/project/__tests__/GetBuildStatusTool.test.js +0 -242
  582. package/mcp-server/tools/project/__tests__/GetConfigValuesTool.test.d.ts +0 -1
  583. package/mcp-server/tools/project/__tests__/GetConfigValuesTool.test.js +0 -209
  584. package/mcp-server/tools/project/__tests__/GuidedWalkthroughTool.test.d.ts +0 -1
  585. package/mcp-server/tools/project/__tests__/GuidedWalkthroughTool.test.js +0 -158
  586. package/mcp-server/tools/project/__tests__/UploadProjectTools.test.d.ts +0 -1
  587. package/mcp-server/tools/project/__tests__/UploadProjectTools.test.js +0 -187
  588. package/mcp-server/tools/project/__tests__/ValidateProjectTool.test.d.ts +0 -1
  589. package/mcp-server/tools/project/__tests__/ValidateProjectTool.test.js +0 -118
  590. package/mcp-server/utils/__tests__/command.test.d.ts +0 -1
  591. package/mcp-server/utils/__tests__/command.test.js +0 -275
  592. package/mcp-server/utils/__tests__/content.test.d.ts +0 -1
  593. package/mcp-server/utils/__tests__/content.test.js +0 -164
  594. package/mcp-server/utils/__tests__/feedbackTracking.test.d.ts +0 -1
  595. package/mcp-server/utils/__tests__/feedbackTracking.test.js +0 -69
@@ -1,160 +0,0 @@
1
- import { vi, describe, it, expect, beforeEach } from 'vitest';
2
- import UIExtensionsDevModeInterface from '../localDev/UIExtensionsDevModeInterface.js';
3
- import LocalDevState from '../localDev/LocalDevState.js';
4
- import { DevModeUnifiedInterface } from '@hubspot/ui-extensions-dev-server';
5
- import { requestPorts } from '@hubspot/local-dev-lib/portManager';
6
- import { logger } from '@hubspot/local-dev-lib/logger';
7
- import { getHubSpotApiOrigin, getHubSpotWebsiteOrigin, } from '@hubspot/local-dev-lib/urls';
8
- import { ENVIRONMENTS } from '@hubspot/local-dev-lib/constants/environments';
9
- vi.mock('@hubspot/ui-extensions-dev-server', () => ({
10
- DevModeUnifiedInterface: {
11
- setup: vi.fn().mockResolvedValue(undefined),
12
- start: vi.fn().mockResolvedValue(undefined),
13
- fileChange: vi.fn().mockResolvedValue(undefined),
14
- cleanup: vi.fn().mockResolvedValue(undefined),
15
- },
16
- }));
17
- vi.mock('@hubspot/local-dev-lib/portManager', () => ({
18
- requestPorts: vi.fn().mockResolvedValue({ 'test-port': 8080 }),
19
- }));
20
- vi.mock('@hubspot/local-dev-lib/urls', () => ({
21
- getHubSpotApiOrigin: vi.fn().mockReturnValue('https://api.hubspot.com'),
22
- getHubSpotWebsiteOrigin: vi.fn().mockReturnValue('https://app.hubspot.com'),
23
- }));
24
- describe('UIExtensionsDevModeInterface', () => {
25
- let uiExtensionsInterface;
26
- let mockLocalDevState;
27
- beforeEach(() => {
28
- vi.mocked(DevModeUnifiedInterface.setup).mockResolvedValue(undefined);
29
- vi.mocked(DevModeUnifiedInterface.start).mockResolvedValue(undefined);
30
- vi.mocked(DevModeUnifiedInterface.fileChange).mockResolvedValue(undefined);
31
- vi.mocked(DevModeUnifiedInterface.cleanup).mockResolvedValue(undefined);
32
- mockLocalDevState = new LocalDevState({
33
- targetProjectAccountId: 123,
34
- targetTestingAccountId: 456,
35
- projectConfig: {
36
- name: 'test-ui-extensions-project',
37
- srcDir: 'src',
38
- platformVersion: '1.0.0',
39
- },
40
- projectDir: '/test/ui-extensions-project',
41
- projectData: {
42
- name: 'test-ui-extensions-project',
43
- id: 789,
44
- createdAt: Date.now(),
45
- deletedAt: 0,
46
- isLocked: false,
47
- portalId: 123,
48
- updatedAt: Date.now(),
49
- },
50
- debug: false,
51
- initialProjectNodes: {
52
- 'test-component': {
53
- uid: 'test-component-uid',
54
- componentType: 'UI_EXTENSION',
55
- config: {
56
- name: 'Test UI Extension',
57
- type: 'card',
58
- },
59
- localDev: {
60
- componentRoot: '/test/path',
61
- componentConfigPath: '/test/path/config.json',
62
- configUpdatedSinceLastUpload: false,
63
- removed: false,
64
- parsingErrors: [],
65
- },
66
- componentDeps: {},
67
- metaFilePath: '/test/path',
68
- files: [],
69
- },
70
- },
71
- initialProjectProfileData: {
72
- testVariable: 'testValue',
73
- },
74
- profile: 'test',
75
- env: ENVIRONMENTS.QA,
76
- });
77
- uiExtensionsInterface = new UIExtensionsDevModeInterface({
78
- localDevState: mockLocalDevState,
79
- });
80
- });
81
- describe('constructor', () => {
82
- it('should store the localDevState reference', () => {
83
- expect(uiExtensionsInterface.localDevState).toBe(mockLocalDevState);
84
- });
85
- });
86
- describe('setup', () => {
87
- it('should call DevModeUnifiedInterface.setup with correct parameters', async () => {
88
- await uiExtensionsInterface.setup();
89
- expect(DevModeUnifiedInterface.setup).toHaveBeenCalledWith({
90
- components: mockLocalDevState.projectNodes,
91
- profileData: mockLocalDevState.projectProfileData,
92
- logger,
93
- urls: {
94
- api: 'https://api.hubspot.com',
95
- web: 'https://app.hubspot.com',
96
- },
97
- });
98
- });
99
- it('should use correct URLs based on environment', async () => {
100
- await uiExtensionsInterface.setup();
101
- expect(getHubSpotApiOrigin).toHaveBeenCalledWith(mockLocalDevState.env);
102
- expect(getHubSpotWebsiteOrigin).toHaveBeenCalledWith(mockLocalDevState.env);
103
- });
104
- it('should pass project nodes and profile data from state', async () => {
105
- await uiExtensionsInterface.setup();
106
- const setupCall = vi.mocked(DevModeUnifiedInterface.setup).mock
107
- .calls[0][0];
108
- expect(setupCall.components).toStrictEqual(mockLocalDevState.projectNodes);
109
- expect(setupCall.profileData).toStrictEqual(mockLocalDevState.projectProfileData);
110
- });
111
- });
112
- describe('start', () => {
113
- it('should call DevModeUnifiedInterface.start with correct parameters', async () => {
114
- await uiExtensionsInterface.start();
115
- expect(DevModeUnifiedInterface.start).toHaveBeenCalledWith({
116
- accountId: mockLocalDevState.targetTestingAccountId,
117
- projectConfig: mockLocalDevState.projectConfig,
118
- requestPorts,
119
- });
120
- });
121
- it('should use targetTestingAccountId from state', async () => {
122
- await uiExtensionsInterface.start();
123
- const startCall = vi.mocked(DevModeUnifiedInterface.start).mock
124
- .calls[0][0];
125
- expect(startCall.accountId).toBe(456); // targetTestingAccountId
126
- });
127
- it('should pass project config from state', async () => {
128
- await uiExtensionsInterface.start();
129
- const startCall = vi.mocked(DevModeUnifiedInterface.start).mock
130
- .calls[0][0];
131
- expect(startCall.projectConfig).toStrictEqual(mockLocalDevState.projectConfig);
132
- });
133
- });
134
- describe('fileChange', () => {
135
- it('should call DevModeUnifiedInterface.fileChange with correct parameters', async () => {
136
- const filePath = 'src/components/TestCard.tsx';
137
- const event = 'change';
138
- await uiExtensionsInterface.fileChange(filePath, event);
139
- expect(DevModeUnifiedInterface.fileChange).toHaveBeenCalledWith(filePath, event);
140
- });
141
- it('should handle different file events', async () => {
142
- const testCases = [
143
- { filePath: 'src/components/Card.tsx', event: 'add' },
144
- { filePath: 'src/styles/main.css', event: 'change' },
145
- { filePath: 'src/config.json', event: 'unlink' },
146
- ];
147
- for (const testCase of testCases) {
148
- await uiExtensionsInterface.fileChange(testCase.filePath, testCase.event);
149
- expect(DevModeUnifiedInterface.fileChange).toHaveBeenCalledWith(testCase.filePath, testCase.event);
150
- }
151
- expect(DevModeUnifiedInterface.fileChange).toHaveBeenCalledTimes(3);
152
- });
153
- });
154
- describe('cleanup', () => {
155
- it('should call DevModeUnifiedInterface.cleanup', async () => {
156
- await uiExtensionsInterface.cleanup();
157
- expect(DevModeUnifiedInterface.cleanup).toHaveBeenCalledWith();
158
- });
159
- });
160
- });
@@ -1 +0,0 @@
1
- export {};
@@ -1,440 +0,0 @@
1
- import fs from 'fs';
2
- import { handleComponentCollision, updateHsMetaFilesWithAutoGeneratedFields, } from '../components.js';
3
- import { uiLogger } from '../../ui/logger.js';
4
- import { coerceToValidUid } from '@hubspot/project-parsing-lib/uid';
5
- import { fileExists } from '../../validation.js';
6
- vi.mock('fs');
7
- vi.mock('../../validation.js');
8
- vi.mock('@hubspot/project-parsing-lib/uid', () => ({
9
- coerceToValidUid: vi.fn(),
10
- }));
11
- vi.mock('@hubspot/project-parsing-lib/constants', () => ({
12
- METAFILE_EXTENSION: '.module.meta.json',
13
- APP_KEY: 'app',
14
- }));
15
- const mockedFs = vi.mocked(fs);
16
- const mockCoerceToValidUid = vi.mocked(coerceToValidUid);
17
- const mockedFileExists = vi.mocked(fileExists);
18
- describe('lib/projects/components', () => {
19
- describe('handleComponentCollision()', () => {
20
- const mockCollision = {
21
- dest: '/dest/path',
22
- src: '/src/path',
23
- collisions: [],
24
- };
25
- beforeEach(() => {
26
- vi.resetAllMocks();
27
- // Default: fileExists returns false (file doesn't exist)
28
- mockedFileExists.mockReturnValue(false);
29
- });
30
- afterEach(() => {
31
- vi.restoreAllMocks();
32
- });
33
- it('handles source file collisions by renaming them with sequential numbers', () => {
34
- const collision = {
35
- ...mockCollision,
36
- collisions: ['component.js', 'utils.ts'],
37
- };
38
- mockedFs.copyFileSync.mockImplementation(() => { });
39
- handleComponentCollision(collision);
40
- expect(mockedFs.copyFileSync).toHaveBeenCalledTimes(2);
41
- expect(mockedFs.copyFileSync).toHaveBeenCalledWith('/src/path/component.js', '/dest/path/component-2.js');
42
- expect(mockedFs.copyFileSync).toHaveBeenCalledWith('/src/path/utils.ts', '/dest/path/utils-2.ts');
43
- });
44
- it('handles metafile collisions by renaming and updating references', () => {
45
- const collision = {
46
- ...mockCollision,
47
- collisions: ['component.module.meta.json', 'source.js'],
48
- };
49
- const mockMetaContent = JSON.stringify({
50
- file: 'source.js',
51
- label: 'Test Component',
52
- });
53
- mockedFs.readFileSync.mockReturnValue(mockMetaContent);
54
- mockedFs.writeFileSync.mockImplementation(() => { });
55
- mockedFs.copyFileSync.mockImplementation(() => { });
56
- handleComponentCollision(collision);
57
- expect(mockedFs.readFileSync).toHaveBeenCalledWith('/src/path/component.module.meta.json', 'utf-8');
58
- expect(mockedFs.writeFileSync).toHaveBeenCalledWith('/dest/path/component-2.module.meta.json', expect.stringContaining('source-2.js'));
59
- expect(mockedFs.copyFileSync).toHaveBeenCalledWith('/src/path/source.js', '/dest/path/source-2.js');
60
- });
61
- it('handles package.json collisions by merging dependencies', () => {
62
- const collision = {
63
- ...mockCollision,
64
- collisions: ['package.json'],
65
- };
66
- const existingPackageJson = {
67
- name: 'existing-package',
68
- dependencies: {
69
- existing: '1.0.0',
70
- shared: '1.0.0',
71
- },
72
- devDependencies: {
73
- 'existing-dev': '1.0.0',
74
- },
75
- };
76
- const newPackageJson = {
77
- name: 'new-package',
78
- dependencies: {
79
- new: '2.0.0',
80
- shared: '2.0.0',
81
- },
82
- devDependencies: {
83
- 'new-dev': '2.0.0',
84
- 'existing-dev': '2.0.0',
85
- },
86
- };
87
- mockedFs.readFileSync
88
- .mockReturnValueOnce(JSON.stringify(existingPackageJson))
89
- .mockReturnValueOnce(JSON.stringify(newPackageJson));
90
- mockedFs.writeFileSync.mockImplementation(() => { });
91
- // Mock console.log to avoid output during tests
92
- const consoleSpy = vi.spyOn(console, 'log').mockImplementation(() => { });
93
- handleComponentCollision(collision);
94
- const expectedMergedPackageJson = {
95
- name: 'existing-package',
96
- dependencies: {
97
- new: '2.0.0',
98
- shared: '1.0.0',
99
- existing: '1.0.0',
100
- },
101
- devDependencies: {
102
- 'new-dev': '2.0.0',
103
- 'existing-dev': '1.0.0',
104
- },
105
- };
106
- expect(mockedFs.writeFileSync).toHaveBeenCalledWith('/dest/path/package.json', JSON.stringify(expectedMergedPackageJson, null, 2));
107
- consoleSpy.mockRestore();
108
- });
109
- it('handles mixed collision types (source files, metafiles, and package.json)', () => {
110
- const collision = {
111
- ...mockCollision,
112
- collisions: [
113
- 'component.js',
114
- 'component.module.meta.json',
115
- 'package.json',
116
- 'utils.ts',
117
- ],
118
- };
119
- const mockMetaContent = JSON.stringify({
120
- file: 'component.js',
121
- label: 'Test Component',
122
- });
123
- const existingPackageJson = { name: 'existing' };
124
- const newPackageJson = { name: 'new', dependencies: { test: '1.0.0' } };
125
- mockedFs.readFileSync
126
- .mockReturnValueOnce(mockMetaContent)
127
- .mockReturnValueOnce(JSON.stringify(existingPackageJson))
128
- .mockReturnValueOnce(JSON.stringify(newPackageJson));
129
- mockedFs.writeFileSync.mockImplementation(() => { });
130
- mockedFs.copyFileSync.mockImplementation(() => { });
131
- const consoleSpy = vi.spyOn(console, 'log').mockImplementation(() => { });
132
- handleComponentCollision(collision);
133
- // Verify source files are copied with new names
134
- expect(mockedFs.copyFileSync).toHaveBeenCalledWith('/src/path/component.js', '/dest/path/component-2.js');
135
- expect(mockedFs.copyFileSync).toHaveBeenCalledWith('/src/path/utils.ts', '/dest/path/utils-2.ts');
136
- // Verify metafile is updated and written with new name
137
- expect(mockedFs.writeFileSync).toHaveBeenCalledWith('/dest/path/component-2.module.meta.json', expect.stringContaining('component-2.js'));
138
- // Verify package.json is merged
139
- expect(mockedFs.writeFileSync).toHaveBeenCalledWith('/dest/path/package.json', expect.stringContaining('"dependencies"'));
140
- consoleSpy.mockRestore();
141
- });
142
- it('handles empty collisions array gracefully', () => {
143
- const collision = {
144
- ...mockCollision,
145
- collisions: [],
146
- };
147
- handleComponentCollision(collision);
148
- expect(mockedFs.copyFileSync).not.toHaveBeenCalled();
149
- expect(mockedFs.readFileSync).not.toHaveBeenCalled();
150
- expect(mockedFs.writeFileSync).not.toHaveBeenCalled();
151
- });
152
- it('correctly categorizes different file types', () => {
153
- const collision = {
154
- ...mockCollision,
155
- collisions: [
156
- 'regular.js',
157
- 'nested/path/file.ts',
158
- 'component.meta.json',
159
- 'another.meta.json',
160
- 'package.json',
161
- ],
162
- };
163
- const mockMetaContent = '{}';
164
- mockedFs.readFileSync.mockReturnValue(mockMetaContent);
165
- mockedFs.writeFileSync.mockImplementation(() => { });
166
- // Track what files are being copied to debug the issue
167
- mockedFs.copyFileSync.mockImplementation(() => { });
168
- // Mock console.log for package.json handling
169
- const consoleSpy = vi.spyOn(console, 'log').mockImplementation(() => { });
170
- handleComponentCollision(collision);
171
- expect(mockedFs.readFileSync).toHaveBeenCalledTimes(2);
172
- // Should handle 2 metafiles
173
- expect(mockedFs.readFileSync).toHaveBeenCalledWith('/dest/path/package.json', 'utf-8');
174
- expect(mockedFs.readFileSync).toHaveBeenCalledWith('/src/path/package.json', 'utf-8');
175
- consoleSpy.mockRestore();
176
- });
177
- it('skips tooling config files on collision instead of renaming them', () => {
178
- const collision = {
179
- ...mockCollision,
180
- collisions: [
181
- 'src/app/cards/.prettierrc.json',
182
- 'src/app/cards/component.js',
183
- 'src/app/cards/eslint.config.js',
184
- ],
185
- };
186
- mockedFs.copyFileSync.mockImplementation(() => { });
187
- handleComponentCollision(collision);
188
- expect(mockedFs.copyFileSync).toHaveBeenCalledTimes(1);
189
- expect(mockedFs.copyFileSync).toHaveBeenCalledWith('/src/path/src/app/cards/component.js', '/dest/path/src/app/cards/component-2.js');
190
- });
191
- it('falls back to timestamp when maxAttempts is exhausted', () => {
192
- const collision = {
193
- ...mockCollision,
194
- collisions: ['component.js'],
195
- };
196
- // Mock Date.now to return a consistent timestamp
197
- const mockTimestamp = 1234567890;
198
- vi.spyOn(Date, 'now').mockReturnValue(mockTimestamp);
199
- // Mock fileExists to return true 10 times (exhausting maxAttempts)
200
- // The function starts with differentiator = 1, then increments to 2, 3, etc.
201
- // It will try 10 times (differentiators 2-11), and if all return true,
202
- // maxAttempts will be 0 and it will fall back to timestamp
203
- mockedFileExists.mockReturnValue(true);
204
- mockedFs.copyFileSync.mockImplementation(() => { });
205
- handleComponentCollision(collision);
206
- // Should use timestamp as differentiator
207
- expect(mockedFs.copyFileSync).toHaveBeenCalledWith('/src/path/component.js', `/dest/path/component-${mockTimestamp}.js`);
208
- vi.restoreAllMocks();
209
- });
210
- it('falls back to timestamp when fileExists throws an error', () => {
211
- const collision = {
212
- ...mockCollision,
213
- collisions: ['component.js'],
214
- };
215
- // Mock Date.now to return a consistent timestamp
216
- const mockTimestamp = 9876543210;
217
- vi.spyOn(Date, 'now').mockReturnValue(mockTimestamp);
218
- // Mock fileExists to throw an error
219
- const mockError = new Error('File system error');
220
- mockedFileExists.mockImplementation(() => {
221
- throw mockError;
222
- });
223
- mockedFs.copyFileSync.mockImplementation(() => { });
224
- const mockUiLogger = vi.mocked(uiLogger);
225
- handleComponentCollision(collision);
226
- // Should log debug message about the error
227
- expect(mockUiLogger.debug).toHaveBeenCalledWith('Failed to check files for filename differentiator. Falling back to timestamp.');
228
- // Should use timestamp as differentiator
229
- expect(mockedFs.copyFileSync).toHaveBeenCalledWith('/src/path/component.js', `/dest/path/component-${mockTimestamp}.js`);
230
- vi.restoreAllMocks();
231
- });
232
- });
233
- describe('updateHsMetaFilesWithAutoGeneratedFields()', () => {
234
- beforeEach(() => {
235
- vi.resetAllMocks();
236
- mockCoerceToValidUid.mockImplementation((input) => input);
237
- });
238
- afterEach(() => {
239
- vi.restoreAllMocks();
240
- });
241
- it('updates component metadata files with project-specific UIDs', () => {
242
- const projectName = 'my-project';
243
- const hsMetaFilePaths = [
244
- '/path/to/component1.meta.json',
245
- '/path/to/component2.meta.json',
246
- ];
247
- const component1 = {
248
- type: 'card',
249
- uid: 'old-uid-1',
250
- config: {
251
- name: 'Old Name',
252
- },
253
- };
254
- const component2 = {
255
- type: 'function',
256
- uid: 'old-uid-2',
257
- };
258
- mockedFs.readFileSync
259
- .mockReturnValueOnce(JSON.stringify(component1))
260
- .mockReturnValueOnce(JSON.stringify(component2));
261
- mockedFs.writeFileSync.mockImplementation(() => { });
262
- mockCoerceToValidUid
263
- .mockReturnValueOnce('card-my-project')
264
- .mockReturnValueOnce('function-my-project');
265
- updateHsMetaFilesWithAutoGeneratedFields(projectName, hsMetaFilePaths);
266
- expect(mockCoerceToValidUid).toHaveBeenCalledWith('my-project_card');
267
- expect(mockCoerceToValidUid).toHaveBeenCalledWith('my-project_function');
268
- expect(mockCoerceToValidUid).toHaveBeenCalledWith('my-project_card');
269
- expect(mockCoerceToValidUid).toHaveBeenCalledWith('my-project_function');
270
- expect(mockedFs.writeFileSync).toHaveBeenCalledWith('/path/to/component1.meta.json', JSON.stringify({
271
- type: 'card',
272
- uid: 'card_my_project',
273
- config: {
274
- name: 'Old Name',
275
- },
276
- }, null, 2));
277
- expect(mockedFs.writeFileSync).toHaveBeenCalledWith('/path/to/component2.meta.json', JSON.stringify({
278
- type: 'function',
279
- uid: 'function_my_project',
280
- }, null, 2));
281
- });
282
- it('handles app components by updating both uid and config.name', () => {
283
- const projectName = 'test-app';
284
- const hsMetaFilePaths = ['/path/to/app.meta.json'];
285
- const appComponent = {
286
- type: 'app',
287
- uid: 'old-app-uid',
288
- config: {
289
- name: 'Old App Name',
290
- other: 'property',
291
- },
292
- };
293
- mockedFs.readFileSync.mockReturnValue(JSON.stringify(appComponent));
294
- mockedFs.writeFileSync.mockImplementation(() => { });
295
- mockCoerceToValidUid.mockReturnValue('app-test-app');
296
- updateHsMetaFilesWithAutoGeneratedFields(projectName, hsMetaFilePaths);
297
- expect(mockCoerceToValidUid).toHaveBeenCalledWith('test-app_app');
298
- expect(mockedFs.writeFileSync).toHaveBeenCalledWith('/path/to/app.meta.json', JSON.stringify({
299
- type: 'app',
300
- uid: 'app_test_app',
301
- config: {
302
- name: 'test-app-App',
303
- other: 'property',
304
- },
305
- }, null, 2));
306
- });
307
- it('handles UID collisions by using differentiators', () => {
308
- const projectName = 'collision-project';
309
- const hsMetaFilePaths = ['/path/to/component1.meta.json'];
310
- const existingUids = ['card_collision_project'];
311
- const component1 = { type: 'card', uid: 'old-uid-1' };
312
- mockedFs.readFileSync.mockReturnValue(JSON.stringify(component1));
313
- mockedFs.writeFileSync.mockImplementation(() => { });
314
- // First call for getBaseUid() check, second call when adding differentiator
315
- mockCoerceToValidUid
316
- .mockReturnValueOnce('card-collision-project')
317
- .mockReturnValueOnce('card-collision-project');
318
- updateHsMetaFilesWithAutoGeneratedFields(projectName, hsMetaFilePaths, existingUids);
319
- expect(mockCoerceToValidUid).toHaveBeenCalledWith('collision-project_card');
320
- // getBaseUid() is called twice - once for initial check, once when adding differentiator
321
- expect(mockCoerceToValidUid).toHaveBeenCalledTimes(2);
322
- // The differentiator is appended with a hyphen, so the final UID has a hyphen before the number
323
- expect(mockedFs.writeFileSync).toHaveBeenCalledWith('/path/to/component1.meta.json', JSON.stringify({
324
- type: 'card',
325
- uid: 'card_collision_project_2',
326
- }, null, 2));
327
- });
328
- it('falls back to original uid when coerceToValidUid returns null', () => {
329
- const projectName = 'fallback-project';
330
- const hsMetaFilePaths = ['/path/to/component.meta.json'];
331
- const component = {
332
- type: 'card',
333
- uid: 'original-uid',
334
- };
335
- mockedFs.readFileSync.mockReturnValue(JSON.stringify(component));
336
- mockedFs.writeFileSync.mockImplementation(() => { });
337
- mockCoerceToValidUid.mockReturnValue(undefined);
338
- updateHsMetaFilesWithAutoGeneratedFields(projectName, hsMetaFilePaths);
339
- expect(mockedFs.writeFileSync).toHaveBeenCalledWith('/path/to/component.meta.json', JSON.stringify({
340
- type: 'card',
341
- uid: 'original-uid',
342
- }, null, 2));
343
- });
344
- it('handles empty hsMetaFilePaths array', () => {
345
- const projectName = 'empty-project';
346
- const hsMetaFilePaths = [];
347
- updateHsMetaFilesWithAutoGeneratedFields(projectName, hsMetaFilePaths);
348
- expect(mockedFs.readFileSync).not.toHaveBeenCalled();
349
- expect(mockedFs.writeFileSync).not.toHaveBeenCalled();
350
- });
351
- it('handles components without config property for app type', () => {
352
- const projectName = 'no-config-project';
353
- const hsMetaFilePaths = ['/path/to/app.meta.json'];
354
- const appComponent = {
355
- type: 'app',
356
- uid: 'app-uid',
357
- // No config property
358
- };
359
- mockedFs.readFileSync.mockReturnValue(JSON.stringify(appComponent));
360
- mockedFs.writeFileSync.mockImplementation(() => { });
361
- mockCoerceToValidUid.mockReturnValue('app-no-config-project');
362
- updateHsMetaFilesWithAutoGeneratedFields(projectName, hsMetaFilePaths);
363
- expect(mockCoerceToValidUid).toHaveBeenCalledWith('no-config-project_app');
364
- expect(mockedFs.writeFileSync).toHaveBeenCalledWith('/path/to/app.meta.json', JSON.stringify({
365
- type: 'app',
366
- uid: 'app_no_config_project',
367
- }, null, 2));
368
- });
369
- it('replaces hyphens with underscores in coerced UIDs', () => {
370
- const projectName = 'my-project';
371
- const hsMetaFilePaths = ['/path/to/component.meta.json'];
372
- const component = {
373
- type: 'card',
374
- uid: 'old-uid',
375
- };
376
- mockedFs.readFileSync.mockReturnValue(JSON.stringify(component));
377
- mockedFs.writeFileSync.mockImplementation(() => { });
378
- // coerceToValidUid returns a value with hyphens that should be converted to underscores
379
- mockCoerceToValidUid.mockReturnValue('my-project-card-with-hyphens');
380
- updateHsMetaFilesWithAutoGeneratedFields(projectName, hsMetaFilePaths);
381
- expect(mockCoerceToValidUid).toHaveBeenCalledWith('my-project_card');
382
- expect(mockedFs.writeFileSync).toHaveBeenCalledWith('/path/to/component.meta.json', JSON.stringify({
383
- type: 'card',
384
- uid: 'my_project_card_with_hyphens',
385
- }, null, 2));
386
- });
387
- it('handles UIDs with multiple hyphens correctly', () => {
388
- const projectName = 'test-project';
389
- const hsMetaFilePaths = ['/path/to/component.meta.json'];
390
- const component = {
391
- type: 'custom-object',
392
- uid: 'old-uid',
393
- };
394
- mockedFs.readFileSync.mockReturnValue(JSON.stringify(component));
395
- mockedFs.writeFileSync.mockImplementation(() => { });
396
- mockCoerceToValidUid.mockReturnValue('test-project-custom-object-type');
397
- updateHsMetaFilesWithAutoGeneratedFields(projectName, hsMetaFilePaths);
398
- expect(mockCoerceToValidUid).toHaveBeenCalledWith('test-project_custom-object');
399
- expect(mockedFs.writeFileSync).toHaveBeenCalledWith('/path/to/component.meta.json', JSON.stringify({
400
- type: 'custom-object',
401
- uid: 'test_project_custom_object_type',
402
- }, null, 2));
403
- });
404
- it('preserves UIDs without hyphens unchanged', () => {
405
- const projectName = 'simpleproject';
406
- const hsMetaFilePaths = ['/path/to/component.meta.json'];
407
- const component = {
408
- type: 'card',
409
- uid: 'old-uid',
410
- };
411
- mockedFs.readFileSync.mockReturnValue(JSON.stringify(component));
412
- mockedFs.writeFileSync.mockImplementation(() => { });
413
- // coerceToValidUid returns a value without hyphens
414
- mockCoerceToValidUid.mockReturnValue('simpleprojectcard');
415
- updateHsMetaFilesWithAutoGeneratedFields(projectName, hsMetaFilePaths);
416
- expect(mockCoerceToValidUid).toHaveBeenCalledWith('simpleproject_card');
417
- expect(mockedFs.writeFileSync).toHaveBeenCalledWith('/path/to/component.meta.json', JSON.stringify({
418
- type: 'card',
419
- uid: 'simpleprojectcard',
420
- }, null, 2));
421
- });
422
- it('handles project names with hyphens in UID generation', () => {
423
- const projectName = 'my-super-project';
424
- const hsMetaFilePaths = ['/path/to/component.meta.json'];
425
- const component = {
426
- type: 'function',
427
- uid: 'old-uid',
428
- };
429
- mockedFs.readFileSync.mockReturnValue(JSON.stringify(component));
430
- mockedFs.writeFileSync.mockImplementation(() => { });
431
- mockCoerceToValidUid.mockReturnValue('my-super-project-function');
432
- updateHsMetaFilesWithAutoGeneratedFields(projectName, hsMetaFilePaths);
433
- expect(mockCoerceToValidUid).toHaveBeenCalledWith('my-super-project_function');
434
- expect(mockedFs.writeFileSync).toHaveBeenCalledWith('/path/to/component.meta.json', JSON.stringify({
435
- type: 'function',
436
- uid: 'my_super_project_function',
437
- }, null, 2));
438
- });
439
- });
440
- });
@@ -1 +0,0 @@
1
- export {};