javascript - 在jestjs中模拟嵌套函数

标签 javascript unit-testing jestjs method-chaining

我有一个非常复杂的对象,我正在使用它来模拟 DataTable() 对象以进行测试。

const obj = {
  DataTable: () => {
    return {
      columns: () => {
        return {
          data: () => {
            return {
              eq: () => {
                return {
                  indexOf: jest.fn(),
                };
              },
            };
          },
          visible: () => {
            return jest.fn();
          },
        };
      },
    };
  },
};

在我的测试代码中,我试图监视其中的一些函数,但它总是返回未定义的。有没有办法模拟深度嵌套函数的返回值?

    jest.spyOn(obj.DataTable().columns().data().eq(), 'indexOf').mockReturnValue('test');
    console.log(obj.DataTable().columns().data().eq().indexOf()); // returns undefined, should return 'test'

最佳答案

这是单元测试解决方案:

index.ts:

import { obj } from './obj';

export function main() {
  return obj.DataTable().columns().data().eq().indexOf();
}

obj.ts:

export const obj = {
  DataTable: () => {
    return {
      columns: () => {
        return {
          data: () => {
            return {
              eq: () => {
                return {
                  indexOf: () => 'real data',
                };
              },
            };
          },
        };
      },
    };
  },
};

index.test.ts:

import { main } from './';
import { obj } from './obj';

describe('61396089', () => {
  afterEach(() => {
    jest.restoreAllMocks();
  });
  it('should pass', () => {
    const mockDataTable = {
      columns: jest.fn().mockReturnThis(),
      data: jest.fn().mockReturnThis(),
      eq: jest.fn().mockReturnThis(),
      indexOf: jest.fn().mockReturnValueOnce('fake data'),
    };
    jest.spyOn(obj, 'DataTable').mockImplementationOnce(() => mockDataTable);
    const actual = main();
    expect(actual).toBe('fake data');
    expect(mockDataTable.columns).toBeCalledTimes(1);
    expect(mockDataTable.data).toBeCalledTimes(1);
    expect(mockDataTable.eq).toBeCalledTimes(1);
    expect(mockDataTable.indexOf).toBeCalledTimes(1);
  });
});

带有覆盖率报告的单元测试结果:

 PASS  stackoverflow/61396089/index.test.ts (20.978s)
  61396089
    ✓ should pass (8ms)

----------|---------|----------|---------|---------|-------------------
File      | % Stmts | % Branch | % Funcs | % Lines | Uncovered Line #s 
----------|---------|----------|---------|---------|-------------------
All files |   44.44 |      100 |   16.67 |   44.44 |                   
 index.ts |     100 |      100 |     100 |     100 |                   
 obj.ts   |   16.67 |      100 |       0 |   16.67 | 3-10              
----------|---------|----------|---------|---------|-------------------
Test Suites: 1 passed, 1 total
Tests:       1 passed, 1 total
Snapshots:   0 total
Time:        23.889s

源代码:https://github.com/mrdulin/react-apollo-graphql-starter-kit/tree/master/stackoverflow/61396089

关于javascript - 在jestjs中模拟嵌套函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61396089/

相关文章:

python - Python Flask 单元测试中登录测试失败

javascript - Angular 2+ 对调用 httpclient get 的服务进行单元测试

javascript - 如何使用 Jest 单元测试触发 transitionend

javascript - 单击时图像突出显示

javascript - react 路由器状态?

unit-testing - Spring 和 Mockito - 忽略传递依赖

reactjs - Jest 单元测试 - 使用 props 模拟组件

jestjs - Jest "Cannot find module"在 CI 中带有 typescript 路径

javascript - Angular组件继承,保留父html

javascript - 从 API 随机生成国家/地区名称