React 组件测试【React Testing Library】

文章目录

前言

  • Testing Library 是一个以用户为中心前端测试 工具集,关注用户行为和交互,而不是组件的内部实现细节。这意味着测试更加关注组件的行为,而不是具体的实现方式
  • 基于 DOM Testing Library,为 React、Angular、Vue 等框架提供了特定的封装,如 React Testing LibraryVue Testing LibraryAngular Testing Library
  • @testing-library/user-event 提供通用的用户事件模拟功能,不依赖于特定框架;@testing-library/jest-dom 为 Jest 测试框架提供自定义断言器

React Testing Library 是一个用于测试 React 组件的轻量级库,它提供了一组工具来模拟用户交互、检查组件的状态和属性,并与 Jest 等测试框架配合使用。它的设计理念是尽可能地模拟用户行为,使测试更加贴近真实场景。

安装和配置

安装

使用 npm 或 yarn 安装 React Testing Library 和 babel 相关依赖:

bash 复制代码
npm install --save-dev jest @babel/core @babel/preset-env @babel/preset-react @babel/preset-typescript babel-jest jest-environment-jsdom @testing-library/dom @testing-library/jest-dom @testing-library/react
# 或者
yarn add --dev jest @babel/core @babel/preset-env @babel/preset-react @babel/preset-typescript babel-jest jest-environment-jsdom @testing-library/dom @testing-library/jest-dom @testing-library/react

配置 Babel

在项目根目录下创建 .babelrc 文件

json 复制代码
{
  "presets": [
    "@babel/preset-env",
    "@babel/preset-react",
    "@babel/preset-typescript"
  ]
}

配置 Jest

在项目根目录下修改 package.json 文件中的 scripts 部分:

json 复制代码
{
  "scripts": {
    "test": "jest"
  }
}

在项目根目录下创建 jest.config.js 文件:

javascript 复制代码
module.exports = {
  modulePaths: ["src"],
  moduleNameMapper: {
    "\\.(css|less)$": "<rootDir>/__mocks__/styleMock.js",
  },
  // 入口文件
  setupFilesAfterEnv: ["<rootDir>/src/setupTests.js"],
  // 使用babel对jsx文件预处理
  transform: {
    "^.+\\.[jt]sx?$": "babel-jest",
  },
};

src 目录下创建 setupTests.js 文件:

javascript 复制代码
import "@testing-library/jest-dom";

基本用法

组件编写

src目录下创建 Hello.tsx 文件:

tsx 复制代码
import React, { useState } from "react";

export const Hello = () => {
  let [count, setCount] = useState(0);
  return (
    <div className="hello">
      <div id="hello">{count}</div>
      <button onClick={() => setCount(count + 1)}> count+1 </button>
    </div>
  );
};

测试用例编写

src目录下创建 Hello.test.jsx 文件:

  • render:渲染组件并返回一个包含 DOM 和事件的对象。
  • screen.getByText:查找包含特定文本的元素。
  • screen.getByTestId :查找具有特定 data-testid 属性的元素。
  • fireEvent.click:模拟点击事件。
  • fireEvent.change:模拟表单元素的值变化。
javascript 复制代码
import React from "react";
import { render, screen, fireEvent } from "@testing-library/react";
import { Hello } from "./Hello";

test("renders learn react link", async () => {
  const { container } = render(<Hello />);
  // DOM 查找
  expect(container.querySelector("#hello")).toBeTruthy();
  expect(container.getElementsByClassName("hello")).toHaveLength(1);
  // 获取元素值
  expect(container.querySelector("#hello").textContent).toBe("0");
  // 事件触发  状态管理
  await fireEvent.click(screen.getByText("count+1"));
  // 获取状态变更
  expect(container.querySelector("#hello").textContent).toBe("1");
});

运行测试代码

打开 cmd,输入命令:

bash 复制代码
yarn test

使用自定义钩子

React Testing Library 支持自定义钩子,用来测试自定义钩子,创建src/useCounter.js

javascript 复制代码
import React, { useState } from "react";

export const useCounter = (initialCount = 0) => {
  const [count, setCount] = useState(initialCount);

  const increment = () => {
    setCount((prevCount) => prevCount + 1);
  };

  return { count, increment };
};

创建src/useCounter.test.js

js 复制代码
import { renderHook ,act} from "@testing-library/react";
import { useCounter } from "./useCounter";

describe("useCounter", () => {
  // 测试初始值
  test("测试初始值", () => {
    const { result } = renderHook(() => useCounter(5));
    expect(result.current.count).toBe(5);
  });

  // 测试 increment 功能
  test(" 测试 increment 功能", () => {
    const { result } = renderHook(() => useCounter(0));
    act(() => {
      result.current.increment();
    });
    expect(result.current.count).toBe(1);
  });
});

测试用例截图

相关推荐
sorryhc16 分钟前
如何设计一个架构良好的前端请求库?
前端·javascript·架构
lvchaoq41 分钟前
react 修复403页面无法在首页跳转问题
前端·javascript·react.js
郝开1 小时前
6. React useState基础使用:useState修改状态的规则;useState修改对象状态的规则
前端·javascript·react.js
Codigger官方1 小时前
Linux 基金会牵头成立 React 基金会:前端开源生态迎来里程碑式变革
linux·前端·react.js
90后的晨仔1 小时前
🌟 Vue3 + Element Plus 表格开发实战:从数据映射到 UI 优化的五大技巧
前端
ObjectX前端实验室2 小时前
【图形编辑器架构】🧠 Figma 风格智能选择工具实现原理【猜测】
前端·react.js
天桥下的卖艺者2 小时前
R语言基于shiny开发随机森林预测模型交互式 Web 应用程序(应用程序)
前端·随机森林·r语言·shiny
技术钱2 小时前
vue3 两份json数据对比不同的页面给于颜色标识
前端·vue.js·json
wangchong915912 小时前
Java在云计算时代的微服务架构演进与实践解析
前端框架
路很长OoO2 小时前
Flutter 插件开发实战:桥接原生 SDK
前端·flutter·harmonyos