@hubspot/cli 7.6.0-beta.4 → 7.6.0-beta.6

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 (587) hide show
  1. package/api/__tests__/migrate.test.js +27 -29
  2. package/api/migrate.d.ts +7 -0
  3. package/api/migrate.js +22 -22
  4. package/bin/cli.js +92 -97
  5. package/bin/hs +2 -2
  6. package/bin/hscms +2 -2
  7. package/bin/silenceErrors.js +1 -2
  8. package/commands/__tests__/account.test.js +29 -34
  9. package/commands/__tests__/auth.test.js +11 -16
  10. package/commands/__tests__/cms.test.js +15 -20
  11. package/commands/__tests__/config.test.js +14 -19
  12. package/commands/__tests__/create.test.js +10 -15
  13. package/commands/__tests__/customObject.test.js +14 -19
  14. package/commands/__tests__/doctor.test.js +43 -48
  15. package/commands/__tests__/feedback.test.js +7 -45
  16. package/commands/__tests__/fetch.test.js +29 -28
  17. package/commands/__tests__/filemanager.test.js +14 -19
  18. package/commands/__tests__/function.test.js +16 -21
  19. package/commands/__tests__/getStarted.test.js +45 -60
  20. package/commands/__tests__/hubdb.test.js +17 -22
  21. package/commands/__tests__/init.test.js +12 -17
  22. package/commands/__tests__/lint.test.js +13 -18
  23. package/commands/__tests__/list.test.js +18 -23
  24. package/commands/__tests__/logs.test.js +28 -27
  25. package/commands/__tests__/mcp.test.js +14 -19
  26. package/commands/__tests__/mv.test.js +14 -52
  27. package/commands/__tests__/open.test.js +13 -51
  28. package/commands/__tests__/project.test.js +44 -49
  29. package/commands/__tests__/remove.test.js +13 -51
  30. package/commands/__tests__/sandbox.test.js +14 -19
  31. package/commands/__tests__/secret.test.js +16 -21
  32. package/commands/__tests__/testAccount.test.js +16 -21
  33. package/commands/__tests__/theme.test.js +15 -20
  34. package/commands/account/__tests__/auth.test.js +11 -16
  35. package/commands/account/__tests__/clean.test.js +12 -17
  36. package/commands/account/__tests__/createOverride.test.js +10 -15
  37. package/commands/account/__tests__/info.test.js +11 -16
  38. package/commands/account/__tests__/list.test.js +11 -16
  39. package/commands/account/__tests__/remove.test.js +13 -18
  40. package/commands/account/__tests__/removeOverride.js +8 -13
  41. package/commands/account/__tests__/rename.test.js +15 -20
  42. package/commands/account/__tests__/use.test.js +10 -15
  43. package/commands/account/auth.d.ts +1 -1
  44. package/commands/account/auth.js +78 -69
  45. package/commands/account/clean.d.ts +1 -1
  46. package/commands/account/clean.js +55 -60
  47. package/commands/account/createOverride.d.ts +1 -1
  48. package/commands/account/createOverride.js +52 -57
  49. package/commands/account/info.d.ts +1 -1
  50. package/commands/account/info.js +33 -35
  51. package/commands/account/list.d.ts +1 -1
  52. package/commands/account/list.js +43 -45
  53. package/commands/account/remove.d.ts +1 -1
  54. package/commands/account/remove.js +37 -42
  55. package/commands/account/removeOverride.d.ts +1 -1
  56. package/commands/account/removeOverride.js +38 -43
  57. package/commands/account/rename.d.ts +1 -1
  58. package/commands/account/rename.js +18 -20
  59. package/commands/account/use.d.ts +1 -1
  60. package/commands/account/use.js +29 -31
  61. package/commands/account.d.ts +1 -1
  62. package/commands/account.js +23 -28
  63. package/commands/app/__tests__/migrate.test.js +29 -34
  64. package/commands/app/migrate.d.ts +2 -2
  65. package/commands/app/migrate.js +40 -43
  66. package/commands/app/secret/__tests__/add.test.js +6 -11
  67. package/commands/app/secret/__tests__/delete.test.js +6 -11
  68. package/commands/app/secret/__tests__/list.test.js +6 -11
  69. package/commands/app/secret/__tests__/update.test.js +6 -11
  70. package/commands/app/secret/add.d.ts +1 -1
  71. package/commands/app/secret/add.js +28 -30
  72. package/commands/app/secret/delete.d.ts +1 -1
  73. package/commands/app/secret/delete.js +34 -36
  74. package/commands/app/secret/list.d.ts +1 -1
  75. package/commands/app/secret/list.js +25 -27
  76. package/commands/app/secret/update.d.ts +1 -1
  77. package/commands/app/secret/update.js +32 -34
  78. package/commands/app/secret.d.ts +1 -1
  79. package/commands/app/secret.js +12 -17
  80. package/commands/app.d.ts +1 -1
  81. package/commands/app.js +6 -11
  82. package/commands/auth.d.ts +1 -1
  83. package/commands/auth.js +70 -72
  84. package/commands/cms/convertFields.d.ts +1 -1
  85. package/commands/cms/convertFields.js +34 -39
  86. package/commands/cms/getReactModule.d.ts +1 -1
  87. package/commands/cms/getReactModule.js +32 -37
  88. package/commands/cms/lighthouseScore.d.ts +1 -1
  89. package/commands/cms/lighthouseScore.js +67 -72
  90. package/commands/cms.d.ts +1 -1
  91. package/commands/cms.js +11 -16
  92. package/commands/completion.d.ts +1 -1
  93. package/commands/completion.js +10 -15
  94. package/commands/config/migrate.d.ts +1 -1
  95. package/commands/config/migrate.js +27 -32
  96. package/commands/config/set.d.ts +2 -1
  97. package/commands/config/set.js +40 -32
  98. package/commands/config.d.ts +1 -1
  99. package/commands/config.js +8 -13
  100. package/commands/create/api-sample.d.ts +1 -1
  101. package/commands/create/api-sample.js +28 -33
  102. package/commands/create/app.d.ts +1 -1
  103. package/commands/create/app.js +3 -5
  104. package/commands/create/function.d.ts +1 -1
  105. package/commands/create/function.js +9 -11
  106. package/commands/create/index.d.ts +1 -1
  107. package/commands/create/index.js +19 -24
  108. package/commands/create/module.d.ts +1 -1
  109. package/commands/create/module.js +12 -14
  110. package/commands/create/react-app.d.ts +1 -1
  111. package/commands/create/react-app.js +3 -5
  112. package/commands/create/template.d.ts +1 -1
  113. package/commands/create/template.js +12 -14
  114. package/commands/create/vue-app.d.ts +1 -1
  115. package/commands/create/vue-app.js +3 -5
  116. package/commands/create/webpack-serverless.d.ts +1 -1
  117. package/commands/create/webpack-serverless.js +3 -5
  118. package/commands/create/website-theme.d.ts +1 -1
  119. package/commands/create/website-theme.js +5 -7
  120. package/commands/create.d.ts +2 -2
  121. package/commands/create.js +30 -35
  122. package/commands/customObject/__tests__/create.test.js +13 -18
  123. package/commands/customObject/__tests__/schema.test.js +18 -23
  124. package/commands/customObject/create.d.ts +1 -1
  125. package/commands/customObject/create.js +28 -30
  126. package/commands/customObject/schema/__tests__/create.test.js +13 -18
  127. package/commands/customObject/schema/__tests__/delete.test.js +13 -18
  128. package/commands/customObject/schema/__tests__/fetch-all.test.js +13 -18
  129. package/commands/customObject/schema/__tests__/fetch.test.js +13 -18
  130. package/commands/customObject/schema/__tests__/list.test.js +13 -18
  131. package/commands/customObject/schema/__tests__/update.test.js +13 -18
  132. package/commands/customObject/schema/create.d.ts +1 -1
  133. package/commands/customObject/schema/create.js +28 -30
  134. package/commands/customObject/schema/delete.d.ts +1 -1
  135. package/commands/customObject/schema/delete.js +24 -26
  136. package/commands/customObject/schema/fetch-all.d.ts +1 -1
  137. package/commands/customObject/schema/fetch-all.js +22 -24
  138. package/commands/customObject/schema/fetch.d.ts +1 -1
  139. package/commands/customObject/schema/fetch.js +24 -26
  140. package/commands/customObject/schema/list.d.ts +1 -1
  141. package/commands/customObject/schema/list.js +13 -15
  142. package/commands/customObject/schema/update.d.ts +1 -1
  143. package/commands/customObject/schema/update.js +32 -34
  144. package/commands/customObject/schema.d.ts +1 -1
  145. package/commands/customObject/schema.js +17 -22
  146. package/commands/customObject.d.ts +1 -1
  147. package/commands/customObject.js +13 -18
  148. package/commands/doctor.d.ts +1 -1
  149. package/commands/doctor.js +28 -33
  150. package/commands/feedback.d.ts +1 -1
  151. package/commands/feedback.js +19 -24
  152. package/commands/fetch.d.ts +1 -1
  153. package/commands/fetch.js +28 -30
  154. package/commands/filemanager/__tests__/fetch.test.js +17 -22
  155. package/commands/filemanager/__tests__/upload.test.js +15 -20
  156. package/commands/filemanager/fetch.d.ts +1 -1
  157. package/commands/filemanager/fetch.js +23 -25
  158. package/commands/filemanager/upload.d.ts +1 -1
  159. package/commands/filemanager/upload.js +39 -44
  160. package/commands/filemanager.d.ts +1 -1
  161. package/commands/filemanager.js +8 -13
  162. package/commands/function/deploy.d.ts +1 -1
  163. package/commands/function/deploy.js +35 -40
  164. package/commands/function/list.d.ts +1 -1
  165. package/commands/function/list.js +24 -29
  166. package/commands/function/server.d.ts +1 -1
  167. package/commands/function/server.js +15 -17
  168. package/commands/function.d.ts +1 -1
  169. package/commands/function.js +12 -18
  170. package/commands/getStarted.d.ts +1 -1
  171. package/commands/getStarted.js +125 -146
  172. package/commands/hubdb/__tests__/clear.test.js +13 -18
  173. package/commands/hubdb/__tests__/create.test.js +13 -18
  174. package/commands/hubdb/__tests__/delete.test.js +13 -18
  175. package/commands/hubdb/__tests__/fetch.test.js +13 -18
  176. package/commands/hubdb/__tests__/list.test.js +23 -28
  177. package/commands/hubdb/clear.d.ts +1 -1
  178. package/commands/hubdb/clear.js +20 -22
  179. package/commands/hubdb/create.d.ts +1 -1
  180. package/commands/hubdb/create.js +30 -35
  181. package/commands/hubdb/delete.d.ts +1 -1
  182. package/commands/hubdb/delete.js +24 -26
  183. package/commands/hubdb/fetch.d.ts +1 -1
  184. package/commands/hubdb/fetch.js +17 -19
  185. package/commands/hubdb/list.d.ts +1 -1
  186. package/commands/hubdb/list.js +33 -35
  187. package/commands/hubdb.d.ts +1 -1
  188. package/commands/hubdb.js +18 -24
  189. package/commands/init.d.ts +1 -1
  190. package/commands/init.js +83 -88
  191. package/commands/lint.d.ts +1 -1
  192. package/commands/lint.js +24 -26
  193. package/commands/list.d.ts +1 -1
  194. package/commands/list.js +32 -37
  195. package/commands/logs.d.ts +1 -1
  196. package/commands/logs.js +35 -37
  197. package/commands/mcp/__tests__/setup.test.js +7 -12
  198. package/commands/mcp/__tests__/start.test.js +7 -12
  199. package/commands/mcp/setup.d.ts +1 -1
  200. package/commands/mcp/setup.js +17 -19
  201. package/commands/mcp/start.d.ts +1 -1
  202. package/commands/mcp/start.js +32 -34
  203. package/commands/mcp.d.ts +1 -1
  204. package/commands/mcp.js +7 -12
  205. package/commands/module/marketplace-validate.d.ts +1 -1
  206. package/commands/module/marketplace-validate.js +21 -26
  207. package/commands/module.d.ts +1 -1
  208. package/commands/module.js +7 -13
  209. package/commands/mv.d.ts +1 -1
  210. package/commands/mv.js +20 -22
  211. package/commands/open.d.ts +1 -1
  212. package/commands/open.js +19 -21
  213. package/commands/project/__tests__/add.test.js +10 -15
  214. package/commands/project/__tests__/create.test.js +14 -19
  215. package/commands/project/__tests__/deploy.test.js +99 -141
  216. package/commands/project/__tests__/devUnifiedFlow.test.js +151 -155
  217. package/commands/project/__tests__/download.test.js +14 -19
  218. package/commands/project/__tests__/installDeps.test.js +32 -70
  219. package/commands/project/__tests__/listBuilds.test.js +14 -19
  220. package/commands/project/__tests__/logs.test.js +56 -94
  221. package/commands/project/__tests__/migrate.test.js +25 -30
  222. package/commands/project/__tests__/migrateApp.test.js +17 -22
  223. package/commands/project/__tests__/open.test.js +16 -21
  224. package/commands/project/__tests__/profile.test.js +14 -19
  225. package/commands/project/__tests__/upload.test.js +18 -23
  226. package/commands/project/__tests__/watch.test.js +14 -19
  227. package/commands/project/add.d.ts +1 -1
  228. package/commands/project/add.js +34 -36
  229. package/commands/project/cloneApp.d.ts +1 -1
  230. package/commands/project/cloneApp.js +67 -72
  231. package/commands/project/create.d.ts +2 -2
  232. package/commands/project/create.js +63 -68
  233. package/commands/project/deploy.d.ts +2 -2
  234. package/commands/project/deploy.js +83 -90
  235. package/commands/project/dev/deprecatedFlow.d.ts +2 -2
  236. package/commands/project/dev/deprecatedFlow.js +52 -58
  237. package/commands/project/dev/index.d.ts +1 -1
  238. package/commands/project/dev/index.js +44 -47
  239. package/commands/project/dev/unifiedFlow.d.ts +3 -3
  240. package/commands/project/dev/unifiedFlow.js +69 -76
  241. package/commands/project/download.d.ts +1 -1
  242. package/commands/project/download.js +35 -40
  243. package/commands/project/installDeps.d.ts +1 -1
  244. package/commands/project/installDeps.js +29 -34
  245. package/commands/project/listBuilds.d.ts +1 -1
  246. package/commands/project/listBuilds.js +40 -45
  247. package/commands/project/logs.d.ts +1 -1
  248. package/commands/project/logs.js +52 -54
  249. package/commands/project/migrate.d.ts +1 -1
  250. package/commands/project/migrate.js +24 -26
  251. package/commands/project/migrateApp.d.ts +2 -2
  252. package/commands/project/migrateApp.js +18 -20
  253. package/commands/project/open.d.ts +1 -1
  254. package/commands/project/open.js +25 -30
  255. package/commands/project/profile/add.d.ts +1 -1
  256. package/commands/project/profile/add.js +68 -73
  257. package/commands/project/profile/delete.d.ts +1 -1
  258. package/commands/project/profile/delete.js +68 -61
  259. package/commands/project/profile.d.ts +1 -1
  260. package/commands/project/profile.js +9 -14
  261. package/commands/project/upload.d.ts +1 -1
  262. package/commands/project/upload.js +50 -55
  263. package/commands/project/validate.d.ts +1 -1
  264. package/commands/project/validate.js +36 -40
  265. package/commands/project/watch.d.ts +1 -1
  266. package/commands/project/watch.js +59 -61
  267. package/commands/project.d.ts +1 -1
  268. package/commands/project.js +38 -43
  269. package/commands/remove.d.ts +1 -1
  270. package/commands/remove.js +15 -17
  271. package/commands/sandbox/__tests__/create.test.js +222 -20
  272. package/commands/sandbox/__tests__/delete.test.js +15 -20
  273. package/commands/sandbox/create.d.ts +2 -2
  274. package/commands/sandbox/create.js +92 -79
  275. package/commands/sandbox/delete.d.ts +1 -1
  276. package/commands/sandbox/delete.js +94 -96
  277. package/commands/sandbox.d.ts +1 -1
  278. package/commands/sandbox.js +9 -14
  279. package/commands/secret/__tests__/addSecret.test.js +13 -18
  280. package/commands/secret/__tests__/deleteSecret.test.js +13 -18
  281. package/commands/secret/__tests__/listSecret.test.js +13 -18
  282. package/commands/secret/__tests__/updateSecret.test.js +13 -18
  283. package/commands/secret/addSecret.d.ts +1 -1
  284. package/commands/secret/addSecret.js +26 -28
  285. package/commands/secret/deleteSecret.d.ts +1 -1
  286. package/commands/secret/deleteSecret.js +27 -29
  287. package/commands/secret/listSecret.d.ts +1 -1
  288. package/commands/secret/listSecret.js +19 -21
  289. package/commands/secret/updateSecret.d.ts +1 -1
  290. package/commands/secret/updateSecret.js +25 -27
  291. package/commands/secret.d.ts +1 -1
  292. package/commands/secret.js +13 -18
  293. package/commands/testAccount/__tests__/create.test.js +17 -22
  294. package/commands/testAccount/__tests__/createConfig.test.js +6 -11
  295. package/commands/testAccount/__tests__/delete.test.js +15 -20
  296. package/commands/testAccount/create.d.ts +1 -1
  297. package/commands/testAccount/create.js +63 -84
  298. package/commands/testAccount/createConfig.d.ts +1 -1
  299. package/commands/testAccount/createConfig.js +36 -41
  300. package/commands/testAccount/delete.d.ts +1 -1
  301. package/commands/testAccount/delete.js +17 -19
  302. package/commands/testAccount.d.ts +1 -1
  303. package/commands/testAccount.js +10 -15
  304. package/commands/theme/__tests__/generate-selectors.test.js +7 -12
  305. package/commands/theme/__tests__/marketplace-validate.test.js +14 -19
  306. package/commands/theme/__tests__/preview.test.js +12 -17
  307. package/commands/theme/generate-selectors.d.ts +1 -1
  308. package/commands/theme/generate-selectors.js +23 -28
  309. package/commands/theme/marketplace-validate.d.ts +1 -1
  310. package/commands/theme/marketplace-validate.js +19 -24
  311. package/commands/theme/preview.d.ts +1 -1
  312. package/commands/theme/preview.js +60 -65
  313. package/commands/theme.d.ts +1 -1
  314. package/commands/theme.js +11 -16
  315. package/commands/upload.d.ts +1 -1
  316. package/commands/upload.js +77 -82
  317. package/commands/watch.d.ts +1 -1
  318. package/commands/watch.js +45 -51
  319. package/lang/en.d.ts +52 -25
  320. package/lang/en.js +421 -397
  321. package/lang/en.lyaml +4 -28
  322. package/lib/__tests__/accountTypes.test.js +20 -22
  323. package/lib/__tests__/buildAccount.test.js +115 -64
  324. package/lib/__tests__/commonOpts.test.js +20 -22
  325. package/lib/__tests__/dependencyManagement.test.js +46 -51
  326. package/lib/__tests__/developerTestAccounts.test.js +27 -62
  327. package/lib/__tests__/hasFeature.test.js +6 -8
  328. package/lib/__tests__/npm.test.js +15 -20
  329. package/lib/__tests__/oauth.test.js +23 -28
  330. package/lib/__tests__/parsing.test.js +18 -20
  331. package/lib/__tests__/polling.test.js +24 -26
  332. package/lib/__tests__/process.test.js +14 -19
  333. package/lib/__tests__/projectProfiles.test.js +34 -39
  334. package/lib/__tests__/sandboxSync.test.js +30 -35
  335. package/lib/__tests__/sandboxes.test.js +29 -31
  336. package/lib/__tests__/serverlessLogs.test.js +8 -13
  337. package/lib/__tests__/usageTracking.test.js +33 -34
  338. package/lib/__tests__/validation.test.js +18 -20
  339. package/lib/__tests__/yargsUtils.test.js +17 -41
  340. package/lib/accountTypes.js +24 -34
  341. package/lib/app/__tests__/migrate.test.js +117 -109
  342. package/lib/app/__tests__/migrate_legacy.test.js +29 -31
  343. package/lib/app/migrate.d.ts +18 -4
  344. package/lib/app/migrate.js +152 -148
  345. package/lib/app/migrate_legacy.d.ts +1 -1
  346. package/lib/app/migrate_legacy.js +72 -78
  347. package/lib/app/urls.js +5 -9
  348. package/lib/buildAccount.d.ts +12 -3
  349. package/lib/buildAccount.js +165 -69
  350. package/lib/commonOpts.d.ts +1 -1
  351. package/lib/commonOpts.js +67 -59
  352. package/lib/configMigrate.js +34 -38
  353. package/lib/configOptions.d.ts +5 -0
  354. package/lib/configOptions.js +44 -40
  355. package/lib/constants.d.ts +8 -0
  356. package/lib/constants.js +39 -34
  357. package/lib/customObject.js +2 -6
  358. package/lib/dependencyManagement.js +37 -45
  359. package/lib/developerTestAccounts.d.ts +1 -1
  360. package/lib/developerTestAccounts.js +34 -39
  361. package/lib/doctor/Diagnosis.d.ts +1 -1
  362. package/lib/doctor/Diagnosis.js +25 -29
  363. package/lib/doctor/DiagnosticInfoBuilder.d.ts +1 -1
  364. package/lib/doctor/DiagnosticInfoBuilder.js +30 -37
  365. package/lib/doctor/Doctor.d.ts +1 -1
  366. package/lib/doctor/Doctor.js +94 -101
  367. package/lib/doctor/__tests__/Diagnosis.test.js +9 -14
  368. package/lib/doctor/__tests__/DiagnosticInfoBuilder.test.js +29 -34
  369. package/lib/doctor/__tests__/Doctor.test.js +24 -26
  370. package/lib/enums/exitCodes.js +1 -4
  371. package/lib/errorHandlers/index.js +33 -52
  372. package/lib/errorHandlers/suppressError.d.ts +1 -1
  373. package/lib/errorHandlers/suppressError.js +28 -31
  374. package/lib/errors/ProjectValidationError.d.ts +4 -0
  375. package/lib/errors/ProjectValidationError.js +9 -0
  376. package/lib/filesystem.js +8 -15
  377. package/lib/generateSelectors.js +18 -29
  378. package/lib/hasFeature.d.ts +1 -1
  379. package/lib/hasFeature.js +3 -6
  380. package/lib/interpolation.js +11 -18
  381. package/lib/lang.d.ts +1 -1
  382. package/lib/lang.js +22 -27
  383. package/lib/links.js +16 -24
  384. package/lib/marketplaceValidate.js +29 -39
  385. package/lib/mcp/setup.d.ts +4 -0
  386. package/lib/mcp/setup.js +106 -82
  387. package/lib/middleware/__test__/configMiddleware.test.js +20 -55
  388. package/lib/middleware/__test__/gitMiddleware.test.js +7 -42
  389. package/lib/middleware/__test__/notificationsMiddleware.test.js +2 -4
  390. package/lib/middleware/__test__/requestMiddleware.test.js +6 -11
  391. package/lib/middleware/__test__/utils.test.js +9 -11
  392. package/lib/middleware/__test__/yargsChecksMiddleware.test.js +9 -44
  393. package/lib/middleware/autoUpdateMiddleware.js +33 -40
  394. package/lib/middleware/configMiddleware.js +36 -42
  395. package/lib/middleware/fireAlarmMiddleware.js +12 -18
  396. package/lib/middleware/gitMiddleware.js +5 -8
  397. package/lib/middleware/notificationsMiddleware.js +16 -23
  398. package/lib/middleware/requestMiddleware.js +4 -10
  399. package/lib/middleware/utils.js +1 -4
  400. package/lib/middleware/yargsChecksMiddleware.js +10 -13
  401. package/lib/npm.js +14 -23
  402. package/lib/oauth.js +29 -35
  403. package/lib/parsing.js +3 -6
  404. package/lib/polling.js +11 -15
  405. package/lib/process.js +11 -19
  406. package/lib/projectProfiles.d.ts +2 -2
  407. package/lib/projectProfiles.js +32 -42
  408. package/lib/projects/ProjectLogsManager.js +18 -21
  409. package/lib/projects/__tests__/AppDevModeInterface.test.js +140 -145
  410. package/lib/projects/__tests__/LocalDevProcess.test.js +100 -140
  411. package/lib/projects/__tests__/LocalDevWebsocketServer.test.js +201 -37
  412. package/lib/projects/__tests__/ProjectLogsManager.test.js +56 -58
  413. package/lib/projects/__tests__/buildAndDeploy.test.js +7 -9
  414. package/lib/projects/__tests__/components.test.js +9 -14
  415. package/lib/projects/__tests__/localDevHelpers.test.js +117 -0
  416. package/lib/projects/__tests__/projects.test.js +35 -40
  417. package/lib/projects/__tests__/structure.test.js +43 -81
  418. package/lib/projects/add/__tests__/legacyAddComponent.test.js +26 -28
  419. package/lib/projects/add/__tests__/v3AddComponent.test.js +25 -30
  420. package/lib/projects/add/legacyAddComponent.d.ts +1 -1
  421. package/lib/projects/add/legacyAddComponent.js +24 -30
  422. package/lib/projects/add/v3AddComponent.d.ts +1 -1
  423. package/lib/projects/add/v3AddComponent.js +37 -42
  424. package/lib/projects/buildAndDeploy.d.ts +1 -1
  425. package/lib/projects/buildAndDeploy.js +88 -97
  426. package/lib/projects/components.js +19 -25
  427. package/lib/projects/config.d.ts +1 -1
  428. package/lib/projects/config.js +32 -41
  429. package/lib/projects/create/__tests__/legacy.test.js +22 -57
  430. package/lib/projects/create/__tests__/v3.test.js +5 -7
  431. package/lib/projects/create/index.d.ts +3 -3
  432. package/lib/projects/create/index.js +19 -22
  433. package/lib/projects/create/legacy.d.ts +1 -1
  434. package/lib/projects/create/legacy.js +25 -31
  435. package/lib/projects/create/v3.d.ts +3 -5
  436. package/lib/projects/create/v3.js +47 -59
  437. package/lib/projects/ensureProjectExists.js +31 -37
  438. package/lib/projects/localDev/AppDevModeInterface.d.ts +3 -3
  439. package/lib/projects/localDev/AppDevModeInterface.js +58 -60
  440. package/lib/projects/localDev/DevServerManager.d.ts +1 -1
  441. package/lib/projects/localDev/DevServerManager.js +22 -26
  442. package/lib/projects/localDev/DevServerManagerV2.d.ts +2 -2
  443. package/lib/projects/localDev/DevServerManagerV2.js +15 -22
  444. package/lib/projects/localDev/LocalDevLogger.d.ts +1 -2
  445. package/lib/projects/localDev/LocalDevLogger.js +66 -66
  446. package/lib/projects/localDev/LocalDevManager.d.ts +1 -1
  447. package/lib/projects/localDev/LocalDevManager.js +106 -111
  448. package/lib/projects/localDev/LocalDevProcess.d.ts +6 -5
  449. package/lib/projects/localDev/LocalDevProcess.js +37 -50
  450. package/lib/projects/localDev/LocalDevState.d.ts +5 -7
  451. package/lib/projects/localDev/LocalDevState.js +9 -11
  452. package/lib/projects/localDev/LocalDevWatcher.d.ts +1 -1
  453. package/lib/projects/localDev/LocalDevWatcher.js +6 -11
  454. package/lib/projects/localDev/LocalDevWebsocketServer.d.ts +3 -3
  455. package/lib/projects/localDev/LocalDevWebsocketServer.js +63 -55
  456. package/lib/projects/localDev/helpers.d.ts +11 -4
  457. package/lib/projects/localDev/helpers.js +211 -174
  458. package/lib/projects/structure.d.ts +3 -3
  459. package/lib/projects/structure.js +32 -78
  460. package/lib/projects/ui.js +10 -13
  461. package/lib/projects/upload.d.ts +1 -1
  462. package/lib/projects/upload.js +57 -73
  463. package/lib/projects/urls.d.ts +1 -1
  464. package/lib/projects/urls.js +15 -25
  465. package/lib/projects/watch.d.ts +1 -1
  466. package/lib/projects/watch.js +48 -54
  467. package/lib/prompts/__tests__/downloadProjectPrompt.test.js +9 -11
  468. package/lib/prompts/__tests__/projectsLogsPrompt.test.js +11 -16
  469. package/lib/prompts/accountNamePrompt.d.ts +1 -1
  470. package/lib/prompts/accountNamePrompt.js +26 -31
  471. package/lib/prompts/accountsPrompt.js +12 -15
  472. package/lib/prompts/cmsFieldPrompt.js +13 -19
  473. package/lib/prompts/createApiSamplePrompt.d.ts +1 -1
  474. package/lib/prompts/createApiSamplePrompt.js +9 -12
  475. package/lib/prompts/createDeveloperTestAccountConfigPrompt.d.ts +2 -2
  476. package/lib/prompts/createDeveloperTestAccountConfigPrompt.js +27 -31
  477. package/lib/prompts/createFunctionPrompt.js +17 -20
  478. package/lib/prompts/createModulePrompt.js +12 -15
  479. package/lib/prompts/createTemplatePrompt.js +5 -8
  480. package/lib/prompts/downloadProjectPrompt.js +17 -20
  481. package/lib/prompts/installAppPrompt.js +19 -26
  482. package/lib/prompts/personalAccessKeyPrompt.d.ts +2 -2
  483. package/lib/prompts/personalAccessKeyPrompt.js +40 -47
  484. package/lib/prompts/previewPrompt.js +15 -22
  485. package/lib/prompts/projectAddPrompt.d.ts +1 -1
  486. package/lib/prompts/projectAddPrompt.js +14 -18
  487. package/lib/prompts/projectDevTargetAccountPrompt.d.ts +1 -1
  488. package/lib/prompts/projectDevTargetAccountPrompt.js +48 -54
  489. package/lib/prompts/projectNameAndDestPrompt.d.ts +1 -1
  490. package/lib/prompts/projectNameAndDestPrompt.js +22 -29
  491. package/lib/prompts/projectNamePrompt.js +11 -14
  492. package/lib/prompts/projectsLogsPrompt.js +5 -8
  493. package/lib/prompts/promptUtils.d.ts +1 -1
  494. package/lib/prompts/promptUtils.js +80 -77
  495. package/lib/prompts/sandboxesPrompt.d.ts +1 -1
  496. package/lib/prompts/sandboxesPrompt.js +26 -30
  497. package/lib/prompts/secretPrompt.js +10 -15
  498. package/lib/prompts/selectAppPrompt.js +11 -14
  499. package/lib/prompts/selectHubDBTablePrompt.js +24 -30
  500. package/lib/prompts/selectProjectTemplatePrompt.d.ts +1 -1
  501. package/lib/prompts/selectProjectTemplatePrompt.js +10 -13
  502. package/lib/prompts/selectPublicAppForMigrationPrompt.js +22 -25
  503. package/lib/prompts/setAsDefaultAccountPrompt.js +13 -16
  504. package/lib/prompts/uploadPrompt.js +11 -17
  505. package/lib/sandboxSync.d.ts +1 -1
  506. package/lib/sandboxSync.js +58 -65
  507. package/lib/sandboxes.d.ts +5 -1
  508. package/lib/sandboxes.js +72 -76
  509. package/lib/schema.js +13 -20
  510. package/lib/serverlessLogs.js +45 -52
  511. package/lib/testUtils.js +4 -8
  512. package/lib/ui/SpinniesManager.d.ts +1 -1
  513. package/lib/ui/SpinniesManager.js +29 -34
  514. package/lib/ui/boxen.js +11 -14
  515. package/lib/ui/git.js +14 -20
  516. package/lib/ui/index.d.ts +6 -0
  517. package/lib/ui/index.js +56 -76
  518. package/lib/ui/logger.js +10 -13
  519. package/lib/ui/serverlessFunctionLogs.js +14 -20
  520. package/lib/ui/spinniesUtils.js +24 -39
  521. package/lib/ui/supportHyperlinks.js +3 -6
  522. package/lib/ui/supportsColor.js +11 -17
  523. package/lib/ui/table.js +6 -13
  524. package/lib/upload.js +15 -21
  525. package/lib/usageTracking.js +35 -44
  526. package/lib/utils/__tests__/isDeepEqual.test.js +269 -0
  527. package/lib/utils/hasFlag.js +2 -8
  528. package/lib/utils/isDeepEqual.d.ts +1 -0
  529. package/lib/utils/isDeepEqual.js +31 -0
  530. package/lib/validation.js +48 -87
  531. package/lib/yargsUtils.d.ts +2 -1
  532. package/lib/yargsUtils.js +19 -16
  533. package/mcp-server/server.js +6 -8
  534. package/mcp-server/tools/index.js +15 -16
  535. package/mcp-server/tools/project/{AddFeatureToProject.d.ts → AddFeatureToProjectTool.d.ts} +5 -5
  536. package/mcp-server/tools/project/AddFeatureToProjectTool.js +76 -0
  537. package/mcp-server/tools/project/CreateProjectTool.d.ts +4 -4
  538. package/mcp-server/tools/project/CreateProjectTool.js +40 -54
  539. package/mcp-server/tools/project/{DeployProject.d.ts → DeployProjectTool.d.ts} +2 -2
  540. package/mcp-server/tools/project/DeployProjectTool.js +49 -0
  541. package/mcp-server/tools/project/GetConfigValuesTool.d.ts +20 -0
  542. package/mcp-server/tools/project/GetConfigValuesTool.js +51 -0
  543. package/mcp-server/tools/project/GuidedWalkthroughTool.d.ts +1 -1
  544. package/mcp-server/tools/project/GuidedWalkthroughTool.js +21 -25
  545. package/mcp-server/tools/project/UploadProjectTools.d.ts +1 -1
  546. package/mcp-server/tools/project/UploadProjectTools.js +12 -19
  547. package/mcp-server/tools/project/ValidateProjectTool.d.ts +1 -1
  548. package/mcp-server/tools/project/ValidateProjectTool.js +13 -17
  549. package/mcp-server/tools/project/__tests__/AddFeatureToProjectTool.test.d.ts +1 -0
  550. package/mcp-server/tools/project/__tests__/{AddFeatureToProject.test.js → AddFeatureToProjectTool.test.js} +15 -17
  551. package/mcp-server/tools/project/__tests__/CreateProjectTool.test.js +12 -15
  552. package/mcp-server/tools/project/__tests__/DeployProjectTool.test.d.ts +1 -0
  553. package/mcp-server/tools/project/__tests__/{DeployProject.test.js → DeployProjectTool.test.js} +6 -8
  554. package/mcp-server/tools/project/__tests__/GetConfigValuesTool.test.d.ts +1 -0
  555. package/mcp-server/tools/project/__tests__/GetConfigValuesTool.test.js +198 -0
  556. package/mcp-server/tools/project/__tests__/GuidedWalkthroughTool.test.js +4 -6
  557. package/mcp-server/tools/project/__tests__/UploadProjectTools.test.js +4 -6
  558. package/mcp-server/tools/project/__tests__/ValidateProjectTool.test.js +4 -6
  559. package/mcp-server/tools/project/constants.d.ts +1 -0
  560. package/mcp-server/tools/project/constants.js +14 -9
  561. package/mcp-server/types.js +1 -5
  562. package/mcp-server/utils/__tests__/command.test.js +9 -11
  563. package/mcp-server/utils/__tests__/project.test.js +12 -17
  564. package/mcp-server/utils/command.d.ts +1 -1
  565. package/mcp-server/utils/command.js +4 -11
  566. package/mcp-server/utils/content.d.ts +1 -1
  567. package/mcp-server/utils/content.js +2 -6
  568. package/mcp-server/utils/project.js +8 -14
  569. package/mcp-server/utils/toolUsageTracking.js +11 -14
  570. package/package.json +22 -15
  571. package/types/Cms.d.ts +1 -1
  572. package/types/Cms.js +1 -2
  573. package/types/LocalDev.d.ts +4 -6
  574. package/types/LocalDev.js +1 -2
  575. package/types/ProjectComponents.d.ts +2 -2
  576. package/types/ProjectComponents.js +1 -2
  577. package/types/Projects.d.ts +1 -1
  578. package/types/Projects.js +2 -5
  579. package/types/Prompts.js +1 -2
  580. package/types/Sandboxes.js +1 -2
  581. package/types/Yargs.js +1 -2
  582. package/ui/index.d.ts +1 -0
  583. package/ui/index.js +6 -0
  584. package/mcp-server/tools/project/AddFeatureToProject.js +0 -88
  585. package/mcp-server/tools/project/DeployProject.js +0 -53
  586. /package/{mcp-server/tools/project/__tests__/AddFeatureToProject.test.d.ts → lib/projects/__tests__/localDevHelpers.test.d.ts} +0 -0
  587. /package/{mcp-server/tools/project/__tests__/DeployProject.test.d.ts → lib/utils/__tests__/isDeepEqual.test.d.ts} +0 -0
@@ -1,30 +1,25 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- const yargs_1 = __importDefault(require("yargs"));
7
- const fetch_1 = __importDefault(require("../filemanager/fetch"));
8
- const upload_1 = __importDefault(require("../filemanager/upload"));
9
- const filemanager_1 = __importDefault(require("../filemanager"));
1
+ import yargs from 'yargs';
2
+ import fetch from '../filemanager/fetch.js';
3
+ import upload from '../filemanager/upload.js';
4
+ import fileManagerCommands from '../filemanager.js';
10
5
  vi.mock('../filemanager/fetch');
11
6
  vi.mock('../filemanager/upload');
12
7
  vi.mock('../../lib/commonOpts');
13
8
  const commandSpy = vi
14
- .spyOn(yargs_1.default, 'command')
15
- .mockReturnValue(yargs_1.default);
9
+ .spyOn(yargs, 'command')
10
+ .mockReturnValue(yargs);
16
11
  const demandCommandSpy = vi
17
- .spyOn(yargs_1.default, 'demandCommand')
18
- .mockReturnValue(yargs_1.default);
12
+ .spyOn(yargs, 'demandCommand')
13
+ .mockReturnValue(yargs);
19
14
  describe('commands/filemanager', () => {
20
15
  describe('command', () => {
21
16
  it('should have the correct command structure', () => {
22
- expect(filemanager_1.default.command).toEqual('filemanager');
17
+ expect(fileManagerCommands.command).toEqual('filemanager');
23
18
  });
24
19
  });
25
20
  describe('describe', () => {
26
21
  it('should provide a description', () => {
27
- expect(filemanager_1.default.describe).toBeDefined();
22
+ expect(fileManagerCommands.describe).toBeDefined();
28
23
  });
29
24
  });
30
25
  describe('builder', () => {
@@ -32,18 +27,18 @@ describe('commands/filemanager', () => {
32
27
  commandSpy.mockClear();
33
28
  demandCommandSpy.mockClear();
34
29
  });
35
- const subcommands = [fetch_1.default, upload_1.default];
30
+ const subcommands = [fetch, upload];
36
31
  it('should demand the command takes one positional argument', () => {
37
- filemanager_1.default.builder(yargs_1.default);
32
+ fileManagerCommands.builder(yargs);
38
33
  expect(demandCommandSpy).toHaveBeenCalledTimes(1);
39
34
  expect(demandCommandSpy).toHaveBeenCalledWith(1, '');
40
35
  });
41
36
  it('should add the correct number of sub commands', () => {
42
- filemanager_1.default.builder(yargs_1.default);
37
+ fileManagerCommands.builder(yargs);
43
38
  expect(commandSpy).toHaveBeenCalledTimes(subcommands.length);
44
39
  });
45
40
  it.each(subcommands)('should attach the %s subcommand', module => {
46
- filemanager_1.default.builder(yargs_1.default);
41
+ fileManagerCommands.builder(yargs);
47
42
  expect(commandSpy).toHaveBeenCalledWith(module);
48
43
  });
49
44
  });
@@ -1,50 +1,45 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- const yargs_1 = __importDefault(require("yargs"));
7
- const list_1 = __importDefault(require("../function/list"));
8
- const deploy_1 = __importDefault(require("../function/deploy"));
9
- const server_1 = __importDefault(require("../function/server"));
10
- const function_1 = __importDefault(require("../function"));
1
+ import yargs from 'yargs';
2
+ import list from '../function/list.js';
3
+ import deploy from '../function/deploy.js';
4
+ import server from '../function/server.js';
5
+ import functionCommands from '../function.js';
11
6
  vi.mock('../function/list');
12
7
  vi.mock('../function/deploy');
13
8
  vi.mock('../function/server');
14
9
  vi.mock('../../lib/commonOpts');
15
10
  const commandSpy = vi
16
- .spyOn(yargs_1.default, 'command')
17
- .mockReturnValue(yargs_1.default);
11
+ .spyOn(yargs, 'command')
12
+ .mockReturnValue(yargs);
18
13
  const demandCommandSpy = vi
19
- .spyOn(yargs_1.default, 'demandCommand')
20
- .mockReturnValue(yargs_1.default);
14
+ .spyOn(yargs, 'demandCommand')
15
+ .mockReturnValue(yargs);
21
16
  describe('commands/function', () => {
22
17
  describe('command', () => {
23
18
  it('should have the correct command structure', () => {
24
- expect(function_1.default.command).toEqual(['function', 'functions']);
19
+ expect(functionCommands.command).toEqual(['function', 'functions']);
25
20
  });
26
21
  });
27
22
  describe('describe', () => {
28
23
  it('should provide a description', () => {
29
- expect(function_1.default.describe).toBeDefined();
24
+ expect(functionCommands.describe).toBeDefined();
30
25
  });
31
26
  });
32
27
  describe('builder', () => {
33
- const subcommands = [list_1.default, deploy_1.default, server_1.default];
28
+ const subcommands = [list, deploy, server];
34
29
  it('should demand the command takes one positional argument', () => {
35
- function_1.default.builder(yargs_1.default);
30
+ functionCommands.builder(yargs);
36
31
  expect(demandCommandSpy).toHaveBeenCalledTimes(1);
37
32
  expect(demandCommandSpy).toHaveBeenCalledWith(1, '');
38
33
  });
39
34
  it('should support the correct options', () => {
40
- function_1.default.builder(yargs_1.default);
35
+ functionCommands.builder(yargs);
41
36
  });
42
37
  it('should add the correct number of sub commands', () => {
43
- function_1.default.builder(yargs_1.default);
38
+ functionCommands.builder(yargs);
44
39
  expect(commandSpy).toHaveBeenCalledTimes(subcommands.length);
45
40
  });
46
41
  it.each(subcommands)('should attach the %s subcommand', module => {
47
- function_1.default.builder(yargs_1.default);
42
+ functionCommands.builder(yargs);
48
43
  expect(commandSpy).toHaveBeenCalledWith(module);
49
44
  });
50
45
  });
@@ -1,18 +1,13 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- const getStarted_1 = __importDefault(require("../getStarted"));
7
- const usageTracking_1 = require("../../lib/usageTracking");
8
- const promptUtils_1 = require("../../lib/prompts/promptUtils");
9
- const projectNameAndDestPrompt_1 = require("../../lib/prompts/projectNameAndDestPrompt");
10
- const github_1 = require("@hubspot/local-dev-lib/github");
11
- const config_1 = require("../../lib/projects/config");
12
- const dependencyManagement_1 = require("../../lib/dependencyManagement");
13
- const constants_1 = require("../../lib/constants");
14
- const exitCodes_1 = require("../../lib/enums/exitCodes");
15
- const open_1 = __importDefault(require("open"));
1
+ import getStartedCommand from '../getStarted.js';
2
+ import { trackCommandUsage } from '../../lib/usageTracking.js';
3
+ import { promptUser } from '../../lib/prompts/promptUtils.js';
4
+ import { projectNameAndDestPrompt } from '../../lib/prompts/projectNameAndDestPrompt.js';
5
+ import { cloneGithubRepo } from '@hubspot/local-dev-lib/github';
6
+ import { getProjectConfig, writeProjectConfig, } from '../../lib/projects/config.js';
7
+ import { getProjectPackageJsonLocations, installPackages, } from '../../lib/dependencyManagement.js';
8
+ import { GET_STARTED_OPTIONS } from '../../lib/constants.js';
9
+ import { EXIT_CODES } from '../../lib/enums/exitCodes.js';
10
+ import open from 'open';
16
11
  vi.mock('../../lib/usageTracking');
17
12
  vi.mock('../../lib/prompts/promptUtils');
18
13
  vi.mock('../../lib/prompts/projectNameAndDestPrompt');
@@ -35,22 +30,22 @@ describe('commands/get-started', () => {
35
30
  });
36
31
  describe('command', () => {
37
32
  it('should have the correct command structure', () => {
38
- expect(getStarted_1.default.command).toEqual('get-started');
33
+ expect(getStartedCommand.command).toEqual('get-started');
39
34
  });
40
35
  });
41
36
  describe('describe', () => {
42
37
  it('should have undefined describe property', () => {
43
- expect(getStarted_1.default.describe).toBeUndefined();
38
+ expect(getStartedCommand.describe).toBeUndefined();
44
39
  });
45
40
  });
46
41
  describe('command structure', () => {
47
42
  it('should have handler function', () => {
48
- expect(getStarted_1.default.handler).toBeDefined();
49
- expect(typeof getStarted_1.default.handler).toBe('function');
43
+ expect(getStartedCommand.handler).toBeDefined();
44
+ expect(typeof getStartedCommand.handler).toBe('function');
50
45
  });
51
46
  it('should have builder function', () => {
52
- expect(getStarted_1.default.builder).toBeDefined();
53
- expect(typeof getStarted_1.default.builder).toBe('function');
47
+ expect(getStartedCommand.builder).toBeDefined();
48
+ expect(typeof getStartedCommand.builder).toBe('function');
54
49
  });
55
50
  });
56
51
  describe('handler', () => {
@@ -72,65 +67,62 @@ describe('commands/get-started', () => {
72
67
  };
73
68
  beforeEach(() => {
74
69
  vi.clearAllMocks();
75
- usageTracking_1.trackCommandUsage.mockResolvedValue(undefined);
76
- projectNameAndDestPrompt_1.projectNameAndDestPrompt.mockResolvedValue({
70
+ trackCommandUsage.mockResolvedValue(undefined);
71
+ projectNameAndDestPrompt.mockResolvedValue({
77
72
  dest: 'test-destination',
78
73
  name: 'test-project',
79
74
  });
80
- github_1.cloneGithubRepo.mockResolvedValue(true);
81
- config_1.getProjectConfig.mockResolvedValue({
75
+ cloneGithubRepo.mockResolvedValue(true);
76
+ getProjectConfig.mockResolvedValue({
82
77
  projectConfig: null,
83
78
  projectDir: null,
84
79
  });
85
- config_1.writeProjectConfig.mockResolvedValue(true);
86
- dependencyManagement_1.getProjectPackageJsonLocations.mockResolvedValue(['/path/to/package/dir']);
87
- dependencyManagement_1.installPackages.mockResolvedValue(undefined);
80
+ writeProjectConfig.mockResolvedValue(true);
81
+ getProjectPackageJsonLocations.mockResolvedValue(['/path/to/package/dir']);
82
+ installPackages.mockResolvedValue(undefined);
88
83
  process.exit = vi.fn();
89
84
  });
90
85
  describe('CMS flow', () => {
91
86
  it('should handle CMS option selection', async () => {
92
- promptUtils_1.promptUser.mockResolvedValue({
93
- default: constants_1.GET_STARTED_OPTIONS.CMS,
87
+ promptUser.mockResolvedValue({
88
+ default: GET_STARTED_OPTIONS.CMS,
94
89
  });
95
- await getStarted_1.default.handler(mockArgs);
96
- expect(process.exit).toHaveBeenCalledWith(exitCodes_1.EXIT_CODES.SUCCESS);
90
+ await getStartedCommand.handler(mockArgs);
91
+ expect(process.exit).toHaveBeenCalledWith(EXIT_CODES.SUCCESS);
97
92
  });
98
93
  it('should open Design Manager when user confirms and browser is available', async () => {
99
- promptUtils_1.promptUser
100
- .mockResolvedValueOnce({ default: constants_1.GET_STARTED_OPTIONS.CMS })
94
+ promptUser
95
+ .mockResolvedValueOnce({ default: GET_STARTED_OPTIONS.CMS })
101
96
  .mockResolvedValueOnce({ shouldOpen: true });
102
- await getStarted_1.default.handler(mockArgs);
103
- expect(open_1.default).toHaveBeenCalledWith(expect.stringContaining('design-manager'), { url: true });
97
+ await getStartedCommand.handler(mockArgs);
98
+ expect(open).toHaveBeenCalledWith(expect.stringContaining('design-manager'), { url: true });
104
99
  });
105
100
  });
106
101
  describe('App flow', () => {
107
102
  beforeEach(() => {
108
- promptUtils_1.promptUser
103
+ promptUser
109
104
  .mockResolvedValueOnce({
110
- default: constants_1.GET_STARTED_OPTIONS.APP,
111
- })
112
- .mockResolvedValueOnce({
113
- shouldInstallDependencies: true,
105
+ default: GET_STARTED_OPTIONS.APP,
114
106
  })
115
107
  .mockResolvedValueOnce({
116
108
  shouldUpload: true,
117
109
  });
118
110
  });
119
111
  it('should handle App option selection', async () => {
120
- await getStarted_1.default.handler(mockArgs);
121
- expect(projectNameAndDestPrompt_1.projectNameAndDestPrompt).toHaveBeenCalledWith(mockArgs);
122
- expect(github_1.cloneGithubRepo).toHaveBeenCalled();
112
+ await getStartedCommand.handler(mockArgs);
113
+ expect(projectNameAndDestPrompt).toHaveBeenCalledWith(mockArgs);
114
+ expect(cloneGithubRepo).toHaveBeenCalled();
123
115
  });
124
116
  it('should handle upload flow when user confirms', async () => {
125
- promptUtils_1.promptUser
126
- .mockResolvedValueOnce({ default: constants_1.GET_STARTED_OPTIONS.APP })
117
+ promptUser
118
+ .mockResolvedValueOnce({ default: GET_STARTED_OPTIONS.APP })
127
119
  .mockResolvedValueOnce({ shouldUpload: true });
128
120
  const mockProjectConfig = {
129
121
  name: 'test-project',
130
122
  srcDir: 'src',
131
123
  platformVersion: '1.0.0',
132
124
  };
133
- config_1.getProjectConfig
125
+ getProjectConfig
134
126
  .mockResolvedValueOnce({
135
127
  projectConfig: null,
136
128
  projectDir: null,
@@ -139,8 +131,8 @@ describe('commands/get-started', () => {
139
131
  projectConfig: mockProjectConfig,
140
132
  projectDir: '/path/to/project',
141
133
  });
142
- await getStarted_1.default.handler(mockArgs);
143
- expect(promptUtils_1.promptUser).toHaveBeenCalledWith([
134
+ await getStartedCommand.handler(mockArgs);
135
+ expect(promptUser).toHaveBeenCalledWith([
144
136
  expect.objectContaining({
145
137
  type: 'confirm',
146
138
  name: 'shouldUpload',
@@ -149,21 +141,14 @@ describe('commands/get-started', () => {
149
141
  }),
150
142
  ]);
151
143
  });
152
- it('should skip upload when user declines', async () => {
153
- promptUtils_1.promptUser
154
- .mockResolvedValueOnce({ shouldInstallDependencies: false })
155
- .mockResolvedValueOnce({ shouldUpload: false });
156
- await getStarted_1.default.handler(mockArgs);
157
- expect(process.exit).toHaveBeenCalledWith(exitCodes_1.EXIT_CODES.SUCCESS);
158
- });
159
144
  });
160
145
  describe('tracking', () => {
161
146
  it('should track command usage', async () => {
162
- promptUtils_1.promptUser.mockResolvedValue({
163
- default: constants_1.GET_STARTED_OPTIONS.APP,
147
+ promptUser.mockResolvedValue({
148
+ default: GET_STARTED_OPTIONS.APP,
164
149
  });
165
- await getStarted_1.default.handler(mockArgs);
166
- expect(usageTracking_1.trackCommandUsage).toHaveBeenCalledWith('get-started', {}, mockArgs.derivedAccountId);
150
+ await getStartedCommand.handler(mockArgs);
151
+ expect(trackCommandUsage).toHaveBeenCalledWith('get-started', {}, mockArgs.derivedAccountId);
167
152
  });
168
153
  });
169
154
  });
@@ -1,35 +1,30 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- const yargs_1 = __importDefault(require("yargs"));
7
- const clear_1 = __importDefault(require("../hubdb/clear"));
8
- const create_1 = __importDefault(require("../hubdb/create"));
9
- const delete_1 = __importDefault(require("../hubdb/delete"));
10
- const fetch_1 = __importDefault(require("../hubdb/fetch"));
11
- const list_1 = __importDefault(require("../hubdb/list"));
12
- const hubdb_1 = __importDefault(require("../hubdb"));
1
+ import yargs from 'yargs';
2
+ import clear from '../hubdb/clear.js';
3
+ import create from '../hubdb/create.js';
4
+ import deleteCommand from '../hubdb/delete.js';
5
+ import fetch from '../hubdb/fetch.js';
6
+ import list from '../hubdb/list.js';
7
+ import hubdbCommands from '../hubdb.js';
13
8
  vi.mock('../hubdb/clear');
14
9
  vi.mock('../hubdb/create');
15
10
  vi.mock('../hubdb/delete');
16
11
  vi.mock('../hubdb/fetch');
17
12
  vi.mock('../../lib/commonOpts');
18
13
  const commandSpy = vi
19
- .spyOn(yargs_1.default, 'command')
20
- .mockReturnValue(yargs_1.default);
14
+ .spyOn(yargs, 'command')
15
+ .mockReturnValue(yargs);
21
16
  const demandCommandSpy = vi
22
- .spyOn(yargs_1.default, 'demandCommand')
23
- .mockReturnValue(yargs_1.default);
17
+ .spyOn(yargs, 'demandCommand')
18
+ .mockReturnValue(yargs);
24
19
  describe('commands/hubdb', () => {
25
20
  describe('command', () => {
26
21
  it('should have the correct command structure', () => {
27
- expect(hubdb_1.default.command).toEqual('hubdb');
22
+ expect(hubdbCommands.command).toEqual('hubdb');
28
23
  });
29
24
  });
30
25
  describe('describe', () => {
31
26
  it('should provide a description', () => {
32
- expect(hubdb_1.default.describe).toBeDefined();
27
+ expect(hubdbCommands.describe).toBeDefined();
33
28
  });
34
29
  });
35
30
  describe('builder', () => {
@@ -37,18 +32,18 @@ describe('commands/hubdb', () => {
37
32
  commandSpy.mockClear();
38
33
  demandCommandSpy.mockClear();
39
34
  });
40
- const subcommands = [clear_1.default, create_1.default, delete_1.default, fetch_1.default, list_1.default];
35
+ const subcommands = [clear, create, deleteCommand, fetch, list];
41
36
  it('should demand the command takes one positional argument', () => {
42
- hubdb_1.default.builder(yargs_1.default);
37
+ hubdbCommands.builder(yargs);
43
38
  expect(demandCommandSpy).toHaveBeenCalledTimes(1);
44
39
  expect(demandCommandSpy).toHaveBeenCalledWith(1, '');
45
40
  });
46
41
  it('should add the correct number of sub commands', () => {
47
- hubdb_1.default.builder(yargs_1.default);
42
+ hubdbCommands.builder(yargs);
48
43
  expect(commandSpy).toHaveBeenCalledTimes(subcommands.length);
49
44
  });
50
45
  it.each(subcommands)('should attach the %s subcommand', module => {
51
- hubdb_1.default.builder(yargs_1.default);
46
+ hubdbCommands.builder(yargs);
52
47
  expect(commandSpy).toHaveBeenCalledWith(module);
53
48
  });
54
49
  });
@@ -1,29 +1,24 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- const yargs_1 = __importDefault(require("yargs"));
7
- const commonOpts_1 = require("../../lib/commonOpts");
8
- const init_1 = __importDefault(require("../init"));
1
+ import yargs from 'yargs';
2
+ import { addConfigOptions, addTestingOptions } from '../../lib/commonOpts.js';
3
+ import initCommand from '../init.js';
9
4
  vi.mock('../../lib/commonOpts');
10
5
  const optionsSpy = vi
11
- .spyOn(yargs_1.default, 'options')
12
- .mockReturnValue(yargs_1.default);
6
+ .spyOn(yargs, 'options')
7
+ .mockReturnValue(yargs);
13
8
  describe('commands/init', () => {
14
9
  describe('command', () => {
15
10
  it('should have the correct command structure', () => {
16
- expect(init_1.default.command).toEqual('init');
11
+ expect(initCommand.command).toEqual('init');
17
12
  });
18
13
  });
19
14
  describe('describe', () => {
20
15
  it('should provide a description', () => {
21
- expect(init_1.default.describe).toBeDefined();
16
+ expect(initCommand.describe).toBeDefined();
22
17
  });
23
18
  });
24
19
  describe('builder', () => {
25
20
  it('should support the correct options', () => {
26
- init_1.default.builder(yargs_1.default);
21
+ initCommand.builder(yargs);
27
22
  expect(optionsSpy).toHaveBeenCalledTimes(1);
28
23
  expect(optionsSpy).toHaveBeenCalledWith({
29
24
  'auth-type': expect.objectContaining({
@@ -38,10 +33,10 @@ describe('commands/init', () => {
38
33
  default: false,
39
34
  }),
40
35
  });
41
- expect(commonOpts_1.addConfigOptions).toHaveBeenCalledTimes(1);
42
- expect(commonOpts_1.addConfigOptions).toHaveBeenCalledWith(yargs_1.default);
43
- expect(commonOpts_1.addTestingOptions).toHaveBeenCalledTimes(1);
44
- expect(commonOpts_1.addTestingOptions).toHaveBeenCalledWith(yargs_1.default);
36
+ expect(addConfigOptions).toHaveBeenCalledTimes(1);
37
+ expect(addConfigOptions).toHaveBeenCalledWith(yargs);
38
+ expect(addTestingOptions).toHaveBeenCalledTimes(1);
39
+ expect(addTestingOptions).toHaveBeenCalledWith(yargs);
45
40
  });
46
41
  });
47
42
  });
@@ -1,38 +1,33 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- const yargs_1 = __importDefault(require("yargs"));
7
- const commonOpts_1 = require("../../lib/commonOpts");
8
- const lint_1 = __importDefault(require("../lint"));
1
+ import yargs from 'yargs';
2
+ import { addConfigOptions, addAccountOptions } from '../../lib/commonOpts.js';
3
+ import lintCommand from '../lint.js';
9
4
  vi.mock('../../lib/commonOpts');
10
5
  const positionalSpy = vi
11
- .spyOn(yargs_1.default, 'positional')
12
- .mockReturnValue(yargs_1.default);
6
+ .spyOn(yargs, 'positional')
7
+ .mockReturnValue(yargs);
13
8
  describe('commands/lint', () => {
14
9
  describe('command', () => {
15
10
  it('should have the correct command structure', () => {
16
- expect(lint_1.default.command).toEqual('lint <path>');
11
+ expect(lintCommand.command).toEqual('lint <path>');
17
12
  });
18
13
  });
19
14
  describe('describe', () => {
20
15
  it('should not provide a description', () => {
21
- expect(lint_1.default.describe).toEqual(undefined);
16
+ expect(lintCommand.describe).toEqual(undefined);
22
17
  });
23
18
  });
24
19
  describe('builder', () => {
25
20
  it('should support the correct positional arguments', () => {
26
- lint_1.default.builder(yargs_1.default);
21
+ lintCommand.builder(yargs);
27
22
  expect(positionalSpy).toHaveBeenCalledTimes(1);
28
23
  expect(positionalSpy).toHaveBeenCalledWith('path', expect.objectContaining({ type: 'string' }));
29
24
  });
30
25
  it('should support the correct options', () => {
31
- lint_1.default.builder(yargs_1.default);
32
- expect(commonOpts_1.addConfigOptions).toHaveBeenCalledTimes(1);
33
- expect(commonOpts_1.addConfigOptions).toHaveBeenCalledWith(yargs_1.default);
34
- expect(commonOpts_1.addAccountOptions).toHaveBeenCalledTimes(1);
35
- expect(commonOpts_1.addAccountOptions).toHaveBeenCalledWith(yargs_1.default);
26
+ lintCommand.builder(yargs);
27
+ expect(addConfigOptions).toHaveBeenCalledTimes(1);
28
+ expect(addConfigOptions).toHaveBeenCalledWith(yargs);
29
+ expect(addAccountOptions).toHaveBeenCalledTimes(1);
30
+ expect(addAccountOptions).toHaveBeenCalledWith(yargs);
36
31
  });
37
32
  });
38
33
  });
@@ -1,46 +1,41 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- const yargs_1 = __importDefault(require("yargs"));
7
- const commonOpts_1 = require("../../lib/commonOpts");
8
- const list_1 = __importDefault(require("../list"));
1
+ import yargs from 'yargs';
2
+ import { addConfigOptions, addAccountOptions, addUseEnvironmentOptions, } from '../../lib/commonOpts.js';
3
+ import listCommand from '../list.js';
9
4
  vi.mock('../../lib/commonOpts');
10
5
  const positionalSpy = vi
11
- .spyOn(yargs_1.default, 'positional')
12
- .mockReturnValue(yargs_1.default);
6
+ .spyOn(yargs, 'positional')
7
+ .mockReturnValue(yargs);
13
8
  const exampleSpy = vi
14
- .spyOn(yargs_1.default, 'example')
15
- .mockReturnValue(yargs_1.default);
9
+ .spyOn(yargs, 'example')
10
+ .mockReturnValue(yargs);
16
11
  describe('commands/list', () => {
17
12
  describe('command', () => {
18
13
  it('should have the correct command structure', () => {
19
- expect(list_1.default.command).toEqual(['list [path]', 'ls [path]']);
14
+ expect(listCommand.command).toEqual(['list [path]', 'ls [path]']);
20
15
  });
21
16
  });
22
17
  describe('describe', () => {
23
18
  it('should provide a description', () => {
24
- expect(list_1.default.describe).toBeDefined();
19
+ expect(listCommand.describe).toBeDefined();
25
20
  });
26
21
  });
27
22
  describe('builder', () => {
28
23
  it('should support the correct positional arguments', () => {
29
- list_1.default.builder(yargs_1.default);
24
+ listCommand.builder(yargs);
30
25
  expect(positionalSpy).toHaveBeenCalledTimes(1);
31
26
  expect(positionalSpy).toHaveBeenCalledWith('path', expect.objectContaining({ type: 'string' }));
32
27
  });
33
28
  it('should support the correct options', () => {
34
- list_1.default.builder(yargs_1.default);
35
- expect(commonOpts_1.addConfigOptions).toHaveBeenCalledTimes(1);
36
- expect(commonOpts_1.addConfigOptions).toHaveBeenCalledWith(yargs_1.default);
37
- expect(commonOpts_1.addAccountOptions).toHaveBeenCalledTimes(1);
38
- expect(commonOpts_1.addAccountOptions).toHaveBeenCalledWith(yargs_1.default);
39
- expect(commonOpts_1.addUseEnvironmentOptions).toHaveBeenCalledTimes(1);
40
- expect(commonOpts_1.addUseEnvironmentOptions).toHaveBeenCalledWith(yargs_1.default);
29
+ listCommand.builder(yargs);
30
+ expect(addConfigOptions).toHaveBeenCalledTimes(1);
31
+ expect(addConfigOptions).toHaveBeenCalledWith(yargs);
32
+ expect(addAccountOptions).toHaveBeenCalledTimes(1);
33
+ expect(addAccountOptions).toHaveBeenCalledWith(yargs);
34
+ expect(addUseEnvironmentOptions).toHaveBeenCalledTimes(1);
35
+ expect(addUseEnvironmentOptions).toHaveBeenCalledWith(yargs);
41
36
  });
42
37
  it('should provide examples', () => {
43
- list_1.default.builder(yargs_1.default);
38
+ listCommand.builder(yargs);
44
39
  expect(exampleSpy).toHaveBeenCalledTimes(1);
45
40
  });
46
41
  });