В настоящее время я пытаюсь оценить различные рамки тестирования, которые работают с React, и оказывается, что Jest находится в моем списке. Тем не менее, я пытаюсь использовать статические свойства, изложенные здесь: https://github.com/jeffmo/es-class-fields-and-static-properties.SyntaxError: Неожиданный токен static
Итак, я взял учебник, который дается на домашней странице Jest, и добавил статический propTypes свойство, мой код выглядит следующим образом:
import React from 'react';
class CheckboxWithLabel extends React.Component {
static defaultProps = {}
constructor(props) {
super(props);
this.state = {isChecked: false};
// since auto-binding is disabled for React's class model
// we can prebind methods here
// http://facebook.github.io/react/blog/2015/01/27/react-v0.13.0-beta-1.html#autobinding
this.onChange = this.onChange.bind(this);
}
onChange() {
this.setState({isChecked: !this.state.isChecked});
}
render() {
return (
<label>
<input
type="checkbox"
checked={this.state.isChecked}
onChange={this.onChange}
/>
{this.state.isChecked ? this.props.labelOn : this.props.labelOff}
</label>
);
}
}
module.exports = CheckboxWithLabel;
Когда я запускаю тесты (тест НПМ или шутя), Он выдает следующее сообщение об ошибке:
➜ jest
Using Jest CLI v0.8.2, jasmine1
FAIL __tests__/CheckboxWithLabel-test.js
● Runtime Error
SyntaxError: Desktop/jest/examples/react/CheckboxWithLabel.js: Unexpected token (5:22)
Мой файл package.json выглядит следующим образом:
{
"dependencies": {
"react": "~0.14.0",
"react-dom": "~0.14.0"
},
"devDependencies": {
"babel-jest": "*",
"babel-preset-es2015": "*",
"babel-preset-react": "*",
"jest-cli": "*",
"react-addons-test-utils": "~0.14.0"
},
"scripts": {
"test": "jest"
},
"jest": {
"scriptPreprocessor": "<rootDir>/node_modules/babel-jest",
"unmockedModulePathPatterns": [
"<rootDir>/node_modules/react",
"<rootDir>/node_modules/react-dom",
"<rootDir>/node_modules/react-addons-test-utils",
"<rootDir>/node_modules/fbjs"
],
"modulePathIgnorePatterns": [
"<rootDir>/node_modules/"
]
}
}
A Какие идеи мне не хватает?
Спасибо.
Спасибо! После этого есть еще одна ошибка: «SyntaxError: Неожиданный токен ..», любые идеи? – HappyCry
Являются ли плагины конкретными для Babel 6? У меня это работает в 5.x, просто установив этап 0. @HappyCry указывает на конкретную строку? –
@MattMolnar: да, это для Вавилона 6. –