@backstage/frontend-test-utils 0.0.0-nightly-20231117021546
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 +16 -0
- package/README.md +12 -0
- package/dist/index.d.ts +20 -0
- package/dist/index.esm.js +94 -0
- package/dist/index.esm.js.map +1 -0
- package/package.json +43 -0
package/CHANGELOG.md
ADDED
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
# @backstage/frontend-test-utils
|
|
2
|
+
|
|
3
|
+
## 0.0.0-nightly-20231117021546
|
|
4
|
+
|
|
5
|
+
### Minor Changes
|
|
6
|
+
|
|
7
|
+
- 59fabd510671: New testing utility library for `@backstage/frontend-app-api` and `@backstage/frontend-plugin-api`.
|
|
8
|
+
|
|
9
|
+
### Patch Changes
|
|
10
|
+
|
|
11
|
+
- 59fabd510671: Added `createExtensionTester` for rendering extensions in tests.
|
|
12
|
+
- Updated dependencies
|
|
13
|
+
- @backstage/frontend-app-api@0.0.0-nightly-20231117021546
|
|
14
|
+
- @backstage/frontend-plugin-api@0.0.0-nightly-20231117021546
|
|
15
|
+
- @backstage/test-utils@0.0.0-nightly-20231117021546
|
|
16
|
+
- @backstage/types@1.1.1
|
package/README.md
ADDED
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
# @backstage/frontend-test-utils
|
|
2
|
+
|
|
3
|
+
Contains utilities that can be used when testing frontend features such as extensions.
|
|
4
|
+
|
|
5
|
+
## Installation
|
|
6
|
+
|
|
7
|
+
Install the package via Yarn into your own packages:
|
|
8
|
+
|
|
9
|
+
```sh
|
|
10
|
+
cd <package-dir> # if within a monorepo
|
|
11
|
+
yarn add --dev @backstage/frontend-test-utils
|
|
12
|
+
```
|
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { Extension } from '@backstage/frontend-plugin-api';
|
|
2
|
+
import { JsonObject } from '@backstage/types';
|
|
3
|
+
import { RenderResult } from '@testing-library/react';
|
|
4
|
+
|
|
5
|
+
/** @public */
|
|
6
|
+
declare class ExtensionTester {
|
|
7
|
+
#private;
|
|
8
|
+
add<TConfig>(extension: Extension<TConfig>, options?: {
|
|
9
|
+
config?: TConfig;
|
|
10
|
+
}): ExtensionTester;
|
|
11
|
+
render(options?: {
|
|
12
|
+
config?: JsonObject;
|
|
13
|
+
}): RenderResult;
|
|
14
|
+
}
|
|
15
|
+
/** @public */
|
|
16
|
+
declare function createExtensionTester<TConfig>(subject: Extension<TConfig>, options?: {
|
|
17
|
+
config?: TConfig;
|
|
18
|
+
}): ExtensionTester;
|
|
19
|
+
|
|
20
|
+
export { ExtensionTester, createExtensionTester };
|
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
import { createSpecializedApp } from '@backstage/frontend-app-api';
|
|
2
|
+
import { createPlugin } from '@backstage/frontend-plugin-api';
|
|
3
|
+
import { MockConfigApi } from '@backstage/test-utils';
|
|
4
|
+
import { render } from '@testing-library/react';
|
|
5
|
+
|
|
6
|
+
var __accessCheck = (obj, member, msg) => {
|
|
7
|
+
if (!member.has(obj))
|
|
8
|
+
throw TypeError("Cannot " + msg);
|
|
9
|
+
};
|
|
10
|
+
var __privateGet = (obj, member, getter) => {
|
|
11
|
+
__accessCheck(obj, member, "read from private field");
|
|
12
|
+
return getter ? getter.call(obj) : member.get(obj);
|
|
13
|
+
};
|
|
14
|
+
var __privateAdd = (obj, member, value) => {
|
|
15
|
+
if (member.has(obj))
|
|
16
|
+
throw TypeError("Cannot add the same private member more than once");
|
|
17
|
+
member instanceof WeakSet ? member.add(obj) : member.set(obj, value);
|
|
18
|
+
};
|
|
19
|
+
var _extensions;
|
|
20
|
+
const _ExtensionTester = class _ExtensionTester {
|
|
21
|
+
constructor() {
|
|
22
|
+
__privateAdd(this, _extensions, new Array());
|
|
23
|
+
}
|
|
24
|
+
/** @internal */
|
|
25
|
+
static forSubject(subject, options) {
|
|
26
|
+
const tester = new _ExtensionTester();
|
|
27
|
+
tester.add(subject, options);
|
|
28
|
+
return tester;
|
|
29
|
+
}
|
|
30
|
+
add(extension, options) {
|
|
31
|
+
__privateGet(this, _extensions).push({
|
|
32
|
+
extension,
|
|
33
|
+
config: options == null ? void 0 : options.config
|
|
34
|
+
});
|
|
35
|
+
return this;
|
|
36
|
+
}
|
|
37
|
+
render(options) {
|
|
38
|
+
const { config = {} } = options != null ? options : {};
|
|
39
|
+
const [subject, ...rest] = __privateGet(this, _extensions);
|
|
40
|
+
if (!subject) {
|
|
41
|
+
throw new Error(
|
|
42
|
+
"No subject found. At least one extension should be added to the tester."
|
|
43
|
+
);
|
|
44
|
+
}
|
|
45
|
+
const extensionsConfig = [
|
|
46
|
+
...rest.map((entry) => ({
|
|
47
|
+
[entry.extension.id]: {
|
|
48
|
+
config: entry.config
|
|
49
|
+
}
|
|
50
|
+
})),
|
|
51
|
+
{
|
|
52
|
+
[subject.extension.id]: {
|
|
53
|
+
attachTo: { id: "core", input: "root" },
|
|
54
|
+
config: subject.config,
|
|
55
|
+
disabled: false
|
|
56
|
+
}
|
|
57
|
+
},
|
|
58
|
+
{
|
|
59
|
+
"core.layout": false
|
|
60
|
+
},
|
|
61
|
+
{
|
|
62
|
+
"core.nav": false
|
|
63
|
+
},
|
|
64
|
+
{
|
|
65
|
+
"core.routes": false
|
|
66
|
+
}
|
|
67
|
+
];
|
|
68
|
+
const finalConfig = {
|
|
69
|
+
...config,
|
|
70
|
+
app: {
|
|
71
|
+
...typeof config.app === "object" ? config.app : void 0,
|
|
72
|
+
extensions: extensionsConfig
|
|
73
|
+
}
|
|
74
|
+
};
|
|
75
|
+
const app = createSpecializedApp({
|
|
76
|
+
features: [
|
|
77
|
+
createPlugin({
|
|
78
|
+
id: "test",
|
|
79
|
+
extensions: __privateGet(this, _extensions).map((entry) => entry.extension)
|
|
80
|
+
})
|
|
81
|
+
],
|
|
82
|
+
config: new MockConfigApi(finalConfig)
|
|
83
|
+
});
|
|
84
|
+
return render(app.createRoot());
|
|
85
|
+
}
|
|
86
|
+
};
|
|
87
|
+
_extensions = new WeakMap();
|
|
88
|
+
let ExtensionTester = _ExtensionTester;
|
|
89
|
+
function createExtensionTester(subject, options) {
|
|
90
|
+
return ExtensionTester.forSubject(subject, options);
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
export { createExtensionTester };
|
|
94
|
+
//# sourceMappingURL=index.esm.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.esm.js","sources":["../src/app/createExtensionTester.ts"],"sourcesContent":["/*\n * Copyright 2023 The Backstage Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { createSpecializedApp } from '@backstage/frontend-app-api';\nimport { Extension, createPlugin } from '@backstage/frontend-plugin-api';\nimport { MockConfigApi } from '@backstage/test-utils';\nimport { JsonArray, JsonObject, JsonValue } from '@backstage/types';\nimport { RenderResult, render } from '@testing-library/react';\n\n/** @public */\nexport class ExtensionTester {\n /** @internal */\n static forSubject<TConfig>(\n subject: Extension<TConfig>,\n options?: { config?: TConfig },\n ): ExtensionTester {\n const tester = new ExtensionTester();\n tester.add(subject, options);\n return tester;\n }\n\n readonly #extensions = new Array<{\n extension: Extension<any>;\n config?: JsonValue;\n }>();\n\n add<TConfig>(\n extension: Extension<TConfig>,\n options?: { config?: TConfig },\n ): ExtensionTester {\n this.#extensions.push({\n extension,\n config: options?.config as JsonValue,\n });\n\n return this;\n }\n\n render(options?: { config?: JsonObject }): RenderResult {\n const { config = {} } = options ?? {};\n\n const [subject, ...rest] = this.#extensions;\n if (!subject) {\n throw new Error(\n 'No subject found. At least one extension should be added to the tester.',\n );\n }\n\n const extensionsConfig: JsonArray = [\n ...rest.map(entry => ({\n [entry.extension.id]: {\n config: entry.config,\n },\n })),\n {\n [subject.extension.id]: {\n attachTo: { id: 'core', input: 'root' },\n config: subject.config,\n disabled: false,\n },\n },\n {\n 'core.layout': false,\n },\n {\n 'core.nav': false,\n },\n {\n 'core.routes': false,\n },\n ];\n\n const finalConfig = {\n ...config,\n app: {\n ...(typeof config.app === 'object' ? config.app : undefined),\n extensions: extensionsConfig,\n },\n };\n\n const app = createSpecializedApp({\n features: [\n createPlugin({\n id: 'test',\n extensions: this.#extensions.map(entry => entry.extension),\n }),\n ],\n config: new MockConfigApi(finalConfig),\n });\n\n return render(app.createRoot());\n }\n}\n\n/** @public */\nexport function createExtensionTester<TConfig>(\n subject: Extension<TConfig>,\n options?: { config?: TConfig },\n): ExtensionTester {\n return ExtensionTester.forSubject(subject, options);\n}\n"],"names":[],"mappings":"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"}
|
package/package.json
ADDED
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@backstage/frontend-test-utils",
|
|
3
|
+
"version": "0.0.0-nightly-20231117021546",
|
|
4
|
+
"main": "dist/index.esm.js",
|
|
5
|
+
"types": "dist/index.d.ts",
|
|
6
|
+
"license": "Apache-2.0",
|
|
7
|
+
"publishConfig": {
|
|
8
|
+
"access": "public",
|
|
9
|
+
"main": "dist/index.esm.js",
|
|
10
|
+
"types": "dist/index.d.ts"
|
|
11
|
+
},
|
|
12
|
+
"backstage": {
|
|
13
|
+
"role": "web-library"
|
|
14
|
+
},
|
|
15
|
+
"sideEffects": false,
|
|
16
|
+
"scripts": {
|
|
17
|
+
"start": "backstage-cli package start",
|
|
18
|
+
"build": "backstage-cli package build",
|
|
19
|
+
"lint": "backstage-cli package lint",
|
|
20
|
+
"test": "backstage-cli package test",
|
|
21
|
+
"clean": "backstage-cli package clean",
|
|
22
|
+
"prepack": "backstage-cli package prepack",
|
|
23
|
+
"postpack": "backstage-cli package postpack"
|
|
24
|
+
},
|
|
25
|
+
"devDependencies": {
|
|
26
|
+
"@backstage/cli": "^0.0.0-nightly-20231117021546",
|
|
27
|
+
"@testing-library/jest-dom": "^6.0.0"
|
|
28
|
+
},
|
|
29
|
+
"files": [
|
|
30
|
+
"dist"
|
|
31
|
+
],
|
|
32
|
+
"dependencies": {
|
|
33
|
+
"@backstage/frontend-app-api": "^0.0.0-nightly-20231117021546",
|
|
34
|
+
"@backstage/frontend-plugin-api": "^0.0.0-nightly-20231117021546",
|
|
35
|
+
"@backstage/test-utils": "^0.0.0-nightly-20231117021546",
|
|
36
|
+
"@backstage/types": "^1.1.1"
|
|
37
|
+
},
|
|
38
|
+
"peerDependencies": {
|
|
39
|
+
"@testing-library/react": "^12.1.3 || ^13.0.0 || ^14.0.0",
|
|
40
|
+
"react": "^16.13.1 || ^17.0.0 || ^18.0.0"
|
|
41
|
+
},
|
|
42
|
+
"module": "./dist/index.esm.js"
|
|
43
|
+
}
|