Skip to content

Commit

Permalink
Upgrade rush version to 5.40.7 (Azure#14202)
Browse files Browse the repository at this point in the history
  • Loading branch information
praveenkuttappan authored Mar 29, 2021
1 parent af55d60 commit f65dc4e
Show file tree
Hide file tree
Showing 4 changed files with 18 additions and 90 deletions.
2 changes: 1 addition & 1 deletion eng/pipelines/templates/steps/build.yml
Original file line number Diff line number Diff line change
Expand Up @@ -35,7 +35,7 @@ steps:
# Option "-p max" ensures parallelism is set to the number of cores on all platforms, which improves build times.
# The default on Windows is "cores - 1" (microsoft/rushstack#436).
- script: |
node eng/tools/rush-runner.js build "${{parameters.ServiceDirectory}}" --verbose -p max --TransitiveDep
node eng/tools/rush-runner.js build "${{parameters.ServiceDirectory}}" --verbose -p max
displayName: "Build libraries"
- script: |
node eng/tools/rush-runner.js build:samples "${{parameters.ServiceDirectory}}" --verbose
Expand Down
4 changes: 2 additions & 2 deletions eng/pipelines/templates/steps/test.yml
Original file line number Diff line number Diff line change
Expand Up @@ -14,13 +14,13 @@ steps:
# Option "-p max" ensures parallelism is set to the number of cores on all platforms, which improves build times.
# The default on Windows is "cores - 1" (microsoft/rushstack#436).
- script: |
node eng/tools/rush-runner.js build "${{parameters.ServiceDirectory}}" --verbose -p max --TransitiveDep
node eng/tools/rush-runner.js build "${{parameters.ServiceDirectory}}" --verbose -p max
displayName: "Build libraries"
# Option "-p max" ensures parallelism is set to the number of cores on all platforms, which improves build times.
# The default on Windows is "cores - 1" (microsoft/rushstack#436).
- script: |
node eng/tools/rush-runner.js build:test "${{parameters.ServiceDirectory}}" --verbose -p max --TransitiveDep
node eng/tools/rush-runner.js build:test "${{parameters.ServiceDirectory}}" --verbose -p max
displayName: "Build test assets"
- template: ../steps/use-node-test-version.yml
Expand Down
100 changes: 14 additions & 86 deletions eng/tools/rush-runner.js
Original file line number Diff line number Diff line change
Expand Up @@ -18,13 +18,8 @@ const parseArgs = () => {
flags = [];
const [scriptPath, action, ...givenArgs] = process.argv.slice(1);
const baseDir = path.resolve(`${path.dirname(scriptPath)}/../..`);
let buildTransitiveDep = false;

for (const arg of givenArgs) {
if (arg == "--TransitiveDep") {
buildTransitiveDep = true;
continue;
}
if (!inFlags && arg.startsWith("-")) {
inFlags = true;
}
Expand All @@ -38,7 +33,7 @@ const parseArgs = () => {
}
}
}
return [baseDir, action, services, flags, buildTransitiveDep];
return [baseDir, action, services, flags];
};

const getAllPackageJsonPaths = (baseDir) => {
Expand All @@ -55,68 +50,6 @@ const getAllPackageJsonPaths = (baseDir) => {
return packagePaths;
};

const getPackageGraph = (baseDir) => {
// Create a graph of packages with edges to packages that are dependent
// for e.g. C requires A and B and D requires A and C
// Graph is as follows
// { A: [C, D], B: [C], C: [D]}
let packageGraph = new Map();
const packageJsons = getAllPackageJsonPaths(baseDir);

for (const filePath of packageJsons) {
const contents = JSON.parse(fs.readFileSync(filePath, "utf8"));
const pkgName = contents["name"];
const dependencies = [];
if (contents.hasOwnProperty("dependencies")) {
for (const pkg in contents["dependencies"]) dependencies.push(pkg);
}

if (contents.hasOwnProperty("devDependencies")) {
for (const pkg in contents["devDependencies"]) dependencies.push(pkg);
}

// Process each package dependency and build dependency graph that links all packages that are dependent on current package
for (let dependentPkg of dependencies) {
if (!packageGraph.has(dependentPkg)) {
packageGraph.set(dependentPkg, new Set());
}
packageGraph.get(dependentPkg).add(pkgName);
}
}
return packageGraph;
};

const getLeafPackages = (packageGraph, packageNames) => {
// Return a set of packages that are dependent on other packages but not a dependency for any package
let leafPackages = new Set();
for (let pkgName of packageNames) {
// if current package is added as dependent by other packages then find leaf packages recursively
if (packageGraph.has(pkgName)) {
// Rush doesn't build transitive dependency if package version is beta
// Passing this package explicitly as a work around we can upgrade rush to latest version 5.38 or higher
leafPackages.add(pkgName);
for (const dependentPackage of getLeafPackages(packageGraph, packageGraph.get(pkgName))) {
leafPackages.add(dependentPackage);
}
} else {
// Current package has no further dependents. Add them to final list
leafPackages.add(pkgName);
}
}
return leafPackages;
};

const getPackagesToBuild = (packageNames, packageGraph) => {
// Find all packages that takes current package as dependency recursively and add leaf packages into list to build
// This will ensure all transitive dependencies are built
// A -> D, C -> D. When A is built, it will build D and C also just by adding --to D
for (const dependentPackage of getLeafPackages(packageGraph, packageNames)) {
if (!packageNames.includes(dependentPackage)) packageNames.push(dependentPackage);
}
console.log(`Packages to build: ${packageNames}`);
return packageNames;
};

const getPackageJsons = (searchDir) => {
// This gets all the directories with package.json at the `sdk/<service>/<service-sdk>` level excluding "arm-" packages
const sdkDirectories = fs
Expand Down Expand Up @@ -173,8 +106,7 @@ const flatMap = (arr, f) => {
return [].concat(...result);
};

const [baseDir, action, serviceDirs, rushParams, buildTransitiveDep] = parseArgs();
const pkgGraph = getPackageGraph(baseDir);
const [baseDir, action, serviceDirs, rushParams] = parseArgs();

const [packageNames, packageDirs] = getServicePackages(baseDir, serviceDirs);

Expand Down Expand Up @@ -207,10 +139,21 @@ if (serviceDirs.length === 0) {
} else {
const actionComponents = action.toLowerCase().split(":");
switch (actionComponents[0]) {
case "build":
if (actionComponents.length == 1) {
rushRunAll("--from", packageNames);
}
else {
// build:samples or build:test doesn't have to build dependent packages
// This should use impacted-by to build from current package to downstream
rushRunAll("--impacted-by", packageNames);
}
break;

case "test":
case "unit-test":
case "integration-test":
rushRunAll("--from", packageNames);
rushRunAll("--impacted-by", packageNames);
break;

case "lint":
Expand All @@ -226,21 +169,6 @@ if (serviceDirs.length === 0) {
}
break;

case "build":
if (actionComponents[1] === "samples") {
// For sample builds, we use --from to run sample builds on dependents
rushRunAll("--from", packageNames);
} else {
// For other builds, we use the transitive dependency logic if required, and build dependencies
// using --to
const requiredPackageNames = buildTransitiveDep
? getPackagesToBuild(packageNames, pkgGraph)
: packageNames;

rushRunAll("--to", requiredPackageNames);
}
break;

default:
rushRunAll("--to", packageNames);
break;
Expand Down
2 changes: 1 addition & 1 deletion rush.json
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@
* path segment in the "$schema" field for all your Rush config files. This will ensure
* correct error-underlining and tab-completion for editors such as VS Code.
*/
"rushVersion": "5.36.1",
"rushVersion": "5.40.7",
/**
* The next field selects which package manager should be installed and determines its version.
* Rush installs its own local copy of the package manager to ensure that your build process
Expand Down

0 comments on commit f65dc4e

Please sign in to comment.