嘲笑jestjs中的嵌套函数

我有一个非常复杂的对象,我正在用它来模拟一个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.commrdulinreact-apollo-graphql-starter-kittreemasterstackoverflow61396089。

给TA打赏
共{{data.count}}人
人已打赏
未分类

window.tableau在IE Edge中未定义。

2022-9-8 14:07:17

未分类

如何在svg上停止蒙版?

2022-9-8 14:07:19

0 条回复 A文章作者 M管理员
    暂无讨论,说说你的看法吧
个人中心
购物车
优惠劵
今日签到
有新私信 私信列表
搜索