aboutsummaryrefslogtreecommitdiff
path: root/node_modules/@jest/transform/build
diff options
context:
space:
mode:
authorJoel Kronqvist <work.joelkronqvist@pm.me>2022-03-11 20:46:06 +0200
committerJoel Kronqvist <work.joelkronqvist@pm.me>2022-03-11 20:46:06 +0200
commit080c5819d87b933816d724a83f3bf4f1686770a7 (patch)
tree4a2ccc68b27edf7d4cbc586c932cc7542b655e19 /node_modules/@jest/transform/build
parent5ac7049a9d30733165cc212dee308163c2a14644 (diff)
parentd003b82235a9329f912522a2f70aa950dfce4998 (diff)
downloadLYLLRuoka-080c5819d87b933816d724a83f3bf4f1686770a7.tar.gz
LYLLRuoka-080c5819d87b933816d724a83f3bf4f1686770a7.zip
Merge branch 'master' of https://github.com/JoelHMikael/FoodJS
Updating remote changes
Diffstat (limited to 'node_modules/@jest/transform/build')
-rw-r--r--node_modules/@jest/transform/build/ScriptTransformer.d.ts40
-rw-r--r--node_modules/@jest/transform/build/ScriptTransformer.js1115
-rw-r--r--node_modules/@jest/transform/build/enhanceUnexpectedTokenMessage.d.ts12
-rw-r--r--node_modules/@jest/transform/build/enhanceUnexpectedTokenMessage.js83
-rw-r--r--node_modules/@jest/transform/build/index.d.ts11
-rw-r--r--node_modules/@jest/transform/build/index.js41
-rw-r--r--node_modules/@jest/transform/build/runtimeErrorsAndWarnings.d.ts10
-rw-r--r--node_modules/@jest/transform/build/runtimeErrorsAndWarnings.js101
-rw-r--r--node_modules/@jest/transform/build/shouldInstrument.d.ts9
-rw-r--r--node_modules/@jest/transform/build/shouldInstrument.js207
-rw-r--r--node_modules/@jest/transform/build/types.d.ts75
-rw-r--r--node_modules/@jest/transform/build/types.js1
12 files changed, 1705 insertions, 0 deletions
diff --git a/node_modules/@jest/transform/build/ScriptTransformer.d.ts b/node_modules/@jest/transform/build/ScriptTransformer.d.ts
new file mode 100644
index 0000000..a36c7c7
--- /dev/null
+++ b/node_modules/@jest/transform/build/ScriptTransformer.d.ts
@@ -0,0 +1,40 @@
+/**
+ * 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.
+ */
+import type { Config } from '@jest/types';
+import type { Options, ReducedTransformOptions, RequireAndTranspileModuleOptions, StringMap, TransformResult } from './types';
+declare class ScriptTransformer {
+ private readonly _config;
+ private readonly _cacheFS;
+ private readonly _cache;
+ private readonly _transformCache;
+ private _transformsAreLoaded;
+ constructor(_config: Config.ProjectConfig, _cacheFS: StringMap);
+ private _buildCacheKeyFromFileInfo;
+ private _getCacheKey;
+ private _getCacheKeyAsync;
+ private _createFolderFromCacheKey;
+ private _getFileCachePath;
+ private _getFileCachePathAsync;
+ private _getTransformPath;
+ loadTransformers(): Promise<void>;
+ private _getTransformer;
+ private _instrumentFile;
+ private _buildTransformResult;
+ transformSource(filepath: Config.Path, content: string, options: ReducedTransformOptions): TransformResult;
+ transformSourceAsync(filepath: Config.Path, content: string, options: ReducedTransformOptions): Promise<TransformResult>;
+ private _transformAndBuildScriptAsync;
+ private _transformAndBuildScript;
+ transformAsync(filename: Config.Path, options: Options, fileSource?: string): Promise<TransformResult>;
+ transform(filename: Config.Path, options: Options, fileSource?: string): TransformResult;
+ transformJson(filename: Config.Path, options: Options, fileSource: string): string;
+ requireAndTranspileModule<ModuleType = unknown>(moduleName: string, callback?: (module: ModuleType) => void | Promise<void>, options?: RequireAndTranspileModuleOptions): Promise<ModuleType>;
+ shouldTransform(filename: Config.Path): boolean;
+}
+export declare function createTranspilingRequire(config: Config.ProjectConfig): Promise<(<TModuleType = unknown>(resolverPath: string, applyInteropRequireDefault?: boolean) => Promise<TModuleType>)>;
+export declare type TransformerType = ScriptTransformer;
+export declare function createScriptTransformer(config: Config.ProjectConfig, cacheFS?: StringMap): Promise<TransformerType>;
+export {};
diff --git a/node_modules/@jest/transform/build/ScriptTransformer.js b/node_modules/@jest/transform/build/ScriptTransformer.js
new file mode 100644
index 0000000..edc7f2c
--- /dev/null
+++ b/node_modules/@jest/transform/build/ScriptTransformer.js
@@ -0,0 +1,1115 @@
+'use strict';
+
+Object.defineProperty(exports, '__esModule', {
+ value: true
+});
+exports.createScriptTransformer = createScriptTransformer;
+exports.createTranspilingRequire = createTranspilingRequire;
+
+function _crypto() {
+ const data = require('crypto');
+
+ _crypto = function () {
+ return data;
+ };
+
+ return data;
+}
+
+function path() {
+ const data = _interopRequireWildcard(require('path'));
+
+ path = function () {
+ return data;
+ };
+
+ return data;
+}
+
+function _core() {
+ const data = require('@babel/core');
+
+ _core = function () {
+ return data;
+ };
+
+ return data;
+}
+
+function _babelPluginIstanbul() {
+ const data = _interopRequireDefault(require('babel-plugin-istanbul'));
+
+ _babelPluginIstanbul = function () {
+ return data;
+ };
+
+ return data;
+}
+
+function _convertSourceMap() {
+ const data = require('convert-source-map');
+
+ _convertSourceMap = function () {
+ return data;
+ };
+
+ return data;
+}
+
+function _fastJsonStableStringify() {
+ const data = _interopRequireDefault(require('fast-json-stable-stringify'));
+
+ _fastJsonStableStringify = function () {
+ return data;
+ };
+
+ return data;
+}
+
+function fs() {
+ const data = _interopRequireWildcard(require('graceful-fs'));
+
+ fs = function () {
+ return data;
+ };
+
+ return data;
+}
+
+function _pirates() {
+ const data = require('pirates');
+
+ _pirates = function () {
+ return data;
+ };
+
+ return data;
+}
+
+function _slash() {
+ const data = _interopRequireDefault(require('slash'));
+
+ _slash = function () {
+ return data;
+ };
+
+ return data;
+}
+
+function _writeFileAtomic() {
+ const data = require('write-file-atomic');
+
+ _writeFileAtomic = function () {
+ return data;
+ };
+
+ return data;
+}
+
+function _jestHasteMap() {
+ const data = _interopRequireDefault(require('jest-haste-map'));
+
+ _jestHasteMap = function () {
+ return data;
+ };
+
+ return data;
+}
+
+function _jestUtil() {
+ const data = require('jest-util');
+
+ _jestUtil = function () {
+ return data;
+ };
+
+ return data;
+}
+
+var _enhanceUnexpectedTokenMessage = _interopRequireDefault(
+ require('./enhanceUnexpectedTokenMessage')
+);
+
+var _runtimeErrorsAndWarnings = require('./runtimeErrorsAndWarnings');
+
+var _shouldInstrument = _interopRequireDefault(require('./shouldInstrument'));
+
+function _interopRequireDefault(obj) {
+ return obj && obj.__esModule ? obj : {default: obj};
+}
+
+function _getRequireWildcardCache(nodeInterop) {
+ if (typeof WeakMap !== 'function') return null;
+ var cacheBabelInterop = new WeakMap();
+ var cacheNodeInterop = new WeakMap();
+ return (_getRequireWildcardCache = function (nodeInterop) {
+ return nodeInterop ? cacheNodeInterop : cacheBabelInterop;
+ })(nodeInterop);
+}
+
+function _interopRequireWildcard(obj, nodeInterop) {
+ if (!nodeInterop && obj && obj.__esModule) {
+ return obj;
+ }
+ if (obj === null || (typeof obj !== 'object' && typeof obj !== 'function')) {
+ return {default: obj};
+ }
+ var cache = _getRequireWildcardCache(nodeInterop);
+ if (cache && cache.has(obj)) {
+ return cache.get(obj);
+ }
+ var newObj = {};
+ var hasPropertyDescriptor =
+ Object.defineProperty && Object.getOwnPropertyDescriptor;
+ for (var key in obj) {
+ if (key !== 'default' && Object.prototype.hasOwnProperty.call(obj, key)) {
+ var desc = hasPropertyDescriptor
+ ? Object.getOwnPropertyDescriptor(obj, key)
+ : null;
+ if (desc && (desc.get || desc.set)) {
+ Object.defineProperty(newObj, key, desc);
+ } else {
+ newObj[key] = obj[key];
+ }
+ }
+ }
+ newObj.default = obj;
+ if (cache) {
+ cache.set(obj, newObj);
+ }
+ return newObj;
+}
+
+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;
+}
+
+// Use `require` to avoid TS rootDir
+const {version: VERSION} = require('../package.json');
+
+// This data structure is used to avoid recalculating some data every time that
+// we need to transform a file. Since ScriptTransformer is instantiated for each
+// file we need to keep this object in the local scope of this module.
+const projectCaches = new Map(); // To reset the cache for specific changesets (rather than package version).
+
+const CACHE_VERSION = '1';
+
+async function waitForPromiseWithCleanup(promise, cleanup) {
+ try {
+ await promise;
+ } finally {
+ cleanup();
+ }
+}
+
+class ScriptTransformer {
+ constructor(_config, _cacheFS) {
+ _defineProperty(this, '_cache', void 0);
+
+ _defineProperty(this, '_transformCache', new Map());
+
+ _defineProperty(this, '_transformsAreLoaded', false);
+
+ this._config = _config;
+ this._cacheFS = _cacheFS;
+ const configString = (0, _fastJsonStableStringify().default)(this._config);
+ let projectCache = projectCaches.get(configString);
+
+ if (!projectCache) {
+ projectCache = {
+ configString,
+ ignorePatternsRegExp: calcIgnorePatternRegExp(this._config),
+ transformRegExp: calcTransformRegExp(this._config),
+ transformedFiles: new Map()
+ };
+ projectCaches.set(configString, projectCache);
+ }
+
+ this._cache = projectCache;
+ }
+
+ _buildCacheKeyFromFileInfo(
+ fileData,
+ filename,
+ transformOptions,
+ transformerCacheKey
+ ) {
+ if (transformerCacheKey) {
+ return (0, _crypto().createHash)('md5')
+ .update(transformerCacheKey)
+ .update(CACHE_VERSION)
+ .digest('hex');
+ }
+
+ return (0, _crypto().createHash)('md5')
+ .update(fileData)
+ .update(transformOptions.configString)
+ .update(transformOptions.instrument ? 'instrument' : '')
+ .update(filename)
+ .update(CACHE_VERSION)
+ .digest('hex');
+ }
+
+ _getCacheKey(fileData, filename, options) {
+ const configString = this._cache.configString;
+ const {transformer, transformerConfig = {}} =
+ this._getTransformer(filename) || {};
+ let transformerCacheKey = undefined;
+ const transformOptions = {
+ ...options,
+ cacheFS: this._cacheFS,
+ config: this._config,
+ configString,
+ transformerConfig
+ };
+
+ if (
+ typeof (transformer === null || transformer === void 0
+ ? void 0
+ : transformer.getCacheKey) === 'function'
+ ) {
+ transformerCacheKey = transformer.getCacheKey(
+ fileData,
+ filename,
+ transformOptions
+ );
+ }
+
+ return this._buildCacheKeyFromFileInfo(
+ fileData,
+ filename,
+ transformOptions,
+ transformerCacheKey
+ );
+ }
+
+ async _getCacheKeyAsync(fileData, filename, options) {
+ const configString = this._cache.configString;
+ const {transformer, transformerConfig = {}} =
+ this._getTransformer(filename) || {};
+ let transformerCacheKey = undefined;
+ const transformOptions = {
+ ...options,
+ cacheFS: this._cacheFS,
+ config: this._config,
+ configString,
+ transformerConfig
+ };
+
+ if (transformer) {
+ const getCacheKey =
+ transformer.getCacheKeyAsync || transformer.getCacheKey;
+
+ if (typeof getCacheKey === 'function') {
+ transformerCacheKey = await getCacheKey(
+ fileData,
+ filename,
+ transformOptions
+ );
+ }
+ }
+
+ return this._buildCacheKeyFromFileInfo(
+ fileData,
+ filename,
+ transformOptions,
+ transformerCacheKey
+ );
+ }
+
+ _createFolderFromCacheKey(filename, cacheKey) {
+ const HasteMapClass = _jestHasteMap().default.getStatic(this._config);
+
+ const baseCacheDir = HasteMapClass.getCacheFilePath(
+ this._config.cacheDirectory,
+ 'jest-transform-cache-' + this._config.name,
+ VERSION
+ ); // Create sub folders based on the cacheKey to avoid creating one
+ // directory with many files.
+
+ const cacheDir = path().join(baseCacheDir, cacheKey[0] + cacheKey[1]);
+ const cacheFilenamePrefix = path()
+ .basename(filename, path().extname(filename))
+ .replace(/\W/g, '');
+ const cachePath = (0, _slash().default)(
+ path().join(cacheDir, cacheFilenamePrefix + '_' + cacheKey)
+ );
+ (0, _jestUtil().createDirectory)(cacheDir);
+ return cachePath;
+ }
+
+ _getFileCachePath(filename, content, options) {
+ const cacheKey = this._getCacheKey(content, filename, options);
+
+ return this._createFolderFromCacheKey(filename, cacheKey);
+ }
+
+ async _getFileCachePathAsync(filename, content, options) {
+ const cacheKey = await this._getCacheKeyAsync(content, filename, options);
+ return this._createFolderFromCacheKey(filename, cacheKey);
+ }
+
+ _getTransformPath(filename) {
+ const transformRegExp = this._cache.transformRegExp;
+
+ if (!transformRegExp) {
+ return undefined;
+ }
+
+ for (let i = 0; i < transformRegExp.length; i++) {
+ if (transformRegExp[i][0].test(filename)) {
+ return transformRegExp[i][1];
+ }
+ }
+
+ return undefined;
+ }
+
+ async loadTransformers() {
+ await Promise.all(
+ this._config.transform.map(
+ async ([, transformPath, transformerConfig]) => {
+ let transformer = await (0, _jestUtil().requireOrImportModule)(
+ transformPath
+ );
+
+ if (!transformer) {
+ throw new Error(
+ (0, _runtimeErrorsAndWarnings.makeInvalidTransformerError)(
+ transformPath
+ )
+ );
+ }
+
+ if (typeof transformer.createTransformer === 'function') {
+ transformer = transformer.createTransformer(transformerConfig);
+ }
+
+ if (
+ typeof transformer.process !== 'function' &&
+ typeof transformer.processAsync !== 'function'
+ ) {
+ throw new Error(
+ (0, _runtimeErrorsAndWarnings.makeInvalidTransformerError)(
+ transformPath
+ )
+ );
+ }
+
+ const res = {
+ transformer,
+ transformerConfig
+ };
+
+ this._transformCache.set(transformPath, res);
+ }
+ )
+ );
+ this._transformsAreLoaded = true;
+ }
+
+ _getTransformer(filename) {
+ if (!this._transformsAreLoaded) {
+ throw new Error(
+ 'Jest: Transformers have not been loaded yet - make sure to run `loadTransformers` and wait for it to complete before starting to transform files'
+ );
+ }
+
+ if (this._config.transform.length === 0) {
+ return null;
+ }
+
+ const transformPath = this._getTransformPath(filename);
+
+ if (!transformPath) {
+ return null;
+ }
+
+ const cached = this._transformCache.get(transformPath);
+
+ if (cached) {
+ return cached;
+ }
+
+ throw new Error(
+ `Jest was unable to load the transformer defined for ${filename}. This is a bug in Jest, please open up an issue`
+ );
+ }
+
+ _instrumentFile(filename, input, canMapToInput, options) {
+ const inputCode = typeof input === 'string' ? input : input.code;
+ const inputMap = typeof input === 'string' ? null : input.map;
+ const result = (0, _core().transformSync)(inputCode, {
+ auxiliaryCommentBefore: ' istanbul ignore next ',
+ babelrc: false,
+ caller: {
+ name: '@jest/transform',
+ supportsDynamicImport: options.supportsDynamicImport,
+ supportsExportNamespaceFrom: options.supportsExportNamespaceFrom,
+ supportsStaticESM: options.supportsStaticESM,
+ supportsTopLevelAwait: options.supportsTopLevelAwait
+ },
+ configFile: false,
+ filename,
+ plugins: [
+ [
+ _babelPluginIstanbul().default,
+ {
+ compact: false,
+ // files outside `cwd` will not be instrumented
+ cwd: this._config.rootDir,
+ exclude: [],
+ extension: false,
+ inputSourceMap: inputMap,
+ useInlineSourceMaps: false
+ }
+ ]
+ ],
+ sourceMaps: canMapToInput ? 'both' : false
+ });
+
+ if (result && result.code) {
+ return result;
+ }
+
+ return input;
+ }
+
+ _buildTransformResult(
+ filename,
+ cacheFilePath,
+ content,
+ transformer,
+ shouldCallTransform,
+ options,
+ processed,
+ sourceMapPath
+ ) {
+ let transformed = {
+ code: content,
+ map: null
+ };
+
+ if (transformer && shouldCallTransform) {
+ if (typeof processed === 'string') {
+ transformed.code = processed;
+ } else if (processed != null && typeof processed.code === 'string') {
+ transformed = processed;
+ } else {
+ throw new Error(
+ (0, _runtimeErrorsAndWarnings.makeInvalidReturnValueError)()
+ );
+ }
+ }
+
+ if (!transformed.map) {
+ try {
+ //Could be a potential freeze here.
+ //See: https://github.com/facebook/jest/pull/5177#discussion_r158883570
+ const inlineSourceMap = (0, _convertSourceMap().fromSource)(
+ transformed.code
+ );
+
+ if (inlineSourceMap) {
+ transformed.map = inlineSourceMap.toObject();
+ }
+ } catch {
+ const transformPath = this._getTransformPath(filename);
+
+ invariant(transformPath);
+ console.warn(
+ (0, _runtimeErrorsAndWarnings.makeInvalidSourceMapWarning)(
+ filename,
+ transformPath
+ )
+ );
+ }
+ } // That means that the transform has a custom instrumentation
+ // logic and will handle it based on `config.collectCoverage` option
+
+ const transformWillInstrument =
+ shouldCallTransform && transformer && transformer.canInstrument; // Apply instrumentation to the code if necessary, keeping the instrumented code and new map
+
+ let map = transformed.map;
+ let code;
+
+ if (!transformWillInstrument && options.instrument) {
+ /**
+ * We can map the original source code to the instrumented code ONLY if
+ * - the process of transforming the code produced a source map e.g. ts-jest
+ * - we did not transform the source code
+ *
+ * Otherwise we cannot make any statements about how the instrumented code corresponds to the original code,
+ * and we should NOT emit any source maps
+ *
+ */
+ const shouldEmitSourceMaps =
+ (transformer != null && map != null) || transformer == null;
+
+ const instrumented = this._instrumentFile(
+ filename,
+ transformed,
+ shouldEmitSourceMaps,
+ options
+ );
+
+ code =
+ typeof instrumented === 'string' ? instrumented : instrumented.code;
+ map = typeof instrumented === 'string' ? null : instrumented.map;
+ } else {
+ code = transformed.code;
+ }
+
+ if (map) {
+ const sourceMapContent =
+ typeof map === 'string' ? map : JSON.stringify(map);
+ invariant(sourceMapPath, 'We should always have default sourceMapPath');
+ writeCacheFile(sourceMapPath, sourceMapContent);
+ } else {
+ sourceMapPath = null;
+ }
+
+ writeCodeCacheFile(cacheFilePath, code);
+ return {
+ code,
+ originalCode: content,
+ sourceMapPath
+ };
+ }
+
+ transformSource(filepath, content, options) {
+ const filename = (0, _jestUtil().tryRealpath)(filepath);
+ const {transformer, transformerConfig = {}} =
+ this._getTransformer(filename) || {};
+
+ const cacheFilePath = this._getFileCachePath(filename, content, options);
+
+ const sourceMapPath = cacheFilePath + '.map'; // Ignore cache if `config.cache` is set (--no-cache)
+
+ const code = this._config.cache ? readCodeCacheFile(cacheFilePath) : null;
+
+ if (code) {
+ // This is broken: we return the code, and a path for the source map
+ // directly from the cache. But, nothing ensures the source map actually
+ // matches that source code. They could have gotten out-of-sync in case
+ // two separate processes write concurrently to the same cache files.
+ return {
+ code,
+ originalCode: content,
+ sourceMapPath
+ };
+ }
+
+ let processed = null;
+ let shouldCallTransform = false;
+
+ if (transformer && this.shouldTransform(filename)) {
+ shouldCallTransform = true;
+ assertSyncTransformer(transformer, this._getTransformPath(filename));
+ processed = transformer.process(content, filename, {
+ ...options,
+ cacheFS: this._cacheFS,
+ config: this._config,
+ configString: this._cache.configString,
+ transformerConfig
+ });
+ }
+
+ return this._buildTransformResult(
+ filename,
+ cacheFilePath,
+ content,
+ transformer,
+ shouldCallTransform,
+ options,
+ processed,
+ sourceMapPath
+ );
+ }
+
+ async transformSourceAsync(filepath, content, options) {
+ const filename = (0, _jestUtil().tryRealpath)(filepath);
+ const {transformer, transformerConfig = {}} =
+ this._getTransformer(filename) || {};
+ const cacheFilePath = await this._getFileCachePathAsync(
+ filename,
+ content,
+ options
+ );
+ const sourceMapPath = cacheFilePath + '.map'; // Ignore cache if `config.cache` is set (--no-cache)
+
+ const code = this._config.cache ? readCodeCacheFile(cacheFilePath) : null;
+
+ if (code) {
+ // This is broken: we return the code, and a path for the source map
+ // directly from the cache. But, nothing ensures the source map actually
+ // matches that source code. They could have gotten out-of-sync in case
+ // two separate processes write concurrently to the same cache files.
+ return {
+ code,
+ originalCode: content,
+ sourceMapPath
+ };
+ }
+
+ let processed = null;
+ let shouldCallTransform = false;
+
+ if (transformer && this.shouldTransform(filename)) {
+ shouldCallTransform = true;
+ const process = transformer.processAsync || transformer.process; // This is probably dead code since `_getTransformerAsync` already asserts this
+
+ invariant(
+ typeof process === 'function',
+ 'A transformer must always export either a `process` or `processAsync`'
+ );
+ processed = await process(content, filename, {
+ ...options,
+ cacheFS: this._cacheFS,
+ config: this._config,
+ configString: this._cache.configString,
+ transformerConfig
+ });
+ }
+
+ return this._buildTransformResult(
+ filename,
+ cacheFilePath,
+ content,
+ transformer,
+ shouldCallTransform,
+ options,
+ processed,
+ sourceMapPath
+ );
+ }
+
+ async _transformAndBuildScriptAsync(
+ filename,
+ options,
+ transformOptions,
+ fileSource
+ ) {
+ const {isInternalModule} = options;
+ let fileContent =
+ fileSource !== null && fileSource !== void 0
+ ? fileSource
+ : this._cacheFS.get(filename);
+
+ if (!fileContent) {
+ fileContent = fs().readFileSync(filename, 'utf8');
+
+ this._cacheFS.set(filename, fileContent);
+ }
+
+ const content = stripShebang(fileContent);
+ let code = content;
+ let sourceMapPath = null;
+ const willTransform =
+ !isInternalModule &&
+ (transformOptions.instrument || this.shouldTransform(filename));
+
+ try {
+ if (willTransform) {
+ const transformedSource = await this.transformSourceAsync(
+ filename,
+ content,
+ transformOptions
+ );
+ code = transformedSource.code;
+ sourceMapPath = transformedSource.sourceMapPath;
+ }
+
+ return {
+ code,
+ originalCode: content,
+ sourceMapPath
+ };
+ } catch (e) {
+ throw (0, _enhanceUnexpectedTokenMessage.default)(e);
+ }
+ }
+
+ _transformAndBuildScript(filename, options, transformOptions, fileSource) {
+ const {isInternalModule} = options;
+ let fileContent =
+ fileSource !== null && fileSource !== void 0
+ ? fileSource
+ : this._cacheFS.get(filename);
+
+ if (!fileContent) {
+ fileContent = fs().readFileSync(filename, 'utf8');
+
+ this._cacheFS.set(filename, fileContent);
+ }
+
+ const content = stripShebang(fileContent);
+ let code = content;
+ let sourceMapPath = null;
+ const willTransform =
+ !isInternalModule &&
+ (transformOptions.instrument || this.shouldTransform(filename));
+
+ try {
+ if (willTransform) {
+ const transformedSource = this.transformSource(
+ filename,
+ content,
+ transformOptions
+ );
+ code = transformedSource.code;
+ sourceMapPath = transformedSource.sourceMapPath;
+ }
+
+ return {
+ code,
+ originalCode: content,
+ sourceMapPath
+ };
+ } catch (e) {
+ throw (0, _enhanceUnexpectedTokenMessage.default)(e);
+ }
+ }
+
+ async transformAsync(filename, options, fileSource) {
+ const instrument =
+ options.coverageProvider === 'babel' &&
+ (0, _shouldInstrument.default)(filename, options, this._config);
+ const scriptCacheKey = getScriptCacheKey(filename, instrument);
+
+ let result = this._cache.transformedFiles.get(scriptCacheKey);
+
+ if (result) {
+ return result;
+ }
+
+ result = await this._transformAndBuildScriptAsync(
+ filename,
+ options,
+ {...options, instrument},
+ fileSource
+ );
+
+ if (scriptCacheKey) {
+ this._cache.transformedFiles.set(scriptCacheKey, result);
+ }
+
+ return result;
+ }
+
+ transform(filename, options, fileSource) {
+ const instrument =
+ options.coverageProvider === 'babel' &&
+ (0, _shouldInstrument.default)(filename, options, this._config);
+ const scriptCacheKey = getScriptCacheKey(filename, instrument);
+
+ let result = this._cache.transformedFiles.get(scriptCacheKey);
+
+ if (result) {
+ return result;
+ }
+
+ result = this._transformAndBuildScript(
+ filename,
+ options,
+ {...options, instrument},
+ fileSource
+ );
+
+ if (scriptCacheKey) {
+ this._cache.transformedFiles.set(scriptCacheKey, result);
+ }
+
+ return result;
+ }
+
+ transformJson(filename, options, fileSource) {
+ const {isInternalModule} = options;
+ const willTransform = !isInternalModule && this.shouldTransform(filename);
+
+ if (willTransform) {
+ const {code: transformedJsonSource} = this.transformSource(
+ filename,
+ fileSource,
+ {...options, instrument: false}
+ );
+ return transformedJsonSource;
+ }
+
+ return fileSource;
+ }
+
+ async requireAndTranspileModule(
+ moduleName,
+ callback,
+ options = {
+ applyInteropRequireDefault: true,
+ instrument: false,
+ supportsDynamicImport: false,
+ supportsExportNamespaceFrom: false,
+ supportsStaticESM: false,
+ supportsTopLevelAwait: false
+ }
+ ) {
+ let transforming = false;
+ const {applyInteropRequireDefault, ...transformOptions} = options;
+ const revertHook = (0, _pirates().addHook)(
+ (code, filename) => {
+ try {
+ transforming = true;
+ return (
+ this.transformSource(filename, code, transformOptions).code || code
+ );
+ } finally {
+ transforming = false;
+ }
+ },
+ {
+ exts: this._config.moduleFileExtensions.map(ext => `.${ext}`),
+ ignoreNodeModules: false,
+ matcher: filename => {
+ if (transforming) {
+ // Don't transform any dependency required by the transformer itself
+ return false;
+ }
+
+ return this.shouldTransform(filename);
+ }
+ }
+ );
+
+ try {
+ const module = await (0, _jestUtil().requireOrImportModule)(
+ moduleName,
+ applyInteropRequireDefault
+ );
+
+ if (!callback) {
+ revertHook();
+ return module;
+ }
+
+ const cbResult = callback(module);
+
+ if ((0, _jestUtil().isPromise)(cbResult)) {
+ return waitForPromiseWithCleanup(cbResult, revertHook).then(
+ () => module
+ );
+ }
+
+ return module;
+ } finally {
+ revertHook();
+ }
+ }
+
+ shouldTransform(filename) {
+ const ignoreRegexp = this._cache.ignorePatternsRegExp;
+ const isIgnored = ignoreRegexp ? ignoreRegexp.test(filename) : false;
+ return this._config.transform.length !== 0 && !isIgnored;
+ }
+} // TODO: do we need to define the generics twice?
+
+async function createTranspilingRequire(config) {
+ const transformer = await createScriptTransformer(config);
+ return async function requireAndTranspileModule(
+ resolverPath,
+ applyInteropRequireDefault = false
+ ) {
+ const transpiledModule = await transformer.requireAndTranspileModule(
+ resolverPath,
+ () => {},
+ {
+ applyInteropRequireDefault,
+ instrument: false,
+ supportsDynamicImport: false,
+ // this might be true, depending on node version.
+ supportsExportNamespaceFrom: false,
+ supportsStaticESM: false,
+ supportsTopLevelAwait: false
+ }
+ );
+ return transpiledModule;
+ };
+}
+
+const removeFile = path => {
+ try {
+ fs().unlinkSync(path);
+ } catch {}
+};
+
+const stripShebang = content => {
+ // If the file data starts with a shebang remove it. Leaves the empty line
+ // to keep stack trace line numbers correct.
+ if (content.startsWith('#!')) {
+ return content.replace(/^#!.*/, '');
+ } else {
+ return content;
+ }
+};
+/**
+ * This is like `writeCacheFile` but with an additional sanity checksum. We
+ * cannot use the same technique for source maps because we expose source map
+ * cache file paths directly to callsites, with the expectation they can read
+ * it right away. This is not a great system, because source map cache file
+ * could get corrupted, out-of-sync, etc.
+ */
+
+function writeCodeCacheFile(cachePath, code) {
+ const checksum = (0, _crypto().createHash)('md5').update(code).digest('hex');
+ writeCacheFile(cachePath, checksum + '\n' + code);
+}
+/**
+ * Read counterpart of `writeCodeCacheFile`. We verify that the content of the
+ * file matches the checksum, in case some kind of corruption happened. This
+ * could happen if an older version of `jest-runtime` writes non-atomically to
+ * the same cache, for example.
+ */
+
+function readCodeCacheFile(cachePath) {
+ const content = readCacheFile(cachePath);
+
+ if (content == null) {
+ return null;
+ }
+
+ const code = content.substring(33);
+ const checksum = (0, _crypto().createHash)('md5').update(code).digest('hex');
+
+ if (checksum === content.substring(0, 32)) {
+ return code;
+ }
+
+ return null;
+}
+/**
+ * Writing to the cache atomically relies on 'rename' being atomic on most
+ * file systems. Doing atomic write reduces the risk of corruption by avoiding
+ * two processes to write to the same file at the same time. It also reduces
+ * the risk of reading a file that's being overwritten at the same time.
+ */
+
+const writeCacheFile = (cachePath, fileData) => {
+ try {
+ (0, _writeFileAtomic().sync)(cachePath, fileData, {
+ encoding: 'utf8',
+ fsync: false
+ });
+ } catch (e) {
+ if (cacheWriteErrorSafeToIgnore(e, cachePath)) {
+ return;
+ }
+
+ e.message =
+ 'jest: failed to cache transform results in: ' +
+ cachePath +
+ '\nFailure message: ' +
+ e.message;
+ removeFile(cachePath);
+ throw e;
+ }
+};
+/**
+ * On Windows, renames are not atomic, leading to EPERM exceptions when two
+ * processes attempt to rename to the same target file at the same time.
+ * If the target file exists we can be reasonably sure another process has
+ * legitimately won a cache write race and ignore the error.
+ */
+
+const cacheWriteErrorSafeToIgnore = (e, cachePath) =>
+ process.platform === 'win32' &&
+ e.code === 'EPERM' &&
+ fs().existsSync(cachePath);
+
+const readCacheFile = cachePath => {
+ if (!fs().existsSync(cachePath)) {
+ return null;
+ }
+
+ let fileData;
+
+ try {
+ fileData = fs().readFileSync(cachePath, 'utf8');
+ } catch (e) {
+ e.message =
+ 'jest: failed to read cache file: ' +
+ cachePath +
+ '\nFailure message: ' +
+ e.message;
+ removeFile(cachePath);
+ throw e;
+ }
+
+ if (fileData == null) {
+ // We must have somehow created the file but failed to write to it,
+ // let's delete it and retry.
+ removeFile(cachePath);
+ }
+
+ return fileData;
+};
+
+const getScriptCacheKey = (filename, instrument) => {
+ const mtime = fs().statSync(filename).mtime;
+ return filename + '_' + mtime.getTime() + (instrument ? '_instrumented' : '');
+};
+
+const calcIgnorePatternRegExp = config => {
+ if (
+ !config.transformIgnorePatterns ||
+ config.transformIgnorePatterns.length === 0
+ ) {
+ return undefined;
+ }
+
+ return new RegExp(config.transformIgnorePatterns.join('|'));
+};
+
+const calcTransformRegExp = config => {
+ if (!config.transform.length) {
+ return undefined;
+ }
+
+ const transformRegexp = [];
+
+ for (let i = 0; i < config.transform.length; i++) {
+ transformRegexp.push([
+ new RegExp(config.transform[i][0]),
+ config.transform[i][1],
+ config.transform[i][2]
+ ]);
+ }
+
+ return transformRegexp;
+};
+
+function invariant(condition, message) {
+ if (!condition) {
+ throw new Error(message);
+ }
+}
+
+function assertSyncTransformer(transformer, name) {
+ invariant(name);
+ invariant(
+ typeof transformer.process === 'function',
+ (0, _runtimeErrorsAndWarnings.makeInvalidSyncTransformerError)(name)
+ );
+}
+
+async function createScriptTransformer(config, cacheFS = new Map()) {
+ const transformer = new ScriptTransformer(config, cacheFS);
+ await transformer.loadTransformers();
+ return transformer;
+}
diff --git a/node_modules/@jest/transform/build/enhanceUnexpectedTokenMessage.d.ts b/node_modules/@jest/transform/build/enhanceUnexpectedTokenMessage.d.ts
new file mode 100644
index 0000000..7847dc7
--- /dev/null
+++ b/node_modules/@jest/transform/build/enhanceUnexpectedTokenMessage.d.ts
@@ -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.
+ */
+interface ErrorWithCodeFrame extends Error {
+ codeFrame?: string;
+}
+export default function handlePotentialSyntaxError(e: ErrorWithCodeFrame): ErrorWithCodeFrame;
+export declare function enhanceUnexpectedTokenMessage(e: Error): Error;
+export {};
diff --git a/node_modules/@jest/transform/build/enhanceUnexpectedTokenMessage.js b/node_modules/@jest/transform/build/enhanceUnexpectedTokenMessage.js
new file mode 100644
index 0000000..d2235f5
--- /dev/null
+++ b/node_modules/@jest/transform/build/enhanceUnexpectedTokenMessage.js
@@ -0,0 +1,83 @@
+'use strict';
+
+Object.defineProperty(exports, '__esModule', {
+ value: true
+});
+exports.default = handlePotentialSyntaxError;
+exports.enhanceUnexpectedTokenMessage = enhanceUnexpectedTokenMessage;
+
+function _chalk() {
+ const data = _interopRequireDefault(require('chalk'));
+
+ _chalk = function () {
+ return data;
+ };
+
+ return data;
+}
+
+function _interopRequireDefault(obj) {
+ return obj && obj.__esModule ? obj : {default: obj};
+}
+
+/**
+ * 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.
+ */
+const DOT = ' \u2022 ';
+
+function handlePotentialSyntaxError(e) {
+ if (e.codeFrame) {
+ e.stack = e.message + '\n' + e.codeFrame;
+ }
+
+ if (
+ // `instanceof` might come from the wrong context
+ e.name === 'SyntaxError' &&
+ !e.message.includes(' expected')
+ ) {
+ throw enhanceUnexpectedTokenMessage(e);
+ }
+
+ return e;
+}
+
+function enhanceUnexpectedTokenMessage(e) {
+ e.stack =
+ `${_chalk().default.bold.red('Jest encountered an unexpected token')}
+
+Jest failed to parse a file. This happens e.g. when your code or its dependencies use non-standard JavaScript syntax, or when Jest is not configured to support such syntax.
+
+Out of the box Jest supports Babel, which will be used to transform your files into valid JS based on your Babel configuration.
+
+By default "node_modules" folder is ignored by transformers.
+
+Here's what you can do:
+${DOT}If you are trying to use ECMAScript Modules, see ${_chalk().default.underline(
+ 'https://jestjs.io/docs/ecmascript-modules'
+ )} for how to enable it.
+${DOT}If you are trying to use TypeScript, see ${_chalk().default.underline(
+ 'https://jestjs.io/docs/getting-started#using-typescript'
+ )}
+${DOT}To have some of your "node_modules" files transformed, you can specify a custom ${_chalk().default.bold(
+ '"transformIgnorePatterns"'
+ )} in your config.
+${DOT}If you need a custom transformation specify a ${_chalk().default.bold(
+ '"transform"'
+ )} option in your config.
+${DOT}If you simply want to mock your non-JS modules (e.g. binary assets) you can stub them out with the ${_chalk().default.bold(
+ '"moduleNameMapper"'
+ )} config option.
+
+You'll find more details and examples of these config options in the docs:
+${_chalk().default.cyan('https://jestjs.io/docs/configuration')}
+For information about custom transformations, see:
+${_chalk().default.cyan('https://jestjs.io/docs/code-transformation')}
+
+${_chalk().default.bold.red('Details:')}
+
+` + e.stack;
+ return e;
+}
diff --git a/node_modules/@jest/transform/build/index.d.ts b/node_modules/@jest/transform/build/index.d.ts
new file mode 100644
index 0000000..09a5081
--- /dev/null
+++ b/node_modules/@jest/transform/build/index.d.ts
@@ -0,0 +1,11 @@
+/**
+ * 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 { createScriptTransformer, createTranspilingRequire, } from './ScriptTransformer';
+export type { TransformerType as ScriptTransformer } from './ScriptTransformer';
+export { default as shouldInstrument } from './shouldInstrument';
+export type { CallerTransformOptions, Transformer, SyncTransformer, AsyncTransformer, ShouldInstrumentOptions, Options as TransformationOptions, TransformOptions, TransformResult, TransformedSource, } from './types';
+export { default as handlePotentialSyntaxError } from './enhanceUnexpectedTokenMessage';
diff --git a/node_modules/@jest/transform/build/index.js b/node_modules/@jest/transform/build/index.js
new file mode 100644
index 0000000..ab4d31a
--- /dev/null
+++ b/node_modules/@jest/transform/build/index.js
@@ -0,0 +1,41 @@
+'use strict';
+
+Object.defineProperty(exports, '__esModule', {
+ value: true
+});
+Object.defineProperty(exports, 'createScriptTransformer', {
+ enumerable: true,
+ get: function () {
+ return _ScriptTransformer.createScriptTransformer;
+ }
+});
+Object.defineProperty(exports, 'createTranspilingRequire', {
+ enumerable: true,
+ get: function () {
+ return _ScriptTransformer.createTranspilingRequire;
+ }
+});
+Object.defineProperty(exports, 'handlePotentialSyntaxError', {
+ enumerable: true,
+ get: function () {
+ return _enhanceUnexpectedTokenMessage.default;
+ }
+});
+Object.defineProperty(exports, 'shouldInstrument', {
+ enumerable: true,
+ get: function () {
+ return _shouldInstrument.default;
+ }
+});
+
+var _ScriptTransformer = require('./ScriptTransformer');
+
+var _shouldInstrument = _interopRequireDefault(require('./shouldInstrument'));
+
+var _enhanceUnexpectedTokenMessage = _interopRequireDefault(
+ require('./enhanceUnexpectedTokenMessage')
+);
+
+function _interopRequireDefault(obj) {
+ return obj && obj.__esModule ? obj : {default: obj};
+}
diff --git a/node_modules/@jest/transform/build/runtimeErrorsAndWarnings.d.ts b/node_modules/@jest/transform/build/runtimeErrorsAndWarnings.d.ts
new file mode 100644
index 0000000..88c8f85
--- /dev/null
+++ b/node_modules/@jest/transform/build/runtimeErrorsAndWarnings.d.ts
@@ -0,0 +1,10 @@
+/**
+ * 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 declare const makeInvalidReturnValueError: () => string;
+export declare const makeInvalidSourceMapWarning: (filename: string, transformPath: string) => string;
+export declare const makeInvalidSyncTransformerError: (transformPath: string) => string;
+export declare const makeInvalidTransformerError: (transformPath: string) => string;
diff --git a/node_modules/@jest/transform/build/runtimeErrorsAndWarnings.js b/node_modules/@jest/transform/build/runtimeErrorsAndWarnings.js
new file mode 100644
index 0000000..a88290d
--- /dev/null
+++ b/node_modules/@jest/transform/build/runtimeErrorsAndWarnings.js
@@ -0,0 +1,101 @@
+'use strict';
+
+Object.defineProperty(exports, '__esModule', {
+ value: true
+});
+exports.makeInvalidTransformerError =
+ exports.makeInvalidSyncTransformerError =
+ exports.makeInvalidSourceMapWarning =
+ exports.makeInvalidReturnValueError =
+ void 0;
+
+function _chalk() {
+ const data = _interopRequireDefault(require('chalk'));
+
+ _chalk = function () {
+ return data;
+ };
+
+ return data;
+}
+
+function _slash() {
+ const data = _interopRequireDefault(require('slash'));
+
+ _slash = function () {
+ return data;
+ };
+
+ return data;
+}
+
+function _interopRequireDefault(obj) {
+ return obj && obj.__esModule ? obj : {default: obj};
+}
+
+/**
+ * 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.
+ */
+const BULLET = '\u25cf ';
+const DOCUMENTATION_NOTE = ` ${_chalk().default.bold(
+ 'Code Transformation Documentation:'
+)}
+ https://jestjs.io/docs/code-transformation
+`;
+
+const makeInvalidReturnValueError = () =>
+ _chalk().default.red(
+ [
+ _chalk().default.bold(BULLET + 'Invalid return value:'),
+ " Code transformer's `process` function must return a string or an object",
+ ' with `code` key containing a string. If `processAsync` function is implemented,',
+ ' it must return a Promise resolving to one of these values.',
+ ''
+ ].join('\n') + DOCUMENTATION_NOTE
+ );
+
+exports.makeInvalidReturnValueError = makeInvalidReturnValueError;
+
+const makeInvalidSourceMapWarning = (filename, transformPath) =>
+ _chalk().default.yellow(
+ [
+ _chalk().default.bold(BULLET + 'Invalid source map:'),
+ ` The source map for "${(0, _slash().default)(
+ filename
+ )}" returned by "${(0, _slash().default)(transformPath)}" is invalid.`,
+ ' Proceeding without source mapping for that file.'
+ ].join('\n')
+ );
+
+exports.makeInvalidSourceMapWarning = makeInvalidSourceMapWarning;
+
+const makeInvalidSyncTransformerError = transformPath =>
+ _chalk().default.red(
+ [
+ _chalk().default.bold(BULLET + 'Invalid synchronous transformer module:'),
+ ` "${(0, _slash().default)(
+ transformPath
+ )}" specified in the "transform" object of Jest configuration`,
+ ' must export a `process` function.',
+ ''
+ ].join('\n') + DOCUMENTATION_NOTE
+ );
+
+exports.makeInvalidSyncTransformerError = makeInvalidSyncTransformerError;
+
+const makeInvalidTransformerError = transformPath =>
+ _chalk().default.red(
+ [
+ _chalk().default.bold(BULLET + 'Invalid transformer module:'),
+ ` "${(0, _slash().default)(
+ transformPath
+ )}" specified in the "transform" object of Jest configuration`,
+ ' must export a `process` or `processAsync` or `createTransformer` function.',
+ ''
+ ].join('\n') + DOCUMENTATION_NOTE
+ );
+
+exports.makeInvalidTransformerError = makeInvalidTransformerError;
diff --git a/node_modules/@jest/transform/build/shouldInstrument.d.ts b/node_modules/@jest/transform/build/shouldInstrument.d.ts
new file mode 100644
index 0000000..2b7b617
--- /dev/null
+++ b/node_modules/@jest/transform/build/shouldInstrument.d.ts
@@ -0,0 +1,9 @@
+/**
+ * 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.
+ */
+import type { Config } from '@jest/types';
+import type { ShouldInstrumentOptions } from './types';
+export default function shouldInstrument(filename: Config.Path, options: ShouldInstrumentOptions, config: Config.ProjectConfig): boolean;
diff --git a/node_modules/@jest/transform/build/shouldInstrument.js b/node_modules/@jest/transform/build/shouldInstrument.js
new file mode 100644
index 0000000..292af31
--- /dev/null
+++ b/node_modules/@jest/transform/build/shouldInstrument.js
@@ -0,0 +1,207 @@
+'use strict';
+
+Object.defineProperty(exports, '__esModule', {
+ value: true
+});
+exports.default = shouldInstrument;
+
+function path() {
+ const data = _interopRequireWildcard(require('path'));
+
+ path = function () {
+ return data;
+ };
+
+ return data;
+}
+
+function _micromatch() {
+ const data = _interopRequireDefault(require('micromatch'));
+
+ _micromatch = function () {
+ return data;
+ };
+
+ return data;
+}
+
+function _jestRegexUtil() {
+ const data = require('jest-regex-util');
+
+ _jestRegexUtil = function () {
+ return data;
+ };
+
+ return data;
+}
+
+function _jestUtil() {
+ const data = require('jest-util');
+
+ _jestUtil = function () {
+ return data;
+ };
+
+ return data;
+}
+
+function _interopRequireDefault(obj) {
+ return obj && obj.__esModule ? obj : {default: obj};
+}
+
+function _getRequireWildcardCache(nodeInterop) {
+ if (typeof WeakMap !== 'function') return null;
+ var cacheBabelInterop = new WeakMap();
+ var cacheNodeInterop = new WeakMap();
+ return (_getRequireWildcardCache = function (nodeInterop) {
+ return nodeInterop ? cacheNodeInterop : cacheBabelInterop;
+ })(nodeInterop);
+}
+
+function _interopRequireWildcard(obj, nodeInterop) {
+ if (!nodeInterop && obj && obj.__esModule) {
+ return obj;
+ }
+ if (obj === null || (typeof obj !== 'object' && typeof obj !== 'function')) {
+ return {default: obj};
+ }
+ var cache = _getRequireWildcardCache(nodeInterop);
+ if (cache && cache.has(obj)) {
+ return cache.get(obj);
+ }
+ var newObj = {};
+ var hasPropertyDescriptor =
+ Object.defineProperty && Object.getOwnPropertyDescriptor;
+ for (var key in obj) {
+ if (key !== 'default' && Object.prototype.hasOwnProperty.call(obj, key)) {
+ var desc = hasPropertyDescriptor
+ ? Object.getOwnPropertyDescriptor(obj, key)
+ : null;
+ if (desc && (desc.get || desc.set)) {
+ Object.defineProperty(newObj, key, desc);
+ } else {
+ newObj[key] = obj[key];
+ }
+ }
+ }
+ newObj.default = obj;
+ if (cache) {
+ cache.set(obj, newObj);
+ }
+ return newObj;
+}
+
+/**
+ * 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.
+ */
+const MOCKS_PATTERN = new RegExp(
+ (0, _jestRegexUtil().escapePathForRegex)(
+ path().sep + '__mocks__' + path().sep
+ )
+);
+const cachedRegexes = new Map();
+
+const getRegex = regexStr => {
+ if (!cachedRegexes.has(regexStr)) {
+ cachedRegexes.set(regexStr, new RegExp(regexStr));
+ }
+
+ const regex = cachedRegexes.get(regexStr); // prevent stateful regexes from breaking, just in case
+
+ regex.lastIndex = 0;
+ return regex;
+};
+
+function shouldInstrument(filename, options, config) {
+ if (!options.collectCoverage) {
+ return false;
+ }
+
+ if (
+ config.forceCoverageMatch.length &&
+ _micromatch().default.any(filename, config.forceCoverageMatch)
+ ) {
+ return true;
+ }
+
+ if (
+ !config.testPathIgnorePatterns.some(pattern =>
+ getRegex(pattern).test(filename)
+ )
+ ) {
+ if (config.testRegex.some(regex => new RegExp(regex).test(filename))) {
+ return false;
+ }
+
+ if (
+ (0, _jestUtil().globsToMatcher)(config.testMatch)(
+ (0, _jestUtil().replacePathSepForGlob)(filename)
+ )
+ ) {
+ return false;
+ }
+ }
+
+ if (
+ // This configuration field contains an object in the form of:
+ // {'path/to/file.js': true}
+ options.collectCoverageOnlyFrom &&
+ !options.collectCoverageOnlyFrom[filename]
+ ) {
+ return false;
+ }
+
+ if (
+ // still cover if `only` is specified
+ !options.collectCoverageOnlyFrom &&
+ options.collectCoverageFrom.length &&
+ !(0, _jestUtil().globsToMatcher)(options.collectCoverageFrom)(
+ (0, _jestUtil().replacePathSepForGlob)(
+ path().relative(config.rootDir, filename)
+ )
+ )
+ ) {
+ return false;
+ }
+
+ if (
+ config.coveragePathIgnorePatterns.some(pattern => !!filename.match(pattern))
+ ) {
+ return false;
+ }
+
+ if (config.globalSetup === filename) {
+ return false;
+ }
+
+ if (config.globalTeardown === filename) {
+ return false;
+ }
+
+ if (config.setupFiles.includes(filename)) {
+ return false;
+ }
+
+ if (config.setupFilesAfterEnv.includes(filename)) {
+ return false;
+ }
+
+ if (MOCKS_PATTERN.test(filename)) {
+ return false;
+ }
+
+ if (options.changedFiles && !options.changedFiles.has(filename)) {
+ if (!options.sourcesRelatedToTestsInChangedFiles) {
+ return false;
+ }
+
+ if (!options.sourcesRelatedToTestsInChangedFiles.has(filename)) {
+ return false;
+ }
+ }
+
+ return true;
+}
diff --git a/node_modules/@jest/transform/build/types.d.ts b/node_modules/@jest/transform/build/types.d.ts
new file mode 100644
index 0000000..038bf9d
--- /dev/null
+++ b/node_modules/@jest/transform/build/types.d.ts
@@ -0,0 +1,75 @@
+/**
+ * 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.
+ */
+import type { RawSourceMap } from 'source-map';
+import type { Config, TransformTypes } from '@jest/types';
+export interface ShouldInstrumentOptions extends Pick<Config.GlobalConfig, 'collectCoverage' | 'collectCoverageFrom' | 'collectCoverageOnlyFrom' | 'coverageProvider'> {
+ changedFiles?: Set<Config.Path>;
+ sourcesRelatedToTestsInChangedFiles?: Set<Config.Path>;
+}
+export interface Options extends ShouldInstrumentOptions, CallerTransformOptions {
+ isInternalModule?: boolean;
+}
+interface FixedRawSourceMap extends Omit<RawSourceMap, 'version'> {
+ version: number;
+}
+export declare type TransformedSource = {
+ code: string;
+ map?: FixedRawSourceMap | string | null;
+} | string;
+export declare type TransformResult = TransformTypes.TransformResult;
+export interface CallerTransformOptions {
+ supportsDynamicImport: boolean;
+ supportsExportNamespaceFrom: boolean;
+ supportsStaticESM: boolean;
+ supportsTopLevelAwait: boolean;
+}
+export interface ReducedTransformOptions extends CallerTransformOptions {
+ instrument: boolean;
+}
+export interface RequireAndTranspileModuleOptions extends ReducedTransformOptions {
+ applyInteropRequireDefault: boolean;
+}
+export declare type StringMap = Map<string, string>;
+export interface TransformOptions<OptionType = unknown> extends ReducedTransformOptions {
+ /** a cached file system which is used in jest-runtime - useful to improve performance */
+ cacheFS: StringMap;
+ config: Config.ProjectConfig;
+ /** A stringified version of the configuration - useful in cache busting */
+ configString: string;
+ /** the options passed through Jest's config by the user */
+ transformerConfig: OptionType;
+}
+export interface SyncTransformer<OptionType = unknown> {
+ /**
+ * Indicates if the transformer is capable of instrumenting the code for code coverage.
+ *
+ * If V8 coverage is _not_ active, and this is `true`, Jest will assume the code is instrumented.
+ * If V8 coverage is _not_ active, and this is `false`. Jest will instrument the code returned by this transformer using Babel.
+ */
+ canInstrument?: boolean;
+ createTransformer?: (options?: OptionType) => SyncTransformer<OptionType>;
+ getCacheKey?: (sourceText: string, sourcePath: Config.Path, options: TransformOptions<OptionType>) => string;
+ getCacheKeyAsync?: (sourceText: string, sourcePath: Config.Path, options: TransformOptions<OptionType>) => Promise<string>;
+ process: (sourceText: string, sourcePath: Config.Path, options: TransformOptions<OptionType>) => TransformedSource;
+ processAsync?: (sourceText: string, sourcePath: Config.Path, options: TransformOptions<OptionType>) => Promise<TransformedSource>;
+}
+export interface AsyncTransformer<OptionType = unknown> {
+ /**
+ * Indicates if the transformer is capable of instrumenting the code for code coverage.
+ *
+ * If V8 coverage is _not_ active, and this is `true`, Jest will assume the code is instrumented.
+ * If V8 coverage is _not_ active, and this is `false`. Jest will instrument the code returned by this transformer using Babel.
+ */
+ canInstrument?: boolean;
+ createTransformer?: (options?: OptionType) => AsyncTransformer<OptionType>;
+ getCacheKey?: (sourceText: string, sourcePath: Config.Path, options: TransformOptions<OptionType>) => string;
+ getCacheKeyAsync?: (sourceText: string, sourcePath: Config.Path, options: TransformOptions<OptionType>) => Promise<string>;
+ process?: (sourceText: string, sourcePath: Config.Path, options: TransformOptions<OptionType>) => TransformedSource;
+ processAsync: (sourceText: string, sourcePath: Config.Path, options: TransformOptions<OptionType>) => Promise<TransformedSource>;
+}
+export declare type Transformer<OptionType = unknown> = SyncTransformer<OptionType> | AsyncTransformer<OptionType>;
+export {};
diff --git a/node_modules/@jest/transform/build/types.js b/node_modules/@jest/transform/build/types.js
new file mode 100644
index 0000000..ad9a93a
--- /dev/null
+++ b/node_modules/@jest/transform/build/types.js
@@ -0,0 +1 @@
+'use strict';