Skip to content

Commit

Permalink
feat(exec): Add just-in-time queue management
Browse files Browse the repository at this point in the history
  • Loading branch information
evocateur committed May 13, 2019
1 parent 3a8b175 commit 23736e5
Show file tree
Hide file tree
Showing 3 changed files with 28 additions and 18 deletions.
34 changes: 22 additions & 12 deletions commands/exec/index.js
Original file line number Diff line number Diff line change
@@ -1,9 +1,10 @@
"use strict";

const pMap = require("p-map");

const ChildProcessUtilities = require("@lerna/child-process");
const Command = require("@lerna/command");
const batchPackages = require("@lerna/batch-packages");
const runParallelBatches = require("@lerna/run-parallel-batches");
const runTopologically = require("@lerna/run-topologically");
const ValidationError = require("@lerna/validation-error");
const { getFilteredPackages } = require("@lerna/filter-options");

Expand Down Expand Up @@ -47,10 +48,6 @@ class ExecCommand extends Command {
this.count = this.filteredPackages.length;
this.packagePlural = this.count === 1 ? "package" : "packages";
this.joinedCommand = [this.command].concat(this.args).join(" ");

this.batchedPackages = this.toposort
? batchPackages(this.filteredPackages, this.options.rejectCycles)
: [this.filteredPackages];
});
}

Expand All @@ -67,8 +64,10 @@ class ExecCommand extends Command {

if (this.options.parallel) {
chain = chain.then(() => this.runCommandInPackagesParallel());
} else if (this.toposort) {
chain = chain.then(() => this.runCommandInPackagesTopological());
} else {
chain = chain.then(() => this.runCommandInPackagesBatched());
chain = chain.then(() => this.runCommandInPackagesLexical());
}

if (this.bail) {
Expand Down Expand Up @@ -120,18 +119,29 @@ class ExecCommand extends Command {
};
}

runCommandInPackagesBatched() {
runCommandInPackagesTopological() {
const runner = this.options.stream
? pkg => this.runCommandInPackageStreaming(pkg)
: pkg => this.runCommandInPackageCapturing(pkg);

return runParallelBatches(this.batchedPackages, this.concurrency, runner).then(batchedResults =>
batchedResults.reduce((arr, batch) => arr.concat(batch), [])
);
return runTopologically({
packages: this.filteredPackages,
concurrency: this.concurrency,
rejectCycles: this.options.rejectCycles,
runner,
});
}

runCommandInPackagesParallel() {
return Promise.all(this.filteredPackages.map(pkg => this.runCommandInPackageStreaming(pkg)));
return pMap(this.filteredPackages, pkg => this.runCommandInPackageStreaming(pkg));
}

runCommandInPackagesLexical() {
const runner = this.options.stream
? pkg => this.runCommandInPackageStreaming(pkg)
: pkg => this.runCommandInPackageCapturing(pkg);

return pMap(this.filteredPackages, runner, { concurrency: this.concurrency });
}

runCommandInPackageStreaming(pkg) {
Expand Down
6 changes: 3 additions & 3 deletions commands/exec/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -35,11 +35,11 @@
"populate--": true
},
"dependencies": {
"@lerna/batch-packages": "file:../../utils/batch-packages",
"@lerna/child-process": "file:../../core/child-process",
"@lerna/command": "file:../../core/command",
"@lerna/filter-options": "file:../../core/filter-options",
"@lerna/run-parallel-batches": "file:../../utils/run-parallel-batches",
"@lerna/validation-error": "file:../../core/validation-error"
"@lerna/run-topologically": "file:../../utils/run-topologically",
"@lerna/validation-error": "file:../../core/validation-error",
"p-map": "^1.2.0"
}
}
6 changes: 3 additions & 3 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

0 comments on commit 23736e5

Please sign in to comment.