單元測試可讓您在瀏覽器之外,獨立測試擴充功能的部分程式碼。舉例來說,您可以編寫單元測試,確保輔助方法能正確將值寫入儲存空間。
不使用擴充功能 API 編寫的程式碼,可以使用 Jest 等架構進行正常測試。為讓程式碼更容易以這種方式進行測試,建議您使用依附元件插入等技術,這類技術有助於在較低層級的實作中移除對 chrome 命名空間的依附元件。
如果您需要測試包含擴充功能 API 的程式碼,請考慮使用模擬資料。
範例:在 Jest 中使用模擬資料
建立 jest.config.js
檔案,宣告會在所有測試前執行的設定檔:
jest.config.js:
module.exports = {
setupFiles: ['<rootDir>/mock-extension-apis.js']
};
在 mock-extension-apis.js
中,為您要呼叫的特定函式新增實作項目:
mock-extension-apis.js:
global.chrome = {
tabs: {
query: async () => { throw new Error("Unimplemented.") };
}
};
接著,使用 jest.spy
在測試中模擬傳回值:
test("getActiveTabId returns active tab ID", async () => {
jest.spyOn(chrome.tabs, "query").mockResolvedValue([{
id: 3,
active: true,
currentWindow: true
}]);
expect(await getActiveTabId()).toBe(3);
});
後續步驟
為確保擴充功能函式運作正常,建議您新增端對端測試。如需完整教學課程,請參閱「使用 Puppeteer 測試 Chrome 擴充功能」。