@eggjs/mock 7.0.0-beta.34 → 7.0.0-beta.36
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/dist/_virtual/rolldown_runtime.js +7 -0
- package/dist/app/extend/agent.d.ts +38 -34
- package/dist/app/extend/agent.js +48 -46
- package/dist/app/extend/application.d.ts +171 -167
- package/dist/app/extend/application.js +382 -442
- package/dist/app/middleware/cluster_app_mock.d.ts +5 -2
- package/dist/app/middleware/cluster_app_mock.js +95 -100
- package/dist/app.d.ts +9 -5
- package/dist/app.js +17 -18
- package/dist/bootstrap.d.ts +9 -5
- package/dist/bootstrap.js +11 -12
- package/dist/index.d.ts +20 -17
- package/dist/index.js +39 -78
- package/dist/inject_mocha.d.ts +1 -1
- package/dist/inject_mocha.js +27 -28
- package/dist/lib/agent_handler.d.ts +7 -3
- package/dist/lib/agent_handler.js +22 -20
- package/dist/lib/app.d.ts +7 -3
- package/dist/lib/app.js +246 -287
- package/dist/lib/app_handler.d.ts +9 -5
- package/dist/lib/app_handler.js +48 -61
- package/dist/lib/cluster.d.ts +122 -118
- package/dist/lib/cluster.js +278 -335
- package/dist/lib/context.d.ts +4 -1
- package/dist/lib/context.js +10 -11
- package/dist/lib/format_options.d.ts +9 -4
- package/dist/lib/format_options.js +60 -88
- package/dist/lib/inject_context.d.ts +8 -5
- package/dist/lib/inject_context.js +103 -123
- package/dist/lib/mock_agent.d.ts +8 -4
- package/dist/lib/mock_agent.js +42 -42
- package/dist/lib/mock_custom_loader.d.ts +4 -1
- package/dist/lib/mock_custom_loader.js +34 -33
- package/dist/lib/mock_http_server.d.ts +6 -2
- package/dist/lib/mock_http_server.js +16 -17
- package/dist/lib/mock_httpclient.d.ts +38 -34
- package/dist/lib/mock_httpclient.js +106 -142
- package/dist/lib/parallel/agent.d.ts +22 -18
- package/dist/lib/parallel/agent.js +106 -112
- package/dist/lib/parallel/app.d.ts +23 -19
- package/dist/lib/parallel/app.js +93 -106
- package/dist/lib/parallel/util.d.ts +5 -2
- package/dist/lib/parallel/util.js +56 -63
- package/dist/lib/prerequire.d.ts +1 -1
- package/dist/lib/prerequire.js +1 -25
- package/dist/lib/request_call_function.d.ts +1 -1
- package/dist/lib/request_call_function.js +34 -47
- package/dist/lib/restore.d.ts +4 -1
- package/dist/lib/restore.js +14 -11
- package/dist/lib/start-cluster.d.ts +1 -2
- package/dist/lib/start-cluster.js +15 -14
- package/dist/lib/supertest.d.ts +14 -9
- package/dist/lib/supertest.js +32 -36
- package/dist/lib/tmp/empty.d.ts +1 -1
- package/dist/lib/tmp/empty.js +1 -2
- package/dist/lib/types.d.ts +71 -67
- package/dist/lib/types.js +1 -2
- package/dist/lib/utils.d.ts +11 -8
- package/dist/lib/utils.js +34 -63
- package/dist/register.d.ts +11 -7
- package/dist/register.js +36 -40
- package/dist/typings/index.d.ts +1 -0
- package/package.json +36 -39
|
@@ -1,116 +1,110 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import path from 'node:path';
|
|
3
|
-
import { Base } from 'sdk-base';
|
|
4
|
-
import { detectPort } from 'detect-port';
|
|
5
|
-
import { importModule } from '@eggjs/utils';
|
|
1
|
+
import { rimraf, sleep } from "../utils.js";
|
|
6
2
|
import { context } from "../context.js";
|
|
7
3
|
import { formatOptions } from "../format_options.js";
|
|
8
|
-
import { sleep, rimraf } from "../utils.js";
|
|
9
4
|
import { setCustomLoader } from "../mock_custom_loader.js";
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
5
|
+
import path from "node:path";
|
|
6
|
+
import { debuglog } from "node:util";
|
|
7
|
+
import { importModule } from "@eggjs/utils";
|
|
8
|
+
import { detectPort } from "detect-port";
|
|
9
|
+
import { Base } from "sdk-base";
|
|
10
|
+
|
|
11
|
+
//#region src/lib/parallel/agent.ts
|
|
12
|
+
const debug = debuglog("egg/mock/lib/parallel/agent");
|
|
13
|
+
var MockAgent = class extends Base {
|
|
14
|
+
baseDir;
|
|
15
|
+
__APP_INIT__ = false;
|
|
16
|
+
#initOnListeners = /* @__PURE__ */ new Set();
|
|
17
|
+
#initOnceListeners = /* @__PURE__ */ new Set();
|
|
18
|
+
_instance;
|
|
19
|
+
constructor(options) {
|
|
20
|
+
super({ initMethod: "_init" });
|
|
21
|
+
this.options = options;
|
|
22
|
+
this.baseDir = this.options.baseDir;
|
|
23
|
+
}
|
|
24
|
+
async _init() {
|
|
25
|
+
if (this.options.beforeInit) {
|
|
26
|
+
await this.options.beforeInit(this);
|
|
27
|
+
delete this.options.beforeInit;
|
|
28
|
+
}
|
|
29
|
+
if (this.options.clean !== false) {
|
|
30
|
+
const logDir = path.join(this.options.baseDir, "logs");
|
|
31
|
+
try {
|
|
32
|
+
await rimraf(logDir);
|
|
33
|
+
} catch (err) {
|
|
34
|
+
console.error(`remove log dir ${logDir} failed: ${err.stack}`);
|
|
35
|
+
}
|
|
36
|
+
const runDir = path.join(this.options.baseDir, "run");
|
|
37
|
+
try {
|
|
38
|
+
await rimraf(runDir);
|
|
39
|
+
} catch (err) {
|
|
40
|
+
console.error(`remove run dir ${runDir} failed: ${err.stack}`);
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
this.options.clusterPort = await detectPort();
|
|
44
|
+
process.env.CLUSTER_PORT = String(this.options.clusterPort);
|
|
45
|
+
debug("get clusterPort %s", this.options.clusterPort);
|
|
46
|
+
const { Agent } = await importModule(this.options.framework);
|
|
47
|
+
const agent = this._instance = new Agent({ ...this.options });
|
|
48
|
+
Object.assign(agent.context, context);
|
|
49
|
+
setCustomLoader(agent);
|
|
50
|
+
debug("agent instantiate");
|
|
51
|
+
this.__APP_INIT__ = true;
|
|
52
|
+
debug("this[APP_INIT] = true");
|
|
53
|
+
this.#bindEvents();
|
|
54
|
+
await agent.ready();
|
|
55
|
+
const msg = {
|
|
56
|
+
action: "egg-ready",
|
|
57
|
+
data: this.options
|
|
58
|
+
};
|
|
59
|
+
agent.messenger.onMessage(msg);
|
|
60
|
+
debug("agent ready");
|
|
61
|
+
}
|
|
62
|
+
#bindEvents() {
|
|
63
|
+
debug("bind cache events to agent");
|
|
64
|
+
for (const args of this.#initOnListeners) {
|
|
65
|
+
debug("on(%s), use cache and pass to agent", args);
|
|
66
|
+
this._instance.on(args[0], args[1]);
|
|
67
|
+
this.removeListener(args[0], args[1]);
|
|
68
|
+
}
|
|
69
|
+
for (const args of this.#initOnceListeners) {
|
|
70
|
+
debug("once(%s), use cache and pass to agent", args);
|
|
71
|
+
this._instance.once(args[0], args[1]);
|
|
72
|
+
this.removeListener(args[0], args[1]);
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
on(...args) {
|
|
76
|
+
if (this.__APP_INIT__) {
|
|
77
|
+
debug("on(%s), pass to agent", args);
|
|
78
|
+
this._instance.on(args[0], args[1]);
|
|
79
|
+
} else {
|
|
80
|
+
debug("on(%s), cache it because agent has not init", args);
|
|
81
|
+
this.#initOnListeners.add(args);
|
|
82
|
+
super.on(args[0], args[1]);
|
|
83
|
+
}
|
|
84
|
+
return this;
|
|
85
|
+
}
|
|
86
|
+
once(...args) {
|
|
87
|
+
if (this.__APP_INIT__) {
|
|
88
|
+
debug("once(%s), pass to agent", args);
|
|
89
|
+
this._instance.once(args[0], args[1]);
|
|
90
|
+
} else {
|
|
91
|
+
debug("once(%s), cache it because agent has not init", args);
|
|
92
|
+
this.#initOnceListeners.add(args);
|
|
93
|
+
super.on(args[0], args[1]);
|
|
94
|
+
}
|
|
95
|
+
return this;
|
|
96
|
+
}
|
|
97
|
+
/**
|
|
98
|
+
* close agent
|
|
99
|
+
*/
|
|
100
|
+
async _close() {
|
|
101
|
+
if (this._instance) await this._instance.close();
|
|
102
|
+
else await sleep(200);
|
|
103
|
+
}
|
|
104
|
+
};
|
|
105
|
+
function createAgent(options) {
|
|
106
|
+
return new MockAgent(formatOptions(options));
|
|
112
107
|
}
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
}
|
|
116
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWdlbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbGliL3BhcmFsbGVsL2FnZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxXQUFXLENBQUM7QUFDckMsT0FBTyxJQUFJLE1BQU0sV0FBVyxDQUFDO0FBRTdCLE9BQU8sRUFBRSxJQUFJLEVBQUUsTUFBTSxVQUFVLENBQUM7QUFDaEMsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sY0FBYyxDQUFDO0FBRzVDLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDeEMsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBRXJELE9BQU8sRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0sYUFBYSxDQUFDO0FBQzVDLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUUzRCxNQUFNLEtBQUssR0FBRyxRQUFRLENBQUMsNkJBQTZCLENBQUMsQ0FBQztBQUV0RCxNQUFNLE9BQU8sU0FBVSxTQUFRLElBQUk7SUFFakMsT0FBTyxDQUFTO0lBQ2hCLFlBQVksR0FBRyxLQUFLLENBQUM7SUFDckIsZ0JBQWdCLEdBQUcsSUFBSSxHQUFHLEVBQVMsQ0FBQztJQUNwQyxrQkFBa0IsR0FBRyxJQUFJLEdBQUcsRUFBUyxDQUFDO0lBQ3RDLFNBQVMsQ0FBVztJQUVwQixZQUFZLE9BQStCO1FBQ3pDLEtBQUssQ0FBQyxFQUFFLFVBQVUsRUFBRSxPQUFPLEVBQUUsQ0FBQyxDQUFDO1FBQy9CLElBQUksQ0FBQyxPQUFPLEdBQUcsT0FBTyxDQUFDO1FBQ3ZCLElBQUksQ0FBQyxPQUFPLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUM7SUFDdEMsQ0FBQztJQUVELEtBQUssQ0FBQyxLQUFLO1FBQ1Qs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
|
|
108
|
+
|
|
109
|
+
//#endregion
|
|
110
|
+
export { MockAgent, createAgent };
|
|
@@ -1,20 +1,24 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
3
|
-
import
|
|
4
|
-
import {
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
1
|
+
import { MockApplicationOptions, MockOptions } from "../types.js";
|
|
2
|
+
import { proxyApp } from "./util.js";
|
|
3
|
+
import { Application } from "egg";
|
|
4
|
+
import { Base } from "sdk-base";
|
|
5
|
+
|
|
6
|
+
//#region src/lib/parallel/app.d.ts
|
|
7
|
+
declare class MockParallelApplication extends Base {
|
|
8
|
+
#private;
|
|
9
|
+
options: MockApplicationOptions;
|
|
10
|
+
baseDir: string;
|
|
11
|
+
__APP_INIT__: boolean;
|
|
12
|
+
_instance: Application;
|
|
13
|
+
constructor(options: MockApplicationOptions);
|
|
14
|
+
_init(): Promise<void>;
|
|
15
|
+
on(...args: any[]): this;
|
|
16
|
+
once(...args: any[]): this;
|
|
17
|
+
/**
|
|
18
|
+
* close app
|
|
19
|
+
*/
|
|
20
|
+
_close(): Promise<void>;
|
|
19
21
|
}
|
|
20
|
-
|
|
22
|
+
declare function createApp(initOptions: MockOptions): ReturnType<typeof proxyApp>;
|
|
23
|
+
//#endregion
|
|
24
|
+
export { MockParallelApplication, createApp };
|
package/dist/lib/parallel/app.js
CHANGED
|
@@ -1,111 +1,98 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
3
|
-
import { importModule } from '@eggjs/utils';
|
|
4
|
-
import { Application as EggApplication } from 'egg';
|
|
1
|
+
import { createServer } from "../mock_http_server.js";
|
|
2
|
+
import { sleep } from "../utils.js";
|
|
5
3
|
import { context } from "../context.js";
|
|
6
4
|
import { formatOptions } from "../format_options.js";
|
|
7
|
-
import { sleep } from "../utils.js";
|
|
8
5
|
import { setCustomLoader } from "../mock_custom_loader.js";
|
|
9
|
-
import { createServer } from "../mock_http_server.js";
|
|
10
6
|
import { proxyApp } from "./util.js";
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
await this._instance.close();
|
|
100
|
-
}
|
|
101
|
-
else {
|
|
102
|
-
// when app init throws an exception, must wait for app quit gracefully
|
|
103
|
-
await sleep(200);
|
|
104
|
-
}
|
|
105
|
-
}
|
|
106
|
-
}
|
|
107
|
-
export function createApp(initOptions) {
|
|
108
|
-
const app = new MockParallelApplication(formatOptions(initOptions));
|
|
109
|
-
return proxyApp(app);
|
|
7
|
+
import { Application } from "egg";
|
|
8
|
+
import { debuglog } from "node:util";
|
|
9
|
+
import { importModule } from "@eggjs/utils";
|
|
10
|
+
import { Base } from "sdk-base";
|
|
11
|
+
|
|
12
|
+
//#region src/lib/parallel/app.ts
|
|
13
|
+
const debug = debuglog("egg/mock/lib/parallel/app");
|
|
14
|
+
var MockParallelApplication = class extends Base {
|
|
15
|
+
baseDir;
|
|
16
|
+
__APP_INIT__ = false;
|
|
17
|
+
#initOnListeners = /* @__PURE__ */ new Set();
|
|
18
|
+
#initOnceListeners = /* @__PURE__ */ new Set();
|
|
19
|
+
_instance;
|
|
20
|
+
constructor(options) {
|
|
21
|
+
super({ initMethod: "_init" });
|
|
22
|
+
this.options = options;
|
|
23
|
+
this.baseDir = options.baseDir;
|
|
24
|
+
}
|
|
25
|
+
async _init() {
|
|
26
|
+
if (this.options.beforeInit) {
|
|
27
|
+
await this.options.beforeInit(this);
|
|
28
|
+
delete this.options.beforeInit;
|
|
29
|
+
}
|
|
30
|
+
if (!this.options.clusterPort) this.options.clusterPort = parseInt(process.env.CLUSTER_PORT);
|
|
31
|
+
if (!this.options.clusterPort) throw new Error("cannot get env.CLUSTER_PORT, parallel run fail");
|
|
32
|
+
debug("get clusterPort %s", this.options.clusterPort);
|
|
33
|
+
const { Application: Application$1 } = await importModule(this.options.framework);
|
|
34
|
+
const app = this._instance = new Application$1({ ...this.options });
|
|
35
|
+
Object.assign(app.context, context);
|
|
36
|
+
setCustomLoader(app);
|
|
37
|
+
debug("app instantiate");
|
|
38
|
+
this.__APP_INIT__ = true;
|
|
39
|
+
debug("this[APP_INIT] = true");
|
|
40
|
+
this.#bindEvents();
|
|
41
|
+
debug("http server instantiate");
|
|
42
|
+
createServer(app);
|
|
43
|
+
await app.ready();
|
|
44
|
+
const msg = {
|
|
45
|
+
action: "egg-ready",
|
|
46
|
+
data: this.options
|
|
47
|
+
};
|
|
48
|
+
app.messenger.onMessage(msg);
|
|
49
|
+
debug("app ready");
|
|
50
|
+
}
|
|
51
|
+
#bindEvents() {
|
|
52
|
+
for (const args of this.#initOnListeners) {
|
|
53
|
+
debug("on(%s), use cache and pass to app", args);
|
|
54
|
+
this._instance.on(args[0], args[1]);
|
|
55
|
+
this.removeListener(args[0], args[1]);
|
|
56
|
+
}
|
|
57
|
+
for (const args of this.#initOnceListeners) {
|
|
58
|
+
debug("once(%s), use cache and pass to app", args);
|
|
59
|
+
this._instance.once(args[0], args[1]);
|
|
60
|
+
this.removeListener(args[0], args[1]);
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
on(...args) {
|
|
64
|
+
if (this.__APP_INIT__) {
|
|
65
|
+
debug("on(%s), pass to app", args);
|
|
66
|
+
this._instance.on(args[0], args[1]);
|
|
67
|
+
} else {
|
|
68
|
+
debug("on(%s), cache it because app has not init", args);
|
|
69
|
+
if (this.#initOnListeners) this.#initOnListeners.add(args);
|
|
70
|
+
super.on(args[0], args[1]);
|
|
71
|
+
}
|
|
72
|
+
return this;
|
|
73
|
+
}
|
|
74
|
+
once(...args) {
|
|
75
|
+
if (this.__APP_INIT__) {
|
|
76
|
+
debug("once(%s), pass to app", args);
|
|
77
|
+
this._instance.once(args[0], args[1]);
|
|
78
|
+
} else {
|
|
79
|
+
debug("once(%s), cache it because app has not init", args);
|
|
80
|
+
if (this.#initOnceListeners) this.#initOnceListeners.add(args);
|
|
81
|
+
super.on(args[0], args[1]);
|
|
82
|
+
}
|
|
83
|
+
return this;
|
|
84
|
+
}
|
|
85
|
+
/**
|
|
86
|
+
* close app
|
|
87
|
+
*/
|
|
88
|
+
async _close() {
|
|
89
|
+
if (this._instance) await this._instance.close();
|
|
90
|
+
else await sleep(200);
|
|
91
|
+
}
|
|
92
|
+
};
|
|
93
|
+
function createApp(initOptions) {
|
|
94
|
+
return proxyApp(new MockParallelApplication(formatOptions(initOptions)));
|
|
110
95
|
}
|
|
111
|
-
|
|
96
|
+
|
|
97
|
+
//#endregion
|
|
98
|
+
export { MockParallelApplication, createApp };
|
|
@@ -1,2 +1,5 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
1
|
+
//#region src/lib/parallel/util.d.ts
|
|
2
|
+
declare const MOCK_APP_METHOD: string[];
|
|
3
|
+
declare function proxyApp(app: any): any;
|
|
4
|
+
//#endregion
|
|
5
|
+
export { MOCK_APP_METHOD, proxyApp };
|
|
@@ -1,65 +1,58 @@
|
|
|
1
|
-
import { debuglog } from 'node:util';
|
|
2
1
|
import { getProperty } from "../utils.js";
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
getPrototypeOf(target) {
|
|
57
|
-
if (!target.__APP_INIT__)
|
|
58
|
-
throw new Error("can't getPrototypeOf before ready");
|
|
59
|
-
debug('proxy handler.getPrototypeOf %s');
|
|
60
|
-
return Object.getPrototypeOf(target._instance);
|
|
61
|
-
},
|
|
62
|
-
});
|
|
63
|
-
return proxyApp;
|
|
2
|
+
import { debuglog } from "node:util";
|
|
3
|
+
|
|
4
|
+
//#region src/lib/parallel/util.ts
|
|
5
|
+
const debug = debuglog("egg/mock/lib/parallel/util");
|
|
6
|
+
const MOCK_APP_METHOD = [
|
|
7
|
+
"ready",
|
|
8
|
+
"isClosed",
|
|
9
|
+
"closed",
|
|
10
|
+
"close",
|
|
11
|
+
"on",
|
|
12
|
+
"once"
|
|
13
|
+
];
|
|
14
|
+
function proxyApp(app) {
|
|
15
|
+
return new Proxy(app, {
|
|
16
|
+
get(target, prop) {
|
|
17
|
+
if (MOCK_APP_METHOD.includes(prop)) return getProperty(target, prop);
|
|
18
|
+
if (!target.__APP_INIT__) throw new Error(`can't get ${prop} before ready`);
|
|
19
|
+
debug("proxy handler.get %s", prop);
|
|
20
|
+
return target._instance[prop];
|
|
21
|
+
},
|
|
22
|
+
set(target, prop, value) {
|
|
23
|
+
if (MOCK_APP_METHOD.includes(prop)) return true;
|
|
24
|
+
if (!target.__APP_INIT__) throw new Error(`can't set ${prop} before ready`);
|
|
25
|
+
debug("proxy handler.set %s", prop);
|
|
26
|
+
target._instance[prop] = value;
|
|
27
|
+
return true;
|
|
28
|
+
},
|
|
29
|
+
defineProperty(target, prop, descriptor) {
|
|
30
|
+
if (MOCK_APP_METHOD.includes(prop)) return true;
|
|
31
|
+
if (!target.__APP_INIT__) throw new Error(`can't defineProperty ${prop} before ready`);
|
|
32
|
+
debug("proxy handler.defineProperty %s", prop);
|
|
33
|
+
Object.defineProperty(target._instance, prop, descriptor);
|
|
34
|
+
return true;
|
|
35
|
+
},
|
|
36
|
+
deleteProperty(target, prop) {
|
|
37
|
+
if (MOCK_APP_METHOD.includes(prop)) return true;
|
|
38
|
+
if (!target.__APP_INIT__) throw new Error(`can't delete ${prop} before ready`);
|
|
39
|
+
debug("proxy handler.deleteProperty %s", prop);
|
|
40
|
+
delete target._instance[prop];
|
|
41
|
+
return true;
|
|
42
|
+
},
|
|
43
|
+
getOwnPropertyDescriptor(target, prop) {
|
|
44
|
+
if (MOCK_APP_METHOD.includes(prop)) return Object.getOwnPropertyDescriptor(target, prop);
|
|
45
|
+
if (!target.__APP_INIT__) throw new Error(`can't getOwnPropertyDescriptor ${prop} before ready`);
|
|
46
|
+
debug("proxy handler.getOwnPropertyDescriptor %s", prop);
|
|
47
|
+
return Object.getOwnPropertyDescriptor(target._instance, prop);
|
|
48
|
+
},
|
|
49
|
+
getPrototypeOf(target) {
|
|
50
|
+
if (!target.__APP_INIT__) throw new Error("can't getPrototypeOf before ready");
|
|
51
|
+
debug("proxy handler.getPrototypeOf %s");
|
|
52
|
+
return Object.getPrototypeOf(target._instance);
|
|
53
|
+
}
|
|
54
|
+
});
|
|
64
55
|
}
|
|
65
|
-
|
|
56
|
+
|
|
57
|
+
//#endregion
|
|
58
|
+
export { MOCK_APP_METHOD, proxyApp };
|