React 基础知识~单元测试/自定义钩子

2024-10-27 18:23:10 编辑:抖狐科技 来源:摘自互联网

  • 当我测试自定义钩子组件时,我使用从@testing-library/react'导入的renderhook和从react-dom/test-utils'导入的act。

・src/app.tsx

import "./app.css";
import counter from "./component/counter/counter";

function app() {
  return (
    <p classname="app">
      <counter></counter>
</p>
  );
}

export default app;

登录后复制

・src/component/counter/counter.tsx

import react, { usestate } from "react";
import { usecounter } from "../../hooks/usecounter";

const counter = () =&gt; {
const { count, increment } = usecounter({ initialcount: 10 });

  return (
    <p>
      <h1>{count}</h1>
      <button onclick="{()"> increment()}&gt;increment</button>
    </p>
  );
};

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 = {}) =&gt; {
  const [count, setcount] = usestate(initialcount);
  const increment = () =&gt; setcount((prev) =&gt; 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", () =&gt; {
  test("Should render the initial count", () =&gt; {
    const { result } = renderHook(useCounter, {
      initialProps: { initialCount: 10 },
    });
    expect(result.current.count).toBe(10);
  });

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

登录后复制

  • 当我传递一个props时,在本例中它是initialcount(= 10),我添加了一个属性initialprops:{initialcount:10}。

  • 当我测试自定义钩子的函数(在本例中为increment())时,我使用该行为并在回调中调用increment()。

・成功
React 基础知识~单元测试/自定义钩子

・失败
React 基础知识~单元测试/自定义钩子

・显示动作
React 基础知识~单元测试/自定义钩子

以上就是React 基础知识~单元测试/自定义钩子的详细内容,更多请关注抖狐科技其它相关文章!

本站文章均为抖狐网站建设摘自权威资料,书籍,或网络原创文章,如有版权纠纷或者违规问题,请即刻联系我们删除,我们欢迎您分享,引用和转载,我们谢绝直接复制和抄袭!感谢...
我们猜你喜欢