-
Notifications
You must be signed in to change notification settings - Fork 439
Expand file tree
/
Copy pathversion.js
More file actions
executable file
·122 lines (111 loc) · 4.14 KB
/
version.js
File metadata and controls
executable file
·122 lines (111 loc) · 4.14 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
/*
* Copyright (c) 2024, Salesforce, Inc.
* All rights reserved.
* SPDX-License-Identifier: MIT
* For full license text, see the LICENSE file in the repo root or https://opensource.org/licenses/MIT
*/
const fs = require('node:fs');
const path = require('node:path');
const readline = require('node:readline');
const semver = require('semver');
const { globSync } = require('glob');
const rootPath = path.resolve(__dirname, '../../');
const rootPackageJsonPath = `${rootPath}/package.json`;
const rootPackageJson = JSON.parse(fs.readFileSync(rootPackageJsonPath, 'utf-8'));
(async () => {
const rawVersion = await getVersion();
const parsedVersion = await parseVersion(rawVersion);
updatePackages(parsedVersion);
})().catch(console.error);
async function getVersion() {
if (process.argv[2]) {
return process.argv[2];
}
const rl = readline.createInterface({
input: process.stdin,
output: process.stdout,
});
const answer = await new Promise((resolve) =>
rl.question('Enter a new LWC version: ', resolve)
);
rl.close();
return answer;
}
async function parseVersion(rawVersion) {
try {
const current = rootPackageJson.version;
const exact = semver.valid(rawVersion);
if (exact) {
// answer is a semver version
if (semver.gt(exact, current)) {
return exact;
}
throw new Error(`Release version ${rawVersion} is not greater than ${current}.`);
}
const incremented = semver.inc(current, rawVersion);
if (incremented) {
// answer is a semver release type (major/minor/etc.)
return incremented;
}
throw new Error(`Invalid release version: ${rawVersion}`);
} catch (error) {
console.error(error);
process.exit(1);
}
}
function updatePackages(newVersion) {
try {
const packagesToUpdate = getPackagesToUpdate();
const workspacesPackageJson = new Set(
packagesToUpdate.map(({ packageJson }) => packageJson.name)
);
for (const { packageJson } of packagesToUpdate) {
packageJson.version = newVersion;
// Look for different types of dependencies
// ex: dependencies, devDependencies, peerDependencies
const pkgDependencyTypes = Object.keys(packageJson).filter((key) =>
key.match(/.*[dD]ependencies/)
);
// Update dependencies in package.json
for (const pkgDependencyType of pkgDependencyTypes) {
for (const pkgDepName of Object.keys(packageJson[pkgDependencyType])) {
if (workspacesPackageJson.has(pkgDepName)) {
// ex: packageJson[devDependencies][@lwc/template-compiler]
packageJson[pkgDependencyType][pkgDepName] = newVersion;
}
}
}
}
// Update package.json files and print updated packges
for (const { originalVersion, packageJson, packageJsonPath } of packagesToUpdate) {
fs.writeFileSync(packageJsonPath, JSON.stringify(packageJson, null, 4) + '\n');
console.log(
`Updated ${packageJson.name} from ${originalVersion} to ${packageJson.version}`
);
}
} catch (error) {
console.error(error);
}
}
function getPackagesToUpdate() {
const packagesToUpdate = [];
const workspacePkgs = rootPackageJson.workspaces.reduce(
(accWorkspacePkgs, workspace) => {
const workspacePkg = globSync(`${workspace}/package.json`);
return [...accWorkspacePkgs, ...workspacePkg];
},
[rootPackageJsonPath]
);
for (const pkgName of workspacePkgs) {
const packageJsonPath = path.resolve(rootPath, pkgName);
if (fs.existsSync(packageJsonPath)) {
const packageJson = JSON.parse(fs.readFileSync(packageJsonPath, 'utf-8'));
packagesToUpdate.push({
originalVersion: packageJson.version,
packageJsonPath,
packageJson,
});
}
}
return packagesToUpdate;
}