Skip to content

Commit aebf4c8

Browse files
filipesilvaBrocco
authored andcommitted
fix(@angular/cli): wait for install to finish before exiting
1 parent 93d5717 commit aebf4c8

File tree

3 files changed

+26
-24
lines changed

3 files changed

+26
-24
lines changed

packages/@angular/cli/tasks/init.ts

+1-6
Original file line numberDiff line numberDiff line change
@@ -89,7 +89,7 @@ export default Task.extend({
8989
return installBlueprint.run(blueprintOpts)
9090
.then(function () {
9191
if (!commandOptions.skipInstall) {
92-
return npmInstall.run();
92+
return checkYarnOrCNPM().then(() => npmInstall.run());
9393
}
9494
})
9595
.then(function () {
@@ -102,11 +102,6 @@ export default Task.extend({
102102
return linkCli.run();
103103
}
104104
})
105-
.then(() => {
106-
if (!commandOptions.skipInstall || commandOptions.linkCli) {
107-
return checkYarnOrCNPM();
108-
}
109-
})
110105
.then(() => {
111106
this.ui.writeLine(chalk.green(`Project '${packageName}' successfully created.`));
112107
});
+19-18
Original file line numberDiff line numberDiff line change
@@ -1,34 +1,35 @@
11
const Task = require('../ember-cli/lib/models/task');
22
import * as chalk from 'chalk';
3-
import {exec} from 'child_process';
4-
import {checkYarnOrCNPM} from '../utilities/check-package-manager';
3+
import { exec } from 'child_process';
54

65

76
export default Task.extend({
8-
run: function() {
7+
run: function () {
98
const ui = this.ui;
109
let packageManager = this.packageManager;
1110
if (packageManager === 'default') {
1211
packageManager = 'npm';
1312
}
1413

15-
return checkYarnOrCNPM().then(function () {
16-
ui.writeLine(chalk.green(`Installing packages for tooling via ${packageManager}.`));
17-
let installCommand = `${packageManager} install`;
18-
if (packageManager === 'npm') {
19-
installCommand = `${packageManager} --quiet install`;
20-
}
14+
ui.writeLine(chalk.green(`Installing packages for tooling via ${packageManager}.`));
15+
let installCommand = `${packageManager} install`;
16+
if (packageManager === 'npm') {
17+
installCommand = `${packageManager} --quiet install`;
18+
}
19+
20+
return new Promise((resolve, reject) => {
2121
exec(installCommand,
2222
(err: NodeJS.ErrnoException, _stdout: string, stderr: string) => {
23-
if (err) {
24-
ui.writeLine(stderr);
25-
const message = 'Package install failed, see above.';
26-
ui.writeLine(chalk.red(message));
27-
throw new Error(message);
28-
} else {
29-
ui.writeLine(chalk.green(`Installed packages for tooling via ${packageManager}.`));
30-
}
31-
});
23+
if (err) {
24+
ui.writeLine(stderr);
25+
const message = 'Package install failed, see above.';
26+
ui.writeLine(chalk.red(message));
27+
reject(message);
28+
} else {
29+
ui.writeLine(chalk.green(`Installed packages for tooling via ${packageManager}.`));
30+
resolve();
31+
}
32+
});
3233
});
3334
}
3435
});

packages/@angular/cli/utilities/check-package-manager.ts

+6
Original file line numberDiff line numberDiff line change
@@ -8,6 +8,12 @@ const packageManager = CliConfig.fromGlobal().get('packageManager');
88

99

1010
export function checkYarnOrCNPM() {
11+
12+
// Don't show messages if user has already changed the default.
13+
if (packageManager !== 'default') {
14+
return Promise.resolve();
15+
}
16+
1117
return Promise
1218
.all([checkYarn(), checkCNPM()])
1319
.then((data: Array<boolean>) => {

0 commit comments

Comments
 (0)