具有Jest的CommonJS模块的多个手动模拟

时间:2015-02-20 22:56:21

标签: unit-testing mocking jestjs

我使用 mocks 文件夹看到了Jest模拟的文档,但我希望能够在一次测试中使用一个模拟模拟一个模块,并在另一个测试中模拟与另一个模拟相同的模块。

例如,使用重新连接和茉莉,您可以执行以下操作:

//module2.js
module.exports = {
    callFoo: function () {
        require('moduleToMock').foo();
    }
};

//module2Test.js
describe("test1", function () {
    var mock;
    beforeEach(function () {
        var rewire = require('rewire');
        mock = jasmine.createSpyObj('mock', ['foo']);
    });
    it("should be mocked with type1", function () {
        mock.foo.and.returnValue("type1");
        rewire('moduleToMock', mock);
        var moduleUsingMockModule = require('module2');
        expect(moduleUsingMockModule.callFoo()).toEqual("type1");
    });
});
describe("test2", function () {
    it("should be mocked with type2", function () {
        mock.foo.and.returnValue("type2");
        rewire('moduleToMock', mock);
        var moduleUsingMockModule = require('module2');
        expect(moduleUsingMockModule.callFoo()).toEqual("type2");
    });
});

这可能与Jest有关吗?不同之处在于我在测试中定义了模拟,而不是在用于所有测试的某个外部文件夹中。

1 个答案:

答案 0 :(得分:2)

是的,你的模拟将如下所示:

module.exports = {
    foo: jest.genMockFunction();
}

然后,您将能够在测试用例中配置自定义行为:

var moduleToMock = require('moduleToMock');

describe('...', function() {
    it('... 1', function() {
        moduleToMock.foo.mockReturnValue('type1')

        expect(moduleToMock.foo).toBeCalled();
        expect(moduleUsingMockModule.callFoo()).toEqual("type1");
    });

    it('... 2', function() {
        moduleToMock.foo.mockReturnValue('type2')

        expect(moduleToMock.foo).toBeCalled();
        expect(moduleUsingMockModule.callFoo()).toEqual("type2");
    });
});