ホームページ  >  記事  >  ウェブフロントエンド  >  React の基本 ~単体テスト/カスタムフック

React の基本 ~単体テスト/カスタムフック

Linda Hamilton
Linda Hamiltonオリジナル
2024-11-01 11:06:02844ブラウズ
  • カスタム フック コンポーネントをテストするときは、@testing-library/react' からインポートされた renderHook と、react-dom/test-utils' からインポートされた act を使用します。

・src/App.tsx

import "./App.css";
import Counter from "./component/counter/Counter";

function App() {
  return (
    <div className="App">
      <Counter />
    </div>
  );
}

export default App;

・src/component/counter/Counter.tsx

import React, { useState } from "react";
import { useCounter } from "../../hooks/useCounter";

const Counter = () => {
const { count, increment } = useCounter({ initialCount: 10 });

  return (
    <div>
      <h1>{count}</h1>
      <button onClick={() => increment()}>Increment</button>
    </div>
  );
};

export default Counter;

・src/hooks/useCounter.tsx

import React, { useState } from "react";
import { UseCounterProps } from "./useCounter.type";

type UseCounterProps = {
  initialCount?: number;
};


export const useCounter = ({ initialCount = 0 }: UseCounterProps = {}) => {
  const [count, setCount] = useState(initialCount);
  const increment = () => setCount((prev) => prev + 1);

  return { count, increment };
};

・src/hooks/useCounter.test.tsx

import { renderHook } from "@testing-library/react";
import { useCounter } from "./useCounter";
import { act } from "react-dom/test-utils";

describe("useCounter", () => {
  test("Should render the initial count", () => {
    const { result } = renderHook(useCounter, {
      initialProps: { initialCount: 10 },
    });
    expect(result.current.count).toBe(10);
  });

  test("Increment the  count", () => {
    const { result } = renderHook(useCounter);
    act(() => {
      result.current.increment();
    });
    expect(result.current.count).toBe(1);
  });
});

  • 小道具を渡すとき、この場合はinitialCount(=10)、initialProps: {initialCount: 10 }.

  • というプロパティを追加します。
  • カスタム フックの関数 (この場合は increment()) をテストするときは、act を使用してコールバック内で increment() を呼び出します。

・成功
React Basics~unit test/custom hook

・失敗
React Basics~unit test/custom hook

・表示アクション
React Basics~unit test/custom hook

以上がReact の基本 ~単体テスト/カスタムフックの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。