Skip to content

Commit

Permalink
fix(@angular/cli): wait for install to finish before exiting
Browse files Browse the repository at this point in the history
  • Loading branch information
filipesilva authored and Brocco committed Jul 20, 2017
1 parent 5fed3cb commit 3ce685b
Show file tree
Hide file tree
Showing 3 changed files with 26 additions and 24 deletions.
7 changes: 1 addition & 6 deletions packages/@angular/cli/tasks/init.ts
Original file line number Diff line number Diff line change
Expand Up @@ -89,7 +89,7 @@ export default Task.extend({
return installBlueprint.run(blueprintOpts)
.then(function () {
if (!commandOptions.skipInstall) {
return npmInstall.run();
return checkYarnOrCNPM().then(() => npmInstall.run());
}
})
.then(function () {
Expand All @@ -102,11 +102,6 @@ export default Task.extend({
return linkCli.run();
}
})
.then(() => {
if (!commandOptions.skipInstall || commandOptions.linkCli) {
return checkYarnOrCNPM();
}
})
.then(() => {
this.ui.writeLine(chalk.green(`Project '${packageName}' successfully created.`));
});
Expand Down
37 changes: 19 additions & 18 deletions packages/@angular/cli/tasks/npm-install.ts
Original file line number Diff line number Diff line change
@@ -1,34 +1,35 @@
const Task = require('../ember-cli/lib/models/task');
import * as chalk from 'chalk';
import {exec} from 'child_process';
import {checkYarnOrCNPM} from '../utilities/check-package-manager';
import { exec } from 'child_process';


export default Task.extend({
run: function() {
run: function () {
const ui = this.ui;
let packageManager = this.packageManager;
if (packageManager === 'default') {
packageManager = 'npm';
}

return checkYarnOrCNPM().then(function () {
ui.writeLine(chalk.green(`Installing packages for tooling via ${packageManager}.`));
let installCommand = `${packageManager} install`;
if (packageManager === 'npm') {
installCommand = `${packageManager} --quiet install`;
}
ui.writeLine(chalk.green(`Installing packages for tooling via ${packageManager}.`));
let installCommand = `${packageManager} install`;
if (packageManager === 'npm') {
installCommand = `${packageManager} --quiet install`;
}

return new Promise((resolve, reject) => {
exec(installCommand,
(err: NodeJS.ErrnoException, _stdout: string, stderr: string) => {
if (err) {
ui.writeLine(stderr);
const message = 'Package install failed, see above.';
ui.writeLine(chalk.red(message));
throw new Error(message);
} else {
ui.writeLine(chalk.green(`Installed packages for tooling via ${packageManager}.`));
}
});
if (err) {
ui.writeLine(stderr);
const message = 'Package install failed, see above.';
ui.writeLine(chalk.red(message));
reject(message);
} else {
ui.writeLine(chalk.green(`Installed packages for tooling via ${packageManager}.`));
resolve();
}
});
});
}
});
6 changes: 6 additions & 0 deletions packages/@angular/cli/utilities/check-package-manager.ts
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,12 @@ const packageManager = CliConfig.fromGlobal().get('packageManager');


export function checkYarnOrCNPM() {

// Don't show messages if user has already changed the default.
if (packageManager !== 'default') {
return Promise.resolve();
}

return Promise
.all([checkYarn(), checkCNPM()])
.then((data: Array<boolean>) => {
Expand Down

0 comments on commit 3ce685b

Please sign in to comment.