@modern-js/plugin-testing 2.0.0-beta.3 → 2.0.0-beta.6
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 +159 -0
- package/dist/js/modern/base/config/index.js +29 -9
- package/dist/js/modern/base/config/patches/assetsModule.js +7 -7
- package/dist/js/modern/base/config/patches/filemock.js +4 -1
- package/dist/js/modern/base/config/patches/index.js +30 -7
- package/dist/js/modern/base/config/patches/transformer.js +13 -18
- package/dist/js/modern/base/config/resolver.js +20 -11
- package/dist/js/modern/base/config/testConfigOperator.js +29 -23
- package/dist/js/modern/base/config/transformer/babelTransformer.js +16 -8
- package/dist/js/modern/base/hook.js +10 -5
- package/dist/js/modern/base/index.js +14 -6
- package/dist/js/modern/base/runJest.js +73 -62
- package/dist/js/modern/base/utils.js +40 -23
- package/dist/js/modern/cli/bff/app.js +37 -12
- package/dist/js/modern/cli/bff/constant.js +4 -1
- package/dist/js/modern/cli/bff/index.js +95 -52
- package/dist/js/modern/cli/bff/mockAPI.js +79 -64
- package/dist/js/modern/cli/bff/setup.js +71 -34
- package/dist/js/modern/cli/bff/utils/index.js +31 -15
- package/dist/js/modern/cli/index.js +65 -30
- package/dist/js/modern/cli/test.js +53 -18
- package/dist/js/modern/constant.js +4 -1
- package/dist/js/modern/index.js +3 -3
- package/dist/js/modern/modern-app.env.d.js +0 -0
- package/dist/js/modern/runtime-testing/app.js +25 -14
- package/dist/js/modern/runtime-testing/base.js +7 -3
- package/dist/js/modern/runtime-testing/customRender.js +24 -10
- package/dist/js/modern/runtime-testing/index.js +1 -1
- package/dist/js/modern/runtime-testing/reduck.js +41 -19
- package/dist/js/modern/runtime-testing/request.js +4 -4
- package/dist/js/modern/runtime-testing/resolvePlugins.js +24 -8
- package/dist/js/node/base/config/index.js +62 -18
- package/dist/js/node/base/config/patches/assetsModule.js +34 -12
- package/dist/js/node/base/config/patches/filemock.js +24 -7
- package/dist/js/node/base/config/patches/index.js +54 -15
- package/dist/js/node/base/config/patches/transformer.js +42 -25
- package/dist/js/node/base/config/resolver.js +25 -10
- package/dist/js/node/base/config/testConfigOperator.js +51 -30
- package/dist/js/node/base/config/transformer/babelTransformer.js +42 -15
- package/dist/js/node/base/hook.js +34 -13
- package/dist/js/node/base/index.js +39 -62
- package/dist/js/node/base/runJest.js +104 -71
- package/dist/js/node/base/types/index.js +15 -0
- package/dist/js/node/base/utils.js +70 -34
- package/dist/js/node/cli/bff/app.js +64 -22
- package/dist/js/node/cli/bff/constant.js +26 -7
- package/dist/js/node/cli/bff/index.js +123 -65
- package/dist/js/node/cli/bff/mockAPI.js +103 -71
- package/dist/js/node/cli/bff/setup.js +71 -28
- package/dist/js/node/cli/bff/utils/index.js +57 -22
- package/dist/js/node/cli/index.js +92 -46
- package/dist/js/node/cli/test.js +81 -27
- package/dist/js/node/constant.js +26 -7
- package/dist/js/node/index.js +19 -18
- package/dist/js/node/modern-app.env.d.js +0 -0
- package/dist/js/node/runtime-testing/app.js +53 -25
- package/dist/js/node/runtime-testing/base.js +34 -32
- package/dist/js/node/runtime-testing/customRender.js +49 -18
- package/dist/js/node/runtime-testing/index.js +18 -27
- package/dist/js/node/runtime-testing/reduck.js +72 -31
- package/dist/js/node/runtime-testing/request.js +36 -13
- package/dist/js/node/runtime-testing/resolvePlugins.js +41 -12
- package/dist/js/treeshaking/base/config/index.js +150 -31
- package/dist/js/treeshaking/base/config/patches/assetsModule.js +9 -11
- package/dist/js/treeshaking/base/config/patches/filemock.js +2 -1
- package/dist/js/treeshaking/base/config/patches/index.js +221 -64
- package/dist/js/treeshaking/base/config/patches/transformer.js +34 -37
- package/dist/js/treeshaking/base/config/resolver.js +36 -13
- package/dist/js/treeshaking/base/config/testConfigOperator.js +120 -69
- package/dist/js/treeshaking/base/config/transformer/babelTransformer.js +16 -10
- package/dist/js/treeshaking/base/hook.js +8 -7
- package/dist/js/treeshaking/base/index.js +7 -6
- package/dist/js/treeshaking/base/runJest.js +281 -164
- package/dist/js/treeshaking/base/types/index.js +1 -0
- package/dist/js/treeshaking/base/utils.js +72 -48
- package/dist/js/treeshaking/cli/bff/app.js +192 -68
- package/dist/js/treeshaking/cli/bff/constant.js +2 -1
- package/dist/js/treeshaking/cli/bff/index.js +291 -130
- package/dist/js/treeshaking/cli/bff/mockAPI.js +181 -91
- package/dist/js/treeshaking/cli/bff/setup.js +185 -59
- package/dist/js/treeshaking/cli/bff/utils/index.js +47 -21
- package/dist/js/treeshaking/cli/index.js +249 -108
- package/dist/js/treeshaking/cli/test.js +177 -44
- package/dist/js/treeshaking/constant.js +2 -1
- package/dist/js/treeshaking/index.js +3 -3
- package/dist/js/treeshaking/modern-app.env.d.js +1 -0
- package/dist/js/treeshaking/runtime-testing/app.js +85 -39
- package/dist/js/treeshaking/runtime-testing/base.js +4 -3
- package/dist/js/treeshaking/runtime-testing/customRender.js +38 -10
- package/dist/js/treeshaking/runtime-testing/index.js +1 -1
- package/dist/js/treeshaking/runtime-testing/reduck.js +85 -33
- package/dist/js/treeshaking/runtime-testing/request.js +49 -19
- package/dist/js/treeshaking/runtime-testing/resolvePlugins.js +45 -14
- package/dist/types/base/config/index.d.ts +1 -0
- package/dist/types/base/config/patches/assetsModule.d.ts +1 -0
- package/dist/types/base/config/patches/filemock.d.ts +1 -0
- package/dist/types/base/config/patches/transformer.d.ts +1 -0
- package/dist/types/base/config/testConfigOperator.d.ts +2 -0
- package/dist/types/base/runJest.d.ts +2 -0
- package/dist/types/base/utils.d.ts +1 -0
- package/dist/types/cli/bff/index.d.ts +2 -0
- package/dist/types/cli/bff/mockAPI.d.ts +1 -0
- package/dist/types/cli/index.d.ts +2 -0
- package/dist/types/runtime-testing/app.d.ts +3 -0
- package/dist/types/runtime-testing/customRender.d.ts +2 -0
- package/package.json +21 -25
|
@@ -1,17 +1,47 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
Object.
|
|
4
|
-
|
|
1
|
+
var __create = Object.create;
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __getOwnPropSymbols = Object.getOwnPropertySymbols;
|
|
6
|
+
var __getProtoOf = Object.getPrototypeOf;
|
|
7
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
8
|
+
var __propIsEnum = Object.prototype.propertyIsEnumerable;
|
|
9
|
+
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
10
|
+
var __spreadValues = (a, b) => {
|
|
11
|
+
for (var prop in b || (b = {}))
|
|
12
|
+
if (__hasOwnProp.call(b, prop))
|
|
13
|
+
__defNormalProp(a, prop, b[prop]);
|
|
14
|
+
if (__getOwnPropSymbols)
|
|
15
|
+
for (var prop of __getOwnPropSymbols(b)) {
|
|
16
|
+
if (__propIsEnum.call(b, prop))
|
|
17
|
+
__defNormalProp(a, prop, b[prop]);
|
|
18
|
+
}
|
|
19
|
+
return a;
|
|
20
|
+
};
|
|
21
|
+
var __export = (target, all) => {
|
|
22
|
+
for (var name in all)
|
|
23
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
24
|
+
};
|
|
25
|
+
var __copyProps = (to, from, except, desc) => {
|
|
26
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
27
|
+
for (let key of __getOwnPropNames(from))
|
|
28
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
29
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
30
|
+
}
|
|
31
|
+
return to;
|
|
32
|
+
};
|
|
33
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
34
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
35
|
+
mod
|
|
36
|
+
));
|
|
37
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
38
|
+
var mockAPI_exports = {};
|
|
39
|
+
__export(mockAPI_exports, {
|
|
40
|
+
default: () => mockAPI_default
|
|
5
41
|
});
|
|
6
|
-
exports
|
|
7
|
-
var ptr =
|
|
8
|
-
var mockAppModule =
|
|
9
|
-
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
|
10
|
-
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
|
11
|
-
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
12
|
-
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
13
|
-
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
14
|
-
// eslint-disable-next-line @typescript-eslint/naming-convention
|
|
42
|
+
module.exports = __toCommonJS(mockAPI_exports);
|
|
43
|
+
var ptr = __toESM(require("path-to-regexp"));
|
|
44
|
+
var mockAppModule = __toESM(require("./app"));
|
|
15
45
|
const mock_replaceUrlWithParams = (url, paramValues, payload) => {
|
|
16
46
|
const keys = [];
|
|
17
47
|
ptr.pathToRegexp(url, keys);
|
|
@@ -21,82 +51,84 @@ const mock_replaceUrlWithParams = (url, paramValues, payload) => {
|
|
|
21
51
|
}
|
|
22
52
|
return cur;
|
|
23
53
|
}, {});
|
|
24
|
-
const getFinalPath = ptr.compile(url, {
|
|
25
|
-
|
|
26
|
-
});
|
|
27
|
-
return getFinalPath(_objectSpread(_objectSpread({}, params), payload));
|
|
54
|
+
const getFinalPath = ptr.compile(url, { encode: encodeURIComponent });
|
|
55
|
+
return getFinalPath(__spreadValues(__spreadValues({}, params), payload));
|
|
28
56
|
};
|
|
29
|
-
|
|
30
|
-
// eslint-disable-next-line @typescript-eslint/naming-convention
|
|
31
|
-
const mock_getParamsAndPayload = args => {
|
|
57
|
+
const mock_getParamsAndPayload = (args) => {
|
|
32
58
|
if (args.length === 0) {
|
|
33
59
|
return [[], {}];
|
|
34
60
|
}
|
|
35
61
|
const head = args[0];
|
|
36
|
-
if (typeof head ===
|
|
62
|
+
if (typeof head === "object") {
|
|
37
63
|
return [[], head];
|
|
38
64
|
} else {
|
|
39
65
|
const latest = args[args.length - 1];
|
|
40
|
-
if (typeof latest ===
|
|
66
|
+
if (typeof latest === "object") {
|
|
41
67
|
return [args.slice(0, args.length - 1), latest];
|
|
42
68
|
} else {
|
|
43
69
|
return [args, {}];
|
|
44
70
|
}
|
|
45
71
|
}
|
|
46
72
|
};
|
|
47
|
-
var
|
|
73
|
+
var mockAPI_default = (mockApiInfosByFile) => {
|
|
48
74
|
const files = Object.keys(mockApiInfosByFile);
|
|
49
|
-
files.forEach(mockedFile => {
|
|
75
|
+
files.forEach((mockedFile) => {
|
|
50
76
|
jest.mock(mockedFile, () => {
|
|
51
|
-
const supertest = require(
|
|
52
|
-
return mockApiInfosByFile[mockedFile].reduce(
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
const [params, payload] = mock_getParamsAndPayload(args);
|
|
59
|
-
const {
|
|
60
|
-
returnHttp
|
|
61
|
-
} = module[info.name];
|
|
62
|
-
const url = mock_replaceUrlWithParams(info.routePath, params, payload.params);
|
|
63
|
-
const app = mockAppModule.getApp();
|
|
64
|
-
let test = supertest(app)[info.httpMethod.toLowerCase()](url);
|
|
65
|
-
if (payload.query) {
|
|
66
|
-
test = test.query(payload.query);
|
|
67
|
-
}
|
|
68
|
-
if (payload.body) {
|
|
69
|
-
test = test.send(payload.body);
|
|
70
|
-
}
|
|
71
|
-
if (payload.data) {
|
|
72
|
-
test = test.send(payload.data);
|
|
73
|
-
}
|
|
74
|
-
if (payload.headers) {
|
|
75
|
-
for (const name in payload.headers) {
|
|
76
|
-
test = test.set(name, payload.headers[name]);
|
|
77
|
+
const supertest = require("supertest");
|
|
78
|
+
return mockApiInfosByFile[mockedFile].reduce(
|
|
79
|
+
(res, info) => {
|
|
80
|
+
const module2 = {
|
|
81
|
+
[info.name]: (...args) => {
|
|
82
|
+
if (mockAppModule.isInHandler()) {
|
|
83
|
+
return info.handler(...args);
|
|
77
84
|
}
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
85
|
+
const [params, payload] = mock_getParamsAndPayload(args);
|
|
86
|
+
const { returnHttp } = module2[info.name];
|
|
87
|
+
const url = mock_replaceUrlWithParams(
|
|
88
|
+
info.routePath,
|
|
89
|
+
params,
|
|
90
|
+
payload.params
|
|
91
|
+
);
|
|
92
|
+
const app = mockAppModule.getApp();
|
|
93
|
+
let test = supertest(app)[info.httpMethod.toLowerCase()](url);
|
|
94
|
+
if (payload.query) {
|
|
95
|
+
test = test.query(payload.query);
|
|
96
|
+
}
|
|
97
|
+
if (payload.body) {
|
|
98
|
+
test = test.send(payload.body);
|
|
99
|
+
}
|
|
100
|
+
if (payload.data) {
|
|
101
|
+
test = test.send(payload.data);
|
|
90
102
|
}
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
103
|
+
if (payload.headers) {
|
|
104
|
+
for (const name in payload.headers) {
|
|
105
|
+
test = test.set(name, payload.headers[name]);
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
if (payload.cookies) {
|
|
109
|
+
test = test.set("Cookie", [payload.cookies]);
|
|
110
|
+
}
|
|
111
|
+
if (returnHttp) {
|
|
112
|
+
return test;
|
|
113
|
+
}
|
|
114
|
+
return test.then((value) => {
|
|
115
|
+
try {
|
|
116
|
+
return JSON.parse(value.text);
|
|
117
|
+
} catch (e) {
|
|
118
|
+
return value.text;
|
|
119
|
+
}
|
|
120
|
+
});
|
|
121
|
+
}
|
|
122
|
+
};
|
|
123
|
+
res[info.name] = module2[info.name];
|
|
124
|
+
Object.assign(res[info.name], info.handler);
|
|
125
|
+
res.__esModule = true;
|
|
126
|
+
return res;
|
|
127
|
+
},
|
|
128
|
+
{}
|
|
129
|
+
);
|
|
99
130
|
});
|
|
100
131
|
});
|
|
101
132
|
};
|
|
102
|
-
|
|
133
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
134
|
+
0 && (module.exports = {});
|
|
@@ -1,41 +1,84 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
var
|
|
4
|
-
var
|
|
5
|
-
var
|
|
6
|
-
var
|
|
7
|
-
var
|
|
8
|
-
|
|
1
|
+
var __create = Object.create;
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __getProtoOf = Object.getPrototypeOf;
|
|
6
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
7
|
+
var __copyProps = (to, from, except, desc) => {
|
|
8
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
9
|
+
for (let key of __getOwnPropNames(from))
|
|
10
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
11
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
12
|
+
}
|
|
13
|
+
return to;
|
|
14
|
+
};
|
|
15
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
16
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
17
|
+
mod
|
|
18
|
+
));
|
|
19
|
+
var __async = (__this, __arguments, generator) => {
|
|
20
|
+
return new Promise((resolve, reject) => {
|
|
21
|
+
var fulfilled = (value) => {
|
|
22
|
+
try {
|
|
23
|
+
step(generator.next(value));
|
|
24
|
+
} catch (e) {
|
|
25
|
+
reject(e);
|
|
26
|
+
}
|
|
27
|
+
};
|
|
28
|
+
var rejected = (value) => {
|
|
29
|
+
try {
|
|
30
|
+
step(generator.throw(value));
|
|
31
|
+
} catch (e) {
|
|
32
|
+
reject(e);
|
|
33
|
+
}
|
|
34
|
+
};
|
|
35
|
+
var step = (x) => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);
|
|
36
|
+
step((generator = generator.apply(__this, __arguments)).next());
|
|
37
|
+
});
|
|
38
|
+
};
|
|
39
|
+
var import_path = __toESM(require("path"));
|
|
40
|
+
var import_bff_core = require("@modern-js/bff-core");
|
|
41
|
+
var import_constant = require("./constant");
|
|
42
|
+
var import_mockAPI = __toESM(require("./mockAPI"));
|
|
43
|
+
var import_app = require("./app");
|
|
9
44
|
let uped = false;
|
|
10
45
|
const setup = () => {
|
|
11
|
-
var
|
|
46
|
+
var _a, _b;
|
|
12
47
|
if (uped) {
|
|
13
48
|
return;
|
|
14
49
|
}
|
|
15
50
|
uped = true;
|
|
16
|
-
const bff_info = global[
|
|
17
|
-
const prefix =
|
|
18
|
-
const apiRouter = new
|
|
19
|
-
apiDir:
|
|
51
|
+
const bff_info = global[import_constant.bff_info_key];
|
|
52
|
+
const prefix = (_b = (_a = bff_info == null ? void 0 : bff_info.modernUserConfig) == null ? void 0 : _a.bff) == null ? void 0 : _b.prefix;
|
|
53
|
+
const apiRouter = new import_bff_core.ApiRouter({
|
|
54
|
+
apiDir: import_path.default.join(bff_info.appDir, "./api"),
|
|
20
55
|
prefix
|
|
21
56
|
});
|
|
22
57
|
const apiInfos = apiRouter.getApiHandlers();
|
|
23
|
-
const apiInfosByFile = apiInfos.reduce(
|
|
24
|
-
|
|
25
|
-
res[apiInfo.filename]
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
58
|
+
const apiInfosByFile = apiInfos.reduce(
|
|
59
|
+
(res, apiInfo) => {
|
|
60
|
+
if (!res[apiInfo.filename]) {
|
|
61
|
+
res[apiInfo.filename] = [];
|
|
62
|
+
}
|
|
63
|
+
res[apiInfo.filename].push(apiInfo);
|
|
64
|
+
return res;
|
|
65
|
+
},
|
|
66
|
+
{}
|
|
67
|
+
);
|
|
30
68
|
let app = null;
|
|
31
|
-
beforeAll(
|
|
69
|
+
beforeAll(() => __async(exports, null, function* () {
|
|
32
70
|
if (!app) {
|
|
33
|
-
app =
|
|
71
|
+
app = yield (0, import_app.createApp)(
|
|
72
|
+
bff_info.appDir,
|
|
73
|
+
bff_info.modernUserConfig,
|
|
74
|
+
bff_info.plugins,
|
|
75
|
+
bff_info.routes
|
|
76
|
+
);
|
|
34
77
|
}
|
|
35
|
-
});
|
|
36
|
-
afterAll(
|
|
37
|
-
|
|
38
|
-
});
|
|
39
|
-
(0,
|
|
78
|
+
}));
|
|
79
|
+
afterAll(() => __async(exports, null, function* () {
|
|
80
|
+
yield (0, import_app.closeServer)();
|
|
81
|
+
}));
|
|
82
|
+
(0, import_mockAPI.default)(apiInfosByFile);
|
|
40
83
|
};
|
|
41
|
-
setup();
|
|
84
|
+
setup();
|
|
@@ -1,29 +1,64 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
Object.
|
|
4
|
-
|
|
1
|
+
var __create = Object.create;
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __getOwnPropSymbols = Object.getOwnPropertySymbols;
|
|
6
|
+
var __getProtoOf = Object.getPrototypeOf;
|
|
7
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
8
|
+
var __propIsEnum = Object.prototype.propertyIsEnumerable;
|
|
9
|
+
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
10
|
+
var __spreadValues = (a, b) => {
|
|
11
|
+
for (var prop in b || (b = {}))
|
|
12
|
+
if (__hasOwnProp.call(b, prop))
|
|
13
|
+
__defNormalProp(a, prop, b[prop]);
|
|
14
|
+
if (__getOwnPropSymbols)
|
|
15
|
+
for (var prop of __getOwnPropSymbols(b)) {
|
|
16
|
+
if (__propIsEnum.call(b, prop))
|
|
17
|
+
__defNormalProp(a, prop, b[prop]);
|
|
18
|
+
}
|
|
19
|
+
return a;
|
|
20
|
+
};
|
|
21
|
+
var __export = (target, all) => {
|
|
22
|
+
for (var name in all)
|
|
23
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
24
|
+
};
|
|
25
|
+
var __copyProps = (to, from, except, desc) => {
|
|
26
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
27
|
+
for (let key of __getOwnPropNames(from))
|
|
28
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
29
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
30
|
+
}
|
|
31
|
+
return to;
|
|
32
|
+
};
|
|
33
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
34
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
35
|
+
mod
|
|
36
|
+
));
|
|
37
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
38
|
+
var utils_exports = {};
|
|
39
|
+
__export(utils_exports, {
|
|
40
|
+
isBFFProject: () => isBFFProject
|
|
5
41
|
});
|
|
6
|
-
exports
|
|
7
|
-
var
|
|
8
|
-
var
|
|
9
|
-
|
|
10
|
-
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
11
|
-
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
12
|
-
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
13
|
-
const isBFFProject = pwd => {
|
|
42
|
+
module.exports = __toCommonJS(utils_exports);
|
|
43
|
+
var import_path = __toESM(require("path"));
|
|
44
|
+
var import_utils = require("@modern-js/utils");
|
|
45
|
+
const isBFFProject = (pwd) => {
|
|
14
46
|
try {
|
|
15
|
-
const packageJson = require(
|
|
16
|
-
const {
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
const
|
|
21
|
-
|
|
47
|
+
const packageJson = require(import_path.default.join(pwd, "./package.json"));
|
|
48
|
+
const { dependencies, devDependencies } = packageJson;
|
|
49
|
+
const isBFF = Object.keys(__spreadValues(__spreadValues({}, dependencies), devDependencies)).some(
|
|
50
|
+
(dependency) => dependency.includes("plugin-bff")
|
|
51
|
+
);
|
|
52
|
+
const isMWA = Object.keys(devDependencies).some(
|
|
53
|
+
(devDependency) => devDependency.includes("app-tools")
|
|
54
|
+
);
|
|
22
55
|
return isMWA && isBFF;
|
|
23
56
|
} catch (error) {
|
|
24
|
-
|
|
25
|
-
console.log(_utils.chalk.red(error));
|
|
57
|
+
console.log(import_utils.chalk.red(error));
|
|
26
58
|
return false;
|
|
27
59
|
}
|
|
28
60
|
};
|
|
29
|
-
|
|
61
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
62
|
+
0 && (module.exports = {
|
|
63
|
+
isBFFProject
|
|
64
|
+
});
|
|
@@ -1,89 +1,135 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
Object.
|
|
4
|
-
|
|
1
|
+
var __create = Object.create;
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __getProtoOf = Object.getPrototypeOf;
|
|
6
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
7
|
+
var __export = (target, all) => {
|
|
8
|
+
for (var name in all)
|
|
9
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
10
|
+
};
|
|
11
|
+
var __copyProps = (to, from, except, desc) => {
|
|
12
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
13
|
+
for (let key of __getOwnPropNames(from))
|
|
14
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
15
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
16
|
+
}
|
|
17
|
+
return to;
|
|
18
|
+
};
|
|
19
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
20
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
21
|
+
mod
|
|
22
|
+
));
|
|
23
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
24
|
+
var __async = (__this, __arguments, generator) => {
|
|
25
|
+
return new Promise((resolve, reject) => {
|
|
26
|
+
var fulfilled = (value) => {
|
|
27
|
+
try {
|
|
28
|
+
step(generator.next(value));
|
|
29
|
+
} catch (e) {
|
|
30
|
+
reject(e);
|
|
31
|
+
}
|
|
32
|
+
};
|
|
33
|
+
var rejected = (value) => {
|
|
34
|
+
try {
|
|
35
|
+
step(generator.throw(value));
|
|
36
|
+
} catch (e) {
|
|
37
|
+
reject(e);
|
|
38
|
+
}
|
|
39
|
+
};
|
|
40
|
+
var step = (x) => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);
|
|
41
|
+
step((generator = generator.apply(__this, __arguments)).next());
|
|
42
|
+
});
|
|
43
|
+
};
|
|
44
|
+
var cli_exports = {};
|
|
45
|
+
__export(cli_exports, {
|
|
46
|
+
default: () => cli_default,
|
|
47
|
+
mergeUserJestConfig: () => mergeUserJestConfig
|
|
5
48
|
});
|
|
6
|
-
|
|
7
|
-
var
|
|
8
|
-
var
|
|
9
|
-
var
|
|
10
|
-
var
|
|
11
|
-
var
|
|
12
|
-
var
|
|
13
|
-
|
|
14
|
-
const mergeUserJestConfig = testUtils => {
|
|
49
|
+
module.exports = __toCommonJS(cli_exports);
|
|
50
|
+
var import_path = __toESM(require("path"));
|
|
51
|
+
var import_utils = require("@modern-js/utils");
|
|
52
|
+
var import_base = require("../base");
|
|
53
|
+
var import_constant = require("../constant");
|
|
54
|
+
var import_bff = __toESM(require("./bff"));
|
|
55
|
+
var import_test = __toESM(require("./test"));
|
|
56
|
+
const mergeUserJestConfig = (testUtils) => {
|
|
15
57
|
const resolveJestConfig = testUtils.testConfig.jest;
|
|
16
|
-
|
|
17
|
-
// resolveJestConfig 如果是函数类型,在所有测试插件 jestConfig 都执行后,再执行生成最终配置
|
|
18
|
-
if (resolveJestConfig && typeof resolveJestConfig !== 'function') {
|
|
58
|
+
if (resolveJestConfig && typeof resolveJestConfig !== "function") {
|
|
19
59
|
testUtils.mergeJestConfig(resolveJestConfig);
|
|
20
60
|
}
|
|
21
61
|
};
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
const BffPlugin = (0, _bff.default)();
|
|
62
|
+
var cli_default = () => {
|
|
63
|
+
const BffPlugin = (0, import_bff.default)();
|
|
25
64
|
return {
|
|
26
|
-
name:
|
|
65
|
+
name: "@modern-js/plugin-testing",
|
|
27
66
|
usePlugins: [BffPlugin],
|
|
28
67
|
post: [BffPlugin.name],
|
|
29
|
-
registerHook:
|
|
30
|
-
setup: api => {
|
|
68
|
+
registerHook: import_base.testingHooks,
|
|
69
|
+
setup: (api) => {
|
|
31
70
|
let testingExportsUtils;
|
|
32
71
|
return {
|
|
33
|
-
commands: ({
|
|
34
|
-
program
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
await (0, _test.default)(api);
|
|
38
|
-
});
|
|
72
|
+
commands: ({ program }) => {
|
|
73
|
+
program.command("test").allowUnknownOption().usage("<regexForTestFiles> --[options]").action(() => __async(void 0, null, function* () {
|
|
74
|
+
yield (0, import_test.default)(api);
|
|
75
|
+
}));
|
|
39
76
|
},
|
|
40
77
|
validateSchema() {
|
|
41
|
-
return
|
|
78
|
+
return import_utils.PLUGIN_SCHEMAS["@modern-js/plugin-testing"];
|
|
42
79
|
},
|
|
43
80
|
config() {
|
|
44
81
|
const appContext = api.useAppContext();
|
|
45
|
-
testingExportsUtils = (0,
|
|
82
|
+
testingExportsUtils = (0, import_utils.createRuntimeExportsUtils)(
|
|
83
|
+
appContext.internalDirectory,
|
|
84
|
+
"testing"
|
|
85
|
+
);
|
|
46
86
|
return {
|
|
47
87
|
source: {
|
|
48
88
|
alias: {
|
|
49
|
-
|
|
89
|
+
"@": import_path.default.join(appContext.appDirectory, "src"),
|
|
90
|
+
"@modern-js/runtime/testing": testingExportsUtils.getPath()
|
|
50
91
|
}
|
|
51
92
|
}
|
|
52
93
|
};
|
|
53
94
|
},
|
|
54
95
|
addRuntimeExports() {
|
|
55
|
-
const testingPath =
|
|
96
|
+
const testingPath = import_path.default.resolve(__dirname, "../");
|
|
56
97
|
testingExportsUtils.addExport(`export * from '${testingPath}'`);
|
|
57
98
|
},
|
|
58
|
-
jestConfig:
|
|
99
|
+
jestConfig: (utils, next) => __async(void 0, null, function* () {
|
|
59
100
|
const appContext = api.useAppContext();
|
|
60
101
|
const userConfig = api.useResolvedConfigContext();
|
|
61
|
-
const apiOnly =
|
|
102
|
+
const apiOnly = yield (0, import_utils.isApiOnly)(appContext.appDirectory);
|
|
62
103
|
if (apiOnly) {
|
|
63
104
|
return next(utils);
|
|
64
105
|
}
|
|
65
|
-
const alias = (0,
|
|
106
|
+
const alias = (0, import_utils.mergeAlias)(userConfig.source.alias);
|
|
66
107
|
if (testingExportsUtils) {
|
|
67
|
-
alias[
|
|
108
|
+
alias["@modern-js/runtime/testing"] = [
|
|
109
|
+
testingExportsUtils.getPath()
|
|
110
|
+
];
|
|
68
111
|
}
|
|
69
112
|
utils.mergeJestConfig({
|
|
70
113
|
globals: {
|
|
71
|
-
[
|
|
114
|
+
[import_constant.MODERNJS_CONFIG_KEY]: userConfig
|
|
72
115
|
},
|
|
73
|
-
moduleNameMapper: (0,
|
|
74
|
-
testEnvironment:
|
|
75
|
-
resolver:
|
|
116
|
+
moduleNameMapper: (0, import_base.getModuleNameMapper)(alias),
|
|
117
|
+
testEnvironment: "jsdom",
|
|
118
|
+
resolver: import_base.DEFAULT_RESOLVER_PATH,
|
|
76
119
|
rootDir: appContext.appDirectory || process.cwd(),
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
120
|
+
testMatch: [
|
|
121
|
+
`<rootDir>/src/**/*.test.[jt]s?(x)`,
|
|
122
|
+
`<rootDir>/tests/**/*.test.[jt]s?(x)`
|
|
123
|
+
]
|
|
81
124
|
});
|
|
82
125
|
mergeUserJestConfig(utils);
|
|
83
126
|
return next(utils);
|
|
84
|
-
}
|
|
127
|
+
})
|
|
85
128
|
};
|
|
86
129
|
}
|
|
87
130
|
};
|
|
88
131
|
};
|
|
89
|
-
|
|
132
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
133
|
+
0 && (module.exports = {
|
|
134
|
+
mergeUserJestConfig
|
|
135
|
+
});
|