From 36bfaf131480d17cea55c6649c015189cb6bab1c Mon Sep 17 00:00:00 2001 From: Michael Lewis Date: Thu, 12 Apr 2018 08:16:00 +0100 Subject: [PATCH] Generalise package main resolving issue (#5968) * Generalise package main resolving issue Resolves #5967 * Update changelog with info about #5968 * Fix linting errors --- CHANGELOG.md | 2 ++ .../__mocks__/mock-module-alt/index.js | 8 ++++++++ .../__mocks__/mock-module-alt/package.json | 4 ++++ .../__tests__/resolve-node-module.test.js | 8 +++++++- packages/jest-resolve/src/default_resolver.js | 6 +++++- 5 files changed, 26 insertions(+), 2 deletions(-) create mode 100644 integration-tests/resolve-node-module/__mocks__/mock-module-alt/index.js create mode 100644 integration-tests/resolve-node-module/__mocks__/mock-module-alt/package.json diff --git a/CHANGELOG.md b/CHANGELOG.md index f0fa49a26b8a..d94812f6efad 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -87,6 +87,8 @@ ([#5914](https://github.com/facebook/jest/pull/5914)) * `[jest-regex-util]` Fix handling regex symbols in tests path on Windows ([#5941](https://github.com/facebook/jest/pull/5941)) +* `[jest-resolve]` Generalise test for package main entries equivalent to ".". + ([#5968)](https://github.com/facebook/jest/pull/5968) ### Chore & Maintenance diff --git a/integration-tests/resolve-node-module/__mocks__/mock-module-alt/index.js b/integration-tests/resolve-node-module/__mocks__/mock-module-alt/index.js new file mode 100644 index 000000000000..acc83d1123dc --- /dev/null +++ b/integration-tests/resolve-node-module/__mocks__/mock-module-alt/index.js @@ -0,0 +1,8 @@ +/** + * Copyright (c) 2014-present, Facebook, Inc. 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. + */ + +module.exports = 'test'; diff --git a/integration-tests/resolve-node-module/__mocks__/mock-module-alt/package.json b/integration-tests/resolve-node-module/__mocks__/mock-module-alt/package.json new file mode 100644 index 000000000000..3136f7174e9e --- /dev/null +++ b/integration-tests/resolve-node-module/__mocks__/mock-module-alt/package.json @@ -0,0 +1,4 @@ +{ + "name": "mock-module-alt", + "main": "./" +} diff --git a/integration-tests/resolve-node-module/__tests__/resolve-node-module.test.js b/integration-tests/resolve-node-module/__tests__/resolve-node-module.test.js index b008272f042a..33172ad2fad3 100644 --- a/integration-tests/resolve-node-module/__tests__/resolve-node-module.test.js +++ b/integration-tests/resolve-node-module/__tests__/resolve-node-module.test.js @@ -8,6 +8,7 @@ 'use strict'; jest.mock('mock-module'); +jest.mock('mock-module-alt'); jest.mock('mock-jsx-module'); it('should resolve entry as index.js when package main is "."', () => { @@ -15,7 +16,12 @@ it('should resolve entry as index.js when package main is "."', () => { expect(mockModule).toEqual('test'); }); -it('should resolve entry as index with other configured module file extention when package main is "."', () => { +it('should resolve entry as index.js when package main is "./"', () => { + const mockModule = require('mock-module-alt'); + expect(mockModule).toEqual('test'); +}); + +it('should resolve entry as index with other configured module file extension when package main is "."', () => { const mockJsxModule = require('mock-jsx-module'); expect(mockJsxModule).toEqual('test jsx'); }); diff --git a/packages/jest-resolve/src/default_resolver.js b/packages/jest-resolve/src/default_resolver.js index beffc1a19ef5..72f5706d4aa8 100644 --- a/packages/jest-resolve/src/default_resolver.js +++ b/packages/jest-resolve/src/default_resolver.js @@ -129,7 +129,7 @@ function resolveSync(target: Path, options: ResolverOptions): Path { pkgmain = JSON.parse(body).main; } catch (e) {} - if (pkgmain && pkgmain !== '.') { + if (pkgmain && !isCurrentDirectory(pkgmain)) { const resolveTarget = path.resolve(name, pkgmain); const result = tryResolve(resolveTarget); if (result) { @@ -175,3 +175,7 @@ function isDirectory(dir: Path): boolean { return result; } + +function isCurrentDirectory(testPath: Path): boolean { + return path.resolve('.') === path.resolve(testPath); +}