我遇到与此问题类似的问题:
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),因为由于某种原因,使用较新版本的节点会引发错误。
非常感谢您的帮助!
答案 0 :(得分:1)
感谢@JMM帮助我隔离源
如果您在webpack中使用别名来解析目录路径,您应该将它们包含在您的mocha运行脚本中,或者使用节点模块模拟它们