2

我有一个要测试的模块。该模块正在使用其他外部模块,并且 jest 很难解决它们。

它将基本路径解析为: ./node_modules/react-tag-input/dist-modules/

而不是: ./node_modules /react-tag-input/node_modules/react-dnd

下面是正在发生的事情的简化版本:

错误:

Cannot find module 'react-dnd' from 'reactTags.js'

  at Resolver.resolveModule (node_modules/jest-cli/node_modules/jest-resolve/build/index.js:160:17)
  at Object.<anonymous> (node_modules/react-tag-input/dist-modules/reactTags.js:13:17)
  at Object.<anonymous> (src/tagger/eventtagger.js:5:404)

这是我的测试文件: caseevent.test.js

import EventTagger from './eventtagger.js';

eventtagger.js

import ReactTags from 'react-tag-input';

包.json

"jest": {
   "moduleFileExtensions": [
      "js",
      "jsx"
   ],
   "modulePaths": [
      "<rootDir>"
   ],
},
"dependencies": {
   "babel-jest": "^17.0.2",
   "flux": "^2.0.1",
   "install": "^0.8.1",
   "jest": "^17.0.3",
   "lodash.flow": "^3.3.0",
   "npm": "^3.10.6",
   "object-assign": "^1.0.0",
   "react": "^15.4.0",
   "react-dnd": "git+https://github.com/jcrogel/react-dnd.git",
   "react-dnd-html5-backend": "^2.0.0",
   "react-dom": "^15.4.0",
   "react-tag-input": "^4.4.0",
   "react-tagcloud": "^0.6.1"
},
"devDependencies": {
   "babel-cli": "^6.9.0",
   "babel-core": "^6.14.0",
   "babel-eslint": "^4.1.3",
   "babel-loader": "^6.2.5",
   "babel-preset-es2015": "^6.0.15",
   "babel-preset-react": "^6.0.15",
   "babel-preset-stage-0": "^6.0.15",
   "babel-register": "^6.9.0",
   "chai": "^3.5.0",
   "enzyme": "^2.6.0",
   "jest-cli": "^17.0.3",
   "jsdom": "^9.4.0",
   "lodash": "4.14.1",
   "react-addons-test-utils": "^15.4.0",
   "react-native": "^0.38.0",
   "react-test-renderer": "15.4.0",
   "sinon": "^1.17.4",
   "webpack": "^1.13.1",
   "webpack-dev-server": "^1.14.1",
   "whatwg-fetch": "^2.0.1"
 }

我错过了什么?如何获得 jest-resolve 来查找或模拟更深层次的组件?

4

2 回答 2

1

我也有同样的问题。我尝试过的一些事情:

测试文件顶部的 jest.unmock(module) 将模块填充到 Jest 设置文件中 jest.mock(jest.fn() => {console.log('do something')) 最后,这似乎有效,但我找不到关于此的文档:

在测试文件的顶部:

/** * @providesModule 模块名称 */

这似乎识别出我需要的模块。Jest 应该隐含地看到开箱即用的模块,但我没有这种经验。

于 2016-12-06T15:17:26.230 回答
0

我在开玩笑的测试中遇到了类似的问题,外部依赖于 webpack。

为了解决这个问题:

  1. 如果 __test__ 文件夹,我会在同一级别创建一个 __mocks__ 文件夹。
  2. 在其中,我创建了一个与依赖项同名的文件,在我的例子中是 jquery ($.js)。
  3. 在我的测试文件中,我使用 jest.mock 函数来引用模拟外部依赖项: jest.mock('$');

从开玩笑的文档: https ://facebook.github.io/jest/docs/manual-mocks.html

希望它可以帮助。

于 2017-02-23T19:47:01.493 回答