溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Jest測試中的定時器模擬

發(fā)布時間:2024-08-28 11:17:40 來源:億速云 閱讀:85 作者:小樊 欄目:編程語言

在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(),以清除所有定時器并避免潛在的錯誤。

向AI問一下細節(jié)

免責(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)容。

AI