React / Mocha测试:找不到导入的组件

时间:2016-05-05 01:34:04

标签: reactjs mocha babeljs redux

我遇到与此问题类似的问题:

Unable to import a React Component in my Mocha test

问题是我已经将这两个更改合并在一起,当我尝试测试组件时,Mocha仍然没有检测到我的“import”语句。

我在我的callstack中看到(附在底部),我正在加载babel-register。

文件如下

文件结构

/client
    /src
      /components
         //test components
      /containers
    /test
      /components
      /dom.js && helper.js

的package.json

"babel": {
    "presets": ["es2015"]
  }
"scripts": {
    "start": "node bin/server.js",
    "test": "mocha --compilers js:babel-register \"./test/**/*.js\" --require ignore-styles",
    "test:watch": "npm run test -- --watch"
  },

mocha.opt文件

--require ./test/test_helper.js
--require ./test/dom.js 
--recursive

编辑:从组件文件中添加了导入语句

//来自组件

import { Modal } from 'components/Modal'

//模态组件

export class RecipeModal extends Component {

这是我尝试运行mocha时收到的调用堆栈/错误消息

Warning: require('react/addons') is deprecated. Access using require('react-addons-{addon}') instead.
Error: Cannot find module 'components/RecipeModal'
    at Function.Module._resolveFilename (module.js:336:15)
    at Function.Module._load (module.js:286:25)
    at Module.require (module.js:365:17)
    at require (module.js:384:17)
    at Object.<anonymous> (index.js:11:1)
    at Module._compile (module.js:434:26)

    at loader (/Users/ACKeepingitCoo/Desktop/ketoBot/client/node_modules/babel-register/lib/node.js:158:5)
    at Object.require.extensions.(anonymous function) [as .js] (/Users/ACKeepingitCoo/Desktop/ketoBot/client/node_modules/babel-register/lib/node.js:168:7)

    at Module.load (module.js:355:32)
    at Function.Module._load (module.js:310:12)
    at Module.require (module.js:365:17)
    at require (module.js:384:17)
    at Object.<anonymous> (Recipes_test.js:2:1)
    at Module._compile (module.js:434:26)
    at loader (/Users/ACKeepingitCoo/Desktop/ketoBot/client/node_modules/babel-register/lib/node.js:158:5)
    at Object.require.extensions.(anonymous function) [as .js] (/Users/ACKeepingitCoo/Desktop/ketoBot/client/node_modules/babel-register/lib/node.js:168:7)

    at Module.load (module.js:355:32)
    at Function.Module._load (module.js:310:12)
    at Module.require (module.js:365:17)
    at require (module.js:384:17)
    at /Users/ACKeepingitCoo/Desktop/ketoBot/client/node_modules/mocha/lib/mocha.js:219:27
    at Array.forEach (native)
    at Mocha.loadFiles (/Users/ACKeepingitCoo/Desktop/ketoBot/client/node_modules/mocha/lib/mocha.js:216:14)
    at Mocha.run (/Users/ACKeepingitCoo/Desktop/ketoBot/client/node_modules/mocha/lib/mocha.js:468:10)
    at loadAndRun (/Users/ACKeepingitCoo/Desktop/ketoBot/client/node_modules/mocha/bin/_mocha:359:22)
    at Object.<anonymous> (/Users/ACKeepingitCoo/Desktop/ketoBot/client/node_modules/mocha/bin/_mocha:376:3)
    at Module._compile (module.js:434:26)
    at Object.Module._extensions..js (module.js:452:10)
    at Module.load (module.js:355:32)
    at Function.Module._load (module.js:310:12)
    at Function.Module.runMain (module.js:475:10)
    at startup (node.js:117:18)
    at node.js:951:3

其他(可能相关的信息)

我正在运行节点版本管理器(节点4.0),因为由于某种原因,使用较新版本的节点会引发错误。

非常感谢您的帮助!

1 个答案:

答案 0 :(得分:1)

感谢@JMM帮助我隔离源

如果您在webpack中使用别名来解析目录路径,您应该将它们包含在您的mocha运行脚本中,或者使用节点模块模拟它们

Using webpack aliases in mocha tests