解决jest处理es模块

Posted xueyoucd

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了解决jest处理es模块相关的知识,希望对你有一定的参考价值。

解决jest处理es模块

问题场景

项目使用jest进行测试时, 当引入外部库是es模块时, jest无法处理导致报错.

Test suite failed to run

    Jest encountered an unexpected token

    This usually means that you are trying to import a file which Jest cannot parse, e.g. it's not plain javascript.

    By default, if Jest sees a Babel config, it will use that to transform your files, ignoring "node_modules".

    Here's what you can do:
     ? To have some of your "node_modules" files transformed, you can specify a custom "transformIgnorePatterns" in your config.
     ? If you need a custom transformation specify a "transform" option in your config.
     ? If you simply want to mock your non-JS modules (e.g. binary assets) you can stub them out with the "moduleNameMapper" config option.


Details:

/home/xueyou/workspace/projects/node_modules/lodash-es/lodash.js:10

import * as lodash from 'lodash-es'

SyntaxError: Unexpected token *

解决方法

查阅issues发现, 目前jest不支持em模块, 只有通过babel去处理了

  1. 安装依赖

    yarn add --dev babel-jest @babel/core @babel/preset-env babel-plugin-transform-es2015-modules-commonjs

  2. 配置babel.config.js

    module.exports = {
        presets: [
            [
                "@babel/preset-env",
                {
                    targets: {
                        node: "current"
                    }
                }
            ]
        ],
        plugins: ["transform-es2015-modules-commonjs"]
    };
    
  3. 配置jest.config.js

    module.exports = {
        preset: "ts-jest",
        testMatch: ["<rootDir>/tests/**/*.(spec|test).ts?(x)"],
        transform: {
            // 将.js后缀的文件使用babel-jest处理
            "^.+\.js$": "babel-jest",
            "^.+\.(ts|tsx)$": "ts-jest"
        },
        // 下面非要从重要, 将不忽略 lodash-es, other-es-lib 这些es库, 从而使babel-jest去处理它们
        transformIgnorePatterns: ["<rootDir>/node_modules/(?!(lodash-es|other-es-lib))"]
    };
    

    脚注

以上是关于解决jest处理es模块的主要内容,如果未能解决你的问题,请参考以下文章

带有 ES6 模块的 babel-jest

Jest,ts-jest,带有 ES 模块导入的打字稿:找不到模块

用 Jest 测试 ES6 模块

Node v13 / Jest / ES6 — 原生支持没有 babel 或 esm 的模块

jest + typescript + es6 模块(又一次,2019 年)- SyntaxError: Unexpected token export

测试具有 RequireJS 依赖项的 es6 模块时,Jest 中的“未定义定义”