@hubspot/cli 7.7.21-experimental.0 → 7.7.21-experimental.1

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 (570) hide show
  1. package/api/__tests__/migrate.test.js +29 -27
  2. package/api/migrate.js +22 -14
  3. package/bin/cli.js +101 -92
  4. package/bin/hs +2 -2
  5. package/bin/hscms +2 -2
  6. package/bin/silenceErrors.js +2 -1
  7. package/commands/__tests__/account.test.js +34 -29
  8. package/commands/__tests__/auth.test.js +16 -11
  9. package/commands/__tests__/cms.test.js +20 -15
  10. package/commands/__tests__/config.test.js +19 -14
  11. package/commands/__tests__/create.test.js +15 -10
  12. package/commands/__tests__/customObject.test.js +19 -14
  13. package/commands/__tests__/doctor.test.js +48 -43
  14. package/commands/__tests__/feedback.test.js +45 -7
  15. package/commands/__tests__/fetch.test.js +28 -29
  16. package/commands/__tests__/filemanager.test.js +19 -14
  17. package/commands/__tests__/function.test.js +21 -16
  18. package/commands/__tests__/getStarted.test.js +50 -55
  19. package/commands/__tests__/hubdb.test.js +22 -17
  20. package/commands/__tests__/init.test.js +17 -12
  21. package/commands/__tests__/lint.test.js +18 -13
  22. package/commands/__tests__/list.test.js +23 -18
  23. package/commands/__tests__/logs.test.js +27 -28
  24. package/commands/__tests__/mcp.test.js +19 -14
  25. package/commands/__tests__/mv.test.js +52 -14
  26. package/commands/__tests__/open.test.js +51 -13
  27. package/commands/__tests__/project.test.js +49 -44
  28. package/commands/__tests__/remove.test.js +51 -13
  29. package/commands/__tests__/sandbox.test.js +19 -14
  30. package/commands/__tests__/secret.test.js +21 -16
  31. package/commands/__tests__/testAccount.test.js +21 -16
  32. package/commands/__tests__/theme.test.js +20 -15
  33. package/commands/account/__tests__/auth.test.js +16 -11
  34. package/commands/account/__tests__/clean.test.js +17 -12
  35. package/commands/account/__tests__/createOverride.test.js +15 -10
  36. package/commands/account/__tests__/info.test.js +16 -11
  37. package/commands/account/__tests__/list.test.js +16 -11
  38. package/commands/account/__tests__/remove.test.js +18 -13
  39. package/commands/account/__tests__/removeOverride.js +13 -8
  40. package/commands/account/__tests__/rename.test.js +20 -15
  41. package/commands/account/__tests__/use.test.js +15 -10
  42. package/commands/account/auth.d.ts +1 -1
  43. package/commands/account/auth.js +67 -65
  44. package/commands/account/clean.d.ts +1 -1
  45. package/commands/account/clean.js +60 -55
  46. package/commands/account/createOverride.d.ts +1 -1
  47. package/commands/account/createOverride.js +57 -52
  48. package/commands/account/info.d.ts +1 -1
  49. package/commands/account/info.js +35 -33
  50. package/commands/account/list.d.ts +1 -1
  51. package/commands/account/list.js +45 -43
  52. package/commands/account/remove.d.ts +1 -1
  53. package/commands/account/remove.js +42 -37
  54. package/commands/account/removeOverride.d.ts +1 -1
  55. package/commands/account/removeOverride.js +43 -38
  56. package/commands/account/rename.d.ts +1 -1
  57. package/commands/account/rename.js +20 -18
  58. package/commands/account/use.d.ts +1 -1
  59. package/commands/account/use.js +31 -29
  60. package/commands/account.d.ts +1 -1
  61. package/commands/account.js +28 -23
  62. package/commands/app/__tests__/install.test.js +52 -0
  63. package/commands/app/__tests__/migrate.test.js +34 -29
  64. package/commands/app/install.d.ts +8 -0
  65. package/commands/app/install.js +127 -0
  66. package/commands/app/migrate.d.ts +2 -2
  67. package/commands/app/migrate.js +43 -40
  68. package/commands/app/secret/__tests__/add.test.js +11 -6
  69. package/commands/app/secret/__tests__/delete.test.js +11 -6
  70. package/commands/app/secret/__tests__/list.test.js +11 -6
  71. package/commands/app/secret/__tests__/update.test.js +11 -6
  72. package/commands/app/secret/add.d.ts +1 -1
  73. package/commands/app/secret/add.js +30 -28
  74. package/commands/app/secret/delete.d.ts +1 -1
  75. package/commands/app/secret/delete.js +36 -34
  76. package/commands/app/secret/list.d.ts +1 -1
  77. package/commands/app/secret/list.js +27 -25
  78. package/commands/app/secret/update.d.ts +1 -1
  79. package/commands/app/secret/update.js +34 -32
  80. package/commands/app/secret.d.ts +1 -1
  81. package/commands/app/secret.js +17 -12
  82. package/commands/app.d.ts +1 -1
  83. package/commands/app.js +16 -6
  84. package/commands/auth.d.ts +1 -1
  85. package/commands/auth.js +72 -70
  86. package/commands/cms/convertFields.d.ts +1 -1
  87. package/commands/cms/convertFields.js +39 -34
  88. package/commands/cms/getReactModule.d.ts +1 -1
  89. package/commands/cms/getReactModule.js +37 -32
  90. package/commands/cms/lighthouseScore.d.ts +1 -1
  91. package/commands/cms/lighthouseScore.js +72 -67
  92. package/commands/cms.d.ts +1 -1
  93. package/commands/cms.js +16 -11
  94. package/commands/completion.d.ts +1 -1
  95. package/commands/completion.js +15 -10
  96. package/commands/config/migrate.d.ts +1 -1
  97. package/commands/config/migrate.js +32 -27
  98. package/commands/config/set.d.ts +1 -1
  99. package/commands/config/set.js +25 -23
  100. package/commands/config.d.ts +1 -1
  101. package/commands/config.js +13 -8
  102. package/commands/create/api-sample.d.ts +1 -1
  103. package/commands/create/api-sample.js +33 -28
  104. package/commands/create/app.d.ts +1 -1
  105. package/commands/create/app.js +5 -3
  106. package/commands/create/function.d.ts +1 -1
  107. package/commands/create/function.js +11 -9
  108. package/commands/create/index.d.ts +1 -1
  109. package/commands/create/index.js +24 -19
  110. package/commands/create/module.d.ts +1 -1
  111. package/commands/create/module.js +14 -12
  112. package/commands/create/react-app.d.ts +1 -1
  113. package/commands/create/react-app.js +5 -3
  114. package/commands/create/template.d.ts +1 -1
  115. package/commands/create/template.js +14 -12
  116. package/commands/create/vue-app.d.ts +1 -1
  117. package/commands/create/vue-app.js +5 -3
  118. package/commands/create/webpack-serverless.d.ts +1 -1
  119. package/commands/create/webpack-serverless.js +5 -3
  120. package/commands/create/website-theme.d.ts +1 -1
  121. package/commands/create/website-theme.js +7 -5
  122. package/commands/create.d.ts +2 -2
  123. package/commands/create.js +35 -30
  124. package/commands/customObject/__tests__/create.test.js +18 -13
  125. package/commands/customObject/__tests__/schema.test.js +23 -18
  126. package/commands/customObject/create.d.ts +1 -1
  127. package/commands/customObject/create.js +30 -28
  128. package/commands/customObject/schema/__tests__/create.test.js +18 -13
  129. package/commands/customObject/schema/__tests__/delete.test.js +18 -13
  130. package/commands/customObject/schema/__tests__/fetch-all.test.js +18 -13
  131. package/commands/customObject/schema/__tests__/fetch.test.js +18 -13
  132. package/commands/customObject/schema/__tests__/list.test.js +18 -13
  133. package/commands/customObject/schema/__tests__/update.test.js +18 -13
  134. package/commands/customObject/schema/create.d.ts +1 -1
  135. package/commands/customObject/schema/create.js +30 -28
  136. package/commands/customObject/schema/delete.d.ts +1 -1
  137. package/commands/customObject/schema/delete.js +26 -24
  138. package/commands/customObject/schema/fetch-all.d.ts +1 -1
  139. package/commands/customObject/schema/fetch-all.js +24 -22
  140. package/commands/customObject/schema/fetch.d.ts +1 -1
  141. package/commands/customObject/schema/fetch.js +26 -24
  142. package/commands/customObject/schema/list.d.ts +1 -1
  143. package/commands/customObject/schema/list.js +15 -13
  144. package/commands/customObject/schema/update.d.ts +1 -1
  145. package/commands/customObject/schema/update.js +34 -32
  146. package/commands/customObject/schema.d.ts +1 -1
  147. package/commands/customObject/schema.js +22 -17
  148. package/commands/customObject.d.ts +1 -1
  149. package/commands/customObject.js +18 -13
  150. package/commands/doctor.d.ts +1 -1
  151. package/commands/doctor.js +33 -28
  152. package/commands/feedback.d.ts +1 -1
  153. package/commands/feedback.js +24 -19
  154. package/commands/fetch.d.ts +1 -1
  155. package/commands/fetch.js +30 -28
  156. package/commands/filemanager/__tests__/fetch.test.js +22 -17
  157. package/commands/filemanager/__tests__/upload.test.js +20 -15
  158. package/commands/filemanager/fetch.d.ts +1 -1
  159. package/commands/filemanager/fetch.js +25 -23
  160. package/commands/filemanager/upload.d.ts +1 -1
  161. package/commands/filemanager/upload.js +44 -39
  162. package/commands/filemanager.d.ts +1 -1
  163. package/commands/filemanager.js +13 -8
  164. package/commands/function/deploy.d.ts +1 -1
  165. package/commands/function/deploy.js +40 -35
  166. package/commands/function/list.d.ts +1 -1
  167. package/commands/function/list.js +29 -24
  168. package/commands/function/server.d.ts +1 -1
  169. package/commands/function/server.js +17 -15
  170. package/commands/function.d.ts +1 -1
  171. package/commands/function.js +18 -12
  172. package/commands/getStarted.d.ts +1 -1
  173. package/commands/getStarted.js +131 -140
  174. package/commands/hubdb/__tests__/clear.test.js +18 -13
  175. package/commands/hubdb/__tests__/create.test.js +18 -13
  176. package/commands/hubdb/__tests__/delete.test.js +18 -13
  177. package/commands/hubdb/__tests__/fetch.test.js +18 -13
  178. package/commands/hubdb/__tests__/list.test.js +28 -23
  179. package/commands/hubdb/clear.d.ts +1 -1
  180. package/commands/hubdb/clear.js +22 -20
  181. package/commands/hubdb/create.d.ts +1 -1
  182. package/commands/hubdb/create.js +35 -30
  183. package/commands/hubdb/delete.d.ts +1 -1
  184. package/commands/hubdb/delete.js +26 -24
  185. package/commands/hubdb/fetch.d.ts +1 -1
  186. package/commands/hubdb/fetch.js +19 -17
  187. package/commands/hubdb/list.d.ts +1 -1
  188. package/commands/hubdb/list.js +35 -33
  189. package/commands/hubdb.d.ts +1 -1
  190. package/commands/hubdb.js +24 -18
  191. package/commands/init.d.ts +1 -1
  192. package/commands/init.js +88 -83
  193. package/commands/lint.d.ts +1 -1
  194. package/commands/lint.js +26 -24
  195. package/commands/list.d.ts +1 -1
  196. package/commands/list.js +37 -32
  197. package/commands/logs.d.ts +1 -1
  198. package/commands/logs.js +37 -35
  199. package/commands/mcp/__tests__/setup.test.js +12 -7
  200. package/commands/mcp/__tests__/start.test.js +12 -7
  201. package/commands/mcp/setup.d.ts +1 -1
  202. package/commands/mcp/setup.js +20 -17
  203. package/commands/mcp/start.d.ts +5 -2
  204. package/commands/mcp/start.js +41 -31
  205. package/commands/mcp.d.ts +1 -1
  206. package/commands/mcp.js +12 -7
  207. package/commands/module/marketplace-validate.d.ts +1 -1
  208. package/commands/module/marketplace-validate.js +26 -21
  209. package/commands/module.d.ts +1 -1
  210. package/commands/module.js +13 -7
  211. package/commands/mv.d.ts +1 -1
  212. package/commands/mv.js +22 -20
  213. package/commands/open.d.ts +1 -1
  214. package/commands/open.js +21 -19
  215. package/commands/project/__tests__/add.test.js +15 -10
  216. package/commands/project/__tests__/create.test.js +19 -14
  217. package/commands/project/__tests__/deploy.test.js +143 -103
  218. package/commands/project/__tests__/devUnifiedFlow.test.js +157 -148
  219. package/commands/project/__tests__/download.test.js +19 -14
  220. package/commands/project/__tests__/installDeps.test.js +70 -32
  221. package/commands/project/__tests__/listBuilds.test.js +19 -14
  222. package/commands/project/__tests__/logs.test.js +94 -56
  223. package/commands/project/__tests__/migrate.test.js +30 -25
  224. package/commands/project/__tests__/migrateApp.test.js +22 -17
  225. package/commands/project/__tests__/open.test.js +21 -16
  226. package/commands/project/__tests__/profile.test.js +19 -14
  227. package/commands/project/__tests__/upload.test.js +23 -18
  228. package/commands/project/__tests__/watch.test.js +19 -14
  229. package/commands/project/add.d.ts +1 -1
  230. package/commands/project/add.js +36 -34
  231. package/commands/project/cloneApp.d.ts +1 -1
  232. package/commands/project/cloneApp.js +72 -67
  233. package/commands/project/create.d.ts +2 -2
  234. package/commands/project/create.js +68 -63
  235. package/commands/project/deploy.d.ts +3 -2
  236. package/commands/project/deploy.js +102 -91
  237. package/commands/project/dev/deprecatedFlow.d.ts +2 -2
  238. package/commands/project/dev/deprecatedFlow.js +58 -52
  239. package/commands/project/dev/index.d.ts +1 -1
  240. package/commands/project/dev/index.js +47 -44
  241. package/commands/project/dev/unifiedFlow.d.ts +3 -3
  242. package/commands/project/dev/unifiedFlow.js +74 -67
  243. package/commands/project/download.d.ts +1 -1
  244. package/commands/project/download.js +40 -35
  245. package/commands/project/installDeps.d.ts +1 -1
  246. package/commands/project/installDeps.js +34 -29
  247. package/commands/project/listBuilds.d.ts +1 -1
  248. package/commands/project/listBuilds.js +45 -40
  249. package/commands/project/logs.d.ts +1 -1
  250. package/commands/project/logs.js +54 -52
  251. package/commands/project/migrate.d.ts +1 -1
  252. package/commands/project/migrate.js +26 -24
  253. package/commands/project/migrateApp.d.ts +2 -2
  254. package/commands/project/migrateApp.js +20 -18
  255. package/commands/project/open.d.ts +1 -1
  256. package/commands/project/open.js +30 -25
  257. package/commands/project/profile/add.d.ts +1 -1
  258. package/commands/project/profile/add.js +73 -68
  259. package/commands/project/profile/delete.d.ts +1 -1
  260. package/commands/project/profile/delete.js +56 -51
  261. package/commands/project/profile.d.ts +1 -1
  262. package/commands/project/profile.js +14 -9
  263. package/commands/project/upload.d.ts +1 -1
  264. package/commands/project/upload.js +55 -50
  265. package/commands/project/validate.d.ts +1 -1
  266. package/commands/project/validate.js +40 -35
  267. package/commands/project/watch.d.ts +1 -1
  268. package/commands/project/watch.js +61 -59
  269. package/commands/project.d.ts +1 -1
  270. package/commands/project.js +43 -38
  271. package/commands/remove.d.ts +1 -1
  272. package/commands/remove.js +17 -15
  273. package/commands/sandbox/__tests__/create.test.js +20 -15
  274. package/commands/sandbox/__tests__/delete.test.js +20 -15
  275. package/commands/sandbox/create.d.ts +1 -1
  276. package/commands/sandbox/create.js +69 -67
  277. package/commands/sandbox/delete.d.ts +1 -1
  278. package/commands/sandbox/delete.js +96 -94
  279. package/commands/sandbox.d.ts +1 -1
  280. package/commands/sandbox.js +14 -9
  281. package/commands/secret/__tests__/addSecret.test.js +18 -13
  282. package/commands/secret/__tests__/deleteSecret.test.js +18 -13
  283. package/commands/secret/__tests__/listSecret.test.js +18 -13
  284. package/commands/secret/__tests__/updateSecret.test.js +18 -13
  285. package/commands/secret/addSecret.d.ts +1 -1
  286. package/commands/secret/addSecret.js +28 -26
  287. package/commands/secret/deleteSecret.d.ts +1 -1
  288. package/commands/secret/deleteSecret.js +29 -27
  289. package/commands/secret/listSecret.d.ts +1 -1
  290. package/commands/secret/listSecret.js +21 -19
  291. package/commands/secret/updateSecret.d.ts +1 -1
  292. package/commands/secret/updateSecret.js +27 -25
  293. package/commands/secret.d.ts +1 -1
  294. package/commands/secret.js +18 -13
  295. package/commands/testAccount/__tests__/create.test.js +22 -17
  296. package/commands/testAccount/__tests__/createConfig.test.js +11 -9
  297. package/commands/testAccount/__tests__/delete.test.js +20 -15
  298. package/commands/testAccount/create.d.ts +1 -1
  299. package/commands/testAccount/create.js +57 -62
  300. package/commands/testAccount/createConfig.d.ts +1 -3
  301. package/commands/testAccount/createConfig.js +47 -43
  302. package/commands/testAccount/delete.d.ts +1 -1
  303. package/commands/testAccount/delete.js +19 -17
  304. package/commands/testAccount.d.ts +1 -1
  305. package/commands/testAccount.js +15 -10
  306. package/commands/theme/__tests__/generate-selectors.test.js +12 -7
  307. package/commands/theme/__tests__/marketplace-validate.test.js +19 -14
  308. package/commands/theme/__tests__/preview.test.js +17 -12
  309. package/commands/theme/generate-selectors.d.ts +1 -1
  310. package/commands/theme/generate-selectors.js +28 -23
  311. package/commands/theme/marketplace-validate.d.ts +1 -1
  312. package/commands/theme/marketplace-validate.js +24 -19
  313. package/commands/theme/preview.d.ts +1 -1
  314. package/commands/theme/preview.js +65 -60
  315. package/commands/theme.d.ts +1 -1
  316. package/commands/theme.js +16 -11
  317. package/commands/upload.d.ts +1 -1
  318. package/commands/upload.js +82 -77
  319. package/commands/watch.d.ts +1 -1
  320. package/commands/watch.js +51 -45
  321. package/lang/en.d.ts +62 -23
  322. package/lang/en.js +434 -389
  323. package/lang/en.lyaml +0 -26
  324. package/lib/__tests__/accountTypes.test.js +22 -20
  325. package/lib/__tests__/buildAccount.test.js +90 -27
  326. package/lib/__tests__/commonOpts.test.js +22 -20
  327. package/lib/__tests__/dependencyManagement.test.js +51 -46
  328. package/lib/__tests__/developerTestAccounts.test.js +62 -27
  329. package/lib/__tests__/hasFeature.test.js +8 -6
  330. package/lib/__tests__/npm.test.js +20 -15
  331. package/lib/__tests__/oauth.test.js +28 -23
  332. package/lib/__tests__/parsing.test.js +20 -18
  333. package/lib/__tests__/polling.test.js +26 -24
  334. package/lib/__tests__/process.test.js +19 -14
  335. package/lib/__tests__/projectProfiles.test.js +39 -34
  336. package/lib/__tests__/sandboxSync.test.js +35 -30
  337. package/lib/__tests__/sandboxes.test.js +31 -29
  338. package/lib/__tests__/serverlessLogs.test.js +13 -8
  339. package/lib/__tests__/usageTracking.test.js +42 -47
  340. package/lib/__tests__/validation.test.js +20 -18
  341. package/lib/__tests__/yargsUtils.test.js +41 -6
  342. package/lib/accountTypes.js +34 -24
  343. package/lib/app/__tests__/migrate.test.js +99 -94
  344. package/lib/app/__tests__/migrate_legacy.test.js +31 -29
  345. package/lib/app/migrate.d.ts +3 -3
  346. package/lib/app/migrate.js +145 -127
  347. package/lib/app/migrate_legacy.d.ts +1 -1
  348. package/lib/app/migrate_legacy.js +78 -72
  349. package/lib/app/urls.js +9 -5
  350. package/lib/buildAccount.d.ts +8 -2
  351. package/lib/buildAccount.js +119 -61
  352. package/lib/commonOpts.d.ts +1 -1
  353. package/lib/commonOpts.js +59 -42
  354. package/lib/configMigrate.js +38 -34
  355. package/lib/configOptions.js +40 -34
  356. package/lib/constants.js +34 -31
  357. package/lib/customObject.js +6 -2
  358. package/lib/dependencyManagement.js +45 -37
  359. package/lib/developerTestAccounts.d.ts +1 -1
  360. package/lib/developerTestAccounts.js +39 -34
  361. package/lib/doctor/Diagnosis.d.ts +1 -1
  362. package/lib/doctor/Diagnosis.js +29 -25
  363. package/lib/doctor/DiagnosticInfoBuilder.d.ts +1 -1
  364. package/lib/doctor/DiagnosticInfoBuilder.js +37 -30
  365. package/lib/doctor/Doctor.d.ts +1 -1
  366. package/lib/doctor/Doctor.js +101 -94
  367. package/lib/doctor/__tests__/Diagnosis.test.js +14 -9
  368. package/lib/doctor/__tests__/DiagnosticInfoBuilder.test.js +34 -29
  369. package/lib/doctor/__tests__/Doctor.test.js +26 -24
  370. package/lib/enums/exitCodes.js +4 -1
  371. package/lib/errorHandlers/index.js +41 -32
  372. package/lib/errorHandlers/suppressError.d.ts +1 -1
  373. package/lib/errorHandlers/suppressError.js +31 -28
  374. package/lib/filesystem.js +15 -8
  375. package/lib/generateSelectors.js +29 -18
  376. package/lib/hasFeature.d.ts +1 -1
  377. package/lib/hasFeature.js +6 -3
  378. package/lib/interpolation.js +18 -11
  379. package/lib/lang.d.ts +1 -1
  380. package/lib/lang.js +27 -22
  381. package/lib/links.js +24 -16
  382. package/lib/marketplaceValidate.js +39 -29
  383. package/lib/mcp/setup.js +105 -72
  384. package/lib/middleware/__test__/configMiddleware.test.js +55 -20
  385. package/lib/middleware/__test__/gitMiddleware.test.js +42 -7
  386. package/lib/middleware/__test__/notificationsMiddleware.test.js +4 -2
  387. package/lib/middleware/__test__/requestMiddleware.test.js +11 -6
  388. package/lib/middleware/__test__/utils.test.js +11 -9
  389. package/lib/middleware/__test__/yargsChecksMiddleware.test.js +44 -9
  390. package/lib/middleware/autoUpdateMiddleware.js +40 -33
  391. package/lib/middleware/configMiddleware.js +42 -36
  392. package/lib/middleware/fireAlarmMiddleware.js +18 -12
  393. package/lib/middleware/gitMiddleware.js +8 -5
  394. package/lib/middleware/notificationsMiddleware.js +23 -16
  395. package/lib/middleware/requestMiddleware.js +10 -4
  396. package/lib/middleware/utils.js +4 -1
  397. package/lib/middleware/yargsChecksMiddleware.js +13 -10
  398. package/lib/npm.js +23 -14
  399. package/lib/oauth.js +35 -29
  400. package/lib/parsing.js +6 -3
  401. package/lib/polling.js +15 -11
  402. package/lib/process.js +19 -11
  403. package/lib/projectProfiles.d.ts +2 -2
  404. package/lib/projectProfiles.js +42 -32
  405. package/lib/projects/ProjectLogsManager.js +21 -18
  406. package/lib/projects/__tests__/AppDevModeInterface.test.js +145 -140
  407. package/lib/projects/__tests__/LocalDevProcess.test.js +73 -68
  408. package/lib/projects/__tests__/LocalDevWebsocketServer.test.js +37 -32
  409. package/lib/projects/__tests__/ProjectLogsManager.test.js +58 -56
  410. package/lib/projects/__tests__/buildAndDeploy.test.js +9 -7
  411. package/lib/projects/__tests__/components.test.js +14 -9
  412. package/lib/projects/__tests__/projects.test.js +40 -35
  413. package/lib/projects/__tests__/structure.test.js +81 -43
  414. package/lib/projects/add/__tests__/legacyAddComponent.test.js +28 -26
  415. package/lib/projects/add/__tests__/v3AddComponent.test.js +30 -25
  416. package/lib/projects/add/legacyAddComponent.d.ts +1 -1
  417. package/lib/projects/add/legacyAddComponent.js +30 -24
  418. package/lib/projects/add/v3AddComponent.d.ts +1 -1
  419. package/lib/projects/add/v3AddComponent.js +42 -36
  420. package/lib/projects/buildAndDeploy.d.ts +1 -1
  421. package/lib/projects/buildAndDeploy.js +97 -88
  422. package/lib/projects/components.js +25 -19
  423. package/lib/projects/config.d.ts +1 -1
  424. package/lib/projects/config.js +41 -32
  425. package/lib/projects/create/__tests__/legacy.test.js +57 -22
  426. package/lib/projects/create/__tests__/v3.test.js +7 -5
  427. package/lib/projects/create/index.d.ts +3 -3
  428. package/lib/projects/create/index.js +22 -19
  429. package/lib/projects/create/legacy.d.ts +1 -1
  430. package/lib/projects/create/legacy.js +31 -25
  431. package/lib/projects/create/v3.d.ts +3 -3
  432. package/lib/projects/create/v3.js +59 -49
  433. package/lib/projects/ensureProjectExists.js +37 -31
  434. package/lib/projects/localDev/AppDevModeInterface.d.ts +3 -3
  435. package/lib/projects/localDev/AppDevModeInterface.js +60 -58
  436. package/lib/projects/localDev/DevServerManager.d.ts +1 -1
  437. package/lib/projects/localDev/DevServerManager.js +24 -24
  438. package/lib/projects/localDev/DevServerManagerV2.d.ts +2 -2
  439. package/lib/projects/localDev/DevServerManagerV2.js +20 -17
  440. package/lib/projects/localDev/LocalDevLogger.d.ts +1 -1
  441. package/lib/projects/localDev/LocalDevLogger.js +64 -59
  442. package/lib/projects/localDev/LocalDevManager.d.ts +1 -1
  443. package/lib/projects/localDev/LocalDevManager.js +111 -106
  444. package/lib/projects/localDev/LocalDevProcess.d.ts +4 -4
  445. package/lib/projects/localDev/LocalDevProcess.js +30 -25
  446. package/lib/projects/localDev/LocalDevState.d.ts +3 -3
  447. package/lib/projects/localDev/LocalDevState.js +5 -3
  448. package/lib/projects/localDev/LocalDevWatcher.d.ts +1 -1
  449. package/lib/projects/localDev/LocalDevWatcher.js +11 -6
  450. package/lib/projects/localDev/LocalDevWebsocketServer.d.ts +1 -1
  451. package/lib/projects/localDev/LocalDevWebsocketServer.js +27 -25
  452. package/lib/projects/localDev/helpers.d.ts +4 -4
  453. package/lib/projects/localDev/helpers.js +174 -156
  454. package/lib/projects/structure.d.ts +4 -4
  455. package/lib/projects/structure.js +78 -32
  456. package/lib/projects/ui.js +13 -10
  457. package/lib/projects/upload.d.ts +3 -2
  458. package/lib/projects/upload.js +65 -55
  459. package/lib/projects/urls.js +24 -14
  460. package/lib/projects/watch.d.ts +1 -1
  461. package/lib/projects/watch.js +54 -48
  462. package/lib/prompts/__tests__/downloadProjectPrompt.test.js +11 -9
  463. package/lib/prompts/__tests__/projectsLogsPrompt.test.js +16 -11
  464. package/lib/prompts/accountNamePrompt.d.ts +1 -1
  465. package/lib/prompts/accountNamePrompt.js +31 -26
  466. package/lib/prompts/accountsPrompt.js +15 -12
  467. package/lib/prompts/cmsFieldPrompt.js +19 -13
  468. package/lib/prompts/createApiSamplePrompt.d.ts +1 -1
  469. package/lib/prompts/createApiSamplePrompt.js +12 -9
  470. package/lib/prompts/createDeveloperTestAccountConfigPrompt.d.ts +11 -10
  471. package/lib/prompts/createDeveloperTestAccountConfigPrompt.js +88 -43
  472. package/lib/prompts/createFunctionPrompt.js +20 -17
  473. package/lib/prompts/createModulePrompt.js +15 -12
  474. package/lib/prompts/createTemplatePrompt.js +8 -5
  475. package/lib/prompts/downloadProjectPrompt.js +20 -17
  476. package/lib/prompts/installAppPrompt.js +26 -19
  477. package/lib/prompts/personalAccessKeyPrompt.d.ts +2 -2
  478. package/lib/prompts/personalAccessKeyPrompt.js +47 -40
  479. package/lib/prompts/previewPrompt.js +22 -15
  480. package/lib/prompts/projectAddPrompt.d.ts +1 -1
  481. package/lib/prompts/projectAddPrompt.js +18 -14
  482. package/lib/prompts/projectDevTargetAccountPrompt.d.ts +1 -1
  483. package/lib/prompts/projectDevTargetAccountPrompt.js +54 -48
  484. package/lib/prompts/projectNameAndDestPrompt.d.ts +1 -1
  485. package/lib/prompts/projectNameAndDestPrompt.js +29 -22
  486. package/lib/prompts/projectNamePrompt.js +14 -11
  487. package/lib/prompts/projectsLogsPrompt.js +8 -5
  488. package/lib/prompts/promptUtils.d.ts +1 -1
  489. package/lib/prompts/promptUtils.js +87 -70
  490. package/lib/prompts/sandboxesPrompt.d.ts +1 -1
  491. package/lib/prompts/sandboxesPrompt.js +30 -26
  492. package/lib/prompts/secretPrompt.js +15 -10
  493. package/lib/prompts/selectAppPrompt.js +14 -11
  494. package/lib/prompts/selectHubDBTablePrompt.js +30 -24
  495. package/lib/prompts/selectProjectTemplatePrompt.d.ts +1 -1
  496. package/lib/prompts/selectProjectTemplatePrompt.js +13 -10
  497. package/lib/prompts/selectPublicAppForMigrationPrompt.js +25 -22
  498. package/lib/prompts/setAsDefaultAccountPrompt.js +16 -13
  499. package/lib/prompts/uploadPrompt.js +17 -11
  500. package/lib/sandboxSync.d.ts +1 -1
  501. package/lib/sandboxSync.js +65 -58
  502. package/lib/sandboxes.d.ts +1 -1
  503. package/lib/sandboxes.js +76 -68
  504. package/lib/schema.js +23 -12
  505. package/lib/serverlessLogs.js +52 -45
  506. package/lib/testUtils.js +8 -4
  507. package/lib/ui/SpinniesManager.d.ts +1 -1
  508. package/lib/ui/SpinniesManager.js +34 -29
  509. package/lib/ui/boxen.js +14 -11
  510. package/lib/ui/git.js +20 -14
  511. package/lib/ui/index.js +74 -56
  512. package/lib/ui/logger.js +13 -10
  513. package/lib/ui/serverlessFunctionLogs.js +20 -14
  514. package/lib/ui/spinniesUtils.js +39 -24
  515. package/lib/ui/supportHyperlinks.js +6 -3
  516. package/lib/ui/supportsColor.js +17 -11
  517. package/lib/ui/table.js +13 -6
  518. package/lib/upload.js +21 -15
  519. package/lib/usageTracking.d.ts +11 -0
  520. package/lib/usageTracking.js +95 -95
  521. package/lib/utils/hasFlag.js +8 -2
  522. package/lib/validation.js +87 -48
  523. package/lib/yargsUtils.d.ts +1 -1
  524. package/lib/yargsUtils.js +16 -13
  525. package/mcp-server/server.js +8 -6
  526. package/mcp-server/tools/index.js +16 -13
  527. package/mcp-server/tools/project/AddFeatureToProject.d.ts +1 -1
  528. package/mcp-server/tools/project/AddFeatureToProject.js +41 -34
  529. package/mcp-server/tools/project/CreateProjectTool.d.ts +3 -3
  530. package/mcp-server/tools/project/CreateProjectTool.js +52 -45
  531. package/mcp-server/tools/project/DeployProject.d.ts +1 -1
  532. package/mcp-server/tools/project/DeployProject.js +24 -17
  533. package/mcp-server/tools/project/GuidedWalkthroughTool.d.ts +1 -1
  534. package/mcp-server/tools/project/GuidedWalkthroughTool.js +27 -20
  535. package/mcp-server/tools/project/UploadProjectTools.d.ts +1 -1
  536. package/mcp-server/tools/project/UploadProjectTools.js +21 -11
  537. package/mcp-server/tools/project/ValidateProjectTool.d.ts +1 -1
  538. package/mcp-server/tools/project/ValidateProjectTool.js +19 -12
  539. package/mcp-server/tools/project/__tests__/AddFeatureToProject.test.js +15 -12
  540. package/mcp-server/tools/project/__tests__/CreateProjectTool.test.js +16 -13
  541. package/mcp-server/tools/project/__tests__/DeployProject.test.js +9 -6
  542. package/mcp-server/tools/project/__tests__/GuidedWalkthroughTool.test.js +7 -4
  543. package/mcp-server/tools/project/__tests__/UploadProjectTools.test.js +7 -4
  544. package/mcp-server/tools/project/__tests__/ValidateProjectTool.test.js +7 -4
  545. package/mcp-server/tools/project/constants.js +9 -3
  546. package/mcp-server/types.js +5 -1
  547. package/mcp-server/utils/__tests__/command.test.js +11 -9
  548. package/mcp-server/utils/__tests__/project.test.js +26 -18
  549. package/mcp-server/utils/command.d.ts +1 -1
  550. package/mcp-server/utils/command.js +11 -4
  551. package/mcp-server/utils/content.d.ts +1 -1
  552. package/mcp-server/utils/content.js +6 -2
  553. package/mcp-server/utils/project.js +17 -8
  554. package/mcp-server/utils/toolUsageTracking.d.ts +1 -0
  555. package/mcp-server/utils/toolUsageTracking.js +25 -0
  556. package/package.json +13 -17
  557. package/types/{cms.d.ts → Cms.d.ts} +1 -1
  558. package/types/Cms.js +2 -0
  559. package/types/LocalDev.d.ts +4 -4
  560. package/types/LocalDev.js +2 -1
  561. package/types/ProjectComponents.d.ts +2 -2
  562. package/types/ProjectComponents.js +2 -1
  563. package/types/Projects.d.ts +1 -1
  564. package/types/Projects.js +5 -2
  565. package/types/Prompts.js +2 -1
  566. package/types/Sandboxes.js +2 -0
  567. package/types/Yargs.js +2 -1
  568. package/types/sandboxes.js +0 -1
  569. /package/{types/cms.js → commands/app/__tests__/install.test.d.ts} +0 -0
  570. /package/types/{sandboxes.d.ts → Sandboxes.d.ts} +0 -0
@@ -1,42 +1,47 @@
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';
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"));
6
11
  vi.mock('../cms/lighthouseScore');
7
12
  vi.mock('../cms/convertFields');
8
13
  vi.mock('../cms/getReactModule');
9
14
  vi.mock('../../lib/commonOpts');
10
15
  const commandSpy = vi
11
- .spyOn(yargs, 'command')
12
- .mockReturnValue(yargs);
16
+ .spyOn(yargs_1.default, 'command')
17
+ .mockReturnValue(yargs_1.default);
13
18
  const demandCommandSpy = vi
14
- .spyOn(yargs, 'demandCommand')
15
- .mockReturnValue(yargs);
19
+ .spyOn(yargs_1.default, 'demandCommand')
20
+ .mockReturnValue(yargs_1.default);
16
21
  describe('commands/cms', () => {
17
22
  describe('command', () => {
18
23
  it('should have the correct command structure', () => {
19
- expect(cmsCommand.command).toEqual('cms');
24
+ expect(cms_1.default.command).toEqual('cms');
20
25
  });
21
26
  });
22
27
  describe('describe', () => {
23
28
  it('should provide a description', () => {
24
- expect(cmsCommand.describe).toBeDefined();
29
+ expect(cms_1.default.describe).toBeDefined();
25
30
  });
26
31
  });
27
32
  describe('builder', () => {
28
- const subcommands = [lighthouseScore, convertFields, getReactModule];
33
+ const subcommands = [lighthouseScore_1.default, convertFields_1.default, getReactModule_1.default];
29
34
  it('should demand the command takes one positional argument', () => {
30
- cmsCommand.builder(yargs);
35
+ cms_1.default.builder(yargs_1.default);
31
36
  expect(demandCommandSpy).toHaveBeenCalledTimes(1);
32
37
  expect(demandCommandSpy).toHaveBeenCalledWith(1, '');
33
38
  });
34
39
  it('should add the correct number of sub commands', () => {
35
- cmsCommand.builder(yargs);
40
+ cms_1.default.builder(yargs_1.default);
36
41
  expect(commandSpy).toHaveBeenCalledTimes(subcommands.length);
37
42
  });
38
43
  it.each(subcommands)('should attach the %s subcommand', module => {
39
- cmsCommand.builder(yargs);
44
+ cms_1.default.builder(yargs_1.default);
40
45
  expect(module).toBeDefined();
41
46
  expect(commandSpy).toHaveBeenCalledWith(module);
42
47
  });
@@ -1,24 +1,29 @@
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';
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"));
5
10
  vi.mock('../config/set');
6
11
  vi.mock('../config/set');
7
12
  const commandSpy = vi
8
- .spyOn(yargs, 'command')
9
- .mockReturnValue(yargs);
13
+ .spyOn(yargs_1.default, 'command')
14
+ .mockReturnValue(yargs_1.default);
10
15
  const demandCommandSpy = vi
11
- .spyOn(yargs, 'demandCommand')
12
- .mockReturnValue(yargs);
16
+ .spyOn(yargs_1.default, 'demandCommand')
17
+ .mockReturnValue(yargs_1.default);
13
18
  describe('commands/config', () => {
14
19
  describe('command', () => {
15
20
  it('should have the correct command structure', () => {
16
- expect(configCommands.command).toEqual('config');
21
+ expect(config_1.default.command).toEqual('config');
17
22
  });
18
23
  });
19
24
  describe('describe', () => {
20
25
  it('should provide a description', () => {
21
- expect(configCommands.describe).toBeDefined();
26
+ expect(config_1.default.describe).toBeDefined();
22
27
  });
23
28
  });
24
29
  describe('builder', () => {
@@ -26,18 +31,18 @@ describe('commands/config', () => {
26
31
  commandSpy.mockClear();
27
32
  demandCommandSpy.mockClear();
28
33
  });
29
- const subcommands = [set, migrate];
34
+ const subcommands = [set_1.default, migrate_1.default];
30
35
  it('should demand the command takes one positional argument', () => {
31
- configCommands.builder(yargs);
36
+ config_1.default.builder(yargs_1.default);
32
37
  expect(demandCommandSpy).toHaveBeenCalledTimes(1);
33
38
  expect(demandCommandSpy).toHaveBeenCalledWith(1, '');
34
39
  });
35
40
  it('should add the correct number of sub commands', () => {
36
- configCommands.builder(yargs);
41
+ config_1.default.builder(yargs_1.default);
37
42
  expect(commandSpy).toHaveBeenCalledTimes(subcommands.length);
38
43
  });
39
44
  it.each(subcommands)('should attach the %s subcommand', module => {
40
- configCommands.builder(yargs);
45
+ config_1.default.builder(yargs_1.default);
41
46
  expect(commandSpy).toHaveBeenCalledWith(module);
42
47
  });
43
48
  });
@@ -1,32 +1,37 @@
1
- import yargs from 'yargs';
2
- import createCommand from '../create.js';
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"));
3
8
  const positionalSpy = vi
4
- .spyOn(yargs, 'positional')
5
- .mockReturnValue(yargs);
9
+ .spyOn(yargs_1.default, 'positional')
10
+ .mockReturnValue(yargs_1.default);
6
11
  const optionSpy = vi
7
- .spyOn(yargs, 'option')
8
- .mockReturnValue(yargs);
12
+ .spyOn(yargs_1.default, 'option')
13
+ .mockReturnValue(yargs_1.default);
9
14
  describe('commands/create', () => {
10
15
  describe('command', () => {
11
16
  it('should have the correct command structure', () => {
12
- expect(createCommand.command).toEqual('create <type> [name] [dest]');
17
+ expect(create_1.default.command).toEqual('create <type> [name] [dest]');
13
18
  });
14
19
  });
15
20
  describe('describe', () => {
16
21
  it('should provide a description', () => {
17
- expect(createCommand.describe).toBeDefined();
22
+ expect(create_1.default.describe).toBeDefined();
18
23
  });
19
24
  });
20
25
  describe('builder', () => {
21
26
  it('should support the correct positional arguments', () => {
22
- createCommand.builder(yargs);
27
+ create_1.default.builder(yargs_1.default);
23
28
  expect(positionalSpy).toHaveBeenCalledTimes(3);
24
29
  expect(positionalSpy).toHaveBeenCalledWith('type', expect.objectContaining({ type: 'string' }));
25
30
  expect(positionalSpy).toHaveBeenCalledWith('name', expect.objectContaining({ type: 'string' }));
26
31
  expect(positionalSpy).toHaveBeenCalledWith('dest', expect.objectContaining({ type: 'string' }));
27
32
  });
28
33
  it('should support the correct options', () => {
29
- createCommand.builder(yargs);
34
+ create_1.default.builder(yargs_1.default);
30
35
  expect(optionSpy).toHaveBeenCalledWith('internal', expect.objectContaining({ type: 'boolean', hidden: true }));
31
36
  });
32
37
  });
@@ -1,20 +1,25 @@
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';
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"));
5
10
  vi.mock('../customObject/create');
6
11
  vi.mock('../customObject/schema');
7
12
  vi.mock('../../lib/commonOpts');
8
13
  const commandSpy = vi
9
- .spyOn(yargs, 'command')
10
- .mockReturnValue(yargs);
14
+ .spyOn(yargs_1.default, 'command')
15
+ .mockReturnValue(yargs_1.default);
11
16
  const demandCommandSpy = vi
12
- .spyOn(yargs, 'demandCommand')
13
- .mockReturnValue(yargs);
17
+ .spyOn(yargs_1.default, 'demandCommand')
18
+ .mockReturnValue(yargs_1.default);
14
19
  describe('commands/customObject', () => {
15
20
  describe('command', () => {
16
21
  it('should have the correct command structure', () => {
17
- expect(customObjectCommands.command).toEqual([
22
+ expect(customObject_1.default.command).toEqual([
18
23
  'custom-object',
19
24
  'custom-objects',
20
25
  'co',
@@ -23,7 +28,7 @@ describe('commands/customObject', () => {
23
28
  });
24
29
  describe('describe', () => {
25
30
  it('should provide a description', () => {
26
- expect(customObjectCommands.describe).toBeDefined();
31
+ expect(customObject_1.default.describe).toBeDefined();
27
32
  });
28
33
  });
29
34
  describe('builder', () => {
@@ -31,18 +36,18 @@ describe('commands/customObject', () => {
31
36
  commandSpy.mockClear();
32
37
  demandCommandSpy.mockClear();
33
38
  });
34
- const subcommands = [create, schema];
39
+ const subcommands = [create_1.default, schema_1.default];
35
40
  it('should demand the command takes one positional argument', () => {
36
- customObjectCommands.builder(yargs);
41
+ customObject_1.default.builder(yargs_1.default);
37
42
  expect(demandCommandSpy).toHaveBeenCalledTimes(1);
38
43
  expect(demandCommandSpy).toHaveBeenCalledWith(1, '');
39
44
  });
40
45
  it('should add the correct number of sub commands', () => {
41
- customObjectCommands.builder(yargs);
46
+ customObject_1.default.builder(yargs_1.default);
42
47
  expect(commandSpy).toHaveBeenCalledTimes(subcommands.length);
43
48
  });
44
49
  it.each(subcommands)('should attach the %s subcommand', module => {
45
- customObjectCommands.builder(yargs);
50
+ customObject_1.default.builder(yargs_1.default);
46
51
  expect(commandSpy).toHaveBeenCalledWith(module);
47
52
  });
48
53
  });
@@ -1,23 +1,28 @@
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';
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");
9
14
  vi.mock('../../lib/usageTracking');
10
15
  vi.mock('../../lib/doctor/Doctor');
11
16
  vi.mock('@hubspot/local-dev-lib/logger');
12
17
  vi.mock('@hubspot/local-dev-lib/path');
13
18
  vi.mock('fs');
14
19
  // @ts-expect-error Doesn't match the actual signature because then the linter complains about unused variables
15
- const DoctorMock = Doctor;
16
- const mockedFs = vi.mocked(fs);
17
- const getCwd = __getCwd;
20
+ const DoctorMock = Doctor_1.Doctor;
21
+ const mockedFs = vi.mocked(fs_1.default);
22
+ const getCwd = path_1.getCwd;
18
23
  const optionSpy = vi
19
- .spyOn(yargs, 'option')
20
- .mockReturnValue(yargs);
24
+ .spyOn(yargs_1.default, 'option')
25
+ .mockReturnValue(yargs_1.default);
21
26
  const date = new Date('2022-02-22');
22
27
  vi.useFakeTimers().setSystemTime(date);
23
28
  describe('doctor', () => {
@@ -30,17 +35,17 @@ describe('doctor', () => {
30
35
  });
31
36
  describe('command', () => {
32
37
  it('should have the proper command name', () => {
33
- expect(doctorCommand.command).toEqual('doctor');
38
+ expect(doctor_1.default.command).toEqual('doctor');
34
39
  });
35
40
  });
36
41
  describe('describe', () => {
37
42
  it('should have a description', () => {
38
- expect(doctorCommand.describe).toEqual('Retrieve diagnostic information about your local HubSpot configurations.');
43
+ expect(doctor_1.default.describe).toEqual('Retrieve diagnostic information about your local HubSpot configurations.');
39
44
  });
40
45
  });
41
46
  describe('builder', () => {
42
47
  it('should apply the correct options', () => {
43
- doctorCommand.builder(yargs);
48
+ doctor_1.default.builder(yargs_1.default);
44
49
  expect(optionSpy).toHaveBeenCalledWith('output-dir', {
45
50
  describe: 'Directory to save a detailed diagnosis JSON file in',
46
51
  type: 'string',
@@ -59,16 +64,16 @@ describe('doctor', () => {
59
64
  });
60
65
  });
61
66
  it('should track the command usage', async () => {
62
- await doctorCommand.handler({});
63
- expect(trackCommandUsage).toHaveBeenCalledTimes(1);
64
- expect(trackCommandUsage).toHaveBeenCalledWith('doctor', undefined, accountId);
67
+ await doctor_1.default.handler({});
68
+ expect(usageTracking_1.trackCommandUsage).toHaveBeenCalledTimes(1);
69
+ expect(usageTracking_1.trackCommandUsage).toHaveBeenCalledWith('doctor', undefined, accountId);
65
70
  });
66
71
  it('should log the diagnosis if it is defined', async () => {
67
- await doctorCommand.handler({});
68
- expect(logger.log).toHaveBeenCalledTimes(1);
69
- expect(logger.log).toHaveBeenCalledWith(diagnosis);
72
+ await doctor_1.default.handler({});
73
+ expect(logger_1.logger.log).toHaveBeenCalledTimes(1);
74
+ expect(logger_1.logger.log).toHaveBeenCalledWith(diagnosis);
70
75
  expect(processExitSpy).toHaveBeenCalledTimes(1);
71
- expect(processExitSpy).toHaveBeenCalledWith(EXIT_CODES.SUCCESS);
76
+ expect(processExitSpy).toHaveBeenCalledWith(exitCodes_1.EXIT_CODES.SUCCESS);
72
77
  });
73
78
  it('should log an error if the diagnosis is undefined', async () => {
74
79
  DoctorMock.mockImplementationOnce(() => {
@@ -77,58 +82,58 @@ describe('doctor', () => {
77
82
  accountId,
78
83
  };
79
84
  });
80
- await doctorCommand.handler({});
81
- expect(logger.error).toHaveBeenCalledTimes(1);
82
- expect(logger.error).toHaveBeenCalledWith('Error generating diagnosis');
85
+ await doctor_1.default.handler({});
86
+ expect(logger_1.logger.error).toHaveBeenCalledTimes(1);
87
+ expect(logger_1.logger.error).toHaveBeenCalledWith('Error generating diagnosis');
83
88
  expect(processExitSpy).toHaveBeenCalledTimes(1);
84
- expect(processExitSpy).toHaveBeenCalledWith(EXIT_CODES.ERROR);
89
+ expect(processExitSpy).toHaveBeenCalledWith(exitCodes_1.EXIT_CODES.ERROR);
85
90
  });
86
91
  it('should write the output to a file if output-dir is defined', async () => {
87
92
  mockedFs.writeFileSync.mockImplementationOnce(() => { });
88
93
  const expectedOutputFile = `/foo/hubspot-doctor-${date.toISOString()}.json`;
89
- await doctorCommand.handler({
94
+ await doctor_1.default.handler({
90
95
  outputDir: '/foo',
91
96
  });
92
- expect(logger.log).not.toHaveBeenCalled();
93
- expect(logger.error).not.toHaveBeenCalled();
97
+ expect(logger_1.logger.log).not.toHaveBeenCalled();
98
+ expect(logger_1.logger.error).not.toHaveBeenCalled();
94
99
  expect(mockedFs.writeFileSync).toHaveBeenCalledTimes(1);
95
100
  expect(mockedFs.writeFileSync).toHaveBeenCalledWith(expectedOutputFile, expect.stringContaining(diagnosis));
96
- expect(logger.success).toHaveBeenCalledTimes(1);
97
- expect(logger.success).toHaveBeenCalledWith(expect.stringMatching(/Output written to /));
101
+ expect(logger_1.logger.success).toHaveBeenCalledTimes(1);
102
+ expect(logger_1.logger.success).toHaveBeenCalledWith(expect.stringMatching(/Output written to /));
98
103
  expect(processExitSpy).toHaveBeenCalledTimes(1);
99
- expect(processExitSpy).toHaveBeenCalledWith(EXIT_CODES.SUCCESS);
104
+ expect(processExitSpy).toHaveBeenCalledWith(exitCodes_1.EXIT_CODES.SUCCESS);
100
105
  });
101
106
  it('should handle absolute paths', async () => {
102
107
  mockedFs.writeFileSync.mockImplementationOnce(() => { });
103
108
  const cwd = '/some/path/to';
104
109
  getCwd.mockImplementationOnce(() => cwd);
105
110
  const expectedOutputFile = `${cwd}/foo/hubspot-doctor-${date.toISOString()}.json`;
106
- await doctorCommand.handler({
111
+ await doctor_1.default.handler({
107
112
  outputDir: './foo',
108
113
  });
109
- expect(logger.log).not.toHaveBeenCalled();
110
- expect(logger.error).not.toHaveBeenCalled();
114
+ expect(logger_1.logger.log).not.toHaveBeenCalled();
115
+ expect(logger_1.logger.error).not.toHaveBeenCalled();
111
116
  expect(mockedFs.writeFileSync).toHaveBeenCalledTimes(1);
112
117
  expect(mockedFs.writeFileSync).toHaveBeenCalledWith(expectedOutputFile, expect.stringContaining(diagnosis));
113
- expect(logger.success).toHaveBeenCalledTimes(1);
114
- expect(logger.success).toHaveBeenCalledWith(expect.stringMatching(/Output written to /));
118
+ expect(logger_1.logger.success).toHaveBeenCalledTimes(1);
119
+ expect(logger_1.logger.success).toHaveBeenCalledWith(expect.stringMatching(/Output written to /));
115
120
  expect(processExitSpy).toHaveBeenCalledTimes(1);
116
- expect(processExitSpy).toHaveBeenCalledWith(EXIT_CODES.SUCCESS);
121
+ expect(processExitSpy).toHaveBeenCalledWith(exitCodes_1.EXIT_CODES.SUCCESS);
117
122
  });
118
123
  it('should log an error message when writing the output fails', async () => {
119
124
  const errorMessage = 'Something bad happened';
120
125
  mockedFs.writeFileSync.mockImplementationOnce(() => {
121
126
  throw new Error(errorMessage);
122
127
  });
123
- await doctorCommand.handler({
128
+ await doctor_1.default.handler({
124
129
  outputDir: '/foo',
125
130
  });
126
- expect(logger.error).toHaveBeenCalledTimes(1);
127
- expect(logger.error).toHaveBeenCalledWith(expect.stringMatching(/Unable to write output to/));
131
+ expect(logger_1.logger.error).toHaveBeenCalledTimes(1);
132
+ expect(logger_1.logger.error).toHaveBeenCalledWith(expect.stringMatching(/Unable to write output to/));
128
133
  expect(mockedFs.writeFileSync).toHaveBeenCalledTimes(1);
129
134
  expect(mockedFs.writeFileSync).toHaveBeenCalledWith(`/foo/hubspot-doctor-${date.toISOString()}.json`, expect.stringContaining(diagnosis));
130
135
  expect(processExitSpy).toHaveBeenCalledTimes(1);
131
- expect(processExitSpy).toHaveBeenCalledWith(EXIT_CODES.ERROR);
136
+ expect(processExitSpy).toHaveBeenCalledWith(exitCodes_1.EXIT_CODES.ERROR);
132
137
  });
133
138
  });
134
139
  });
@@ -1,24 +1,62 @@
1
- import yargs from 'yargs';
2
- import * as commonOpts from '../../lib/commonOpts.js';
3
- import feedbackCommand from '../feedback.js';
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"));
4
42
  vi.mock('yargs');
5
43
  vi.mock('../../lib/commonOpts');
6
44
  describe('commands/feedback', () => {
7
45
  describe('command', () => {
8
46
  it('should have the correct command structure', () => {
9
- expect(feedbackCommand.command).toEqual('feedback');
47
+ expect(feedback_1.default.command).toEqual('feedback');
10
48
  });
11
49
  });
12
50
  describe('describe', () => {
13
51
  it('should provide a description', () => {
14
- expect(feedbackCommand.describe).toBeDefined();
52
+ expect(feedback_1.default.describe).toBeDefined();
15
53
  });
16
54
  });
17
55
  describe('builder', () => {
18
56
  it('should support the correct options', () => {
19
- feedbackCommand.builder(yargs);
57
+ feedback_1.default.builder(yargs_1.default);
20
58
  expect(commonOpts.addGlobalOptions).toHaveBeenCalledTimes(1);
21
- expect(commonOpts.addGlobalOptions).toHaveBeenCalledWith(yargs);
59
+ expect(commonOpts.addGlobalOptions).toHaveBeenCalledWith(yargs_1.default);
22
60
  });
23
61
  });
24
62
  });
@@ -1,57 +1,56 @@
1
- import yargs from 'yargs';
2
- import { addAccountOptions, addConfigOptions, addOverwriteOptions, addCmsPublishModeOptions, addUseEnvironmentOptions, } from '../../lib/commonOpts.js';
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");
3
8
  vi.mock('../../lib/commonOpts');
4
9
  // Import this last so mocks apply
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);
10
+ const fetch_1 = __importDefault(require("../fetch"));
12
11
  describe('commands/fetch', () => {
13
12
  describe('command', () => {
14
13
  it('should have the correct command structure', () => {
15
- expect(fetchCommand.command).toEqual('fetch <src> [dest]');
14
+ expect(fetch_1.default.command).toEqual('fetch <src> [dest]');
16
15
  });
17
16
  });
18
17
  describe('describe', () => {
19
18
  it('should provide a description', () => {
20
- expect(fetchCommand.describe).toBeDefined();
19
+ expect(fetch_1.default.describe).toBeDefined();
21
20
  });
22
21
  });
23
22
  describe('builder', () => {
24
23
  it('should support the correct positional arguments', () => {
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' }));
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' }));
29
28
  });
30
29
  it('should support the correct options', () => {
31
- fetchCommand.builder(yargs);
32
- expect(optionsSpy).toHaveBeenCalledTimes(2);
33
- expect(optionsSpy).toHaveBeenCalledWith({
30
+ fetch_1.default.builder(yargs_1.default);
31
+ expect(yargs_1.default.options).toHaveBeenCalledTimes(2);
32
+ expect(yargs_1.default.options).toHaveBeenCalledWith({
34
33
  staging: expect.objectContaining({
35
34
  type: 'boolean',
36
35
  default: false,
37
36
  hidden: true,
38
37
  }),
39
38
  });
40
- expect(optionsSpy).toHaveBeenCalledWith({
39
+ expect(yargs_1.default.options).toHaveBeenCalledWith({
41
40
  assetVersion: expect.objectContaining({ type: 'number' }),
42
41
  });
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, {
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, {
51
50
  read: true,
52
51
  });
53
- expect(addUseEnvironmentOptions).toHaveBeenCalledTimes(1);
54
- expect(addUseEnvironmentOptions).toHaveBeenCalledWith(yargs);
52
+ expect(commonOpts_1.addUseEnvironmentOptions).toHaveBeenCalledTimes(1);
53
+ expect(commonOpts_1.addUseEnvironmentOptions).toHaveBeenCalledWith(yargs_1.default);
55
54
  });
56
55
  });
57
56
  });
@@ -1,25 +1,30 @@
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';
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"));
5
10
  vi.mock('../filemanager/fetch');
6
11
  vi.mock('../filemanager/upload');
7
12
  vi.mock('../../lib/commonOpts');
8
13
  const commandSpy = vi
9
- .spyOn(yargs, 'command')
10
- .mockReturnValue(yargs);
14
+ .spyOn(yargs_1.default, 'command')
15
+ .mockReturnValue(yargs_1.default);
11
16
  const demandCommandSpy = vi
12
- .spyOn(yargs, 'demandCommand')
13
- .mockReturnValue(yargs);
17
+ .spyOn(yargs_1.default, 'demandCommand')
18
+ .mockReturnValue(yargs_1.default);
14
19
  describe('commands/filemanager', () => {
15
20
  describe('command', () => {
16
21
  it('should have the correct command structure', () => {
17
- expect(fileManagerCommands.command).toEqual('filemanager');
22
+ expect(filemanager_1.default.command).toEqual('filemanager');
18
23
  });
19
24
  });
20
25
  describe('describe', () => {
21
26
  it('should provide a description', () => {
22
- expect(fileManagerCommands.describe).toBeDefined();
27
+ expect(filemanager_1.default.describe).toBeDefined();
23
28
  });
24
29
  });
25
30
  describe('builder', () => {
@@ -27,18 +32,18 @@ describe('commands/filemanager', () => {
27
32
  commandSpy.mockClear();
28
33
  demandCommandSpy.mockClear();
29
34
  });
30
- const subcommands = [fetch, upload];
35
+ const subcommands = [fetch_1.default, upload_1.default];
31
36
  it('should demand the command takes one positional argument', () => {
32
- fileManagerCommands.builder(yargs);
37
+ filemanager_1.default.builder(yargs_1.default);
33
38
  expect(demandCommandSpy).toHaveBeenCalledTimes(1);
34
39
  expect(demandCommandSpy).toHaveBeenCalledWith(1, '');
35
40
  });
36
41
  it('should add the correct number of sub commands', () => {
37
- fileManagerCommands.builder(yargs);
42
+ filemanager_1.default.builder(yargs_1.default);
38
43
  expect(commandSpy).toHaveBeenCalledTimes(subcommands.length);
39
44
  });
40
45
  it.each(subcommands)('should attach the %s subcommand', module => {
41
- fileManagerCommands.builder(yargs);
46
+ filemanager_1.default.builder(yargs_1.default);
42
47
  expect(commandSpy).toHaveBeenCalledWith(module);
43
48
  });
44
49
  });