Mih*_*šič 43 reactjs jestjs babeljs
这是我在package.json文件中的jest配置:
"jest": {
"automock": false,
"browser": true,
"moduleNameMapper": {
"\\.(jpg|jpeg|png|gif|eot|otf|webp|svg|ttf|woff|woff2|mp4|webm|wav|mp3|m4a|aac|oga)$": "./app/tests/mocks/FileMock.js",
"\\.(css|less)$": "identity-obj-proxy"
},
"moduleFileExtensions": [
"js",
"jsx"
],
"moduleDirectories": [
"node_modules"
],
"transform": {
"^.+\\.jsx?$": "./node_modules/babel-jest",
"\\.(jpg|jpeg|png|gif|eot|otf|webp|svg|ttf|woff|woff2|mp4|webm|wav|mp3|m4a|aac|oga)$": "./app/tests/mocks/FileTransformer.js"
},
"testEnvironment": "jsdom",
"testPathDirs": [
"./app/tests"
],
"testRegex": ".*.test.js",
"verbose": true
}
Run Code Online (Sandbox Code Playgroud)
和.babelrc文件位于我的根文件夹中:
{
"plugins": ["syntax-dynamic-import", "transform-runtime"],
"presets": [
[
"es2015",
{
"modules": false
}
],
"react",
"stage-0"
],
"env": {
"start": {
"presets": [
"react-hmre"
]
}
}
}
Run Code Online (Sandbox Code Playgroud)
根据在开玩笑的入门页面上找到的文档,这是我需要让babel工作的所有东西.
无论如何,这个测试:
import React from 'react';
import {shallow} from 'enzyme';
import Landing from '../components/Landing.component';
describe('<Landing/>', () => {
it('should render a header to the page', () => {
const landing = shallow(<Landing/>);
expect(landing.find('h1').text()).toBe('This is the Landing component');
});
});
Run Code Online (Sandbox Code Playgroud)
收益:
FAIL app/tests/Landing.component.test.js
? Test suite failed to run
/Users/shooshte/PersonalProjects/surviveJS/app/tests/Landing.component.test.js:1
({"Object.<anonymous>":function(module,exports,require,__dirname,__filename,global,jest){import React from 'react';
^^^^^^
SyntaxError: Unexpected token import
at transformAndBuildScript (node_modules/jest-runtime/build/transform.js:320:12)
Run Code Online (Sandbox Code Playgroud)
我究竟做错了什么?
Mih*_*šič 37
Jest将env变量设置为test,因此我必须将我的预设添加到.babelrc中的env设置:
{
"plugins": ["syntax-dynamic-import", "transform-runtime"],
"presets": [
[
"es2015",
{
"modules": false
}
],
"react",
"stage-0"
],
"env": {
"start": {
"presets": [
"react-hmre"
]
},
"test": {
"presets": ["es2015", "react", "stage-0"]
}
}
}
Run Code Online (Sandbox Code Playgroud)
小智 5
每个年度预设仅编译当年批准的内容。巴别预置-ENV内容替换
es2015,es2016,es2017,latest
在此基础上,对最新的配置,就必须使用/更换你的插件/预置es2015任何esX新的一个:env。
babel-preset-env使用npm install。.babelrc您应该相应地更新:{
"presets": [
"env",
"stage-0",
"react-native"
],
"plugins": ...
}
Run Code Online (Sandbox Code Playgroud)
有关Babel插件官方文档的更多信息。
?? 请记住,数组中插件/预设的顺序很重要。
就我而言,我有以下.babelrc配置:
{
"presets": [
["env", { "modules": false }],
"react",
"stage-2"
],
"plugins": [
"transform-runtime",
"transform-class-properties",
"react-hot-loader/babel"
]
}
Run Code Online (Sandbox Code Playgroud)
即使babel-env指定了我仍然收到错误。要修复它,我必须删除“模块”:错误标志。
Jest 不处理导入,因此它需要一个转换插件,这就是我必须添加该插件的原因:
babel-插件-动态-导入-节点
并更新我的 babel 设置以告诉 jest 使用此插件正确转换代码:
"env": {
"test": {
"plugins" : ["dynamic-import-node"]
}
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
47538 次 |
| 最近记录: |