@backstage/cli 0.18.0 → 0.18.1-next.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +7 -0
- package/dist/cjs/{Lockfile-48dc675e.cjs.js → Lockfile-72b7072e.cjs.js} +25 -9
- package/dist/cjs/{PackageGraph-1d7b086a.cjs.js → PackageGraph-6e1d4bd4.cjs.js} +17 -9
- package/dist/cjs/{build-52ba70a2.cjs.js → build-3b11f7c9.cjs.js} +26 -15
- package/dist/cjs/{buildBackend-55985c84.cjs.js → buildBackend-87996ad4.cjs.js} +61 -36
- package/dist/cjs/{buildWorkspace-d663903d.cjs.js → buildWorkspace-425726da.cjs.js} +7 -7
- package/dist/cjs/{bump-1a3769e9.cjs.js → bump-f3c6b3cd.cjs.js} +88 -33
- package/dist/cjs/{clean-9a8c294a.cjs.js → clean-798512b5.cjs.js} +2 -2
- package/dist/cjs/{config-de1bf46a.cjs.js → config-4a59f918.cjs.js} +15 -11
- package/dist/cjs/{create-b0ca2add.cjs.js → create-a7269bb5.cjs.js} +80 -32
- package/dist/cjs/{createDistWorkspace-fc94c796.cjs.js → createDistWorkspace-cb9a9a84.cjs.js} +137 -65
- package/dist/cjs/{createPlugin-4d7e1b01.cjs.js → createPlugin-fca2c26e.cjs.js} +69 -30
- package/dist/cjs/{diff-a561bee3.cjs.js → diff-3dec490d.cjs.js} +68 -16
- package/dist/cjs/{docs-bd70b38e.cjs.js → docs-e60d4fe7.cjs.js} +9 -5
- package/dist/cjs/{fix-47eb8dc4.cjs.js → fix-b60a5395.cjs.js} +17 -7
- package/dist/cjs/{index-27d57881.cjs.js → index-131467e2.cjs.js} +10 -10
- package/dist/cjs/{index-7e13cc9d.cjs.js → index-50703ee1.cjs.js} +151 -50
- package/dist/cjs/{index-4f4a8498.cjs.js → index-71d143d5.cjs.js} +57 -38
- package/dist/cjs/{index-bb24147b.cjs.js → index-7efbd23e.cjs.js} +39 -12
- package/dist/cjs/{info-29f0ee36.cjs.js → info-04610119.cjs.js} +20 -6
- package/dist/cjs/{install-fea0e3f5.cjs.js → install-589f1c25.cjs.js} +44 -17
- package/dist/cjs/{lint-81a75364.cjs.js → lint-41010f96.cjs.js} +37 -11
- package/dist/cjs/{lint-1711bbbb.cjs.js → lint-6fcb9a70.cjs.js} +5 -3
- package/dist/cjs/{lint-0db8937c.cjs.js → lint-7f6b0d33.cjs.js} +4 -4
- package/dist/cjs/{list-deprecations-cea8fad3.cjs.js → list-deprecations-8aee2123.cjs.js} +3 -3
- package/dist/cjs/{pack-8ab429c0.cjs.js → pack-91881c2f.cjs.js} +17 -11
- package/dist/cjs/packageLintConfigs-f9e5fcc6.cjs.js +83 -0
- package/dist/cjs/packageRole-16eb6c89.cjs.js +59 -0
- package/dist/cjs/{packageRoles-a310f84c.cjs.js → packageRoles-96528891.cjs.js} +5 -3
- package/dist/cjs/packageScripts-eb2443c2.cjs.js +98 -0
- package/dist/cjs/{packages-ea5c38ec.cjs.js → packages-1b40c101.cjs.js} +17 -12
- package/dist/cjs/parallel-a8f6219c.cjs.js +187 -0
- package/dist/cjs/{paths-d98c9d0c.cjs.js → paths-b34f135a.cjs.js} +100 -55
- package/dist/cjs/{print-4cbe70e7.cjs.js → print-e99d7c2e.cjs.js} +4 -4
- package/dist/cjs/{run-5e05ba2c.cjs.js → run-722b1384.cjs.js} +2 -2
- package/dist/cjs/{schema-2c842cbe.cjs.js → schema-c636e913.cjs.js} +9 -5
- package/dist/cjs/{tasks-b054c9ce.cjs.js → tasks-4776baa6.cjs.js} +29 -12
- package/dist/cjs/{test-b5969f53.cjs.js → test-76539f57.cjs.js} +3 -3
- package/dist/cjs/{validate-8a03d402.cjs.js → validate-f9273594.cjs.js} +4 -4
- package/dist/index.cjs.js +1 -1
- package/package.json +12 -12
- package/dist/cjs/packageLintConfigs-77b71b79.cjs.js +0 -74
- package/dist/cjs/packageRole-d1e7c7d6.cjs.js +0 -53
- package/dist/cjs/packageScripts-6731503e.cjs.js +0 -96
- package/dist/cjs/parallel-8286d3fa.cjs.js +0 -171
package/CHANGELOG.md
CHANGED
|
@@ -97,12 +97,16 @@ class Lockfile {
|
|
|
97
97
|
continue;
|
|
98
98
|
}
|
|
99
99
|
const invalid = allEntries.filter((e) => !semver__default["default"].validRange(e.range));
|
|
100
|
-
result.invalidRanges.push(
|
|
100
|
+
result.invalidRanges.push(
|
|
101
|
+
...invalid.map(({ range }) => ({ name, range }))
|
|
102
|
+
);
|
|
101
103
|
const entries = allEntries.filter((e) => semver__default["default"].validRange(e.range));
|
|
102
104
|
if (entries.length < 2) {
|
|
103
105
|
continue;
|
|
104
106
|
}
|
|
105
|
-
const versions = Array.from(new Set(entries.map((e) => e.version))).sort(
|
|
107
|
+
const versions = Array.from(new Set(entries.map((e) => e.version))).sort(
|
|
108
|
+
(v1, v2) => semver__default["default"].rcompare(v1, v2)
|
|
109
|
+
);
|
|
106
110
|
if (versions.length < 2) {
|
|
107
111
|
continue;
|
|
108
112
|
}
|
|
@@ -110,7 +114,9 @@ class Lockfile {
|
|
|
110
114
|
for (const { version, range } of entries) {
|
|
111
115
|
const acceptedVersion = versions.find((v) => semver__default["default"].satisfies(v, range));
|
|
112
116
|
if (!acceptedVersion) {
|
|
113
|
-
throw new Error(
|
|
117
|
+
throw new Error(
|
|
118
|
+
`No existing version was accepted for range ${range}, searching through ${versions}, for package ${name}`
|
|
119
|
+
);
|
|
114
120
|
}
|
|
115
121
|
if (acceptedVersion !== version) {
|
|
116
122
|
result.newVersions.push({
|
|
@@ -128,7 +134,9 @@ class Lockfile {
|
|
|
128
134
|
const maxVersion = Array.from(acceptedVersions).sort(semver__default["default"].rcompare)[0];
|
|
129
135
|
const maxEntry = (_a = entries.filter((e) => semver__default["default"].satisfies(maxVersion, e.range)).map((e) => ({ e, min: semver__default["default"].minVersion(e.range) })).filter((p) => p.min).sort((a, b) => semver__default["default"].rcompare(a.min, b.min))[0]) == null ? void 0 : _a.e;
|
|
130
136
|
if (!maxEntry) {
|
|
131
|
-
throw new Error(
|
|
137
|
+
throw new Error(
|
|
138
|
+
`No entry found that satisfies max version '${maxVersion}'`
|
|
139
|
+
);
|
|
132
140
|
}
|
|
133
141
|
for (const { version, range } of entries) {
|
|
134
142
|
if (semver__default["default"].satisfies(maxVersion, range)) {
|
|
@@ -165,11 +173,17 @@ class Lockfile {
|
|
|
165
173
|
throw new Error(`No entry data for ${query}`);
|
|
166
174
|
}
|
|
167
175
|
if (entryData.version !== oldVersion) {
|
|
168
|
-
throw new Error(
|
|
176
|
+
throw new Error(
|
|
177
|
+
`Expected existing version data for ${query} to be ${oldVersion}, was ${entryData.version}`
|
|
178
|
+
);
|
|
169
179
|
}
|
|
170
|
-
const matchingEntry = Object.entries(this.data).find(
|
|
180
|
+
const matchingEntry = Object.entries(this.data).find(
|
|
181
|
+
([q, e]) => q.startsWith(`${name}@`) && e.version === newVersion
|
|
182
|
+
);
|
|
171
183
|
if (!matchingEntry) {
|
|
172
|
-
throw new Error(
|
|
184
|
+
throw new Error(
|
|
185
|
+
`No matching entry found for ${name} at version ${newVersion}`
|
|
186
|
+
);
|
|
173
187
|
}
|
|
174
188
|
this.data[query] = matchingEntry[1];
|
|
175
189
|
const entry = (_a = this.packages.get(name)) == null ? void 0 : _a.find((e) => e.range === range);
|
|
@@ -177,7 +191,9 @@ class Lockfile {
|
|
|
177
191
|
throw new Error(`No entry data for ${query}`);
|
|
178
192
|
}
|
|
179
193
|
if (entry.version !== oldVersion) {
|
|
180
|
-
throw new Error(
|
|
194
|
+
throw new Error(
|
|
195
|
+
`Expected existing version data for ${query} to be ${oldVersion}, was ${entryData.version}`
|
|
196
|
+
);
|
|
181
197
|
}
|
|
182
198
|
entry.version = newVersion;
|
|
183
199
|
}
|
|
@@ -191,4 +207,4 @@ class Lockfile {
|
|
|
191
207
|
}
|
|
192
208
|
|
|
193
209
|
exports.Lockfile = Lockfile;
|
|
194
|
-
//# sourceMappingURL=Lockfile-
|
|
210
|
+
//# sourceMappingURL=Lockfile-72b7072e.cjs.js.map
|
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
|
|
3
3
|
var path = require('path');
|
|
4
4
|
var getPackages = require('@manypkg/get-packages');
|
|
5
|
-
var index = require('./index-
|
|
5
|
+
var index = require('./index-50703ee1.cjs.js');
|
|
6
6
|
var errors = require('@backstage/errors');
|
|
7
7
|
var child_process = require('child_process');
|
|
8
8
|
var util = require('util');
|
|
@@ -56,7 +56,9 @@ class PackageGraph extends Map {
|
|
|
56
56
|
const name = pkg.packageJson.name;
|
|
57
57
|
const existingPkg = graph.get(name);
|
|
58
58
|
if (existingPkg) {
|
|
59
|
-
throw new Error(
|
|
59
|
+
throw new Error(
|
|
60
|
+
`Duplicate package name '${name}' at ${pkg.dir} and ${existingPkg.dir}`
|
|
61
|
+
);
|
|
60
62
|
}
|
|
61
63
|
graph.set(name, {
|
|
62
64
|
name,
|
|
@@ -86,7 +88,9 @@ class PackageGraph extends Map {
|
|
|
86
88
|
depPkg.localDependents.set(node.name, node);
|
|
87
89
|
}
|
|
88
90
|
}
|
|
89
|
-
for (const depName of Object.keys(
|
|
91
|
+
for (const depName of Object.keys(
|
|
92
|
+
node.packageJson.devDependencies || {}
|
|
93
|
+
)) {
|
|
90
94
|
const depPkg = graph.get(depName);
|
|
91
95
|
if (depPkg) {
|
|
92
96
|
node.allLocalDependencies.set(depName, depPkg);
|
|
@@ -95,7 +99,9 @@ class PackageGraph extends Map {
|
|
|
95
99
|
depPkg.localDevDependents.set(node.name, node);
|
|
96
100
|
}
|
|
97
101
|
}
|
|
98
|
-
for (const depName of Object.keys(
|
|
102
|
+
for (const depName of Object.keys(
|
|
103
|
+
node.packageJson.optionalDependencies || {}
|
|
104
|
+
)) {
|
|
99
105
|
const depPkg = graph.get(depName);
|
|
100
106
|
if (depPkg) {
|
|
101
107
|
node.allLocalDependencies.set(depName, depPkg);
|
|
@@ -132,10 +138,12 @@ class PackageGraph extends Map {
|
|
|
132
138
|
async listChangedPackages(options) {
|
|
133
139
|
var _a, _b;
|
|
134
140
|
const changedFiles = await listChangedFiles(options.ref);
|
|
135
|
-
const dirMap = new Map(
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
141
|
+
const dirMap = new Map(
|
|
142
|
+
Array.from(this.values()).map((pkg) => [
|
|
143
|
+
path__default["default"].relative(index.paths.targetRoot, pkg.dir).split(path__default["default"].sep).join(path__default["default"].posix.sep) + path__default["default"].posix.sep,
|
|
144
|
+
pkg
|
|
145
|
+
])
|
|
146
|
+
);
|
|
139
147
|
const packageDirs = Array.from(dirMap.keys());
|
|
140
148
|
const result = new Array();
|
|
141
149
|
let searchIndex = 0;
|
|
@@ -158,4 +166,4 @@ class PackageGraph extends Map {
|
|
|
158
166
|
}
|
|
159
167
|
|
|
160
168
|
exports.PackageGraph = PackageGraph;
|
|
161
|
-
//# sourceMappingURL=PackageGraph-
|
|
169
|
+
//# sourceMappingURL=PackageGraph-6e1d4bd4.cjs.js.map
|
|
@@ -2,17 +2,17 @@
|
|
|
2
2
|
|
|
3
3
|
var chalk = require('chalk');
|
|
4
4
|
var path = require('path');
|
|
5
|
-
var createDistWorkspace = require('./createDistWorkspace-
|
|
6
|
-
var PackageGraph = require('./PackageGraph-
|
|
7
|
-
var parallel = require('./parallel-
|
|
8
|
-
var index = require('./index-
|
|
9
|
-
var packageRoles = require('./packageRoles-
|
|
10
|
-
var buildBackend = require('./buildBackend-
|
|
5
|
+
var createDistWorkspace = require('./createDistWorkspace-cb9a9a84.cjs.js');
|
|
6
|
+
var PackageGraph = require('./PackageGraph-6e1d4bd4.cjs.js');
|
|
7
|
+
var parallel = require('./parallel-a8f6219c.cjs.js');
|
|
8
|
+
var index = require('./index-50703ee1.cjs.js');
|
|
9
|
+
var packageRoles = require('./packageRoles-96528891.cjs.js');
|
|
10
|
+
var buildBackend = require('./buildBackend-87996ad4.cjs.js');
|
|
11
11
|
require('fs-extra');
|
|
12
12
|
require('os');
|
|
13
13
|
require('tar');
|
|
14
14
|
require('lodash/partition');
|
|
15
|
-
require('./run-
|
|
15
|
+
require('./run-722b1384.cjs.js');
|
|
16
16
|
require('child_process');
|
|
17
17
|
require('util');
|
|
18
18
|
require('@backstage/errors');
|
|
@@ -40,7 +40,7 @@ require('html-webpack-plugin');
|
|
|
40
40
|
require('react-dev-utils/ModuleScopePlugin');
|
|
41
41
|
require('run-script-webpack-plugin');
|
|
42
42
|
require('webpack-node-externals');
|
|
43
|
-
require('./paths-
|
|
43
|
+
require('./paths-b34f135a.cjs.js');
|
|
44
44
|
require('mini-css-extract-plugin');
|
|
45
45
|
require('eslint-webpack-plugin');
|
|
46
46
|
require('lodash/pickBy');
|
|
@@ -49,7 +49,7 @@ require('react-dev-utils/FileSizeReporter');
|
|
|
49
49
|
require('react-dev-utils/formatWebpackMessages');
|
|
50
50
|
require('webpack-dev-server');
|
|
51
51
|
require('react-dev-utils/openBrowser');
|
|
52
|
-
require('./config-
|
|
52
|
+
require('./config-4a59f918.cjs.js');
|
|
53
53
|
require('@backstage/config-loader');
|
|
54
54
|
require('@backstage/config');
|
|
55
55
|
|
|
@@ -67,7 +67,9 @@ function createScriptOptionsParser(anyCmd, commandPath) {
|
|
|
67
67
|
targetCmd = targetCmd == null ? void 0 : targetCmd.commands.find((c) => c.name() === name);
|
|
68
68
|
}
|
|
69
69
|
if (!targetCmd) {
|
|
70
|
-
throw new Error(
|
|
70
|
+
throw new Error(
|
|
71
|
+
`Could not find package command '${commandPath.join(" ")}'`
|
|
72
|
+
);
|
|
71
73
|
}
|
|
72
74
|
const cmd = targetCmd;
|
|
73
75
|
const expectedScript = `backstage-cli ${commandPath.join(" ")}`;
|
|
@@ -94,7 +96,10 @@ async function command(opts, cmd) {
|
|
|
94
96
|
const changedPackages = await graph.listChangedPackages({
|
|
95
97
|
ref: opts.since
|
|
96
98
|
});
|
|
97
|
-
const withDevDependents = graph.collectPackageNames(
|
|
99
|
+
const withDevDependents = graph.collectPackageNames(
|
|
100
|
+
changedPackages.map((pkg) => pkg.name),
|
|
101
|
+
(pkg) => pkg.localDevDependents.keys()
|
|
102
|
+
);
|
|
98
103
|
packages = Array.from(withDevDependents).map((name) => graph.get(name));
|
|
99
104
|
}
|
|
100
105
|
const apps = new Array();
|
|
@@ -121,7 +126,9 @@ async function command(opts, cmd) {
|
|
|
121
126
|
}
|
|
122
127
|
const buildOptions = parseBuildScript((_c = pkg.packageJson.scripts) == null ? void 0 : _c.build);
|
|
123
128
|
if (!buildOptions) {
|
|
124
|
-
console.warn(
|
|
129
|
+
console.warn(
|
|
130
|
+
`Ignored ${pkg.packageJson.name} because it does not have a matching build script`
|
|
131
|
+
);
|
|
125
132
|
return [];
|
|
126
133
|
}
|
|
127
134
|
return {
|
|
@@ -143,7 +150,9 @@ async function command(opts, cmd) {
|
|
|
143
150
|
var _a, _b;
|
|
144
151
|
const buildOptions = parseBuildScript((_a = pkg.packageJson.scripts) == null ? void 0 : _a.build);
|
|
145
152
|
if (!buildOptions) {
|
|
146
|
-
console.warn(
|
|
153
|
+
console.warn(
|
|
154
|
+
`Ignored ${pkg.packageJson.name} because it does not have a matching build script`
|
|
155
|
+
);
|
|
147
156
|
return;
|
|
148
157
|
}
|
|
149
158
|
await buildBackend.buildFrontend({
|
|
@@ -161,7 +170,9 @@ async function command(opts, cmd) {
|
|
|
161
170
|
var _a;
|
|
162
171
|
const buildOptions = parseBuildScript((_a = pkg.packageJson.scripts) == null ? void 0 : _a.build);
|
|
163
172
|
if (!buildOptions) {
|
|
164
|
-
console.warn(
|
|
173
|
+
console.warn(
|
|
174
|
+
`Ignored ${pkg.packageJson.name} because it does not have a matching build script`
|
|
175
|
+
);
|
|
165
176
|
return;
|
|
166
177
|
}
|
|
167
178
|
await buildBackend.buildBackend({
|
|
@@ -174,4 +185,4 @@ async function command(opts, cmd) {
|
|
|
174
185
|
}
|
|
175
186
|
|
|
176
187
|
exports.command = command;
|
|
177
|
-
//# sourceMappingURL=build-
|
|
188
|
+
//# sourceMappingURL=build-3b11f7c9.cjs.js.map
|
|
@@ -10,10 +10,10 @@ require('run-script-webpack-plugin');
|
|
|
10
10
|
require('webpack-node-externals');
|
|
11
11
|
require('@backstage/cli-common');
|
|
12
12
|
require('@manypkg/get-packages');
|
|
13
|
-
var paths = require('./paths-
|
|
13
|
+
var paths = require('./paths-b34f135a.cjs.js');
|
|
14
14
|
require('mini-css-extract-plugin');
|
|
15
|
-
require('./index-
|
|
16
|
-
require('./run-
|
|
15
|
+
require('./index-50703ee1.cjs.js');
|
|
16
|
+
require('./run-722b1384.cjs.js');
|
|
17
17
|
require('eslint-webpack-plugin');
|
|
18
18
|
require('lodash/pickBy');
|
|
19
19
|
var yn = require('yn');
|
|
@@ -22,11 +22,11 @@ var formatWebpackMessages = require('react-dev-utils/formatWebpackMessages');
|
|
|
22
22
|
var chalk = require('chalk');
|
|
23
23
|
require('webpack-dev-server');
|
|
24
24
|
require('react-dev-utils/openBrowser');
|
|
25
|
-
var parallel = require('./parallel-
|
|
26
|
-
var config = require('./config-
|
|
25
|
+
var parallel = require('./parallel-a8f6219c.cjs.js');
|
|
26
|
+
var config = require('./config-4a59f918.cjs.js');
|
|
27
27
|
var os = require('os');
|
|
28
28
|
var tar = require('tar');
|
|
29
|
-
var createDistWorkspace = require('./createDistWorkspace-
|
|
29
|
+
var createDistWorkspace = require('./createDistWorkspace-cb9a9a84.cjs.js');
|
|
30
30
|
|
|
31
31
|
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
|
|
32
32
|
|
|
@@ -60,7 +60,11 @@ async function buildBundle(options) {
|
|
|
60
60
|
});
|
|
61
61
|
}
|
|
62
62
|
if (configSchema) {
|
|
63
|
-
await fs__default["default"].writeJson(
|
|
63
|
+
await fs__default["default"].writeJson(
|
|
64
|
+
path.resolve(paths$1.targetDist, ".config-schema.json"),
|
|
65
|
+
configSchema.serialize(),
|
|
66
|
+
{ spaces: 2 }
|
|
67
|
+
);
|
|
64
68
|
}
|
|
65
69
|
const { stats } = await build(compiler, isCi).catch((error) => {
|
|
66
70
|
console.log(chalk__default["default"].red("Failed to compile.\n"));
|
|
@@ -71,31 +75,42 @@ ${error.message || error}`);
|
|
|
71
75
|
throw new Error("No stats returned");
|
|
72
76
|
}
|
|
73
77
|
if (statsJsonEnabled) {
|
|
74
|
-
await require("bfj").write(
|
|
78
|
+
await require("bfj").write(
|
|
79
|
+
path.resolve(paths$1.targetDist, "bundle-stats.json"),
|
|
80
|
+
stats.toJson()
|
|
81
|
+
);
|
|
75
82
|
}
|
|
76
|
-
FileSizeReporter.printFileSizesAfterBuild(
|
|
83
|
+
FileSizeReporter.printFileSizesAfterBuild(
|
|
84
|
+
stats,
|
|
85
|
+
previousFileSizes,
|
|
86
|
+
paths$1.targetDist,
|
|
87
|
+
WARN_AFTER_BUNDLE_GZIP_SIZE,
|
|
88
|
+
WARN_AFTER_CHUNK_GZIP_SIZE
|
|
89
|
+
);
|
|
77
90
|
}
|
|
78
91
|
async function build(compiler, isCi) {
|
|
79
92
|
var _a, _b;
|
|
80
|
-
const stats = await new Promise(
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
if (err
|
|
84
|
-
|
|
85
|
-
errors: [
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
93
|
+
const stats = await new Promise(
|
|
94
|
+
(resolve, reject) => {
|
|
95
|
+
compiler.run((err, buildStats) => {
|
|
96
|
+
if (err) {
|
|
97
|
+
if (err.message) {
|
|
98
|
+
const { errors: errors2 } = formatWebpackMessages__default["default"]({
|
|
99
|
+
errors: [err.message],
|
|
100
|
+
warnings: new Array(),
|
|
101
|
+
_showErrors: true,
|
|
102
|
+
_showWarnings: true
|
|
103
|
+
});
|
|
104
|
+
throw new Error(errors2[0]);
|
|
105
|
+
} else {
|
|
106
|
+
reject(err);
|
|
107
|
+
}
|
|
91
108
|
} else {
|
|
92
|
-
|
|
109
|
+
resolve(buildStats);
|
|
93
110
|
}
|
|
94
|
-
}
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
});
|
|
98
|
-
});
|
|
111
|
+
});
|
|
112
|
+
}
|
|
113
|
+
);
|
|
99
114
|
if (!stats) {
|
|
100
115
|
throw new Error("No stats provided");
|
|
101
116
|
}
|
|
@@ -112,7 +127,11 @@ async function build(compiler, isCi) {
|
|
|
112
127
|
throw new Error(errors[0]);
|
|
113
128
|
}
|
|
114
129
|
if (isCi && warnings.length) {
|
|
115
|
-
console.log(
|
|
130
|
+
console.log(
|
|
131
|
+
chalk__default["default"].yellow(
|
|
132
|
+
"\nTreating warnings as errors because process.env.CI = true.\n"
|
|
133
|
+
)
|
|
134
|
+
);
|
|
116
135
|
throw new Error(warnings.join("\n\n"));
|
|
117
136
|
}
|
|
118
137
|
return { stats };
|
|
@@ -154,14 +173,20 @@ async function buildBackend(options) {
|
|
|
154
173
|
const distDir = path.resolve(targetDir, "dist");
|
|
155
174
|
await fs__default["default"].remove(distDir);
|
|
156
175
|
await fs__default["default"].mkdir(distDir);
|
|
157
|
-
await fs__default["default"].move(
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
176
|
+
await fs__default["default"].move(
|
|
177
|
+
path.resolve(tmpDir, SKELETON_FILE),
|
|
178
|
+
path.resolve(distDir, SKELETON_FILE)
|
|
179
|
+
);
|
|
180
|
+
await tar__default["default"].create(
|
|
181
|
+
{
|
|
182
|
+
file: path.resolve(distDir, BUNDLE_FILE),
|
|
183
|
+
cwd: tmpDir,
|
|
184
|
+
portable: true,
|
|
185
|
+
noMtime: true,
|
|
186
|
+
gzip: true
|
|
187
|
+
},
|
|
188
|
+
[""]
|
|
189
|
+
);
|
|
165
190
|
} finally {
|
|
166
191
|
await fs__default["default"].remove(tmpDir);
|
|
167
192
|
}
|
|
@@ -169,4 +194,4 @@ async function buildBackend(options) {
|
|
|
169
194
|
|
|
170
195
|
exports.buildBackend = buildBackend;
|
|
171
196
|
exports.buildFrontend = buildFrontend;
|
|
172
|
-
//# sourceMappingURL=buildBackend-
|
|
197
|
+
//# sourceMappingURL=buildBackend-87996ad4.cjs.js.map
|
|
@@ -1,21 +1,21 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
3
|
var fs = require('fs-extra');
|
|
4
|
-
var createDistWorkspace = require('./createDistWorkspace-
|
|
4
|
+
var createDistWorkspace = require('./createDistWorkspace-cb9a9a84.cjs.js');
|
|
5
5
|
require('chalk');
|
|
6
6
|
require('path');
|
|
7
7
|
require('os');
|
|
8
8
|
require('tar');
|
|
9
9
|
require('lodash/partition');
|
|
10
|
-
require('./index-
|
|
10
|
+
require('./index-50703ee1.cjs.js');
|
|
11
11
|
require('commander');
|
|
12
12
|
require('semver');
|
|
13
13
|
require('@backstage/cli-common');
|
|
14
14
|
require('@backstage/errors');
|
|
15
|
-
require('./run-
|
|
15
|
+
require('./run-722b1384.cjs.js');
|
|
16
16
|
require('child_process');
|
|
17
17
|
require('util');
|
|
18
|
-
require('./PackageGraph-
|
|
18
|
+
require('./PackageGraph-6e1d4bd4.cjs.js');
|
|
19
19
|
require('@manypkg/get-packages');
|
|
20
20
|
require('rollup');
|
|
21
21
|
require('@rollup/plugin-commonjs');
|
|
@@ -28,9 +28,9 @@ require('@rollup/plugin-json');
|
|
|
28
28
|
require('@rollup/plugin-yaml');
|
|
29
29
|
require('rollup-pluginutils');
|
|
30
30
|
require('./svgrTemplate-550efce6.cjs.js');
|
|
31
|
-
require('./parallel-
|
|
31
|
+
require('./parallel-a8f6219c.cjs.js');
|
|
32
32
|
require('worker_threads');
|
|
33
|
-
require('./packageRoles-
|
|
33
|
+
require('./packageRoles-96528891.cjs.js');
|
|
34
34
|
require('zod');
|
|
35
35
|
require('npm-packlist');
|
|
36
36
|
|
|
@@ -48,4 +48,4 @@ var buildWorkspace = async (dir, packages) => {
|
|
|
48
48
|
};
|
|
49
49
|
|
|
50
50
|
exports["default"] = buildWorkspace;
|
|
51
|
-
//# sourceMappingURL=buildWorkspace-
|
|
51
|
+
//# sourceMappingURL=buildWorkspace-425726da.cjs.js.map
|
|
@@ -7,13 +7,13 @@ var semver = require('semver');
|
|
|
7
7
|
var minimatch = require('minimatch');
|
|
8
8
|
var errors = require('@backstage/errors');
|
|
9
9
|
var path = require('path');
|
|
10
|
-
var run = require('./run-
|
|
11
|
-
var index = require('./index-
|
|
12
|
-
var Lockfile = require('./Lockfile-
|
|
13
|
-
var packages = require('./packages-
|
|
14
|
-
var lint = require('./lint-
|
|
10
|
+
var run = require('./run-722b1384.cjs.js');
|
|
11
|
+
var index = require('./index-50703ee1.cjs.js');
|
|
12
|
+
var Lockfile = require('./Lockfile-72b7072e.cjs.js');
|
|
13
|
+
var packages = require('./packages-1b40c101.cjs.js');
|
|
14
|
+
var lint = require('./lint-41010f96.cjs.js');
|
|
15
15
|
var cliCommon = require('@backstage/cli-common');
|
|
16
|
-
var parallel = require('./parallel-
|
|
16
|
+
var parallel = require('./parallel-a8f6219c.cjs.js');
|
|
17
17
|
var releaseManifests = require('@backstage/release-manifests');
|
|
18
18
|
require('global-agent/bootstrap');
|
|
19
19
|
require('child_process');
|
|
@@ -103,12 +103,15 @@ var bump = async (opts) => {
|
|
|
103
103
|
}
|
|
104
104
|
continue;
|
|
105
105
|
}
|
|
106
|
-
versionBumps.set(
|
|
107
|
-
name,
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
106
|
+
versionBumps.set(
|
|
107
|
+
pkg.name,
|
|
108
|
+
((_b = versionBumps.get(pkg.name)) != null ? _b : []).concat({
|
|
109
|
+
name,
|
|
110
|
+
location: pkg.location,
|
|
111
|
+
range: `^${target}`,
|
|
112
|
+
target
|
|
113
|
+
})
|
|
114
|
+
);
|
|
112
115
|
}
|
|
113
116
|
}
|
|
114
117
|
});
|
|
@@ -155,7 +158,11 @@ var bump = async (opts) => {
|
|
|
155
158
|
const key = JSON.stringify({ name, range });
|
|
156
159
|
if (!removed.has(key)) {
|
|
157
160
|
removed.add(key);
|
|
158
|
-
console.log(
|
|
161
|
+
console.log(
|
|
162
|
+
`${chalk__default["default"].magenta("unlocking")} ${name}@${chalk__default["default"].yellow(
|
|
163
|
+
range
|
|
164
|
+
)} ~> ${chalk__default["default"].yellow(target)}`
|
|
165
|
+
);
|
|
159
166
|
lockfile.remove(name, range);
|
|
160
167
|
}
|
|
161
168
|
}
|
|
@@ -170,7 +177,11 @@ var bump = async (opts) => {
|
|
|
170
177
|
const pkgPath = path.resolve(deps[0].location, "package.json");
|
|
171
178
|
const pkgJson = await fs__default["default"].readJson(pkgPath);
|
|
172
179
|
for (const dep of deps) {
|
|
173
|
-
console.log(
|
|
180
|
+
console.log(
|
|
181
|
+
`${chalk__default["default"].cyan("bumping")} ${dep.name} in ${chalk__default["default"].cyan(
|
|
182
|
+
name
|
|
183
|
+
)} to ${chalk__default["default"].yellow(dep.range)}`
|
|
184
|
+
);
|
|
174
185
|
for (const depType of DEP_TYPES) {
|
|
175
186
|
if (depType in pkgJson && dep.name in pkgJson[depType]) {
|
|
176
187
|
const oldRange = pkgJson[depType][dep.name];
|
|
@@ -193,15 +204,27 @@ var bump = async (opts) => {
|
|
|
193
204
|
if (pattern === DEFAULT_PATTERN_GLOB) {
|
|
194
205
|
await bumpBackstageJsonVersion(releaseManifest.releaseVersion);
|
|
195
206
|
} else {
|
|
196
|
-
console.log(
|
|
207
|
+
console.log(
|
|
208
|
+
chalk__default["default"].yellow(
|
|
209
|
+
`Skipping backstage.json update as custom pattern is used`
|
|
210
|
+
)
|
|
211
|
+
);
|
|
197
212
|
}
|
|
198
213
|
await runYarnInstall();
|
|
199
214
|
if (breakingUpdates.size > 0) {
|
|
200
215
|
console.log();
|
|
201
|
-
console.log(
|
|
216
|
+
console.log(
|
|
217
|
+
chalk__default["default"].yellow("\u26A0\uFE0F The following packages may have breaking changes:")
|
|
218
|
+
);
|
|
202
219
|
console.log();
|
|
203
|
-
for (const [name, { from, to }] of Array.from(
|
|
204
|
-
|
|
220
|
+
for (const [name, { from, to }] of Array.from(
|
|
221
|
+
breakingUpdates.entries()
|
|
222
|
+
).sort()) {
|
|
223
|
+
console.log(
|
|
224
|
+
` ${chalk__default["default"].yellow(name)} : ${chalk__default["default"].yellow(from)} ~> ${chalk__default["default"].yellow(
|
|
225
|
+
to
|
|
226
|
+
)}`
|
|
227
|
+
);
|
|
205
228
|
let path;
|
|
206
229
|
if (name.startsWith("@backstage/plugin-")) {
|
|
207
230
|
path = `plugins/${name.replace("@backstage/plugin-", "")}`;
|
|
@@ -209,7 +232,9 @@ var bump = async (opts) => {
|
|
|
209
232
|
path = `packages/${name.replace("@backstage/", "")}`;
|
|
210
233
|
}
|
|
211
234
|
if (path) {
|
|
212
|
-
console.log(
|
|
235
|
+
console.log(
|
|
236
|
+
` https://github.com/backstage/backstage/blob/master/${path}/CHANGELOG.md`
|
|
237
|
+
);
|
|
213
238
|
}
|
|
214
239
|
console.log();
|
|
215
240
|
}
|
|
@@ -226,13 +251,19 @@ var bump = async (opts) => {
|
|
|
226
251
|
if (result.newVersions.length > 0) {
|
|
227
252
|
throw new Error("Duplicate versions present after package bump");
|
|
228
253
|
}
|
|
229
|
-
const forbiddenNewRanges = result.newRanges.filter(
|
|
254
|
+
const forbiddenNewRanges = result.newRanges.filter(
|
|
255
|
+
({ name }) => lint.forbiddenDuplicatesFilter(name)
|
|
256
|
+
);
|
|
230
257
|
if (forbiddenNewRanges.length > 0) {
|
|
231
|
-
throw new Error(
|
|
258
|
+
throw new Error(
|
|
259
|
+
`Version bump failed for ${forbiddenNewRanges.map((i) => i.name).join(", ")}`
|
|
260
|
+
);
|
|
232
261
|
}
|
|
233
262
|
};
|
|
234
263
|
function createStrictVersionFinder(options) {
|
|
235
|
-
const releasePackages = new Map(
|
|
264
|
+
const releasePackages = new Map(
|
|
265
|
+
options.releaseManifest.packages.map((p) => [p.name, p.version])
|
|
266
|
+
);
|
|
236
267
|
return async function findTargetVersion(name) {
|
|
237
268
|
console.log(`Checking for updates of ${name}`);
|
|
238
269
|
const manifestVersion = releasePackages.get(name);
|
|
@@ -250,7 +281,9 @@ function createVersionFinder(options) {
|
|
|
250
281
|
} = options;
|
|
251
282
|
const distTag = releaseLine === "main" ? "latest" : releaseLine;
|
|
252
283
|
const found = /* @__PURE__ */ new Map();
|
|
253
|
-
const releasePackages = new Map(
|
|
284
|
+
const releasePackages = new Map(
|
|
285
|
+
releaseManifest == null ? void 0 : releaseManifest.packages.map((p) => [p.name, p.version])
|
|
286
|
+
);
|
|
254
287
|
return async function findTargetVersion(name) {
|
|
255
288
|
const existing = found.get(name);
|
|
256
289
|
if (existing) {
|
|
@@ -274,10 +307,14 @@ function createVersionFinder(options) {
|
|
|
274
307
|
const latestVersionDateStr = info.time[latestVersion];
|
|
275
308
|
const taggedVersionDateStr = info.time[taggedVersion];
|
|
276
309
|
if (!latestVersionDateStr) {
|
|
277
|
-
throw new Error(
|
|
310
|
+
throw new Error(
|
|
311
|
+
`No time available for version '${latestVersion}' of ${name}`
|
|
312
|
+
);
|
|
278
313
|
}
|
|
279
314
|
if (!taggedVersionDateStr) {
|
|
280
|
-
throw new Error(
|
|
315
|
+
throw new Error(
|
|
316
|
+
`No time available for version '${taggedVersion}' of ${name}`
|
|
317
|
+
);
|
|
281
318
|
}
|
|
282
319
|
const latestVersionRelease = new Date(latestVersionDateStr).getTime();
|
|
283
320
|
const taggedVersionRelease = new Date(taggedVersionDateStr).getTime();
|
|
@@ -306,17 +343,31 @@ async function bumpBackstageJsonVersion(version) {
|
|
|
306
343
|
const from = encodeURIComponent(prevVersion);
|
|
307
344
|
const to = encodeURIComponent(version);
|
|
308
345
|
const link = `https://backstage.github.io/upgrade-helper/?from=${from}&to=${to}`;
|
|
309
|
-
console.log(
|
|
346
|
+
console.log(
|
|
347
|
+
yellow(
|
|
348
|
+
`Upgraded from release ${green(prevVersion)} to ${green(
|
|
349
|
+
version
|
|
350
|
+
)}, please review these template changes:`
|
|
351
|
+
)
|
|
352
|
+
);
|
|
310
353
|
console.log();
|
|
311
354
|
console.log(` ${cyan(link)}`);
|
|
312
355
|
console.log();
|
|
313
356
|
} else {
|
|
314
|
-
console.log(
|
|
357
|
+
console.log(
|
|
358
|
+
yellow(
|
|
359
|
+
`Your project is now at version ${version}, which has been written to ${cliCommon.BACKSTAGE_JSON}`
|
|
360
|
+
)
|
|
361
|
+
);
|
|
315
362
|
}
|
|
316
|
-
await fs__default["default"].writeJson(
|
|
317
|
-
|
|
318
|
-
|
|
319
|
-
|
|
363
|
+
await fs__default["default"].writeJson(
|
|
364
|
+
backstageJsonPath,
|
|
365
|
+
{ ...backstageJson, version },
|
|
366
|
+
{
|
|
367
|
+
spaces: 2,
|
|
368
|
+
encoding: "utf8"
|
|
369
|
+
}
|
|
370
|
+
);
|
|
320
371
|
}
|
|
321
372
|
async function runYarnInstall() {
|
|
322
373
|
const spinner = ora__default["default"]({
|
|
@@ -329,7 +380,11 @@ async function runYarnInstall() {
|
|
|
329
380
|
await run.run("yarn", ["install"], {
|
|
330
381
|
env: {
|
|
331
382
|
FORCE_COLOR: "true",
|
|
332
|
-
...Object.fromEntries(
|
|
383
|
+
...Object.fromEntries(
|
|
384
|
+
Object.entries(process.env).map(
|
|
385
|
+
([name, value]) => name.startsWith("npm_") ? [name, void 0] : [name, value]
|
|
386
|
+
)
|
|
387
|
+
)
|
|
333
388
|
},
|
|
334
389
|
stdoutLogFunc: (data) => installOutput.push(data),
|
|
335
390
|
stderrLogFunc: (data) => installOutput.push(data)
|
|
@@ -346,4 +401,4 @@ exports.bumpBackstageJsonVersion = bumpBackstageJsonVersion;
|
|
|
346
401
|
exports.createStrictVersionFinder = createStrictVersionFinder;
|
|
347
402
|
exports.createVersionFinder = createVersionFinder;
|
|
348
403
|
exports["default"] = bump;
|
|
349
|
-
//# sourceMappingURL=bump-
|
|
404
|
+
//# sourceMappingURL=bump-f3c6b3cd.cjs.js.map
|