From 3e7a5044e3a687c8accbfc9f8a60c469bf4fdad6 Mon Sep 17 00:00:00 2001 From: fengmk2 Date: Tue, 2 Jul 2024 22:44:13 +0800 Subject: [PATCH] fix: don't close used mock agent (#170) avoid ClientDestroyedError ```bash ClientDestroyedError: The client is destroyed at Agent.dispatch (node_modules/undici/lib/dispatcher-base.js:172:15) at MockAgent.dispatch (node_modules/undici/lib/mock/mock-agent.js:65:25) at MockAgent.request (node_modules/undici/lib/api/api-request.js:169:10) ``` ## Summary by CodeRabbit - **Refactor** - Improved the control flow in the `restore()` method to enhance function execution order. - Streamlined logic in agent management for better clarity and efficiency. --- index.js | 4 ++-- lib/mock_agent.js | 20 ++++++++------------ 2 files changed, 10 insertions(+), 14 deletions(-) diff --git a/index.js b/index.js index 6382895..19e27a5 100644 --- a/index.js +++ b/index.js @@ -22,9 +22,9 @@ module.exports.default = mock; Object.assign(mock, mm, { restore() { cluster.restore(); - mm.restore(); + mockAgent.restore(app); // return promise - return mockAgent.restore(app); + return mm.restore(); }, /** diff --git a/lib/mock_agent.js b/lib/mock_agent.js index 9eeba0d..4b544dd 100644 --- a/lib/mock_agent.js +++ b/lib/mock_agent.js @@ -8,12 +8,10 @@ module.exports = { getAgent(app) { if (!_global) { _global = getGlobalDispatcher(); - if (typeof app?.httpclient?.getDispatcher === 'function') { - if (!app[APP_HTTPCLIENT_AGENT]) { - // save the raw dispatcher - app[APP_HTTPCLIENT_AGENT] = app.httpclient.getDispatcher(); - } - } + } + if (!app?.httpclient?.[APP_HTTPCLIENT_AGENT] && typeof app?.httpclient?.getDispatcher === 'function') { + // save the raw dispatcher + app.httpclient[APP_HTTPCLIENT_AGENT] = app.httpclient.getDispatcher(); } if (!_mockAgent) { _mockAgent = new MockAgent(); @@ -24,16 +22,14 @@ module.exports = { } return _mockAgent; }, - async restore(app) { + restore(app) { if (!_mockAgent) return; if (_global) { setGlobalDispatcher(_global); - if (app?.[APP_HTTPCLIENT_AGENT]) { - app.httpclient.setDispatcher(app[APP_HTTPCLIENT_AGENT]); - } } - const agent = _mockAgent; + if (app?.httpclient?.[APP_HTTPCLIENT_AGENT]) { + app.httpclient.setDispatcher(app.httpclient[APP_HTTPCLIENT_AGENT]); + } _mockAgent = null; - await agent.close(); }, };