@hubspot/cli 6.2.0 → 6.2.2-beta.0

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 (344) hide show
  1. package/README.md +12 -95
  2. package/bin/cli.d.ts +2 -0
  3. package/bin/cli.js +107 -128
  4. package/commands/accounts/clean.d.ts +1 -0
  5. package/commands/accounts/clean.js +82 -116
  6. package/commands/accounts/info.d.ts +1 -0
  7. package/commands/accounts/info.js +32 -43
  8. package/commands/accounts/list.d.ts +1 -0
  9. package/commands/accounts/list.js +65 -92
  10. package/commands/accounts/remove.d.ts +1 -0
  11. package/commands/accounts/remove.js +43 -73
  12. package/commands/accounts/rename.d.ts +1 -0
  13. package/commands/accounts/rename.js +26 -41
  14. package/commands/accounts/use.d.ts +1 -0
  15. package/commands/accounts/use.js +36 -57
  16. package/commands/accounts.d.ts +1 -0
  17. package/commands/accounts.js +16 -18
  18. package/commands/auth.d.ts +1 -0
  19. package/commands/auth.js +133 -200
  20. package/commands/cms/convertFields.d.ts +1 -0
  21. package/commands/cms/convertFields.js +66 -81
  22. package/commands/cms/lighthouseScore.d.ts +1 -0
  23. package/commands/cms/lighthouseScore.js +236 -298
  24. package/commands/cms/reactModules.d.ts +1 -0
  25. package/commands/cms/reactModules.js +46 -53
  26. package/commands/cms.d.ts +1 -0
  27. package/commands/cms.js +11 -13
  28. package/commands/config/set.d.ts +1 -0
  29. package/commands/config/set.js +64 -79
  30. package/commands/config.d.ts +1 -0
  31. package/commands/config.js +7 -9
  32. package/commands/create/api-sample.d.ts +1 -0
  33. package/commands/create/api-sample.js +54 -74
  34. package/commands/create/app.d.ts +1 -0
  35. package/commands/create/app.js +8 -7
  36. package/commands/create/function.d.ts +1 -0
  37. package/commands/create/function.js +15 -14
  38. package/commands/create/index.d.ts +1 -0
  39. package/commands/create/index.js +12 -9
  40. package/commands/create/module.d.ts +1 -0
  41. package/commands/create/module.js +21 -19
  42. package/commands/create/react-app.d.ts +1 -0
  43. package/commands/create/react-app.js +7 -6
  44. package/commands/create/template.d.ts +1 -0
  45. package/commands/create/template.js +23 -24
  46. package/commands/create/vue-app.d.ts +1 -0
  47. package/commands/create/vue-app.js +7 -6
  48. package/commands/create/webpack-serverless.d.ts +1 -0
  49. package/commands/create/webpack-serverless.js +7 -6
  50. package/commands/create/website-theme.d.ts +1 -0
  51. package/commands/create/website-theme.js +15 -15
  52. package/commands/create.d.ts +24 -0
  53. package/commands/create.js +65 -80
  54. package/commands/customObject/create.d.ts +1 -0
  55. package/commands/customObject/create.js +33 -47
  56. package/commands/customObject/schema/create.d.ts +1 -0
  57. package/commands/customObject/schema/create.js +42 -67
  58. package/commands/customObject/schema/delete.d.ts +1 -0
  59. package/commands/customObject/schema/delete.js +28 -39
  60. package/commands/customObject/schema/fetch-all.d.ts +1 -0
  61. package/commands/customObject/schema/fetch-all.js +30 -39
  62. package/commands/customObject/schema/fetch.d.ts +1 -0
  63. package/commands/customObject/schema/fetch.js +48 -63
  64. package/commands/customObject/schema/list.d.ts +1 -0
  65. package/commands/customObject/schema/list.js +14 -17
  66. package/commands/customObject/schema/update.d.ts +1 -0
  67. package/commands/customObject/schema/update.js +46 -72
  68. package/commands/customObject/schema.d.ts +1 -0
  69. package/commands/customObject/schema.js +12 -12
  70. package/commands/customObject.d.ts +1 -0
  71. package/commands/customObject.js +14 -22
  72. package/commands/feedback.d.ts +1 -0
  73. package/commands/feedback.js +25 -33
  74. package/commands/fetch.d.ts +1 -0
  75. package/commands/fetch.js +53 -78
  76. package/commands/filemanager/fetch.d.ts +1 -0
  77. package/commands/filemanager/fetch.js +38 -56
  78. package/commands/filemanager/upload.d.ts +1 -0
  79. package/commands/filemanager/upload.js +88 -128
  80. package/commands/filemanager.d.ts +1 -0
  81. package/commands/filemanager.js +12 -18
  82. package/commands/functions/deploy.d.ts +1 -0
  83. package/commands/functions/deploy.js +76 -99
  84. package/commands/functions/list.d.ts +1 -0
  85. package/commands/functions/list.js +41 -48
  86. package/commands/functions/server.d.ts +1 -0
  87. package/commands/functions/server.js +50 -65
  88. package/commands/functions.d.ts +1 -0
  89. package/commands/functions.js +13 -15
  90. package/commands/hubdb/clear.d.ts +1 -0
  91. package/commands/hubdb/clear.js +37 -56
  92. package/commands/hubdb/create.d.ts +1 -0
  93. package/commands/hubdb/create.js +34 -57
  94. package/commands/hubdb/delete.d.ts +1 -0
  95. package/commands/hubdb/delete.js +29 -44
  96. package/commands/hubdb/fetch.d.ts +1 -0
  97. package/commands/hubdb/fetch.js +30 -46
  98. package/commands/hubdb.d.ts +1 -0
  99. package/commands/hubdb.js +12 -14
  100. package/commands/init.d.ts +1 -0
  101. package/commands/init.js +103 -160
  102. package/commands/lint.d.ts +1 -0
  103. package/commands/lint.js +34 -45
  104. package/commands/list.d.ts +1 -0
  105. package/commands/list.js +74 -101
  106. package/commands/logs.d.ts +1 -0
  107. package/commands/logs.js +98 -121
  108. package/commands/module/marketplace-validate.d.ts +1 -0
  109. package/commands/module/marketplace-validate.js +32 -57
  110. package/commands/module.d.ts +1 -0
  111. package/commands/module.js +7 -9
  112. package/commands/mv.d.ts +1 -0
  113. package/commands/mv.js +53 -71
  114. package/commands/open.d.ts +1 -0
  115. package/commands/open.js +48 -62
  116. package/commands/project/add.d.ts +1 -0
  117. package/commands/project/add.js +47 -70
  118. package/commands/project/cloneApp.d.ts +1 -0
  119. package/commands/project/cloneApp.js +119 -180
  120. package/commands/project/create.d.ts +1 -0
  121. package/commands/project/create.js +49 -81
  122. package/commands/project/deploy.d.ts +1 -0
  123. package/commands/project/deploy.js +105 -182
  124. package/commands/project/dev.d.ts +1 -0
  125. package/commands/project/dev.js +126 -227
  126. package/commands/project/download.d.ts +1 -0
  127. package/commands/project/download.js +73 -123
  128. package/commands/project/installDeps.d.ts +1 -0
  129. package/commands/project/installDeps.js +52 -59
  130. package/commands/project/listBuilds.d.ts +1 -0
  131. package/commands/project/listBuilds.js +97 -139
  132. package/commands/project/logs.d.ts +1 -0
  133. package/commands/project/logs.js +86 -128
  134. package/commands/project/migrateApp.d.ts +1 -0
  135. package/commands/project/migrateApp.js +158 -248
  136. package/commands/project/open.d.ts +1 -0
  137. package/commands/project/open.js +44 -68
  138. package/commands/project/upload.d.ts +1 -0
  139. package/commands/project/upload.js +72 -116
  140. package/commands/project/watch.d.ts +1 -0
  141. package/commands/project/watch.js +94 -152
  142. package/commands/project.d.ts +1 -0
  143. package/commands/project.js +21 -23
  144. package/commands/remove.d.ts +1 -0
  145. package/commands/remove.js +28 -43
  146. package/commands/sandbox/create.d.ts +1 -0
  147. package/commands/sandbox/create.js +143 -187
  148. package/commands/sandbox/delete.d.ts +1 -0
  149. package/commands/sandbox/delete.js +166 -221
  150. package/commands/sandbox.d.ts +1 -0
  151. package/commands/sandbox.js +10 -12
  152. package/commands/secrets/addSecret.d.ts +1 -0
  153. package/commands/secrets/addSecret.js +34 -52
  154. package/commands/secrets/deleteSecret.d.ts +1 -0
  155. package/commands/secrets/deleteSecret.js +33 -50
  156. package/commands/secrets/listSecrets.d.ts +1 -0
  157. package/commands/secrets/listSecrets.js +28 -42
  158. package/commands/secrets/updateSecret.d.ts +1 -0
  159. package/commands/secrets/updateSecret.js +35 -53
  160. package/commands/secrets.d.ts +1 -0
  161. package/commands/secrets.js +12 -13
  162. package/commands/theme/generate-selectors.d.ts +1 -0
  163. package/commands/theme/generate-selectors.js +129 -192
  164. package/commands/theme/marketplace-validate.d.ts +1 -0
  165. package/commands/theme/marketplace-validate.js +32 -57
  166. package/commands/theme/preview.d.ts +1 -0
  167. package/commands/theme/preview.js +170 -195
  168. package/commands/theme.d.ts +1 -0
  169. package/commands/theme.js +9 -11
  170. package/commands/upload.d.ts +1 -0
  171. package/commands/upload.js +199 -287
  172. package/commands/watch.d.ts +1 -0
  173. package/commands/watch.js +128 -172
  174. package/lang/en.lyaml +2 -3
  175. package/lib/DevServerManager.d.ts +1 -0
  176. package/lib/DevServerManager.js +99 -124
  177. package/lib/LocalDevManager.d.ts +1 -0
  178. package/lib/LocalDevManager.js +322 -490
  179. package/lib/accountTypes.d.ts +7 -0
  180. package/lib/accountTypes.js +32 -34
  181. package/lib/buildAccount.d.ts +1 -0
  182. package/lib/buildAccount.js +132 -179
  183. package/lib/commonOpts.d.ts +1 -0
  184. package/lib/commonOpts.js +60 -91
  185. package/lib/configOptions.d.ts +1 -0
  186. package/lib/configOptions.js +110 -0
  187. package/lib/constants.d.ts +84 -0
  188. package/lib/constants.js +64 -91
  189. package/lib/debugInfo.d.ts +1 -0
  190. package/lib/debugInfo.js +14 -13
  191. package/lib/dependencyManagement.d.ts +1 -0
  192. package/lib/dependencyManagement.js +92 -132
  193. package/lib/developerTestAccounts.d.ts +1 -0
  194. package/lib/developerTestAccounts.js +67 -91
  195. package/lib/enums/exitCodes.d.ts +5 -0
  196. package/lib/enums/exitCodes.js +7 -8
  197. package/lib/environment.d.ts +1 -0
  198. package/lib/environment.js +13 -14
  199. package/lib/errorHandlers/index.d.ts +1 -0
  200. package/lib/errorHandlers/index.js +66 -80
  201. package/lib/errorHandlers/suppressError.d.ts +1 -0
  202. package/lib/errorHandlers/suppressError.js +66 -106
  203. package/lib/filesystem.d.ts +2 -0
  204. package/lib/filesystem.js +22 -28
  205. package/lib/generate-selectors.d.ts +1 -0
  206. package/lib/generate-selectors.js +102 -138
  207. package/lib/hasFeature.d.ts +1 -0
  208. package/lib/hasFeature.js +8 -15
  209. package/lib/hasFlag.d.ts +1 -0
  210. package/lib/hasFlag.js +13 -13
  211. package/lib/hublValidate.d.ts +2 -0
  212. package/lib/hublValidate.js +28 -28
  213. package/lib/interpolation.d.ts +1 -0
  214. package/lib/interpolation.js +50 -92
  215. package/lib/interpolationHelpers.d.ts +10 -0
  216. package/lib/interpolationHelpers.js +30 -22
  217. package/lib/lang.d.ts +1 -0
  218. package/lib/lang.js +52 -78
  219. package/lib/links.d.ts +1 -0
  220. package/lib/links.js +94 -114
  221. package/lib/localDev.d.ts +1 -0
  222. package/lib/localDev.js +285 -433
  223. package/lib/marketplace-validate.d.ts +1 -0
  224. package/lib/marketplace-validate.js +105 -126
  225. package/lib/oauth.d.ts +1 -0
  226. package/lib/oauth.js +64 -78
  227. package/lib/polling.d.ts +1 -0
  228. package/lib/polling.js +26 -26
  229. package/lib/process.d.ts +1 -0
  230. package/lib/process.js +41 -53
  231. package/lib/projectLogsManager.d.ts +1 -0
  232. package/lib/projectLogsManager.js +78 -130
  233. package/lib/projectStructure.d.ts +1 -0
  234. package/lib/projectStructure.js +89 -109
  235. package/lib/projects.d.ts +1 -0
  236. package/lib/projects.js +595 -958
  237. package/lib/projectsWatch.d.ts +1 -0
  238. package/lib/projectsWatch.js +127 -228
  239. package/lib/prompts/accountNamePrompt.d.ts +1 -0
  240. package/lib/prompts/accountNamePrompt.js +60 -65
  241. package/lib/prompts/accountsPrompt.d.ts +1 -0
  242. package/lib/prompts/accountsPrompt.js +33 -37
  243. package/lib/prompts/activeInstallConfirmationPrompt.d.ts +1 -0
  244. package/lib/prompts/activeInstallConfirmationPrompt.js +13 -13
  245. package/lib/prompts/cleanUploadPrompt.d.ts +1 -0
  246. package/lib/prompts/cleanUploadPrompt.js +13 -13
  247. package/lib/prompts/cmsFieldPrompt.d.ts +1 -0
  248. package/lib/prompts/cmsFieldPrompt.js +37 -39
  249. package/lib/prompts/createApiSamplePrompt.d.ts +1 -0
  250. package/lib/prompts/createApiSamplePrompt.js +49 -52
  251. package/lib/prompts/createFunctionPrompt.d.ts +1 -0
  252. package/lib/prompts/createFunctionPrompt.js +57 -56
  253. package/lib/prompts/createModulePrompt.d.ts +1 -0
  254. package/lib/prompts/createModulePrompt.js +47 -50
  255. package/lib/prompts/createProjectPrompt.d.ts +1 -0
  256. package/lib/prompts/createProjectPrompt.js +95 -129
  257. package/lib/prompts/createTemplatePrompt.d.ts +1 -0
  258. package/lib/prompts/createTemplatePrompt.js +18 -19
  259. package/lib/prompts/deployBuildIdPrompt.d.ts +1 -0
  260. package/lib/prompts/deployBuildIdPrompt.js +15 -15
  261. package/lib/prompts/downloadProjectPrompt.d.ts +1 -0
  262. package/lib/prompts/downloadProjectPrompt.js +39 -41
  263. package/lib/prompts/feedbackPrompt.d.ts +1 -0
  264. package/lib/prompts/feedbackPrompt.js +29 -30
  265. package/lib/prompts/folderOverwritePrompt.d.ts +1 -0
  266. package/lib/prompts/folderOverwritePrompt.js +10 -10
  267. package/lib/prompts/installPublicAppPrompt.d.ts +1 -0
  268. package/lib/prompts/installPublicAppPrompt.js +29 -42
  269. package/lib/prompts/personalAccessKeyPrompt.d.ts +1 -0
  270. package/lib/prompts/personalAccessKeyPrompt.js +104 -110
  271. package/lib/prompts/previewPrompt.d.ts +1 -0
  272. package/lib/prompts/previewPrompt.js +46 -47
  273. package/lib/prompts/projectAddPrompt.d.ts +1 -0
  274. package/lib/prompts/projectAddPrompt.js +37 -38
  275. package/lib/prompts/projectDevTargetAccountPrompt.d.ts +1 -0
  276. package/lib/prompts/projectDevTargetAccountPrompt.js +150 -193
  277. package/lib/prompts/projectNamePrompt.d.ts +1 -0
  278. package/lib/prompts/projectNamePrompt.js +25 -25
  279. package/lib/prompts/projectsLogsPrompt.d.ts +1 -0
  280. package/lib/prompts/projectsLogsPrompt.js +21 -27
  281. package/lib/prompts/promptUtils.d.ts +1 -0
  282. package/lib/prompts/promptUtils.js +17 -17
  283. package/lib/prompts/sandboxesPrompt.d.ts +1 -0
  284. package/lib/prompts/sandboxesPrompt.js +50 -59
  285. package/lib/prompts/secretPrompt.d.ts +1 -0
  286. package/lib/prompts/secretPrompt.js +15 -16
  287. package/lib/prompts/selectPublicAppPrompt.d.ts +1 -0
  288. package/lib/prompts/selectPublicAppPrompt.js +58 -82
  289. package/lib/prompts/setAsDefaultAccountPrompt.d.ts +1 -0
  290. package/lib/prompts/setAsDefaultAccountPrompt.js +19 -24
  291. package/lib/prompts/uploadPrompt.d.ts +1 -0
  292. package/lib/prompts/uploadPrompt.js +30 -30
  293. package/lib/regex.d.ts +1 -0
  294. package/lib/regex.js +4 -5
  295. package/lib/sandboxSync.d.ts +1 -0
  296. package/lib/sandboxSync.js +100 -166
  297. package/lib/sandboxes.d.ts +1 -0
  298. package/lib/sandboxes.js +201 -316
  299. package/lib/schema.d.ts +3 -0
  300. package/lib/schema.js +29 -33
  301. package/lib/serverlessLogs.d.ts +1 -0
  302. package/lib/serverlessLogs.js +131 -173
  303. package/lib/ui/SpinniesManager.d.ts +1 -0
  304. package/lib/ui/SpinniesManager.js +198 -254
  305. package/lib/ui/git.d.ts +1 -0
  306. package/lib/ui/git.js +20 -19
  307. package/lib/ui/index.d.ts +1 -0
  308. package/lib/ui/index.js +117 -167
  309. package/lib/ui/serverlessFunctionLogs.d.ts +1 -0
  310. package/lib/ui/serverlessFunctionLogs.js +53 -70
  311. package/lib/ui/spinniesUtils.d.ts +1 -0
  312. package/lib/ui/spinniesUtils.js +111 -133
  313. package/lib/ui/supportHyperlinks.d.ts +1 -0
  314. package/lib/ui/supportHyperlinks.js +49 -62
  315. package/lib/ui/supportsColor.d.ts +1 -0
  316. package/lib/ui/supportsColor.js +81 -109
  317. package/lib/ui/table.d.ts +1 -0
  318. package/lib/ui/table.js +49 -55
  319. package/lib/upload.d.ts +1 -0
  320. package/lib/upload.js +40 -43
  321. package/lib/usageTracking.d.ts +1 -0
  322. package/lib/usageTracking.js +133 -155
  323. package/lib/validation.d.ts +1 -0
  324. package/lib/validation.js +144 -203
  325. package/package.json +84 -48
  326. package/CHANGELOG.md +0 -16
  327. package/commands/__tests__/projects.test.js +0 -105
  328. package/commands/config/set/allowUsageTracking.js +0 -52
  329. package/commands/config/set/defaultMode.js +0 -59
  330. package/commands/config/set/httpTimeout.js +0 -42
  331. package/commands/project/__tests__/deploy.test.js +0 -443
  332. package/commands/project/__tests__/installDeps.test.js +0 -168
  333. package/commands/project/__tests__/logs.test.js +0 -304
  334. package/hubspot.sample.config.yml +0 -28
  335. package/jest.config.js +0 -4
  336. package/lib/__tests__/commonOpts.test.js +0 -83
  337. package/lib/__tests__/dependencyManagement.test.js +0 -243
  338. package/lib/__tests__/downloadProjectPrompt.test.js +0 -31
  339. package/lib/__tests__/projectLogsManager.test.js +0 -212
  340. package/lib/__tests__/projects.test.js +0 -140
  341. package/lib/__tests__/serverlessLogs.test.js +0 -162
  342. package/lib/__tests__/validation.test.js +0 -140
  343. package/lib/getFunctionArrays.js +0 -18
  344. package/lib/prompts/__tests__/projectsLogsPrompt.test.js +0 -46
@@ -1,52 +0,0 @@
1
- const { logger } = require('@hubspot/local-dev-lib/logger');
2
- const { updateAllowUsageTracking } = require('@hubspot/local-dev-lib/config');
3
- const { trackCommandUsage } = require('../../../lib/usageTracking');
4
- const { promptUser } = require('../../../lib/prompts/promptUtils');
5
- const { i18n } = require('../../../lib/lang');
6
-
7
- const i18nKey = 'commands.config.subcommands.set.options.allowUsageTracking';
8
-
9
- const enableOrDisableUsageTracking = async () => {
10
- const { isEnabled } = await promptUser([
11
- {
12
- type: 'list',
13
- look: false,
14
- name: 'isEnabled',
15
- pageSize: 20,
16
- message: i18n(`${i18nKey}.promptMessage`),
17
- choices: [
18
- {
19
- name: i18n(`${i18nKey}.labels.enabled`),
20
- value: true,
21
- },
22
- {
23
- name: i18n(`${i18nKey}.labels.disabled`),
24
- value: false,
25
- },
26
- ],
27
- default: true,
28
- },
29
- ]);
30
-
31
- return isEnabled;
32
- };
33
-
34
- const setAllowUsageTracking = async ({ accountId, allowUsageTracking }) => {
35
- trackCommandUsage('config-set-allow-usage-tracking', null, accountId);
36
-
37
- let isEnabled;
38
-
39
- if (typeof allowUsageTracking === 'boolean') {
40
- isEnabled = allowUsageTracking;
41
- } else {
42
- isEnabled = await enableOrDisableUsageTracking();
43
- }
44
-
45
- updateAllowUsageTracking(isEnabled);
46
-
47
- return logger.log(i18n(`${i18nKey}.success`, { isEnabled }));
48
- };
49
-
50
- module.exports = {
51
- setAllowUsageTracking,
52
- };
@@ -1,59 +0,0 @@
1
- const { logger } = require('@hubspot/local-dev-lib/logger');
2
- const { updateDefaultMode } = require('@hubspot/local-dev-lib/config');
3
- const { MODE } = require('@hubspot/local-dev-lib/constants/files');
4
- const { commaSeparatedValues } = require('@hubspot/local-dev-lib/text');
5
- const { trackCommandUsage } = require('../../../lib/usageTracking');
6
- const { promptUser } = require('../../../lib/prompts/promptUtils');
7
- const { i18n } = require('../../../lib/lang');
8
-
9
- const i18nKey = 'commands.config.subcommands.set.options.defaultMode';
10
-
11
- const ALL_MODES = Object.values(MODE);
12
-
13
- const selectMode = async () => {
14
- const { mode } = await promptUser([
15
- {
16
- type: 'list',
17
- look: false,
18
- name: 'mode',
19
- pageSize: 20,
20
- message: i18n(`${i18nKey}.promptMessage`),
21
- choices: ALL_MODES,
22
- default: MODE.publish,
23
- },
24
- ]);
25
-
26
- return mode;
27
- };
28
-
29
- const setDefaultMode = async ({ accountId, defaultMode }) => {
30
- trackCommandUsage('config-set-default-mode', null, accountId);
31
-
32
- let newDefault;
33
-
34
- if (!defaultMode) {
35
- newDefault = await selectMode();
36
- } else if (defaultMode && ALL_MODES.find(m => m === defaultMode)) {
37
- newDefault = defaultMode;
38
- } else {
39
- logger.error(
40
- i18n(`${i18nKey}.errors`, {
41
- mode: newDefault,
42
- validModes: commaSeparatedValues(ALL_MODES),
43
- })
44
- );
45
- newDefault = await selectMode();
46
- }
47
-
48
- updateDefaultMode(newDefault);
49
-
50
- return logger.success(
51
- i18n(`${i18nKey}.success`, {
52
- mode: newDefault,
53
- })
54
- );
55
- };
56
-
57
- module.exports = {
58
- setDefaultMode,
59
- };
@@ -1,42 +0,0 @@
1
- const { logger } = require('@hubspot/local-dev-lib/logger');
2
- const { updateHttpTimeout } = require('@hubspot/local-dev-lib/config');
3
- const { promptUser } = require('../../../lib/prompts/promptUtils');
4
- const { trackCommandUsage } = require('../../../lib/usageTracking');
5
- const { i18n } = require('../../../lib/lang');
6
-
7
- const i18nKey = 'commands.config.subcommands.set.options.httpTimeout';
8
-
9
- const enterTimeout = async () => {
10
- const { timeout } = await promptUser([
11
- {
12
- name: 'timeout',
13
- message: i18n(`${i18nKey}.promptMessage`),
14
- type: 'input',
15
- default: 30000,
16
- },
17
- ]);
18
-
19
- return timeout;
20
- };
21
-
22
- const setHttpTimeout = async ({ accountId, httpTimeout }) => {
23
- trackCommandUsage('config-set-http-timeout', null, accountId);
24
-
25
- let newHttpTimeout;
26
-
27
- if (!httpTimeout) {
28
- newHttpTimeout = await enterTimeout();
29
- } else {
30
- newHttpTimeout = httpTimeout;
31
- }
32
-
33
- updateHttpTimeout(newHttpTimeout);
34
-
35
- return logger.success(
36
- i18n(`${i18nKey}.success`, { timeout: newHttpTimeout })
37
- );
38
- };
39
-
40
- module.exports = {
41
- setHttpTimeout,
42
- };
@@ -1,443 +0,0 @@
1
- jest.mock('../../../lib/commonOpts');
2
- jest.mock('yargs');
3
- jest.mock('@hubspot/local-dev-lib/logger');
4
- jest.mock('@hubspot/local-dev-lib/api/projects');
5
- jest.mock('../../../lib/validation');
6
- jest.mock('../../../lib/projects');
7
- jest.mock('../../../lib/prompts/projectNamePrompt');
8
- jest.mock('../../../lib/prompts/deployBuildIdPrompt');
9
- jest.mock('@hubspot/local-dev-lib/config');
10
- jest.mock('../../../lib/usageTracking');
11
- jest.mock('../../../lib/ui');
12
-
13
- const libUi = jest.requireActual('../../../lib/ui');
14
- const {
15
- uiCommandReference,
16
- uiAccountDescription,
17
- uiBetaTag,
18
- uiLink,
19
- } = require('../../../lib/ui');
20
-
21
- uiBetaTag.mockImplementation(libUi.uiBetaTag);
22
-
23
- const {
24
- handler,
25
- describe: deployDescribe,
26
- command,
27
- builder,
28
- } = require('../deploy');
29
-
30
- const {
31
- addAccountOptions,
32
- addConfigOptions,
33
- getAccountId,
34
- addUseEnvironmentOptions,
35
- } = require('../../../lib/commonOpts');
36
-
37
- const {
38
- deployProject,
39
- fetchProject,
40
- } = require('@hubspot/local-dev-lib/api/projects');
41
- const { loadAndValidateOptions } = require('../../../lib/validation');
42
- const {
43
- getProjectConfig,
44
- pollDeployStatus,
45
- getProjectDetailUrl,
46
- } = require('../../../lib/projects');
47
- const { projectNamePrompt } = require('../../../lib/prompts/projectNamePrompt');
48
- const {
49
- deployBuildIdPrompt,
50
- } = require('../../../lib/prompts/deployBuildIdPrompt');
51
- const { getAccountConfig } = require('@hubspot/local-dev-lib/config');
52
-
53
- const yargs = require('yargs');
54
- const { trackCommandUsage } = require('../../../lib/usageTracking');
55
- const { logger } = require('@hubspot/local-dev-lib/logger');
56
- const { EXIT_CODES } = require('../../../lib/enums/exitCodes');
57
- const { AxiosError, HttpStatusCode } = require('axios');
58
-
59
- const chalk = require('chalk');
60
- const {
61
- HubSpotHttpError,
62
- } = require('@hubspot/local-dev-lib/models/HubSpotHttpError');
63
-
64
- describe('commands/project/deploy', () => {
65
- const projectFlag = 'project';
66
- const buildFlag = 'build';
67
- const buildAliases = ['buildId'];
68
-
69
- describe('describe', () => {
70
- it('should contain the beta tag', () => {
71
- expect(deployDescribe).toContain('[BETA]');
72
- });
73
- it('should provide an accurate description of what the command is doing', () => {
74
- expect(deployDescribe).toMatch(/Deploy a project build/);
75
- });
76
- });
77
-
78
- describe('command', () => {
79
- it('should the correct command structure', () => {
80
- expect(command).toEqual('deploy');
81
- });
82
- });
83
-
84
- describe('builder', () => {
85
- it('should add the correct options', () => {
86
- builder(yargs);
87
- expect(yargs.options).toHaveBeenCalledTimes(1);
88
- expect(yargs.options).toHaveBeenCalledWith({
89
- [projectFlag]: {
90
- describe: 'Project name',
91
- type: 'string',
92
- },
93
- [buildFlag]: {
94
- alias: buildAliases,
95
- describe: 'Project build ID to be deployed',
96
- type: 'number',
97
- },
98
- });
99
- });
100
-
101
- it('should add the correct examples', () => {
102
- builder(yargs);
103
- expect(yargs.example).toHaveBeenCalledTimes(1);
104
- expect(yargs.example).toHaveBeenCalledWith([
105
- ['$0 project deploy', 'Deploy the latest build of the current project'],
106
- [
107
- `$0 project deploy --${projectFlag}="my-project" --${buildFlag}=5`,
108
- 'Deploy build 5 of the project my-project',
109
- ],
110
- ]);
111
- });
112
-
113
- it('should add the config options', () => {
114
- builder(yargs);
115
- expect(addConfigOptions).toHaveBeenCalledTimes(1);
116
- expect(addConfigOptions).toHaveBeenCalledWith(yargs);
117
- });
118
-
119
- it('should add the account options', () => {
120
- builder(yargs);
121
- expect(addAccountOptions).toHaveBeenCalledTimes(1);
122
- expect(addAccountOptions).toHaveBeenCalledWith(yargs);
123
- });
124
-
125
- it('should add the environment options', () => {
126
- builder(yargs);
127
- expect(addUseEnvironmentOptions).toHaveBeenCalledTimes(1);
128
- expect(addUseEnvironmentOptions).toHaveBeenCalledWith(yargs);
129
- });
130
-
131
- it('should the yargs object it is passed', () => {
132
- expect(builder(yargs)).toEqual(yargs);
133
- });
134
- });
135
-
136
- describe('handler', () => {
137
- let projectConfig;
138
- let processExitSpy;
139
- const accountId = 1234567890;
140
- const accountType = 'STANDARD';
141
- let options;
142
- const projectDetails = {
143
- latestBuild: { buildId: 8 },
144
- deployedBuildId: 1,
145
- };
146
- const deployDetails = {
147
- id: 123,
148
- };
149
- const projectDetailUrl = 'http://project-details-page-url.com';
150
- const viewProjectsInHubSpot = 'View project builds in HubSpot';
151
-
152
- beforeEach(() => {
153
- options = {
154
- project: 'project name from options',
155
- buildId: 2,
156
- accountId,
157
- };
158
- projectConfig = {
159
- name: 'project name from config',
160
- };
161
- getProjectConfig.mockResolvedValue({ projectConfig });
162
- projectNamePrompt.mockResolvedValue({ projectName: 'fooo' });
163
- getProjectDetailUrl.mockReturnValue(projectDetailUrl);
164
- uiLink.mockImplementation(text => {
165
- return text;
166
- });
167
- getAccountId.mockReturnValue(accountId);
168
- getAccountConfig.mockReturnValue({ accountType });
169
- fetchProject.mockResolvedValue({ data: projectDetails });
170
- deployProject.mockResolvedValue({ data: deployDetails });
171
- deployBuildIdPrompt.mockResolvedValue({
172
- buildId: projectDetails.latestBuild.buildId,
173
- });
174
-
175
- // Spy on process.exit so our tests don't close when it's called
176
- processExitSpy = jest.spyOn(process, 'exit').mockImplementation(() => {});
177
- });
178
-
179
- it('should load and validate the options', async () => {
180
- await handler(options);
181
- expect(loadAndValidateOptions).toHaveBeenCalledTimes(1);
182
- expect(loadAndValidateOptions).toHaveBeenCalledWith(options);
183
- });
184
-
185
- it('should get the account id from the options', async () => {
186
- await handler(options);
187
- expect(getAccountId).toHaveBeenCalledTimes(1);
188
- expect(getAccountId).toHaveBeenCalledWith(options);
189
- });
190
-
191
- it('should load the account config for the correct account id', async () => {
192
- await handler(options);
193
- expect(getAccountConfig).toHaveBeenCalledTimes(1);
194
- expect(getAccountConfig).toHaveBeenCalledWith(accountId);
195
- });
196
-
197
- it('should track the command usage', async () => {
198
- await handler(options);
199
- expect(trackCommandUsage).toHaveBeenCalledTimes(1);
200
- expect(trackCommandUsage).toHaveBeenCalledWith(
201
- 'project-deploy',
202
- { type: accountType },
203
- accountId
204
- );
205
- });
206
-
207
- it('should load the project config', async () => {
208
- await handler(options);
209
- expect(getProjectConfig).toHaveBeenCalledTimes(1);
210
- expect(getProjectConfig).toHaveBeenCalledWith();
211
- });
212
-
213
- it('should load the project config', async () => {
214
- await handler(options);
215
- expect(getProjectConfig).toHaveBeenCalledTimes(1);
216
- expect(getProjectConfig).toHaveBeenCalledWith();
217
- });
218
-
219
- it('should prompt for the project name', async () => {
220
- await handler(options);
221
- expect(projectNamePrompt).toHaveBeenCalledTimes(1);
222
- expect(projectNamePrompt).toHaveBeenCalledWith(accountId, {
223
- project: options.project,
224
- });
225
- });
226
-
227
- it('should use the project name from the config is a project options is not provided', async () => {
228
- delete options.project;
229
- await handler(options);
230
- expect(projectNamePrompt).toHaveBeenCalledTimes(1);
231
- expect(projectNamePrompt).toHaveBeenCalledWith(accountId, {
232
- project: projectConfig.name,
233
- });
234
- });
235
-
236
- it('should fetch the project details', async () => {
237
- await handler(options);
238
- expect(fetchProject).toHaveBeenCalledTimes(1);
239
- expect(fetchProject).toHaveBeenCalledWith(accountId, options.project);
240
- });
241
-
242
- it('should use the name from the prompt if no others are defined', async () => {
243
- delete options.project;
244
- const promptProjectName = 'project name from the prompt';
245
- projectNamePrompt.mockReturnValue({ projectName: promptProjectName });
246
- getProjectConfig.mockResolvedValue({});
247
-
248
- await handler(options);
249
-
250
- expect(projectNamePrompt).toHaveBeenCalledTimes(1);
251
- expect(projectNamePrompt).toHaveBeenCalledWith(accountId, {});
252
- expect(fetchProject).toHaveBeenCalledTimes(1);
253
- expect(fetchProject).toHaveBeenCalledWith(accountId, promptProjectName);
254
- });
255
-
256
- it('should log an error and exit when latest build is not defined', async () => {
257
- fetchProject.mockResolvedValue({ data: {} });
258
- await handler(options);
259
- expect(logger.error).toHaveBeenCalledTimes(1);
260
- expect(logger.error).toHaveBeenCalledWith(
261
- 'Deploy error: no builds for this project were found.'
262
- );
263
- expect(processExitSpy).toHaveBeenCalledTimes(1);
264
- expect(processExitSpy).toHaveBeenCalledWith(EXIT_CODES.ERROR);
265
- });
266
-
267
- it('should log an error and exit when buildId option is not a valid build', async () => {
268
- options.buildId = projectDetails.latestBuild.buildId + 1;
269
- await handler(options);
270
- expect(uiLink).toHaveBeenCalledTimes(1);
271
- expect(uiLink).toHaveBeenCalledWith(
272
- viewProjectsInHubSpot,
273
- projectDetailUrl
274
- );
275
- expect(logger.error).toHaveBeenCalledTimes(1);
276
- expect(logger.error).toHaveBeenCalledWith(
277
- `Build ${options.buildId} does not exist for project ${options.project}. ${viewProjectsInHubSpot}`
278
- );
279
- expect(processExitSpy).toHaveBeenCalledTimes(1);
280
- expect(processExitSpy).toHaveBeenCalledWith(EXIT_CODES.ERROR);
281
- });
282
-
283
- it('should log an error and exit when buildId option is already deployed', async () => {
284
- options.buildId = projectDetails.deployedBuildId;
285
- await handler(options);
286
- expect(uiLink).toHaveBeenCalledTimes(1);
287
- expect(uiLink).toHaveBeenCalledWith(
288
- viewProjectsInHubSpot,
289
- projectDetailUrl
290
- );
291
- expect(logger.error).toHaveBeenCalledTimes(1);
292
- expect(logger.error).toHaveBeenCalledWith(
293
- `Build ${options.buildId} is already deployed. ${viewProjectsInHubSpot}`
294
- );
295
- expect(processExitSpy).toHaveBeenCalledTimes(1);
296
- expect(processExitSpy).toHaveBeenCalledWith(EXIT_CODES.ERROR);
297
- });
298
-
299
- it('should prompt for build id if no option is provided', async () => {
300
- delete options.buildId;
301
- await handler(options);
302
- expect(deployBuildIdPrompt).toHaveBeenCalledTimes(1);
303
- expect(deployBuildIdPrompt).toHaveBeenCalledWith(
304
- projectDetails.latestBuild.buildId,
305
- projectDetails.deployedBuildId,
306
- expect.any(Function)
307
- );
308
- });
309
-
310
- it('should log an error and exit if the prompted value is invalid', async () => {
311
- delete options.buildId;
312
- deployBuildIdPrompt.mockReturnValue({});
313
-
314
- await handler(options);
315
-
316
- expect(deployBuildIdPrompt).toHaveBeenCalledTimes(1);
317
- expect(logger.error).toHaveBeenCalledTimes(1);
318
- expect(logger.error).toHaveBeenCalledWith(
319
- 'You must specify a build to deploy'
320
- );
321
- expect(processExitSpy).toHaveBeenCalledTimes(1);
322
- expect(processExitSpy).toHaveBeenCalledWith(EXIT_CODES.ERROR);
323
- });
324
-
325
- it('should deploy the project', async () => {
326
- await handler(options);
327
- expect(deployProject).toHaveBeenCalledTimes(1);
328
- expect(deployProject).toHaveBeenCalledWith(
329
- accountId,
330
- options.project,
331
- options.buildId
332
- );
333
- });
334
-
335
- it('should log an error and exit when the deploy fails', async () => {
336
- const errorMessage = `Just wasn't feeling it`;
337
- deployProject.mockResolvedValue({
338
- data: {
339
- error: { message: errorMessage },
340
- },
341
- });
342
-
343
- await handler(options);
344
- expect(logger.error).toHaveBeenCalledTimes(1);
345
- expect(logger.error).toHaveBeenCalledWith(
346
- `Deploy error: ${errorMessage}`
347
- );
348
- expect(processExitSpy).toHaveBeenCalledTimes(1);
349
- expect(processExitSpy).toHaveBeenCalledWith(EXIT_CODES.ERROR);
350
- });
351
-
352
- it('should poll the deploy status', async () => {
353
- await handler(options);
354
- expect(pollDeployStatus).toHaveBeenCalledTimes(1);
355
- expect(pollDeployStatus).toHaveBeenCalledWith(
356
- accountId,
357
- options.project,
358
- deployDetails.id,
359
- options.buildId
360
- );
361
- });
362
-
363
- it('log an error and exit if a 404 status is returned', async () => {
364
- const commandReference = 'hs project upload';
365
- const accountDescription = 'SuperCoolTestAccount';
366
- uiCommandReference.mockReturnValue(commandReference);
367
- uiAccountDescription.mockReturnValue(accountDescription);
368
- fetchProject.mockImplementation(() => {
369
- throw new HubSpotHttpError('OH NO', {
370
- cause: new AxiosError(
371
- 'OH NO',
372
- '',
373
- {},
374
- {},
375
- { status: HttpStatusCode.NotFound }
376
- ),
377
- });
378
- });
379
- await handler(options);
380
-
381
- expect(logger.error).toHaveBeenCalledTimes(1);
382
- expect(logger.error).toHaveBeenCalledWith(
383
- `The project ${chalk.bold(
384
- options.project
385
- )} does not exist in account ${accountDescription}. Run ${commandReference} to upload your project files to HubSpot.`
386
- );
387
- expect(processExitSpy).toHaveBeenCalledTimes(1);
388
- expect(processExitSpy).toHaveBeenCalledWith(EXIT_CODES.ERROR);
389
- });
390
-
391
- it('log an error and exit if a 400 status is returned', async () => {
392
- const commandReference = 'hs project upload';
393
- const accountDescription = 'SuperCoolTestAccount';
394
- uiCommandReference.mockReturnValue(commandReference);
395
- uiAccountDescription.mockReturnValue(accountDescription);
396
- const errorMessage = 'Something bad happened';
397
- fetchProject.mockImplementation(() => {
398
- throw new HubSpotHttpError(errorMessage, {
399
- cause: new AxiosError(
400
- errorMessage,
401
- '',
402
- {},
403
- {},
404
- { status: HttpStatusCode.BadRequest }
405
- ),
406
- });
407
- });
408
- await handler(options);
409
-
410
- expect(logger.error).toHaveBeenCalledTimes(1);
411
- expect(logger.error).toHaveBeenCalledWith('The request was bad.');
412
- expect(processExitSpy).toHaveBeenCalledTimes(1);
413
- expect(processExitSpy).toHaveBeenCalledWith(EXIT_CODES.ERROR);
414
- });
415
-
416
- it('log an error another unexpected status code is returned', async () => {
417
- const commandReference = 'hs project upload';
418
- const accountDescription = 'SuperCoolTestAccount';
419
- uiCommandReference.mockReturnValue(commandReference);
420
- uiAccountDescription.mockReturnValue(accountDescription);
421
- const errorMessage = 'Something bad happened';
422
- fetchProject.mockImplementation(() => {
423
- throw new HubSpotHttpError('OH NO', {
424
- cause: new AxiosError(
425
- errorMessage,
426
- '',
427
- {},
428
- {},
429
- { status: HttpStatusCode.MethodNotAllowed }
430
- ),
431
- });
432
- });
433
- await handler(options);
434
-
435
- expect(logger.error).toHaveBeenCalledTimes(1);
436
- expect(logger.error).toHaveBeenCalledWith(
437
- `The request for 'project deploy' in account ${accountId} failed due to a client error.`
438
- );
439
- expect(processExitSpy).toHaveBeenCalledTimes(1);
440
- expect(processExitSpy).toHaveBeenCalledWith(EXIT_CODES.ERROR);
441
- });
442
- });
443
- });