@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,46 +0,0 @@
1
- import yargs from 'yargs';
2
- import * as commonOpts from '../../../lib/commonOpts.js';
3
- import mvCommand from '../mv.js';
4
- vi.mock('../../../lib/commonOpts');
5
- const positionalSpy = vi
6
- .spyOn(yargs, 'positional')
7
- .mockReturnValue(yargs);
8
- describe('commands/cms/mv', () => {
9
- describe('command', () => {
10
- it('should have the correct command structure', () => {
11
- expect(mvCommand.command).toBe('mv <srcPath> <destPath>');
12
- });
13
- });
14
- describe('describe', () => {
15
- it('should provide a description', () => {
16
- expect(mvCommand.describe).toBeDefined();
17
- });
18
- });
19
- describe('builder', () => {
20
- it('should support the correct options', () => {
21
- mvCommand.builder(yargs);
22
- expect(commonOpts.addGlobalOptions).toHaveBeenCalledTimes(1);
23
- expect(commonOpts.addGlobalOptions).toHaveBeenCalledWith(yargs);
24
- expect(commonOpts.addConfigOptions).toHaveBeenCalledTimes(1);
25
- expect(commonOpts.addConfigOptions).toHaveBeenCalledWith(yargs);
26
- expect(commonOpts.addAccountOptions).toHaveBeenCalledTimes(1);
27
- expect(commonOpts.addAccountOptions).toHaveBeenCalledWith(yargs);
28
- expect(commonOpts.addUseEnvironmentOptions).toHaveBeenCalledTimes(1);
29
- expect(commonOpts.addUseEnvironmentOptions).toHaveBeenCalledWith(yargs);
30
- });
31
- it('should add the srcPath positional argument', () => {
32
- mvCommand.builder(yargs);
33
- expect(positionalSpy).toHaveBeenCalledWith('srcPath', {
34
- describe: 'Remote hubspot path',
35
- type: 'string',
36
- });
37
- });
38
- it('should add the destPath positional argument', () => {
39
- mvCommand.builder(yargs);
40
- expect(positionalSpy).toHaveBeenCalledWith('destPath', {
41
- describe: 'Remote hubspot path',
42
- type: 'string',
43
- });
44
- });
45
- });
46
- });
@@ -1 +0,0 @@
1
- export {};
@@ -1,54 +0,0 @@
1
- import yargs from 'yargs';
2
- import preview from '../theme/preview.js';
3
- import generateSelectors from '../theme/generate-selectors.js';
4
- import marketplaceValidate from '../theme/marketplace-validate.js';
5
- import create from '../theme/create.js';
6
- import themeCommands from '../theme.js';
7
- vi.mock('../theme/preview');
8
- vi.mock('../theme/generate-selectors');
9
- vi.mock('../theme/marketplace-validate');
10
- vi.mock('../theme/create');
11
- vi.mock('../../lib/commonOpts');
12
- const commandSpy = vi
13
- .spyOn(yargs, 'command')
14
- .mockReturnValue(yargs);
15
- const demandCommandSpy = vi
16
- .spyOn(yargs, 'demandCommand')
17
- .mockReturnValue(yargs);
18
- describe('commands/cms/theme', () => {
19
- describe('command', () => {
20
- it('should have the correct command structure', () => {
21
- expect(themeCommands.command).toEqual(['theme', 'themes']);
22
- });
23
- });
24
- describe('describe', () => {
25
- it('should provide a description', () => {
26
- expect(themeCommands.describe).toBeDefined();
27
- });
28
- });
29
- describe('builder', () => {
30
- beforeEach(() => {
31
- commandSpy.mockClear();
32
- demandCommandSpy.mockClear();
33
- });
34
- const subcommands = [
35
- preview,
36
- generateSelectors,
37
- marketplaceValidate,
38
- create,
39
- ];
40
- it('should demand the command takes one positional argument', () => {
41
- themeCommands.builder(yargs);
42
- expect(demandCommandSpy).toHaveBeenCalledTimes(1);
43
- expect(demandCommandSpy).toHaveBeenCalledWith(1, '');
44
- });
45
- it('should add the correct number of sub commands', () => {
46
- themeCommands.builder(yargs);
47
- expect(commandSpy).toHaveBeenCalledTimes(subcommands.length);
48
- });
49
- it.each(subcommands)('should attach the %s subcommand', module => {
50
- themeCommands.builder(yargs);
51
- expect(commandSpy).toHaveBeenCalledWith(module);
52
- });
53
- });
54
- });
@@ -1 +0,0 @@
1
- export {};
@@ -1,312 +0,0 @@
1
- import yargs from 'yargs';
2
- import fs from 'fs';
3
- import path from 'path';
4
- import * as uploadFolderLib from '@hubspot/local-dev-lib/cms/uploadFolder';
5
- import * as fileMapperLib from '@hubspot/local-dev-lib/api/fileMapper';
6
- import * as pathLib from '@hubspot/local-dev-lib/path';
7
- import * as modulesLib from '@hubspot/local-dev-lib/cms/modules';
8
- import * as ignoreRulesLib from '@hubspot/local-dev-lib/ignoreRules';
9
- import * as themesLib from '@hubspot/local-dev-lib/cms/themes';
10
- import * as configLib from '@hubspot/local-dev-lib/config';
11
- import * as handleFieldsJSLib from '@hubspot/local-dev-lib/cms/handleFieldsJS';
12
- import { uiLogger } from '../../../lib/ui/logger.js';
13
- import * as errorHandlers from '../../../lib/errorHandlers/index.js';
14
- import * as commonOpts from '../../../lib/commonOpts.js';
15
- import * as uploadPromptLib from '../../../lib/prompts/uploadPrompt.js';
16
- import * as promptUtilsLib from '../../../lib/prompts/promptUtils.js';
17
- import * as validationLib from '../../../lib/validation.js';
18
- import * as usageTrackingLib from '../../../lib/usageTracking.js';
19
- import * as uploadLib from '../../../lib/upload.js';
20
- import { EXIT_CODES } from '../../../lib/enums/exitCodes.js';
21
- import uploadCommand from '../upload.js';
22
- vi.mock('fs');
23
- vi.mock('@hubspot/local-dev-lib/cms/uploadFolder');
24
- vi.mock('@hubspot/local-dev-lib/api/fileMapper');
25
- vi.mock('@hubspot/local-dev-lib/path');
26
- vi.mock('@hubspot/local-dev-lib/cms/modules');
27
- vi.mock('@hubspot/local-dev-lib/ignoreRules');
28
- vi.mock('@hubspot/local-dev-lib/cms/themes');
29
- vi.mock('@hubspot/local-dev-lib/config');
30
- vi.mock('@hubspot/local-dev-lib/cms/handleFieldsJS');
31
- vi.mock('../../../lib/errorHandlers/index.js');
32
- vi.mock('../../../lib/commonOpts.js');
33
- vi.mock('../../../lib/prompts/uploadPrompt.js');
34
- vi.mock('../../../lib/prompts/promptUtils.js');
35
- vi.mock('../../../lib/validation.js');
36
- vi.mock('../../../lib/upload.js');
37
- const uploadFolderSpy = vi.spyOn(uploadFolderLib, 'uploadFolder');
38
- const uploadSpy = vi.spyOn(fileMapperLib, 'upload');
39
- const deleteFileSpy = vi.spyOn(fileMapperLib, 'deleteFile');
40
- const statSyncSpy = vi.spyOn(fs, 'statSync');
41
- const validateSrcAndDestPathsSpy = vi.spyOn(modulesLib, 'validateSrcAndDestPaths');
42
- const shouldIgnoreFileSpy = vi.spyOn(ignoreRulesLib, 'shouldIgnoreFile');
43
- const isAllowedExtensionSpy = vi.spyOn(pathLib, 'isAllowedExtension');
44
- const getCwdSpy = vi.spyOn(pathLib, 'getCwd');
45
- const convertToUnixPathSpy = vi.spyOn(pathLib, 'convertToUnixPath');
46
- const uploadPromptSpy = vi.spyOn(uploadPromptLib, 'uploadPrompt');
47
- const confirmPromptSpy = vi.spyOn(promptUtilsLib, 'confirmPrompt');
48
- const validateCmsPublishModeSpy = vi.spyOn(validationLib, 'validateCmsPublishMode');
49
- const trackCommandUsageSpy = vi.spyOn(usageTrackingLib, 'trackCommandUsage');
50
- const getUploadableFileListSpy = vi.spyOn(uploadLib, 'getUploadableFileList');
51
- const getCmsPublishModeSpy = vi.spyOn(commonOpts, 'getCmsPublishMode');
52
- const getThemePreviewUrlSpy = vi.spyOn(themesLib, 'getThemePreviewUrl');
53
- const getThemeJSONPathSpy = vi.spyOn(themesLib, 'getThemeJSONPath');
54
- const hasUploadErrorsSpy = vi.spyOn(uploadFolderLib, 'hasUploadErrors');
55
- const processExitSpy = vi.spyOn(process, 'exit');
56
- const logErrorSpy = vi.spyOn(errorHandlers, 'logError');
57
- const getConfigAccountIfExistsSpy = vi.spyOn(configLib, 'getConfigAccountIfExists');
58
- const isConvertableFieldJsSpy = vi.spyOn(handleFieldsJSLib, 'isConvertableFieldJs');
59
- describe('commands/cms/upload', () => {
60
- beforeEach(() => {
61
- // @ts-expect-error Mock implementation
62
- processExitSpy.mockImplementation(() => { });
63
- getCwdSpy.mockReturnValue('/test/cwd');
64
- convertToUnixPathSpy.mockImplementation(p => p.replace(/\\/g, '/'));
65
- validateCmsPublishModeSpy.mockReturnValue(true);
66
- getCmsPublishModeSpy.mockReturnValue('publish');
67
- uploadPromptSpy.mockResolvedValue({ src: '', dest: '' });
68
- validateSrcAndDestPathsSpy.mockResolvedValue([]);
69
- getThemeJSONPathSpy.mockReturnValue(null);
70
- getThemePreviewUrlSpy.mockReturnValue(undefined);
71
- // Mock config to prevent reading actual config file in CI
72
- getConfigAccountIfExistsSpy.mockReturnValue(undefined);
73
- isConvertableFieldJsSpy.mockReturnValue(false);
74
- });
75
- describe('command', () => {
76
- it('should have the correct command structure', () => {
77
- expect(uploadCommand.command).toEqual('upload [src] [dest]');
78
- });
79
- });
80
- describe('describe', () => {
81
- it('should provide a description', () => {
82
- expect(uploadCommand.describe).toBeDefined();
83
- });
84
- });
85
- describe('builder', () => {
86
- it('should support the correct options', () => {
87
- const optionsSpy = vi.spyOn(yargs, 'option');
88
- const positionalSpy = vi.spyOn(yargs, 'positional');
89
- uploadCommand.builder(yargs);
90
- expect(positionalSpy).toHaveBeenCalledWith('src', expect.objectContaining({ type: 'string' }));
91
- expect(positionalSpy).toHaveBeenCalledWith('dest', expect.objectContaining({ type: 'string' }));
92
- expect(optionsSpy).toHaveBeenCalledWith('field-options', expect.objectContaining({ type: 'array' }));
93
- expect(optionsSpy).toHaveBeenCalledWith('save-output', expect.objectContaining({ type: 'boolean' }));
94
- expect(optionsSpy).toHaveBeenCalledWith('convert-fields', expect.objectContaining({ type: 'boolean' }));
95
- expect(optionsSpy).toHaveBeenCalledWith('clean', expect.objectContaining({ type: 'boolean' }));
96
- expect(optionsSpy).toHaveBeenCalledWith('force', expect.objectContaining({ type: 'boolean' }));
97
- });
98
- });
99
- describe('handler', () => {
100
- let args;
101
- beforeEach(() => {
102
- args = {
103
- src: 'test.js',
104
- dest: '/dest/test.js',
105
- derivedAccountId: 123456,
106
- };
107
- });
108
- describe('validation', () => {
109
- it('should exit if CMS publish mode validation fails', async () => {
110
- validateCmsPublishModeSpy.mockReturnValue(false);
111
- await uploadCommand.handler(args);
112
- expect(validateCmsPublishModeSpy).toHaveBeenCalledWith(args);
113
- expect(processExitSpy).toHaveBeenCalledWith(EXIT_CODES.WARNING);
114
- });
115
- it('should prompt for src and dest when not provided', async () => {
116
- delete args.src;
117
- delete args.dest;
118
- uploadPromptSpy.mockResolvedValue({
119
- src: 'prompted.js',
120
- dest: '/prompted/dest.js',
121
- });
122
- statSyncSpy.mockReturnValue({
123
- isFile: () => true,
124
- isDirectory: () => false,
125
- });
126
- isAllowedExtensionSpy.mockReturnValue(true);
127
- shouldIgnoreFileSpy.mockReturnValue(false);
128
- // @ts-expect-error Mock return value doesn't need full type implementation
129
- uploadSpy.mockResolvedValue({});
130
- await uploadCommand.handler(args);
131
- expect(uploadPromptSpy).toHaveBeenCalledWith(args);
132
- expect(uploadSpy).toHaveBeenCalled();
133
- });
134
- it('should error if dest is not provided', async () => {
135
- args.dest = '';
136
- uploadPromptSpy.mockResolvedValue({ src: 'test.js', dest: '' });
137
- await uploadCommand.handler(args);
138
- expect(uiLogger.error).toHaveBeenCalledWith(expect.stringContaining('destination'));
139
- });
140
- it('should error if src path is invalid', async () => {
141
- statSyncSpy.mockImplementation(() => {
142
- throw new Error('File not found');
143
- });
144
- await uploadCommand.handler(args);
145
- expect(uiLogger.error).toHaveBeenCalledWith(expect.stringContaining('path to a file or folder'));
146
- });
147
- it('should error if src path is not a file or directory', async () => {
148
- statSyncSpy.mockReturnValue({
149
- isFile: () => false,
150
- isDirectory: () => false,
151
- });
152
- await uploadCommand.handler(args);
153
- expect(uiLogger.error).toHaveBeenCalledWith(expect.stringContaining('path to a file or folder'));
154
- });
155
- it('should exit if src/dest validation fails', async () => {
156
- statSyncSpy.mockReturnValue({
157
- isFile: () => true,
158
- isDirectory: () => false,
159
- });
160
- validateSrcAndDestPathsSpy.mockResolvedValue([
161
- { id: '1', message: 'Invalid path' },
162
- ]);
163
- await uploadCommand.handler(args);
164
- expect(uiLogger.error).toHaveBeenCalledWith('Invalid path');
165
- expect(processExitSpy).toHaveBeenCalledWith(EXIT_CODES.WARNING);
166
- });
167
- });
168
- describe('file upload', () => {
169
- beforeEach(() => {
170
- statSyncSpy.mockReturnValue({
171
- isFile: () => true,
172
- isDirectory: () => false,
173
- });
174
- isAllowedExtensionSpy.mockReturnValue(true);
175
- shouldIgnoreFileSpy.mockReturnValue(false);
176
- });
177
- it('should track command usage for file uploads', async () => {
178
- // @ts-expect-error Mock return value doesn't need full type implementation
179
- uploadSpy.mockResolvedValue({});
180
- await uploadCommand.handler(args);
181
- expect(trackCommandUsageSpy).toHaveBeenCalledWith('upload', { mode: 'publish', type: 'file' }, 123456);
182
- });
183
- it('should upload a file successfully', async () => {
184
- // @ts-expect-error Mock return value doesn't need full type implementation
185
- uploadSpy.mockResolvedValue({});
186
- await uploadCommand.handler(args);
187
- expect(uploadSpy).toHaveBeenCalledWith(123456, path.resolve('/test/cwd', 'test.js'), '/dest/test.js', expect.any(Object));
188
- expect(uiLogger.success).toHaveBeenCalledWith(expect.stringMatching(/uploaded/i));
189
- });
190
- it('should error if file has disallowed extension', async () => {
191
- isAllowedExtensionSpy.mockReturnValue(false);
192
- await uploadCommand.handler(args);
193
- expect(uploadSpy).not.toHaveBeenCalled();
194
- expect(uiLogger.error).toHaveBeenCalledWith(expect.stringContaining('path to a file or folder'));
195
- });
196
- it('should error if file is ignored', async () => {
197
- shouldIgnoreFileSpy.mockReturnValue(true);
198
- await uploadCommand.handler(args);
199
- expect(uploadSpy).not.toHaveBeenCalled();
200
- expect(uiLogger.error).toHaveBeenCalledWith(expect.stringContaining('ignored'));
201
- });
202
- it('should handle upload errors', async () => {
203
- vi.useFakeTimers();
204
- const error = new Error('Upload failed');
205
- uploadSpy.mockRejectedValue(error);
206
- await uploadCommand.handler(args);
207
- await vi.runAllTimersAsync();
208
- expect(uiLogger.error).toHaveBeenCalled();
209
- expect(logErrorSpy).toHaveBeenCalledWith(error, expect.any(errorHandlers.ApiErrorContext));
210
- expect(processExitSpy).toHaveBeenCalledWith(EXIT_CODES.WARNING);
211
- vi.useRealTimers();
212
- });
213
- it('should log theme preview URL if available', async () => {
214
- getThemePreviewUrlSpy.mockReturnValue('http://preview.url');
215
- // @ts-expect-error Mock return value doesn't need full type implementation
216
- uploadSpy.mockResolvedValue({});
217
- await uploadCommand.handler(args);
218
- expect(getThemePreviewUrlSpy).toHaveBeenCalledWith('test.js', 123456);
219
- expect(uiLogger.log).toHaveBeenCalledWith(expect.stringContaining('http://preview.url'));
220
- });
221
- });
222
- describe('folder upload', () => {
223
- beforeEach(() => {
224
- statSyncSpy.mockReturnValue({
225
- isFile: () => false,
226
- isDirectory: () => true,
227
- });
228
- getUploadableFileListSpy.mockResolvedValue([]);
229
- uploadFolderSpy.mockResolvedValue([]);
230
- hasUploadErrorsSpy.mockReturnValue(false);
231
- });
232
- it('should track command usage for folder uploads', async () => {
233
- await uploadCommand.handler(args);
234
- expect(trackCommandUsageSpy).toHaveBeenCalledWith('upload', { mode: 'publish', type: 'folder' }, 123456);
235
- });
236
- it('should upload a folder successfully', async () => {
237
- await uploadCommand.handler(args);
238
- expect(uploadFolderSpy).toHaveBeenCalledWith(123456, path.resolve('/test/cwd', 'test.js'), '/dest/test.js', {}, expect.objectContaining({
239
- convertFields: undefined,
240
- saveOutput: undefined,
241
- }), []);
242
- expect(uiLogger.success).toHaveBeenCalledWith(expect.stringContaining('complete'));
243
- });
244
- it('should handle clean upload with confirmation', async () => {
245
- args.clean = true;
246
- confirmPromptSpy.mockResolvedValue(true);
247
- // @ts-expect-error Mock return value doesn't need full type implementation
248
- deleteFileSpy.mockResolvedValue({});
249
- await uploadCommand.handler(args);
250
- expect(confirmPromptSpy).toHaveBeenCalled();
251
- expect(deleteFileSpy).toHaveBeenCalledWith(123456, '/dest/test.js');
252
- // Check that log was called multiple times (upload message + cleaning message)
253
- expect(uiLogger.log).toHaveBeenCalled();
254
- });
255
- it('should skip clean upload if not confirmed', async () => {
256
- args.clean = true;
257
- confirmPromptSpy.mockResolvedValue(false);
258
- await uploadCommand.handler(args);
259
- expect(deleteFileSpy).not.toHaveBeenCalled();
260
- });
261
- it('should force clean upload without confirmation', async () => {
262
- args.clean = true;
263
- args.force = true;
264
- // @ts-expect-error Mock return value doesn't need full type implementation
265
- deleteFileSpy.mockResolvedValue({});
266
- await uploadCommand.handler(args);
267
- expect(confirmPromptSpy).not.toHaveBeenCalled();
268
- expect(deleteFileSpy).toHaveBeenCalledWith(123456, '/dest/test.js');
269
- });
270
- it('should handle delete errors during clean upload', async () => {
271
- args.clean = true;
272
- args.force = true;
273
- const error = new Error('Delete failed');
274
- deleteFileSpy.mockRejectedValue(error);
275
- await uploadCommand.handler(args);
276
- expect(uiLogger.error).toHaveBeenCalledWith(expect.stringContaining('Deleting'));
277
- });
278
- it('should error if folder upload has errors', async () => {
279
- hasUploadErrorsSpy.mockReturnValue(true);
280
- await uploadCommand.handler(args);
281
- expect(uiLogger.error).toHaveBeenCalledWith(expect.stringContaining('failed'));
282
- expect(processExitSpy).toHaveBeenCalledWith(EXIT_CODES.WARNING);
283
- });
284
- it('should handle folder upload errors', async () => {
285
- vi.useFakeTimers();
286
- const error = new Error('Folder upload failed');
287
- uploadFolderSpy.mockRejectedValue(error);
288
- await uploadCommand.handler(args);
289
- await vi.runAllTimersAsync();
290
- expect(uiLogger.error).toHaveBeenCalled();
291
- expect(logErrorSpy).toHaveBeenCalledWith(error, {
292
- accountId: 123456,
293
- });
294
- expect(processExitSpy).toHaveBeenCalledWith(EXIT_CODES.WARNING);
295
- vi.useRealTimers();
296
- });
297
- it('should pass convertFields option to uploadFolder', async () => {
298
- args.convertFields = true;
299
- await uploadCommand.handler(args);
300
- expect(uploadFolderSpy).toHaveBeenCalledWith(123456, expect.any(String), expect.any(String), {}, expect.objectContaining({
301
- convertFields: true,
302
- }), expect.any(Array));
303
- });
304
- it('should generate uploadable file list with convertFields', async () => {
305
- args.convertFields = true;
306
- getUploadableFileListSpy.mockResolvedValue(['file1.js', 'file2.js']);
307
- await uploadCommand.handler(args);
308
- expect(getUploadableFileListSpy).toHaveBeenCalledWith(path.resolve('/test/cwd', 'test.js'), true);
309
- });
310
- });
311
- });
312
- });
@@ -1 +0,0 @@
1
- export {};
@@ -1,204 +0,0 @@
1
- import yargs from 'yargs';
2
- import fs from 'fs';
3
- import path from 'path';
4
- import { AxiosError } from 'axios';
5
- import * as watchLib from '@hubspot/local-dev-lib/cms/watch';
6
- import * as pathLib from '@hubspot/local-dev-lib/path';
7
- import * as configLib from '@hubspot/local-dev-lib/config';
8
- import { uiLogger } from '../../../lib/ui/logger.js';
9
- import * as commonOpts from '../../../lib/commonOpts.js';
10
- import * as uploadPromptLib from '../../../lib/prompts/uploadPrompt.js';
11
- import * as validationLib from '../../../lib/validation.js';
12
- import * as usageTrackingLib from '../../../lib/usageTracking.js';
13
- import * as uploadLib from '../../../lib/upload.js';
14
- import { EXIT_CODES } from '../../../lib/enums/exitCodes.js';
15
- import watchCommand from '../watch.js';
16
- vi.mock('fs');
17
- vi.mock('@hubspot/local-dev-lib/cms/watch');
18
- vi.mock('@hubspot/local-dev-lib/path');
19
- vi.mock('@hubspot/local-dev-lib/config');
20
- vi.mock('../../../lib/commonOpts.js');
21
- vi.mock('../../../lib/prompts/uploadPrompt.js');
22
- vi.mock('../../../lib/validation.js');
23
- vi.mock('../../../lib/upload.js');
24
- const watchSpy = vi.spyOn(watchLib, 'watch');
25
- const statSyncSpy = vi.spyOn(fs, 'statSync');
26
- const getCwdSpy = vi.spyOn(pathLib, 'getCwd');
27
- const uploadPromptSpy = vi.spyOn(uploadPromptLib, 'uploadPrompt');
28
- const validateCmsPublishModeSpy = vi.spyOn(validationLib, 'validateCmsPublishMode');
29
- const getCmsPublishModeSpy = vi.spyOn(commonOpts, 'getCmsPublishMode');
30
- const trackCommandUsageSpy = vi.spyOn(usageTrackingLib, 'trackCommandUsage');
31
- const getUploadableFileListSpy = vi.spyOn(uploadLib, 'getUploadableFileList');
32
- const processExitSpy = vi.spyOn(process, 'exit');
33
- const getConfigAccountIfExistsSpy = vi.spyOn(configLib, 'getConfigAccountIfExists');
34
- describe('commands/cms/watch', () => {
35
- beforeEach(() => {
36
- // @ts-expect-error Mock implementation
37
- processExitSpy.mockImplementation(() => { });
38
- getCwdSpy.mockReturnValue('/test/cwd');
39
- validateCmsPublishModeSpy.mockReturnValue(true);
40
- getCmsPublishModeSpy.mockReturnValue('publish');
41
- uploadPromptSpy.mockResolvedValue({ src: '', dest: '' });
42
- // @ts-expect-error Mock return value doesn't need full type implementation
43
- watchSpy.mockImplementation(() => ({}));
44
- getUploadableFileListSpy.mockResolvedValue([]);
45
- // Mock config to prevent reading actual config file in CI
46
- getConfigAccountIfExistsSpy.mockReturnValue(undefined);
47
- });
48
- describe('command', () => {
49
- it('should have the correct command structure', () => {
50
- expect(watchCommand.command).toEqual('watch [src] [dest]');
51
- });
52
- });
53
- describe('describe', () => {
54
- it('should provide a description', () => {
55
- expect(watchCommand.describe).toBeDefined();
56
- });
57
- });
58
- describe('builder', () => {
59
- it('should support the correct options', () => {
60
- const positionalSpy = vi.spyOn(yargs, 'positional');
61
- const optionSpy = vi.spyOn(yargs, 'option');
62
- watchCommand.builder(yargs);
63
- expect(positionalSpy).toHaveBeenCalledWith('src', expect.objectContaining({ type: 'string' }));
64
- expect(positionalSpy).toHaveBeenCalledWith('dest', expect.objectContaining({ type: 'string' }));
65
- expect(optionSpy).toHaveBeenCalledWith('remove', expect.objectContaining({ type: 'boolean', alias: 'r' }));
66
- expect(optionSpy).toHaveBeenCalledWith('initial-upload', expect.objectContaining({ type: 'boolean', alias: 'i' }));
67
- expect(optionSpy).toHaveBeenCalledWith('notify', expect.objectContaining({ type: 'string', alias: 'n' }));
68
- expect(optionSpy).toHaveBeenCalledWith('convert-fields', expect.objectContaining({ type: 'boolean' }));
69
- });
70
- });
71
- describe('handler', () => {
72
- let args;
73
- beforeEach(() => {
74
- args = {
75
- src: 'src',
76
- dest: '/dest',
77
- derivedAccountId: 123456,
78
- remove: false,
79
- initialUpload: false,
80
- };
81
- statSyncSpy.mockReturnValue({
82
- isFile: () => false,
83
- isDirectory: () => true,
84
- });
85
- });
86
- describe('validation', () => {
87
- it('should exit if CMS publish mode validation fails', async () => {
88
- validateCmsPublishModeSpy.mockReturnValue(false);
89
- await watchCommand.handler(args);
90
- expect(validateCmsPublishModeSpy).toHaveBeenCalledWith(args);
91
- expect(processExitSpy).toHaveBeenCalledWith(EXIT_CODES.ERROR);
92
- });
93
- it('should prompt for src and dest when not provided', async () => {
94
- delete args.src;
95
- delete args.dest;
96
- uploadPromptSpy.mockResolvedValue({
97
- src: 'prompted-src',
98
- dest: '/prompted-dest',
99
- });
100
- await watchCommand.handler(args);
101
- expect(uploadPromptSpy).toHaveBeenCalledWith(args);
102
- });
103
- it('should error if src path is invalid', async () => {
104
- statSyncSpy.mockImplementation(() => {
105
- throw new Error('File not found');
106
- });
107
- await watchCommand.handler(args);
108
- expect(uiLogger.log).toHaveBeenCalledWith(expect.stringContaining('path to a directory'));
109
- expect(watchSpy).not.toHaveBeenCalled();
110
- });
111
- it('should error if src path is not a directory', async () => {
112
- statSyncSpy.mockReturnValue({
113
- isFile: () => true,
114
- isDirectory: () => false,
115
- });
116
- await watchCommand.handler(args);
117
- expect(uiLogger.log).toHaveBeenCalledWith(expect.stringContaining('path to a directory'));
118
- expect(watchSpy).not.toHaveBeenCalled();
119
- });
120
- it('should error if dest is not provided', async () => {
121
- args.dest = '';
122
- uploadPromptSpy.mockResolvedValue({ src: 'src', dest: '' });
123
- await watchCommand.handler(args);
124
- expect(uiLogger.log).toHaveBeenCalledWith(expect.stringContaining('destination'));
125
- expect(watchSpy).not.toHaveBeenCalled();
126
- });
127
- });
128
- describe('watch execution', () => {
129
- it('should track command usage', async () => {
130
- await watchCommand.handler(args);
131
- expect(trackCommandUsageSpy).toHaveBeenCalledWith('watch', { mode: 'publish' }, 123456);
132
- });
133
- it('should start watching without initial upload by default', async () => {
134
- await watchCommand.handler(args);
135
- expect(getUploadableFileListSpy).not.toHaveBeenCalled();
136
- expect(watchSpy).toHaveBeenCalledWith(123456, path.resolve('/test/cwd', 'src'), '/dest', expect.objectContaining({
137
- cmsPublishMode: 'publish',
138
- remove: false,
139
- disableInitial: true,
140
- }), null, expect.any(Function), undefined, expect.any(Function));
141
- });
142
- it('should generate uploadable file list when initialUpload is true', async () => {
143
- args.initialUpload = true;
144
- getUploadableFileListSpy.mockResolvedValue(['file1.js', 'file2.js']);
145
- await watchCommand.handler(args);
146
- expect(getUploadableFileListSpy).toHaveBeenCalledWith(path.resolve('/test/cwd', 'src'), undefined);
147
- expect(watchSpy).toHaveBeenCalledWith(123456, expect.any(String), expect.any(String), expect.objectContaining({
148
- disableInitial: false,
149
- filePaths: ['file1.js', 'file2.js'],
150
- }), null, expect.any(Function), undefined, expect.any(Function));
151
- });
152
- it('should pass remove option to watch', async () => {
153
- args.remove = true;
154
- await watchCommand.handler(args);
155
- expect(watchSpy).toHaveBeenCalledWith(123456, expect.any(String), expect.any(String), expect.objectContaining({
156
- remove: true,
157
- }), null, expect.any(Function), undefined, expect.any(Function));
158
- });
159
- it('should pass notify option to watch', async () => {
160
- args.notify = 'http://notify.url';
161
- await watchCommand.handler(args);
162
- expect(watchSpy).toHaveBeenCalledWith(123456, expect.any(String), expect.any(String), expect.objectContaining({
163
- notify: 'http://notify.url',
164
- }), null, expect.any(Function), undefined, expect.any(Function));
165
- });
166
- it('should pass convertFields to getUploadableFileList', async () => {
167
- args.initialUpload = true;
168
- args.convertFields = true;
169
- await watchCommand.handler(args);
170
- expect(getUploadableFileListSpy).toHaveBeenCalledWith(expect.any(String), true);
171
- });
172
- it('should pass command options to watch', async () => {
173
- args.saveOutput = true;
174
- args.fieldOptions = ['option1'];
175
- await watchCommand.handler(args);
176
- expect(watchSpy).toHaveBeenCalledWith(123456, expect.any(String), expect.any(String), expect.objectContaining({
177
- commandOptions: expect.objectContaining({
178
- saveOutput: true,
179
- fieldOptions: ['option1'],
180
- }),
181
- }), null, expect.any(Function), undefined, expect.any(Function));
182
- });
183
- });
184
- describe('error handlers', () => {
185
- it('should provide error handler for folder errors', async () => {
186
- await watchCommand.handler(args);
187
- const folderErrorHandler = watchSpy.mock.calls[0][5];
188
- const error = new AxiosError('Folder error');
189
- // @ts-expect-error Axios version mismatch between test and implementation
190
- folderErrorHandler?.(error);
191
- expect(uiLogger.error).toHaveBeenCalledWith(expect.stringContaining('failures'));
192
- });
193
- it('should provide error handler factory for file errors', async () => {
194
- await watchCommand.handler(args);
195
- const fileErrorHandlerFactory = watchSpy.mock.calls[0][7];
196
- const fileErrorHandler = fileErrorHandlerFactory?.('test.js', '/dest/test.js', 123456);
197
- const error = new AxiosError('File error');
198
- // @ts-expect-error Axios version mismatch between test and implementation
199
- fileErrorHandler?.(error);
200
- expect(uiLogger.error).toHaveBeenCalledWith(expect.stringContaining('test.js'));
201
- });
202
- });
203
- });
204
- });
@@ -1 +0,0 @@
1
- export {};