@hubspot/cli 8.1.0 → 8.1.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.
- package/api/migrate.js +8 -4
- package/api/releases.d.ts +36 -0
- package/api/releases.js +41 -0
- package/bin/cli.js +12 -6
- package/commands/account/auth.js +7 -7
- package/commands/account/clean.js +7 -6
- package/commands/account/createOverride.js +10 -7
- package/commands/account/info.js +36 -17
- package/commands/account/link.d.ts +4 -0
- package/commands/account/link.js +89 -0
- package/commands/account/list.js +32 -76
- package/commands/account/remove.js +4 -3
- package/commands/account/removeOverride.js +11 -10
- package/commands/account/rename.js +5 -6
- package/commands/account/unlink.d.ts +4 -0
- package/commands/account/unlink.js +70 -0
- package/commands/account/use.js +75 -6
- package/commands/account.js +4 -0
- package/commands/api.d.ts +10 -0
- package/commands/api.js +164 -0
- package/commands/app/migrate.js +13 -13
- package/commands/app/secret/add.js +6 -7
- package/commands/app/secret/delete.js +9 -10
- package/commands/app/secret/list.js +6 -7
- package/commands/app/secret/update.js +8 -9
- package/commands/auth.js +19 -15
- package/commands/cms/app/create.js +9 -5
- package/commands/cms/convertFields.js +8 -8
- package/commands/cms/delete.js +2 -3
- package/commands/cms/fetch.js +7 -7
- package/commands/cms/function/create.js +9 -5
- package/commands/cms/function/deploy.js +2 -3
- package/commands/cms/function/list.js +11 -7
- package/commands/cms/function/logs.js +17 -22
- package/commands/cms/function/server.js +2 -3
- package/commands/cms/getReactModule.js +7 -8
- package/commands/cms/lighthouseScore.js +25 -24
- package/commands/cms/lint.js +4 -5
- package/commands/cms/list.js +5 -6
- package/commands/cms/module/create.js +14 -5
- package/commands/cms/module/marketplace-validate.js +7 -8
- package/commands/cms/mv.js +2 -3
- package/commands/cms/template/create.js +10 -6
- package/commands/cms/theme/create.js +5 -5
- package/commands/cms/theme/generate-selectors.js +5 -4
- package/commands/cms/theme/marketplace-validate.js +8 -9
- package/commands/cms/theme/preview.js +23 -70
- package/commands/cms/upload.js +15 -12
- package/commands/cms/watch.d.ts +0 -1
- package/commands/cms/watch.js +6 -12
- package/commands/cms/webpack/create.js +5 -5
- package/commands/completion.js +3 -5
- package/commands/config/migrate.js +6 -7
- package/commands/config/set.js +5 -6
- package/commands/customObject/create.js +4 -5
- package/commands/customObject/createSchema.js +4 -5
- package/commands/customObject/deleteSchema.js +4 -5
- package/commands/customObject/fetchAllSchemas.js +2 -3
- package/commands/customObject/fetchSchema.js +2 -3
- package/commands/customObject/listSchemas.js +2 -3
- package/commands/customObject/updateSchema.js +4 -5
- package/commands/doctor.js +8 -8
- package/commands/feedback.js +7 -5
- package/commands/filemanager/fetch.js +5 -6
- package/commands/filemanager/upload.js +5 -5
- package/commands/getStarted.js +17 -19
- package/commands/hubdb/clear.js +6 -3
- package/commands/hubdb/create.js +4 -5
- package/commands/hubdb/delete.js +9 -6
- package/commands/hubdb/fetch.js +6 -3
- package/commands/hubdb/list.js +16 -14
- package/commands/init.js +15 -14
- package/commands/mcp/setup.js +5 -14
- package/commands/mcp/start.js +2 -4
- package/commands/open.js +4 -5
- package/commands/project/add.js +13 -8
- package/commands/project/appInstallStatus.d.ts +4 -0
- package/commands/project/appInstallStatus.js +132 -0
- package/commands/project/create.js +28 -17
- package/commands/project/delete.d.ts +7 -0
- package/commands/project/delete.js +74 -0
- package/commands/project/deploy.js +39 -36
- package/commands/project/dev/deprecatedFlow.js +62 -17
- package/commands/project/dev/index.d.ts +3 -3
- package/commands/project/dev/index.js +59 -48
- package/commands/project/dev/unifiedFlow.js +70 -21
- package/commands/project/download.js +12 -9
- package/commands/project/info.d.ts +4 -0
- package/commands/project/info.js +67 -0
- package/commands/project/installDeps.js +9 -6
- package/commands/project/lint.js +33 -10
- package/commands/project/list.d.ts +2 -2
- package/commands/project/list.js +15 -14
- package/commands/project/listBuilds.js +8 -6
- package/commands/project/logs.js +5 -6
- package/commands/project/migrate.js +18 -18
- package/commands/project/open.js +5 -6
- package/commands/project/profile/add.js +12 -8
- package/commands/project/profile/delete.js +15 -11
- package/commands/project/updateDeps.js +9 -6
- package/commands/project/upload.d.ts +3 -0
- package/commands/project/upload.js +98 -25
- package/commands/project/validate.js +12 -12
- package/commands/project/watch.js +32 -19
- package/commands/project.js +12 -3
- package/commands/sandbox/create.js +18 -45
- package/commands/sandbox/delete.js +13 -14
- package/commands/secret/addSecret.js +6 -7
- package/commands/secret/deleteSecret.js +5 -6
- package/commands/secret/listSecret.js +2 -3
- package/commands/secret/updateSecret.js +4 -5
- package/commands/testAccount/create.d.ts +1 -1
- package/commands/testAccount/create.js +25 -17
- package/commands/testAccount/createConfig.js +7 -8
- package/commands/testAccount/delete.js +27 -18
- package/commands/testAccount/importData.js +6 -7
- package/commands/upgrade.js +9 -10
- package/lang/en.d.ts +276 -14
- package/lang/en.js +293 -28
- package/lib/accountAuth.js +4 -0
- package/lib/api/usageTracking.d.ts +29 -0
- package/lib/api/usageTracking.js +28 -0
- package/lib/app/migrate.js +18 -5
- package/lib/buildAccount.d.ts +1 -6
- package/lib/buildAccount.js +9 -42
- package/lib/commandSuggestion.js +1 -7
- package/lib/constants.d.ts +3 -4
- package/lib/constants.js +5 -4
- package/lib/doctor/Diagnosis.js +5 -5
- package/lib/doctor/Doctor.js +7 -7
- package/lib/errorHandlers/index.js +4 -3
- package/lib/errorHandlers/suppressError.js +4 -0
- package/lib/errors/PromptExitError.d.ts +6 -0
- package/lib/errors/PromptExitError.js +11 -0
- package/lib/generateSelectors.js +1 -2
- package/lib/getStartedV2Actions.d.ts +13 -0
- package/lib/getStartedV2Actions.js +56 -3
- package/lib/hasFeature.js +1 -2
- package/lib/link/accountTableUtils.d.ts +10 -0
- package/lib/link/accountTableUtils.js +39 -0
- package/lib/link/index.d.ts +18 -0
- package/lib/link/index.js +185 -0
- package/lib/link/linkUtils.d.ts +5 -0
- package/lib/link/linkUtils.js +49 -0
- package/lib/link/prompts.d.ts +7 -0
- package/lib/link/prompts.js +126 -0
- package/lib/link/renderLinkedAccountsTable.d.ts +2 -0
- package/lib/link/renderLinkedAccountsTable.js +14 -0
- package/lib/link/warnIfLinkedDirectory.d.ts +1 -0
- package/lib/link/warnIfLinkedDirectory.js +9 -0
- package/lib/mcp/setup.d.ts +1 -0
- package/lib/mcp/setup.js +77 -30
- package/lib/middleware/autoUpdateMiddleware.js +6 -3
- package/lib/process.d.ts +1 -1
- package/lib/process.js +10 -3
- package/lib/projects/ProjectLogsManager.js +6 -3
- package/lib/projects/components.js +15 -4
- package/lib/projects/create/index.js +3 -6
- package/lib/projects/create/legacy.js +5 -10
- package/lib/projects/create/v2.js +5 -14
- package/lib/projects/delete.d.ts +13 -0
- package/lib/projects/delete.js +193 -0
- package/lib/projects/deploy.d.ts +1 -1
- package/lib/projects/deploy.js +2 -2
- package/lib/projects/ensureProjectExists.js +1 -2
- package/lib/projects/localDev/AppDevModeInterface.js +13 -9
- package/lib/projects/localDev/DevServerManager_DEPRECATED.d.ts +4 -1
- package/lib/projects/localDev/DevServerManager_DEPRECATED.js +3 -3
- package/lib/projects/localDev/DevSessionManager.d.ts +6 -3
- package/lib/projects/localDev/DevSessionManager.js +31 -19
- package/lib/projects/localDev/LocalDevManager_DEPRECATED.d.ts +5 -0
- package/lib/projects/localDev/LocalDevManager_DEPRECATED.js +21 -10
- package/lib/projects/localDev/LocalDevProcess.js +6 -5
- package/lib/projects/localDev/LocalDevState.d.ts +3 -2
- package/lib/projects/localDev/LocalDevState.js +3 -1
- package/lib/projects/localDev/helpers/account.d.ts +4 -3
- package/lib/projects/localDev/helpers/account.js +21 -30
- package/lib/projects/localDev/helpers/process.d.ts +1 -1
- package/lib/projects/localDev/helpers/process.js +4 -10
- package/lib/projects/localDev/helpers/project.d.ts +4 -3
- package/lib/projects/localDev/helpers/project.js +32 -16
- package/lib/projects/npmAuditOnUpload.d.ts +10 -0
- package/lib/projects/npmAuditOnUpload.js +73 -0
- package/lib/projects/pollProjectBuildAndDeploy.d.ts +5 -1
- package/lib/projects/pollProjectBuildAndDeploy.js +93 -87
- package/lib/projects/preview.d.ts +7 -0
- package/lib/projects/preview.js +48 -0
- package/lib/projects/projectInfo.d.ts +5 -0
- package/lib/projects/projectInfo.js +82 -0
- package/lib/projects/projectProfiles.d.ts +1 -2
- package/lib/projects/projectProfiles.js +5 -17
- package/lib/projects/uieLinting.d.ts +17 -3
- package/lib/projects/uieLinting.js +93 -28
- package/lib/projects/upload.d.ts +4 -1
- package/lib/projects/upload.js +71 -50
- package/lib/projects/watch.d.ts +2 -1
- package/lib/projects/watch.js +32 -24
- package/lib/projects/workspaces.d.ts +52 -0
- package/lib/projects/workspaces.js +365 -0
- package/lib/prompts/createApiSamplePrompt.js +4 -0
- package/lib/prompts/downloadProjectPrompt.js +11 -10
- package/lib/prompts/installAppPrompt.js +3 -2
- package/lib/prompts/personalAccessKeyPrompt.js +3 -2
- package/lib/prompts/projectDevTargetAccountPrompt.d.ts +1 -0
- package/lib/prompts/projectDevTargetAccountPrompt.js +23 -16
- package/lib/prompts/projectProfilePrompt.d.ts +2 -0
- package/lib/prompts/projectProfilePrompt.js +46 -0
- package/lib/prompts/projectsLogsPrompt.js +3 -0
- package/lib/prompts/promptUtils.js +4 -2
- package/lib/prompts/selectHubDBTablePrompt.js +8 -4
- package/lib/prompts/selectPublicAppForMigrationPrompt.js +12 -6
- package/lib/sandboxes.d.ts +1 -9
- package/lib/sandboxes.js +0 -21
- package/lib/serverlessLogs.js +50 -44
- package/lib/theme/cmsDevServerProcess.d.ts +14 -0
- package/lib/theme/cmsDevServerProcess.js +149 -0
- package/lib/theme/cmsDevServerRunner.d.ts +14 -0
- package/lib/theme/cmsDevServerRunner.js +90 -0
- package/lib/theme/migrate.d.ts +1 -1
- package/lib/theme/migrate.js +1 -5
- package/lib/ui/SpinniesManager.d.ts +1 -0
- package/lib/ui/SpinniesManager.js +22 -6
- package/lib/ui/accountTable.d.ts +8 -0
- package/lib/ui/accountTable.js +67 -0
- package/lib/ui/spinniesUtils.d.ts +0 -1
- package/lib/ui/spinniesUtils.js +6 -16
- package/lib/usageTracking.d.ts +9 -20
- package/lib/usageTracking.js +51 -34
- package/lib/yargs/makeWrappedYargsHandler.d.ts +3 -0
- package/lib/yargs/makeWrappedYargsHandler.js +121 -0
- package/lib/yargs/makeYargsBuilder.d.ts +13 -0
- package/lib/yargs/makeYargsBuilder.js +33 -0
- package/lib/yargs/parseYargsOrExit.d.ts +4 -0
- package/lib/yargs/parseYargsOrExit.js +25 -0
- package/lib/yargs/strictEnforceBoolean.d.ts +1 -0
- package/lib/yargs/strictEnforceBoolean.js +13 -0
- package/lib/yargsUtils.d.ts +3 -16
- package/lib/yargsUtils.js +3 -48
- package/mcp-server/Tool.d.ts +15 -0
- package/mcp-server/Tool.js +53 -0
- package/mcp-server/server.js +43 -3
- package/mcp-server/tools/cms/HsCreateFunctionTool.d.ts +4 -2
- package/mcp-server/tools/cms/HsCreateFunctionTool.js +11 -9
- package/mcp-server/tools/cms/HsCreateModuleTool.d.ts +4 -2
- package/mcp-server/tools/cms/HsCreateModuleTool.js +12 -11
- package/mcp-server/tools/cms/HsCreateTemplateTool.d.ts +4 -2
- package/mcp-server/tools/cms/HsCreateTemplateTool.js +11 -9
- package/mcp-server/tools/cms/HsFunctionLogsTool.d.ts +4 -2
- package/mcp-server/tools/cms/HsFunctionLogsTool.js +10 -9
- package/mcp-server/tools/cms/HsListFunctionsTool.d.ts +4 -2
- package/mcp-server/tools/cms/HsListFunctionsTool.js +10 -9
- package/mcp-server/tools/cms/HsListTool.d.ts +4 -2
- package/mcp-server/tools/cms/HsListTool.js +11 -9
- package/mcp-server/tools/index.d.ts +3 -2
- package/mcp-server/tools/index.js +24 -22
- package/mcp-server/tools/project/AddFeatureToProjectTool.d.ts +25 -5
- package/mcp-server/tools/project/AddFeatureToProjectTool.js +16 -18
- package/mcp-server/tools/project/CreateProjectTool.d.ts +29 -6
- package/mcp-server/tools/project/CreateProjectTool.js +16 -18
- package/mcp-server/tools/project/CreateTestAccountTool.d.ts +4 -2
- package/mcp-server/tools/project/CreateTestAccountTool.js +22 -10
- package/mcp-server/tools/project/DeployProjectTool.d.ts +4 -2
- package/mcp-server/tools/project/DeployProjectTool.js +6 -8
- package/mcp-server/tools/project/DocFetchTool.d.ts +4 -2
- package/mcp-server/tools/project/DocFetchTool.js +8 -6
- package/mcp-server/tools/project/DocsSearchTool.d.ts +9 -3
- package/mcp-server/tools/project/DocsSearchTool.js +32 -9
- package/mcp-server/tools/project/FindProjectsTool.d.ts +15 -0
- package/mcp-server/tools/project/FindProjectsTool.js +60 -0
- package/mcp-server/tools/project/GetApiUsagePatternsByAppIdTool.d.ts +4 -2
- package/mcp-server/tools/project/GetApiUsagePatternsByAppIdTool.js +13 -14
- package/mcp-server/tools/project/GetApplicationInfoTool.d.ts +4 -2
- package/mcp-server/tools/project/GetApplicationInfoTool.js +8 -6
- package/mcp-server/tools/project/GetBuildLogsTool.d.ts +6 -4
- package/mcp-server/tools/project/GetBuildLogsTool.js +15 -14
- package/mcp-server/tools/project/GetBuildStatusTool.d.ts +5 -3
- package/mcp-server/tools/project/GetBuildStatusTool.js +12 -11
- package/mcp-server/tools/project/GetConfigValuesTool.d.ts +4 -2
- package/mcp-server/tools/project/GetConfigValuesTool.js +12 -7
- package/mcp-server/tools/project/GuidedWalkthroughTool.d.ts +10 -3
- package/mcp-server/tools/project/GuidedWalkthroughTool.js +5 -12
- package/mcp-server/tools/project/UploadProjectTools.d.ts +4 -2
- package/mcp-server/tools/project/UploadProjectTools.js +11 -9
- package/mcp-server/tools/project/ValidateProjectTool.d.ts +4 -2
- package/mcp-server/tools/project/ValidateProjectTool.js +10 -8
- package/mcp-server/tools/project/constants.d.ts +13 -1
- package/mcp-server/tools/project/constants.js +13 -16
- package/mcp-server/types.d.ts +0 -7
- package/mcp-server/types.js +1 -13
- package/mcp-server/utils/command.d.ts +5 -0
- package/mcp-server/utils/command.js +24 -0
- package/mcp-server/utils/feedbackTracking.js +2 -17
- package/mcp-server/utils/logger.d.ts +10 -0
- package/mcp-server/utils/logger.js +29 -0
- package/mcp-server/utils/toolUsageTracking.js +10 -8
- package/package.json +15 -11
- package/types/Link.d.ts +32 -0
- package/types/Link.js +5 -0
- package/types/LocalDev.d.ts +5 -0
- package/types/PackageJson.d.ts +1 -0
- package/types/Projects.d.ts +19 -0
- package/types/Prompts.d.ts +1 -0
- package/types/Yargs.d.ts +19 -1
- package/ui/components/getStarted/GetStartedFlow.js +79 -2
- package/ui/components/getStarted/reducer.d.ts +20 -0
- package/ui/components/getStarted/reducer.js +36 -0
- package/ui/components/getStarted/screens/InstallationScreen.d.ts +7 -0
- package/ui/components/getStarted/screens/InstallationScreen.js +16 -0
- package/ui/components/getStarted/screens/ProjectSetupScreen.js +2 -1
- package/ui/lib/constants.d.ts +1 -0
- package/ui/lib/constants.js +1 -0
- package/api/__tests__/migrate.test.d.ts +0 -1
- package/api/__tests__/migrate.test.js +0 -199
- package/commands/__tests__/account.test.d.ts +0 -1
- package/commands/__tests__/account.test.js +0 -69
- package/commands/__tests__/auth.test.d.ts +0 -1
- package/commands/__tests__/auth.test.js +0 -43
- package/commands/__tests__/cms.test.d.ts +0 -1
- package/commands/__tests__/cms.test.js +0 -87
- package/commands/__tests__/config.test.d.ts +0 -1
- package/commands/__tests__/config.test.js +0 -44
- package/commands/__tests__/customObject.test.d.ts +0 -1
- package/commands/__tests__/customObject.test.js +0 -68
- package/commands/__tests__/doctor.test.d.ts +0 -1
- package/commands/__tests__/doctor.test.js +0 -132
- package/commands/__tests__/feedback.test.d.ts +0 -1
- package/commands/__tests__/feedback.test.js +0 -24
- package/commands/__tests__/filemanager.test.d.ts +0 -1
- package/commands/__tests__/filemanager.test.js +0 -45
- package/commands/__tests__/getStarted.test.d.ts +0 -1
- package/commands/__tests__/getStarted.test.js +0 -173
- package/commands/__tests__/hubdb.test.d.ts +0 -1
- package/commands/__tests__/hubdb.test.js +0 -50
- package/commands/__tests__/init.test.d.ts +0 -1
- package/commands/__tests__/init.test.js +0 -42
- package/commands/__tests__/mcp.test.d.ts +0 -1
- package/commands/__tests__/mcp.test.js +0 -46
- package/commands/__tests__/open.test.d.ts +0 -1
- package/commands/__tests__/open.test.js +0 -58
- package/commands/__tests__/project.test.d.ts +0 -1
- package/commands/__tests__/project.test.js +0 -125
- package/commands/__tests__/sandbox.test.d.ts +0 -1
- package/commands/__tests__/sandbox.test.js +0 -44
- package/commands/__tests__/secret.test.d.ts +0 -1
- package/commands/__tests__/secret.test.js +0 -49
- package/commands/__tests__/testAccount.test.d.ts +0 -1
- package/commands/__tests__/testAccount.test.js +0 -57
- package/commands/__tests__/upgrade.test.d.ts +0 -1
- package/commands/__tests__/upgrade.test.js +0 -309
- package/commands/account/__tests__/auth.test.d.ts +0 -1
- package/commands/account/__tests__/auth.test.js +0 -206
- package/commands/account/__tests__/clean.test.d.ts +0 -1
- package/commands/account/__tests__/clean.test.js +0 -28
- package/commands/account/__tests__/createOverride.test.d.ts +0 -1
- package/commands/account/__tests__/createOverride.test.js +0 -32
- package/commands/account/__tests__/info.test.d.ts +0 -1
- package/commands/account/__tests__/info.test.js +0 -28
- package/commands/account/__tests__/list.test.d.ts +0 -1
- package/commands/account/__tests__/list.test.js +0 -153
- package/commands/account/__tests__/remove.test.d.ts +0 -1
- package/commands/account/__tests__/remove.test.js +0 -36
- package/commands/account/__tests__/removeOverride.d.ts +0 -1
- package/commands/account/__tests__/removeOverride.js +0 -25
- package/commands/account/__tests__/rename.test.d.ts +0 -1
- package/commands/account/__tests__/rename.test.js +0 -82
- package/commands/account/__tests__/use.test.d.ts +0 -1
- package/commands/account/__tests__/use.test.js +0 -170
- package/commands/app/__tests__/migrate.test.d.ts +0 -1
- package/commands/app/__tests__/migrate.test.js +0 -111
- package/commands/app/secret/__tests__/add.test.d.ts +0 -1
- package/commands/app/secret/__tests__/add.test.js +0 -140
- package/commands/app/secret/__tests__/delete.test.d.ts +0 -1
- package/commands/app/secret/__tests__/delete.test.js +0 -28
- package/commands/app/secret/__tests__/list.test.d.ts +0 -1
- package/commands/app/secret/__tests__/list.test.js +0 -25
- package/commands/app/secret/__tests__/update.test.d.ts +0 -1
- package/commands/app/secret/__tests__/update.test.js +0 -28
- package/commands/cms/__tests__/delete.test.d.ts +0 -1
- package/commands/cms/__tests__/delete.test.js +0 -39
- package/commands/cms/__tests__/fetch.test.d.ts +0 -1
- package/commands/cms/__tests__/fetch.test.js +0 -156
- package/commands/cms/__tests__/function.test.d.ts +0 -1
- package/commands/cms/__tests__/function.test.js +0 -50
- package/commands/cms/__tests__/lint.test.d.ts +0 -1
- package/commands/cms/__tests__/lint.test.js +0 -33
- package/commands/cms/__tests__/list.test.d.ts +0 -1
- package/commands/cms/__tests__/list.test.js +0 -42
- package/commands/cms/__tests__/module.test.d.ts +0 -1
- package/commands/cms/__tests__/module.test.js +0 -45
- package/commands/cms/__tests__/mv.test.d.ts +0 -1
- package/commands/cms/__tests__/mv.test.js +0 -46
- package/commands/cms/__tests__/theme.test.d.ts +0 -1
- package/commands/cms/__tests__/theme.test.js +0 -54
- package/commands/cms/__tests__/upload.test.d.ts +0 -1
- package/commands/cms/__tests__/upload.test.js +0 -308
- package/commands/cms/__tests__/watch.test.d.ts +0 -1
- package/commands/cms/__tests__/watch.test.js +0 -212
- package/commands/cms/function/__tests__/logs.test.d.ts +0 -1
- package/commands/cms/function/__tests__/logs.test.js +0 -70
- package/commands/cms/theme/__tests__/generate-selectors.test.d.ts +0 -1
- package/commands/cms/theme/__tests__/generate-selectors.test.js +0 -28
- package/commands/cms/theme/__tests__/marketplace-validate.test.d.ts +0 -1
- package/commands/cms/theme/__tests__/marketplace-validate.test.js +0 -36
- package/commands/cms/theme/__tests__/preview.test.d.ts +0 -1
- package/commands/cms/theme/__tests__/preview.test.js +0 -54
- package/commands/customObject/__tests__/create.test.d.ts +0 -1
- package/commands/customObject/__tests__/create.test.js +0 -40
- package/commands/customObject/__tests__/createSchema.test.d.ts +0 -1
- package/commands/customObject/__tests__/createSchema.test.js +0 -28
- package/commands/customObject/__tests__/deleteSchema.test.d.ts +0 -1
- package/commands/customObject/__tests__/deleteSchema.test.js +0 -42
- package/commands/customObject/__tests__/fetch-all-schemas.test.d.ts +0 -1
- package/commands/customObject/__tests__/fetch-all-schemas.test.js +0 -41
- package/commands/customObject/__tests__/fetchSchema.test.d.ts +0 -1
- package/commands/customObject/__tests__/fetchSchema.test.js +0 -45
- package/commands/customObject/__tests__/listSchemas.test.d.ts +0 -1
- package/commands/customObject/__tests__/listSchemas.test.js +0 -29
- package/commands/customObject/__tests__/updateSchema.test.d.ts +0 -1
- package/commands/customObject/__tests__/updateSchema.test.js +0 -40
- package/commands/filemanager/__tests__/fetch.test.d.ts +0 -1
- package/commands/filemanager/__tests__/fetch.test.js +0 -32
- package/commands/filemanager/__tests__/upload.test.d.ts +0 -1
- package/commands/filemanager/__tests__/upload.test.js +0 -191
- package/commands/hubdb/__tests__/clear.test.d.ts +0 -1
- package/commands/hubdb/__tests__/clear.test.js +0 -28
- package/commands/hubdb/__tests__/create.test.d.ts +0 -1
- package/commands/hubdb/__tests__/create.test.js +0 -28
- package/commands/hubdb/__tests__/delete.test.d.ts +0 -1
- package/commands/hubdb/__tests__/delete.test.js +0 -28
- package/commands/hubdb/__tests__/fetch.test.d.ts +0 -1
- package/commands/hubdb/__tests__/fetch.test.js +0 -28
- package/commands/hubdb/__tests__/list.test.d.ts +0 -1
- package/commands/hubdb/__tests__/list.test.js +0 -88
- package/commands/mcp/__tests__/setup.test.d.ts +0 -1
- package/commands/mcp/__tests__/setup.test.js +0 -26
- package/commands/mcp/__tests__/start.test.d.ts +0 -1
- package/commands/mcp/__tests__/start.test.js +0 -137
- package/commands/project/__tests__/add.test.d.ts +0 -1
- package/commands/project/__tests__/add.test.js +0 -107
- package/commands/project/__tests__/create.test.d.ts +0 -1
- package/commands/project/__tests__/create.test.js +0 -97
- package/commands/project/__tests__/deploy.test.d.ts +0 -1
- package/commands/project/__tests__/deploy.test.js +0 -307
- package/commands/project/__tests__/dev.test.d.ts +0 -1
- package/commands/project/__tests__/dev.test.js +0 -273
- package/commands/project/__tests__/devUnifiedFlow.test.d.ts +0 -1
- package/commands/project/__tests__/devUnifiedFlow.test.js +0 -434
- package/commands/project/__tests__/download.test.d.ts +0 -1
- package/commands/project/__tests__/download.test.js +0 -39
- package/commands/project/__tests__/installDeps.test.d.ts +0 -1
- package/commands/project/__tests__/installDeps.test.js +0 -140
- package/commands/project/__tests__/lint.test.d.ts +0 -1
- package/commands/project/__tests__/lint.test.js +0 -704
- package/commands/project/__tests__/list.test.d.ts +0 -1
- package/commands/project/__tests__/list.test.js +0 -31
- package/commands/project/__tests__/listBuilds.test.d.ts +0 -1
- package/commands/project/__tests__/listBuilds.test.js +0 -38
- package/commands/project/__tests__/logs.test.d.ts +0 -1
- package/commands/project/__tests__/logs.test.js +0 -202
- package/commands/project/__tests__/migrate.test.d.ts +0 -1
- package/commands/project/__tests__/migrate.test.js +0 -106
- package/commands/project/__tests__/open.test.d.ts +0 -1
- package/commands/project/__tests__/open.test.js +0 -39
- package/commands/project/__tests__/profile.test.d.ts +0 -1
- package/commands/project/__tests__/profile.test.js +0 -42
- package/commands/project/__tests__/updateDeps.test.d.ts +0 -1
- package/commands/project/__tests__/updateDeps.test.js +0 -140
- package/commands/project/__tests__/upload.test.d.ts +0 -1
- package/commands/project/__tests__/upload.test.js +0 -234
- package/commands/project/__tests__/validate.test.d.ts +0 -1
- package/commands/project/__tests__/validate.test.js +0 -381
- package/commands/project/__tests__/watch.test.d.ts +0 -1
- package/commands/project/__tests__/watch.test.js +0 -35
- package/commands/sandbox/__tests__/create.test.d.ts +0 -1
- package/commands/sandbox/__tests__/create.test.js +0 -245
- package/commands/sandbox/__tests__/delete.test.d.ts +0 -1
- package/commands/sandbox/__tests__/delete.test.js +0 -31
- package/commands/secret/__tests__/addSecret.test.d.ts +0 -1
- package/commands/secret/__tests__/addSecret.test.js +0 -162
- package/commands/secret/__tests__/deleteSecret.test.d.ts +0 -1
- package/commands/secret/__tests__/deleteSecret.test.js +0 -41
- package/commands/secret/__tests__/listSecret.test.d.ts +0 -1
- package/commands/secret/__tests__/listSecret.test.js +0 -29
- package/commands/secret/__tests__/updateSecret.test.d.ts +0 -1
- package/commands/secret/__tests__/updateSecret.test.js +0 -29
- package/commands/testAccount/__tests__/create.test.d.ts +0 -1
- package/commands/testAccount/__tests__/create.test.js +0 -106
- package/commands/testAccount/__tests__/createConfig.test.d.ts +0 -1
- package/commands/testAccount/__tests__/createConfig.test.js +0 -32
- package/commands/testAccount/__tests__/delete.test.d.ts +0 -1
- package/commands/testAccount/__tests__/delete.test.js +0 -29
- package/commands/testAccount/__tests__/importData.test.d.ts +0 -1
- package/commands/testAccount/__tests__/importData.test.js +0 -92
- package/lib/__tests__/CLIWebSocketServer.test.d.ts +0 -1
- package/lib/__tests__/CLIWebSocketServer.test.js +0 -252
- package/lib/__tests__/accountAuth.test.d.ts +0 -1
- package/lib/__tests__/accountAuth.test.js +0 -258
- package/lib/__tests__/accountTypes.test.d.ts +0 -1
- package/lib/__tests__/accountTypes.test.js +0 -98
- package/lib/__tests__/buildAccount.test.d.ts +0 -1
- package/lib/__tests__/buildAccount.test.js +0 -262
- package/lib/__tests__/cliUpgradeUtils.test.d.ts +0 -1
- package/lib/__tests__/cliUpgradeUtils.test.js +0 -131
- package/lib/__tests__/commandSuggestion.test.d.ts +0 -1
- package/lib/__tests__/commandSuggestion.test.js +0 -119
- package/lib/__tests__/commonOpts.test.d.ts +0 -1
- package/lib/__tests__/commonOpts.test.js +0 -80
- package/lib/__tests__/dependencyManagement.test.d.ts +0 -1
- package/lib/__tests__/dependencyManagement.test.js +0 -1067
- package/lib/__tests__/developerTestAccounts.test.d.ts +0 -1
- package/lib/__tests__/developerTestAccounts.test.js +0 -156
- package/lib/__tests__/hasFeature.test.d.ts +0 -1
- package/lib/__tests__/hasFeature.test.js +0 -167
- package/lib/__tests__/http.test.d.ts +0 -1
- package/lib/__tests__/http.test.js +0 -40
- package/lib/__tests__/importData.test.d.ts +0 -1
- package/lib/__tests__/importData.test.js +0 -98
- package/lib/__tests__/npmCli.test.d.ts +0 -1
- package/lib/__tests__/npmCli.test.js +0 -84
- package/lib/__tests__/oauth.test.d.ts +0 -1
- package/lib/__tests__/oauth.test.js +0 -109
- package/lib/__tests__/parsing.test.d.ts +0 -1
- package/lib/__tests__/parsing.test.js +0 -34
- package/lib/__tests__/polling.test.d.ts +0 -1
- package/lib/__tests__/polling.test.js +0 -76
- package/lib/__tests__/process.test.d.ts +0 -1
- package/lib/__tests__/process.test.js +0 -89
- package/lib/__tests__/sandboxSync.test.d.ts +0 -1
- package/lib/__tests__/sandboxSync.test.js +0 -147
- package/lib/__tests__/sandboxes.test.d.ts +0 -1
- package/lib/__tests__/sandboxes.test.js +0 -156
- package/lib/__tests__/serverlessLogs.test.d.ts +0 -1
- package/lib/__tests__/serverlessLogs.test.js +0 -148
- package/lib/__tests__/usageTracking.test.d.ts +0 -1
- package/lib/__tests__/usageTracking.test.js +0 -197
- package/lib/__tests__/validation.test.d.ts +0 -1
- package/lib/__tests__/validation.test.js +0 -143
- package/lib/__tests__/yargsUtils.test.d.ts +0 -1
- package/lib/__tests__/yargsUtils.test.js +0 -124
- package/lib/app/__tests__/migrate.test.d.ts +0 -1
- package/lib/app/__tests__/migrate.test.js +0 -638
- package/lib/doctor/__tests__/Diagnosis.test.d.ts +0 -1
- package/lib/doctor/__tests__/Diagnosis.test.js +0 -84
- package/lib/doctor/__tests__/DiagnosticInfoBuilder.test.d.ts +0 -1
- package/lib/doctor/__tests__/DiagnosticInfoBuilder.test.js +0 -177
- package/lib/doctor/__tests__/Doctor.test.d.ts +0 -1
- package/lib/doctor/__tests__/Doctor.test.js +0 -560
- package/lib/errorHandlers/__tests__/index.test.d.ts +0 -1
- package/lib/errorHandlers/__tests__/index.test.js +0 -278
- package/lib/mcp/__tests__/setup.test.d.ts +0 -1
- package/lib/mcp/__tests__/setup.test.js +0 -194
- package/lib/middleware/__tests__/commandTargetingUtils.test.d.ts +0 -1
- package/lib/middleware/__tests__/commandTargetingUtils.test.js +0 -99
- package/lib/middleware/__tests__/configMiddleware.test.d.ts +0 -1
- package/lib/middleware/__tests__/configMiddleware.test.js +0 -118
- package/lib/middleware/__tests__/gitMiddleware.test.d.ts +0 -1
- package/lib/middleware/__tests__/gitMiddleware.test.js +0 -43
- package/lib/middleware/__tests__/requestMiddleware.test.d.ts +0 -1
- package/lib/middleware/__tests__/requestMiddleware.test.js +0 -15
- package/lib/middleware/__tests__/usageTrackingMiddleware.test.d.ts +0 -1
- package/lib/middleware/__tests__/usageTrackingMiddleware.test.js +0 -44
- package/lib/middleware/__tests__/yargsChecksMiddleware.test.d.ts +0 -1
- package/lib/middleware/__tests__/yargsChecksMiddleware.test.js +0 -39
- package/lib/projects/__tests__/AppDevModeInterface.test.d.ts +0 -1
- package/lib/projects/__tests__/AppDevModeInterface.test.js +0 -541
- package/lib/projects/__tests__/DevServerManager.test.d.ts +0 -1
- package/lib/projects/__tests__/DevServerManager.test.js +0 -185
- package/lib/projects/__tests__/DevSessionManager.test.d.ts +0 -1
- package/lib/projects/__tests__/DevSessionManager.test.js +0 -250
- package/lib/projects/__tests__/LocalDevProcess.test.d.ts +0 -1
- package/lib/projects/__tests__/LocalDevProcess.test.js +0 -481
- package/lib/projects/__tests__/LocalDevWebsocketServer.test.d.ts +0 -1
- package/lib/projects/__tests__/LocalDevWebsocketServer.test.js +0 -231
- package/lib/projects/__tests__/ProjectLogsManager.test.d.ts +0 -1
- package/lib/projects/__tests__/ProjectLogsManager.test.js +0 -302
- package/lib/projects/__tests__/UIExtensionsDevModeInterface.test.d.ts +0 -1
- package/lib/projects/__tests__/UIExtensionsDevModeInterface.test.js +0 -160
- package/lib/projects/__tests__/components.test.d.ts +0 -1
- package/lib/projects/__tests__/components.test.js +0 -426
- package/lib/projects/__tests__/deploy.test.d.ts +0 -1
- package/lib/projects/__tests__/deploy.test.js +0 -231
- package/lib/projects/__tests__/localDevProjectHelpers.test.d.ts +0 -1
- package/lib/projects/__tests__/localDevProjectHelpers.test.js +0 -120
- package/lib/projects/__tests__/platformVersion.test.d.ts +0 -1
- package/lib/projects/__tests__/platformVersion.test.js +0 -63
- package/lib/projects/__tests__/pollProjectBuildAndDeploy.test.d.ts +0 -1
- package/lib/projects/__tests__/pollProjectBuildAndDeploy.test.js +0 -328
- package/lib/projects/__tests__/projectProfiles.test.d.ts +0 -1
- package/lib/projects/__tests__/projectProfiles.test.js +0 -441
- package/lib/projects/__tests__/projects.test.d.ts +0 -1
- package/lib/projects/__tests__/projects.test.js +0 -58
- package/lib/projects/__tests__/structure.test.d.ts +0 -1
- package/lib/projects/__tests__/structure.test.js +0 -210
- package/lib/projects/__tests__/uieLinting.test.d.ts +0 -1
- package/lib/projects/__tests__/uieLinting.test.js +0 -631
- package/lib/projects/__tests__/upload.test.d.ts +0 -1
- package/lib/projects/__tests__/upload.test.js +0 -183
- package/lib/projects/add/__tests__/legacyAddComponent.test.d.ts +0 -1
- package/lib/projects/add/__tests__/legacyAddComponent.test.js +0 -245
- package/lib/projects/add/__tests__/v2AddComponent.test.d.ts +0 -1
- package/lib/projects/add/__tests__/v2AddComponent.test.js +0 -343
- package/lib/projects/create/__tests__/legacy.test.d.ts +0 -1
- package/lib/projects/create/__tests__/legacy.test.js +0 -90
- package/lib/projects/create/__tests__/v2.test.d.ts +0 -1
- package/lib/projects/create/__tests__/v2.test.js +0 -257
- package/lib/projects/platformVersion.d.ts +0 -9
- package/lib/projects/platformVersion.js +0 -39
- package/lib/prompts/__tests__/createDeveloperTestAccountConfigPrompt.test.d.ts +0 -1
- package/lib/prompts/__tests__/createDeveloperTestAccountConfigPrompt.test.js +0 -157
- package/lib/prompts/__tests__/createFunctionPrompt.test.d.ts +0 -1
- package/lib/prompts/__tests__/createFunctionPrompt.test.js +0 -129
- package/lib/prompts/__tests__/createModulePrompt.test.d.ts +0 -1
- package/lib/prompts/__tests__/createModulePrompt.test.js +0 -187
- package/lib/prompts/__tests__/createTemplatePrompt.test.d.ts +0 -1
- package/lib/prompts/__tests__/createTemplatePrompt.test.js +0 -102
- package/lib/prompts/__tests__/downloadProjectPrompt.test.d.ts +0 -1
- package/lib/prompts/__tests__/downloadProjectPrompt.test.js +0 -31
- package/lib/prompts/__tests__/projectAddPrompt.test.d.ts +0 -1
- package/lib/prompts/__tests__/projectAddPrompt.test.js +0 -143
- package/lib/prompts/__tests__/projectsLogsPrompt.test.d.ts +0 -1
- package/lib/prompts/__tests__/projectsLogsPrompt.test.js +0 -37
- package/lib/prompts/__tests__/selectProjectTemplatePrompt.test.d.ts +0 -1
- package/lib/prompts/__tests__/selectProjectTemplatePrompt.test.js +0 -160
- package/lib/sandboxSync.d.ts +0 -4
- package/lib/sandboxSync.js +0 -102
- package/lib/theme/__tests__/migrate.test.d.ts +0 -1
- package/lib/theme/__tests__/migrate.test.js +0 -256
- package/lib/ui/__tests__/SpinniesManager.test.d.ts +0 -1
- package/lib/ui/__tests__/SpinniesManager.test.js +0 -488
- package/lib/ui/__tests__/removeAnsiCodes.test.d.ts +0 -1
- package/lib/ui/__tests__/removeAnsiCodes.test.js +0 -84
- package/mcp-server/tools/cms/__tests__/HsCreateFunctionTool.test.d.ts +0 -1
- package/mcp-server/tools/cms/__tests__/HsCreateFunctionTool.test.js +0 -255
- package/mcp-server/tools/cms/__tests__/HsCreateModuleTool.test.d.ts +0 -1
- package/mcp-server/tools/cms/__tests__/HsCreateModuleTool.test.js +0 -228
- package/mcp-server/tools/cms/__tests__/HsCreateTemplateTool.test.d.ts +0 -1
- package/mcp-server/tools/cms/__tests__/HsCreateTemplateTool.test.js +0 -209
- package/mcp-server/tools/cms/__tests__/HsFunctionLogsTool.test.d.ts +0 -1
- package/mcp-server/tools/cms/__tests__/HsFunctionLogsTool.test.js +0 -187
- package/mcp-server/tools/cms/__tests__/HsListFunctionsTool.test.d.ts +0 -1
- package/mcp-server/tools/cms/__tests__/HsListFunctionsTool.test.js +0 -125
- package/mcp-server/tools/cms/__tests__/HsListTool.test.d.ts +0 -1
- package/mcp-server/tools/cms/__tests__/HsListTool.test.js +0 -125
- package/mcp-server/tools/project/__tests__/AddFeatureToProjectTool.test.d.ts +0 -1
- package/mcp-server/tools/project/__tests__/AddFeatureToProjectTool.test.js +0 -158
- package/mcp-server/tools/project/__tests__/CreateProjectTool.test.d.ts +0 -1
- package/mcp-server/tools/project/__tests__/CreateProjectTool.test.js +0 -133
- package/mcp-server/tools/project/__tests__/CreateTestAccountTool.test.d.ts +0 -1
- package/mcp-server/tools/project/__tests__/CreateTestAccountTool.test.js +0 -462
- package/mcp-server/tools/project/__tests__/DeployProjectTool.test.d.ts +0 -1
- package/mcp-server/tools/project/__tests__/DeployProjectTool.test.js +0 -126
- package/mcp-server/tools/project/__tests__/DocFetchTool.test.d.ts +0 -1
- package/mcp-server/tools/project/__tests__/DocFetchTool.test.js +0 -125
- package/mcp-server/tools/project/__tests__/DocsSearchTool.test.d.ts +0 -1
- package/mcp-server/tools/project/__tests__/DocsSearchTool.test.js +0 -210
- package/mcp-server/tools/project/__tests__/GetApiUsagePatternsByAppIdTool.test.d.ts +0 -1
- package/mcp-server/tools/project/__tests__/GetApiUsagePatternsByAppIdTool.test.js +0 -178
- package/mcp-server/tools/project/__tests__/GetApplicationInfoTool.test.d.ts +0 -1
- package/mcp-server/tools/project/__tests__/GetApplicationInfoTool.test.js +0 -124
- package/mcp-server/tools/project/__tests__/GetBuildLogsTool.test.d.ts +0 -1
- package/mcp-server/tools/project/__tests__/GetBuildLogsTool.test.js +0 -307
- package/mcp-server/tools/project/__tests__/GetBuildStatusTool.test.d.ts +0 -1
- package/mcp-server/tools/project/__tests__/GetBuildStatusTool.test.js +0 -242
- package/mcp-server/tools/project/__tests__/GetConfigValuesTool.test.d.ts +0 -1
- package/mcp-server/tools/project/__tests__/GetConfigValuesTool.test.js +0 -209
- package/mcp-server/tools/project/__tests__/GuidedWalkthroughTool.test.d.ts +0 -1
- package/mcp-server/tools/project/__tests__/GuidedWalkthroughTool.test.js +0 -158
- package/mcp-server/tools/project/__tests__/UploadProjectTools.test.d.ts +0 -1
- package/mcp-server/tools/project/__tests__/UploadProjectTools.test.js +0 -179
- package/mcp-server/tools/project/__tests__/ValidateProjectTool.test.d.ts +0 -1
- package/mcp-server/tools/project/__tests__/ValidateProjectTool.test.js +0 -118
- package/mcp-server/utils/__tests__/command.test.d.ts +0 -1
- package/mcp-server/utils/__tests__/command.test.js +0 -45
- package/mcp-server/utils/__tests__/content.test.d.ts +0 -1
- package/mcp-server/utils/__tests__/content.test.js +0 -164
- package/mcp-server/utils/__tests__/feedbackTracking.test.d.ts +0 -1
- package/mcp-server/utils/__tests__/feedbackTracking.test.js +0 -124
- package/mcp-server/utils/__tests__/project.test.d.ts +0 -1
- package/mcp-server/utils/__tests__/project.test.js +0 -140
- package/mcp-server/utils/project.d.ts +0 -5
- package/mcp-server/utils/project.js +0 -18
|
@@ -1,187 +0,0 @@
|
|
|
1
|
-
import { describe, it, expect, vi, beforeEach } from 'vitest';
|
|
2
|
-
import { createModulePrompt } from '../createModulePrompt.js';
|
|
3
|
-
import { promptUser } from '../promptUtils.js';
|
|
4
|
-
vi.mock('../promptUtils.js');
|
|
5
|
-
const mockPromptUser = vi.mocked(promptUser);
|
|
6
|
-
describe('createModulePrompt', () => {
|
|
7
|
-
beforeEach(() => {
|
|
8
|
-
vi.resetAllMocks();
|
|
9
|
-
});
|
|
10
|
-
describe('when all parameters are provided', () => {
|
|
11
|
-
it('should return provided values without prompting', async () => {
|
|
12
|
-
const commandArgs = {
|
|
13
|
-
moduleLabel: 'My Module',
|
|
14
|
-
reactType: true,
|
|
15
|
-
contentTypes: 'LANDING_PAGE,SITE_PAGE',
|
|
16
|
-
global: false,
|
|
17
|
-
availableForNewContent: true,
|
|
18
|
-
};
|
|
19
|
-
const result = await createModulePrompt(commandArgs);
|
|
20
|
-
expect(mockPromptUser).not.toHaveBeenCalled();
|
|
21
|
-
expect(result).toEqual({
|
|
22
|
-
moduleLabel: 'My Module',
|
|
23
|
-
reactType: true,
|
|
24
|
-
contentTypes: ['LANDING_PAGE', 'SITE_PAGE'],
|
|
25
|
-
global: false,
|
|
26
|
-
availableForNewContent: true,
|
|
27
|
-
});
|
|
28
|
-
});
|
|
29
|
-
it('should use default values when optional parameters not provided', async () => {
|
|
30
|
-
const commandArgs = {
|
|
31
|
-
moduleLabel: 'My Module',
|
|
32
|
-
};
|
|
33
|
-
mockPromptUser.mockResolvedValue({
|
|
34
|
-
reactType: false,
|
|
35
|
-
contentTypes: ['ANY'],
|
|
36
|
-
global: false,
|
|
37
|
-
availableForNewContent: true,
|
|
38
|
-
});
|
|
39
|
-
const result = await createModulePrompt(commandArgs);
|
|
40
|
-
expect(mockPromptUser).toHaveBeenCalledWith([
|
|
41
|
-
expect.objectContaining({ name: 'reactType' }),
|
|
42
|
-
expect.objectContaining({ name: 'contentTypes' }),
|
|
43
|
-
expect.objectContaining({ name: 'global' }),
|
|
44
|
-
expect.objectContaining({ name: 'availableForNewContent' }),
|
|
45
|
-
]);
|
|
46
|
-
expect(result).toEqual({
|
|
47
|
-
moduleLabel: 'My Module',
|
|
48
|
-
reactType: false,
|
|
49
|
-
contentTypes: ['ANY'],
|
|
50
|
-
global: false,
|
|
51
|
-
availableForNewContent: true,
|
|
52
|
-
});
|
|
53
|
-
});
|
|
54
|
-
it('should parse contentTypes string correctly', async () => {
|
|
55
|
-
const commandArgs = {
|
|
56
|
-
moduleLabel: 'Test Module',
|
|
57
|
-
contentTypes: 'BLOG_POST, EMAIL, LANDING_PAGE',
|
|
58
|
-
};
|
|
59
|
-
mockPromptUser.mockResolvedValue({
|
|
60
|
-
reactType: false,
|
|
61
|
-
global: false,
|
|
62
|
-
availableForNewContent: true,
|
|
63
|
-
});
|
|
64
|
-
const result = await createModulePrompt(commandArgs);
|
|
65
|
-
expect(result.contentTypes).toEqual([
|
|
66
|
-
'BLOG_POST',
|
|
67
|
-
'EMAIL',
|
|
68
|
-
'LANDING_PAGE',
|
|
69
|
-
]);
|
|
70
|
-
});
|
|
71
|
-
});
|
|
72
|
-
describe('when some parameters are missing', () => {
|
|
73
|
-
it('should only prompt for missing parameters', async () => {
|
|
74
|
-
const commandArgs = {
|
|
75
|
-
moduleLabel: 'My Module',
|
|
76
|
-
reactType: true,
|
|
77
|
-
};
|
|
78
|
-
mockPromptUser.mockResolvedValue({
|
|
79
|
-
contentTypes: ['SITE_PAGE'],
|
|
80
|
-
global: true,
|
|
81
|
-
availableForNewContent: false,
|
|
82
|
-
});
|
|
83
|
-
const result = await createModulePrompt(commandArgs);
|
|
84
|
-
expect(mockPromptUser).toHaveBeenCalledWith([
|
|
85
|
-
expect.objectContaining({ name: 'contentTypes' }),
|
|
86
|
-
expect.objectContaining({ name: 'global' }),
|
|
87
|
-
expect.objectContaining({ name: 'availableForNewContent' }),
|
|
88
|
-
]);
|
|
89
|
-
expect(result).toEqual({
|
|
90
|
-
moduleLabel: 'My Module',
|
|
91
|
-
reactType: true,
|
|
92
|
-
contentTypes: ['SITE_PAGE'],
|
|
93
|
-
global: true,
|
|
94
|
-
availableForNewContent: false,
|
|
95
|
-
});
|
|
96
|
-
});
|
|
97
|
-
});
|
|
98
|
-
describe('when no parameters are provided', () => {
|
|
99
|
-
it('should prompt for all parameters', async () => {
|
|
100
|
-
mockPromptUser.mockResolvedValue({
|
|
101
|
-
moduleLabel: 'Prompted Module',
|
|
102
|
-
reactType: false,
|
|
103
|
-
contentTypes: ['ANY'],
|
|
104
|
-
global: false,
|
|
105
|
-
availableForNewContent: true,
|
|
106
|
-
});
|
|
107
|
-
const result = await createModulePrompt();
|
|
108
|
-
expect(mockPromptUser).toHaveBeenCalledWith([
|
|
109
|
-
expect.objectContaining({ name: 'moduleLabel' }),
|
|
110
|
-
expect.objectContaining({ name: 'reactType' }),
|
|
111
|
-
expect.objectContaining({ name: 'contentTypes' }),
|
|
112
|
-
expect.objectContaining({ name: 'global' }),
|
|
113
|
-
expect.objectContaining({ name: 'availableForNewContent' }),
|
|
114
|
-
]);
|
|
115
|
-
expect(result).toEqual({
|
|
116
|
-
moduleLabel: 'Prompted Module',
|
|
117
|
-
reactType: false,
|
|
118
|
-
contentTypes: ['ANY'],
|
|
119
|
-
global: false,
|
|
120
|
-
availableForNewContent: true,
|
|
121
|
-
});
|
|
122
|
-
});
|
|
123
|
-
});
|
|
124
|
-
describe('parameter precedence', () => {
|
|
125
|
-
it('should prioritize command args over prompted values', async () => {
|
|
126
|
-
const commandArgs = {
|
|
127
|
-
moduleLabel: 'Args Module',
|
|
128
|
-
global: true,
|
|
129
|
-
};
|
|
130
|
-
mockPromptUser.mockResolvedValue({
|
|
131
|
-
reactType: false,
|
|
132
|
-
contentTypes: ['EMAIL'],
|
|
133
|
-
availableForNewContent: false,
|
|
134
|
-
});
|
|
135
|
-
const result = await createModulePrompt(commandArgs);
|
|
136
|
-
expect(result).toEqual({
|
|
137
|
-
moduleLabel: 'Args Module', // from commandArgs
|
|
138
|
-
reactType: false, // from prompt
|
|
139
|
-
contentTypes: ['EMAIL'], // from prompt
|
|
140
|
-
global: true, // from commandArgs
|
|
141
|
-
availableForNewContent: false, // from prompt
|
|
142
|
-
});
|
|
143
|
-
});
|
|
144
|
-
it('should handle boolean false values correctly', async () => {
|
|
145
|
-
const commandArgs = {
|
|
146
|
-
moduleLabel: 'Test Module',
|
|
147
|
-
reactType: false,
|
|
148
|
-
contentTypes: 'ANY',
|
|
149
|
-
global: false,
|
|
150
|
-
availableForNewContent: false,
|
|
151
|
-
};
|
|
152
|
-
const result = await createModulePrompt(commandArgs);
|
|
153
|
-
expect(mockPromptUser).not.toHaveBeenCalled();
|
|
154
|
-
expect(result).toEqual({
|
|
155
|
-
moduleLabel: 'Test Module',
|
|
156
|
-
reactType: false,
|
|
157
|
-
contentTypes: ['ANY'],
|
|
158
|
-
global: false,
|
|
159
|
-
availableForNewContent: false,
|
|
160
|
-
});
|
|
161
|
-
});
|
|
162
|
-
it('should handle mixed scenario with partial command args and prompting', async () => {
|
|
163
|
-
const commandArgs = {
|
|
164
|
-
moduleLabel: 'Partial Module',
|
|
165
|
-
contentTypes: 'BLOG_POST,BLOG_LISTING',
|
|
166
|
-
};
|
|
167
|
-
mockPromptUser.mockResolvedValue({
|
|
168
|
-
reactType: true,
|
|
169
|
-
global: false,
|
|
170
|
-
availableForNewContent: true,
|
|
171
|
-
});
|
|
172
|
-
const result = await createModulePrompt(commandArgs);
|
|
173
|
-
expect(mockPromptUser).toHaveBeenCalledWith([
|
|
174
|
-
expect.objectContaining({ name: 'reactType' }),
|
|
175
|
-
expect.objectContaining({ name: 'global' }),
|
|
176
|
-
expect.objectContaining({ name: 'availableForNewContent' }),
|
|
177
|
-
]);
|
|
178
|
-
expect(result).toEqual({
|
|
179
|
-
moduleLabel: 'Partial Module', // from commandArgs
|
|
180
|
-
reactType: true, // from prompt
|
|
181
|
-
contentTypes: ['BLOG_POST', 'BLOG_LISTING'], // from commandArgs (parsed)
|
|
182
|
-
global: false, // from prompt
|
|
183
|
-
availableForNewContent: true, // from prompt
|
|
184
|
-
});
|
|
185
|
-
});
|
|
186
|
-
});
|
|
187
|
-
});
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
|
@@ -1,102 +0,0 @@
|
|
|
1
|
-
import { describe, it, expect, vi, beforeEach } from 'vitest';
|
|
2
|
-
import { createTemplatePrompt } from '../createTemplatePrompt.js';
|
|
3
|
-
import { promptUser } from '../promptUtils.js';
|
|
4
|
-
vi.mock('../promptUtils.js');
|
|
5
|
-
const mockPromptUser = vi.mocked(promptUser);
|
|
6
|
-
describe('createTemplatePrompt', () => {
|
|
7
|
-
beforeEach(() => {
|
|
8
|
-
vi.resetAllMocks();
|
|
9
|
-
});
|
|
10
|
-
describe('when templateType is provided', () => {
|
|
11
|
-
it('should return provided templateType without prompting', async () => {
|
|
12
|
-
const commandArgs = {
|
|
13
|
-
templateType: 'page-template',
|
|
14
|
-
};
|
|
15
|
-
const result = await createTemplatePrompt(commandArgs);
|
|
16
|
-
expect(mockPromptUser).not.toHaveBeenCalled();
|
|
17
|
-
expect(result).toEqual({
|
|
18
|
-
templateType: 'page-template',
|
|
19
|
-
});
|
|
20
|
-
});
|
|
21
|
-
it('should work with different template types', async () => {
|
|
22
|
-
const testCases = [
|
|
23
|
-
'email-template',
|
|
24
|
-
'partial',
|
|
25
|
-
'global-partial',
|
|
26
|
-
'blog-listing-template',
|
|
27
|
-
'blog-post-template',
|
|
28
|
-
'search-template',
|
|
29
|
-
'section',
|
|
30
|
-
];
|
|
31
|
-
for (const templateType of testCases) {
|
|
32
|
-
const commandArgs = { templateType };
|
|
33
|
-
const result = await createTemplatePrompt(commandArgs);
|
|
34
|
-
expect(mockPromptUser).not.toHaveBeenCalled();
|
|
35
|
-
expect(result).toEqual({ templateType });
|
|
36
|
-
vi.resetAllMocks();
|
|
37
|
-
}
|
|
38
|
-
});
|
|
39
|
-
});
|
|
40
|
-
describe('when templateType is not provided', () => {
|
|
41
|
-
it('should prompt for templateType', async () => {
|
|
42
|
-
mockPromptUser.mockResolvedValue({
|
|
43
|
-
templateType: 'page-template',
|
|
44
|
-
});
|
|
45
|
-
const result = await createTemplatePrompt();
|
|
46
|
-
expect(mockPromptUser).toHaveBeenCalledWith([
|
|
47
|
-
expect.objectContaining({
|
|
48
|
-
name: 'templateType',
|
|
49
|
-
type: 'list',
|
|
50
|
-
choices: expect.any(Array),
|
|
51
|
-
}),
|
|
52
|
-
]);
|
|
53
|
-
expect(result).toEqual({
|
|
54
|
-
templateType: 'page-template',
|
|
55
|
-
});
|
|
56
|
-
});
|
|
57
|
-
it('should prompt when commandArgs is empty', async () => {
|
|
58
|
-
mockPromptUser.mockResolvedValue({
|
|
59
|
-
templateType: 'email-template',
|
|
60
|
-
});
|
|
61
|
-
const result = await createTemplatePrompt({});
|
|
62
|
-
expect(mockPromptUser).toHaveBeenCalledWith([
|
|
63
|
-
expect.objectContaining({ name: 'templateType' }),
|
|
64
|
-
]);
|
|
65
|
-
expect(result).toEqual({
|
|
66
|
-
templateType: 'email-template',
|
|
67
|
-
});
|
|
68
|
-
});
|
|
69
|
-
it('should prompt when templateType is undefined', async () => {
|
|
70
|
-
const commandArgs = {
|
|
71
|
-
templateType: undefined,
|
|
72
|
-
};
|
|
73
|
-
mockPromptUser.mockResolvedValue({
|
|
74
|
-
templateType: 'partial',
|
|
75
|
-
});
|
|
76
|
-
const result = await createTemplatePrompt(commandArgs);
|
|
77
|
-
expect(mockPromptUser).toHaveBeenCalledWith([
|
|
78
|
-
expect.objectContaining({ name: 'templateType' }),
|
|
79
|
-
]);
|
|
80
|
-
expect(result).toEqual({
|
|
81
|
-
templateType: 'partial',
|
|
82
|
-
});
|
|
83
|
-
});
|
|
84
|
-
});
|
|
85
|
-
describe('integration scenarios', () => {
|
|
86
|
-
it('should handle mixed usage patterns', async () => {
|
|
87
|
-
// First call with templateType provided
|
|
88
|
-
let result = await createTemplatePrompt({
|
|
89
|
-
templateType: 'blog-post-template',
|
|
90
|
-
});
|
|
91
|
-
expect(result.templateType).toBe('blog-post-template');
|
|
92
|
-
expect(mockPromptUser).not.toHaveBeenCalled();
|
|
93
|
-
// Second call without templateType
|
|
94
|
-
mockPromptUser.mockResolvedValue({
|
|
95
|
-
templateType: 'section',
|
|
96
|
-
});
|
|
97
|
-
result = await createTemplatePrompt();
|
|
98
|
-
expect(result.templateType).toBe('section');
|
|
99
|
-
expect(mockPromptUser).toHaveBeenCalledTimes(1);
|
|
100
|
-
});
|
|
101
|
-
});
|
|
102
|
-
});
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
|
@@ -1,31 +0,0 @@
|
|
|
1
|
-
import { getConfigAccountIfExists } from '@hubspot/local-dev-lib/config';
|
|
2
|
-
import { fetchProjects } from '@hubspot/local-dev-lib/api/projects';
|
|
3
|
-
import { downloadProjectPrompt } from '../downloadProjectPrompt.js';
|
|
4
|
-
vi.mock('../promptUtils', () => ({
|
|
5
|
-
promptUser: vi.fn().mockResolvedValue({ project: 'test-project' }),
|
|
6
|
-
}));
|
|
7
|
-
vi.mock('@hubspot/local-dev-lib/api/projects', () => ({
|
|
8
|
-
fetchProjects: vi.fn().mockResolvedValue({
|
|
9
|
-
data: { results: [] },
|
|
10
|
-
}),
|
|
11
|
-
}));
|
|
12
|
-
vi.mock('@hubspot/local-dev-lib/config', () => ({
|
|
13
|
-
getConfigAccountIfExists: vi
|
|
14
|
-
.fn()
|
|
15
|
-
.mockImplementation(() => ({ accountId: 123456789 })),
|
|
16
|
-
globalConfigFileExists: vi.fn().mockReturnValue(true),
|
|
17
|
-
}));
|
|
18
|
-
describe('lib/prompts/downloadProjectPrompt', () => {
|
|
19
|
-
it('should honor the account passed as an option', async () => {
|
|
20
|
-
const account = 'Prod';
|
|
21
|
-
await downloadProjectPrompt({ account });
|
|
22
|
-
expect(getConfigAccountIfExists).toHaveBeenCalledTimes(1);
|
|
23
|
-
expect(getConfigAccountIfExists).toHaveBeenCalledWith(account);
|
|
24
|
-
});
|
|
25
|
-
it('should fetch the projects for the correct accountId', async () => {
|
|
26
|
-
const account = 'Prod';
|
|
27
|
-
await downloadProjectPrompt({ account });
|
|
28
|
-
expect(fetchProjects).toHaveBeenCalledTimes(1);
|
|
29
|
-
expect(fetchProjects).toHaveBeenCalledWith(123456789);
|
|
30
|
-
});
|
|
31
|
-
});
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
|
@@ -1,143 +0,0 @@
|
|
|
1
|
-
import { Separator } from '@inquirer/prompts';
|
|
2
|
-
import { projectAddPromptV2 } from '../projectAddPrompt.js';
|
|
3
|
-
import { promptUser } from '../promptUtils.js';
|
|
4
|
-
vi.mock('../promptUtils');
|
|
5
|
-
const mockedPromptUser = vi.mocked(promptUser);
|
|
6
|
-
describe('lib/prompts/projectAddPrompt', () => {
|
|
7
|
-
const mockComponentTemplate = {
|
|
8
|
-
label: 'Test Module',
|
|
9
|
-
path: 'test-module',
|
|
10
|
-
type: 'module',
|
|
11
|
-
supportedAuthTypes: ['oauth'],
|
|
12
|
-
supportedDistributions: ['private'],
|
|
13
|
-
};
|
|
14
|
-
const mockComponentTemplateWithCliSelector = {
|
|
15
|
-
label: 'Workflow Action Tool',
|
|
16
|
-
path: 'workflow-action-tool',
|
|
17
|
-
type: 'workflow-action',
|
|
18
|
-
cliSelector: 'workflow-action-tool',
|
|
19
|
-
supportedAuthTypes: ['oauth'],
|
|
20
|
-
supportedDistributions: ['private'],
|
|
21
|
-
};
|
|
22
|
-
describe('projectAddPromptV2()', () => {
|
|
23
|
-
beforeEach(() => {
|
|
24
|
-
// Mock returns empty result, logic will use selectedComponents when selectedFeatures provided
|
|
25
|
-
mockedPromptUser.mockResolvedValue({});
|
|
26
|
-
});
|
|
27
|
-
it('should select component based on cliSelector when provided', async () => {
|
|
28
|
-
const templateChoice = {
|
|
29
|
-
name: 'Workflow Action Tool',
|
|
30
|
-
value: mockComponentTemplateWithCliSelector,
|
|
31
|
-
};
|
|
32
|
-
const components = [templateChoice];
|
|
33
|
-
const selectedFeatures = ['workflow-action-tool'];
|
|
34
|
-
const result = await projectAddPromptV2(components, selectedFeatures);
|
|
35
|
-
expect(result.componentTemplate).toEqual([
|
|
36
|
-
mockComponentTemplateWithCliSelector,
|
|
37
|
-
]);
|
|
38
|
-
expect(mockedPromptUser).toHaveBeenCalledWith([
|
|
39
|
-
expect.objectContaining({
|
|
40
|
-
name: 'componentTemplate',
|
|
41
|
-
when: false, // selectedFeatures provided, so skip prompt
|
|
42
|
-
}),
|
|
43
|
-
]);
|
|
44
|
-
});
|
|
45
|
-
it('should select component based on type when cliSelector not provided', async () => {
|
|
46
|
-
const templateChoice = {
|
|
47
|
-
name: 'Test Module',
|
|
48
|
-
value: mockComponentTemplate,
|
|
49
|
-
};
|
|
50
|
-
const components = [templateChoice];
|
|
51
|
-
const selectedFeatures = ['module'];
|
|
52
|
-
const result = await projectAddPromptV2(components, selectedFeatures);
|
|
53
|
-
expect(result.componentTemplate).toEqual([mockComponentTemplate]);
|
|
54
|
-
expect(mockedPromptUser).toHaveBeenCalledWith([
|
|
55
|
-
expect.objectContaining({
|
|
56
|
-
name: 'componentTemplate',
|
|
57
|
-
when: false, // selectedFeatures provided and selectedComponents found
|
|
58
|
-
}),
|
|
59
|
-
]);
|
|
60
|
-
});
|
|
61
|
-
it('should prefer cliSelector over type when both are available', async () => {
|
|
62
|
-
const templateChoice = {
|
|
63
|
-
name: 'Workflow Action Tool',
|
|
64
|
-
value: mockComponentTemplateWithCliSelector,
|
|
65
|
-
};
|
|
66
|
-
const components = [templateChoice];
|
|
67
|
-
const selectedFeatures = ['workflow-action-tool']; // matches cliSelector
|
|
68
|
-
const result = await projectAddPromptV2(components, selectedFeatures);
|
|
69
|
-
expect(result.componentTemplate).toEqual([
|
|
70
|
-
mockComponentTemplateWithCliSelector,
|
|
71
|
-
]);
|
|
72
|
-
});
|
|
73
|
-
it('should not select component when neither cliSelector nor type matches', async () => {
|
|
74
|
-
const templateChoice = {
|
|
75
|
-
name: 'Test Module',
|
|
76
|
-
value: mockComponentTemplate,
|
|
77
|
-
};
|
|
78
|
-
const components = [templateChoice];
|
|
79
|
-
const selectedFeatures = ['non-matching-feature'];
|
|
80
|
-
mockedPromptUser.mockResolvedValue({ componentTemplate: [] });
|
|
81
|
-
const result = await projectAddPromptV2(components, selectedFeatures);
|
|
82
|
-
expect(result.componentTemplate).toEqual([]);
|
|
83
|
-
});
|
|
84
|
-
it('should throw error when selected feature component is disabled', async () => {
|
|
85
|
-
const disabledTemplateChoice = {
|
|
86
|
-
name: 'Disabled Component',
|
|
87
|
-
value: mockComponentTemplateWithCliSelector,
|
|
88
|
-
disabled: 'Component is disabled for testing',
|
|
89
|
-
};
|
|
90
|
-
const components = [disabledTemplateChoice];
|
|
91
|
-
const selectedFeatures = ['workflow-action-tool'];
|
|
92
|
-
await expect(projectAddPromptV2(components, selectedFeatures)).rejects.toThrow(/Cannot.*feature.*workflow-action/);
|
|
93
|
-
});
|
|
94
|
-
it('should handle multiple components with mixed cliSelector availability', async () => {
|
|
95
|
-
const choice1 = {
|
|
96
|
-
name: 'Test Module',
|
|
97
|
-
value: mockComponentTemplate,
|
|
98
|
-
};
|
|
99
|
-
const choice2 = {
|
|
100
|
-
name: 'Workflow Action Tool',
|
|
101
|
-
value: mockComponentTemplateWithCliSelector,
|
|
102
|
-
};
|
|
103
|
-
const components = [choice1, choice2];
|
|
104
|
-
const selectedFeatures = ['module', 'workflow-action-tool'];
|
|
105
|
-
const result = await projectAddPromptV2(components, selectedFeatures);
|
|
106
|
-
expect(result.componentTemplate).toEqual([
|
|
107
|
-
mockComponentTemplate,
|
|
108
|
-
mockComponentTemplateWithCliSelector,
|
|
109
|
-
]);
|
|
110
|
-
});
|
|
111
|
-
it('should skip Separator instances when processing components', async () => {
|
|
112
|
-
const separator = new Separator();
|
|
113
|
-
const templateChoice = {
|
|
114
|
-
name: 'Test Module',
|
|
115
|
-
value: mockComponentTemplate,
|
|
116
|
-
};
|
|
117
|
-
const components = [separator, templateChoice];
|
|
118
|
-
const selectedFeatures = ['module'];
|
|
119
|
-
const result = await projectAddPromptV2(components, selectedFeatures);
|
|
120
|
-
expect(result.componentTemplate).toEqual([mockComponentTemplate]);
|
|
121
|
-
});
|
|
122
|
-
it('should prompt user when no selectedFeatures provided', async () => {
|
|
123
|
-
const templateChoice = {
|
|
124
|
-
name: 'Test Module',
|
|
125
|
-
value: mockComponentTemplate,
|
|
126
|
-
};
|
|
127
|
-
const components = [templateChoice];
|
|
128
|
-
const selectedFeatures = undefined;
|
|
129
|
-
mockedPromptUser.mockResolvedValue({
|
|
130
|
-
componentTemplate: [mockComponentTemplate],
|
|
131
|
-
});
|
|
132
|
-
const result = await projectAddPromptV2(components, selectedFeatures);
|
|
133
|
-
expect(mockedPromptUser).toHaveBeenCalledWith([
|
|
134
|
-
expect.objectContaining({
|
|
135
|
-
name: 'componentTemplate',
|
|
136
|
-
type: 'checkbox',
|
|
137
|
-
choices: components,
|
|
138
|
-
}),
|
|
139
|
-
]);
|
|
140
|
-
expect(result.componentTemplate).toEqual([mockComponentTemplate]);
|
|
141
|
-
});
|
|
142
|
-
});
|
|
143
|
-
});
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
|
@@ -1,37 +0,0 @@
|
|
|
1
|
-
import { projectLogsPrompt } from '../projectsLogsPrompt.js';
|
|
2
|
-
import { promptUser } from '../promptUtils.js';
|
|
3
|
-
import chalk from 'chalk';
|
|
4
|
-
vi.mock('../promptUtils');
|
|
5
|
-
describe('lib/prompts/projectsLogsPrompt', () => {
|
|
6
|
-
it('should return undefined functionName when functionChoices is undefined', async () => {
|
|
7
|
-
const actual = await projectLogsPrompt({ functionChoices: undefined });
|
|
8
|
-
expect(actual).toEqual({});
|
|
9
|
-
expect(promptUser).not.toHaveBeenCalled();
|
|
10
|
-
});
|
|
11
|
-
it('should return the functionName without prompting when there is only one functionChoice', async () => {
|
|
12
|
-
const functionChoice = 'this-is-the-only-function';
|
|
13
|
-
const { functionName } = await projectLogsPrompt({
|
|
14
|
-
functionChoices: [functionChoice],
|
|
15
|
-
});
|
|
16
|
-
expect(functionName).toEqual(functionChoice);
|
|
17
|
-
expect(promptUser).not.toHaveBeenCalled();
|
|
18
|
-
});
|
|
19
|
-
it('should prompt the user if there is more than one choice', async () => {
|
|
20
|
-
const functionChoices = ['choice 1', 'choice 2'];
|
|
21
|
-
const projectName = 'my cool project';
|
|
22
|
-
await projectLogsPrompt({
|
|
23
|
-
functionChoices,
|
|
24
|
-
projectName,
|
|
25
|
-
});
|
|
26
|
-
expect(promptUser).toHaveBeenCalledTimes(1);
|
|
27
|
-
expect(promptUser).toHaveBeenLastCalledWith(expect.arrayContaining([
|
|
28
|
-
expect.objectContaining({
|
|
29
|
-
name: 'functionName',
|
|
30
|
-
type: 'list',
|
|
31
|
-
message: `[--function] Select function in ${chalk.bold(projectName)} project`,
|
|
32
|
-
when: expect.any(Function),
|
|
33
|
-
choices: functionChoices,
|
|
34
|
-
}),
|
|
35
|
-
]));
|
|
36
|
-
});
|
|
37
|
-
});
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
|
@@ -1,160 +0,0 @@
|
|
|
1
|
-
import { Separator } from '@inquirer/prompts';
|
|
2
|
-
import { selectProjectTemplatePrompt } from '../selectProjectTemplatePrompt.js';
|
|
3
|
-
import { promptUser } from '../promptUtils.js';
|
|
4
|
-
vi.mock('../promptUtils');
|
|
5
|
-
const mockedPromptUser = vi.mocked(promptUser);
|
|
6
|
-
describe('lib/prompts/selectProjectTemplatePrompt', () => {
|
|
7
|
-
const mockComponentTemplate = {
|
|
8
|
-
label: 'Test Module',
|
|
9
|
-
path: 'test-module',
|
|
10
|
-
type: 'module',
|
|
11
|
-
supportedAuthTypes: ['oauth'],
|
|
12
|
-
supportedDistributions: ['private'],
|
|
13
|
-
};
|
|
14
|
-
const mockComponentTemplateWithCliSelector = {
|
|
15
|
-
label: 'Workflow Action Tool',
|
|
16
|
-
path: 'workflow-action-tool',
|
|
17
|
-
type: 'workflow-action',
|
|
18
|
-
cliSelector: 'workflow-action-tool',
|
|
19
|
-
supportedAuthTypes: ['oauth'],
|
|
20
|
-
supportedDistributions: ['private'],
|
|
21
|
-
};
|
|
22
|
-
beforeEach(() => {
|
|
23
|
-
mockedPromptUser.mockResolvedValue({});
|
|
24
|
-
});
|
|
25
|
-
describe('selectProjectTemplatePrompt with component templates', () => {
|
|
26
|
-
it('should select component based on cliSelector when provided', async () => {
|
|
27
|
-
const templateChoice = {
|
|
28
|
-
name: 'Workflow Action Tool',
|
|
29
|
-
value: mockComponentTemplateWithCliSelector,
|
|
30
|
-
};
|
|
31
|
-
const componentTemplates = [templateChoice];
|
|
32
|
-
const promptOptions = {
|
|
33
|
-
features: ['workflow-action-tool'],
|
|
34
|
-
};
|
|
35
|
-
const result = await selectProjectTemplatePrompt(promptOptions, undefined, componentTemplates);
|
|
36
|
-
expect(result.componentTemplates).toEqual([
|
|
37
|
-
mockComponentTemplateWithCliSelector,
|
|
38
|
-
]);
|
|
39
|
-
expect(mockedPromptUser).toHaveBeenCalledWith([
|
|
40
|
-
expect.objectContaining({ name: 'projectTemplate' }),
|
|
41
|
-
expect.objectContaining({ name: 'componentTemplates' }),
|
|
42
|
-
]);
|
|
43
|
-
});
|
|
44
|
-
it('should select component based on type when cliSelector not provided', async () => {
|
|
45
|
-
const templateChoice = {
|
|
46
|
-
name: 'Test Module',
|
|
47
|
-
value: mockComponentTemplate,
|
|
48
|
-
};
|
|
49
|
-
const componentTemplates = [templateChoice];
|
|
50
|
-
const promptOptions = {
|
|
51
|
-
features: ['module'],
|
|
52
|
-
};
|
|
53
|
-
const result = await selectProjectTemplatePrompt(promptOptions, undefined, componentTemplates);
|
|
54
|
-
expect(result.componentTemplates).toEqual([mockComponentTemplate]);
|
|
55
|
-
});
|
|
56
|
-
it('should prefer cliSelector over type when both are available', async () => {
|
|
57
|
-
const templateChoice = {
|
|
58
|
-
name: 'Workflow Action Tool',
|
|
59
|
-
value: mockComponentTemplateWithCliSelector,
|
|
60
|
-
};
|
|
61
|
-
const componentTemplates = [templateChoice];
|
|
62
|
-
const promptOptions = {
|
|
63
|
-
features: ['workflow-action-tool'], // matches cliSelector, not type
|
|
64
|
-
};
|
|
65
|
-
const result = await selectProjectTemplatePrompt(promptOptions, undefined, componentTemplates);
|
|
66
|
-
expect(result.componentTemplates).toEqual([
|
|
67
|
-
mockComponentTemplateWithCliSelector,
|
|
68
|
-
]);
|
|
69
|
-
});
|
|
70
|
-
it('should not select component when neither cliSelector nor type matches', async () => {
|
|
71
|
-
const templateChoice = {
|
|
72
|
-
name: 'Test Module',
|
|
73
|
-
value: mockComponentTemplate,
|
|
74
|
-
};
|
|
75
|
-
const componentTemplates = [templateChoice];
|
|
76
|
-
const promptOptions = {
|
|
77
|
-
features: ['non-matching-feature'],
|
|
78
|
-
};
|
|
79
|
-
const result = await selectProjectTemplatePrompt(promptOptions, undefined, componentTemplates);
|
|
80
|
-
expect(result.componentTemplates).toEqual([]);
|
|
81
|
-
});
|
|
82
|
-
it('should throw error when selected feature component is disabled', async () => {
|
|
83
|
-
const disabledTemplateChoice = {
|
|
84
|
-
name: 'Disabled Component',
|
|
85
|
-
value: mockComponentTemplateWithCliSelector,
|
|
86
|
-
disabled: 'Component is disabled for testing',
|
|
87
|
-
};
|
|
88
|
-
const componentTemplates = [disabledTemplateChoice];
|
|
89
|
-
const promptOptions = {
|
|
90
|
-
features: ['workflow-action-tool'],
|
|
91
|
-
};
|
|
92
|
-
await expect(selectProjectTemplatePrompt(promptOptions, undefined, componentTemplates)).rejects.toThrow(/Cannot create project with template.*workflow-action/);
|
|
93
|
-
});
|
|
94
|
-
it('should handle multiple components with mixed cliSelector availability', async () => {
|
|
95
|
-
const choice1 = {
|
|
96
|
-
name: 'Test Module',
|
|
97
|
-
value: mockComponentTemplate,
|
|
98
|
-
};
|
|
99
|
-
const choice2 = {
|
|
100
|
-
name: 'Workflow Action Tool',
|
|
101
|
-
value: mockComponentTemplateWithCliSelector,
|
|
102
|
-
};
|
|
103
|
-
const componentTemplates = [choice1, choice2];
|
|
104
|
-
const promptOptions = {
|
|
105
|
-
features: ['module', 'workflow-action-tool'],
|
|
106
|
-
};
|
|
107
|
-
const result = await selectProjectTemplatePrompt(promptOptions, undefined, componentTemplates);
|
|
108
|
-
expect(result.componentTemplates).toEqual([
|
|
109
|
-
mockComponentTemplate,
|
|
110
|
-
mockComponentTemplateWithCliSelector,
|
|
111
|
-
]);
|
|
112
|
-
});
|
|
113
|
-
it('should skip Separator instances when processing components', async () => {
|
|
114
|
-
const separator = new Separator();
|
|
115
|
-
const templateChoice = {
|
|
116
|
-
name: 'Test Module',
|
|
117
|
-
value: mockComponentTemplate,
|
|
118
|
-
};
|
|
119
|
-
const componentTemplates = [separator, templateChoice];
|
|
120
|
-
const promptOptions = {
|
|
121
|
-
features: ['module'],
|
|
122
|
-
};
|
|
123
|
-
const result = await selectProjectTemplatePrompt(promptOptions, undefined, componentTemplates);
|
|
124
|
-
expect(result.componentTemplates).toEqual([mockComponentTemplate]);
|
|
125
|
-
});
|
|
126
|
-
it('should prompt user when no features provided', async () => {
|
|
127
|
-
const templateChoice = {
|
|
128
|
-
name: 'Test Module',
|
|
129
|
-
value: mockComponentTemplate,
|
|
130
|
-
};
|
|
131
|
-
const componentTemplates = [templateChoice];
|
|
132
|
-
const promptOptions = {};
|
|
133
|
-
mockedPromptUser.mockResolvedValue({
|
|
134
|
-
componentTemplates: [mockComponentTemplate],
|
|
135
|
-
});
|
|
136
|
-
const result = await selectProjectTemplatePrompt(promptOptions, undefined, componentTemplates);
|
|
137
|
-
expect(mockedPromptUser).toHaveBeenCalledWith([
|
|
138
|
-
expect.objectContaining({ name: 'projectTemplate' }),
|
|
139
|
-
expect.objectContaining({
|
|
140
|
-
name: 'componentTemplates',
|
|
141
|
-
type: 'checkbox',
|
|
142
|
-
choices: componentTemplates,
|
|
143
|
-
}),
|
|
144
|
-
]);
|
|
145
|
-
expect(result.componentTemplates).toEqual([mockComponentTemplate]);
|
|
146
|
-
});
|
|
147
|
-
it('should handle empty componentTemplates selection', async () => {
|
|
148
|
-
const templateChoice = {
|
|
149
|
-
name: 'Test Module',
|
|
150
|
-
value: mockComponentTemplate,
|
|
151
|
-
};
|
|
152
|
-
const componentTemplates = [templateChoice];
|
|
153
|
-
const promptOptions = {
|
|
154
|
-
features: ['non-matching-feature'],
|
|
155
|
-
};
|
|
156
|
-
const result = await selectProjectTemplatePrompt(promptOptions, undefined, componentTemplates);
|
|
157
|
-
expect(result.componentTemplates).toEqual([]);
|
|
158
|
-
});
|
|
159
|
-
});
|
|
160
|
-
});
|