@backstage/cli 0.8.0 → 0.9.1
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 +74 -0
- package/config/jest.js +1 -0
- package/config/jestSucraseTransform.js +5 -1
- package/dist/cjs/{build-67600f1b.cjs.js → build-33ad5323.cjs.js} +3 -3
- package/dist/cjs/{build-e40a0213.cjs.js → build-7302d21d.cjs.js} +3 -3
- package/dist/cjs/{build-bc4676c2.cjs.js → build-75ee78ab.cjs.js} +5 -5
- package/dist/cjs/{build-b1d7370a.cjs.js → build-e21fe681.cjs.js} +3 -3
- package/dist/cjs/{buildImage-87db5bdc.cjs.js → buildImage-477aa186.cjs.js} +4 -4
- package/dist/cjs/{buildWorkspace-a2cdfe01.cjs.js → buildWorkspace-fa590fad.cjs.js} +4 -4
- package/dist/cjs/{bump-ac730182.cjs.js → bump-5e4ffccb.cjs.js} +28 -6
- package/dist/cjs/{bundle-87d28bdc.cjs.js → bundle-4390c300.cjs.js} +5 -5
- package/dist/cjs/{clean-35a57bd3.cjs.js → clean-9279505e.cjs.js} +2 -2
- package/dist/cjs/{config-1cb21231.cjs.js → config-6ab0fc63.cjs.js} +21 -6
- package/dist/cjs/create-4ffadaca.cjs.js +483 -0
- package/dist/cjs/{createPlugin-2f659d68.cjs.js → createPlugin-eb7251ea.cjs.js} +8 -9
- package/dist/cjs/{dev-16c0ce16.cjs.js → dev-02640e59.cjs.js} +4 -4
- package/dist/cjs/{diff-a4954af4.cjs.js → diff-56188f93.cjs.js} +2 -2
- package/dist/cjs/{docs-a7479ba6.cjs.js → docs-8039cb55.cjs.js} +3 -3
- package/dist/cjs/{index-b7f652f5.cjs.js → index-994e77d9.cjs.js} +170 -51
- package/dist/cjs/{index-0f748910.cjs.js → index-a18a4cd9.cjs.js} +13 -11
- package/dist/cjs/{index-4c79e77e.cjs.js → index-e84c4ef7.cjs.js} +2 -2
- package/dist/cjs/{info-ce3b675b.cjs.js → info-2a0746e3.cjs.js} +3 -3
- package/dist/cjs/{install-f429b250.cjs.js → install-807a9039.cjs.js} +4 -4
- package/dist/cjs/{lint-91629493.cjs.js → lint-03faccc3.cjs.js} +3 -3
- package/dist/cjs/{lint-593f7432.cjs.js → lint-50ae8c8b.cjs.js} +3 -3
- package/dist/cjs/{pack-55575502.cjs.js → pack-7d39c708.cjs.js} +2 -2
- package/dist/cjs/{packager-ffd3916c.cjs.js → packager-d328c8db.cjs.js} +2 -2
- package/dist/cjs/{packages-cf50189b.cjs.js → packages-24e76f27.cjs.js} +3 -3
- package/dist/cjs/{paths-905effc9.cjs.js → paths-eecbbe83.cjs.js} +20 -5
- package/dist/cjs/{print-e38bfaf2.cjs.js → print-fec91280.cjs.js} +5 -4
- package/dist/cjs/{removePlugin-54aea35e.cjs.js → removePlugin-595ea65d.cjs.js} +5 -3
- package/dist/cjs/{run-01f17015.cjs.js → run-40072d67.cjs.js} +2 -2
- package/dist/cjs/{schema-da983141.cjs.js → schema-00648d3a.cjs.js} +3 -3
- package/dist/cjs/{serve-e5e1b0f5.cjs.js → serve-199d043b.cjs.js} +7 -7
- package/dist/cjs/{serve-66ee41a6.cjs.js → serve-e57a7acf.cjs.js} +6 -6
- package/dist/cjs/{server-d911b5cc.cjs.js → server-c7c24602.cjs.js} +2 -2
- package/dist/cjs/{tasks-c4f76ac0.cjs.js → tasks-0f3092d3.cjs.js} +78 -12
- package/dist/cjs/{testCommand-7bcc9228.cjs.js → testCommand-a5c5fec6.cjs.js} +3 -3
- package/dist/cjs/{validate-ce36976b.cjs.js → validate-011c509c.cjs.js} +5 -4
- package/dist/index.cjs.js +1 -1
- package/package.json +21 -20
- package/templates/default-backend-plugin/package.json.hbs +39 -37
- package/templates/default-backend-plugin/src/run.ts.hbs +1 -1
- package/templates/default-common-plugin-package/.eslintrc.js +3 -0
- package/templates/default-common-plugin-package/README.md.hbs +5 -0
- package/templates/default-common-plugin-package/package.json.hbs +34 -0
- package/templates/default-common-plugin-package/src/index.ts.hbs +19 -0
- package/templates/default-common-plugin-package/src/setupTests.ts +1 -0
- package/templates/default-common-plugin-package/tsconfig.json +9 -0
- package/templates/default-plugin/package.json.hbs +5 -3
- package/templates/default-plugin/src/components/ExampleComponent/ExampleComponent.test.tsx.hbs +5 -2
- package/templates/default-plugin/src/components/ExampleFetchComponent/ExampleFetchComponent.test.tsx.hbs +2 -2
- package/templates/default-plugin/src/routes.ts.hbs +1 -1
- package/templates/scaffolder-module/.eslintrc.js +3 -0
- package/templates/scaffolder-module/README.md.hbs +5 -0
- package/templates/scaffolder-module/package.json.hbs +37 -0
- package/templates/scaffolder-module/src/actions/example/example.test.ts +50 -0
- package/templates/scaffolder-module/src/actions/example/example.ts +57 -0
- package/templates/scaffolder-module/src/actions/example/index.ts +1 -0
- package/templates/scaffolder-module/src/actions/index.ts +1 -0
- package/templates/scaffolder-module/src/index.ts.hbs +8 -0
- package/templates/scaffolder-module/tsconfig.json +9 -0
|
@@ -13,16 +13,16 @@ require('webpack-node-externals');
|
|
|
13
13
|
require('@backstage/cli-common');
|
|
14
14
|
require('terser-webpack-plugin');
|
|
15
15
|
require('mini-css-extract-plugin');
|
|
16
|
-
var index = require('./index-
|
|
17
|
-
require('./run-
|
|
16
|
+
var index = require('./index-994e77d9.cjs.js');
|
|
17
|
+
require('./run-40072d67.cjs.js');
|
|
18
18
|
require('lodash/pickBy');
|
|
19
19
|
require('yn');
|
|
20
20
|
require('react-dev-utils/FileSizeReporter');
|
|
21
21
|
require('react-dev-utils/formatWebpackMessages');
|
|
22
|
-
var server = require('./server-
|
|
23
|
-
var config = require('./config-
|
|
22
|
+
var server = require('./server-c7c24602.cjs.js');
|
|
23
|
+
var config = require('./config-6ab0fc63.cjs.js');
|
|
24
24
|
var Lockfile = require('./Lockfile-80f0eec4.cjs.js');
|
|
25
|
-
var lint = require('./lint-
|
|
25
|
+
var lint = require('./lint-50ae8c8b.cjs.js');
|
|
26
26
|
require('commander');
|
|
27
27
|
require('semver');
|
|
28
28
|
require('@backstage/config/package.json');
|
|
@@ -31,7 +31,7 @@ require('child_process');
|
|
|
31
31
|
require('util');
|
|
32
32
|
require('webpack-dev-server');
|
|
33
33
|
require('react-dev-utils/openBrowser');
|
|
34
|
-
require('./paths-
|
|
34
|
+
require('./paths-eecbbe83.cjs.js');
|
|
35
35
|
require('./parallel-a4714c72.cjs.js');
|
|
36
36
|
require('./svgrTemplate-2d0d15cf.cjs.js');
|
|
37
37
|
require('@backstage/config-loader');
|
|
@@ -75,4 +75,4 @@ var serve = async (cmd) => {
|
|
|
75
75
|
};
|
|
76
76
|
|
|
77
77
|
exports.default = serve;
|
|
78
|
-
//# sourceMappingURL=serve-
|
|
78
|
+
//# sourceMappingURL=serve-199d043b.cjs.js.map
|
|
@@ -11,15 +11,15 @@ require('webpack-node-externals');
|
|
|
11
11
|
require('@backstage/cli-common');
|
|
12
12
|
require('terser-webpack-plugin');
|
|
13
13
|
require('mini-css-extract-plugin');
|
|
14
|
-
var index = require('./index-
|
|
15
|
-
require('./run-
|
|
14
|
+
var index = require('./index-994e77d9.cjs.js');
|
|
15
|
+
require('./run-40072d67.cjs.js');
|
|
16
16
|
require('lodash/pickBy');
|
|
17
17
|
require('yn');
|
|
18
18
|
require('react-dev-utils/FileSizeReporter');
|
|
19
19
|
require('react-dev-utils/formatWebpackMessages');
|
|
20
20
|
require('chalk');
|
|
21
|
-
var server = require('./server-
|
|
22
|
-
var config = require('./config-
|
|
21
|
+
var server = require('./server-c7c24602.cjs.js');
|
|
22
|
+
var config = require('./config-6ab0fc63.cjs.js');
|
|
23
23
|
require('commander');
|
|
24
24
|
require('semver');
|
|
25
25
|
require('@backstage/config/package.json');
|
|
@@ -28,7 +28,7 @@ require('child_process');
|
|
|
28
28
|
require('util');
|
|
29
29
|
require('webpack-dev-server');
|
|
30
30
|
require('react-dev-utils/openBrowser');
|
|
31
|
-
require('./paths-
|
|
31
|
+
require('./paths-eecbbe83.cjs.js');
|
|
32
32
|
require('./parallel-a4714c72.cjs.js');
|
|
33
33
|
require('./svgrTemplate-2d0d15cf.cjs.js');
|
|
34
34
|
require('@backstage/config-loader');
|
|
@@ -53,4 +53,4 @@ var serve = async (cmd) => {
|
|
|
53
53
|
};
|
|
54
54
|
|
|
55
55
|
exports.default = serve;
|
|
56
|
-
//# sourceMappingURL=serve-
|
|
56
|
+
//# sourceMappingURL=serve-e57a7acf.cjs.js.map
|
|
@@ -4,7 +4,7 @@ var fs = require('fs-extra');
|
|
|
4
4
|
var webpack = require('webpack');
|
|
5
5
|
var WebpackDevServer = require('webpack-dev-server');
|
|
6
6
|
var openBrowser = require('react-dev-utils/openBrowser');
|
|
7
|
-
var paths = require('./paths-
|
|
7
|
+
var paths = require('./paths-eecbbe83.cjs.js');
|
|
8
8
|
|
|
9
9
|
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
|
|
10
10
|
|
|
@@ -70,4 +70,4 @@ async function serveBundle(options) {
|
|
|
70
70
|
}
|
|
71
71
|
|
|
72
72
|
exports.serveBundle = serveBundle;
|
|
73
|
-
//# sourceMappingURL=server-
|
|
73
|
+
//# sourceMappingURL=server-c7c24602.cjs.js.map
|
|
@@ -2,11 +2,14 @@
|
|
|
2
2
|
|
|
3
3
|
var fs = require('fs-extra');
|
|
4
4
|
var path = require('path');
|
|
5
|
+
var index = require('./index-994e77d9.cjs.js');
|
|
5
6
|
var chalk = require('chalk');
|
|
6
7
|
var handlebars = require('handlebars');
|
|
7
8
|
var ora = require('ora');
|
|
9
|
+
var util = require('util');
|
|
8
10
|
var recursive = require('recursive-readdir');
|
|
9
|
-
var
|
|
11
|
+
var child_process = require('child_process');
|
|
12
|
+
var errors = require('@backstage/errors');
|
|
10
13
|
|
|
11
14
|
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
|
|
12
15
|
|
|
@@ -22,13 +25,13 @@ const USER_ID_RE = /^@[-\w]+$/;
|
|
|
22
25
|
const EMAIL_RE = /^[^@]+@[-.\w]+\.[-\w]+$/i;
|
|
23
26
|
const DEFAULT_OWNER = "@backstage/maintainers";
|
|
24
27
|
async function getCodeownersFilePath(rootDir) {
|
|
25
|
-
const
|
|
28
|
+
const possiblePaths = [
|
|
26
29
|
path__default['default'].join(rootDir, ".github", "CODEOWNERS"),
|
|
27
30
|
path__default['default'].join(rootDir, ".gitlab", "CODEOWNERS"),
|
|
28
31
|
path__default['default'].join(rootDir, "docs", "CODEOWNERS"),
|
|
29
32
|
path__default['default'].join(rootDir, "CODEOWNERS")
|
|
30
33
|
];
|
|
31
|
-
for (const p of
|
|
34
|
+
for (const p of possiblePaths) {
|
|
32
35
|
if (await fs__default['default'].pathExists(p)) {
|
|
33
36
|
return p;
|
|
34
37
|
}
|
|
@@ -51,8 +54,19 @@ function parseOwnerIds(spaceSeparatedOwnerIds) {
|
|
|
51
54
|
}
|
|
52
55
|
return ids;
|
|
53
56
|
}
|
|
54
|
-
async function addCodeownersEntry(
|
|
55
|
-
const
|
|
57
|
+
async function addCodeownersEntry(ownedPath, ownerStr, codeownersFilePath) {
|
|
58
|
+
const ownerIds = parseOwnerIds(ownerStr);
|
|
59
|
+
if (!ownerIds || ownerIds.length === 0) {
|
|
60
|
+
return false;
|
|
61
|
+
}
|
|
62
|
+
let filePath = codeownersFilePath;
|
|
63
|
+
if (!filePath) {
|
|
64
|
+
filePath = await getCodeownersFilePath(index.paths.targetRoot);
|
|
65
|
+
if (!filePath) {
|
|
66
|
+
return false;
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
const allLines = (await fs__default['default'].readFile(filePath, "utf8")).split("\n");
|
|
56
70
|
const commentLines = [];
|
|
57
71
|
for (const line of allLines) {
|
|
58
72
|
if (line[0] !== "#") {
|
|
@@ -75,24 +89,26 @@ async function addCodeownersEntry(codeownersFilePath, ownedPath, ownerIds) {
|
|
|
75
89
|
return [entryPath, ...entry.ownerIds].join(" ");
|
|
76
90
|
});
|
|
77
91
|
const newLines = [...commentLines, "", ...newDeclarationLines, ""];
|
|
78
|
-
await fs__default['default'].writeFile(
|
|
92
|
+
await fs__default['default'].writeFile(filePath, newLines.join("\n"), "utf8");
|
|
93
|
+
return true;
|
|
79
94
|
}
|
|
80
95
|
|
|
96
|
+
const exec = util.promisify(child_process.exec);
|
|
81
97
|
const TASK_NAME_MAX_LENGTH = 14;
|
|
82
98
|
class Task {
|
|
83
99
|
static log(name = "") {
|
|
84
|
-
process.
|
|
100
|
+
process.stderr.write(`${chalk__default['default'].green(name)}
|
|
85
101
|
`);
|
|
86
102
|
}
|
|
87
103
|
static error(message = "") {
|
|
88
|
-
process.
|
|
104
|
+
process.stderr.write(`
|
|
89
105
|
${chalk__default['default'].red(message)}
|
|
90
106
|
|
|
91
107
|
`);
|
|
92
108
|
}
|
|
93
109
|
static section(name) {
|
|
94
110
|
const title = chalk__default['default'].green(`${name}:`);
|
|
95
|
-
process.
|
|
111
|
+
process.stderr.write(`
|
|
96
112
|
${title}
|
|
97
113
|
`);
|
|
98
114
|
}
|
|
@@ -107,13 +123,34 @@ ${chalk__default['default'].red(message)}
|
|
|
107
123
|
color: "green"
|
|
108
124
|
}).start();
|
|
109
125
|
try {
|
|
110
|
-
await taskFunc();
|
|
126
|
+
const result = await taskFunc();
|
|
111
127
|
spinner.succeed();
|
|
128
|
+
return result;
|
|
112
129
|
} catch (error) {
|
|
113
130
|
spinner.fail();
|
|
114
131
|
throw error;
|
|
115
132
|
}
|
|
116
133
|
}
|
|
134
|
+
static async forCommand(command, options) {
|
|
135
|
+
try {
|
|
136
|
+
await Task.forItem("executing", command, async () => {
|
|
137
|
+
await exec(command, {cwd: options == null ? void 0 : options.cwd});
|
|
138
|
+
});
|
|
139
|
+
} catch (error) {
|
|
140
|
+
errors.assertError(error);
|
|
141
|
+
if (error.stderr) {
|
|
142
|
+
process.stderr.write(error.stderr);
|
|
143
|
+
}
|
|
144
|
+
if (error.stdout) {
|
|
145
|
+
process.stdout.write(error.stdout);
|
|
146
|
+
}
|
|
147
|
+
if (options == null ? void 0 : options.optional) {
|
|
148
|
+
Task.error(`Warning: Failed to execute command ${chalk__default['default'].cyan(command)}`);
|
|
149
|
+
} else {
|
|
150
|
+
throw new Error(`Failed to execute command '${chalk__default['default'].cyan(command)}', ${error}`);
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
}
|
|
117
154
|
}
|
|
118
155
|
async function templatingTask(templateDir, destinationDir, context, versionProvider) {
|
|
119
156
|
const files = await recursive__default['default'](templateDir).catch((error) => {
|
|
@@ -127,7 +164,9 @@ async function templatingTask(templateDir, destinationDir, context, versionProvi
|
|
|
127
164
|
await Task.forItem("templating", path.basename(file), async () => {
|
|
128
165
|
const destination = destinationFile.replace(/\.hbs$/, "");
|
|
129
166
|
const template = await fs__default['default'].readFile(file);
|
|
130
|
-
const compiled = handlebars__default['default'].compile(template.toString()
|
|
167
|
+
const compiled = handlebars__default['default'].compile(template.toString(), {
|
|
168
|
+
strict: true
|
|
169
|
+
});
|
|
131
170
|
const contents = compiled({name: path.basename(destination), ...context}, {
|
|
132
171
|
helpers: {
|
|
133
172
|
versionQuery(name, versionHint) {
|
|
@@ -152,10 +191,37 @@ async function templatingTask(templateDir, destinationDir, context, versionProvi
|
|
|
152
191
|
}
|
|
153
192
|
}
|
|
154
193
|
}
|
|
194
|
+
async function addPackageDependency(path, options) {
|
|
195
|
+
try {
|
|
196
|
+
const pkgJson = await fs__default['default'].readJson(path);
|
|
197
|
+
const normalize = (obj) => {
|
|
198
|
+
if (Object.keys(obj).length === 0) {
|
|
199
|
+
return void 0;
|
|
200
|
+
}
|
|
201
|
+
return Object.fromEntries(Object.keys(obj).sort().map((key) => [key, obj[key]]));
|
|
202
|
+
};
|
|
203
|
+
pkgJson.dependencies = normalize({
|
|
204
|
+
...pkgJson.dependencies,
|
|
205
|
+
...options.dependencies
|
|
206
|
+
});
|
|
207
|
+
pkgJson.devDependencies = normalize({
|
|
208
|
+
...pkgJson.devDependencies,
|
|
209
|
+
...options.devDependencies
|
|
210
|
+
});
|
|
211
|
+
pkgJson.peerDependencies = normalize({
|
|
212
|
+
...pkgJson.peerDependencies,
|
|
213
|
+
...options.peerDependencies
|
|
214
|
+
});
|
|
215
|
+
await fs__default['default'].writeJson(path, pkgJson, {spaces: 2});
|
|
216
|
+
} catch (error) {
|
|
217
|
+
throw new Error(`Failed to add package dependencies, ${error}`);
|
|
218
|
+
}
|
|
219
|
+
}
|
|
155
220
|
|
|
156
221
|
exports.Task = Task;
|
|
157
222
|
exports.addCodeownersEntry = addCodeownersEntry;
|
|
223
|
+
exports.addPackageDependency = addPackageDependency;
|
|
158
224
|
exports.getCodeownersFilePath = getCodeownersFilePath;
|
|
159
225
|
exports.parseOwnerIds = parseOwnerIds;
|
|
160
226
|
exports.templatingTask = templatingTask;
|
|
161
|
-
//# sourceMappingURL=tasks-
|
|
227
|
+
//# sourceMappingURL=tasks-0f3092d3.cjs.js.map
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
|
-
var index = require('./index-
|
|
4
|
-
var run = require('./run-
|
|
3
|
+
var index = require('./index-994e77d9.cjs.js');
|
|
4
|
+
var run = require('./run-40072d67.cjs.js');
|
|
5
5
|
require('commander');
|
|
6
6
|
require('chalk');
|
|
7
7
|
require('fs-extra');
|
|
@@ -45,4 +45,4 @@ var testCommand = async (cmd) => {
|
|
|
45
45
|
};
|
|
46
46
|
|
|
47
47
|
exports.default = testCommand;
|
|
48
|
-
//# sourceMappingURL=testCommand-
|
|
48
|
+
//# sourceMappingURL=testCommand-a5c5fec6.cjs.js.map
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
|
-
var config = require('./config-
|
|
3
|
+
var config = require('./config-6ab0fc63.cjs.js');
|
|
4
4
|
require('@backstage/config-loader');
|
|
5
5
|
require('@backstage/config');
|
|
6
|
-
require('./index-
|
|
6
|
+
require('./index-994e77d9.cjs.js');
|
|
7
7
|
require('commander');
|
|
8
8
|
require('chalk');
|
|
9
9
|
require('fs-extra');
|
|
@@ -16,9 +16,10 @@ var validate = async (cmd) => {
|
|
|
16
16
|
await config.loadCliConfig({
|
|
17
17
|
args: cmd.config,
|
|
18
18
|
fromPackage: cmd.package,
|
|
19
|
-
mockEnv: cmd.lax
|
|
19
|
+
mockEnv: cmd.lax,
|
|
20
|
+
fullVisibility: !cmd.frontend
|
|
20
21
|
});
|
|
21
22
|
};
|
|
22
23
|
|
|
23
24
|
exports.default = validate;
|
|
24
|
-
//# sourceMappingURL=validate-
|
|
25
|
+
//# sourceMappingURL=validate-011c509c.cjs.js.map
|
package/dist/index.cjs.js
CHANGED
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@backstage/cli",
|
|
3
3
|
"description": "CLI for developing Backstage plugins and apps",
|
|
4
|
-
"version": "0.
|
|
4
|
+
"version": "0.9.1",
|
|
5
5
|
"private": false,
|
|
6
6
|
"publishConfig": {
|
|
7
7
|
"access": "public"
|
|
@@ -28,21 +28,22 @@
|
|
|
28
28
|
"backstage-cli": "bin/backstage-cli"
|
|
29
29
|
},
|
|
30
30
|
"dependencies": {
|
|
31
|
-
"@backstage/cli-common": "^0.1.
|
|
32
|
-
"@backstage/config": "^0.1.
|
|
33
|
-
"@backstage/config-loader": "^0.
|
|
34
|
-
"@backstage/errors": "^0.1.
|
|
31
|
+
"@backstage/cli-common": "^0.1.6",
|
|
32
|
+
"@backstage/config": "^0.1.11",
|
|
33
|
+
"@backstage/config-loader": "^0.8.0",
|
|
34
|
+
"@backstage/errors": "^0.1.5",
|
|
35
|
+
"@backstage/types": "^0.1.1",
|
|
35
36
|
"@hot-loader/react-dom": "^16.13.0",
|
|
36
37
|
"@lerna/package-graph": "^4.0.0",
|
|
37
38
|
"@lerna/project": "^4.0.0",
|
|
38
39
|
"@octokit/request": "^5.4.12",
|
|
39
|
-
"@rollup/plugin-commonjs": "^
|
|
40
|
+
"@rollup/plugin-commonjs": "^21.0.1",
|
|
40
41
|
"@rollup/plugin-json": "^4.0.2",
|
|
41
42
|
"@rollup/plugin-node-resolve": "^13.0.0",
|
|
42
43
|
"@rollup/plugin-yaml": "^3.0.0",
|
|
43
|
-
"@spotify/eslint-config-base": "^
|
|
44
|
-
"@spotify/eslint-config-react": "^
|
|
45
|
-
"@spotify/eslint-config-typescript": "^
|
|
44
|
+
"@spotify/eslint-config-base": "^12.0.0",
|
|
45
|
+
"@spotify/eslint-config-react": "^12.0.0",
|
|
46
|
+
"@spotify/eslint-config-typescript": "^12.0.0",
|
|
46
47
|
"@sucrase/jest-plugin": "^2.1.1",
|
|
47
48
|
"@sucrase/webpack-loader": "^2.0.0",
|
|
48
49
|
"@svgr/plugin-jsx": "5.5.x",
|
|
@@ -81,7 +82,7 @@
|
|
|
81
82
|
"jest": "^26.0.1",
|
|
82
83
|
"jest-css-modules": "^2.1.0",
|
|
83
84
|
"jest-transform-yaml": "^0.1.1",
|
|
84
|
-
"json-schema": "^0.
|
|
85
|
+
"json-schema": "^0.4.0",
|
|
85
86
|
"lodash": "^4.17.21",
|
|
86
87
|
"mini-css-extract-plugin": "^2.4.2",
|
|
87
88
|
"node-libs-browser": "^2.2.1",
|
|
@@ -109,21 +110,21 @@
|
|
|
109
110
|
"typescript": "^4.0.3",
|
|
110
111
|
"util": "^0.12.3",
|
|
111
112
|
"webpack": "^5.48.0",
|
|
112
|
-
"webpack-dev-server": "4.
|
|
113
|
+
"webpack-dev-server": "4.3.1",
|
|
113
114
|
"webpack-node-externals": "^3.0.0",
|
|
114
115
|
"yaml": "^1.10.0",
|
|
115
116
|
"yml-loader": "^2.1.0",
|
|
116
117
|
"yn": "^4.0.0"
|
|
117
118
|
},
|
|
118
119
|
"devDependencies": {
|
|
119
|
-
"@backstage/backend-common": "^0.9.
|
|
120
|
-
"@backstage/config": "^0.1.
|
|
121
|
-
"@backstage/core-app-api": "^0.1.
|
|
122
|
-
"@backstage/core-components": "^0.7.
|
|
123
|
-
"@backstage/core-plugin-api": "^0.1
|
|
124
|
-
"@backstage/dev-utils": "^0.2.
|
|
125
|
-
"@backstage/test-utils": "^0.1.
|
|
126
|
-
"@backstage/theme": "^0.2.
|
|
120
|
+
"@backstage/backend-common": "^0.9.11",
|
|
121
|
+
"@backstage/config": "^0.1.11",
|
|
122
|
+
"@backstage/core-app-api": "^0.1.23",
|
|
123
|
+
"@backstage/core-components": "^0.7.5",
|
|
124
|
+
"@backstage/core-plugin-api": "^0.2.1",
|
|
125
|
+
"@backstage/dev-utils": "^0.2.13",
|
|
126
|
+
"@backstage/test-utils": "^0.1.23",
|
|
127
|
+
"@backstage/theme": "^0.2.13",
|
|
127
128
|
"@types/diff": "^5.0.0",
|
|
128
129
|
"@types/express": "^4.17.6",
|
|
129
130
|
"@types/fs-extra": "^9.0.1",
|
|
@@ -233,5 +234,5 @@
|
|
|
233
234
|
}
|
|
234
235
|
}
|
|
235
236
|
},
|
|
236
|
-
"gitHead": "
|
|
237
|
+
"gitHead": "85c127e436a24140bb3606f17f034f82aa9c7c0d"
|
|
237
238
|
}
|
|
@@ -4,41 +4,43 @@
|
|
|
4
4
|
"main": "src/index.ts",
|
|
5
5
|
"types": "src/index.ts",
|
|
6
6
|
"license": "Apache-2.0",
|
|
7
|
-
|
|
8
|
-
{{
|
|
7
|
+
{{#if privatePackage}}
|
|
8
|
+
"private": {{privatePackage}},
|
|
9
|
+
{{/if}}
|
|
9
10
|
"publishConfig": {
|
|
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
|
-
|
|
11
|
+
{{#if npmRegistry}}
|
|
12
|
+
"registry": "{{npmRegistry}}",
|
|
13
|
+
{{/if}}
|
|
14
|
+
"access": "public",
|
|
15
|
+
"main": "dist/index.cjs.js",
|
|
16
|
+
"types": "dist/index.d.ts"
|
|
17
|
+
},
|
|
18
|
+
"scripts": {
|
|
19
|
+
"start": "backstage-cli backend:dev",
|
|
20
|
+
"build": "backstage-cli backend:build",
|
|
21
|
+
"lint": "backstage-cli lint",
|
|
22
|
+
"test": "backstage-cli test",
|
|
23
|
+
"prepack": "backstage-cli prepack",
|
|
24
|
+
"postpack": "backstage-cli postpack",
|
|
25
|
+
"clean": "backstage-cli clean"
|
|
26
|
+
},
|
|
27
|
+
"dependencies": {
|
|
28
|
+
"@backstage/backend-common": "{{versionQuery '@backstage/backend-common'}}",
|
|
29
|
+
"@backstage/config": "{{versionQuery '@backstage/config'}}",
|
|
30
|
+
"@types/express": "{{versionQuery '@types/express' '4.17.6'}}",
|
|
31
|
+
"express": "{{versionQuery 'express' '4.17.1'}}",
|
|
32
|
+
"express-promise-router": "{{versionQuery 'express-promise-router' '4.1.0'}}",
|
|
33
|
+
"winston": "{{versionQuery 'winston' '3.2.1'}}",
|
|
34
|
+
"cross-fetch": "{{versionQuery 'cross-fetch' '3.0.6'}}",
|
|
35
|
+
"yn": "{{versionQuery 'yn' '4.0.0'}}"
|
|
36
|
+
},
|
|
37
|
+
"devDependencies": {
|
|
38
|
+
"@backstage/cli": "{{versionQuery '@backstage/cli'}}",
|
|
39
|
+
"@types/supertest": "{{versionQuery '@types/supertest' '2.0.8'}}",
|
|
40
|
+
"supertest": "{{versionQuery 'supertest' '4.0.2'}}",
|
|
41
|
+
"msw": "{{versionQuery 'msw' '0.35.0'}}"
|
|
42
|
+
},
|
|
43
|
+
"files": [
|
|
44
|
+
"dist"
|
|
45
|
+
]
|
|
46
|
+
}
|
|
@@ -18,7 +18,7 @@ import { getRootLogger } from '@backstage/backend-common';
|
|
|
18
18
|
import yn from 'yn';
|
|
19
19
|
import { startStandaloneServer } from './service/standaloneServer';
|
|
20
20
|
|
|
21
|
-
const port = process.env.PLUGIN_PORT ? Number(process.env.PLUGIN_PORT) :
|
|
21
|
+
const port = process.env.PLUGIN_PORT ? Number(process.env.PLUGIN_PORT) : 7007;
|
|
22
22
|
const enableCors = yn(process.env.PLUGIN_CORS, { default: false });
|
|
23
23
|
const logger = getRootLogger();
|
|
24
24
|
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "{{name}}",
|
|
3
|
+
"description": "Common functionalities for the {{id}} plugin",
|
|
4
|
+
"version": "{{pluginVersion}}",
|
|
5
|
+
"main": "src/index.ts",
|
|
6
|
+
"types": "src/index.ts",
|
|
7
|
+
"license": "Apache-2.0",
|
|
8
|
+
{{#if privatePackage}}
|
|
9
|
+
"private": {{privatePackage}},
|
|
10
|
+
{{/if}}
|
|
11
|
+
"publishConfig": {
|
|
12
|
+
{{#if npmRegistry}}
|
|
13
|
+
"registry": "{{npmRegistry}}",
|
|
14
|
+
{{/if}}
|
|
15
|
+
"access": "public",
|
|
16
|
+
"main": "dist/index.cjs.js",
|
|
17
|
+
"module": "dist/index.esm.js",
|
|
18
|
+
"types": "dist/index.d.ts"
|
|
19
|
+
},
|
|
20
|
+
"scripts": {
|
|
21
|
+
"build": "backstage-cli build",
|
|
22
|
+
"lint": "backstage-cli lint",
|
|
23
|
+
"test": "backstage-cli test",
|
|
24
|
+
"prepack": "backstage-cli prepack",
|
|
25
|
+
"postpack": "backstage-cli postpack",
|
|
26
|
+
"clean": "backstage-cli clean"
|
|
27
|
+
},
|
|
28
|
+
"devDependencies": {
|
|
29
|
+
"@backstage/cli": "{{versionQuery '@backstage/cli'}}"
|
|
30
|
+
},
|
|
31
|
+
"files": [
|
|
32
|
+
"dist"
|
|
33
|
+
]
|
|
34
|
+
}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
/***/
|
|
2
|
+
/**
|
|
3
|
+
* Common functionalities for the {{id}} plugin.
|
|
4
|
+
*
|
|
5
|
+
* @packageDocumentation
|
|
6
|
+
*/
|
|
7
|
+
|
|
8
|
+
/**
|
|
9
|
+
* In this package you might for example declare types that are common
|
|
10
|
+
* between the frontend and backend plugin packages.
|
|
11
|
+
*/
|
|
12
|
+
export type CommonType = {
|
|
13
|
+
field: string
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
/**
|
|
17
|
+
* Or you might declare some common constants.
|
|
18
|
+
*/
|
|
19
|
+
export const COMMON_CONSTANT = 1
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -4,10 +4,12 @@
|
|
|
4
4
|
"main": "src/index.ts",
|
|
5
5
|
"types": "src/index.ts",
|
|
6
6
|
"license": "Apache-2.0",
|
|
7
|
-
{{#if privatePackage}}
|
|
7
|
+
{{#if privatePackage}}
|
|
8
|
+
"private": {{privatePackage}},
|
|
8
9
|
{{/if}}
|
|
9
10
|
"publishConfig": {
|
|
10
|
-
{{#if npmRegistry}}
|
|
11
|
+
{{#if npmRegistry}}
|
|
12
|
+
"registry": "{{npmRegistry}}",
|
|
11
13
|
{{/if}}
|
|
12
14
|
"access": "public",
|
|
13
15
|
"main": "dist/index.esm.js",
|
|
@@ -44,7 +46,7 @@
|
|
|
44
46
|
"@testing-library/user-event": "{{versionQuery '@testing-library/user-event' '13.1.8'}}",
|
|
45
47
|
"@types/jest": "{{versionQuery '@types/jest' '26.0.7'}}",
|
|
46
48
|
"@types/node": "{{versionQuery '@types/node' '14.14.32'}}",
|
|
47
|
-
"msw": "{{versionQuery 'msw' '0.
|
|
49
|
+
"msw": "{{versionQuery 'msw' '0.35.0'}}",
|
|
48
50
|
"cross-fetch": "{{versionQuery 'cross-fetch' '3.0.6'}}"
|
|
49
51
|
},
|
|
50
52
|
"files": [
|
package/templates/default-plugin/src/components/ExampleComponent/ExampleComponent.test.tsx.hbs
CHANGED
|
@@ -4,12 +4,15 @@ import { ThemeProvider } from '@material-ui/core';
|
|
|
4
4
|
import { lightTheme } from '@backstage/theme';
|
|
5
5
|
import { rest } from 'msw';
|
|
6
6
|
import { setupServer } from 'msw/node';
|
|
7
|
-
import {
|
|
7
|
+
import {
|
|
8
|
+
setupRequestMockHandlers,
|
|
9
|
+
renderInTestApp,
|
|
10
|
+
} from "@backstage/test-utils";
|
|
8
11
|
|
|
9
12
|
describe('ExampleComponent', () => {
|
|
10
13
|
const server = setupServer();
|
|
11
14
|
// Enable sane handlers for network requests
|
|
12
|
-
|
|
15
|
+
setupRequestMockHandlers(server);
|
|
13
16
|
|
|
14
17
|
// setup mock response
|
|
15
18
|
beforeEach(() => {
|
|
@@ -3,12 +3,12 @@ import { render } from '@testing-library/react';
|
|
|
3
3
|
import { ExampleFetchComponent } from './ExampleFetchComponent';
|
|
4
4
|
import { rest } from 'msw';
|
|
5
5
|
import { setupServer } from 'msw/node';
|
|
6
|
-
import {
|
|
6
|
+
import { setupRequestMockHandlers } from '@backstage/test-utils';
|
|
7
7
|
|
|
8
8
|
describe('ExampleFetchComponent', () => {
|
|
9
9
|
const server = setupServer();
|
|
10
10
|
// Enable sane handlers for network requests
|
|
11
|
-
|
|
11
|
+
setupRequestMockHandlers(server);
|
|
12
12
|
|
|
13
13
|
// setup mock response
|
|
14
14
|
beforeEach(() => {
|