使用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")
});
这样,我的最后两次测试将失败,因为在第一次测试中设置的模拟仍处于活动状态。
答案 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");
})
);