@hubspot/cli 6.2.0 → 6.2.2-experimental.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 (347) hide show
  1. package/bin/cli.d.ts +2 -0
  2. package/bin/cli.js +107 -128
  3. package/commands/accounts/clean.d.ts +4 -0
  4. package/commands/accounts/clean.js +80 -116
  5. package/commands/accounts/info.d.ts +4 -0
  6. package/commands/accounts/info.js +30 -43
  7. package/commands/accounts/list.d.ts +4 -0
  8. package/commands/accounts/list.js +63 -92
  9. package/commands/accounts/remove.d.ts +4 -0
  10. package/commands/accounts/remove.js +41 -73
  11. package/commands/accounts/rename.d.ts +4 -0
  12. package/commands/accounts/rename.js +24 -41
  13. package/commands/accounts/use.d.ts +4 -0
  14. package/commands/accounts/use.js +34 -57
  15. package/commands/accounts.d.ts +3 -0
  16. package/commands/accounts.js +14 -18
  17. package/commands/auth.d.ts +4 -0
  18. package/commands/auth.js +131 -200
  19. package/commands/cms/convertFields.d.ts +4 -0
  20. package/commands/cms/convertFields.js +64 -81
  21. package/commands/cms/lighthouseScore.d.ts +4 -0
  22. package/commands/cms/lighthouseScore.js +234 -298
  23. package/commands/cms/reactModules.d.ts +4 -0
  24. package/commands/cms/reactModules.js +44 -53
  25. package/commands/cms.d.ts +3 -0
  26. package/commands/cms.js +9 -13
  27. package/commands/config/set/allowUsageTracking.d.ts +4 -0
  28. package/commands/config/set/allowUsageTracking.js +31 -38
  29. package/commands/config/set/defaultMode.d.ts +4 -0
  30. package/commands/config/set/defaultMode.js +32 -43
  31. package/commands/config/set/httpTimeout.d.ts +4 -0
  32. package/commands/config/set/httpTimeout.js +21 -30
  33. package/commands/config/set.d.ts +4 -0
  34. package/commands/config/set.js +61 -76
  35. package/commands/config.d.ts +3 -0
  36. package/commands/config.js +5 -9
  37. package/commands/create/api-sample.d.ts +13 -0
  38. package/commands/create/api-sample.js +52 -74
  39. package/commands/create/app.d.ts +10 -0
  40. package/commands/create/app.js +6 -7
  41. package/commands/create/function.d.ts +6 -0
  42. package/commands/create/function.js +13 -14
  43. package/commands/create/index.d.ts +109 -0
  44. package/commands/create/index.js +10 -9
  45. package/commands/create/module.d.ts +11 -0
  46. package/commands/create/module.js +19 -19
  47. package/commands/create/react-app.d.ts +9 -0
  48. package/commands/create/react-app.js +5 -6
  49. package/commands/create/template.d.ts +12 -0
  50. package/commands/create/template.js +21 -24
  51. package/commands/create/vue-app.d.ts +9 -0
  52. package/commands/create/vue-app.js +5 -6
  53. package/commands/create/webpack-serverless.d.ts +9 -0
  54. package/commands/create/webpack-serverless.js +5 -6
  55. package/commands/create/website-theme.d.ts +9 -0
  56. package/commands/create/website-theme.js +13 -15
  57. package/commands/create.d.ts +4 -0
  58. package/commands/create.js +62 -80
  59. package/commands/customObject/create.d.ts +4 -0
  60. package/commands/customObject/create.js +31 -47
  61. package/commands/customObject/schema/create.d.ts +4 -0
  62. package/commands/customObject/schema/create.js +40 -67
  63. package/commands/customObject/schema/delete.d.ts +4 -0
  64. package/commands/customObject/schema/delete.js +26 -39
  65. package/commands/customObject/schema/fetch-all.d.ts +4 -0
  66. package/commands/customObject/schema/fetch-all.js +28 -39
  67. package/commands/customObject/schema/fetch.d.ts +4 -0
  68. package/commands/customObject/schema/fetch.js +46 -63
  69. package/commands/customObject/schema/list.d.ts +3 -0
  70. package/commands/customObject/schema/list.js +12 -17
  71. package/commands/customObject/schema/update.d.ts +4 -0
  72. package/commands/customObject/schema/update.js +44 -72
  73. package/commands/customObject/schema.d.ts +3 -0
  74. package/commands/customObject/schema.js +10 -12
  75. package/commands/customObject.d.ts +3 -0
  76. package/commands/customObject.js +12 -22
  77. package/commands/feedback.d.ts +4 -0
  78. package/commands/feedback.js +23 -33
  79. package/commands/fetch.d.ts +4 -0
  80. package/commands/fetch.js +51 -78
  81. package/commands/filemanager/fetch.d.ts +4 -0
  82. package/commands/filemanager/fetch.js +36 -56
  83. package/commands/filemanager/upload.d.ts +4 -0
  84. package/commands/filemanager/upload.js +86 -128
  85. package/commands/filemanager.d.ts +3 -0
  86. package/commands/filemanager.js +10 -18
  87. package/commands/functions/deploy.d.ts +4 -0
  88. package/commands/functions/deploy.js +74 -99
  89. package/commands/functions/list.d.ts +4 -0
  90. package/commands/functions/list.js +29 -47
  91. package/commands/functions/server.d.ts +4 -0
  92. package/commands/functions/server.js +48 -65
  93. package/commands/functions.d.ts +3 -0
  94. package/commands/functions.js +11 -15
  95. package/commands/hubdb/clear.d.ts +4 -0
  96. package/commands/hubdb/clear.js +35 -56
  97. package/commands/hubdb/create.d.ts +4 -0
  98. package/commands/hubdb/create.js +32 -57
  99. package/commands/hubdb/delete.d.ts +4 -0
  100. package/commands/hubdb/delete.js +27 -44
  101. package/commands/hubdb/fetch.d.ts +4 -0
  102. package/commands/hubdb/fetch.js +28 -46
  103. package/commands/hubdb.d.ts +3 -0
  104. package/commands/hubdb.js +10 -14
  105. package/commands/init.d.ts +4 -0
  106. package/commands/init.js +101 -160
  107. package/commands/lint.d.ts +4 -0
  108. package/commands/lint.js +32 -45
  109. package/commands/list.d.ts +4 -0
  110. package/commands/list.js +72 -101
  111. package/commands/logs.d.ts +4 -0
  112. package/commands/logs.js +96 -121
  113. package/commands/module/marketplace-validate.d.ts +4 -0
  114. package/commands/module/marketplace-validate.js +30 -57
  115. package/commands/module.d.ts +3 -0
  116. package/commands/module.js +5 -9
  117. package/commands/mv.d.ts +4 -0
  118. package/commands/mv.js +51 -71
  119. package/commands/open.d.ts +4 -0
  120. package/commands/open.js +46 -62
  121. package/commands/project/add.d.ts +4 -0
  122. package/commands/project/add.js +45 -70
  123. package/commands/project/cloneApp.d.ts +4 -0
  124. package/commands/project/cloneApp.js +117 -180
  125. package/commands/project/create.d.ts +4 -0
  126. package/commands/project/create.js +47 -81
  127. package/commands/project/deploy.d.ts +4 -0
  128. package/commands/project/deploy.js +103 -182
  129. package/commands/project/dev.d.ts +4 -0
  130. package/commands/project/dev.js +123 -227
  131. package/commands/project/download.d.ts +4 -0
  132. package/commands/project/download.js +71 -123
  133. package/commands/project/installDeps.d.ts +6 -0
  134. package/commands/project/installDeps.js +50 -59
  135. package/commands/project/listBuilds.d.ts +4 -0
  136. package/commands/project/listBuilds.js +95 -139
  137. package/commands/project/logs.d.ts +4 -0
  138. package/commands/project/logs.js +84 -128
  139. package/commands/project/migrateApp.d.ts +4 -0
  140. package/commands/project/migrateApp.js +156 -248
  141. package/commands/project/open.d.ts +4 -0
  142. package/commands/project/open.js +42 -68
  143. package/commands/project/upload.d.ts +4 -0
  144. package/commands/project/upload.js +70 -116
  145. package/commands/project/watch.d.ts +4 -0
  146. package/commands/project/watch.js +92 -152
  147. package/commands/project.d.ts +3 -0
  148. package/commands/project.js +19 -23
  149. package/commands/remove.d.ts +4 -0
  150. package/commands/remove.js +26 -43
  151. package/commands/sandbox/create.d.ts +4 -0
  152. package/commands/sandbox/create.js +141 -187
  153. package/commands/sandbox/delete.d.ts +4 -0
  154. package/commands/sandbox/delete.js +164 -221
  155. package/commands/sandbox.d.ts +3 -0
  156. package/commands/sandbox.js +8 -12
  157. package/commands/secrets/addSecret.d.ts +4 -0
  158. package/commands/secrets/addSecret.js +32 -52
  159. package/commands/secrets/deleteSecret.d.ts +4 -0
  160. package/commands/secrets/deleteSecret.js +31 -50
  161. package/commands/secrets/listSecrets.d.ts +4 -0
  162. package/commands/secrets/listSecrets.js +26 -42
  163. package/commands/secrets/updateSecret.d.ts +4 -0
  164. package/commands/secrets/updateSecret.js +33 -53
  165. package/commands/secrets.d.ts +3 -0
  166. package/commands/secrets.js +10 -13
  167. package/commands/theme/generate-selectors.d.ts +4 -0
  168. package/commands/theme/generate-selectors.js +127 -192
  169. package/commands/theme/marketplace-validate.d.ts +4 -0
  170. package/commands/theme/marketplace-validate.js +30 -57
  171. package/commands/theme/preview.d.ts +4 -0
  172. package/commands/theme/preview.js +161 -196
  173. package/commands/theme.d.ts +3 -0
  174. package/commands/theme.js +7 -11
  175. package/commands/upload.d.ts +4 -0
  176. package/commands/upload.js +197 -287
  177. package/commands/watch.d.ts +4 -0
  178. package/commands/watch.js +126 -172
  179. package/lang/en.lyaml +2 -3
  180. package/lib/DevServerManager.d.ts +35 -0
  181. package/lib/DevServerManager.js +97 -124
  182. package/lib/LocalDevManager.d.ts +41 -0
  183. package/lib/LocalDevManager.js +320 -490
  184. package/lib/accountTypes.d.ts +6 -0
  185. package/lib/accountTypes.js +16 -32
  186. package/lib/buildAccount.d.ts +22 -0
  187. package/lib/buildAccount.js +130 -179
  188. package/lib/commonOpts.d.ts +20 -0
  189. package/lib/commonOpts.js +58 -91
  190. package/lib/constants.d.ts +83 -0
  191. package/lib/constants.js +61 -71
  192. package/lib/debugInfo.d.ts +3 -0
  193. package/lib/debugInfo.js +12 -13
  194. package/lib/dependencyManagement.d.ts +7 -0
  195. package/lib/dependencyManagement.js +90 -132
  196. package/lib/developerTestAccounts.d.ts +7 -0
  197. package/lib/developerTestAccounts.js +65 -91
  198. package/lib/enums/exitCodes.d.ts +5 -0
  199. package/lib/enums/exitCodes.js +5 -7
  200. package/lib/environment.d.ts +1 -0
  201. package/lib/environment.js +10 -10
  202. package/lib/errorHandlers/index.d.ts +19 -0
  203. package/lib/errorHandlers/index.js +64 -80
  204. package/lib/errorHandlers/suppressError.d.ts +1 -0
  205. package/lib/errorHandlers/suppressError.js +64 -106
  206. package/lib/filesystem.d.ts +2 -0
  207. package/lib/filesystem.js +16 -24
  208. package/lib/generate-selectors.d.ts +6 -0
  209. package/lib/generate-selectors.js +99 -137
  210. package/lib/getFunctionArrays.d.ts +1 -0
  211. package/lib/getFunctionArrays.js +12 -13
  212. package/lib/hasFeature.d.ts +1 -0
  213. package/lib/hasFeature.js +5 -11
  214. package/lib/hasFlag.d.ts +2 -0
  215. package/lib/hasFlag.js +6 -10
  216. package/lib/hublValidate.d.ts +4 -0
  217. package/lib/hublValidate.js +20 -24
  218. package/lib/interpolation.d.ts +10 -0
  219. package/lib/interpolation.js +48 -92
  220. package/lib/interpolationHelpers.d.ts +6 -0
  221. package/lib/interpolationHelpers.js +19 -19
  222. package/lib/lang.d.ts +3 -0
  223. package/lib/lang.js +50 -78
  224. package/lib/links.d.ts +127 -0
  225. package/lib/links.js +92 -114
  226. package/lib/localDev.d.ts +11 -0
  227. package/lib/localDev.js +283 -433
  228. package/lib/marketplace-validate.d.ts +5 -0
  229. package/lib/marketplace-validate.js +103 -126
  230. package/lib/oauth.d.ts +1 -0
  231. package/lib/oauth.js +62 -78
  232. package/lib/polling.d.ts +1 -0
  233. package/lib/polling.js +24 -26
  234. package/lib/process.d.ts +2 -0
  235. package/lib/process.js +39 -53
  236. package/lib/projectLogsManager.d.ts +19 -0
  237. package/lib/projectLogsManager.js +76 -130
  238. package/lib/projectStructure.d.ts +13 -0
  239. package/lib/projectStructure.js +87 -109
  240. package/lib/projects.d.ts +40 -0
  241. package/lib/projects.js +589 -957
  242. package/lib/projectsWatch.d.ts +1 -0
  243. package/lib/projectsWatch.js +122 -228
  244. package/lib/prompts/accountNamePrompt.d.ts +11 -0
  245. package/lib/prompts/accountNamePrompt.js +58 -65
  246. package/lib/prompts/accountsPrompt.d.ts +3 -0
  247. package/lib/prompts/accountsPrompt.js +31 -37
  248. package/lib/prompts/activeInstallConfirmationPrompt.d.ts +1 -0
  249. package/lib/prompts/activeInstallConfirmationPrompt.js +11 -13
  250. package/lib/prompts/cleanUploadPrompt.d.ts +1 -0
  251. package/lib/prompts/cleanUploadPrompt.js +11 -13
  252. package/lib/prompts/cmsFieldPrompt.d.ts +1 -0
  253. package/lib/prompts/cmsFieldPrompt.js +35 -39
  254. package/lib/prompts/createApiSamplePrompt.d.ts +1 -0
  255. package/lib/prompts/createApiSamplePrompt.js +47 -52
  256. package/lib/prompts/createFunctionPrompt.d.ts +1 -0
  257. package/lib/prompts/createFunctionPrompt.js +55 -56
  258. package/lib/prompts/createModulePrompt.d.ts +1 -0
  259. package/lib/prompts/createModulePrompt.js +45 -50
  260. package/lib/prompts/createProjectPrompt.d.ts +1 -0
  261. package/lib/prompts/createProjectPrompt.js +88 -127
  262. package/lib/prompts/createTemplatePrompt.d.ts +1 -0
  263. package/lib/prompts/createTemplatePrompt.js +16 -19
  264. package/lib/prompts/deployBuildIdPrompt.d.ts +1 -0
  265. package/lib/prompts/deployBuildIdPrompt.js +13 -15
  266. package/lib/prompts/downloadProjectPrompt.d.ts +1 -0
  267. package/lib/prompts/downloadProjectPrompt.js +36 -40
  268. package/lib/prompts/feedbackPrompt.d.ts +2 -0
  269. package/lib/prompts/feedbackPrompt.js +27 -30
  270. package/lib/prompts/folderOverwritePrompt.d.ts +1 -0
  271. package/lib/prompts/folderOverwritePrompt.js +8 -10
  272. package/lib/prompts/installPublicAppPrompt.d.ts +1 -0
  273. package/lib/prompts/installPublicAppPrompt.js +27 -42
  274. package/lib/prompts/personalAccessKeyPrompt.d.ts +69 -0
  275. package/lib/prompts/personalAccessKeyPrompt.js +102 -110
  276. package/lib/prompts/previewPrompt.d.ts +2 -0
  277. package/lib/prompts/previewPrompt.js +44 -47
  278. package/lib/prompts/projectAddPrompt.d.ts +1 -0
  279. package/lib/prompts/projectAddPrompt.js +35 -38
  280. package/lib/prompts/projectDevTargetAccountPrompt.d.ts +4 -0
  281. package/lib/prompts/projectDevTargetAccountPrompt.js +148 -193
  282. package/lib/prompts/projectNamePrompt.d.ts +1 -0
  283. package/lib/prompts/projectNamePrompt.js +23 -25
  284. package/lib/prompts/projectsLogsPrompt.d.ts +5 -0
  285. package/lib/prompts/projectsLogsPrompt.js +19 -27
  286. package/lib/prompts/promptUtils.d.ts +2 -0
  287. package/lib/prompts/promptUtils.js +15 -17
  288. package/lib/prompts/sandboxesPrompt.d.ts +2 -0
  289. package/lib/prompts/sandboxesPrompt.js +48 -59
  290. package/lib/prompts/secretPrompt.d.ts +1 -0
  291. package/lib/prompts/secretPrompt.js +13 -16
  292. package/lib/prompts/selectPublicAppPrompt.d.ts +5 -0
  293. package/lib/prompts/selectPublicAppPrompt.js +55 -81
  294. package/lib/prompts/setAsDefaultAccountPrompt.d.ts +1 -0
  295. package/lib/prompts/setAsDefaultAccountPrompt.js +17 -24
  296. package/lib/prompts/uploadPrompt.d.ts +1 -0
  297. package/lib/prompts/uploadPrompt.js +28 -30
  298. package/lib/regex.d.ts +1 -0
  299. package/lib/regex.js +2 -2
  300. package/lib/sandboxSync.d.ts +8 -0
  301. package/lib/sandboxSync.js +98 -166
  302. package/lib/sandboxes.d.ts +40 -0
  303. package/lib/sandboxes.js +199 -316
  304. package/lib/schema.d.ts +2 -0
  305. package/lib/schema.js +20 -26
  306. package/lib/serverlessLogs.d.ts +8 -0
  307. package/lib/serverlessLogs.js +128 -172
  308. package/lib/ui/SpinniesManager.d.ts +61 -0
  309. package/lib/ui/SpinniesManager.js +196 -254
  310. package/lib/ui/git.d.ts +1 -0
  311. package/lib/ui/git.js +18 -19
  312. package/lib/ui/index.d.ts +36 -0
  313. package/lib/ui/index.js +115 -167
  314. package/lib/ui/serverlessFunctionLogs.d.ts +1 -0
  315. package/lib/ui/serverlessFunctionLogs.js +51 -70
  316. package/lib/ui/spinniesUtils.d.ts +60 -0
  317. package/lib/ui/spinniesUtils.js +109 -133
  318. package/lib/ui/supportHyperlinks.d.ts +3 -0
  319. package/lib/ui/supportHyperlinks.js +46 -61
  320. package/lib/ui/supportsColor.d.ts +13 -0
  321. package/lib/ui/supportsColor.js +78 -108
  322. package/lib/ui/table.d.ts +2 -0
  323. package/lib/ui/table.js +47 -55
  324. package/lib/upload.d.ts +1 -0
  325. package/lib/upload.js +37 -42
  326. package/lib/usageTracking.d.ts +6 -0
  327. package/lib/usageTracking.js +131 -155
  328. package/lib/validation.d.ts +16 -0
  329. package/lib/validation.js +142 -203
  330. package/package.json +78 -48
  331. package/CHANGELOG.md +0 -16
  332. package/LICENSE +0 -12
  333. package/README.md +0 -154
  334. package/commands/__tests__/projects.test.js +0 -105
  335. package/commands/project/__tests__/deploy.test.js +0 -443
  336. package/commands/project/__tests__/installDeps.test.js +0 -168
  337. package/commands/project/__tests__/logs.test.js +0 -304
  338. package/hubspot.sample.config.yml +0 -28
  339. package/jest.config.js +0 -4
  340. package/lib/__tests__/commonOpts.test.js +0 -83
  341. package/lib/__tests__/dependencyManagement.test.js +0 -243
  342. package/lib/__tests__/downloadProjectPrompt.test.js +0 -31
  343. package/lib/__tests__/projectLogsManager.test.js +0 -212
  344. package/lib/__tests__/projects.test.js +0 -140
  345. package/lib/__tests__/serverlessLogs.test.js +0 -162
  346. package/lib/__tests__/validation.test.js +0 -140
  347. package/lib/prompts/__tests__/projectsLogsPrompt.test.js +0 -46
@@ -1,168 +0,0 @@
1
- jest.mock('../../../lib/projects');
2
- jest.mock('@hubspot/local-dev-lib/logger');
3
- jest.mock('../../../lib/dependencyManagement');
4
- jest.mock('../../../lib/prompts/promptUtils');
5
- jest.mock('../../../lib/usageTracking');
6
- jest.mock('../../../lib/commonOpts');
7
-
8
- const { getProjectConfig } = require('../../../lib/projects');
9
- const { EXIT_CODES } = require('../../../lib/enums/exitCodes');
10
- const { logger } = require('@hubspot/local-dev-lib/logger');
11
- const { trackCommandUsage } = require('../../../lib/usageTracking');
12
- const { getAccountId } = require('../../../lib/commonOpts');
13
- const {
14
- installPackages,
15
- getProjectPackageJsonLocations,
16
- } = require('../../../lib/dependencyManagement');
17
- const { promptUser } = require('../../../lib/prompts/promptUtils');
18
- const {
19
- command,
20
- describe: installDepsDescribe,
21
- builder,
22
- handler,
23
- } = require('../installDeps');
24
- const path = require('path');
25
-
26
- describe('commands/project/installDeps', () => {
27
- describe('command', () => {
28
- it('should have the correct command string', () => {
29
- expect(command).toEqual('install-deps [packages..]');
30
- });
31
- });
32
-
33
- describe('describe', () => {
34
- it('should have the correct description', () => {
35
- expect(installDepsDescribe).toEqual(null);
36
- });
37
- });
38
-
39
- describe('builder', () => {
40
- let yargs;
41
- beforeEach(() => {
42
- yargs = {
43
- example: jest.fn().mockImplementation(() => yargs),
44
- };
45
- });
46
-
47
- it('should add correct examples', () => {
48
- builder(yargs);
49
- expect(yargs.example).toHaveBeenCalledTimes(1);
50
- expect(yargs.example).toHaveBeenCalledWith([
51
- ['$0 project install-deps', 'Install the dependencies for the project'],
52
- [
53
- '$0 project install-deps dependency1 dependency2',
54
- 'Install the dependencies to one or more project subcomponents',
55
- ],
56
- ]);
57
- });
58
- });
59
-
60
- describe('handler', () => {
61
- let processExitSpy;
62
-
63
- beforeEach(() => {
64
- processExitSpy = jest.spyOn(process, 'exit').mockImplementation(() => {});
65
- });
66
-
67
- it('should track the command usage', async () => {
68
- const accountId = 999999;
69
- getAccountId.mockReturnValue(accountId);
70
- await handler({});
71
-
72
- expect(getAccountId).toHaveBeenCalledTimes(1);
73
- expect(trackCommandUsage).toHaveBeenCalledTimes(1);
74
- expect(trackCommandUsage).toHaveBeenCalledWith(
75
- 'project-install-deps',
76
- null,
77
- accountId
78
- );
79
- });
80
-
81
- it('should handle exceptions', async () => {
82
- const error = new Error('Something went super wrong');
83
-
84
- getProjectConfig.mockImplementationOnce(() => {
85
- throw error;
86
- });
87
-
88
- await handler({});
89
-
90
- expect(logger.debug).toHaveBeenCalledTimes(1);
91
- expect(logger.debug).toHaveBeenCalledWith(error);
92
-
93
- expect(logger.error).toHaveBeenCalledTimes(1);
94
- expect(logger.error).toHaveBeenCalledWith(error.message);
95
-
96
- expect(processExitSpy).toHaveBeenCalledTimes(1);
97
- expect(processExitSpy).toHaveBeenCalledWith(EXIT_CODES.ERROR);
98
- });
99
-
100
- it('should log an error and exit when the project config is not defined', async () => {
101
- getProjectConfig.mockResolvedValueOnce(null);
102
- await handler({});
103
-
104
- expect(logger.error).toHaveBeenCalledTimes(1);
105
- expect(logger.error).toHaveBeenCalledWith(
106
- 'No project detected. Run this command from a project directory.'
107
- );
108
- expect(processExitSpy).toHaveBeenCalledTimes(1);
109
- expect(processExitSpy).toHaveBeenCalledWith(EXIT_CODES.ERROR);
110
- });
111
-
112
- it('should log an error and exit when the project config has no projectDir', async () => {
113
- getProjectConfig.mockResolvedValueOnce({ projectDir: null });
114
- await handler({});
115
-
116
- expect(logger.error).toHaveBeenCalledTimes(1);
117
- expect(logger.error).toHaveBeenCalledWith(
118
- 'No project detected. Run this command from a project directory.'
119
- );
120
- expect(processExitSpy).toHaveBeenCalledTimes(1);
121
- expect(processExitSpy).toHaveBeenCalledWith(EXIT_CODES.ERROR);
122
- });
123
-
124
- it('should prompt for input when packages is defined', async () => {
125
- const projectDir = 'src';
126
- getProjectConfig.mockResolvedValue({ projectDir });
127
- const packageJsonLocation = path.join(projectDir, 'directory1');
128
- promptUser.mockResolvedValueOnce(packageJsonLocation);
129
- getProjectPackageJsonLocations.mockResolvedValue([packageJsonLocation]);
130
- await handler({ packages: ['@hubspot/local-dev-lib'] });
131
- expect(getProjectPackageJsonLocations).toHaveBeenCalledTimes(1);
132
- expect(promptUser).toHaveBeenCalledTimes(1);
133
- expect(promptUser).toHaveBeenCalledWith([
134
- {
135
- name: 'selectedInstallLocations',
136
- type: 'checkbox',
137
- when: expect.any(Function),
138
- choices: [
139
- {
140
- name: 'directory1',
141
- value: packageJsonLocation,
142
- },
143
- ],
144
- message: 'Choose the project components to install the dependencies:',
145
- validate: expect.any(Function),
146
- },
147
- ]);
148
- });
149
-
150
- it('should call installPackages correctly', async () => {
151
- const projectDir = 'src';
152
- const packageJsonLocation = path.join(projectDir, 'directory1');
153
- const installLocations = [packageJsonLocation];
154
- const packages = ['@hubspot/local-dev-lib'];
155
-
156
- getProjectConfig.mockResolvedValue({ projectDir });
157
- promptUser.mockResolvedValueOnce(packageJsonLocation);
158
- getProjectPackageJsonLocations.mockResolvedValue(installLocations);
159
- await handler({ packages });
160
-
161
- expect(installPackages).toHaveBeenCalledTimes(1);
162
- expect(installPackages).toHaveBeenCalledWith({
163
- packages,
164
- installLocations,
165
- });
166
- });
167
- });
168
- });
@@ -1,304 +0,0 @@
1
- jest.mock('../../../lib/commonOpts');
2
- jest.mock('../../../lib/usageTracking');
3
- jest.mock('../../../lib/validation');
4
- jest.mock('../../../lib/projectLogsManager');
5
- jest.mock('../../../lib/prompts/projectsLogsPrompt');
6
- jest.mock('@hubspot/local-dev-lib/logger');
7
- jest.mock('../../../lib/ui/table');
8
- jest.mock('../../../lib/ui');
9
- jest.mock('../../../lib/errorHandlers');
10
-
11
- // Deps where we don't want mocks
12
- const libUi = jest.requireActual('../../../lib/ui');
13
-
14
- const { uiLine, uiLink, uiBetaTag } = require('../../../lib/ui');
15
-
16
- uiBetaTag.mockImplementation(libUi.uiBetaTag);
17
-
18
- const {
19
- addUseEnvironmentOptions,
20
- getAccountId,
21
- } = require('../../../lib/commonOpts');
22
- const ProjectLogsManager = require('../../../lib/projectLogsManager');
23
- const {
24
- projectLogsPrompt,
25
- } = require('../../../lib/prompts/projectsLogsPrompt');
26
- const { getTableContents, getTableHeader } = require('../../../lib/ui/table');
27
-
28
- const { trackCommandUsage } = require('../../../lib/usageTracking');
29
-
30
- const {
31
- handler,
32
- describe: logsDescribe,
33
- command,
34
- builder,
35
- } = require('../logs');
36
- const { EXIT_CODES } = require('../../../lib/enums/exitCodes');
37
- const { logError } = require('../../../lib/errorHandlers');
38
-
39
- describe('commands/project/logs', () => {
40
- let processExitSpy;
41
- beforeEach(() => {
42
- processExitSpy = jest.spyOn(process, 'exit').mockImplementation(() => {});
43
- });
44
-
45
- describe('command', () => {
46
- it('should have the proper command string', async () => {
47
- expect(command).toEqual('logs');
48
- });
49
- });
50
-
51
- describe('describe', () => {
52
- it('should contain the beta tag', () => {
53
- expect(logsDescribe).toContain('[BETA]');
54
- });
55
- it('should provide an accurate description of what the command is doing', () => {
56
- expect(logsDescribe).toMatch(
57
- /Get execution logs for a serverless function within a project/
58
- );
59
- });
60
- });
61
-
62
- describe('builder', () => {
63
- let yargsMock = {};
64
- beforeEach(() => {
65
- yargsMock = {
66
- options: jest.fn().mockImplementation(() => yargsMock),
67
- conflicts: jest.fn().mockImplementation(() => yargsMock),
68
- example: jest.fn().mockImplementation(() => yargsMock),
69
- };
70
- });
71
-
72
- it('should add all of the options', () => {
73
- builder(yargsMock);
74
- expect(yargsMock.options).toHaveBeenCalledTimes(1);
75
- expect(yargsMock.options).toHaveBeenCalledWith({
76
- function: {
77
- alias: 'function',
78
- requiresArg: true,
79
- describe: 'App function name',
80
- type: 'string',
81
- },
82
- latest: {
83
- alias: 'l',
84
- type: 'boolean',
85
- describe: 'Retrieve most recent log only',
86
- },
87
- compact: {
88
- type: 'boolean',
89
- describe: 'Output compact logs',
90
- },
91
- tail: {
92
- alias: ['t', 'follow'],
93
- describe: 'Tail logs',
94
- type: 'boolean',
95
- },
96
- limit: {
97
- type: 'number',
98
- describe: 'Limit the number of logs to output',
99
- },
100
- });
101
- });
102
-
103
- it('should add the environment options', () => {
104
- builder(yargsMock);
105
- expect(addUseEnvironmentOptions).toHaveBeenCalledTimes(1);
106
- expect(addUseEnvironmentOptions).toHaveBeenCalledWith(yargsMock);
107
- });
108
-
109
- it('should set tail and limit as conflicting arguments', () => {
110
- builder(yargsMock);
111
- expect(yargsMock.conflicts).toHaveBeenCalledTimes(1);
112
- expect(yargsMock.conflicts).toHaveBeenCalledWith('tail', 'limit');
113
- });
114
-
115
- it('should set examples', () => {
116
- builder(yargsMock);
117
- expect(yargsMock.example).toHaveBeenCalledTimes(1);
118
- expect(yargsMock.example).toHaveBeenCalledWith([
119
- [
120
- '$0 project logs',
121
- 'Open the project logs prompt to get logs for a serverless function',
122
- ],
123
- [
124
- '$0 project logs --function=my-function',
125
- 'Get logs for function named "my-function" within the app named "app" within the project named "my-project"',
126
- ],
127
- ]);
128
- });
129
- });
130
-
131
- describe('handler', () => {
132
- const accountId = 12345678;
133
-
134
- beforeEach(() => {
135
- getAccountId.mockReturnValue(accountId);
136
- projectLogsPrompt.mockResolvedValue({ functionName: 'foo' });
137
- });
138
-
139
- it('should get the account id', async () => {
140
- const options = {
141
- foo: 'bar',
142
- };
143
- await handler(options);
144
- expect(getAccountId).toHaveBeenCalledTimes(1);
145
- expect(getAccountId).toHaveBeenCalledWith(options);
146
- });
147
-
148
- it('should track the command usage', async () => {
149
- const options = {
150
- foo: 'bar',
151
- };
152
- await handler(options);
153
- expect(trackCommandUsage).toHaveBeenCalledTimes(1);
154
- expect(trackCommandUsage).toHaveBeenCalledWith(
155
- 'project-logs',
156
- null,
157
- accountId
158
- );
159
- });
160
-
161
- it('should initialize the ProjectLogsManager', async () => {
162
- const options = {
163
- foo: 'bar',
164
- };
165
- await handler(options);
166
- expect(ProjectLogsManager.init).toHaveBeenCalledTimes(1);
167
- expect(ProjectLogsManager.init).toHaveBeenCalledWith(accountId);
168
- });
169
-
170
- it('should prompt the user for input', async () => {
171
- const functionNames = ['function1', 'function2'];
172
- ProjectLogsManager.getFunctionNames.mockReturnValue(functionNames);
173
- const options = {
174
- foo: 'bar',
175
- };
176
- await handler(options);
177
- expect(projectLogsPrompt).toHaveBeenCalledTimes(1);
178
- expect(projectLogsPrompt).toHaveBeenCalledWith({
179
- functionChoices: functionNames,
180
- promptOptions: options,
181
- });
182
- });
183
-
184
- it('should set the function', async () => {
185
- const selectedFunction = 'function1';
186
- ProjectLogsManager.getFunctionNames.mockReturnValue([
187
- selectedFunction,
188
- 'function2',
189
- ]);
190
- projectLogsPrompt.mockReturnValue({
191
- functionName: selectedFunction,
192
- });
193
-
194
- await handler({});
195
- expect(ProjectLogsManager.setFunction).toHaveBeenCalledTimes(1);
196
- expect(ProjectLogsManager.setFunction).toHaveBeenCalledWith(
197
- selectedFunction
198
- );
199
- });
200
-
201
- it('should log public functions correctly', async () => {
202
- const functionNames = ['function1', 'function2'];
203
- const selectedFunction = 'function1';
204
- ProjectLogsManager.getFunctionNames.mockReturnValue(functionNames);
205
- projectLogsPrompt.mockReturnValue({
206
- functionName: selectedFunction,
207
- });
208
-
209
- const tableHeaders = ['Header 1', 'Header 2'];
210
- getTableHeader.mockReturnValue(tableHeaders);
211
-
212
- ProjectLogsManager.isPublicFunction = true;
213
- ProjectLogsManager.accountId = accountId;
214
- ProjectLogsManager.functionName = selectedFunction;
215
- ProjectLogsManager.endpointName = 'my-endpoint';
216
- ProjectLogsManager.appId = 123456;
217
-
218
- await handler({});
219
- expect(getTableHeader).toHaveBeenCalledTimes(1);
220
- expect(getTableHeader).toHaveBeenCalledWith([
221
- 'Account',
222
- 'Function',
223
- 'Endpoint',
224
- ]);
225
-
226
- expect(getTableContents).toHaveBeenCalledTimes(1);
227
- expect(getTableContents).toHaveBeenCalledWith(
228
- [
229
- tableHeaders,
230
- [
231
- ProjectLogsManager.accountId,
232
- ProjectLogsManager.functionName,
233
- ProjectLogsManager.endpointName,
234
- ],
235
- ],
236
- { border: { bodyLeft: ' ' } }
237
- );
238
- expect(uiLink).toHaveBeenCalledTimes(1);
239
- expect(uiLink).toHaveBeenCalledWith(
240
- 'View function logs in HubSpot',
241
- `https://app.hubspot.com/private-apps/${accountId}/${ProjectLogsManager.appId}/logs/serverlessGatewayExecution?path=${ProjectLogsManager.endpointName}`
242
- );
243
- expect(uiLine).toHaveBeenCalledTimes(1);
244
- });
245
-
246
- it('should log private functions correctly', async () => {
247
- const functionNames = ['function1', 'function2'];
248
- const selectedFunction = 'function1';
249
-
250
- ProjectLogsManager.getFunctionNames.mockReturnValue(functionNames);
251
- projectLogsPrompt.mockReturnValue({
252
- functionName: selectedFunction,
253
- });
254
-
255
- const tableHeaders = ['Header 1', 'Header 2'];
256
- getTableHeader.mockReturnValue(tableHeaders);
257
-
258
- ProjectLogsManager.isPublicFunction = false;
259
- ProjectLogsManager.accountId = accountId;
260
- ProjectLogsManager.functionName = selectedFunction;
261
- ProjectLogsManager.appId = 456789;
262
-
263
- await handler({});
264
- expect(getTableHeader).toHaveBeenCalledTimes(1);
265
- expect(getTableHeader).toHaveBeenCalledWith(['Account', 'Function']);
266
-
267
- expect(getTableContents).toHaveBeenCalledTimes(1);
268
- expect(getTableContents).toHaveBeenCalledWith(
269
- [
270
- tableHeaders,
271
- [ProjectLogsManager.accountId, ProjectLogsManager.functionName],
272
- ],
273
- { border: { bodyLeft: ' ' } }
274
- );
275
-
276
- expect(uiLink).toHaveBeenCalledWith(
277
- 'View function logs in HubSpot',
278
- `https://app.hubspot.com/private-apps/${accountId}/${ProjectLogsManager.appId}/logs/crm?serverlessFunction=${selectedFunction}`
279
- );
280
-
281
- expect(uiLine).toHaveBeenCalledTimes(1);
282
- });
283
-
284
- it('should handle errors correctly', async () => {
285
- const error = new Error('Something went wrong');
286
- ProjectLogsManager.init.mockImplementation(() => {
287
- throw error;
288
- });
289
-
290
- ProjectLogsManager.projectName = 'Super cool project';
291
-
292
- await handler({});
293
-
294
- expect(logError).toHaveBeenCalledTimes(1);
295
- expect(logError).toHaveBeenCalledWith(error, {
296
- accountId: accountId,
297
- projectName: ProjectLogsManager.projectName,
298
- });
299
-
300
- expect(processExitSpy).toHaveBeenCalledTimes(1);
301
- expect(processExitSpy).toHaveBeenCalledWith(EXIT_CODES.ERROR);
302
- });
303
- });
304
- });
@@ -1,28 +0,0 @@
1
- defaultPortal: DEV
2
-
3
- # Optionally set the default mode for all accounts
4
- defaultMode: publish
5
-
6
- # Override default HTTP timeout in milliseconds
7
- httpTimeout: 30000
8
-
9
- # Disable usage tracking
10
- allowUsageTracking: false
11
-
12
- # List of accounts that are intended to be used
13
- portals:
14
- # Account set up to use OAuth2
15
- - name: PROD
16
- portalId: 456
17
- authType: oauth2
18
- auth:
19
- clientId: d996372f-2b53-30d3-9c3b-4fdde4bce3a2
20
- clientSecret: f90a6248-fbc0-3b03-b0db-ec58c95e791
21
- scopes:
22
- - content
23
- tokenInfo:
24
- expiresAt: '2019-05-02T02:52:05.233Z'
25
- refreshToken: 84d22710-4cb7-5581-ba05-35f9945e5e8e
26
- accessToken: >-
27
- CJDVnLanLRICEQIYyLu8LyDh9E4opf1GMhkAxGuU5XN_O2O2QhX0khw7cwIkPkBRHye-OfIADgLBAAADAIADAAAAAAAAAAJCGQC8a5TlhtSU8T-2mVLxOBpxS18aM42oGKk
28
-
package/jest.config.js DELETED
@@ -1,4 +0,0 @@
1
- module.exports = {
2
- testPathIgnorePatterns: ['commands/functions/test.js'],
3
- clearMocks: true,
4
- };
@@ -1,83 +0,0 @@
1
- const {
2
- MODE,
3
- DEFAULT_MODE,
4
- } = require('@hubspot/local-dev-lib/constants/files');
5
- const {
6
- getAndLoadConfigIfNeeded,
7
- getAccountId,
8
- getAccountConfig,
9
- loadConfigFromEnvironment,
10
- } = require('@hubspot/local-dev-lib/config');
11
- const { getMode } = require('../commonOpts');
12
-
13
- jest.mock('@hubspot/local-dev-lib/config');
14
- jest.mock('@hubspot/local-dev-lib/logger');
15
-
16
- describe('@hubspot/cli/lib/commonOpts', () => {
17
- describe('getMode()', () => {
18
- const accounts = {
19
- PROD: 123,
20
- DEV: 456,
21
- };
22
- const devAccountConfig = {
23
- accountId: accounts.DEV,
24
- name: 'DEV',
25
- defaultMode: MODE.draft,
26
- };
27
- const prodAccountConfig = {
28
- accountId: accounts.PROD,
29
- name: 'PROD',
30
- };
31
- const config = {
32
- defaultAccount: 'DEV',
33
- accounts: [devAccountConfig, prodAccountConfig],
34
- };
35
- const configWithDefaultMode = {
36
- ...config,
37
- defaultMode: MODE.draft,
38
- };
39
-
40
- afterEach(() => {
41
- getAndLoadConfigIfNeeded.mockReset();
42
- getAccountId.mockReset();
43
- getAccountConfig.mockReset();
44
- loadConfigFromEnvironment.mockReset();
45
- });
46
-
47
- describe('mode option precedence', () => {
48
- describe('1. --mode', () => {
49
- it('should return the mode specified by the command option if present.', () => {
50
- getAndLoadConfigIfNeeded.mockReturnValue(configWithDefaultMode);
51
- getAccountConfig.mockReturnValue(devAccountConfig);
52
- expect(getMode({ mode: MODE.draft })).toBe(MODE.draft);
53
- expect(getMode({ mode: MODE.publish })).toBe(MODE.publish);
54
- expect(getMode({ mode: 'undefined-mode' })).toBe('undefined-mode');
55
- });
56
- });
57
- describe('2. hubspot.config.yml -> config.accounts[x].defaultMode', () => {
58
- it('should return the defaultMode specified by the account specific config if present.', () => {
59
- getAndLoadConfigIfNeeded.mockReturnValue(configWithDefaultMode);
60
- getAccountId.mockReturnValue(accounts.DEV);
61
- getAccountConfig.mockReturnValue(devAccountConfig);
62
- loadConfigFromEnvironment.mockReturnValue(undefined);
63
- expect(getMode({ account: accounts.DEV })).toBe(MODE.draft);
64
- });
65
- });
66
- describe('3. hubspot.config.yml -> config.defaultMode', () => {
67
- it('should return the defaultMode specified by the config if present.', () => {
68
- getAndLoadConfigIfNeeded.mockReturnValue(configWithDefaultMode);
69
- getAccountId.mockReturnValue(accounts.PROD);
70
- getAccountConfig.mockReturnValue(prodAccountConfig);
71
- loadConfigFromEnvironment.mockReturnValue(undefined);
72
- expect(getMode({ account: accounts.PROD })).toBe(MODE.draft);
73
- });
74
- });
75
- describe('4. DEFAULT_MODE', () => {
76
- it('should return the defaultMode specified by the config if present.', () => {
77
- loadConfigFromEnvironment.mockReturnValue(undefined);
78
- expect(getMode({ account: 'xxxxx' })).toBe(DEFAULT_MODE);
79
- });
80
- });
81
- });
82
- });
83
- });