mirror of
				https://github.com/Azure/setup-helm.git
				synced 2025-10-25 03:56:31 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			532 lines
		
	
	
		
			26 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			532 lines
		
	
	
		
			26 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| "use strict";
 | |
| var __assign = (this && this.__assign) || function () {
 | |
|     __assign = Object.assign || function(t) {
 | |
|         for (var s, i = 1, n = arguments.length; i < n; i++) {
 | |
|             s = arguments[i];
 | |
|             for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
 | |
|                 t[p] = s[p];
 | |
|         }
 | |
|         return t;
 | |
|     };
 | |
|     return __assign.apply(this, arguments);
 | |
| };
 | |
| var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
 | |
|     var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
 | |
|     if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
 | |
|     else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
 | |
|     return c > 3 && r && Object.defineProperty(target, key, r), r;
 | |
| };
 | |
| var __values = (this && this.__values) || function(o) {
 | |
|     var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0;
 | |
|     if (m) return m.call(o);
 | |
|     if (o && typeof o.length === "number") return {
 | |
|         next: function () {
 | |
|             if (o && i >= o.length) o = void 0;
 | |
|             return { value: o && o[i++], done: !o };
 | |
|         }
 | |
|     };
 | |
|     throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined.");
 | |
| };
 | |
| var __read = (this && this.__read) || function (o, n) {
 | |
|     var m = typeof Symbol === "function" && o[Symbol.iterator];
 | |
|     if (!m) return o;
 | |
|     var i = m.call(o), r, ar = [], e;
 | |
|     try {
 | |
|         while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
 | |
|     }
 | |
|     catch (error) { e = { error: error }; }
 | |
|     finally {
 | |
|         try {
 | |
|             if (r && !r.done && (m = i["return"])) m.call(i);
 | |
|         }
 | |
|         finally { if (e) throw e.error; }
 | |
|     }
 | |
|     return ar;
 | |
| };
 | |
| var __spread = (this && this.__spread) || function () {
 | |
|     for (var ar = [], i = 0; i < arguments.length; i++) ar = ar.concat(__read(arguments[i]));
 | |
|     return ar;
 | |
| };
 | |
| var _a;
 | |
| Object.defineProperty(exports, "__esModule", { value: true });
 | |
| exports.ConfigSet = exports.TS_JEST_OUT_DIR = exports.IGNORE_DIAGNOSTIC_CODES = exports.MY_DIGEST = void 0;
 | |
| var bs_logger_1 = require("bs-logger");
 | |
| var fs_1 = require("fs");
 | |
| var jest_util_1 = require("jest-util");
 | |
| var json5 = require("json5");
 | |
| var path_1 = require("path");
 | |
| var typescript_1 = require("typescript");
 | |
| var instance_1 = require("../compiler/instance");
 | |
| var constants_1 = require("../constants");
 | |
| var hoist_jest_1 = require("../transformers/hoist-jest");
 | |
| var backports_1 = require("../utils/backports");
 | |
| var importer_1 = require("../utils/importer");
 | |
| var json_1 = require("../utils/json");
 | |
| var logger_1 = require("../utils/logger");
 | |
| var memoize_1 = require("../utils/memoize");
 | |
| var messages_1 = require("../utils/messages");
 | |
| var normalize_slashes_1 = require("../utils/normalize-slashes");
 | |
| var sha1_1 = require("../utils/sha1");
 | |
| var ts_error_1 = require("../utils/ts-error");
 | |
| exports.MY_DIGEST = fs_1.readFileSync(path_1.resolve(__dirname, '..', '..', '.ts-jest-digest'), 'utf8');
 | |
| exports.IGNORE_DIAGNOSTIC_CODES = [
 | |
|     6059,
 | |
|     18002,
 | |
|     18003,
 | |
| ];
 | |
| exports.TS_JEST_OUT_DIR = '$$ts-jest$$';
 | |
| var TARGET_TO_VERSION_MAPPING = (_a = {},
 | |
|     _a[typescript_1.ScriptTarget.ES2018] = 'es2018',
 | |
|     _a[typescript_1.ScriptTarget.ES2019] = 'es2019',
 | |
|     _a[typescript_1.ScriptTarget.ES2020] = 'es2020',
 | |
|     _a[typescript_1.ScriptTarget.ESNext] = 'ESNext',
 | |
|     _a);
 | |
| var normalizeRegex = function (pattern) {
 | |
|     return pattern ? (typeof pattern === 'string' ? pattern : pattern.source) : undefined;
 | |
| };
 | |
| var toDiagnosticCode = function (code) { var _a; return code ? (_a = parseInt(("" + code).trim().replace(/^TS/, ''), 10)) !== null && _a !== void 0 ? _a : undefined : undefined; };
 | |
| var toDiagnosticCodeList = function (items, into) {
 | |
|     var e_1, _a;
 | |
|     if (into === void 0) { into = []; }
 | |
|     try {
 | |
|         for (var items_1 = __values(items), items_1_1 = items_1.next(); !items_1_1.done; items_1_1 = items_1.next()) {
 | |
|             var item = items_1_1.value;
 | |
|             if (typeof item === 'string') {
 | |
|                 var children = item.trim().split(/\s*,\s*/g);
 | |
|                 if (children.length > 1) {
 | |
|                     toDiagnosticCodeList(children, into);
 | |
|                     continue;
 | |
|                 }
 | |
|                 item = children[0];
 | |
|             }
 | |
|             if (!item)
 | |
|                 continue;
 | |
|             var code = toDiagnosticCode(item);
 | |
|             if (code && !into.includes(code))
 | |
|                 into.push(code);
 | |
|         }
 | |
|     }
 | |
|     catch (e_1_1) { e_1 = { error: e_1_1 }; }
 | |
|     finally {
 | |
|         try {
 | |
|             if (items_1_1 && !items_1_1.done && (_a = items_1.return)) _a.call(items_1);
 | |
|         }
 | |
|         finally { if (e_1) throw e_1.error; }
 | |
|     }
 | |
|     return into;
 | |
| };
 | |
| var ConfigSet = (function () {
 | |
|     function ConfigSet(jestConfig, parentLogger) {
 | |
|         var _a, _b;
 | |
|         var _c, _d, _e, _f;
 | |
|         this.parentLogger = parentLogger;
 | |
|         this.customTransformers = Object.create(null);
 | |
|         this._overriddenCompilerOptions = {
 | |
|             sourceMap: true,
 | |
|             inlineSourceMap: false,
 | |
|             inlineSources: true,
 | |
|             declaration: false,
 | |
|             noEmit: false,
 | |
|             removeComments: false,
 | |
|             out: undefined,
 | |
|             outFile: undefined,
 | |
|             composite: undefined,
 | |
|             declarationDir: undefined,
 | |
|             declarationMap: undefined,
 | |
|             emitDeclarationOnly: undefined,
 | |
|             sourceRoot: undefined,
 | |
|             tsBuildInfoFile: undefined,
 | |
|         };
 | |
|         this.logger = this.parentLogger
 | |
|             ? this.parentLogger.child((_a = {}, _a[bs_logger_1.LogContexts.namespace] = 'config', _a))
 | |
|             : logger_1.rootLogger.child({ namespace: 'config' });
 | |
|         this._backportJestCfg(jestConfig !== null && jestConfig !== void 0 ? jestConfig : Object.create(null));
 | |
|         this.cwd = path_1.normalize((_c = this._jestCfg.cwd) !== null && _c !== void 0 ? _c : process.cwd());
 | |
|         this.rootDir = path_1.normalize((_d = this._jestCfg.rootDir) !== null && _d !== void 0 ? _d : this.cwd);
 | |
|         var tsJestCfg = this._jestCfg.globals && this._jestCfg.globals['ts-jest'];
 | |
|         var options = tsJestCfg !== null && tsJestCfg !== void 0 ? tsJestCfg : Object.create(null);
 | |
|         this.compilerModule = importer_1.importer.typescript("Using \"ts-jest\" requires this package to be installed.", (_e = options.compiler) !== null && _e !== void 0 ? _e : 'typescript');
 | |
|         this.isolatedModules = (_f = options.isolatedModules) !== null && _f !== void 0 ? _f : false;
 | |
|         this.logger.debug({ compilerModule: this.compilerModule }, 'normalized compiler module config via ts-jest option');
 | |
|         this._matchablePatterns = __spread(this._jestCfg.testMatch, this._jestCfg.testRegex).filter(function (pattern) {
 | |
|             return pattern instanceof RegExp || typeof pattern === 'string';
 | |
|         });
 | |
|         if (!this._matchablePatterns.length) {
 | |
|             (_b = this._matchablePatterns).push.apply(_b, __spread(constants_1.DEFAULT_JEST_TEST_MATCH));
 | |
|         }
 | |
|         this._matchTestFilePath = jest_util_1.globsToMatcher(this._matchablePatterns.filter(function (pattern) { return typeof pattern === 'string'; }));
 | |
|         this._setupTsJestCfg(options);
 | |
|         this._resolveTsCacheDir();
 | |
|     }
 | |
|     ConfigSet.prototype._backportJestCfg = function (jestCfg) {
 | |
|         var config = backports_1.backportJestConfig(this.logger, jestCfg);
 | |
|         this.logger.debug({ jestConfig: config }, 'normalized jest config');
 | |
|         this._jestCfg = config;
 | |
|     };
 | |
|     ConfigSet.prototype._setupTsJestCfg = function (options) {
 | |
|         var _this = this;
 | |
|         var _a, _b, _c, _d;
 | |
|         if (options.packageJson) {
 | |
|             this.logger.warn("The option `packageJson` is deprecated and will be removed in ts-jest 27. This option is not used by internal `ts-jest`");
 | |
|         }
 | |
|         if (!options.babelConfig) {
 | |
|             this.logger.debug('babel is disabled');
 | |
|         }
 | |
|         else {
 | |
|             var baseBabelCfg = { cwd: this.cwd };
 | |
|             if (typeof options.babelConfig === 'string') {
 | |
|                 var babelCfgPath = this.resolvePath(options.babelConfig);
 | |
|                 if (path_1.extname(options.babelConfig) === '.js') {
 | |
|                     this._babelConfig = __assign(__assign({}, baseBabelCfg), require(babelCfgPath));
 | |
|                 }
 | |
|                 else {
 | |
|                     this._babelConfig = __assign(__assign({}, baseBabelCfg), json5.parse(fs_1.readFileSync(babelCfgPath, 'utf-8')));
 | |
|                 }
 | |
|             }
 | |
|             else if (typeof options.babelConfig === 'object') {
 | |
|                 this._babelConfig = __assign(__assign({}, baseBabelCfg), options.babelConfig);
 | |
|             }
 | |
|             else {
 | |
|                 this._babelConfig = baseBabelCfg;
 | |
|             }
 | |
|             this.logger.debug({ babelConfig: this._babelConfig }, 'normalized babel config via ts-jest option');
 | |
|         }
 | |
|         if (!this._babelConfig) {
 | |
|             this._overriddenCompilerOptions.module = this.compilerModule.ModuleKind.CommonJS;
 | |
|         }
 | |
|         else {
 | |
|             this._babelJestTransformers = importer_1.importer
 | |
|                 .babelJest("Using \"babel-jest\" requires this package to be installed.")
 | |
|                 .createTransformer(this._babelConfig);
 | |
|             this.logger.debug('created babel-jest transformer');
 | |
|         }
 | |
|         var diagnosticsOpt = (_a = options.diagnostics) !== null && _a !== void 0 ? _a : true;
 | |
|         var ignoreList = __spread(exports.IGNORE_DIAGNOSTIC_CODES);
 | |
|         if (typeof diagnosticsOpt === 'object') {
 | |
|             var ignoreCodes = diagnosticsOpt.ignoreCodes;
 | |
|             if (ignoreCodes) {
 | |
|                 Array.isArray(ignoreCodes) ? ignoreList.push.apply(ignoreList, __spread(ignoreCodes)) : ignoreList.push(ignoreCodes);
 | |
|             }
 | |
|             this._diagnostics = {
 | |
|                 pretty: (_b = diagnosticsOpt.pretty) !== null && _b !== void 0 ? _b : true,
 | |
|                 exclude: (_c = diagnosticsOpt.exclude) !== null && _c !== void 0 ? _c : [],
 | |
|                 ignoreCodes: toDiagnosticCodeList(ignoreList),
 | |
|                 throws: !diagnosticsOpt.warnOnly,
 | |
|             };
 | |
|             if (diagnosticsOpt.pathRegex) {
 | |
|                 this.logger.warn("The option `pathRegex` is deprecated and will be removed in ts-jest 27, use `exclude` instead");
 | |
|                 this._diagnostics = __assign(__assign({}, this._diagnostics), { pathRegex: normalizeRegex(diagnosticsOpt.pathRegex) });
 | |
|             }
 | |
|         }
 | |
|         else {
 | |
|             this._diagnostics = {
 | |
|                 ignoreCodes: diagnosticsOpt ? toDiagnosticCodeList(ignoreList) : [],
 | |
|                 exclude: [],
 | |
|                 pretty: true,
 | |
|                 throws: diagnosticsOpt,
 | |
|             };
 | |
|         }
 | |
|         if (this._diagnostics.pathRegex && !this._diagnostics.exclude.length) {
 | |
|             this._shouldGetDiagnosticsForFile = new RegExp(this._diagnostics.pathRegex);
 | |
|         }
 | |
|         else {
 | |
|             this._shouldGetDiagnosticsForFile = this._diagnostics.exclude.length
 | |
|                 ? jest_util_1.globsToMatcher(this._diagnostics.exclude)
 | |
|                 : function () { return true; };
 | |
|         }
 | |
|         this.logger.debug({ diagnostics: this._diagnostics }, 'normalized diagnostics config via ts-jest option');
 | |
|         if (options.tsConfig) {
 | |
|             this.logger.warn("The option `tsConfig` is deprecated and will be removed in ts-jest 27, use `tsconfig` instead");
 | |
|         }
 | |
|         var tsconfigOpt = (_d = options.tsConfig) !== null && _d !== void 0 ? _d : options.tsconfig;
 | |
|         var configFilePath = typeof tsconfigOpt === 'string' ? this.resolvePath(tsconfigOpt) : undefined;
 | |
|         this.parsedTsConfig = this._resolveTsConfig(typeof tsconfigOpt === 'object' ? tsconfigOpt : undefined, configFilePath);
 | |
|         this.raiseDiagnostics(this.parsedTsConfig.errors, configFilePath);
 | |
|         this.logger.debug({ tsconfig: this.parsedTsConfig }, 'normalized typescript config via ts-jest option');
 | |
|         var astTransformers = options.astTransformers;
 | |
|         this.customTransformers = {
 | |
|             before: [hoist_jest_1.factory(this)],
 | |
|         };
 | |
|         if (astTransformers) {
 | |
|             if (Array.isArray(astTransformers)) {
 | |
|                 this.logger.warn("The configuration for astTransformers as string[] is deprecated and will be removed in ts-jest 27. Please define your custom AST transformers in a form of an object. More information you can check online documentation https://kulshekhar.github.io/ts-jest/user/config/astTransformers");
 | |
|                 this.customTransformers = {
 | |
|                     before: __spread(this.customTransformers.before, astTransformers.map(function (transformer) {
 | |
|                         var transformerPath = _this.resolvePath(transformer, { nodeResolve: true });
 | |
|                         return require(transformerPath).factory(_this);
 | |
|                     })),
 | |
|                 };
 | |
|             }
 | |
|             else {
 | |
|                 var resolveTransformers = function (transformers) {
 | |
|                     return transformers.map(function (transformer) {
 | |
|                         var transformerPath;
 | |
|                         if (typeof transformer === 'string') {
 | |
|                             transformerPath = _this.resolvePath(transformer, { nodeResolve: true });
 | |
|                             return require(transformerPath).factory(_this);
 | |
|                         }
 | |
|                         else {
 | |
|                             transformerPath = _this.resolvePath(transformer.path, { nodeResolve: true });
 | |
|                             return require(transformerPath).factory(_this, transformer.options);
 | |
|                         }
 | |
|                     });
 | |
|                 };
 | |
|                 if (astTransformers.before) {
 | |
|                     this.customTransformers = {
 | |
|                         before: __spread(this.customTransformers.before, resolveTransformers(astTransformers.before)),
 | |
|                     };
 | |
|                 }
 | |
|                 if (astTransformers.after) {
 | |
|                     this.customTransformers = __assign(__assign({}, this.customTransformers), { after: resolveTransformers(astTransformers.after) });
 | |
|                 }
 | |
|                 if (astTransformers.afterDeclarations) {
 | |
|                     this.customTransformers = __assign(__assign({}, this.customTransformers), { afterDeclarations: resolveTransformers(astTransformers.afterDeclarations) });
 | |
|                 }
 | |
|             }
 | |
|         }
 | |
|         this.logger.debug({ customTransformers: this.customTransformers }, 'normalized custom AST transformers via ts-jest option');
 | |
|         if (options.stringifyContentPathRegex) {
 | |
|             this._stringifyContentRegExp =
 | |
|                 typeof options.stringifyContentPathRegex === 'string'
 | |
|                     ? new RegExp(normalizeRegex(options.stringifyContentPathRegex))
 | |
|                     : options.stringifyContentPathRegex;
 | |
|             this.logger.debug({ stringifyContentPathRegex: this._stringifyContentRegExp }, 'normalized stringifyContentPathRegex config via ts-jest option');
 | |
|         }
 | |
|     };
 | |
|     ConfigSet.prototype._resolveTsCacheDir = function () {
 | |
|         if (!this._jestCfg.cache) {
 | |
|             this.logger.debug('file caching disabled');
 | |
|             return undefined;
 | |
|         }
 | |
|         var cacheSuffix = sha1_1.sha1(json_1.stringify({
 | |
|             version: this.compilerModule.version,
 | |
|             digest: this.tsJestDigest,
 | |
|             compilerModule: this.compilerModule,
 | |
|             compilerOptions: this.parsedTsConfig.options,
 | |
|             isolatedModules: this.isolatedModules,
 | |
|             diagnostics: this._diagnostics,
 | |
|         }));
 | |
|         var res = path_1.join(this._jestCfg.cacheDirectory, 'ts-jest', cacheSuffix.substr(0, 2), cacheSuffix.substr(2));
 | |
|         this.logger.debug({ cacheDirectory: res }, 'will use file caching');
 | |
|         this.tsCacheDir = res;
 | |
|     };
 | |
|     ConfigSet.prototype._resolveTsConfig = function (compilerOptions, resolvedConfigFile) {
 | |
|         var e_2, _a;
 | |
|         var _b;
 | |
|         var config = { compilerOptions: Object.create(null) };
 | |
|         var basePath = normalize_slashes_1.normalizeSlashes(this.rootDir);
 | |
|         var ts = this.compilerModule;
 | |
|         var configFileName = resolvedConfigFile
 | |
|             ? normalize_slashes_1.normalizeSlashes(resolvedConfigFile)
 | |
|             : ts.findConfigFile(normalize_slashes_1.normalizeSlashes(this.rootDir), ts.sys.fileExists);
 | |
|         if (configFileName) {
 | |
|             this.logger.debug({ tsConfigFileName: configFileName }, 'readTsConfig(): reading', configFileName);
 | |
|             var result_1 = ts.readConfigFile(configFileName, ts.sys.readFile);
 | |
|             if (result_1.error) {
 | |
|                 return { errors: [result_1.error], fileNames: [], options: {} };
 | |
|             }
 | |
|             config = result_1.config;
 | |
|             basePath = normalize_slashes_1.normalizeSlashes(path_1.dirname(configFileName));
 | |
|         }
 | |
|         config.compilerOptions = __assign(__assign({}, config.compilerOptions), compilerOptions);
 | |
|         var result = ts.parseJsonConfigFileContent(config, ts.sys, basePath, undefined, configFileName);
 | |
|         if (result.options.sourceMap === false) {
 | |
|             this.logger.warn(messages_1.interpolate("Got `sourceMap: false` from tsconfig file \"{{path}}\". This will disable source map support in ts-jest 27. Please set `sourceMap: true` in your tsconfig file \"{{path}}\" if you want to keep source map support on", {
 | |
|                 path: result.options.configFilePath,
 | |
|             }));
 | |
|         }
 | |
|         var forcedOptions = this._overriddenCompilerOptions;
 | |
|         var finalOptions = result.options;
 | |
|         if (finalOptions.target === undefined) {
 | |
|             finalOptions.target = ts.ScriptTarget.ES5;
 | |
|         }
 | |
|         var target = finalOptions.target;
 | |
|         var defaultModule = [ts.ScriptTarget.ES3, ts.ScriptTarget.ES5].includes(target)
 | |
|             ? ts.ModuleKind.CommonJS
 | |
|             : ts.ModuleKind.ESNext;
 | |
|         var moduleValue = finalOptions.module == null ? defaultModule : finalOptions.module;
 | |
|         if ('module' in forcedOptions &&
 | |
|             moduleValue !== forcedOptions.module &&
 | |
|             !(finalOptions.esModuleInterop || finalOptions.allowSyntheticDefaultImports)) {
 | |
|             result.errors.push({
 | |
|                 code: 151001,
 | |
|                 messageText: "If you have issues related to imports, you should consider setting `esModuleInterop` to `true` in your TypeScript configuration file (usually `tsconfig.json`). See https://blogs.msdn.microsoft.com/typescript/2018/01/31/announcing-typescript-2-7/#easier-ecmascript-module-interoperability for more information.",
 | |
|                 category: ts.DiagnosticCategory.Message,
 | |
|                 file: undefined,
 | |
|                 start: undefined,
 | |
|                 length: undefined,
 | |
|             });
 | |
|             if (!('allowSyntheticDefaultImports' in config.compilerOptions)) {
 | |
|                 finalOptions.allowSyntheticDefaultImports = true;
 | |
|             }
 | |
|         }
 | |
|         if (finalOptions.allowJs && !finalOptions.outDir) {
 | |
|             finalOptions.outDir = exports.TS_JEST_OUT_DIR;
 | |
|         }
 | |
|         try {
 | |
|             for (var _c = __values(Object.keys(forcedOptions)), _d = _c.next(); !_d.done; _d = _c.next()) {
 | |
|                 var key = _d.value;
 | |
|                 var val = forcedOptions[key];
 | |
|                 if (val === undefined) {
 | |
|                     delete finalOptions[key];
 | |
|                 }
 | |
|                 else {
 | |
|                     finalOptions[key] = val;
 | |
|                 }
 | |
|             }
 | |
|         }
 | |
|         catch (e_2_1) { e_2 = { error: e_2_1 }; }
 | |
|         finally {
 | |
|             try {
 | |
|                 if (_d && !_d.done && (_a = _c.return)) _a.call(_c);
 | |
|             }
 | |
|             finally { if (e_2) throw e_2.error; }
 | |
|         }
 | |
|         var nodeJsVer = process.version;
 | |
|         var compilationTarget = result.options.target;
 | |
|         if (!this._babelConfig &&
 | |
|             ((nodeJsVer.startsWith('v10') && compilationTarget > typescript_1.ScriptTarget.ES2018) ||
 | |
|                 (nodeJsVer.startsWith('v12') && compilationTarget > typescript_1.ScriptTarget.ES2019))) {
 | |
|             var message = messages_1.interpolate("There is a mismatch between your NodeJs version {{nodeJsVer}} and your TypeScript target {{compilationTarget}}. This might lead to some unexpected errors when running tests with `ts-jest`. To fix this, you can check https://github.com/microsoft/TypeScript/wiki/Node-Target-Mapping", {
 | |
|                 nodeJsVer: process.version,
 | |
|                 compilationTarget: (_b = config.compilerOptions.target) !== null && _b !== void 0 ? _b : TARGET_TO_VERSION_MAPPING[compilationTarget],
 | |
|             });
 | |
|             this.logger.warn(message);
 | |
|         }
 | |
|         return result;
 | |
|     };
 | |
|     Object.defineProperty(ConfigSet.prototype, "tsCompiler", {
 | |
|         get: function () {
 | |
|             return instance_1.createCompilerInstance(this);
 | |
|         },
 | |
|         enumerable: false,
 | |
|         configurable: true
 | |
|     });
 | |
|     Object.defineProperty(ConfigSet.prototype, "babelConfig", {
 | |
|         get: function () {
 | |
|             return this._babelConfig;
 | |
|         },
 | |
|         enumerable: false,
 | |
|         configurable: true
 | |
|     });
 | |
|     Object.defineProperty(ConfigSet.prototype, "babelJestTransformer", {
 | |
|         get: function () {
 | |
|             return this._babelJestTransformers;
 | |
|         },
 | |
|         enumerable: false,
 | |
|         configurable: true
 | |
|     });
 | |
|     Object.defineProperty(ConfigSet.prototype, "tsJestDigest", {
 | |
|         get: function () {
 | |
|             return exports.MY_DIGEST;
 | |
|         },
 | |
|         enumerable: false,
 | |
|         configurable: true
 | |
|     });
 | |
|     Object.defineProperty(ConfigSet.prototype, "hooks", {
 | |
|         get: function () {
 | |
|             var hooksFile = process.env.TS_JEST_HOOKS;
 | |
|             if (hooksFile) {
 | |
|                 hooksFile = path_1.resolve(this.cwd, hooksFile);
 | |
|                 return importer_1.importer.tryTheseOr(hooksFile, {});
 | |
|             }
 | |
|             return {};
 | |
|         },
 | |
|         enumerable: false,
 | |
|         configurable: true
 | |
|     });
 | |
|     ConfigSet.prototype.isTestFile = function (fileName) {
 | |
|         var _this = this;
 | |
|         return this._matchablePatterns.some(function (pattern) {
 | |
|             return typeof pattern === 'string' ? _this._matchTestFilePath(fileName) : pattern.test(fileName);
 | |
|         });
 | |
|     };
 | |
|     ConfigSet.prototype.shouldStringifyContent = function (filePath) {
 | |
|         return this._stringifyContentRegExp ? this._stringifyContentRegExp.test(filePath) : false;
 | |
|     };
 | |
|     ConfigSet.prototype.raiseDiagnostics = function (diagnostics, filePath, logger) {
 | |
|         var _this = this;
 | |
|         var ignoreCodes = this._diagnostics.ignoreCodes;
 | |
|         var DiagnosticCategory = this.compilerModule.DiagnosticCategory;
 | |
|         var filteredDiagnostics = filePath && !this.shouldReportDiagnostics(filePath)
 | |
|             ? []
 | |
|             : diagnostics.filter(function (diagnostic) {
 | |
|                 var _a;
 | |
|                 if (((_a = diagnostic.file) === null || _a === void 0 ? void 0 : _a.fileName) && !_this.shouldReportDiagnostics(diagnostic.file.fileName)) {
 | |
|                     return false;
 | |
|                 }
 | |
|                 return !ignoreCodes.includes(diagnostic.code);
 | |
|             });
 | |
|         if (!filteredDiagnostics.length)
 | |
|             return;
 | |
|         var error = this._createTsError(filteredDiagnostics);
 | |
|         var importantCategories = [DiagnosticCategory.Warning, DiagnosticCategory.Error];
 | |
|         if (this._diagnostics.throws && filteredDiagnostics.some(function (d) { return importantCategories.includes(d.category); })) {
 | |
|             throw error;
 | |
|         }
 | |
|         logger ? logger.warn({ error: error }, error.message) : this.logger.warn({ error: error }, error.message);
 | |
|     };
 | |
|     ConfigSet.prototype.shouldReportDiagnostics = function (filePath) {
 | |
|         return this._shouldGetDiagnosticsForFile instanceof RegExp
 | |
|             ? this._shouldGetDiagnosticsForFile.test(filePath)
 | |
|             : this._shouldGetDiagnosticsForFile(filePath);
 | |
|     };
 | |
|     ConfigSet.prototype._createTsError = function (diagnostics) {
 | |
|         var _this = this;
 | |
|         var formatDiagnostics = this._diagnostics.pretty
 | |
|             ? this.compilerModule.formatDiagnosticsWithColorAndContext
 | |
|             : this.compilerModule.formatDiagnostics;
 | |
|         var diagnosticHost = {
 | |
|             getNewLine: function () { return '\n'; },
 | |
|             getCurrentDirectory: function () { return _this.cwd; },
 | |
|             getCanonicalFileName: function (path) { return path; },
 | |
|         };
 | |
|         var diagnosticText = formatDiagnostics(diagnostics, diagnosticHost);
 | |
|         var diagnosticCodes = diagnostics.map(function (x) { return x.code; });
 | |
|         return new ts_error_1.TSError(diagnosticText, diagnosticCodes);
 | |
|     };
 | |
|     ConfigSet.prototype.resolvePath = function (inputPath, _a) {
 | |
|         var _b = _a === void 0 ? {} : _a, _c = _b.throwIfMissing, throwIfMissing = _c === void 0 ? true : _c, _d = _b.nodeResolve, nodeResolve = _d === void 0 ? false : _d;
 | |
|         var path = inputPath;
 | |
|         var nodeResolved = false;
 | |
|         if (path.startsWith('<rootDir>')) {
 | |
|             path = path_1.resolve(path_1.join(this.rootDir, path.substr(9)));
 | |
|         }
 | |
|         else if (!path_1.isAbsolute(path)) {
 | |
|             if (!path.startsWith('.') && nodeResolve) {
 | |
|                 try {
 | |
|                     path = require.resolve(path);
 | |
|                     nodeResolved = true;
 | |
|                 }
 | |
|                 catch (_) { }
 | |
|             }
 | |
|             if (!nodeResolved) {
 | |
|                 path = path_1.resolve(this.cwd, path);
 | |
|             }
 | |
|         }
 | |
|         if (!nodeResolved && nodeResolve) {
 | |
|             try {
 | |
|                 path = require.resolve(path);
 | |
|                 nodeResolved = true;
 | |
|             }
 | |
|             catch (_) { }
 | |
|         }
 | |
|         if (throwIfMissing && !fs_1.existsSync(path)) {
 | |
|             throw new Error(messages_1.interpolate("File not found: {{inputPath}} (resolved as: {{resolvedPath}})", { inputPath: inputPath, resolvedPath: path }));
 | |
|         }
 | |
|         this.logger.debug({ fromPath: inputPath, toPath: path }, 'resolved path from', inputPath, 'to', path);
 | |
|         return path;
 | |
|     };
 | |
|     __decorate([
 | |
|         memoize_1.Memoize()
 | |
|     ], ConfigSet.prototype, "tsCompiler", null);
 | |
|     __decorate([
 | |
|         memoize_1.Memoize()
 | |
|     ], ConfigSet.prototype, "tsJestDigest", null);
 | |
|     __decorate([
 | |
|         memoize_1.Memoize()
 | |
|     ], ConfigSet.prototype, "hooks", null);
 | |
|     return ConfigSet;
 | |
| }());
 | |
| exports.ConfigSet = ConfigSet;
 |