241 lines
6.9 KiB
JavaScript
241 lines
6.9 KiB
JavaScript
'use strict';
|
|
|
|
Object.defineProperty(exports, '__esModule', {
|
|
value: true
|
|
});
|
|
exports.default = void 0;
|
|
function _path() {
|
|
const data = require('path');
|
|
_path = function () {
|
|
return data;
|
|
};
|
|
return data;
|
|
}
|
|
function _jestPnpResolver() {
|
|
const data = _interopRequireDefault(require('jest-pnp-resolver'));
|
|
_jestPnpResolver = function () {
|
|
return data;
|
|
};
|
|
return data;
|
|
}
|
|
function _resolve() {
|
|
const data = require('resolve');
|
|
_resolve = function () {
|
|
return data;
|
|
};
|
|
return data;
|
|
}
|
|
var resolve = _interopRequireWildcard(require('resolve.exports'));
|
|
var _fileWalkers = require('./fileWalkers');
|
|
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 _interopRequireDefault(obj) {
|
|
return obj && obj.__esModule ? obj : {default: obj};
|
|
}
|
|
/**
|
|
* Copyright (c) Meta Platforms, Inc. and affiliates.
|
|
*
|
|
* This source code is licensed under the MIT license found in the
|
|
* LICENSE file in the root directory of this source tree.
|
|
*/
|
|
|
|
/**
|
|
* Allows transforming parsed `package.json` contents.
|
|
*
|
|
* @param pkg - Parsed `package.json` contents.
|
|
* @param file - Path to `package.json` file.
|
|
* @param dir - Directory that contains the `package.json`.
|
|
*
|
|
* @returns Transformed `package.json` contents.
|
|
*/
|
|
|
|
/**
|
|
* Allows transforming a path within a package.
|
|
*
|
|
* @param pkg - Parsed `package.json` contents.
|
|
* @param path - Path being resolved.
|
|
* @param relativePath - Path relative from the `package.json` location.
|
|
*
|
|
* @returns Relative path that will be joined from the `package.json` location.
|
|
*/
|
|
|
|
const defaultResolver = (path, options) => {
|
|
// Yarn 2 adds support to `resolve` automatically so the pnpResolver is only
|
|
// needed for Yarn 1 which implements version 1 of the pnp spec
|
|
if (process.versions.pnp === '1') {
|
|
return (0, _jestPnpResolver().default)(path, options);
|
|
}
|
|
const resolveOptions = {
|
|
...options,
|
|
isDirectory: _fileWalkers.isDirectory,
|
|
isFile: _fileWalkers.isFile,
|
|
preserveSymlinks: false,
|
|
readPackageSync,
|
|
realpathSync: _fileWalkers.realpathSync
|
|
};
|
|
const pathToResolve = getPathInModule(path, resolveOptions);
|
|
|
|
// resolveSync dereferences symlinks to ensure we don't create a separate
|
|
// module instance depending on how it was referenced.
|
|
const result = (0, _resolve().sync)(pathToResolve, resolveOptions);
|
|
return result;
|
|
};
|
|
var _default = defaultResolver;
|
|
/*
|
|
* helper functions
|
|
*/
|
|
exports.default = _default;
|
|
function readPackageSync(_, file) {
|
|
return (0, _fileWalkers.readPackageCached)(file);
|
|
}
|
|
function getPathInModule(path, options) {
|
|
if (shouldIgnoreRequestForExports(path)) {
|
|
return path;
|
|
}
|
|
if (path.startsWith('#')) {
|
|
const closestPackageJson = (0, _fileWalkers.findClosestPackageJson)(
|
|
options.basedir
|
|
);
|
|
if (!closestPackageJson) {
|
|
throw new Error(
|
|
`Jest: unable to locate closest package.json from ${options.basedir} when resolving import "${path}"`
|
|
);
|
|
}
|
|
const pkg = (0, _fileWalkers.readPackageCached)(closestPackageJson);
|
|
const resolved = resolve.imports(
|
|
pkg,
|
|
path,
|
|
createResolveOptions(options.conditions)
|
|
);
|
|
if (resolved) {
|
|
const target = resolved[0];
|
|
return target.startsWith('.')
|
|
? // internal relative filepath
|
|
(0, _path().resolve)((0, _path().dirname)(closestPackageJson), target)
|
|
: // this is an external module, re-resolve it
|
|
defaultResolver(target, options);
|
|
}
|
|
if (pkg.imports) {
|
|
throw new Error(
|
|
'`imports` exists, but no results - this is a bug in Jest. Please report an issue'
|
|
);
|
|
}
|
|
}
|
|
const segments = path.split('/');
|
|
let moduleName = segments.shift();
|
|
if (moduleName) {
|
|
if (moduleName.startsWith('@')) {
|
|
moduleName = `${moduleName}/${segments.shift()}`;
|
|
}
|
|
|
|
// self-reference
|
|
const closestPackageJson = (0, _fileWalkers.findClosestPackageJson)(
|
|
options.basedir
|
|
);
|
|
if (closestPackageJson) {
|
|
const pkg = (0, _fileWalkers.readPackageCached)(closestPackageJson);
|
|
if (pkg.name === moduleName) {
|
|
const resolved = resolve.exports(
|
|
pkg,
|
|
segments.join('/') || '.',
|
|
createResolveOptions(options.conditions)
|
|
);
|
|
if (resolved) {
|
|
return (0, _path().resolve)(
|
|
(0, _path().dirname)(closestPackageJson),
|
|
resolved[0]
|
|
);
|
|
}
|
|
if (pkg.exports) {
|
|
throw new Error(
|
|
'`exports` exists, but no results - this is a bug in Jest. Please report an issue'
|
|
);
|
|
}
|
|
}
|
|
}
|
|
let packageJsonPath = '';
|
|
try {
|
|
packageJsonPath = (0, _resolve().sync)(
|
|
`${moduleName}/package.json`,
|
|
options
|
|
);
|
|
} catch {
|
|
// ignore if package.json cannot be found
|
|
}
|
|
if (packageJsonPath && (0, _fileWalkers.isFile)(packageJsonPath)) {
|
|
const pkg = (0, _fileWalkers.readPackageCached)(packageJsonPath);
|
|
const resolved = resolve.exports(
|
|
pkg,
|
|
segments.join('/') || '.',
|
|
createResolveOptions(options.conditions)
|
|
);
|
|
if (resolved) {
|
|
return (0, _path().resolve)(
|
|
(0, _path().dirname)(packageJsonPath),
|
|
resolved[0]
|
|
);
|
|
}
|
|
if (pkg.exports) {
|
|
throw new Error(
|
|
'`exports` exists, but no results - this is a bug in Jest. Please report an issue'
|
|
);
|
|
}
|
|
}
|
|
}
|
|
return path;
|
|
}
|
|
function createResolveOptions(conditions) {
|
|
return conditions
|
|
? {
|
|
conditions,
|
|
unsafe: true
|
|
}
|
|
: // no conditions were passed - let's assume this is Jest internal and it should be `require`
|
|
{
|
|
browser: false,
|
|
require: true
|
|
};
|
|
}
|
|
|
|
// if it's a relative import or an absolute path, imports/exports are ignored
|
|
const shouldIgnoreRequestForExports = path =>
|
|
path.startsWith('.') || (0, _path().isAbsolute)(path);
|