setup-kubectl/node_modules/ts-jest/dist/config/config-set.js

532 lines
26 KiB
JavaScript
Raw Normal View History

"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;