小编Unk*_*per的帖子

使用 Jest 测试 ES6 类会引发“不是构造函数”错误

我在这里发现了类似的问题,但似乎没有答案。

我正在尝试使用 Jest 测试 ES6 类,如下所示:

// src/myclass.js
export default class MyClass {
    constructor(options) {
        // currently this is empty while I debug this problem
    }
}
Run Code Online (Sandbox Code Playgroud)

和测试:

// test/myclass.test.js
import { MyClass } from '../src/myclass.js';

describe("Test Constructor", () => {

    test("doesn't throw error when constructed", async () => {
        expect(() => {
            const testMyClass = new MyClass();
        }).not.toThrowError();
    }

});
Run Code Online (Sandbox Code Playgroud)

当我运行测试时,Jest 抛出一个错误说:

类型错误:_myClass.MyClass 不是构造函数

我最好的猜测是这是 babel 配置的问题,但我似乎无法弄清楚。如果我更改MyClass为函数而不是类并删除导出/导入(即类前的做事方式),那么它会按预期工作。

这是我在 package.json 中的配置:

"devDependencies": {
    "@babel/core": "^7.1.2",
    "@babel/preset-env": …
Run Code Online (Sandbox Code Playgroud)

javascript jestjs babeljs babel-jest es6-class

18
推荐指数
2
解决办法
2万
查看次数

标签 统计

babel-jest ×1

babeljs ×1

es6-class ×1

javascript ×1

jestjs ×1