Skip to main content
 首页 » 编程设计

javascript之如何更改模拟导入的行为

2024年11月01日1452php

我对在 Jest 中模拟如何对实现进行单元测试感到很困惑。问题是我想模拟不同的预期行为。

有什么办法可以做到这一点?因为导入只能在文件的顶部并且能够模拟某些东西,所以必须在导入之前声明它。我还尝试传递一个本地函数,以便我可以覆盖该行为,但开 Jest 提示您不允许传递任何本地函数。

jest.mock('the-package-to-mock', () => ({ 
  methodToMock: jest.fn(() => console.log('Hello')) 
})); 
 
import * as theThingToTest from '../../../app/actions/toTest' 
import * as types from '../../../app/actions/types' 
 
it('test1', () => { 
  expect(theThingToTest.someAction().type).toBe(types.SOME_TYPE) 
}) 
 
it('test2', () => { 
  //the-package-to-mock.methodToMock should behave like something else 
  expect(theThingToTest.someAction().type).toBe(types.SOME_TYPE) 
}) 

内部如你所想 theThingToTest.someAction()使用 the-package-to-mock.methodToMock

请您参考如下方法:

您可以使用 spy 模拟并导入模拟模块。在您的测试中,您使用 mockImplementation 设置模拟的行为方式。 :

jest.mock('the-package-to-mock', () => ({ 
  methodToMock: jest.fn() 
})); 
import { methodToMock } from 'the-package-to-mock' 
 
it('test1', () => { 
  methodToMock.mockImplementation(() => 'someValue') 
}) 
 
it('test2', () => { 
  methodToMock.mockImplementation(() => 'anotherValue') 
})