diff --git a/packages/nx/src/command-line/add/add.ts b/packages/nx/src/command-line/add/add.ts index b227b11d3b6025..20c771b43d17ee 100644 --- a/packages/nx/src/command-line/add/add.ts +++ b/packages/nx/src/command-line/add/add.ts @@ -16,7 +16,7 @@ import { workspaceRoot } from '../../utils/workspace-root'; import type { AddOptions } from './command-object'; import { normalizeVersionForNxJson } from '../init/implementation/dot-nx/add-nx-scripts'; -export function addHandler(options: AddOptions): Promise { +export function addHandler(options: AddOptions): Promise { if (options.verbose) { process.env.NX_VERBOSE_LOGGING = 'true'; } diff --git a/packages/nx/src/command-line/add/command-object.ts b/packages/nx/src/command-line/add/command-object.ts index 21bbbae903e077..a06d51dd2ae2f5 100644 --- a/packages/nx/src/command-line/add/command-object.ts +++ b/packages/nx/src/command-line/add/command-object.ts @@ -47,6 +47,9 @@ export const yargsAddCommand: CommandModule< '$0 add @nx/react@17.0.0', 'Install version `17.0.0` of the `@nx/react` package and run its `@nx/react:init` generator' ) as any, - handler: (args) => - import('./add').then((m) => m.addHandler(withOverrides(args))), + handler: async (args) => { + process.exit( + await import('./add').then((m) => m.addHandler(withOverrides(args))) + ); + }, }; diff --git a/packages/nx/src/command-line/affected/command-object.ts b/packages/nx/src/command-line/affected/command-object.ts index 268a040126f208..167017e30a0dd5 100644 --- a/packages/nx/src/command-line/affected/command-object.ts +++ b/packages/nx/src/command-line/affected/command-object.ts @@ -37,7 +37,7 @@ export const yargsAffectedCommand: CommandModule = { 'affected' ), handler: async (args) => { - return handleErrors( + const exitCode = await handleErrors( (args.verbose as boolean) ?? process.env.NX_VERBOSE_LOGGING === 'true', async () => { return (await import('./affected')).affected( @@ -46,6 +46,7 @@ export const yargsAffectedCommand: CommandModule = { ); } ); + process.exit(exitCode); }, }; @@ -60,7 +61,7 @@ export const yargsAffectedTestCommand: CommandModule = { 'affected' ), handler: async (args) => { - return handleErrors( + const exitCode = await handleErrors( (args.verbose as boolean) ?? process.env.NX_VERBOSE_LOGGING === 'true', async () => { return (await import('./affected')).affected('affected', { @@ -69,6 +70,7 @@ export const yargsAffectedTestCommand: CommandModule = { }); } ); + process.exit(exitCode); }, }; @@ -83,7 +85,7 @@ export const yargsAffectedBuildCommand: CommandModule = { 'affected' ), handler: async (args) => { - return handleErrors( + const exitCode = await handleErrors( (args.verbose as boolean) ?? process.env.NX_VERBOSE_LOGGING === 'true', async () => { return (await import('./affected')).affected('affected', { @@ -92,6 +94,7 @@ export const yargsAffectedBuildCommand: CommandModule = { }); } ); + process.exit(exitCode); }, }; @@ -106,7 +109,7 @@ export const yargsAffectedLintCommand: CommandModule = { 'affected' ), handler: async (args) => { - return handleErrors( + const exitCode = await handleErrors( (args.verbose as boolean) ?? process.env.NX_VERBOSE_LOGGING === 'true', async () => { return (await import('./affected')).affected('affected', { @@ -115,6 +118,7 @@ export const yargsAffectedLintCommand: CommandModule = { }); } ); + process.exit(exitCode); }, }; @@ -129,7 +133,7 @@ export const yargsAffectedE2ECommand: CommandModule = { 'affected' ), handler: async (args) => { - return handleErrors( + const exitCode = await handleErrors( (args.verbose as boolean) ?? process.env.NX_VERBOSE_LOGGING === 'true', async () => { return (await import('./affected')).affected('affected', { @@ -138,5 +142,6 @@ export const yargsAffectedE2ECommand: CommandModule = { }); } ); + process.exit(exitCode); }, }; diff --git a/packages/nx/src/command-line/deprecated/command-objects.ts b/packages/nx/src/command-line/deprecated/command-objects.ts index ec19de708ac429..1ab2c0818a1f01 100644 --- a/packages/nx/src/command-line/deprecated/command-objects.ts +++ b/packages/nx/src/command-line/deprecated/command-objects.ts @@ -19,10 +19,9 @@ export const yargsAffectedGraphCommand: CommandModule = { describe: false, aliases: ['affected:dep-graph'], builder: (yargs) => withAffectedOptions(withGraphOptions(yargs)), - handler: (args) => - handleErrors(false, () => { - throw new Error(affectedGraphDeprecationMessage); - }), + handler: (args) => { + throw new Error(affectedGraphDeprecationMessage); + }, deprecated: affectedGraphDeprecationMessage, }; @@ -45,9 +44,8 @@ export const yargsPrintAffectedCommand: CommandModule = { describe: 'Select the type of projects to be returned (e.g., --type=app)', }), - handler: (args) => - handleErrors(false, () => { - throw new Error(printAffectedDeprecationMessage); - }), + handler: (args) => { + throw new Error(printAffectedDeprecationMessage); + }, deprecated: printAffectedDeprecationMessage, }; diff --git a/packages/nx/src/command-line/run-many/command-object.ts b/packages/nx/src/command-line/run-many/command-object.ts index 4cc6ff2f89043c..c1a734f887742c 100644 --- a/packages/nx/src/command-line/run-many/command-object.ts +++ b/packages/nx/src/command-line/run-many/command-object.ts @@ -21,11 +21,13 @@ export const yargsRunManyCommand: CommandModule = { ), 'run-many' ), - handler: async (args) => - await handleErrors( + handler: async (args) => { + const exitCode = await handleErrors( (args.verbose as boolean) ?? process.env.NX_VERBOSE_LOGGING === 'true', async () => { (await import('./run-many')).runMany(withOverrides(args)); } - ), + ); + process.exit(exitCode); + }, }; diff --git a/packages/nx/src/command-line/run/command-object.ts b/packages/nx/src/command-line/run/command-object.ts index 571dfd33499b50..04b471edc946a7 100644 --- a/packages/nx/src/command-line/run/command-object.ts +++ b/packages/nx/src/command-line/run/command-object.ts @@ -16,13 +16,15 @@ export const yargsRunCommand: CommandModule = { You can skip the use of Nx cache by using the --skip-nx-cache option.`, builder: (yargs) => withRunOneOptions(withBatch(yargs)), - handler: async (args) => - await handleErrors( + handler: async (args) => { + const exitCode = await handleErrors( (args.verbose as boolean) ?? process.env.NX_VERBOSE_LOGGING === 'true', async () => { (await import('./run-one')).runOne(process.cwd(), withOverrides(args)); } - ), + ); + process.exit(exitCode); + }, }; /** diff --git a/packages/nx/src/command-line/show/command-object.ts b/packages/nx/src/command-line/show/command-object.ts index 890275b5d05c96..aacc0e9f62ba57 100644 --- a/packages/nx/src/command-line/show/command-object.ts +++ b/packages/nx/src/command-line/show/command-object.ts @@ -123,15 +123,15 @@ const showProjectsCommand: CommandModule = { '$0 show projects --affected --exclude=*-e2e', 'Show affected projects in the workspace, excluding end-to-end projects' ) as any, - handler: (args) => { - return handleErrors( + handler: async (args) => { + const exitCode = await handleErrors( args.verbose ?? process.env.NX_VERBOSE_LOGGING === 'true', async () => { const { showProjectsHandler } = await import('./projects'); await showProjectsHandler(args); - process.exit(0); } ); + process.exit(exitCode); }, }; @@ -177,14 +177,14 @@ const showProjectCommand: CommandModule = { '$0 show project my-app --web', 'View project information for my-app in the browser' ), - handler: (args) => { - return handleErrors( + handler: async (args) => { + const exitCode = await handleErrors( args.verbose ?? process.env.NX_VERBOSE_LOGGING === 'true', async () => { const { showProjectHandler } = await import('./project'); await showProjectHandler(args); - process.exit(0); } ); + process.exit(exitCode); }, }; diff --git a/packages/nx/src/utils/params.ts b/packages/nx/src/utils/params.ts index daa0237c9b0ac6..81a5d6aaf5dcca 100644 --- a/packages/nx/src/utils/params.ts +++ b/packages/nx/src/utils/params.ts @@ -91,7 +91,11 @@ export type Options = { export async function handleErrors(isVerbose: boolean, fn: Function) { try { - return await fn(); + const result = await fn(); + if (typeof result === 'number') { + return result; + } + return 0; } catch (err) { err ||= new Error('Unknown error caught'); if (err.constructor.name === 'UnsuccessfulWorkflowExecution') {