您好,登錄后才能下訂單哦!
Jest 是一個(gè)流行的 JavaScript 測(cè)試框架,可以與 React Hooks 一起使用來進(jìn)行組件和功能的單元測(cè)試
npm install --save-dev jest @testing-library/react @testing-library/jest-dom
jest.config.js
文件,添加以下內(nèi)容:module.exports = {
preset: "react",
testEnvironment: "jsdom",
};
useCounter.js
的自定義 Hooks 文件,內(nèi)容如下:import { useState } from "react";
const useCounter = (initialValue = 0) => {
const [count, setCount] = useState(initialValue);
const increment = () => {
setCount((prevCount) => prevCount + 1);
};
const decrement = () => {
setCount((prevCount) => prevCount - 1);
};
return { count, increment, decrement };
};
export default useCounter;
為此 Hooks 編寫測(cè)試用例 useCounter.test.js
:
import { renderHook, act } from "@testing-library/react-hooks";
import useCounter from "./useCounter";
describe("useCounter", () => {
it("should increment counter", () => {
const { result } = renderHook(() => useCounter());
act(() => {
result.current.increment();
});
expect(result.current.count).toBe(1);
});
it("should decrement counter", () => {
const { result } = renderHook(() => useCounter());
act(() => {
result.current.decrement();
});
expect(result.current.count).toBe(-1);
});
});
package.json
中添加一個(gè)名為 test
的腳本:"scripts": {
"test": "jest"
}
然后運(yùn)行 npm test
,Jest 將自動(dòng)查找并運(yùn)行所有測(cè)試用例。
這只是一個(gè)簡(jiǎn)單的示例,實(shí)際上你可以根據(jù)需要編寫更復(fù)雜的測(cè)試用例來覆蓋各種場(chǎng)景。記住始終確保在執(zhí)行任何副作用(例如 API 調(diào)用)之前使用 act()
函數(shù)包裝操作。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。