用Jest模拟Typescript中导入函数的返回值

时间:2020-04-21 18:06:38

标签: javascript typescript unit-testing testing jestjs

我有一个函数,让我们称它为generateName,正如您已经猜到的那样,它会生成一个名称。问题是每次运行测试时都会生成一个新名称。

在我的一项测试中,我断言使用包含该名称的对象调用了一个函数。但是,名称不断变化。我可以检查对象是否具有属性名称,但是我真的不想这么做。

我的想法是我可以模拟generateName函数的返回值并执行类似的操作

Import { generateName } from ‘libs/generateName’

jest.fn(generateName).mockResolvedValue ( ‘hello’ )

expect ( spy ).toHaveBeenCalledWith ( 
      expect.objectContaining ( {
        name: 'houses',
      } )
)

1 个答案:

答案 0 :(得分:0)

您可以使用jest.mock(moduleName, factory, options)模拟libs/generateName模块。

例如 generateName.ts

export async function generateName() {
  const name = Math.random() + '';
  return name;
}

main.ts

import { generateName } from './generateName';

export function main() {
  return generateName();
}

main.test.ts

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

jest.mock('./generateName', () => {
  return {
    generateName: jest.fn(),
  };
});

describe('61350152', () => {
  it('should pass', async () => {
    (generateName as jest.MockedFunction<typeof generateName>).mockResolvedValueOnce('hello');
    const actual = await main();
    expect(actual).toBe('hello');
  });
});

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

 PASS  stackoverflow/61350152/main.test.ts (28.524s)
  61350152
    ✓ should pass (6ms)

----------|---------|----------|---------|---------|-------------------
File      | % Stmts | % Branch | % Funcs | % Lines | Uncovered Line #s 
----------|---------|----------|---------|---------|-------------------
All files |     100 |      100 |     100 |     100 |                   
 main.ts  |     100 |      100 |     100 |     100 |                   
----------|---------|----------|---------|---------|-------------------
Test Suites: 1 passed, 1 total
Tests:       1 passed, 1 total
Snapshots:   0 total
Time:        31.98s