如何在Jest中使用babel-preset-env

agm*_*984 3 babel node.js jestjs babel-node

我们正在更新API,Babel的Henry Zhu提醒我注意此预设,babel-preset-env以替换babel-preset-es2015and的需要babel-preset-es2018

现在,我在理解最简单的方式来处理所有事情时遇到了困难。

  • 我们的API使用节点v8.x和async / await,本机承诺
  • 我要传播算子
  • 我要管道操作员
  • 我想要导入/导出语法
  • 我想支持杰斯特
  • 我喜欢babel-node如何将API转换到内存中

如果我仅向您显示配置的当前位置,这将更加容易:

.babelrc

 {
   "presets": [
     "env",
       {
         "targets": {
           "node": "current"
         }
       },
     "jest"
   ]
 }
Run Code Online (Sandbox Code Playgroud)

package.json

 {
   "scripts": {
     "test": "node --harmony-async-await node_modules/jest/bin/jest.js",
     "start:local": "NODE_ENV=localhost npm run babel-node -- warpcore/server.js",
     "start": "npm run babel-node -- warpcore/server.js",
     "babel-node": "babel-node --presets=es2015,stage-2"
   },
   "dependencies": {
     "babel-polyfill": "^6.23.0"
   },
   "devDependencies": {
     "babel-cli": "^6.24.1",
     "babel-core": "^6.25.0",
     "babel-eslint": "^7.2.3",
     "babel-jest": "^20.0.3",
     "babel-preset-env": "^1.6.0",
     "babel-preset-es2015": "^6.24.1",
     "babel-preset-es2018": "^1.0.0",
     "babel-preset-stage-2": "^6.24.1",
     "jest": "^20.0.4"
   },
   "jest": {
     "testURL": "http://localhost:8080",
     "testEnvironment": "node"
   }
 }
Run Code Online (Sandbox Code Playgroud)

我不确定如何组织这些事情才能最好地实现我在上面的项目符号列表。

我应该做些什么改变?

  • 我认为babel-node脚本需要更改
  • 我怀疑我可以删除其中一些软件包
  • 我怀疑.babelrc档案不是最佳档案

agm*_*984 5

我想我可以使用了。解决方法如下:

.babelrc

问题中张贴的一个语法有错误,因为环境预设需要用括号括起来[](来自:http : //babeljs.io/docs/plugins/preset-env/

正确:

 {
   "presets": [
     ["env",
       {
         "targets": {
           "node": "current"
         }
       }],
     "jest"
   ]
 }
Run Code Online (Sandbox Code Playgroud)

package.json

问题中张贴的内容可以删除以下几项:

  {
     "scripts": {
       "test": "jest --verbose",
       "start:local": "cross-env NODE_ENV=localhost babel-node -- app.js",
       "babel-node": "babel-node --presets=env"
    },
    "dependencies": {
      "babel-cli": "^6.24.1",
      "babel-preset-env": "^1.6.0"
    },
    "devDependencies": {
      "babel-eslint": "^7.2.3",
      "babel-jest": "^20.0.3",
      "jest": "^20.0.4"
    },
    "jest": {
      "testURL": "http://localhost:8080",
      "testEnvironment": "node"
    }
  }
Run Code Online (Sandbox Code Playgroud)

我认为干净得多。.babelrc如果要显式包含或排除任何预设,或指定要支持的浏览器,则可以从文件中调制预设。


Ben*_*uer 5

如果您想使用Jest 替换babel-preset-env来替换babel-preset-es2015(已弃用),则必须确保将“ env”配置中的“ modules ”属性设置为“ commonjs” ”。

这是示例配置:

.babelrc

{     
  "env": {
    "test": {
      "plugins": [
        "transform-class-properties",
        "transform-object-rest-spread"
      ],
      "presets": [
        "jest",
        "react",
        [
          "env",
          {
            "debug": false,
            "modules": "commonjs",
            "targets": {
              "node": "current"
            },
            "useBuiltIns": true
          }
        ]
      ]
    }
  }
}
Run Code Online (Sandbox Code Playgroud)

您可以在中看到env.test预设env(即“ babel-preset-env”配置)的“模块”设置为“ commonjs”。这很重要,否则您将收到“ SyntaxError:意外的令牌导入”。

为了完整起见,这是一个简单的测试:

ExampleButton.test.jsx

import ExampleButton from './ExampleButton';
import React from 'react';
import renderer from 'react-test-renderer';

test('Example Test', () => {
  const component = renderer.create(<ExampleButton />);
  const json = component.toJSON();
  expect(json.type).toBe('button');
});
Run Code Online (Sandbox Code Playgroud)

ExampleButton.jsx

import React from 'react';

class ExampleButton extends React.Component {
  render() {
    return (
      <button onClick={this.props.onClick}>
        {this.props.text}
      </button>
    )
  }
}

export default ExampleButton;
Run Code Online (Sandbox Code Playgroud)

对于Babel设置,我使用了以下依赖项:

"babel-core": "6.26.0",
"babel-jest": "21.2.0",
"babel-plugin-transform-class-properties": "6.24.1",
"babel-plugin-transform-object-rest-spread": "6.26.0",
"babel-preset-env": "1.6.1",
"babel-preset-react": "6.24.1",
"jest": "21.2.1",
"react-test-renderer": "16.1.1",
Run Code Online (Sandbox Code Playgroud)

  • 当从Babel 6迁移到Babel 6具有默认模块的模块:7时,我发现这很困难,而Babel 7的预设环境则没有。但是为什么开玩笑需要commonjs模块呢?我从来没有真正理解过这一部分,无论我对commonjs,amd,umd等之间的区别有多少了解。对于为什么玩笑绝对需要commonjs有简单的解释吗? (2认同)