使用jestjs进行单元测试隔离

时间:2017-04-07 09:57:03

标签: unit-testing ecmascript-6 jestjs

使用jest处理测试隔离的最佳方法是什么?我想用静态方法测试ES6类,并模拟单元测试不直接关注的方法。

我的班级档案:

class Util {

    static getFirstName() {
        return "John";
    }

    static getLastName() {
        return "Doe";
    }

    static getFullName(){
        return `${Util.getFirstName()} ${Util.getLastName()}`;
    }
}

我的测试文件:

import Util from '../src/util';

test("Test getFullName", () => {
    Util.getFirstName = jest.fn().mockReturnValue("MockFirstName");
    Util.getLastName = jest.fn().mockReturnValue("MockLastName");

    expect(Util.getFullName()).toBe("MockFirstName MockLastName")
});

test("Test getFirstName", () => {
    expect(Util.getFirstName()).toBe("John")
});

test("Test getLastName", () => {
    expect(Util.getLastName()).toBe("Doe")
});

这样,我的最后两次测试将失败,因为在第一次测试中设置的模拟仍处于活动状态。

1 个答案:

答案 0 :(得分:2)

假设这些import语句正在转换为require,您应该可以使用resetModules

beforeEach(() => {
    // Clears the require cache so that a new module is require'd
    // before each test.
    jest.resetModules();
});

然后在每个测试中,您需要要求模块:

test("name", () => {
    const { default: Util } = require("../src/util");
});

或者,如果您可以使用动态导入语法:

test("name", () => import("../src/util")
    .then(({ default: Util }) => {
        expect(Util.getFirstName()).toBe("John");
    })
);