Add node modules and compiled JavaScript from main (#57)
Co-authored-by: Oliver King <oking3@uncc.edu>
This commit is contained in:
parent
d893f27da9
commit
7f7e5ba5ea
6750 changed files with 1745644 additions and 10860 deletions
12
node_modules/jest-leak-detector/build/index.d.ts
generated
vendored
Normal file
12
node_modules/jest-leak-detector/build/index.d.ts
generated
vendored
Normal file
|
@ -0,0 +1,12 @@
|
|||
/**
|
||||
* Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved.
|
||||
*
|
||||
* This source code is licensed under the MIT license found in the
|
||||
* LICENSE file in the root directory of this source tree.
|
||||
*/
|
||||
export default class {
|
||||
private _isReferenceBeingHeld;
|
||||
constructor(value: unknown);
|
||||
isLeaking(): Promise<boolean>;
|
||||
private _runGarbageCollector;
|
||||
}
|
139
node_modules/jest-leak-detector/build/index.js
generated
vendored
Normal file
139
node_modules/jest-leak-detector/build/index.js
generated
vendored
Normal file
|
@ -0,0 +1,139 @@
|
|||
'use strict';
|
||||
|
||||
Object.defineProperty(exports, '__esModule', {
|
||||
value: true
|
||||
});
|
||||
exports.default = void 0;
|
||||
|
||||
function _v() {
|
||||
const data = require('v8');
|
||||
|
||||
_v = function () {
|
||||
return data;
|
||||
};
|
||||
|
||||
return data;
|
||||
}
|
||||
|
||||
function _vm() {
|
||||
const data = require('vm');
|
||||
|
||||
_vm = function () {
|
||||
return data;
|
||||
};
|
||||
|
||||
return data;
|
||||
}
|
||||
|
||||
function _util() {
|
||||
const data = require('util');
|
||||
|
||||
_util = function () {
|
||||
return data;
|
||||
};
|
||||
|
||||
return data;
|
||||
}
|
||||
|
||||
function _prettyFormat() {
|
||||
const data = _interopRequireDefault(require('pretty-format'));
|
||||
|
||||
_prettyFormat = function () {
|
||||
return data;
|
||||
};
|
||||
|
||||
return data;
|
||||
}
|
||||
|
||||
function _jestGetType() {
|
||||
const data = require('jest-get-type');
|
||||
|
||||
_jestGetType = function () {
|
||||
return data;
|
||||
};
|
||||
|
||||
return data;
|
||||
}
|
||||
|
||||
function _interopRequireDefault(obj) {
|
||||
return obj && obj.__esModule ? obj : {default: obj};
|
||||
}
|
||||
|
||||
function _defineProperty(obj, key, value) {
|
||||
if (key in obj) {
|
||||
Object.defineProperty(obj, key, {
|
||||
value: value,
|
||||
enumerable: true,
|
||||
configurable: true,
|
||||
writable: true
|
||||
});
|
||||
} else {
|
||||
obj[key] = value;
|
||||
}
|
||||
return obj;
|
||||
}
|
||||
|
||||
const tick = (0, _util().promisify)(setImmediate);
|
||||
|
||||
class _default {
|
||||
constructor(value) {
|
||||
_defineProperty(this, '_isReferenceBeingHeld', void 0);
|
||||
|
||||
if ((0, _jestGetType().isPrimitive)(value)) {
|
||||
throw new TypeError(
|
||||
[
|
||||
'Primitives cannot leak memory.',
|
||||
'You passed a ' +
|
||||
typeof value +
|
||||
': <' +
|
||||
(0, _prettyFormat().default)(value) +
|
||||
'>'
|
||||
].join(' ')
|
||||
);
|
||||
}
|
||||
|
||||
let weak;
|
||||
|
||||
try {
|
||||
// eslint-disable-next-line import/no-extraneous-dependencies
|
||||
weak = require('weak-napi');
|
||||
} catch (err) {
|
||||
if (!err || err.code !== 'MODULE_NOT_FOUND') {
|
||||
throw err;
|
||||
}
|
||||
|
||||
throw new Error(
|
||||
'The leaking detection mechanism requires the "weak-napi" package to be installed and work. ' +
|
||||
'Please install it as a dependency on your main project'
|
||||
);
|
||||
}
|
||||
|
||||
weak(value, () => (this._isReferenceBeingHeld = false));
|
||||
this._isReferenceBeingHeld = true; // Ensure value is not leaked by the closure created by the "weak" callback.
|
||||
|
||||
value = null;
|
||||
}
|
||||
|
||||
async isLeaking() {
|
||||
this._runGarbageCollector(); // wait some ticks to allow GC to run properly, see https://github.com/nodejs/node/issues/34636#issuecomment-669366235
|
||||
|
||||
for (let i = 0; i < 10; i++) {
|
||||
await tick();
|
||||
}
|
||||
|
||||
return this._isReferenceBeingHeld;
|
||||
}
|
||||
|
||||
_runGarbageCollector() {
|
||||
const isGarbageCollectorHidden = !global.gc; // GC is usually hidden, so we have to expose it before running.
|
||||
|
||||
(0, _v().setFlagsFromString)('--expose-gc');
|
||||
(0, _vm().runInNewContext)('gc')(); // The GC was not initially exposed, so let's hide it again.
|
||||
|
||||
if (isGarbageCollectorHidden) {
|
||||
(0, _v().setFlagsFromString)('--no-expose-gc');
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
exports.default = _default;
|
Loading…
Add table
Add a link
Reference in a new issue