From 233555c024eb0f939658aea71a6af5d4a9b3ef0d Mon Sep 17 00:00:00 2001 From: Keraito Date: Fri, 21 Sep 2018 19:57:44 +0200 Subject: [PATCH 1/3] Return promise from initiate generator --- lib/cli/lib/initiate.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/cli/lib/initiate.js b/lib/cli/lib/initiate.js index 5f019c21a96f..136a599e8646 100644 --- a/lib/cli/lib/initiate.js +++ b/lib/cli/lib/initiate.js @@ -185,7 +185,7 @@ export default function(options, pkg) { } }; - runGenerator().catch(ex => { + return runGenerator().catch(ex => { logger.error(`\n ${chalk.red(ex.stack)}`); process.exit(1); }); From ced0fcfa168c13d8423ef3d693bb9b5f354101c4 Mon Sep 17 00:00:00 2001 From: Keraito Date: Fri, 21 Sep 2018 19:57:51 +0200 Subject: [PATCH 2/3] Isolate getstorybook code --- lib/cli/bin/generate.js | 69 ++++++++++++++++++++--------------------- 1 file changed, 34 insertions(+), 35 deletions(-) diff --git a/lib/cli/bin/generate.js b/lib/cli/bin/generate.js index 7040af903a21..38020d9295de 100644 --- a/lib/cli/bin/generate.js +++ b/lib/cli/bin/generate.js @@ -12,39 +12,38 @@ if (process.argv[1].includes('getstorybook')) { logger.log(chalk.yellow('The official command to install Storybook from now on is:\n')); codeLog(['storybook init']); logger.log(); - initiate({}, pkg); - process.exit(0); -} - -program - .command('init') - .description('Initialize Storybook into your project.') - .option('-f --force', 'Forcely add storybook') - .option('-s --skip-install', 'Skip installing deps') - .option('-N --use-npm', 'Use npm to install deps') - .option('-p --parser ', 'jscodeshift parser') - .option('-h --html', 'Add storybook for HTML') - .action(options => initiate(options, pkg)); - -program - .command('start') - .description('Start the local Storybook server') - .option('-N --use-npm', 'Use NPM to start the Storybook server') - .action(options => yarnSpawnSync(options, ['run', 'storybook'])); - -program - .command('build') - .description('Build the Storybook static application') - .option('-N --use-npm', 'Use NPM to build the Storybook server') - .action(options => yarnSpawnSync(options, ['build', 'storybook'])); - -program.command('*', { noHelp: true }).action(cmd => { - logger.error('Invalid command: %s.\nSee --help for a list of available commands.', cmd); - process.exit(1); -}); - -program.version(pkg.version).parse(process.argv); - -if (!program.args.length) { - program.help(); + initiate({ force: true }, pkg).then(() => process.exit(0)); +} else { + program + .command('init') + .description('Initialize Storybook into your project.') + .option('-f --force', 'Forcely add storybook') + .option('-s --skip-install', 'Skip installing deps') + .option('-N --use-npm', 'Use npm to install deps') + .option('-p --parser ', 'jscodeshift parser') + .option('-h --html', 'Add storybook for HTML') + .action(options => initiate(options, pkg)); + + program + .command('start') + .description('Start the local Storybook server') + .option('-N --use-npm', 'Use NPM to start the Storybook server') + .action(options => yarnSpawnSync(options, ['run', 'storybook'])); + + program + .command('build') + .description('Build the Storybook static application') + .option('-N --use-npm', 'Use NPM to build the Storybook server') + .action(options => yarnSpawnSync(options, ['build', 'storybook'])); + + program.command('*', { noHelp: true }).action(cmd => { + logger.error('Invalid command: %s.\nSee --help for a list of available commands.', cmd); + process.exit(1); + }); + + program.version(pkg.version).parse(process.argv); + + if (!program.args.length) { + program.help(); + } } From 242dcbd7dd5d7324fadfbebcdd2e7a9995af3da0 Mon Sep 17 00:00:00 2001 From: Keraito Date: Fri, 21 Sep 2018 20:03:31 +0200 Subject: [PATCH 3/3] Remove debugging flag --- lib/cli/bin/generate.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/cli/bin/generate.js b/lib/cli/bin/generate.js index 38020d9295de..f8596afa8d9f 100644 --- a/lib/cli/bin/generate.js +++ b/lib/cli/bin/generate.js @@ -12,7 +12,7 @@ if (process.argv[1].includes('getstorybook')) { logger.log(chalk.yellow('The official command to install Storybook from now on is:\n')); codeLog(['storybook init']); logger.log(); - initiate({ force: true }, pkg).then(() => process.exit(0)); + initiate({}, pkg).then(() => process.exit(0)); } else { program .command('init')