From df379513b3606b24f2e5f4d4877e0f727b1da121 Mon Sep 17 00:00:00 2001 From: Tim Seckinger Date: Fri, 22 Feb 2019 22:10:19 +0100 Subject: [PATCH 1/2] decentralize resolve types --- packages/jest-haste-map/src/index.ts | 1 + .../jest-resolve-dependencies/src/index.ts | 24 ++++++++++++------- packages/jest-resolve/src/index.ts | 14 ++++++++--- packages/jest-types/src/Resolve.ts | 17 ------------- packages/jest-types/src/index.ts | 2 -- 5 files changed, 28 insertions(+), 30 deletions(-) delete mode 100644 packages/jest-types/src/Resolve.ts diff --git a/packages/jest-haste-map/src/index.ts b/packages/jest-haste-map/src/index.ts index f809a46df037..fedc0f81a019 100644 --- a/packages/jest-haste-map/src/index.ts +++ b/packages/jest-haste-map/src/index.ts @@ -221,6 +221,7 @@ const getWhiteList = (list: Array | undefined): RegExp | null => { * Worker processes can directly access the cache through `HasteMap.read()`. * */ +/* eslint-disable-next-line no-redeclare */ class HasteMap extends EventEmitter { private _buildPromise: Promise | null; private _cachePath: Config.Path; diff --git a/packages/jest-resolve-dependencies/src/index.ts b/packages/jest-resolve-dependencies/src/index.ts index 583ab2f91f85..c0a081dffe0b 100644 --- a/packages/jest-resolve-dependencies/src/index.ts +++ b/packages/jest-resolve-dependencies/src/index.ts @@ -5,15 +5,23 @@ * LICENSE file in the root directory of this source tree. */ -import {Config, Resolve, Snapshot} from '@jest/types'; +import {Config, Snapshot} from '@jest/types'; import {FS as HasteFS} from 'jest-haste-map'; import Resolver from 'jest-resolve'; import {isSnapshotPath} from 'jest-snapshot'; +namespace DependencyResolver { + export type ResolvedModule = { + file: Config.Path; + dependencies: Config.Path[]; + }; +} + /** * DependencyResolver is used to resolve the direct dependencies of a module or * to retrieve a list of all transitive inverse dependencies. */ +/* eslint-disable-next-line no-redeclare */ class DependencyResolver { private _hasteFS: HasteFS; private _resolver: Resolver; @@ -31,7 +39,7 @@ class DependencyResolver { resolve( file: Config.Path, - options?: Resolve.ResolveModuleConfig, + options?: Resolver.ResolveModuleConfig, ): Array { const dependencies = this._hasteFS.getDependencies(file); if (!dependencies) { @@ -64,19 +72,19 @@ class DependencyResolver { resolveInverseModuleMap( paths: Set, filter: (file: Config.Path) => boolean, - options?: Resolve.ResolveModuleConfig, - ): Array { + options?: Resolver.ResolveModuleConfig, + ): Array { if (!paths.size) { return []; } const collectModules = ( related: Set, - moduleMap: Array, + moduleMap: Array, changed: Set, ) => { const visitedModules = new Set(); - const result: Array = []; + const result: Array = []; while (changed.size) { changed = new Set( moduleMap.reduce>((acc, module) => { @@ -116,7 +124,7 @@ class DependencyResolver { } } } - const modules: Array = []; + const modules: Array = []; for (const file of this._hasteFS.getAbsoluteFileIterator()) { modules.push({ dependencies: this.resolve(file, options), @@ -129,7 +137,7 @@ class DependencyResolver { resolveInverse( paths: Set, filter: (file: Config.Path) => boolean, - options?: Resolve.ResolveModuleConfig, + options?: Resolver.ResolveModuleConfig, ): Array { return this.resolveInverseModuleMap(paths, filter, options).map( module => module.file, diff --git a/packages/jest-resolve/src/index.ts b/packages/jest-resolve/src/index.ts index 666116b2db5d..c08f54cb9eab 100644 --- a/packages/jest-resolve/src/index.ts +++ b/packages/jest-resolve/src/index.ts @@ -6,7 +6,7 @@ */ import path from 'path'; -import {Config, Resolve} from '@jest/types'; +import {Config} from '@jest/types'; import {ModuleMap} from 'jest-haste-map'; import {sync as realpath} from 'realpath-native'; import chalk from 'chalk'; @@ -27,6 +27,13 @@ type FindNodeModuleConfig = { type BooleanObject = {[key: string]: boolean}; +namespace Resolver { + export type ResolveModuleConfig = { + skipNodeResolution?: boolean; + paths?: Config.Path[]; + }; +} + const NATIVE_PLATFORM = 'native'; // We might be inside a symlink. @@ -39,6 +46,7 @@ const nodePaths = process.env.NODE_PATH .map(p => path.resolve(resolvedCwd, p)) : null; +/* eslint-disable-next-line no-redeclare */ class Resolver { private readonly _options: ResolverConfig; private readonly _moduleMap: ModuleMap; @@ -97,7 +105,7 @@ class Resolver { resolveModuleFromDirIfExists( dirname: Config.Path, moduleName: string, - options?: Resolve.ResolveModuleConfig, + options?: Resolver.ResolveModuleConfig, ): Config.Path | null { const paths = (options && options.paths) || this._options.modulePaths; const moduleDirectory = this._options.moduleDirectories; @@ -180,7 +188,7 @@ class Resolver { resolveModule( from: Config.Path, moduleName: string, - options?: Resolve.ResolveModuleConfig, + options?: Resolver.ResolveModuleConfig, ): Config.Path { const dirname = path.dirname(from); const module = this.resolveModuleFromDirIfExists( diff --git a/packages/jest-types/src/Resolve.ts b/packages/jest-types/src/Resolve.ts deleted file mode 100644 index 61ce0329cb95..000000000000 --- a/packages/jest-types/src/Resolve.ts +++ /dev/null @@ -1,17 +0,0 @@ -/** - * 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 {Path} from './Config'; - -export type ResolveModuleConfig = { - skipNodeResolution?: boolean; - paths?: Path[]; -}; -export type ResolvedModule = { - file: Path; - dependencies: Path[]; -}; diff --git a/packages/jest-types/src/index.ts b/packages/jest-types/src/index.ts index 0226a0a00820..b6fb07c461be 100644 --- a/packages/jest-types/src/index.ts +++ b/packages/jest-types/src/index.ts @@ -10,7 +10,6 @@ import * as Console from './Console'; import * as Matchers from './Matchers'; import * as Mocks from './Mocks'; import * as PrettyFormat from './PrettyFormat'; -import * as Resolve from './Resolve'; import * as Snapshot from './Snapshot'; import * as SourceMaps from './SourceMaps'; import * as TestResult from './TestResult'; @@ -21,7 +20,6 @@ export { Matchers, Mocks, PrettyFormat, - Resolve, Snapshot, SourceMaps, TestResult, From a867df2df690bb235dd47d183c23ba7ece2eb0ef Mon Sep 17 00:00:00 2001 From: Tim Seckinger Date: Sat, 23 Feb 2019 15:32:05 +0100 Subject: [PATCH 2/2] update snapshot line numbers --- e2e/__tests__/__snapshots__/moduleNameMapper.test.js.snap | 2 +- .../__snapshots__/resolveNoFileExtensions.test.js.snap | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/e2e/__tests__/__snapshots__/moduleNameMapper.test.js.snap b/e2e/__tests__/__snapshots__/moduleNameMapper.test.js.snap index 687ca938186f..9609d706b96c 100644 --- a/e2e/__tests__/__snapshots__/moduleNameMapper.test.js.snap +++ b/e2e/__tests__/__snapshots__/moduleNameMapper.test.js.snap @@ -30,6 +30,6 @@ FAIL __tests__/index.js 12 | module.exports = () => 'test'; 13 | - at createNoMappedModuleFoundError (../../packages/jest-resolve/build/index.js:434:17) + at createNoMappedModuleFoundError (../../packages/jest-resolve/build/index.js:435:17) at Object.require (index.js:10:1) `; diff --git a/e2e/__tests__/__snapshots__/resolveNoFileExtensions.test.js.snap b/e2e/__tests__/__snapshots__/resolveNoFileExtensions.test.js.snap index 13dc33fad1c2..8bb20a9f7d29 100644 --- a/e2e/__tests__/__snapshots__/resolveNoFileExtensions.test.js.snap +++ b/e2e/__tests__/__snapshots__/resolveNoFileExtensions.test.js.snap @@ -33,6 +33,6 @@ FAIL __tests__/test.js | ^ 4 | - at Resolver.resolveModule (../../packages/jest-resolve/build/index.js:201:17) + at Resolver.resolveModule (../../packages/jest-resolve/build/index.js:202:17) at Object.require (index.js:3:18) `;