Jest:如何将参数传递给mock构造函数?

问题描述 投票:1回答:1

如果我想创建一个ES6类的实例方法的模拟实现,我会这样做

// ExampleClass.js
export class ExampleClass {
    constructor(someValue) {
        this.a = someValue;
    }

    exampleMethod(anotherValue) {
        // do something with 'anotherValue'
    }
}

// OtherModule.js
import {ExampleClass} from './ExampleClass';
export const fooBar = () => {
    const ex = new ExampleClass("hello world");
    ex.exampleMethod("another value");
};

// ExampleClass.test.js
import {fooBar} from './OtherModule';
import {ExampleClass} from './ExampleClass';
jest.mock('./ExampleClass');

it('try to create a mock of ExampleClass', () => {
    ExampleClass.mockClear();

    fooBar();

    // to verify values for of instance method "exampleMethod" of ExampleClass instance
    expect(ExampleClass.mock.instances[0].exampleMethod.calls.length).toBe(1);
    expect(ExampleClass.mock.instances[0].exampleMethod.calls[0][0]).toBe("another value");

    // How to verify values for **constructor** of ExampleClass ?????
    // expect(ExampleClass.mock.instances[0].constructor.calls.length).toBe(1);
    // expect(ExampleClass.mock.instances[0].constructor.calls[0][0]).toBe("another value");
});

我不知道怎么做(以及在评论代码中提到的那种)是如何监视/访问构造函数的值(而不仅仅是实例方法)。

任何帮助将不胜感激! ❤

javascript jestjs
1个回答
0
投票

ExampleClass是构造函数,因为整个模块是自动模拟的,所以它已经被设置为模拟函数:

import {fooBar} from './OtherModule';
import {ExampleClass} from './ExampleClass';
jest.mock('./ExampleClass');

it('try to create a mock of ExampleClass', () => {
    ExampleClass.mockClear();

    fooBar();

    // to verify values for of instance method "exampleMethod" of ExampleClass instance
    expect(ExampleClass.mock.instances[0].exampleMethod.mock.calls.length).toBe(1);  // SUCCESS
    expect(ExampleClass.mock.instances[0].exampleMethod.mock.calls[0][0]).toBe("another value");  // SUCCESS

    // Verify values for **constructor** of ExampleClass
    expect(ExampleClass.mock.calls.length).toBe(1);  // SUCCESS
    expect(ExampleClass.mock.calls[0][0]).toBe("hello world");  // SUCCESS
});
© www.soinside.com 2019 - 2024. All rights reserved.