Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

node-tdd

Package Overview
Dependencies
Maintainers
1
Versions
167
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

node-tdd - npm Package Compare versions

Comparing version 2.14.0 to 2.15.0

26

lib/modules/request-recorder.js

@@ -11,2 +11,4 @@ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }

const https = require('http');
const path = require('path');

@@ -85,3 +87,7 @@

assert(hasCassette === true);
const options = requestInjector.getLastOptions();
const {
protocol,
options,
body
} = requestInjector.getLast();

@@ -96,3 +102,7 @@ if (anyFlagPresent(['record'])) {

await new Promise(resolve => {
const r = http.request(options, response => {
options.protocol = `${protocol}:`;
const r = {
http,
https
}[protocol].request(options, response => {
response.on('data', () => {});

@@ -102,4 +112,4 @@ response.on('end', resolve);

if (options.body !== undefined) {
r.write(options.body);
if (body !== undefined) {
r.write(body);
}

@@ -118,6 +128,6 @@

expectedCassette.push({
scope: `${options.uri.protocol}//${options.uri.host}`,
scope: `${protocol}://${options.host}:${options.port}`,
method: options.method,
path: options.uri.path,
body: tryParseJson(options.body),
path: options.path,
body: tryParseJson(body),
status: 200,

@@ -233,2 +243,2 @@ response: {},

};
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/modules/request-recorder.js"],"names":["assert","require","http","path","fs","Joi","nock","nockListener","healSqsSendMessageBatch","buildKey","tryParseJson","convertHeaders","requestInjector","nockBack","back","nockRecorder","recorder","module","exports","opts","object","keys","cassetteFolder","string","stripHeaders","boolean","strict","heal","alternatives","nockDone","cassetteFilePath","knownCassetteNames","records","outOfOrderErrors","expectedCassette","pendingMocks","anyFlagPresent","flags","Array","isArray","length","needleFlags","split","some","flag","includes","inject","cassetteFile","push","join","hasCassette","existsSync","cassetteContent","smartRead","define","map","e","idx","key","interceptors","record","setMode","fixtures","subscribe","options","getLastOptions","rec","output_objects","dont_print","enable_reqheaders_recording","Promise","resolve","r","request","response","on","body","undefined","write","end","recorded","play","clear","Object","assign","headers","rawHeaders","scope","uri","protocol","host","method","status","responseIsBinary","before","scopeIdx","filteringRequestBody","findIndex","m","requestBody","filteringPath","requestPath","after","req","interceptor","requestBodyString","responseBody","reduce","respBody","fn","splice","afterRecord","recordings","JSON","stringify","release","unsubscribeAll","smartWrite","keepOrder","Error","shutdown","unexpectedFiles","walkDir","filter","f","get","slice","unmatchedRecordings"],"mappings":"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","sourcesContent":["const assert = require('assert');\nconst http = require('http');\nconst path = require('path');\nconst fs = require('smart-fs');\nconst Joi = require('joi-strict');\nconst nock = require('nock');\nconst nockListener = require('./request-recorder/nock-listener');\nconst healSqsSendMessageBatch = require('./request-recorder/heal-sqs-send-message-batch');\nconst { buildKey, tryParseJson, convertHeaders } = require('./request-recorder/util');\nconst requestInjector = require('./request-recorder/request-injector');\n\nconst nockBack = nock.back;\nconst nockRecorder = nock.recorder;\n\nmodule.exports = (opts) => {\n  Joi.assert(opts, Joi.object().keys({\n    cassetteFolder: Joi.string(),\n    stripHeaders: Joi.boolean(),\n    strict: Joi.boolean(),\n    heal: Joi.alternatives(Joi.boolean(), Joi.string())\n  }), 'Invalid Options Provided');\n  let nockDone = null;\n  let cassetteFilePath = null;\n  const knownCassetteNames = [];\n  const records = [];\n  const outOfOrderErrors = [];\n  const expectedCassette = [];\n  const pendingMocks = [];\n\n  const anyFlagPresent = (flags) => {\n    assert(Array.isArray(flags) && flags.length !== 0);\n    if (typeof opts.heal !== 'string') {\n      return false;\n    }\n    const needleFlags = opts.heal.split(',');\n    return flags.some((flag) => needleFlags.includes(flag));\n  };\n\n  return ({\n    inject: async (cassetteFile) => {\n      assert(nockDone === null);\n      knownCassetteNames.push(cassetteFile);\n      records.length = 0;\n      outOfOrderErrors.length = 0;\n      expectedCassette.length = 0;\n      pendingMocks.length = 0;\n\n      cassetteFilePath = path.join(opts.cassetteFolder, cassetteFile);\n      const hasCassette = fs.existsSync(cassetteFilePath);\n      if (hasCassette) {\n        const cassetteContent = fs.smartRead(cassetteFilePath);\n        pendingMocks.push(...nock\n          .define(cassetteContent)\n          .map((e, idx) => ({\n            idx,\n            key: buildKey(e.interceptors[0]),\n            record: cassetteContent[idx]\n          })));\n      }\n\n      nockBack.setMode(hasCassette ? 'lockdown' : 'record');\n      nockBack.fixtures = opts.cassetteFolder;\n      nockListener.subscribe('no match', () => {\n        assert(hasCassette === true);\n        const options = requestInjector.getLastOptions();\n        if (anyFlagPresent(['record'])) {\n          expectedCassette.push(async () => {\n            nockRecorder.rec({\n              output_objects: true,\n              dont_print: true,\n              enable_reqheaders_recording: false\n            });\n            await new Promise((resolve) => {\n              const r = http.request(options, (response) => {\n                response.on('data', () => {});\n                response.on('end', resolve);\n              });\n              if (options.body !== undefined) {\n                r.write(options.body);\n              }\n              r.end();\n            });\n            const recorded = nockRecorder.play();\n            nockRecorder.clear();\n            return recorded.map((record) => Object.assign(record, {\n              headers: opts.stripHeaders === true ? undefined : convertHeaders(record.rawHeaders),\n              rawHeaders: undefined\n            }));\n          });\n        } else if (anyFlagPresent(['stub'])) {\n          expectedCassette.push({\n            scope: `${options.uri.protocol}//${options.uri.host}`,\n            method: options.method,\n            path: options.uri.path,\n            body: tryParseJson(options.body),\n            status: 200,\n            response: {},\n            responseIsBinary: false\n          });\n        }\n      });\n      nockDone = await new Promise((resolve) => nockBack(cassetteFile, {\n        before: (scope, scopeIdx) => {\n          records.push({ ...scope });\n          // eslint-disable-next-line no-param-reassign\n          scope.filteringRequestBody = (body) => {\n            if (anyFlagPresent(['magic', 'body'])) {\n              const idx = pendingMocks.findIndex((m) => m.idx === scopeIdx);\n              const requestBody = tryParseJson(body);\n              pendingMocks[idx].record.body = requestBody === null ? 'null' : requestBody;\n              return scope.body;\n            }\n            return body;\n          };\n          // eslint-disable-next-line no-param-reassign\n          scope.filteringPath = (requestPath) => {\n            if (anyFlagPresent(['magic', 'path'])) {\n              const idx = pendingMocks.findIndex((m) => m.idx === scopeIdx);\n              pendingMocks[idx].record.path = requestPath;\n              return scope.path;\n            }\n            return requestPath;\n          };\n          return scope;\n        },\n        after: (scope, scopeIdx) => {\n          scope.on('request', (req, interceptor, requestBodyString) => {\n            const idx = pendingMocks.findIndex((e) => e.idx === scopeIdx);\n\n            if (anyFlagPresent(['magic', 'response'])) {\n              const responseBody = tryParseJson([\n                healSqsSendMessageBatch\n              ].reduce(\n                (respBody, fn) => fn(requestBodyString, respBody, scope),\n                interceptor.body\n              ));\n              // eslint-disable-next-line no-param-reassign\n              interceptor.body = responseBody;\n              pendingMocks[idx].record.response = responseBody;\n            }\n\n            expectedCassette.push(pendingMocks[idx].record);\n            if (idx !== 0) {\n              outOfOrderErrors.push(pendingMocks[idx].key);\n            }\n            pendingMocks.splice(idx, 1);\n          });\n        },\n        afterRecord: (recordings) => JSON.stringify(recordings.map((r) => ({\n          ...r,\n          body: tryParseJson(r.body),\n          rawHeaders: opts.stripHeaders === true ? undefined : r.rawHeaders\n        })), null, 2)\n      }, resolve));\n      requestInjector.inject();\n    },\n    release: async () => {\n      assert(nockDone !== null);\n      requestInjector.release();\n      nockDone();\n      nockDone = null;\n      nockListener.unsubscribeAll('no match');\n\n      for (let idx = 0; idx < expectedCassette.length; idx += 1) {\n        if (typeof expectedCassette[idx] === 'function') {\n          // eslint-disable-next-line no-await-in-loop\n          expectedCassette.splice(idx, 1, ...await expectedCassette[idx]());\n          idx -= 1;\n        }\n      }\n\n      if (opts.heal !== false) {\n        fs.smartWrite(\n          cassetteFilePath,\n          anyFlagPresent(['magic', 'prune'])\n            ? expectedCassette\n            : [...expectedCassette, ...pendingMocks.map(({ record }) => record)],\n          { keepOrder: outOfOrderErrors.length === 0 && pendingMocks.length === 0 }\n        );\n      }\n      if (opts.strict !== false) {\n        if (outOfOrderErrors.length !== 0) {\n          throw new Error(`Out of Order Recordings: ${outOfOrderErrors.join(', ')}`);\n        }\n        if (pendingMocks.length !== 0) {\n          throw new Error(`Unmatched Recordings: ${pendingMocks.map((e) => e.key).join(', ')}`);\n        }\n      }\n    },\n    shutdown: () => {\n      const unexpectedFiles = fs.walkDir(opts.cassetteFolder).filter((f) => !knownCassetteNames.includes(f));\n      if (unexpectedFiles.length !== 0) {\n        throw new Error(`Unexpected file(s) in cassette folder: ${unexpectedFiles.join(', ')}`);\n      }\n    },\n    get: () => ({\n      records: records.slice(),\n      outOfOrderErrors: outOfOrderErrors.slice(),\n      unmatchedRecordings: pendingMocks.map((e) => e.key).slice(),\n      expectedCassette: expectedCassette.slice(),\n      cassetteFilePath\n    })\n  });\n};\n"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/modules/request-recorder.js"],"names":["assert","require","http","https","path","fs","Joi","nock","nockListener","healSqsSendMessageBatch","buildKey","tryParseJson","convertHeaders","requestInjector","nockBack","back","nockRecorder","recorder","module","exports","opts","object","keys","cassetteFolder","string","stripHeaders","boolean","strict","heal","alternatives","nockDone","cassetteFilePath","knownCassetteNames","records","outOfOrderErrors","expectedCassette","pendingMocks","anyFlagPresent","flags","Array","isArray","length","needleFlags","split","some","flag","includes","inject","cassetteFile","push","join","hasCassette","existsSync","cassetteContent","smartRead","define","map","e","idx","key","interceptors","record","setMode","fixtures","subscribe","protocol","options","body","getLast","rec","output_objects","dont_print","enable_reqheaders_recording","Promise","resolve","r","request","response","on","undefined","write","end","recorded","play","clear","Object","assign","headers","rawHeaders","scope","host","port","method","status","responseIsBinary","before","scopeIdx","filteringRequestBody","findIndex","m","requestBody","filteringPath","requestPath","after","req","interceptor","requestBodyString","responseBody","reduce","respBody","fn","splice","afterRecord","recordings","JSON","stringify","release","unsubscribeAll","smartWrite","keepOrder","Error","shutdown","unexpectedFiles","walkDir","filter","f","get","slice","unmatchedRecordings"],"mappings":"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","sourcesContent":["const assert = require('assert');\nconst http = require('http');\nconst https = require('http');\nconst path = require('path');\nconst fs = require('smart-fs');\nconst Joi = require('joi-strict');\nconst nock = require('nock');\nconst nockListener = require('./request-recorder/nock-listener');\nconst healSqsSendMessageBatch = require('./request-recorder/heal-sqs-send-message-batch');\nconst { buildKey, tryParseJson, convertHeaders } = require('./request-recorder/util');\nconst requestInjector = require('./request-recorder/request-injector');\n\nconst nockBack = nock.back;\nconst nockRecorder = nock.recorder;\n\nmodule.exports = (opts) => {\n  Joi.assert(opts, Joi.object().keys({\n    cassetteFolder: Joi.string(),\n    stripHeaders: Joi.boolean(),\n    strict: Joi.boolean(),\n    heal: Joi.alternatives(Joi.boolean(), Joi.string())\n  }), 'Invalid Options Provided');\n  let nockDone = null;\n  let cassetteFilePath = null;\n  const knownCassetteNames = [];\n  const records = [];\n  const outOfOrderErrors = [];\n  const expectedCassette = [];\n  const pendingMocks = [];\n\n  const anyFlagPresent = (flags) => {\n    assert(Array.isArray(flags) && flags.length !== 0);\n    if (typeof opts.heal !== 'string') {\n      return false;\n    }\n    const needleFlags = opts.heal.split(',');\n    return flags.some((flag) => needleFlags.includes(flag));\n  };\n\n  return ({\n    inject: async (cassetteFile) => {\n      assert(nockDone === null);\n      knownCassetteNames.push(cassetteFile);\n      records.length = 0;\n      outOfOrderErrors.length = 0;\n      expectedCassette.length = 0;\n      pendingMocks.length = 0;\n\n      cassetteFilePath = path.join(opts.cassetteFolder, cassetteFile);\n      const hasCassette = fs.existsSync(cassetteFilePath);\n      if (hasCassette) {\n        const cassetteContent = fs.smartRead(cassetteFilePath);\n        pendingMocks.push(...nock\n          .define(cassetteContent)\n          .map((e, idx) => ({\n            idx,\n            key: buildKey(e.interceptors[0]),\n            record: cassetteContent[idx]\n          })));\n      }\n\n      nockBack.setMode(hasCassette ? 'lockdown' : 'record');\n      nockBack.fixtures = opts.cassetteFolder;\n      nockListener.subscribe('no match', () => {\n        assert(hasCassette === true);\n        const { protocol, options, body } = requestInjector.getLast();\n        if (anyFlagPresent(['record'])) {\n          expectedCassette.push(async () => {\n            nockRecorder.rec({\n              output_objects: true,\n              dont_print: true,\n              enable_reqheaders_recording: false\n            });\n            await new Promise((resolve) => {\n              options.protocol = `${protocol}:`;\n              const r = { http, https }[protocol].request(options, (response) => {\n                response.on('data', () => {});\n                response.on('end', resolve);\n              });\n              if (body !== undefined) {\n                r.write(body);\n              }\n              r.end();\n            });\n            const recorded = nockRecorder.play();\n            nockRecorder.clear();\n            return recorded.map((record) => Object.assign(record, {\n              headers: opts.stripHeaders === true ? undefined : convertHeaders(record.rawHeaders),\n              rawHeaders: undefined\n            }));\n          });\n        } else if (anyFlagPresent(['stub'])) {\n          expectedCassette.push({\n            scope: `${protocol}://${options.host}:${options.port}`,\n            method: options.method,\n            path: options.path,\n            body: tryParseJson(body),\n            status: 200,\n            response: {},\n            responseIsBinary: false\n          });\n        }\n      });\n      nockDone = await new Promise((resolve) => nockBack(cassetteFile, {\n        before: (scope, scopeIdx) => {\n          records.push({ ...scope });\n          // eslint-disable-next-line no-param-reassign\n          scope.filteringRequestBody = (body) => {\n            if (anyFlagPresent(['magic', 'body'])) {\n              const idx = pendingMocks.findIndex((m) => m.idx === scopeIdx);\n              const requestBody = tryParseJson(body);\n              pendingMocks[idx].record.body = requestBody === null ? 'null' : requestBody;\n              return scope.body;\n            }\n            return body;\n          };\n          // eslint-disable-next-line no-param-reassign\n          scope.filteringPath = (requestPath) => {\n            if (anyFlagPresent(['magic', 'path'])) {\n              const idx = pendingMocks.findIndex((m) => m.idx === scopeIdx);\n              pendingMocks[idx].record.path = requestPath;\n              return scope.path;\n            }\n            return requestPath;\n          };\n          return scope;\n        },\n        after: (scope, scopeIdx) => {\n          scope.on('request', (req, interceptor, requestBodyString) => {\n            const idx = pendingMocks.findIndex((e) => e.idx === scopeIdx);\n\n            if (anyFlagPresent(['magic', 'response'])) {\n              const responseBody = tryParseJson([\n                healSqsSendMessageBatch\n              ].reduce(\n                (respBody, fn) => fn(requestBodyString, respBody, scope),\n                interceptor.body\n              ));\n              // eslint-disable-next-line no-param-reassign\n              interceptor.body = responseBody;\n              pendingMocks[idx].record.response = responseBody;\n            }\n\n            expectedCassette.push(pendingMocks[idx].record);\n            if (idx !== 0) {\n              outOfOrderErrors.push(pendingMocks[idx].key);\n            }\n            pendingMocks.splice(idx, 1);\n          });\n        },\n        afterRecord: (recordings) => JSON.stringify(recordings.map((r) => ({\n          ...r,\n          body: tryParseJson(r.body),\n          rawHeaders: opts.stripHeaders === true ? undefined : r.rawHeaders\n        })), null, 2)\n      }, resolve));\n      requestInjector.inject();\n    },\n    release: async () => {\n      assert(nockDone !== null);\n      requestInjector.release();\n      nockDone();\n      nockDone = null;\n      nockListener.unsubscribeAll('no match');\n\n      for (let idx = 0; idx < expectedCassette.length; idx += 1) {\n        if (typeof expectedCassette[idx] === 'function') {\n          // eslint-disable-next-line no-await-in-loop\n          expectedCassette.splice(idx, 1, ...await expectedCassette[idx]());\n          idx -= 1;\n        }\n      }\n\n      if (opts.heal !== false) {\n        fs.smartWrite(\n          cassetteFilePath,\n          anyFlagPresent(['magic', 'prune'])\n            ? expectedCassette\n            : [...expectedCassette, ...pendingMocks.map(({ record }) => record)],\n          { keepOrder: outOfOrderErrors.length === 0 && pendingMocks.length === 0 }\n        );\n      }\n      if (opts.strict !== false) {\n        if (outOfOrderErrors.length !== 0) {\n          throw new Error(`Out of Order Recordings: ${outOfOrderErrors.join(', ')}`);\n        }\n        if (pendingMocks.length !== 0) {\n          throw new Error(`Unmatched Recordings: ${pendingMocks.map((e) => e.key).join(', ')}`);\n        }\n      }\n    },\n    shutdown: () => {\n      const unexpectedFiles = fs.walkDir(opts.cassetteFolder).filter((f) => !knownCassetteNames.includes(f));\n      if (unexpectedFiles.length !== 0) {\n        throw new Error(`Unexpected file(s) in cassette folder: ${unexpectedFiles.join(', ')}`);\n      }\n    },\n    get: () => ({\n      records: records.slice(),\n      outOfOrderErrors: outOfOrderErrors.slice(),\n      unmatchedRecordings: pendingMocks.map((e) => e.key).slice(),\n      expectedCassette: expectedCassette.slice(),\n      cassetteFilePath\n    })\n  });\n};\n"]}

@@ -5,26 +5,72 @@ const assert = require('assert');

const https = require('https');
const common = require('nock/lib/common');
let requestOriginal = null;
let lastRequestOptions = null;
let lastProtocol = null;
let lastOptions = null;
let lastBody = null;
const requestWrapper = (...args) => {
lastRequestOptions = common.normalizeClientRequestArgs(...args).options;
return requestOriginal(...args);
const wrapper = proto => {
let requestOriginal = null;
const protocol = {
http,
https
}[proto];
const requestWrapper = (...args) => {
lastProtocol = proto;
lastOptions = common.normalizeClientRequestArgs(...args).options;
lastBody = lastOptions.body;
const result = requestOriginal.call(protocol, ...args);
if (lastBody === undefined) {
lastBody = [];
const writeOriginal = result.write;
result.write = (...chunks) => {
lastBody.push(chunks);
return writeOriginal.call(result, ...chunks);
};
}
return result;
};
return {
inject: () => {
assert(protocol.request !== requestWrapper, 'Inject Failure');
requestOriginal = protocol.request;
protocol.request = requestWrapper;
lastProtocol = null;
lastOptions = null;
lastBody = null;
},
release: () => {
assert(protocol.request === requestWrapper, 'Release Failure');
protocol.request = requestOriginal;
requestOriginal = null;
}
};
};
module.exports = {
inject: () => {
assert(http.request !== requestWrapper, 'Inject Failure');
requestOriginal = http.request;
http.request = requestWrapper;
},
release: () => {
assert(http.request === requestWrapper, 'Release Failure');
http.request = requestOriginal;
requestOriginal = null;
lastRequestOptions = null;
},
getLastOptions: () => lastRequestOptions
};
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9tb2R1bGVzL3JlcXVlc3QtcmVjb3JkZXIvcmVxdWVzdC1pbmplY3Rvci5qcyJdLCJuYW1lcyI6WyJhc3NlcnQiLCJyZXF1aXJlIiwiaHR0cCIsImNvbW1vbiIsInJlcXVlc3RPcmlnaW5hbCIsImxhc3RSZXF1ZXN0T3B0aW9ucyIsInJlcXVlc3RXcmFwcGVyIiwiYXJncyIsIm5vcm1hbGl6ZUNsaWVudFJlcXVlc3RBcmdzIiwib3B0aW9ucyIsIm1vZHVsZSIsImV4cG9ydHMiLCJpbmplY3QiLCJyZXF1ZXN0IiwicmVsZWFzZSIsImdldExhc3RPcHRpb25zIl0sIm1hcHBpbmdzIjoiQUFBQSxNQUFNQSxNQUFNLEdBQUdDLE9BQU8sQ0FBQyxRQUFELENBQXRCOztBQUNBLE1BQU1DLElBQUksR0FBR0QsT0FBTyxDQUFDLE1BQUQsQ0FBcEI7O0FBQ0EsTUFBTUUsTUFBTSxHQUFHRixPQUFPLENBQUMsaUJBQUQsQ0FBdEI7O0FBRUEsSUFBSUcsZUFBZSxHQUFHLElBQXRCO0FBQ0EsSUFBSUMsa0JBQWtCLEdBQUcsSUFBekI7O0FBRUEsTUFBTUMsY0FBYyxHQUFHLENBQUMsR0FBR0MsSUFBSixLQUFhO0FBQ2xDRixFQUFBQSxrQkFBa0IsR0FBR0YsTUFBTSxDQUFDSywwQkFBUCxDQUFrQyxHQUFHRCxJQUFyQyxFQUEyQ0UsT0FBaEU7QUFDQSxTQUFPTCxlQUFlLENBQUMsR0FBR0csSUFBSixDQUF0QjtBQUNELENBSEQ7O0FBS0FHLE1BQU0sQ0FBQ0MsT0FBUCxHQUFpQjtBQUNmQyxFQUFBQSxNQUFNLEVBQUUsTUFBTTtBQUNaWixJQUFBQSxNQUFNLENBQUNFLElBQUksQ0FBQ1csT0FBTCxLQUFpQlAsY0FBbEIsRUFBa0MsZ0JBQWxDLENBQU47QUFDQUYsSUFBQUEsZUFBZSxHQUFHRixJQUFJLENBQUNXLE9BQXZCO0FBQ0FYLElBQUFBLElBQUksQ0FBQ1csT0FBTCxHQUFlUCxjQUFmO0FBQ0QsR0FMYztBQU1mUSxFQUFBQSxPQUFPLEVBQUUsTUFBTTtBQUNiZCxJQUFBQSxNQUFNLENBQUNFLElBQUksQ0FBQ1csT0FBTCxLQUFpQlAsY0FBbEIsRUFBa0MsaUJBQWxDLENBQU47QUFDQUosSUFBQUEsSUFBSSxDQUFDVyxPQUFMLEdBQWVULGVBQWY7QUFDQUEsSUFBQUEsZUFBZSxHQUFHLElBQWxCO0FBQ0FDLElBQUFBLGtCQUFrQixHQUFHLElBQXJCO0FBQ0QsR0FYYztBQVlmVSxFQUFBQSxjQUFjLEVBQUUsTUFBTVY7QUFaUCxDQUFqQiIsInNvdXJjZXNDb250ZW50IjpbImNvbnN0IGFzc2VydCA9IHJlcXVpcmUoJ2Fzc2VydCcpO1xuY29uc3QgaHR0cCA9IHJlcXVpcmUoJ2h0dHAnKTtcbmNvbnN0IGNvbW1vbiA9IHJlcXVpcmUoJ25vY2svbGliL2NvbW1vbicpO1xuXG5sZXQgcmVxdWVzdE9yaWdpbmFsID0gbnVsbDtcbmxldCBsYXN0UmVxdWVzdE9wdGlvbnMgPSBudWxsO1xuXG5jb25zdCByZXF1ZXN0V3JhcHBlciA9ICguLi5hcmdzKSA9PiB7XG4gIGxhc3RSZXF1ZXN0T3B0aW9ucyA9IGNvbW1vbi5ub3JtYWxpemVDbGllbnRSZXF1ZXN0QXJncyguLi5hcmdzKS5vcHRpb25zO1xuICByZXR1cm4gcmVxdWVzdE9yaWdpbmFsKC4uLmFyZ3MpO1xufTtcblxubW9kdWxlLmV4cG9ydHMgPSB7XG4gIGluamVjdDogKCkgPT4ge1xuICAgIGFzc2VydChodHRwLnJlcXVlc3QgIT09IHJlcXVlc3RXcmFwcGVyLCAnSW5qZWN0IEZhaWx1cmUnKTtcbiAgICByZXF1ZXN0T3JpZ2luYWwgPSBodHRwLnJlcXVlc3Q7XG4gICAgaHR0cC5yZXF1ZXN0ID0gcmVxdWVzdFdyYXBwZXI7XG4gIH0sXG4gIHJlbGVhc2U6ICgpID0+IHtcbiAgICBhc3NlcnQoaHR0cC5yZXF1ZXN0ID09PSByZXF1ZXN0V3JhcHBlciwgJ1JlbGVhc2UgRmFpbHVyZScpO1xuICAgIGh0dHAucmVxdWVzdCA9IHJlcXVlc3RPcmlnaW5hbDtcbiAgICByZXF1ZXN0T3JpZ2luYWwgPSBudWxsO1xuICAgIGxhc3RSZXF1ZXN0T3B0aW9ucyA9IG51bGw7XG4gIH0sXG4gIGdldExhc3RPcHRpb25zOiAoKSA9PiBsYXN0UmVxdWVzdE9wdGlvbnNcbn07XG4iXX0=
module.exports = (() => {
const httpWrapper = wrapper('http');
const httpsWrapper = wrapper('https');
return {
inject: () => {
httpWrapper.inject();
httpsWrapper.inject();
},
release: () => {
httpWrapper.release();
httpsWrapper.release();
},
getLast: () => ({
protocol: lastProtocol,
options: lastOptions,
body: lastBody
})
};
})();
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9tb2R1bGVzL3JlcXVlc3QtcmVjb3JkZXIvcmVxdWVzdC1pbmplY3Rvci5qcyJdLCJuYW1lcyI6WyJhc3NlcnQiLCJyZXF1aXJlIiwiaHR0cCIsImh0dHBzIiwiY29tbW9uIiwibGFzdFByb3RvY29sIiwibGFzdE9wdGlvbnMiLCJsYXN0Qm9keSIsIndyYXBwZXIiLCJwcm90byIsInJlcXVlc3RPcmlnaW5hbCIsInByb3RvY29sIiwicmVxdWVzdFdyYXBwZXIiLCJhcmdzIiwibm9ybWFsaXplQ2xpZW50UmVxdWVzdEFyZ3MiLCJvcHRpb25zIiwiYm9keSIsInJlc3VsdCIsImNhbGwiLCJ1bmRlZmluZWQiLCJ3cml0ZU9yaWdpbmFsIiwid3JpdGUiLCJjaHVua3MiLCJwdXNoIiwiaW5qZWN0IiwicmVxdWVzdCIsInJlbGVhc2UiLCJtb2R1bGUiLCJleHBvcnRzIiwiaHR0cFdyYXBwZXIiLCJodHRwc1dyYXBwZXIiLCJnZXRMYXN0Il0sIm1hcHBpbmdzIjoiQUFBQSxNQUFNQSxNQUFNLEdBQUdDLE9BQU8sQ0FBQyxRQUFELENBQXRCOztBQUNBLE1BQU1DLElBQUksR0FBR0QsT0FBTyxDQUFDLE1BQUQsQ0FBcEI7O0FBQ0EsTUFBTUUsS0FBSyxHQUFHRixPQUFPLENBQUMsT0FBRCxDQUFyQjs7QUFDQSxNQUFNRyxNQUFNLEdBQUdILE9BQU8sQ0FBQyxpQkFBRCxDQUF0Qjs7QUFFQSxJQUFJSSxZQUFZLEdBQUcsSUFBbkI7QUFDQSxJQUFJQyxXQUFXLEdBQUcsSUFBbEI7QUFDQSxJQUFJQyxRQUFRLEdBQUcsSUFBZjs7QUFFQSxNQUFNQyxPQUFPLEdBQUlDLEtBQUQsSUFBVztBQUN6QixNQUFJQyxlQUFlLEdBQUcsSUFBdEI7QUFDQSxRQUFNQyxRQUFRLEdBQUc7QUFBRVQsSUFBQUEsSUFBRjtBQUFRQyxJQUFBQTtBQUFSLElBQWdCTSxLQUFoQixDQUFqQjs7QUFFQSxRQUFNRyxjQUFjLEdBQUcsQ0FBQyxHQUFHQyxJQUFKLEtBQWE7QUFDbENSLElBQUFBLFlBQVksR0FBR0ksS0FBZjtBQUNBSCxJQUFBQSxXQUFXLEdBQUdGLE1BQU0sQ0FBQ1UsMEJBQVAsQ0FBa0MsR0FBR0QsSUFBckMsRUFBMkNFLE9BQXpEO0FBQ0FSLElBQUFBLFFBQVEsR0FBR0QsV0FBVyxDQUFDVSxJQUF2QjtBQUNBLFVBQU1DLE1BQU0sR0FBR1AsZUFBZSxDQUFDUSxJQUFoQixDQUFxQlAsUUFBckIsRUFBK0IsR0FBR0UsSUFBbEMsQ0FBZjs7QUFDQSxRQUFJTixRQUFRLEtBQUtZLFNBQWpCLEVBQTRCO0FBQzFCWixNQUFBQSxRQUFRLEdBQUcsRUFBWDtBQUNBLFlBQU1hLGFBQWEsR0FBR0gsTUFBTSxDQUFDSSxLQUE3Qjs7QUFDQUosTUFBQUEsTUFBTSxDQUFDSSxLQUFQLEdBQWUsQ0FBQyxHQUFHQyxNQUFKLEtBQWU7QUFDNUJmLFFBQUFBLFFBQVEsQ0FBQ2dCLElBQVQsQ0FBY0QsTUFBZDtBQUNBLGVBQU9GLGFBQWEsQ0FBQ0YsSUFBZCxDQUFtQkQsTUFBbkIsRUFBMkIsR0FBR0ssTUFBOUIsQ0FBUDtBQUNELE9BSEQ7QUFJRDs7QUFDRCxXQUFPTCxNQUFQO0FBQ0QsR0FkRDs7QUFnQkEsU0FBTztBQUNMTyxJQUFBQSxNQUFNLEVBQUUsTUFBTTtBQUNaeEIsTUFBQUEsTUFBTSxDQUFDVyxRQUFRLENBQUNjLE9BQVQsS0FBcUJiLGNBQXRCLEVBQXNDLGdCQUF0QyxDQUFOO0FBQ0FGLE1BQUFBLGVBQWUsR0FBR0MsUUFBUSxDQUFDYyxPQUEzQjtBQUNBZCxNQUFBQSxRQUFRLENBQUNjLE9BQVQsR0FBbUJiLGNBQW5CO0FBQ0FQLE1BQUFBLFlBQVksR0FBRyxJQUFmO0FBQ0FDLE1BQUFBLFdBQVcsR0FBRyxJQUFkO0FBQ0FDLE1BQUFBLFFBQVEsR0FBRyxJQUFYO0FBQ0QsS0FSSTtBQVNMbUIsSUFBQUEsT0FBTyxFQUFFLE1BQU07QUFDYjFCLE1BQUFBLE1BQU0sQ0FBQ1csUUFBUSxDQUFDYyxPQUFULEtBQXFCYixjQUF0QixFQUFzQyxpQkFBdEMsQ0FBTjtBQUNBRCxNQUFBQSxRQUFRLENBQUNjLE9BQVQsR0FBbUJmLGVBQW5CO0FBQ0FBLE1BQUFBLGVBQWUsR0FBRyxJQUFsQjtBQUNEO0FBYkksR0FBUDtBQWVELENBbkNEOztBQXFDQWlCLE1BQU0sQ0FBQ0MsT0FBUCxHQUFpQixDQUFDLE1BQU07QUFDdEIsUUFBTUMsV0FBVyxHQUFHckIsT0FBTyxDQUFDLE1BQUQsQ0FBM0I7QUFDQSxRQUFNc0IsWUFBWSxHQUFHdEIsT0FBTyxDQUFDLE9BQUQsQ0FBNUI7QUFDQSxTQUFPO0FBQ0xnQixJQUFBQSxNQUFNLEVBQUUsTUFBTTtBQUNaSyxNQUFBQSxXQUFXLENBQUNMLE1BQVo7QUFDQU0sTUFBQUEsWUFBWSxDQUFDTixNQUFiO0FBQ0QsS0FKSTtBQUtMRSxJQUFBQSxPQUFPLEVBQUUsTUFBTTtBQUNiRyxNQUFBQSxXQUFXLENBQUNILE9BQVo7QUFDQUksTUFBQUEsWUFBWSxDQUFDSixPQUFiO0FBQ0QsS0FSSTtBQVNMSyxJQUFBQSxPQUFPLEVBQUUsT0FBTztBQUNkcEIsTUFBQUEsUUFBUSxFQUFFTixZQURJO0FBRWRVLE1BQUFBLE9BQU8sRUFBRVQsV0FGSztBQUdkVSxNQUFBQSxJQUFJLEVBQUVUO0FBSFEsS0FBUDtBQVRKLEdBQVA7QUFlRCxDQWxCZ0IsR0FBakIiLCJzb3VyY2VzQ29udGVudCI6WyJjb25zdCBhc3NlcnQgPSByZXF1aXJlKCdhc3NlcnQnKTtcbmNvbnN0IGh0dHAgPSByZXF1aXJlKCdodHRwJyk7XG5jb25zdCBodHRwcyA9IHJlcXVpcmUoJ2h0dHBzJyk7XG5jb25zdCBjb21tb24gPSByZXF1aXJlKCdub2NrL2xpYi9jb21tb24nKTtcblxubGV0IGxhc3RQcm90b2NvbCA9IG51bGw7XG5sZXQgbGFzdE9wdGlvbnMgPSBudWxsO1xubGV0IGxhc3RCb2R5ID0gbnVsbDtcblxuY29uc3Qgd3JhcHBlciA9IChwcm90bykgPT4ge1xuICBsZXQgcmVxdWVzdE9yaWdpbmFsID0gbnVsbDtcbiAgY29uc3QgcHJvdG9jb2wgPSB7IGh0dHAsIGh0dHBzIH1bcHJvdG9dO1xuXG4gIGNvbnN0IHJlcXVlc3RXcmFwcGVyID0gKC4uLmFyZ3MpID0+IHtcbiAgICBsYXN0UHJvdG9jb2wgPSBwcm90bztcbiAgICBsYXN0T3B0aW9ucyA9IGNvbW1vbi5ub3JtYWxpemVDbGllbnRSZXF1ZXN0QXJncyguLi5hcmdzKS5vcHRpb25zO1xuICAgIGxhc3RCb2R5ID0gbGFzdE9wdGlvbnMuYm9keTtcbiAgICBjb25zdCByZXN1bHQgPSByZXF1ZXN0T3JpZ2luYWwuY2FsbChwcm90b2NvbCwgLi4uYXJncyk7XG4gICAgaWYgKGxhc3RCb2R5ID09PSB1bmRlZmluZWQpIHtcbiAgICAgIGxhc3RCb2R5ID0gW107XG4gICAgICBjb25zdCB3cml0ZU9yaWdpbmFsID0gcmVzdWx0LndyaXRlO1xuICAgICAgcmVzdWx0LndyaXRlID0gKC4uLmNodW5rcykgPT4ge1xuICAgICAgICBsYXN0Qm9keS5wdXNoKGNodW5rcyk7XG4gICAgICAgIHJldHVybiB3cml0ZU9yaWdpbmFsLmNhbGwocmVzdWx0LCAuLi5jaHVua3MpO1xuICAgICAgfTtcbiAgICB9XG4gICAgcmV0dXJuIHJlc3VsdDtcbiAgfTtcblxuICByZXR1cm4ge1xuICAgIGluamVjdDogKCkgPT4ge1xuICAgICAgYXNzZXJ0KHByb3RvY29sLnJlcXVlc3QgIT09IHJlcXVlc3RXcmFwcGVyLCAnSW5qZWN0IEZhaWx1cmUnKTtcbiAgICAgIHJlcXVlc3RPcmlnaW5hbCA9IHByb3RvY29sLnJlcXVlc3Q7XG4gICAgICBwcm90b2NvbC5yZXF1ZXN0ID0gcmVxdWVzdFdyYXBwZXI7XG4gICAgICBsYXN0UHJvdG9jb2wgPSBudWxsO1xuICAgICAgbGFzdE9wdGlvbnMgPSBudWxsO1xuICAgICAgbGFzdEJvZHkgPSBudWxsO1xuICAgIH0sXG4gICAgcmVsZWFzZTogKCkgPT4ge1xuICAgICAgYXNzZXJ0KHByb3RvY29sLnJlcXVlc3QgPT09IHJlcXVlc3RXcmFwcGVyLCAnUmVsZWFzZSBGYWlsdXJlJyk7XG4gICAgICBwcm90b2NvbC5yZXF1ZXN0ID0gcmVxdWVzdE9yaWdpbmFsO1xuICAgICAgcmVxdWVzdE9yaWdpbmFsID0gbnVsbDtcbiAgICB9XG4gIH07XG59O1xuXG5tb2R1bGUuZXhwb3J0cyA9ICgoKSA9PiB7XG4gIGNvbnN0IGh0dHBXcmFwcGVyID0gd3JhcHBlcignaHR0cCcpO1xuICBjb25zdCBodHRwc1dyYXBwZXIgPSB3cmFwcGVyKCdodHRwcycpO1xuICByZXR1cm4ge1xuICAgIGluamVjdDogKCkgPT4ge1xuICAgICAgaHR0cFdyYXBwZXIuaW5qZWN0KCk7XG4gICAgICBodHRwc1dyYXBwZXIuaW5qZWN0KCk7XG4gICAgfSxcbiAgICByZWxlYXNlOiAoKSA9PiB7XG4gICAgICBodHRwV3JhcHBlci5yZWxlYXNlKCk7XG4gICAgICBodHRwc1dyYXBwZXIucmVsZWFzZSgpO1xuICAgIH0sXG4gICAgZ2V0TGFzdDogKCkgPT4gKHtcbiAgICAgIHByb3RvY29sOiBsYXN0UHJvdG9jb2wsXG4gICAgICBvcHRpb25zOiBsYXN0T3B0aW9ucyxcbiAgICAgIGJvZHk6IGxhc3RCb2R5XG4gICAgfSlcbiAgfTtcbn0pKCk7XG4iXX0=
{
"name": "node-tdd",
"version": "2.14.0",
"version": "2.15.0",
"description": "Drop in extension for mocha to abstract commonly used test setups",

@@ -49,3 +49,3 @@ "main": "lib/index.js",

"@blackflux/robo-config-plugin": "3.4.13",
"aws-sdk": "2.703.0",
"aws-sdk": "2.704.0",
"aws-sdk-wrap": "4.4.8",

@@ -52,0 +52,0 @@ "babel-eslint": "10.1.0",

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc