@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.
Files changed (63) hide show
  1. package/dist/_virtual/rolldown_runtime.js +7 -0
  2. package/dist/app/extend/agent.d.ts +38 -34
  3. package/dist/app/extend/agent.js +48 -46
  4. package/dist/app/extend/application.d.ts +171 -167
  5. package/dist/app/extend/application.js +382 -442
  6. package/dist/app/middleware/cluster_app_mock.d.ts +5 -2
  7. package/dist/app/middleware/cluster_app_mock.js +95 -100
  8. package/dist/app.d.ts +9 -5
  9. package/dist/app.js +17 -18
  10. package/dist/bootstrap.d.ts +9 -5
  11. package/dist/bootstrap.js +11 -12
  12. package/dist/index.d.ts +20 -17
  13. package/dist/index.js +39 -78
  14. package/dist/inject_mocha.d.ts +1 -1
  15. package/dist/inject_mocha.js +27 -28
  16. package/dist/lib/agent_handler.d.ts +7 -3
  17. package/dist/lib/agent_handler.js +22 -20
  18. package/dist/lib/app.d.ts +7 -3
  19. package/dist/lib/app.js +246 -287
  20. package/dist/lib/app_handler.d.ts +9 -5
  21. package/dist/lib/app_handler.js +48 -61
  22. package/dist/lib/cluster.d.ts +122 -118
  23. package/dist/lib/cluster.js +278 -335
  24. package/dist/lib/context.d.ts +4 -1
  25. package/dist/lib/context.js +10 -11
  26. package/dist/lib/format_options.d.ts +9 -4
  27. package/dist/lib/format_options.js +60 -88
  28. package/dist/lib/inject_context.d.ts +8 -5
  29. package/dist/lib/inject_context.js +103 -123
  30. package/dist/lib/mock_agent.d.ts +8 -4
  31. package/dist/lib/mock_agent.js +42 -42
  32. package/dist/lib/mock_custom_loader.d.ts +4 -1
  33. package/dist/lib/mock_custom_loader.js +34 -33
  34. package/dist/lib/mock_http_server.d.ts +6 -2
  35. package/dist/lib/mock_http_server.js +16 -17
  36. package/dist/lib/mock_httpclient.d.ts +38 -34
  37. package/dist/lib/mock_httpclient.js +106 -142
  38. package/dist/lib/parallel/agent.d.ts +22 -18
  39. package/dist/lib/parallel/agent.js +106 -112
  40. package/dist/lib/parallel/app.d.ts +23 -19
  41. package/dist/lib/parallel/app.js +93 -106
  42. package/dist/lib/parallel/util.d.ts +5 -2
  43. package/dist/lib/parallel/util.js +56 -63
  44. package/dist/lib/prerequire.d.ts +1 -1
  45. package/dist/lib/prerequire.js +1 -25
  46. package/dist/lib/request_call_function.d.ts +1 -1
  47. package/dist/lib/request_call_function.js +34 -47
  48. package/dist/lib/restore.d.ts +4 -1
  49. package/dist/lib/restore.js +14 -11
  50. package/dist/lib/start-cluster.d.ts +1 -2
  51. package/dist/lib/start-cluster.js +15 -14
  52. package/dist/lib/supertest.d.ts +14 -9
  53. package/dist/lib/supertest.js +32 -36
  54. package/dist/lib/tmp/empty.d.ts +1 -1
  55. package/dist/lib/tmp/empty.js +1 -2
  56. package/dist/lib/types.d.ts +71 -67
  57. package/dist/lib/types.js +1 -2
  58. package/dist/lib/utils.d.ts +11 -8
  59. package/dist/lib/utils.js +34 -63
  60. package/dist/register.d.ts +11 -7
  61. package/dist/register.js +36 -40
  62. package/dist/typings/index.d.ts +1 -0
  63. package/package.json +36 -39
@@ -1,445 +1,385 @@
1
- import { debuglog } from 'node:util';
2
- import http, { IncomingMessage } from 'node:http';
3
- import fs from 'node:fs';
4
- import assert from 'node:assert';
5
- import mergeDescriptors from 'merge-descriptors';
6
- import { isAsyncFunction, isObject } from 'is-type-of';
7
- import { mock, restore } from 'mm';
8
- import { Transport, Logger } from 'egg-logger';
9
- import { Application } from 'egg';
10
1
  import { getMockAgent, restoreMockAgent } from "../../lib/mock_agent.js";
11
- import { createMockHttpClient, } from "../../lib/mock_httpclient.js";
12
- import { request as supertestRequest, EggTestRequest } from "../../lib/supertest.js";
13
- import {} from "../../lib/types.js";
14
- const debug = debuglog('egg/mock/app/extend/application');
15
- const ORIGIN_TYPES = Symbol('@eggjs/mock originTypes');
16
- const BACKGROUND_TASKS = Symbol('Application#backgroundTasks');
17
- const REUSED_CTX = Symbol('Context#reusedInSuite');
18
- export default class ApplicationUnittest extends Application {
19
- _mockHttpClient;
20
- /**
21
- * mock Context
22
- * @function App#mockContext
23
- * @param {Object} data - ctx data
24
- * @param {Object} [options] - mock ctx options
25
- * @example
26
- * ```js
27
- * const ctx = app.mockContext({
28
- * user: {
29
- * name: 'Jason'
30
- * }
31
- * });
32
- * console.log(ctx.user.name); // Jason
33
- *
34
- * // controller
35
- * module.exports = function*() {
36
- * this.body = this.user.name;
37
- * };
38
- * ```
39
- */
40
- mockContext(data, options) {
41
- data = data ?? {};
42
- function mockRequest(req) {
43
- for (const key in data?.headers) {
44
- mock(req.headers, key, data.headers[key]);
45
- mock(req.headers, key.toLowerCase(), data.headers[key]);
46
- }
47
- }
48
- // try to use app.options.mockCtxStorage first
49
- const mockCtxStorage = this.options.mockCtxStorage ?? true;
50
- options = Object.assign({ mockCtxStorage }, options);
51
- if ('_customMockContext' in this && typeof this._customMockContext === 'function') {
52
- this._customMockContext(data);
53
- }
54
- // 使用者自定义mock,可以覆盖上面的 mock
55
- for (const key in data) {
56
- mock(this.context, key, data[key]);
57
- }
58
- const req = this.mockRequest(data);
59
- const res = new http.ServerResponse(req);
60
- if (options.reuseCtxStorage !== false) {
61
- if (this.currentContext && !this.currentContext[REUSED_CTX]) {
62
- mockRequest(this.currentContext.request.req);
63
- this.currentContext[REUSED_CTX] = true;
64
- return this.currentContext;
65
- }
66
- }
67
- const ctx = this.createContext(req, res);
68
- if (options.mockCtxStorage) {
69
- mock(this.ctxStorage, 'getStore', () => ctx);
70
- }
71
- return ctx;
72
- }
73
- async mockContextScope(fn, data) {
74
- const ctx = this.mockContext(data, {
75
- mockCtxStorage: false,
76
- reuseCtxStorage: false,
77
- });
78
- return await this.ctxStorage.run(ctx, async () => {
79
- return await fn(ctx);
80
- });
81
- }
82
- /**
83
- * mock cookie session
84
- * @function App#mockSession
85
- * @param {Object} data - session object
86
- */
87
- mockSession(data) {
88
- if (!data) {
89
- return this;
90
- }
91
- if (isObject(data) && !('save' in data)) {
92
- // keep session.save() work
93
- Object.defineProperty(data, 'save', {
94
- value: () => { },
95
- enumerable: false,
96
- });
97
- }
98
- mock(this.context, 'session', data);
99
- return this;
100
- }
101
- /**
102
- * Mock service
103
- * @function App#mockService
104
- * @param {String} service - name
105
- * @param {String} methodName - method
106
- * @param {Object|Function|Error} fn - mock you data
107
- */
108
- mockService(service, methodName, fn) {
109
- if (typeof service === 'string') {
110
- const splits = service.split('.');
111
- service = this.serviceClasses;
112
- for (const key of splits) {
113
- service = service[key];
114
- }
115
- service = service.prototype || service;
116
- }
117
- this._mockFn(service, methodName, fn);
118
- return this;
119
- }
120
- /**
121
- * mock service that return error
122
- * @function App#mockServiceError
123
- * @param {String} service - name
124
- * @param {String} methodName - method
125
- * @param {Error} [err] - error information
126
- */
127
- mockServiceError(service, methodName, err) {
128
- if (typeof err === 'string') {
129
- err = new Error(err);
130
- }
131
- if (!err) {
132
- // mockServiceError(service, methodName)
133
- err = new Error(`mock ${methodName} error`);
134
- }
135
- this.mockService(service, methodName, err);
136
- return this;
137
- }
138
- _mockFn(obj, name, data) {
139
- const origin = obj[name];
140
- assert(typeof origin === 'function', `property ${name} in original object must be function`);
141
- // keep origin properties' type to support mock multi times
142
- if (!obj[ORIGIN_TYPES])
143
- obj[ORIGIN_TYPES] = {};
144
- let type = obj[ORIGIN_TYPES][name];
145
- if (!type) {
146
- type = obj[ORIGIN_TYPES][name] = isAsyncFunction(origin) ? 'async' : 'sync';
147
- }
148
- if (typeof data === 'function') {
149
- const fn = data;
150
- // if original is async function
151
- // but the mock function is normal function, need to change it return a promise
152
- if (type === 'async' && !isAsyncFunction(fn)) {
153
- mock(obj, name, function (...args) {
154
- return new Promise((resolve) => {
155
- resolve(fn.apply(this, args));
156
- });
157
- });
158
- return;
159
- }
160
- mock(obj, name, fn);
161
- return;
162
- }
163
- if (type === 'async') {
164
- mock(obj, name, () => {
165
- return new Promise((resolve, reject) => {
166
- if (data instanceof Error)
167
- return reject(data);
168
- resolve(data);
169
- });
170
- });
171
- return;
172
- }
173
- mock(obj, name, () => {
174
- if (data instanceof Error) {
175
- throw data;
176
- }
177
- return data;
178
- });
179
- }
180
- /**
181
- * mock request
182
- * @function App#mockRequest
183
- * @param {Request} req - mock request
184
- */
185
- mockRequest(req) {
186
- req = { ...req };
187
- const headers = req.headers ?? {};
188
- for (const key in req.headers) {
189
- headers[key.toLowerCase()] = req.headers[key];
190
- }
191
- if (!headers['x-forwarded-for']) {
192
- headers['x-forwarded-for'] = '127.0.0.1';
193
- }
194
- headers['x-mock-request-from'] = '@eggjs/mock';
195
- req.headers = headers;
196
- mergeDescriptors(req, {
197
- query: {},
198
- querystring: '',
199
- host: '127.0.0.1',
200
- hostname: '127.0.0.1',
201
- protocol: 'http',
202
- secure: 'false',
203
- method: 'GET',
204
- url: '/',
205
- path: '/',
206
- socket: {
207
- remoteAddress: '127.0.0.1',
208
- remotePort: 7001,
209
- },
210
- });
211
- return req;
212
- }
213
- /**
214
- * mock cookies
215
- * @function App#mockCookies
216
- */
217
- mockCookies(cookies) {
218
- if (!cookies) {
219
- return this;
220
- }
221
- const createContext = this.createContext;
222
- mock(this, 'createContext', function (req, res) {
223
- const ctx = createContext.call(this, req, res);
224
- const getCookie = ctx.cookies.get;
225
- mock(ctx.cookies, 'get', function (key, opts) {
226
- if (cookies[key]) {
227
- return cookies[key];
228
- }
229
- return getCookie.call(this, key, opts);
230
- });
231
- return ctx;
232
- });
233
- return this;
234
- }
235
- /**
236
- * mock header
237
- * @function App#mockHeaders
238
- */
239
- mockHeaders(headers) {
240
- if (!headers) {
241
- return this;
242
- }
243
- const getHeader = this.request.get;
244
- mock(this.request, 'get', function (field) {
245
- const value = findHeaders(headers, field);
246
- if (value)
247
- return value;
248
- return getHeader.call(this, field);
249
- });
250
- return this;
251
- }
252
- /**
253
- * mock csrf
254
- * @function App#mockCsrf
255
- * @since 1.11
256
- */
257
- mockCsrf() {
258
- mock(this.context, 'assertCSRF', () => { });
259
- mock(this.context, 'assertCsrf', () => { });
260
- return this;
261
- }
262
- /**
263
- * mock httpclient
264
- * @alias mockHttpClient
265
- * @function App#mockHttpclient
266
- */
267
- mockHttpclient(mockUrl, mockMethod, mockResult) {
268
- return this.mockHttpClient(mockUrl, mockMethod, mockResult);
269
- }
270
- /**
271
- * mock httpclient
272
- * @function App#mockHttpClient
273
- */
274
- mockHttpClient(mockUrl, mockMethod, mockResult) {
275
- if (!this._mockHttpClient) {
276
- this._mockHttpClient = createMockHttpClient(this);
277
- }
278
- this._mockHttpClient(mockUrl, mockMethod, mockResult);
279
- return this;
280
- }
281
- /**
282
- * @deprecated Please use app.mockHttpClient instead of app.mockUrllib
283
- */
284
- mockUrllib(mockUrl, mockMethod, mockResult) {
285
- this.deprecate('[@eggjs/mock] Please use app.mockHttpClient instead of app.mockUrllib');
286
- return this.mockHttpClient(mockUrl, mockMethod, mockResult);
287
- }
288
- /**
289
- * get mock httpclient agent
290
- * @function App#mockHttpclientAgent
291
- */
292
- mockAgent() {
293
- return getMockAgent(this);
294
- }
295
- async mockAgentRestore() {
296
- await restoreMockAgent();
297
- }
298
- /**
299
- * @see mm#restore
300
- * @function App#mockRestore
301
- */
302
- async mockRestore() {
303
- await this.mockAgentRestore();
304
- restore();
305
- }
306
- /**
307
- * @see mm
308
- * @function App#mm
309
- */
310
- get mm() {
311
- return mock;
312
- }
313
- /**
314
- * override loadAgent
315
- * @function App#loadAgent
316
- */
317
- loadAgent() { }
318
- /**
319
- * mock serverEnv
320
- * @function App#mockEnv
321
- * @param {String} env - serverEnv
322
- */
323
- mockEnv(env) {
324
- mock(this.config, 'env', env);
325
- mock(this.config, 'serverEnv', env);
326
- debug('mock env: %o', env);
327
- return this;
328
- }
329
- /**
330
- * http request helper
331
- * @function App#httpRequest
332
- * @return {SupertestRequest} req - supertest request
333
- * @see https://github.com/visionmedia/supertest
334
- */
335
- httpRequest() {
336
- return supertestRequest(this);
337
- }
338
- /**
339
- * collection logger message, then can be use on `expectLog()`
340
- * @param {String|Logger} [logger] - logger instance, default is `app.logger`
341
- * @function App#mockLog
342
- */
343
- mockLog(logger) {
344
- logger = logger ?? this.logger;
345
- if (typeof logger === 'string') {
346
- logger = this.getLogger(logger);
347
- }
348
- // make sure mock once
349
- if ('_mockLogs' in logger && logger._mockLogs)
350
- return;
351
- const transport = new Transport(logger.options);
352
- // https://github.com/eggjs/egg-logger/blob/master/lib/logger.js#L64
353
- const log = logger.log;
354
- const mockLogs = [];
355
- mock(logger, '_mockLogs', mockLogs);
356
- mock(logger, 'log', (level, args, meta) => {
357
- const message = transport.log(level, args, meta);
358
- mockLogs.push(message);
359
- log.apply(logger, [level, args, meta]);
360
- });
361
- }
362
- __checkExpectLog(expectOrNot, str, logger) {
363
- logger = logger || this.logger;
364
- if (typeof logger === 'string') {
365
- logger = this.getLogger(logger);
366
- }
367
- const filepath = logger.options.file;
368
- let content;
369
- if ('_mockLogs' in logger && logger._mockLogs) {
370
- content = logger._mockLogs.join('\n');
371
- }
372
- else {
373
- content = fs.readFileSync(filepath, 'utf8');
374
- }
375
- let match;
376
- let type;
377
- if (str instanceof RegExp) {
378
- match = str.test(content);
379
- type = 'RegExp';
380
- }
381
- else {
382
- match = content.includes(String(str));
383
- type = 'String';
384
- }
385
- if (expectOrNot) {
386
- assert(match, `Can't find ${type}:"${str}" in ${filepath}, log content: ...${content.substring(content.length - 500)}`);
387
- }
388
- else {
389
- assert(!match, `Find ${type}:"${str}" in ${filepath}, log content: ...${content.substring(content.length - 500)}`);
390
- }
391
- }
392
- /**
393
- * expect str/regexp in the logger, if your server disk is slow, please call `mockLog()` first.
394
- * @param {String|RegExp} str - test str or regexp
395
- * @param {String|Logger} [logger] - logger instance, default is `ctx.logger`
396
- * @function App#expectLog
397
- */
398
- expectLog(str, logger) {
399
- this.__checkExpectLog(true, str, logger);
400
- }
401
- /**
402
- * not expect str/regexp in the logger, if your server disk is slow, please call `mockLog()` first.
403
- * @param {String|RegExp} str - test str or regexp
404
- * @param {String|Logger} [logger] - logger instance, default is `ctx.logger`
405
- * @function App#notExpectLog
406
- */
407
- notExpectLog(str, logger) {
408
- this.__checkExpectLog(false, str, logger);
409
- }
410
- async backgroundTasksFinished() {
411
- const tasks = this._backgroundTasks;
412
- debug('waiting %d background tasks', tasks.length);
413
- if (tasks.length === 0)
414
- return;
415
- this._backgroundTasks = [];
416
- await Promise.all(tasks);
417
- debug('finished %d background tasks', tasks.length);
418
- if (this._backgroundTasks.length) {
419
- debug('new background tasks created: %s', this._backgroundTasks.length);
420
- await this.backgroundTasksFinished();
421
- }
422
- }
423
- get _backgroundTasks() {
424
- if (!this[BACKGROUND_TASKS]) {
425
- this[BACKGROUND_TASKS] = [];
426
- }
427
- return this[BACKGROUND_TASKS];
428
- }
429
- set _backgroundTasks(tasks) {
430
- this[BACKGROUND_TASKS] = tasks;
431
- }
432
- }
2
+ import { createMockHttpClient } from "../../lib/mock_httpclient.js";
3
+ import { request } from "../../lib/supertest.js";
4
+ import { Application } from "egg";
5
+ import assert from "node:assert";
6
+ import { mock, restore } from "mm";
7
+ import { debuglog } from "node:util";
8
+ import fs from "node:fs";
9
+ import http, { IncomingMessage } from "node:http";
10
+ import { Logger, Transport } from "egg-logger";
11
+ import { isAsyncFunction, isObject } from "is-type-of";
12
+ import mergeDescriptors from "merge-descriptors";
13
+
14
+ //#region src/app/extend/application.ts
15
+ const debug = debuglog("egg/mock/app/extend/application");
16
+ const ORIGIN_TYPES = Symbol("@eggjs/mock originTypes");
17
+ const BACKGROUND_TASKS = Symbol("Application#backgroundTasks");
18
+ const REUSED_CTX = Symbol("Context#reusedInSuite");
19
+ var ApplicationUnittest = class extends Application {
20
+ _mockHttpClient;
21
+ /**
22
+ * mock Context
23
+ * @function App#mockContext
24
+ * @param {Object} data - ctx data
25
+ * @param {Object} [options] - mock ctx options
26
+ * @example
27
+ * ```js
28
+ * const ctx = app.mockContext({
29
+ * user: {
30
+ * name: 'Jason'
31
+ * }
32
+ * });
33
+ * console.log(ctx.user.name); // Jason
34
+ *
35
+ * // controller
36
+ * module.exports = function*() {
37
+ * this.body = this.user.name;
38
+ * };
39
+ * ```
40
+ */
41
+ mockContext(data, options) {
42
+ data = data ?? {};
43
+ function mockRequest(req$1) {
44
+ for (const key in data?.headers) {
45
+ mock(req$1.headers, key, data.headers[key]);
46
+ mock(req$1.headers, key.toLowerCase(), data.headers[key]);
47
+ }
48
+ }
49
+ const mockCtxStorage = this.options.mockCtxStorage ?? true;
50
+ options = Object.assign({ mockCtxStorage }, options);
51
+ if ("_customMockContext" in this && typeof this._customMockContext === "function") this._customMockContext(data);
52
+ for (const key in data) mock(this.context, key, data[key]);
53
+ const req = this.mockRequest(data);
54
+ const res = new http.ServerResponse(req);
55
+ if (options.reuseCtxStorage !== false) {
56
+ if (this.currentContext && !this.currentContext[REUSED_CTX]) {
57
+ mockRequest(this.currentContext.request.req);
58
+ this.currentContext[REUSED_CTX] = true;
59
+ return this.currentContext;
60
+ }
61
+ }
62
+ const ctx = this.createContext(req, res);
63
+ if (options.mockCtxStorage) mock(this.ctxStorage, "getStore", () => ctx);
64
+ return ctx;
65
+ }
66
+ async mockContextScope(fn, data) {
67
+ const ctx = this.mockContext(data, {
68
+ mockCtxStorage: false,
69
+ reuseCtxStorage: false
70
+ });
71
+ return await this.ctxStorage.run(ctx, async () => {
72
+ return await fn(ctx);
73
+ });
74
+ }
75
+ /**
76
+ * mock cookie session
77
+ * @function App#mockSession
78
+ * @param {Object} data - session object
79
+ */
80
+ mockSession(data) {
81
+ if (!data) return this;
82
+ if (isObject(data) && !("save" in data)) Object.defineProperty(data, "save", {
83
+ value: () => {},
84
+ enumerable: false
85
+ });
86
+ mock(this.context, "session", data);
87
+ return this;
88
+ }
89
+ /**
90
+ * Mock service
91
+ * @function App#mockService
92
+ * @param {String} service - name
93
+ * @param {String} methodName - method
94
+ * @param {Object|Function|Error} fn - mock you data
95
+ */
96
+ mockService(service, methodName, fn) {
97
+ if (typeof service === "string") {
98
+ const splits = service.split(".");
99
+ service = this.serviceClasses;
100
+ for (const key of splits) service = service[key];
101
+ service = service.prototype || service;
102
+ }
103
+ this._mockFn(service, methodName, fn);
104
+ return this;
105
+ }
106
+ /**
107
+ * mock service that return error
108
+ * @function App#mockServiceError
109
+ * @param {String} service - name
110
+ * @param {String} methodName - method
111
+ * @param {Error} [err] - error information
112
+ */
113
+ mockServiceError(service, methodName, err) {
114
+ if (typeof err === "string") err = new Error(err);
115
+ if (!err) err = /* @__PURE__ */ new Error(`mock ${methodName} error`);
116
+ this.mockService(service, methodName, err);
117
+ return this;
118
+ }
119
+ _mockFn(obj, name, data) {
120
+ const origin = obj[name];
121
+ assert(typeof origin === "function", `property ${name} in original object must be function`);
122
+ if (!obj[ORIGIN_TYPES]) obj[ORIGIN_TYPES] = {};
123
+ let type = obj[ORIGIN_TYPES][name];
124
+ if (!type) type = obj[ORIGIN_TYPES][name] = isAsyncFunction(origin) ? "async" : "sync";
125
+ if (typeof data === "function") {
126
+ const fn = data;
127
+ if (type === "async" && !isAsyncFunction(fn)) {
128
+ mock(obj, name, function(...args) {
129
+ return new Promise((resolve) => {
130
+ resolve(fn.apply(this, args));
131
+ });
132
+ });
133
+ return;
134
+ }
135
+ mock(obj, name, fn);
136
+ return;
137
+ }
138
+ if (type === "async") {
139
+ mock(obj, name, () => {
140
+ return new Promise((resolve, reject) => {
141
+ if (data instanceof Error) return reject(data);
142
+ resolve(data);
143
+ });
144
+ });
145
+ return;
146
+ }
147
+ mock(obj, name, () => {
148
+ if (data instanceof Error) throw data;
149
+ return data;
150
+ });
151
+ }
152
+ /**
153
+ * mock request
154
+ * @function App#mockRequest
155
+ * @param {Request} req - mock request
156
+ */
157
+ mockRequest(req) {
158
+ req = { ...req };
159
+ const headers = req.headers ?? {};
160
+ for (const key in req.headers) headers[key.toLowerCase()] = req.headers[key];
161
+ if (!headers["x-forwarded-for"]) headers["x-forwarded-for"] = "127.0.0.1";
162
+ headers["x-mock-request-from"] = "@eggjs/mock";
163
+ req.headers = headers;
164
+ mergeDescriptors(req, {
165
+ query: {},
166
+ querystring: "",
167
+ host: "127.0.0.1",
168
+ hostname: "127.0.0.1",
169
+ protocol: "http",
170
+ secure: "false",
171
+ method: "GET",
172
+ url: "/",
173
+ path: "/",
174
+ socket: {
175
+ remoteAddress: "127.0.0.1",
176
+ remotePort: 7001
177
+ }
178
+ });
179
+ return req;
180
+ }
181
+ /**
182
+ * mock cookies
183
+ * @function App#mockCookies
184
+ */
185
+ mockCookies(cookies) {
186
+ if (!cookies) return this;
187
+ const createContext = this.createContext;
188
+ mock(this, "createContext", function(req, res) {
189
+ const ctx = createContext.call(this, req, res);
190
+ const getCookie = ctx.cookies.get;
191
+ mock(ctx.cookies, "get", function(key, opts) {
192
+ if (cookies[key]) return cookies[key];
193
+ return getCookie.call(this, key, opts);
194
+ });
195
+ return ctx;
196
+ });
197
+ return this;
198
+ }
199
+ /**
200
+ * mock header
201
+ * @function App#mockHeaders
202
+ */
203
+ mockHeaders(headers) {
204
+ if (!headers) return this;
205
+ const getHeader = this.request.get;
206
+ mock(this.request, "get", function(field) {
207
+ const value = findHeaders(headers, field);
208
+ if (value) return value;
209
+ return getHeader.call(this, field);
210
+ });
211
+ return this;
212
+ }
213
+ /**
214
+ * mock csrf
215
+ * @function App#mockCsrf
216
+ * @since 1.11
217
+ */
218
+ mockCsrf() {
219
+ mock(this.context, "assertCSRF", () => {});
220
+ mock(this.context, "assertCsrf", () => {});
221
+ return this;
222
+ }
223
+ /**
224
+ * mock httpclient
225
+ * @alias mockHttpClient
226
+ * @function App#mockHttpclient
227
+ */
228
+ mockHttpclient(mockUrl, mockMethod, mockResult) {
229
+ return this.mockHttpClient(mockUrl, mockMethod, mockResult);
230
+ }
231
+ /**
232
+ * mock httpclient
233
+ * @function App#mockHttpClient
234
+ */
235
+ mockHttpClient(mockUrl, mockMethod, mockResult) {
236
+ if (!this._mockHttpClient) this._mockHttpClient = createMockHttpClient(this);
237
+ this._mockHttpClient(mockUrl, mockMethod, mockResult);
238
+ return this;
239
+ }
240
+ /**
241
+ * @deprecated Please use app.mockHttpClient instead of app.mockUrllib
242
+ */
243
+ mockUrllib(mockUrl, mockMethod, mockResult) {
244
+ this.deprecate("[@eggjs/mock] Please use app.mockHttpClient instead of app.mockUrllib");
245
+ return this.mockHttpClient(mockUrl, mockMethod, mockResult);
246
+ }
247
+ /**
248
+ * get mock httpclient agent
249
+ * @function App#mockHttpclientAgent
250
+ */
251
+ mockAgent() {
252
+ return getMockAgent(this);
253
+ }
254
+ async mockAgentRestore() {
255
+ await restoreMockAgent();
256
+ }
257
+ /**
258
+ * @see mm#restore
259
+ * @function App#mockRestore
260
+ */
261
+ async mockRestore() {
262
+ await this.mockAgentRestore();
263
+ restore();
264
+ }
265
+ /**
266
+ * @see mm
267
+ * @function App#mm
268
+ */
269
+ get mm() {
270
+ return mock;
271
+ }
272
+ /**
273
+ * override loadAgent
274
+ * @function App#loadAgent
275
+ */
276
+ loadAgent() {}
277
+ /**
278
+ * mock serverEnv
279
+ * @function App#mockEnv
280
+ * @param {String} env - serverEnv
281
+ */
282
+ mockEnv(env) {
283
+ mock(this.config, "env", env);
284
+ mock(this.config, "serverEnv", env);
285
+ debug("mock env: %o", env);
286
+ return this;
287
+ }
288
+ /**
289
+ * http request helper
290
+ * @function App#httpRequest
291
+ * @return {SupertestRequest} req - supertest request
292
+ * @see https://github.com/visionmedia/supertest
293
+ */
294
+ httpRequest() {
295
+ return request(this);
296
+ }
297
+ /**
298
+ * collection logger message, then can be use on `expectLog()`
299
+ * @param {String|Logger} [logger] - logger instance, default is `app.logger`
300
+ * @function App#mockLog
301
+ */
302
+ mockLog(logger) {
303
+ logger = logger ?? this.logger;
304
+ if (typeof logger === "string") logger = this.getLogger(logger);
305
+ if ("_mockLogs" in logger && logger._mockLogs) return;
306
+ const transport = new Transport(logger.options);
307
+ const log = logger.log;
308
+ const mockLogs = [];
309
+ mock(logger, "_mockLogs", mockLogs);
310
+ mock(logger, "log", (level, args, meta) => {
311
+ const message = transport.log(level, args, meta);
312
+ mockLogs.push(message);
313
+ log.apply(logger, [
314
+ level,
315
+ args,
316
+ meta
317
+ ]);
318
+ });
319
+ }
320
+ __checkExpectLog(expectOrNot, str, logger) {
321
+ logger = logger || this.logger;
322
+ if (typeof logger === "string") logger = this.getLogger(logger);
323
+ const filepath = logger.options.file;
324
+ let content;
325
+ if ("_mockLogs" in logger && logger._mockLogs) content = logger._mockLogs.join("\n");
326
+ else content = fs.readFileSync(filepath, "utf8");
327
+ let match;
328
+ let type;
329
+ if (str instanceof RegExp) {
330
+ match = str.test(content);
331
+ type = "RegExp";
332
+ } else {
333
+ match = content.includes(String(str));
334
+ type = "String";
335
+ }
336
+ if (expectOrNot) assert(match, `Can't find ${type}:"${str}" in ${filepath}, log content: ...${content.substring(content.length - 500)}`);
337
+ else assert(!match, `Find ${type}:"${str}" in ${filepath}, log content: ...${content.substring(content.length - 500)}`);
338
+ }
339
+ /**
340
+ * expect str/regexp in the logger, if your server disk is slow, please call `mockLog()` first.
341
+ * @param {String|RegExp} str - test str or regexp
342
+ * @param {String|Logger} [logger] - logger instance, default is `ctx.logger`
343
+ * @function App#expectLog
344
+ */
345
+ expectLog(str, logger) {
346
+ this.__checkExpectLog(true, str, logger);
347
+ }
348
+ /**
349
+ * not expect str/regexp in the logger, if your server disk is slow, please call `mockLog()` first.
350
+ * @param {String|RegExp} str - test str or regexp
351
+ * @param {String|Logger} [logger] - logger instance, default is `ctx.logger`
352
+ * @function App#notExpectLog
353
+ */
354
+ notExpectLog(str, logger) {
355
+ this.__checkExpectLog(false, str, logger);
356
+ }
357
+ async backgroundTasksFinished() {
358
+ const tasks = this._backgroundTasks;
359
+ debug("waiting %d background tasks", tasks.length);
360
+ if (tasks.length === 0) return;
361
+ this._backgroundTasks = [];
362
+ await Promise.all(tasks);
363
+ debug("finished %d background tasks", tasks.length);
364
+ if (this._backgroundTasks.length) {
365
+ debug("new background tasks created: %s", this._backgroundTasks.length);
366
+ await this.backgroundTasksFinished();
367
+ }
368
+ }
369
+ get _backgroundTasks() {
370
+ if (!this[BACKGROUND_TASKS]) this[BACKGROUND_TASKS] = [];
371
+ return this[BACKGROUND_TASKS];
372
+ }
373
+ set _backgroundTasks(tasks) {
374
+ this[BACKGROUND_TASKS] = tasks;
375
+ }
376
+ };
433
377
  function findHeaders(headers, key) {
434
- if (!headers || !key) {
435
- return null;
436
- }
437
- key = key.toLowerCase();
438
- for (const headerKey in headers) {
439
- if (key === headerKey.toLowerCase()) {
440
- return headers[headerKey];
441
- }
442
- }
443
- return null;
378
+ if (!headers || !key) return null;
379
+ key = key.toLowerCase();
380
+ for (const headerKey in headers) if (key === headerKey.toLowerCase()) return headers[headerKey];
381
+ return null;
444
382
  }
445
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBwbGljYXRpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXBwL2V4dGVuZC9hcHBsaWNhdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sV0FBVyxDQUFDO0FBQ3JDLE9BQU8sSUFBSSxFQUFFLEVBQUUsZUFBZSxFQUFFLE1BQU0sV0FBVyxDQUFDO0FBQ2xELE9BQU8sRUFBRSxNQUFNLFNBQVMsQ0FBQztBQUN6QixPQUFPLE1BQU0sTUFBTSxhQUFhLENBQUM7QUFFakMsT0FBTyxnQkFBZ0IsTUFBTSxtQkFBbUIsQ0FBQztBQUNqRCxPQUFPLEVBQUUsZUFBZSxFQUFFLFFBQVEsRUFBRSxNQUFNLFlBQVksQ0FBQztBQUN2RCxPQUFPLEVBQUUsSUFBSSxFQUFFLE9BQU8sRUFBRSxNQUFNLElBQUksQ0FBQztBQUNuQyxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBcUMsTUFBTSxZQUFZLENBQUM7QUFDbEYsT0FBTyxFQUFnQixXQUFXLEVBQUUsTUFBTSxLQUFLLENBQUM7QUFHaEQsT0FBTyxFQUFFLFlBQVksRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ3pFLE9BQU8sRUFDTCxvQkFBb0IsR0FJckIsTUFBTSw4QkFBOEIsQ0FBQztBQUN0QyxPQUFPLEVBQUUsT0FBTyxJQUFJLGdCQUFnQixFQUFFLGNBQWMsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3JGLE9BQU8sRUFBb0IsTUFBTSxvQkFBb0IsQ0FBQztBQUV0RCxNQUFNLEtBQUssR0FBRyxRQUFRLENBQUMsaUNBQWlDLENBQUMsQ0FBQztBQUUxRCxNQUFNLFlBQVksR0FBRyxNQUFNLENBQUMseUJBQXlCLENBQUMsQ0FBQztBQUN2RCxNQUFNLGdCQUFnQixHQUFHLE1BQU0sQ0FBQyw2QkFBNkIsQ0FBQyxDQUFDO0FBQy9ELE1BQU0sVUFBVSxHQUFHLE1BQU0sQ0FBQyx1QkFBdUIsQ0FB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
383
+
384
+ //#endregion
385
+ export { ApplicationUnittest as default };