aboutsummaryrefslogtreecommitdiff
path: root/node_modules/jest-config/build/resolveConfigPath.js
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-config/build/resolveConfigPath.js
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-config/build/resolveConfigPath.js')
-rw-r--r--node_modules/jest-config/build/resolveConfigPath.js247
1 files changed, 247 insertions, 0 deletions
diff --git a/node_modules/jest-config/build/resolveConfigPath.js b/node_modules/jest-config/build/resolveConfigPath.js
new file mode 100644
index 0000000..12472b0
--- /dev/null
+++ b/node_modules/jest-config/build/resolveConfigPath.js
@@ -0,0 +1,247 @@
+'use strict';
+
+Object.defineProperty(exports, '__esModule', {
+ value: true
+});
+exports.default = resolveConfigPath;
+
+function path() {
+ const data = _interopRequireWildcard(require('path'));
+
+ path = function () {
+ return data;
+ };
+
+ return data;
+}
+
+function _chalk() {
+ const data = _interopRequireDefault(require('chalk'));
+
+ _chalk = function () {
+ return data;
+ };
+
+ return data;
+}
+
+function fs() {
+ const data = _interopRequireWildcard(require('graceful-fs'));
+
+ fs = function () {
+ return data;
+ };
+
+ return data;
+}
+
+function _slash() {
+ const data = _interopRequireDefault(require('slash'));
+
+ _slash = function () {
+ return data;
+ };
+
+ return data;
+}
+
+var _constants = require('./constants');
+
+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 isFile = filePath =>
+ fs().existsSync(filePath) && !fs().lstatSync(filePath).isDirectory();
+
+const getConfigFilename = ext => _constants.JEST_CONFIG_BASE_NAME + ext;
+
+function resolveConfigPath(
+ pathToResolve,
+ cwd,
+ skipMultipleConfigWarning = false
+) {
+ if (!path().isAbsolute(cwd)) {
+ throw new Error(`"cwd" must be an absolute path. cwd: ${cwd}`);
+ }
+
+ const absolutePath = path().isAbsolute(pathToResolve)
+ ? pathToResolve
+ : path().resolve(cwd, pathToResolve);
+
+ if (isFile(absolutePath)) {
+ return absolutePath;
+ } // This is a guard against passing non existing path as a project/config,
+ // that will otherwise result in a very confusing situation.
+ // e.g.
+ // With a directory structure like this:
+ // my_project/
+ // package.json
+ //
+ // Passing a `my_project/some_directory_that_doesnt_exist` as a project
+ // name will resolve into a (possibly empty) `my_project/package.json` and
+ // try to run all tests it finds under `my_project` directory.
+
+ if (!fs().existsSync(absolutePath)) {
+ throw new Error(
+ "Can't find a root directory while resolving a config file path.\n" +
+ `Provided path to resolve: ${pathToResolve}\n` +
+ `cwd: ${cwd}`
+ );
+ }
+
+ return resolveConfigPathByTraversing(
+ absolutePath,
+ pathToResolve,
+ cwd,
+ skipMultipleConfigWarning
+ );
+}
+
+const resolveConfigPathByTraversing = (
+ pathToResolve,
+ initialPath,
+ cwd,
+ skipMultipleConfigWarning
+) => {
+ const configFiles = _constants.JEST_CONFIG_EXT_ORDER.map(ext =>
+ path().resolve(pathToResolve, getConfigFilename(ext))
+ ).filter(isFile);
+
+ const packageJson = findPackageJson(pathToResolve);
+
+ if (packageJson && hasPackageJsonJestKey(packageJson)) {
+ configFiles.push(packageJson);
+ }
+
+ if (!skipMultipleConfigWarning && configFiles.length > 1) {
+ console.warn(makeMultipleConfigsWarning(configFiles));
+ }
+
+ if (configFiles.length > 0 || packageJson) {
+ var _configFiles$;
+
+ return (_configFiles$ = configFiles[0]) !== null && _configFiles$ !== void 0
+ ? _configFiles$
+ : packageJson;
+ } // This is the system root.
+ // We tried everything, config is nowhere to be found ¯\_(ツ)_/¯
+
+ if (pathToResolve === path().dirname(pathToResolve)) {
+ throw new Error(makeResolutionErrorMessage(initialPath, cwd));
+ } // go up a level and try it again
+
+ return resolveConfigPathByTraversing(
+ path().dirname(pathToResolve),
+ initialPath,
+ cwd,
+ skipMultipleConfigWarning
+ );
+};
+
+const findPackageJson = pathToResolve => {
+ const packagePath = path().resolve(pathToResolve, _constants.PACKAGE_JSON);
+
+ if (isFile(packagePath)) {
+ return packagePath;
+ }
+
+ return undefined;
+};
+
+const hasPackageJsonJestKey = packagePath => {
+ const content = fs().readFileSync(packagePath, 'utf8');
+
+ try {
+ return 'jest' in JSON.parse(content);
+ } catch {
+ // If package is not a valid JSON
+ return false;
+ }
+};
+
+const makeResolutionErrorMessage = (initialPath, cwd) =>
+ 'Could not find a config file based on provided values:\n' +
+ `path: "${initialPath}"\n` +
+ `cwd: "${cwd}"\n` +
+ 'Config paths must be specified by either a direct path to a config\n' +
+ 'file, or a path to a directory. If directory is given, Jest will try to\n' +
+ `traverse directory tree up, until it finds one of those files in exact order: ${_constants.JEST_CONFIG_EXT_ORDER.map(
+ ext => `"${getConfigFilename(ext)}"`
+ ).join(' or ')}.`;
+
+function extraIfPackageJson(configPath) {
+ if (configPath.endsWith(_constants.PACKAGE_JSON)) {
+ return '`jest` key in ';
+ }
+
+ return '';
+}
+
+const makeMultipleConfigsWarning = configPaths =>
+ _chalk().default.yellow(
+ [
+ _chalk().default.bold('\u25cf Multiple configurations found:'),
+ ...configPaths.map(
+ configPath =>
+ ` * ${extraIfPackageJson(configPath)}${(0, _slash().default)(
+ configPath
+ )}`
+ ),
+ '',
+ ' Implicit config resolution does not allow multiple configuration files.',
+ ' Either remove unused config files or select one explicitly with `--config`.',
+ '',
+ ' Configuration Documentation:',
+ ' https://jestjs.io/docs/configuration.html',
+ ''
+ ].join('\n')
+ );