@eggjs/mock 7.0.0-beta.19 → 7.0.0-beta.21

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.
Files changed (63) hide show
  1. package/dist/app/extend/agent.d.ts +33 -38
  2. package/dist/app/extend/agent.js +45 -47
  3. package/dist/app/extend/application.d.ts +167 -171
  4. package/dist/app/extend/application.js +442 -382
  5. package/dist/app/middleware/cluster_app_mock.d.ts +2 -5
  6. package/dist/app/middleware/cluster_app_mock.js +99 -96
  7. package/dist/app.d.ts +5 -9
  8. package/dist/app.js +18 -17
  9. package/dist/bootstrap.d.ts +5 -9
  10. package/dist/bootstrap.js +12 -11
  11. package/dist/index.d.ts +76 -80
  12. package/dist/index.js +81 -38
  13. package/dist/inject_mocha.d.ts +1 -1
  14. package/dist/inject_mocha.js +28 -27
  15. package/dist/lib/agent_handler.d.ts +3 -7
  16. package/dist/lib/agent_handler.js +20 -22
  17. package/dist/lib/app.d.ts +3 -7
  18. package/dist/lib/app.js +285 -248
  19. package/dist/lib/app_handler.d.ts +5 -9
  20. package/dist/lib/app_handler.js +62 -49
  21. package/dist/lib/cluster.d.ts +92 -97
  22. package/dist/lib/cluster.js +335 -278
  23. package/dist/lib/context.d.ts +1 -4
  24. package/dist/lib/context.js +11 -10
  25. package/dist/lib/format_options.d.ts +2 -7
  26. package/dist/lib/format_options.js +88 -60
  27. package/dist/lib/inject_context.d.ts +1 -4
  28. package/dist/lib/inject_context.js +123 -103
  29. package/dist/lib/mock_agent.d.ts +4 -8
  30. package/dist/lib/mock_agent.js +42 -42
  31. package/dist/lib/mock_custom_loader.d.ts +1 -4
  32. package/dist/lib/mock_custom_loader.js +33 -34
  33. package/dist/lib/mock_http_server.d.ts +2 -6
  34. package/dist/lib/mock_http_server.js +17 -16
  35. package/dist/lib/mock_httpclient.d.ts +34 -38
  36. package/dist/lib/mock_httpclient.js +142 -106
  37. package/dist/lib/parallel/agent.d.ts +19 -23
  38. package/dist/lib/parallel/agent.js +113 -107
  39. package/dist/lib/parallel/app.d.ts +19 -23
  40. package/dist/lib/parallel/app.js +108 -96
  41. package/dist/lib/parallel/util.d.ts +3 -6
  42. package/dist/lib/parallel/util.js +64 -57
  43. package/dist/lib/prerequire.d.ts +1 -1
  44. package/dist/lib/prerequire.js +25 -1
  45. package/dist/lib/request_call_function.d.ts +1 -1
  46. package/dist/lib/request_call_function.js +47 -34
  47. package/dist/lib/restore.d.ts +1 -4
  48. package/dist/lib/restore.js +11 -14
  49. package/dist/lib/start-cluster.d.ts +2 -1
  50. package/dist/lib/start-cluster.js +14 -15
  51. package/dist/lib/supertest.d.ts +6 -11
  52. package/dist/lib/supertest.js +36 -35
  53. package/dist/lib/tmp/empty.d.ts +1 -1
  54. package/dist/lib/tmp/empty.js +2 -1
  55. package/dist/lib/types.d.ts +64 -68
  56. package/dist/lib/types.js +2 -1
  57. package/dist/lib/utils.d.ts +8 -11
  58. package/dist/lib/utils.js +63 -34
  59. package/dist/register.d.ts +7 -9
  60. package/dist/register.js +40 -36
  61. package/package.json +7 -8
  62. package/dist/_virtual/rolldown_runtime.js +0 -7
  63. package/dist/typings/index.d.ts +0 -1
@@ -1,283 +1,340 @@
1
- import { rimrafSync, sleep } from "./utils.js";
2
- import { request } from "./supertest.js";
1
+ import { debuglog } from 'node:util';
2
+ import path from 'node:path';
3
+ import os from 'node:os';
4
+ import childProcess from 'node:child_process';
5
+ import { once } from 'node:events';
6
+ import { existsSync } from 'node:fs';
7
+ import { Coffee } from 'coffee';
8
+ import { Ready } from 'get-ready';
9
+ import { request as supertestRequest } from "./supertest.js";
10
+ import { sleep, rimrafSync } from "./utils.js";
3
11
  import { formatOptions } from "./format_options.js";
4
- import path from "node:path";
5
- import { debuglog } from "node:util";
6
- import os from "node:os";
7
- import childProcess from "node:child_process";
8
- import { once } from "node:events";
9
- import { existsSync } from "node:fs";
10
- import { Coffee } from "coffee";
11
- import { Ready } from "get-ready";
12
-
13
- //#region src/lib/cluster.ts
14
- const debug = debuglog("egg/mock/lib/cluster");
15
- const clusters = /* @__PURE__ */ new Map();
16
- globalThis.eggMockMasterPort = 17e3 + process.pid % 1e3;
17
- let serverBin = path.join(import.meta.dirname, "start-cluster.js");
18
- if (!existsSync(serverBin)) serverBin = path.join(import.meta.dirname, "start-cluster.ts");
19
- let requestCallFunctionFile = path.join(import.meta.dirname, "request_call_function.js");
20
- if (!existsSync(requestCallFunctionFile)) requestCallFunctionFile = path.join(import.meta.dirname, "request_call_function.ts");
12
+ const debug = debuglog('egg/mock/lib/cluster');
13
+ const clusters = new Map();
14
+ globalThis.eggMockMasterPort = 17000 + (process.pid % 1000);
15
+ let serverBin = path.join(import.meta.dirname, 'start-cluster.js');
16
+ if (!existsSync(serverBin)) {
17
+ serverBin = path.join(import.meta.dirname, 'start-cluster.ts');
18
+ }
19
+ let requestCallFunctionFile = path.join(import.meta.dirname, 'request_call_function.js');
20
+ if (!existsSync(requestCallFunctionFile)) {
21
+ requestCallFunctionFile = path.join(import.meta.dirname, 'request_call_function.ts');
22
+ }
21
23
  /**
22
- * A cluster version of egg.Application, you can test with supertest
23
- * @example
24
- * ```js
25
- * const mm = require('mm');
26
- * const request = require('supertest');
27
- *
28
- * describe('ClusterApplication', () => {
29
- * let app;
30
- * before(function (done) {
31
- * app = mm.cluster({ baseDir });
32
- * app.ready(done);
33
- * });
34
- *
35
- * after(function () {
36
- * app.close();
37
- * });
38
- *
39
- * it('should 200', function (done) {
40
- * request(app.callback())
41
- * .get('/')
42
- * .expect(200, done);
43
- * });
44
- * });
45
- */
46
- var ClusterApplication = class extends Coffee {
47
- options;
48
- port;
49
- baseDir;
50
- closed;
51
- _address;
52
- /**
53
- * @class
54
- * @param {Object} options
55
- * - {String} baseDir - The directory of the application
56
- * - {Object} plugins - Custom you plugins
57
- * - {String} framework - The directory of the egg framework
58
- * - {Boolean} [cache=true] - Cache application based on baseDir
59
- * - {Boolean} [coverage=true] - Switch on process coverage, but it'll be slower
60
- * - {Boolean} [clean=true] - Remove $baseDir/logs
61
- * - {Object} [opt] - opt pass to coffee, such as { execArgv: ['--debug'] }
62
- * ```
63
- */
64
- constructor(options) {
65
- const opt = options.opt;
66
- delete options.opt;
67
- options.port = options.port ?? ++globalThis.eggMockMasterPort;
68
- if (!options.workers) options.workers = 1;
69
- const args = [JSON.stringify(options)];
70
- debug("fork %s, args: %s, opt: %j", serverBin, args.join(" "), opt);
71
- super({
72
- method: "fork",
73
- cmd: serverBin,
74
- args,
75
- opt
76
- });
77
- Ready.mixin(this);
78
- this.port = options.port;
79
- this.baseDir = options.baseDir;
80
- this.debug(process.env.DEBUG ? 0 : 2);
81
- if (options.coverage === false) this.coverage(false);
82
- process.nextTick(() => {
83
- this.proc.on("message", (msg) => {
84
- switch (msg && msg.action ? msg.action : msg) {
85
- case "egg-ready":
86
- debug("on message egg-ready %o", msg);
87
- this._address = msg.data.address;
88
- this.emit("close", 0);
89
- break;
90
- case "app-worker-died":
91
- case "agent-worker-died":
92
- this.emit("close", 1);
93
- break;
94
- default: break;
95
- }
96
- });
97
- });
98
- this.end(() => this.ready(true));
99
- }
100
- /**
101
- * the process that forked
102
- * @member {ChildProcess}
103
- */
104
- get process() {
105
- return this.proc;
106
- }
107
- /**
108
- * Compatible API for supertest
109
- */
110
- callback() {
111
- return this;
112
- }
113
- /**
114
- * Compatible API for supertest
115
- * @member {String} url
116
- * @private
117
- */
118
- get url() {
119
- if (this._address) return this._address;
120
- return "http://127.0.0.1:" + this.port;
121
- }
122
- /**
123
- * Compatible API for supertest
124
- */
125
- address() {
126
- return {
127
- port: this.port,
128
- address: this._address
129
- };
130
- }
131
- /**
132
- * Compatible API for supertest
133
- */
134
- listen() {
135
- return this;
136
- }
137
- /**
138
- * kill the process
139
- */
140
- async close() {
141
- this.closed = true;
142
- const proc = this.proc;
143
- const baseDir = this.baseDir;
144
- if (proc?.connected) {
145
- proc.kill("SIGTERM");
146
- await once(proc, "exit");
147
- }
148
- clusters.delete(baseDir);
149
- debug("delete cluster cache %s, remain %s", baseDir, [...clusters.keys()]);
150
- if (os.platform() === "win32") await sleep(1e3);
151
- }
152
- get isClosed() {
153
- return this.closed;
154
- }
155
- get router() {
156
- const self = this;
157
- return { pathFor(url) {
158
- return self._callFunctionOnAppWorker("pathFor", [url], "router", true);
159
- } };
160
- }
161
- /**
162
- * get app[property] value in app worker
163
- */
164
- getAppInstanceProperty(property) {
165
- return this._callFunctionOnAppWorker("__getter__", [], property, true);
166
- }
167
- /**
168
- * collection logger message, then can be use on `expectLog()`
169
- * it's different from `app.expectLog()`, only support string params.
170
- *
171
- * @param {String} [logger] - logger instance name, default is `logger`
172
- * @function ClusterApplication#expectLog
173
- */
174
- mockLog(logger) {
175
- logger = logger ?? "logger";
176
- this._callFunctionOnAppWorker("mockLog", [logger], null, true);
177
- }
178
- /**
179
- * expect str in the logger
180
- * it's different from `app.expectLog()`, only support string params.
181
- *
182
- * @param {String} str - test str
183
- * @param {String} [logger] - logger instance name, default is `logger`
184
- * @function ClusterApplication#expectLog
185
- */
186
- expectLog(str, logger) {
187
- logger = logger ?? "logger";
188
- this._callFunctionOnAppWorker("expectLog", [str, logger], null, true);
189
- }
190
- /**
191
- * not expect str in the logger
192
- * it's different from `app.notExpectLog()`, only support string params.
193
- *
194
- * @param {String} str - test str
195
- * @param {String} [logger] - logger instance name, default is `logger`
196
- * @function ClusterApplication#notExpectLog
197
- */
198
- notExpectLog(str, logger) {
199
- logger = logger ?? "logger";
200
- this._callFunctionOnAppWorker("notExpectLog", [str, logger], null, true);
201
- }
202
- httpRequest() {
203
- return request(this);
204
- }
205
- _callFunctionOnAppWorker(method, args = [], property = void 0, needResult = false) {
206
- for (let i = 0; i < args.length; i++) {
207
- const arg = args[i];
208
- if (typeof arg === "function") args[i] = {
209
- __egg_mock_type: "function",
210
- value: arg.toString()
211
- };
212
- else if (arg instanceof Error) {
213
- const errObject = {
214
- __egg_mock_type: "error",
215
- name: arg.name,
216
- message: arg.message,
217
- stack: arg.stack
218
- };
219
- for (const key in arg) if (key !== "name" && key !== "message" && key !== "stack") errObject[key] = arg[key];
220
- args[i] = errObject;
221
- }
222
- }
223
- const data = {
224
- port: this.port,
225
- method,
226
- args,
227
- property,
228
- needResult
229
- };
230
- const child = childProcess.spawnSync(process.execPath, [requestCallFunctionFile, JSON.stringify(data)], { stdio: "pipe" });
231
- let result;
232
- if (child.stdout && child.stdout.length > 0) if (needResult) result = JSON.parse(child.stdout.toString());
233
- else console.error(child.stdout.toString());
234
- if (child.status !== 0) throw new Error(child.stderr.toString());
235
- if (child.error) throw child.error;
236
- return result;
237
- }
238
- };
239
- function createCluster(initOptions) {
240
- const options = formatOptions(initOptions);
241
- if (options.cache && clusters.has(options.baseDir)) {
242
- const clusterApp$1 = clusters.get(options.baseDir);
243
- if (!clusterApp$1.isClosed) return clusterApp$1;
244
- clusters.delete(options.baseDir);
245
- }
246
- if (options.clean !== false) {
247
- const logDir = path.join(options.baseDir, "logs");
248
- try {
249
- rimrafSync(logDir);
250
- } catch (err) {
251
- console.error(`remove log dir ${logDir} failed: ${err.stack}`);
252
- }
253
- const runDir = path.join(options.baseDir, "run");
254
- try {
255
- rimrafSync(runDir);
256
- } catch (err) {
257
- console.error(`remove run dir ${runDir} failed: ${err.stack}`);
258
- }
259
- }
260
- let clusterApp = new ClusterApplication(options);
261
- clusterApp = new Proxy(clusterApp, { get(target, prop) {
262
- debug("proxy handler.get %s", prop);
263
- const method = prop;
264
- if (typeof method === "string" && /^mock\w+$/.test(method) && target[method] === void 0) return function mockProxy(...args) {
265
- return target._callFunctionOnAppWorker(method, args, null, true);
266
- };
267
- return target[prop];
268
- } });
269
- clusters.set(options.baseDir, clusterApp);
270
- return clusterApp;
24
+ * A cluster version of egg.Application, you can test with supertest
25
+ * @example
26
+ * ```js
27
+ * const mm = require('mm');
28
+ * const request = require('supertest');
29
+ *
30
+ * describe('ClusterApplication', () => {
31
+ * let app;
32
+ * before(function (done) {
33
+ * app = mm.cluster({ baseDir });
34
+ * app.ready(done);
35
+ * });
36
+ *
37
+ * after(function () {
38
+ * app.close();
39
+ * });
40
+ *
41
+ * it('should 200', function (done) {
42
+ * request(app.callback())
43
+ * .get('/')
44
+ * .expect(200, done);
45
+ * });
46
+ * });
47
+ */
48
+ export class ClusterApplication extends Coffee {
49
+ options;
50
+ port;
51
+ baseDir;
52
+ closed;
53
+ _address;
54
+ /**
55
+ * @class
56
+ * @param {Object} options
57
+ * - {String} baseDir - The directory of the application
58
+ * - {Object} plugins - Custom you plugins
59
+ * - {String} framework - The directory of the egg framework
60
+ * - {Boolean} [cache=true] - Cache application based on baseDir
61
+ * - {Boolean} [coverage=true] - Switch on process coverage, but it'll be slower
62
+ * - {Boolean} [clean=true] - Remove $baseDir/logs
63
+ * - {Object} [opt] - opt pass to coffee, such as { execArgv: ['--debug'] }
64
+ * ```
65
+ */
66
+ constructor(options) {
67
+ const opt = options.opt;
68
+ delete options.opt;
69
+ // incremental port
70
+ options.port = options.port ?? ++globalThis.eggMockMasterPort;
71
+ // Set 1 worker when test
72
+ if (!options.workers) {
73
+ options.workers = 1;
74
+ }
75
+ const args = [JSON.stringify(options)];
76
+ debug('fork %s, args: %s, opt: %j', serverBin, args.join(' '), opt);
77
+ super({
78
+ method: 'fork',
79
+ cmd: serverBin,
80
+ args,
81
+ opt,
82
+ });
83
+ Ready.mixin(this);
84
+ this.port = options.port;
85
+ this.baseDir = options.baseDir;
86
+ // print stdout and stderr when DEBUG, otherwise stderr.
87
+ this.debug(process.env.DEBUG ? 0 : 2);
88
+ // disable coverage
89
+ if (options.coverage === false) {
90
+ this.coverage(false);
91
+ }
92
+ process.nextTick(() => {
93
+ this.proc.on('message', (msg) => {
94
+ // 'egg-ready' and { action: 'egg-ready' }
95
+ const action = msg && msg.action ? msg.action : msg;
96
+ switch (action) {
97
+ case 'egg-ready':
98
+ // data: { port: 17703, address: 'http://127.0.0.1:17703', protocol: 'http' }
99
+ debug('on message egg-ready %o', msg);
100
+ this._address = msg.data.address;
101
+ this.emit('close', 0);
102
+ break;
103
+ case 'app-worker-died':
104
+ case 'agent-worker-died':
105
+ this.emit('close', 1);
106
+ break;
107
+ default:
108
+ // ignore it
109
+ break;
110
+ }
111
+ });
112
+ });
113
+ this.end(() => this.ready(true));
114
+ }
115
+ /**
116
+ * the process that forked
117
+ * @member {ChildProcess}
118
+ */
119
+ get process() {
120
+ return this.proc;
121
+ }
122
+ /**
123
+ * Compatible API for supertest
124
+ */
125
+ callback() {
126
+ return this;
127
+ }
128
+ /**
129
+ * Compatible API for supertest
130
+ * @member {String} url
131
+ * @private
132
+ */
133
+ get url() {
134
+ if (this._address) {
135
+ return this._address;
136
+ }
137
+ return 'http://127.0.0.1:' + this.port;
138
+ }
139
+ /**
140
+ * Compatible API for supertest
141
+ */
142
+ address() {
143
+ return {
144
+ port: this.port,
145
+ address: this._address,
146
+ };
147
+ }
148
+ /**
149
+ * Compatible API for supertest
150
+ */
151
+ listen() {
152
+ return this;
153
+ }
154
+ /**
155
+ * kill the process
156
+ */
157
+ async close() {
158
+ this.closed = true;
159
+ const proc = this.proc;
160
+ const baseDir = this.baseDir;
161
+ if (proc?.connected) {
162
+ proc.kill('SIGTERM');
163
+ await once(proc, 'exit');
164
+ }
165
+ clusters.delete(baseDir);
166
+ debug('delete cluster cache %s, remain %s', baseDir, [...clusters.keys()]);
167
+ if (os.platform() === 'win32') {
168
+ await sleep(1000);
169
+ }
170
+ }
171
+ get isClosed() {
172
+ return this.closed;
173
+ }
174
+ // mock app.router.pathFor(name) api
175
+ get router() {
176
+ const self = this;
177
+ return {
178
+ pathFor(url) {
179
+ return self._callFunctionOnAppWorker('pathFor', [url], 'router', true);
180
+ },
181
+ };
182
+ }
183
+ /**
184
+ * get app[property] value in app worker
185
+ */
186
+ getAppInstanceProperty(property) {
187
+ return this._callFunctionOnAppWorker('__getter__', [], property, true);
188
+ }
189
+ /**
190
+ * collection logger message, then can be use on `expectLog()`
191
+ * it's different from `app.expectLog()`, only support string params.
192
+ *
193
+ * @param {String} [logger] - logger instance name, default is `logger`
194
+ * @function ClusterApplication#expectLog
195
+ */
196
+ mockLog(logger) {
197
+ logger = logger ?? 'logger';
198
+ this._callFunctionOnAppWorker('mockLog', [logger], null, true);
199
+ }
200
+ /**
201
+ * expect str in the logger
202
+ * it's different from `app.expectLog()`, only support string params.
203
+ *
204
+ * @param {String} str - test str
205
+ * @param {String} [logger] - logger instance name, default is `logger`
206
+ * @function ClusterApplication#expectLog
207
+ */
208
+ expectLog(str, logger) {
209
+ logger = logger ?? 'logger';
210
+ this._callFunctionOnAppWorker('expectLog', [str, logger], null, true);
211
+ }
212
+ /**
213
+ * not expect str in the logger
214
+ * it's different from `app.notExpectLog()`, only support string params.
215
+ *
216
+ * @param {String} str - test str
217
+ * @param {String} [logger] - logger instance name, default is `logger`
218
+ * @function ClusterApplication#notExpectLog
219
+ */
220
+ notExpectLog(str, logger) {
221
+ logger = logger ?? 'logger';
222
+ this._callFunctionOnAppWorker('notExpectLog', [str, logger], null, true);
223
+ }
224
+ httpRequest() {
225
+ return supertestRequest(this);
226
+ }
227
+ _callFunctionOnAppWorker(method, args = [], property = undefined, needResult = false) {
228
+ for (let i = 0; i < args.length; i++) {
229
+ const arg = args[i];
230
+ if (typeof arg === 'function') {
231
+ args[i] = {
232
+ __egg_mock_type: 'function',
233
+ value: arg.toString(),
234
+ };
235
+ }
236
+ else if (arg instanceof Error) {
237
+ const errObject = {
238
+ __egg_mock_type: 'error',
239
+ name: arg.name,
240
+ message: arg.message,
241
+ stack: arg.stack,
242
+ };
243
+ for (const key in arg) {
244
+ if (key !== 'name' && key !== 'message' && key !== 'stack') {
245
+ errObject[key] = arg[key];
246
+ }
247
+ }
248
+ args[i] = errObject;
249
+ }
250
+ }
251
+ const data = {
252
+ port: this.port,
253
+ method,
254
+ args,
255
+ property,
256
+ needResult,
257
+ };
258
+ const child = childProcess.spawnSync(process.execPath, [requestCallFunctionFile, JSON.stringify(data)], {
259
+ stdio: 'pipe',
260
+ });
261
+ // if (child.stderr && child.stderr.length > 0) {
262
+ // console.error(child.stderr.toString());
263
+ // }
264
+ let result;
265
+ if (child.stdout && child.stdout.length > 0) {
266
+ if (needResult) {
267
+ result = JSON.parse(child.stdout.toString());
268
+ }
269
+ else {
270
+ console.error(child.stdout.toString());
271
+ }
272
+ }
273
+ if (child.status !== 0) {
274
+ throw new Error(child.stderr.toString());
275
+ }
276
+ if (child.error) {
277
+ throw child.error;
278
+ }
279
+ return result;
280
+ }
281
+ }
282
+ export function createCluster(initOptions) {
283
+ const options = formatOptions(initOptions);
284
+ if (options.cache && clusters.has(options.baseDir)) {
285
+ const clusterApp = clusters.get(options.baseDir);
286
+ // return cache when it hasn't been killed
287
+ if (!clusterApp.isClosed) {
288
+ return clusterApp;
289
+ }
290
+ // delete the cache when it's closed
291
+ clusters.delete(options.baseDir);
292
+ }
293
+ if (options.clean !== false) {
294
+ const logDir = path.join(options.baseDir, 'logs');
295
+ try {
296
+ rimrafSync(logDir);
297
+ }
298
+ catch (err) {
299
+ console.error(`remove log dir ${logDir} failed: ${err.stack}`);
300
+ }
301
+ const runDir = path.join(options.baseDir, 'run');
302
+ try {
303
+ rimrafSync(runDir);
304
+ }
305
+ catch (err) {
306
+ console.error(`remove run dir ${runDir} failed: ${err.stack}`);
307
+ }
308
+ }
309
+ let clusterApp = new ClusterApplication(options);
310
+ clusterApp = new Proxy(clusterApp, {
311
+ get(target, prop) {
312
+ debug('proxy handler.get %s', prop);
313
+ // proxy mockXXX function to app worker
314
+ const method = prop;
315
+ if (typeof method === 'string' && /^mock\w+$/.test(method) && target[method] === undefined) {
316
+ return function mockProxy(...args) {
317
+ return target._callFunctionOnAppWorker(method, args, null, true);
318
+ };
319
+ }
320
+ return target[prop];
321
+ },
322
+ });
323
+ clusters.set(options.baseDir, clusterApp);
324
+ return clusterApp;
271
325
  }
272
- async function restore() {
273
- for (const clusterApp of clusters.values()) await clusterApp.mockRestore();
326
+ // export to let mm.restore() worked
327
+ export async function restore() {
328
+ for (const clusterApp of clusters.values()) {
329
+ // will proxy to app.mockRestore()
330
+ await clusterApp.mockRestore();
331
+ }
274
332
  }
275
- process.on("exit", () => {
276
- for (const clusterApp of clusters.values()) {
277
- debug("on exit close clusterApp, port: %s", clusterApp.port);
278
- clusterApp.close();
279
- }
333
+ // ensure to close App process on test exit.
334
+ process.on('exit', () => {
335
+ for (const clusterApp of clusters.values()) {
336
+ debug('on exit close clusterApp, port: %s', clusterApp.port);
337
+ clusterApp.close();
338
+ }
280
339
  });
281
-
282
- //#endregion
283
- export { ClusterApplication, createCluster, restore };
340
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2x1c3Rlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9saWIvY2x1c3Rlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sV0FBVyxDQUFDO0FBQ3JDLE9BQU8sSUFBSSxNQUFNLFdBQVcsQ0FBQztBQUM3QixPQUFPLEVBQUUsTUFBTSxTQUFTLENBQUM7QUFDekIsT0FBTyxZQUFZLE1BQU0sb0JBQW9CLENBQUM7QUFDOUMsT0FBTyxFQUFFLElBQUksRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUNuQyxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sU0FBUyxDQUFDO0FBRXJDLE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxRQUFRLENBQUM7QUFDaEMsT0FBTyxFQUFFLEtBQUssRUFBRSxNQUFNLFdBQVcsQ0FBQztBQUVsQyxPQUFPLEVBQUUsT0FBTyxJQUFJLGdCQUFnQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDN0QsT0FBTyxFQUFFLEtBQUssRUFBRSxVQUFVLEVBQUUsTUFBTSxZQUFZLENBQUM7QUFDL0MsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBSXBELE1BQU0sS0FBSyxHQUFHLFFBQVEsQ0FBQyxzQkFBc0IsQ0FBQyxDQUFDO0FBRS9DLE1BQU0sUUFBUSxHQUFHLElBQUksR0FBRyxFQUFFLENBQUM7QUFLM0IsVUFBVSxDQUFDLGlCQUFpQixHQUFHLEtBQUssR0FBRyxDQUFDLE9BQU8sQ0FBQyxHQUFHLEdBQUcsSUFBSSxDQUFDLENBQUM7QUFFNUQsSUFBSSxTQUFTLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRSxrQkFBa0IsQ0FBQyxDQUFDO0FBQ25FLElBQUksQ0FBQyxVQUFVLENBQUMsU0FBUyxDQUFDLEVBQUUsQ0FBQztJQUMzQixTQUFTLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFN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
@@ -1,4 +1 @@
1
- //#region src/lib/context.d.ts
2
- declare const context: any;
3
- //#endregion
4
- export { context };
1
+ export declare const context: any;