From 5fefc20f12a49dfb3765f69b5c048e4b2ed04d5e Mon Sep 17 00:00:00 2001 From: Antoine Pultier <45740+fungiboletus@users.noreply.github.com> Date: Thu, 19 Nov 2020 18:43:17 +0100 Subject: [PATCH] Instantiate CacheableLookup only when needed (#1529) --- source/core/index.ts | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/source/core/index.ts b/source/core/index.ts index f3b08fb4d..ae1015fa6 100644 --- a/source/core/index.ts +++ b/source/core/index.ts @@ -31,7 +31,7 @@ import normalizePromiseArguments from '../as-promise/normalize-arguments'; import {PromiseOnly} from '../as-promise/types'; import calculateRetryDelay from './calculate-retry-delay'; -const globalDnsCache = new CacheableLookup(); +let globalDnsCache: CacheableLookup; type HttpRequestFunction = typeof httpRequest; type Error = NodeJS.ErrnoException; @@ -1758,6 +1758,10 @@ export default class Request extends Duplex implements RequestEvents { // `options.dnsCache` if (options.dnsCache === true) { + if (!globalDnsCache) { + globalDnsCache = new CacheableLookup(); + } + options.dnsCache = globalDnsCache; } else if (!is.undefined(options.dnsCache) && !options.dnsCache.lookup) { throw new TypeError(`Parameter \`dnsCache\` must be a CacheableLookup instance or a boolean, got ${is(options.dnsCache)}`);