您好,登錄后才能下訂單哦!
在Jest測試中,有時候需要對定時器(如setTimeout、setInterval等)進行模擬,以便更好地控制測試流程和避免實際等待
要在Jest中模擬定時器,你可以使用jest.useFakeTimers()
方法。這會告訴Jest使用模擬的定時器而不是實際的定時器。然后,你可以使用jest.advanceTimersByTime()
或jest.runOnlyPendingTimers()
方法來控制定時器的執(zhí)行。
下面是一個簡單的示例:
// myFunction.js
function myFunction(callback) {
setTimeout(() => {
callback('Hello, World!');
}, 1000);
}
module.exports = myFunction;
// myFunction.test.js
const myFunction = require('./myFunction');
describe('myFunction', () => {
beforeEach(() => {
jest.useFakeTimers(); // 使用模擬的定時器
});
afterEach(() => {
jest.clearAllTimers(); // 清除所有定時器
});
it('should call the callback after 1 second', () => {
const callback = jest.fn();
myFunction(callback);
expect(callback).not.toBeCalled(); // 此時回調(diào)函數(shù)還未被調(diào)用
jest.advanceTimersByTime(500); // 模擬過去了500ms
expect(callback).not.toBeCalled(); // 回調(diào)函數(shù)仍未被調(diào)用
jest.advanceTimersByTime(500); // 再模擬過去了500ms
expect(callback).toBeCalledWith('Hello, World!'); // 回調(diào)函數(shù)現(xiàn)在應(yīng)該被調(diào)用了
});
});
在這個示例中,我們首先使用jest.useFakeTimers()
啟用模擬定時器。然后,在測試用例中,我們使用jest.advanceTimersByTime()
方法來模擬時間的流逝。最后,我們檢查回調(diào)函數(shù)是否在預(yù)期的時間內(nèi)被調(diào)用。
注意:當(dāng)使用模擬定時器時,請確保在每個測試用例之后調(diào)用jest.clearAllTimers()
,以清除所有定時器并避免潛在的錯誤。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。