@hubspot/cli 7.6.0-beta.5 → 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 -50
  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 +119 -125
  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 +96 -134
  216. package/commands/project/__tests__/devUnifiedFlow.test.js +133 -141
  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 +1 -1
  234. package/commands/project/deploy.js +67 -69
  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 +63 -71
  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 -58
  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 +31 -8
  320. package/lang/en.js +404 -384
  321. package/lang/en.lyaml +4 -2
  322. package/lib/__tests__/accountTypes.test.js +20 -22
  323. package/lib/__tests__/buildAccount.test.js +88 -65
  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 +5 -2
  349. package/lib/buildAccount.js +126 -80
  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 -44
  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 -24
  442. package/lib/projects/localDev/DevServerManagerV2.d.ts +2 -2
  443. package/lib/projects/localDev/DevServerManagerV2.js +15 -20
  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 +10 -3
  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 +1 -1
  476. package/lib/prompts/createDeveloperTestAccountConfigPrompt.js +23 -26
  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 +17 -24
  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 +21 -14
  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,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 auth_1 = __importDefault(require("../auth"));
1
+ import yargs from 'yargs';
2
+ import { addConfigOptions, addTestingOptions } from '../../lib/commonOpts.js';
3
+ import authCommand from '../auth.js';
9
4
  vi.mock('../../lib/commonOpts');
10
5
  const optionsSpy = vi
11
6
  .spyOn(mockYargs, 'options')
12
- .mockReturnValue(yargs_1.default);
7
+ .mockReturnValue(yargs);
13
8
  describe('commands/auth', () => {
14
9
  describe('command', () => {
15
10
  it('should have the correct command structure', () => {
16
- expect(auth_1.default.command).toEqual('auth');
11
+ expect(authCommand.command).toEqual('auth');
17
12
  });
18
13
  });
19
14
  describe('describe', () => {
20
15
  it('should provide a description', () => {
21
- expect(auth_1.default.describe).toBeDefined();
16
+ expect(authCommand.describe).toBeDefined();
22
17
  });
23
18
  });
24
19
  describe('builder', () => {
25
20
  it('should support the correct options', () => {
26
- auth_1.default.builder(yargs_1.default);
21
+ authCommand.builder(yargs);
27
22
  expect(optionsSpy).toHaveBeenCalledTimes(1);
28
23
  expect(optionsSpy).toHaveBeenCalledWith({
29
24
  'auth-type': expect.objectContaining({
@@ -34,10 +29,10 @@ describe('commands/auth', () => {
34
29
  account: expect.objectContaining({ type: 'string' }),
35
30
  'personal-access-key': expect.objectContaining({ type: 'string' }),
36
31
  });
37
- expect(commonOpts_1.addConfigOptions).toHaveBeenCalledTimes(1);
38
- expect(commonOpts_1.addConfigOptions).toHaveBeenCalledWith(yargs_1.default);
39
- expect(commonOpts_1.addTestingOptions).toHaveBeenCalledTimes(1);
40
- expect(commonOpts_1.addTestingOptions).toHaveBeenCalledWith(yargs_1.default);
32
+ expect(addConfigOptions).toHaveBeenCalledTimes(1);
33
+ expect(addConfigOptions).toHaveBeenCalledWith(yargs);
34
+ expect(addTestingOptions).toHaveBeenCalledTimes(1);
35
+ expect(addTestingOptions).toHaveBeenCalledWith(yargs);
41
36
  });
42
37
  });
43
38
  });
@@ -1,47 +1,42 @@
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 lighthouseScore_1 = __importDefault(require("../cms/lighthouseScore"));
8
- const convertFields_1 = __importDefault(require("../cms/convertFields"));
9
- const getReactModule_1 = __importDefault(require("../cms/getReactModule"));
10
- const cms_1 = __importDefault(require("../cms"));
1
+ import yargs from 'yargs';
2
+ import lighthouseScore from '../cms/lighthouseScore.js';
3
+ import convertFields from '../cms/convertFields.js';
4
+ import getReactModule from '../cms/getReactModule.js';
5
+ import cmsCommand from '../cms.js';
11
6
  vi.mock('../cms/lighthouseScore');
12
7
  vi.mock('../cms/convertFields');
13
8
  vi.mock('../cms/getReactModule');
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/cms', () => {
22
17
  describe('command', () => {
23
18
  it('should have the correct command structure', () => {
24
- expect(cms_1.default.command).toEqual('cms');
19
+ expect(cmsCommand.command).toEqual('cms');
25
20
  });
26
21
  });
27
22
  describe('describe', () => {
28
23
  it('should provide a description', () => {
29
- expect(cms_1.default.describe).toBeDefined();
24
+ expect(cmsCommand.describe).toBeDefined();
30
25
  });
31
26
  });
32
27
  describe('builder', () => {
33
- const subcommands = [lighthouseScore_1.default, convertFields_1.default, getReactModule_1.default];
28
+ const subcommands = [lighthouseScore, convertFields, getReactModule];
34
29
  it('should demand the command takes one positional argument', () => {
35
- cms_1.default.builder(yargs_1.default);
30
+ cmsCommand.builder(yargs);
36
31
  expect(demandCommandSpy).toHaveBeenCalledTimes(1);
37
32
  expect(demandCommandSpy).toHaveBeenCalledWith(1, '');
38
33
  });
39
34
  it('should add the correct number of sub commands', () => {
40
- cms_1.default.builder(yargs_1.default);
35
+ cmsCommand.builder(yargs);
41
36
  expect(commandSpy).toHaveBeenCalledTimes(subcommands.length);
42
37
  });
43
38
  it.each(subcommands)('should attach the %s subcommand', module => {
44
- cms_1.default.builder(yargs_1.default);
39
+ cmsCommand.builder(yargs);
45
40
  expect(module).toBeDefined();
46
41
  expect(commandSpy).toHaveBeenCalledWith(module);
47
42
  });
@@ -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 set_1 = __importDefault(require("../config/set"));
8
- const migrate_1 = __importDefault(require("../config/migrate"));
9
- const config_1 = __importDefault(require("../config"));
1
+ import yargs from 'yargs';
2
+ import set from '../config/set.js';
3
+ import migrate from '../config/migrate.js';
4
+ import configCommands from '../config.js';
10
5
  vi.mock('../config/set');
11
6
  vi.mock('../config/set');
12
7
  const commandSpy = vi
13
- .spyOn(yargs_1.default, 'command')
14
- .mockReturnValue(yargs_1.default);
8
+ .spyOn(yargs, 'command')
9
+ .mockReturnValue(yargs);
15
10
  const demandCommandSpy = vi
16
- .spyOn(yargs_1.default, 'demandCommand')
17
- .mockReturnValue(yargs_1.default);
11
+ .spyOn(yargs, 'demandCommand')
12
+ .mockReturnValue(yargs);
18
13
  describe('commands/config', () => {
19
14
  describe('command', () => {
20
15
  it('should have the correct command structure', () => {
21
- expect(config_1.default.command).toEqual('config');
16
+ expect(configCommands.command).toEqual('config');
22
17
  });
23
18
  });
24
19
  describe('describe', () => {
25
20
  it('should provide a description', () => {
26
- expect(config_1.default.describe).toBeDefined();
21
+ expect(configCommands.describe).toBeDefined();
27
22
  });
28
23
  });
29
24
  describe('builder', () => {
@@ -31,18 +26,18 @@ describe('commands/config', () => {
31
26
  commandSpy.mockClear();
32
27
  demandCommandSpy.mockClear();
33
28
  });
34
- const subcommands = [set_1.default, migrate_1.default];
29
+ const subcommands = [set, migrate];
35
30
  it('should demand the command takes one positional argument', () => {
36
- config_1.default.builder(yargs_1.default);
31
+ configCommands.builder(yargs);
37
32
  expect(demandCommandSpy).toHaveBeenCalledTimes(1);
38
33
  expect(demandCommandSpy).toHaveBeenCalledWith(1, '');
39
34
  });
40
35
  it('should add the correct number of sub commands', () => {
41
- config_1.default.builder(yargs_1.default);
36
+ configCommands.builder(yargs);
42
37
  expect(commandSpy).toHaveBeenCalledTimes(subcommands.length);
43
38
  });
44
39
  it.each(subcommands)('should attach the %s subcommand', module => {
45
- config_1.default.builder(yargs_1.default);
40
+ configCommands.builder(yargs);
46
41
  expect(commandSpy).toHaveBeenCalledWith(module);
47
42
  });
48
43
  });
@@ -1,37 +1,32 @@
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 create_1 = __importDefault(require("../create"));
1
+ import yargs from 'yargs';
2
+ import createCommand from '../create.js';
8
3
  const positionalSpy = vi
9
- .spyOn(yargs_1.default, 'positional')
10
- .mockReturnValue(yargs_1.default);
4
+ .spyOn(yargs, 'positional')
5
+ .mockReturnValue(yargs);
11
6
  const optionSpy = vi
12
- .spyOn(yargs_1.default, 'option')
13
- .mockReturnValue(yargs_1.default);
7
+ .spyOn(yargs, 'option')
8
+ .mockReturnValue(yargs);
14
9
  describe('commands/create', () => {
15
10
  describe('command', () => {
16
11
  it('should have the correct command structure', () => {
17
- expect(create_1.default.command).toEqual('create <type> [name] [dest]');
12
+ expect(createCommand.command).toEqual('create <type> [name] [dest]');
18
13
  });
19
14
  });
20
15
  describe('describe', () => {
21
16
  it('should provide a description', () => {
22
- expect(create_1.default.describe).toBeDefined();
17
+ expect(createCommand.describe).toBeDefined();
23
18
  });
24
19
  });
25
20
  describe('builder', () => {
26
21
  it('should support the correct positional arguments', () => {
27
- create_1.default.builder(yargs_1.default);
22
+ createCommand.builder(yargs);
28
23
  expect(positionalSpy).toHaveBeenCalledTimes(3);
29
24
  expect(positionalSpy).toHaveBeenCalledWith('type', expect.objectContaining({ type: 'string' }));
30
25
  expect(positionalSpy).toHaveBeenCalledWith('name', expect.objectContaining({ type: 'string' }));
31
26
  expect(positionalSpy).toHaveBeenCalledWith('dest', expect.objectContaining({ type: 'string' }));
32
27
  });
33
28
  it('should support the correct options', () => {
34
- create_1.default.builder(yargs_1.default);
29
+ createCommand.builder(yargs);
35
30
  expect(optionSpy).toHaveBeenCalledWith('internal', expect.objectContaining({ type: 'boolean', hidden: true }));
36
31
  });
37
32
  });
@@ -1,25 +1,20 @@
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 create_1 = __importDefault(require("../customObject/create"));
8
- const schema_1 = __importDefault(require("../customObject/schema"));
9
- const customObject_1 = __importDefault(require("../customObject"));
1
+ import yargs from 'yargs';
2
+ import create from '../customObject/create.js';
3
+ import schema from '../customObject/schema.js';
4
+ import customObjectCommands from '../customObject.js';
10
5
  vi.mock('../customObject/create');
11
6
  vi.mock('../customObject/schema');
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/customObject', () => {
20
15
  describe('command', () => {
21
16
  it('should have the correct command structure', () => {
22
- expect(customObject_1.default.command).toEqual([
17
+ expect(customObjectCommands.command).toEqual([
23
18
  'custom-object',
24
19
  'custom-objects',
25
20
  'co',
@@ -28,7 +23,7 @@ describe('commands/customObject', () => {
28
23
  });
29
24
  describe('describe', () => {
30
25
  it('should provide a description', () => {
31
- expect(customObject_1.default.describe).toBeDefined();
26
+ expect(customObjectCommands.describe).toBeDefined();
32
27
  });
33
28
  });
34
29
  describe('builder', () => {
@@ -36,18 +31,18 @@ describe('commands/customObject', () => {
36
31
  commandSpy.mockClear();
37
32
  demandCommandSpy.mockClear();
38
33
  });
39
- const subcommands = [create_1.default, schema_1.default];
34
+ const subcommands = [create, schema];
40
35
  it('should demand the command takes one positional argument', () => {
41
- customObject_1.default.builder(yargs_1.default);
36
+ customObjectCommands.builder(yargs);
42
37
  expect(demandCommandSpy).toHaveBeenCalledTimes(1);
43
38
  expect(demandCommandSpy).toHaveBeenCalledWith(1, '');
44
39
  });
45
40
  it('should add the correct number of sub commands', () => {
46
- customObject_1.default.builder(yargs_1.default);
41
+ customObjectCommands.builder(yargs);
47
42
  expect(commandSpy).toHaveBeenCalledTimes(subcommands.length);
48
43
  });
49
44
  it.each(subcommands)('should attach the %s subcommand', module => {
50
- customObject_1.default.builder(yargs_1.default);
45
+ customObjectCommands.builder(yargs);
51
46
  expect(commandSpy).toHaveBeenCalledWith(module);
52
47
  });
53
48
  });
@@ -1,28 +1,23 @@
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 exitCodes_1 = require("../../lib/enums/exitCodes");
7
- const yargs_1 = __importDefault(require("yargs"));
8
- const doctor_1 = __importDefault(require("../doctor"));
9
- const usageTracking_1 = require("../../lib/usageTracking");
10
- const Doctor_1 = require("../../lib/doctor/Doctor");
11
- const logger_1 = require("@hubspot/local-dev-lib/logger");
12
- const fs_1 = __importDefault(require("fs"));
13
- const path_1 = require("@hubspot/local-dev-lib/path");
1
+ import { EXIT_CODES } from '../../lib/enums/exitCodes.js';
2
+ import yargs from 'yargs';
3
+ import doctorCommand from '../doctor.js';
4
+ import { trackCommandUsage } from '../../lib/usageTracking.js';
5
+ import { Doctor } from '../../lib/doctor/Doctor.js';
6
+ import { logger } from '@hubspot/local-dev-lib/logger';
7
+ import fs from 'fs';
8
+ import { getCwd as __getCwd } from '@hubspot/local-dev-lib/path';
14
9
  vi.mock('../../lib/usageTracking');
15
10
  vi.mock('../../lib/doctor/Doctor');
16
11
  vi.mock('@hubspot/local-dev-lib/logger');
17
12
  vi.mock('@hubspot/local-dev-lib/path');
18
13
  vi.mock('fs');
19
14
  // @ts-expect-error Doesn't match the actual signature because then the linter complains about unused variables
20
- const DoctorMock = Doctor_1.Doctor;
21
- const mockedFs = vi.mocked(fs_1.default);
22
- const getCwd = path_1.getCwd;
15
+ const DoctorMock = Doctor;
16
+ const mockedFs = vi.mocked(fs);
17
+ const getCwd = __getCwd;
23
18
  const optionSpy = vi
24
- .spyOn(yargs_1.default, 'option')
25
- .mockReturnValue(yargs_1.default);
19
+ .spyOn(yargs, 'option')
20
+ .mockReturnValue(yargs);
26
21
  const date = new Date('2022-02-22');
27
22
  vi.useFakeTimers().setSystemTime(date);
28
23
  describe('doctor', () => {
@@ -35,17 +30,17 @@ describe('doctor', () => {
35
30
  });
36
31
  describe('command', () => {
37
32
  it('should have the proper command name', () => {
38
- expect(doctor_1.default.command).toEqual('doctor');
33
+ expect(doctorCommand.command).toEqual('doctor');
39
34
  });
40
35
  });
41
36
  describe('describe', () => {
42
37
  it('should have a description', () => {
43
- expect(doctor_1.default.describe).toEqual('Retrieve diagnostic information about your local HubSpot configurations.');
38
+ expect(doctorCommand.describe).toEqual('Retrieve diagnostic information about your local HubSpot configurations.');
44
39
  });
45
40
  });
46
41
  describe('builder', () => {
47
42
  it('should apply the correct options', () => {
48
- doctor_1.default.builder(yargs_1.default);
43
+ doctorCommand.builder(yargs);
49
44
  expect(optionSpy).toHaveBeenCalledWith('output-dir', {
50
45
  describe: 'Directory to save a detailed diagnosis JSON file in',
51
46
  type: 'string',
@@ -64,16 +59,16 @@ describe('doctor', () => {
64
59
  });
65
60
  });
66
61
  it('should track the command usage', async () => {
67
- await doctor_1.default.handler({});
68
- expect(usageTracking_1.trackCommandUsage).toHaveBeenCalledTimes(1);
69
- expect(usageTracking_1.trackCommandUsage).toHaveBeenCalledWith('doctor', undefined, accountId);
62
+ await doctorCommand.handler({});
63
+ expect(trackCommandUsage).toHaveBeenCalledTimes(1);
64
+ expect(trackCommandUsage).toHaveBeenCalledWith('doctor', undefined, accountId);
70
65
  });
71
66
  it('should log the diagnosis if it is defined', async () => {
72
- await doctor_1.default.handler({});
73
- expect(logger_1.logger.log).toHaveBeenCalledTimes(1);
74
- expect(logger_1.logger.log).toHaveBeenCalledWith(diagnosis);
67
+ await doctorCommand.handler({});
68
+ expect(logger.log).toHaveBeenCalledTimes(1);
69
+ expect(logger.log).toHaveBeenCalledWith(diagnosis);
75
70
  expect(processExitSpy).toHaveBeenCalledTimes(1);
76
- expect(processExitSpy).toHaveBeenCalledWith(exitCodes_1.EXIT_CODES.SUCCESS);
71
+ expect(processExitSpy).toHaveBeenCalledWith(EXIT_CODES.SUCCESS);
77
72
  });
78
73
  it('should log an error if the diagnosis is undefined', async () => {
79
74
  DoctorMock.mockImplementationOnce(() => {
@@ -82,58 +77,58 @@ describe('doctor', () => {
82
77
  accountId,
83
78
  };
84
79
  });
85
- await doctor_1.default.handler({});
86
- expect(logger_1.logger.error).toHaveBeenCalledTimes(1);
87
- expect(logger_1.logger.error).toHaveBeenCalledWith('Error generating diagnosis');
80
+ await doctorCommand.handler({});
81
+ expect(logger.error).toHaveBeenCalledTimes(1);
82
+ expect(logger.error).toHaveBeenCalledWith('Error generating diagnosis');
88
83
  expect(processExitSpy).toHaveBeenCalledTimes(1);
89
- expect(processExitSpy).toHaveBeenCalledWith(exitCodes_1.EXIT_CODES.ERROR);
84
+ expect(processExitSpy).toHaveBeenCalledWith(EXIT_CODES.ERROR);
90
85
  });
91
86
  it('should write the output to a file if output-dir is defined', async () => {
92
87
  mockedFs.writeFileSync.mockImplementationOnce(() => { });
93
88
  const expectedOutputFile = `/foo/hubspot-doctor-${date.toISOString()}.json`;
94
- await doctor_1.default.handler({
89
+ await doctorCommand.handler({
95
90
  outputDir: '/foo',
96
91
  });
97
- expect(logger_1.logger.log).not.toHaveBeenCalled();
98
- expect(logger_1.logger.error).not.toHaveBeenCalled();
92
+ expect(logger.log).not.toHaveBeenCalled();
93
+ expect(logger.error).not.toHaveBeenCalled();
99
94
  expect(mockedFs.writeFileSync).toHaveBeenCalledTimes(1);
100
95
  expect(mockedFs.writeFileSync).toHaveBeenCalledWith(expectedOutputFile, expect.stringContaining(diagnosis));
101
- expect(logger_1.logger.success).toHaveBeenCalledTimes(1);
102
- expect(logger_1.logger.success).toHaveBeenCalledWith(expect.stringMatching(/Output written to /));
96
+ expect(logger.success).toHaveBeenCalledTimes(1);
97
+ expect(logger.success).toHaveBeenCalledWith(expect.stringMatching(/Output written to /));
103
98
  expect(processExitSpy).toHaveBeenCalledTimes(1);
104
- expect(processExitSpy).toHaveBeenCalledWith(exitCodes_1.EXIT_CODES.SUCCESS);
99
+ expect(processExitSpy).toHaveBeenCalledWith(EXIT_CODES.SUCCESS);
105
100
  });
106
101
  it('should handle absolute paths', async () => {
107
102
  mockedFs.writeFileSync.mockImplementationOnce(() => { });
108
103
  const cwd = '/some/path/to';
109
104
  getCwd.mockImplementationOnce(() => cwd);
110
105
  const expectedOutputFile = `${cwd}/foo/hubspot-doctor-${date.toISOString()}.json`;
111
- await doctor_1.default.handler({
106
+ await doctorCommand.handler({
112
107
  outputDir: './foo',
113
108
  });
114
- expect(logger_1.logger.log).not.toHaveBeenCalled();
115
- expect(logger_1.logger.error).not.toHaveBeenCalled();
109
+ expect(logger.log).not.toHaveBeenCalled();
110
+ expect(logger.error).not.toHaveBeenCalled();
116
111
  expect(mockedFs.writeFileSync).toHaveBeenCalledTimes(1);
117
112
  expect(mockedFs.writeFileSync).toHaveBeenCalledWith(expectedOutputFile, expect.stringContaining(diagnosis));
118
- expect(logger_1.logger.success).toHaveBeenCalledTimes(1);
119
- expect(logger_1.logger.success).toHaveBeenCalledWith(expect.stringMatching(/Output written to /));
113
+ expect(logger.success).toHaveBeenCalledTimes(1);
114
+ expect(logger.success).toHaveBeenCalledWith(expect.stringMatching(/Output written to /));
120
115
  expect(processExitSpy).toHaveBeenCalledTimes(1);
121
- expect(processExitSpy).toHaveBeenCalledWith(exitCodes_1.EXIT_CODES.SUCCESS);
116
+ expect(processExitSpy).toHaveBeenCalledWith(EXIT_CODES.SUCCESS);
122
117
  });
123
118
  it('should log an error message when writing the output fails', async () => {
124
119
  const errorMessage = 'Something bad happened';
125
120
  mockedFs.writeFileSync.mockImplementationOnce(() => {
126
121
  throw new Error(errorMessage);
127
122
  });
128
- await doctor_1.default.handler({
123
+ await doctorCommand.handler({
129
124
  outputDir: '/foo',
130
125
  });
131
- expect(logger_1.logger.error).toHaveBeenCalledTimes(1);
132
- expect(logger_1.logger.error).toHaveBeenCalledWith(expect.stringMatching(/Unable to write output to/));
126
+ expect(logger.error).toHaveBeenCalledTimes(1);
127
+ expect(logger.error).toHaveBeenCalledWith(expect.stringMatching(/Unable to write output to/));
133
128
  expect(mockedFs.writeFileSync).toHaveBeenCalledTimes(1);
134
129
  expect(mockedFs.writeFileSync).toHaveBeenCalledWith(`/foo/hubspot-doctor-${date.toISOString()}.json`, expect.stringContaining(diagnosis));
135
130
  expect(processExitSpy).toHaveBeenCalledTimes(1);
136
- expect(processExitSpy).toHaveBeenCalledWith(exitCodes_1.EXIT_CODES.ERROR);
131
+ expect(processExitSpy).toHaveBeenCalledWith(EXIT_CODES.ERROR);
137
132
  });
138
133
  });
139
134
  });
@@ -1,62 +1,24 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
- Object.defineProperty(o, "default", { enumerable: true, value: v });
15
- }) : function(o, v) {
16
- o["default"] = v;
17
- });
18
- var __importStar = (this && this.__importStar) || (function () {
19
- var ownKeys = function(o) {
20
- ownKeys = Object.getOwnPropertyNames || function (o) {
21
- var ar = [];
22
- for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
- return ar;
24
- };
25
- return ownKeys(o);
26
- };
27
- return function (mod) {
28
- if (mod && mod.__esModule) return mod;
29
- var result = {};
30
- if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
- __setModuleDefault(result, mod);
32
- return result;
33
- };
34
- })();
35
- var __importDefault = (this && this.__importDefault) || function (mod) {
36
- return (mod && mod.__esModule) ? mod : { "default": mod };
37
- };
38
- Object.defineProperty(exports, "__esModule", { value: true });
39
- const yargs_1 = __importDefault(require("yargs"));
40
- const commonOpts = __importStar(require("../../lib/commonOpts"));
41
- const feedback_1 = __importDefault(require("../feedback"));
1
+ import yargs from 'yargs';
2
+ import * as commonOpts from '../../lib/commonOpts.js';
3
+ import feedbackCommand from '../feedback.js';
42
4
  vi.mock('yargs');
43
5
  vi.mock('../../lib/commonOpts');
44
6
  describe('commands/feedback', () => {
45
7
  describe('command', () => {
46
8
  it('should have the correct command structure', () => {
47
- expect(feedback_1.default.command).toEqual('feedback');
9
+ expect(feedbackCommand.command).toEqual('feedback');
48
10
  });
49
11
  });
50
12
  describe('describe', () => {
51
13
  it('should provide a description', () => {
52
- expect(feedback_1.default.describe).toBeDefined();
14
+ expect(feedbackCommand.describe).toBeDefined();
53
15
  });
54
16
  });
55
17
  describe('builder', () => {
56
18
  it('should support the correct options', () => {
57
- feedback_1.default.builder(yargs_1.default);
19
+ feedbackCommand.builder(yargs);
58
20
  expect(commonOpts.addGlobalOptions).toHaveBeenCalledTimes(1);
59
- expect(commonOpts.addGlobalOptions).toHaveBeenCalledWith(yargs_1.default);
21
+ expect(commonOpts.addGlobalOptions).toHaveBeenCalledWith(yargs);
60
22
  });
61
23
  });
62
24
  });
@@ -1,56 +1,57 @@
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");
1
+ import yargs from 'yargs';
2
+ import { addAccountOptions, addConfigOptions, addOverwriteOptions, addCmsPublishModeOptions, addUseEnvironmentOptions, } from '../../lib/commonOpts.js';
8
3
  vi.mock('../../lib/commonOpts');
9
4
  // Import this last so mocks apply
10
- const fetch_1 = __importDefault(require("../fetch"));
5
+ import fetchCommand from '../fetch.js';
6
+ const positionalSpy = vi
7
+ .spyOn(yargs, 'positional')
8
+ .mockReturnValue(yargs);
9
+ const optionsSpy = vi
10
+ .spyOn(yargs, 'options')
11
+ .mockReturnValue(yargs);
11
12
  describe('commands/fetch', () => {
12
13
  describe('command', () => {
13
14
  it('should have the correct command structure', () => {
14
- expect(fetch_1.default.command).toEqual('fetch <src> [dest]');
15
+ expect(fetchCommand.command).toEqual('fetch <src> [dest]');
15
16
  });
16
17
  });
17
18
  describe('describe', () => {
18
19
  it('should provide a description', () => {
19
- expect(fetch_1.default.describe).toBeDefined();
20
+ expect(fetchCommand.describe).toBeDefined();
20
21
  });
21
22
  });
22
23
  describe('builder', () => {
23
24
  it('should support the correct positional arguments', () => {
24
- fetch_1.default.builder(yargs_1.default);
25
- expect(yargs_1.default.positional).toHaveBeenCalledTimes(2);
26
- expect(yargs_1.default.positional).toHaveBeenCalledWith('src', expect.objectContaining({ type: 'string' }));
27
- expect(yargs_1.default.positional).toHaveBeenCalledWith('dest', expect.objectContaining({ type: 'string' }));
25
+ fetchCommand.builder(yargs);
26
+ expect(positionalSpy).toHaveBeenCalledTimes(2);
27
+ expect(positionalSpy).toHaveBeenCalledWith('src', expect.objectContaining({ type: 'string' }));
28
+ expect(positionalSpy).toHaveBeenCalledWith('dest', expect.objectContaining({ type: 'string' }));
28
29
  });
29
30
  it('should support the correct options', () => {
30
- fetch_1.default.builder(yargs_1.default);
31
- expect(yargs_1.default.options).toHaveBeenCalledTimes(2);
32
- expect(yargs_1.default.options).toHaveBeenCalledWith({
31
+ fetchCommand.builder(yargs);
32
+ expect(optionsSpy).toHaveBeenCalledTimes(2);
33
+ expect(optionsSpy).toHaveBeenCalledWith({
33
34
  staging: expect.objectContaining({
34
35
  type: 'boolean',
35
36
  default: false,
36
37
  hidden: true,
37
38
  }),
38
39
  });
39
- expect(yargs_1.default.options).toHaveBeenCalledWith({
40
+ expect(optionsSpy).toHaveBeenCalledWith({
40
41
  assetVersion: expect.objectContaining({ type: 'number' }),
41
42
  });
42
- expect(commonOpts_1.addConfigOptions).toHaveBeenCalledTimes(1);
43
- expect(commonOpts_1.addConfigOptions).toHaveBeenCalledWith(yargs_1.default);
44
- expect(commonOpts_1.addAccountOptions).toHaveBeenCalledTimes(1);
45
- expect(commonOpts_1.addAccountOptions).toHaveBeenCalledWith(yargs_1.default);
46
- expect(commonOpts_1.addOverwriteOptions).toHaveBeenCalledTimes(1);
47
- expect(commonOpts_1.addOverwriteOptions).toHaveBeenCalledWith(yargs_1.default);
48
- expect(commonOpts_1.addCmsPublishModeOptions).toHaveBeenCalledTimes(1);
49
- expect(commonOpts_1.addCmsPublishModeOptions).toHaveBeenCalledWith(yargs_1.default, {
43
+ expect(addConfigOptions).toHaveBeenCalledTimes(1);
44
+ expect(addConfigOptions).toHaveBeenCalledWith(yargs);
45
+ expect(addAccountOptions).toHaveBeenCalledTimes(1);
46
+ expect(addAccountOptions).toHaveBeenCalledWith(yargs);
47
+ expect(addOverwriteOptions).toHaveBeenCalledTimes(1);
48
+ expect(addOverwriteOptions).toHaveBeenCalledWith(yargs);
49
+ expect(addCmsPublishModeOptions).toHaveBeenCalledTimes(1);
50
+ expect(addCmsPublishModeOptions).toHaveBeenCalledWith(yargs, {
50
51
  read: true,
51
52
  });
52
- expect(commonOpts_1.addUseEnvironmentOptions).toHaveBeenCalledTimes(1);
53
- expect(commonOpts_1.addUseEnvironmentOptions).toHaveBeenCalledWith(yargs_1.default);
53
+ expect(addUseEnvironmentOptions).toHaveBeenCalledTimes(1);
54
+ expect(addUseEnvironmentOptions).toHaveBeenCalledWith(yargs);
54
55
  });
55
56
  });
56
57
  });