reactjs - 语法错误: Unexpected reserved word on running mocha with enzyme

标签 reactjs mocha.js enzyme

使用 Mocha 进行 enzyme 测试。我收到错误

(function (exports, require, module, __filename, __dirname) { import React fro ^^^^^^

SyntaxError: Unexpected reserved word

我的测试文件中有下面给出的测试脚本

import React from 'react';
import { assert } from 'chai';
import { render } from 'enzyme';
import Book from '../src/Book';

describe("Book", () => {
it("render text", () => {
const wrapper = render(<Book author="Dan Abramov" title="Redux and ReactJS" />);

assert.equal(wrapper.text(), 'Redux and ReactJS by Dan Abramov');
});
});

我尝试用 require 替换 import,但没有成功。如果有人伸出援手来解决这个问题,那就太好了。

编辑 我在下面包含了 package.json 文件,

{
"name": "test-client",
"version": "0.0.1",
"description": "test companies client.",
"repository": "https://github.com/Test/test-client",
"main": "js/app.js",
"directories": {
"test": "test"
},
"scripts": {
"test": "mocha"
},

"dependencies": {
"classnames": "2.2.*",
"clone": "^1.0.2",
"es5-shim": "4.1.*",
"es6-object-assign": "1.0.*",
"es6-promise": "3.0.*",
"flux": "^2.1.1",
"font-awesome": "^4.5.0",
"form-data": "^1.0.0-rc3",
"hashids": "^1.0.2",
"howler": "^1.1.29",
"isomorphic-fetch": "^2.2.1",
"js-cookie": "^2.1.0",
"json3": "3.3.*",
"keymirror": "0.1.*",
"normalize.css": "^4.0.0",
"react": "^15.0.1",
"react-addons-create-fragment": "^15.0.1",
"react-dnd": "^2.1.4",
"react-dnd-html5-backend": "^2.1.2",
"react-dom": "^15.0.1",
"react-infinite": "^0.9.2",
"react-paginate": "^1.0.4",
"react-tooltip": "^2.0.0",
"socket.io-client": "1.3.*",
"twemoji": "^2.0.5",
"unorm": "^1.4.1"
},
"devDependencies": {
"browserify": "^6.2.0",
"catw": "^1.0.1",
"dockerode": "^2.0.4",
"dotenv": "^2.0.0",
"envify": "^3.4.0",
"gulp-awspublish": "^3.0.2",
"less": "^2.6.1",
"reactify": "^0.15.2",
"watchify": "^3.4.0"
},
"browserify": {
"transform": [
  "reactify",
  "envify"
]
},
"scripts": {
"start-css": "catw -c 'lessc -' 'css/src/*.less' -o css/bundle.css -v",
"start-js": "watchify -o js/bundle.js -v -d js/app.js",
"start": "npm run start-css & npm run start-js"
},
"author": "Test"
}

最佳答案

您的测试使用 ES2015,为此您需要一个类似 Babel 的转译器.

要使其与 Mocha 一起使用,您首先需要安装一些软件包:

$ npm install --save-dev babel-core babel-preset-es2015 babel-preset-react

接下来,将以下内容添加到您的 package.json 中:

"babel": {
  "presets": [ "es2015", "react" ]
}

或者,如果您没有 package.json,请在工作目录中创建一个名为 .babelrc 的文件,其中包含以下内容:

{
  "presets": [ "es2015", "react" ]
}

最后,告诉 Mocha 使用 Babel 转译器:

$ mocha --compilers js:babel-core/register test.js

关于reactjs - 语法错误: Unexpected reserved word on running mocha with enzyme,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37679590/

相关文章:

reactjs - React - 如果输入值 = {name} 则无法输入

reactjs - 用 Jest 测试 onChange 事件

javascript - 测试 react 组件 : Jest encountered an unexpected token

javascript - Chai deep 包含对嵌套对象的断言

node.js - nodejs mocha如何处理近似匹配

webpack - 将 Mocha 与 Babel 结合使用时出现意外的 token 导入

reactjs - enzyme 和 react 测试库之间的区别

javascript - redux-状态发生变化但组件不显示重新渲染的 View

javascript - 在 React 生命周期方法中使用本地方法

reactjs - 如何在 useState prevState 映射中使用 "if"