使用Jest进行JavaScript单元测试

news2024/11/28 6:59:54
💓 博客主页:瑕疵的CSDN主页
📝 Gitee主页:瑕疵的gitee主页
⏩ 文章专栏:《热点资讯》

使用Jest进行JavaScript单元测试

    • 引言
    • Jest 简介
      • 安装 Jest
      • 创建基本配置
      • 编写测试用例
      • 运行测试
      • 快照测试
      • 模拟函数
      • 代码覆盖率报告
      • 最佳实践
        • 保持测试独立
        • 使用描述性命名
        • 模拟外部依赖
        • 写测试先于写代码
      • 实际案例
      • 总结

引言

在现代软件开发中,测试是确保代码质量和稳定性的关键步骤。Jest 是一个流行的 JavaScript 测试框架,它提供了丰富的功能和易用的 API,使得编写和运行单元测试变得更加简单。本文将详细介绍如何使用 Jest 进行 JavaScript 单元测试,包括安装、配置、编写测试用例和最佳实践等内容。

Jest 简介

Jest 是一个 JavaScript 测试框架,由 Facebook 维护。它主要用于测试 JavaScript 代码,但也支持 React、Vue 等前端框架。Jest 的主要特点包括:

  • 零配置:开箱即用,无需复杂的配置即可开始编写测试。
  • 快照测试:支持快照测试,可以轻松捕获 UI 组件的变化。
  • 模拟函数:提供强大的模拟函数功能,可以模拟外部依赖。
  • 并行执行:支持并行执行测试,提高测试速度。
  • 代码覆盖率报告:生成详细的代码覆盖率报告,帮助开发者了解测试覆盖情况。

安装 Jest

在使用 Jest 之前,需要安装必要的依赖。假设你已经安装了 Node.js 和 npm,可以使用以下命令安装 Jest:

npm init -y
npm install jest --save-dev

创建基本配置

Jest 默认会查找 package.json 中的 test 脚本。你可以在 package.json 中添加一个测试脚本:

{
  "scripts": {
    "test": "jest"
  }
}

编写测试用例

在项目的 __tests__ 目录下创建一个测试文件,例如 sum.test.js

// __tests__/sum.test.js
const sum = require('../sum');

it('adds 1 + 2 to equal 3', () => {
  expect(sum(1, 2)).toBe(3);
});

运行测试

使用以下命令运行测试:

npm test

这将根据配置文件运行所有的测试用例,并输出测试结果。

快照测试

快照测试是 Jest 的一个强大功能,可以捕获组件的输出并在后续测试中进行比较。例如,假设你有一个 React 组件:

// components/MyComponent.js
import React from 'react';

const MyComponent = () => (
  <div>
    <h1>Hello, World!</h1>
  </div>
);

export default MyComponent;

在测试文件中编写快照测试:

// __tests__/MyComponent.test.js
import React from 'react';
import renderer from 'react-test-renderer';
import MyComponent from '../components/MyComponent';

it('matches the snapshot', () => {
  const component = renderer.create(<MyComponent />);
  const tree = component.toJSON();
  expect(tree).toMatchSnapshot();
});

模拟函数

Jest 提供了强大的模拟函数功能,可以模拟外部依赖。例如,假设你有一个函数需要调用外部 API:

// src/api.js
const fetchData = async () => {
  const response = await fetch('https://api.example.com/data');
  return response.json();
};

module.exports = fetchData;

在测试文件中模拟 fetch 函数:

// __tests__/api.test.js
const fetchData = require('../src/api');

jest.mock('node-fetch');

it('calls the API and returns data', async () => {
  global.fetch = jest.fn(() =>
    Promise.resolve({
      json: () => Promise.resolve({ data: 'example' })
    })
  );

  const result = await fetchData();
  expect(result).toEqual({ data: 'example' });
});

代码覆盖率报告

Jest 可以生成详细的代码覆盖率报告。在 package.json 中添加一个覆盖率脚本:

{
  "scripts": {
    "test": "jest",
    "coverage": "jest --coverage"
  }
}

使用以下命令生成覆盖率报告:

npm run coverage

最佳实践

保持测试独立
每个测试用例应该独立于其他测试用例,避免相互影响。

使用描述性命名
测试用例的名称应该清晰明了,便于理解测试的目的。

模拟外部依赖
使用模拟函数和模块,避免测试依赖外部环境。

写测试先于写代码
遵循测试驱动开发(TDD)的原则,先编写测试用例再编写实现代码。

实际案例

Jest 已经被广泛应用于各种 JavaScript 项目,例如:

  • 前端应用:测试 React、Vue 等前端框架的组件和逻辑。
  • 后端应用:测试 Node.js 应用的业务逻辑和 API。
  • 库和框架:测试第三方库和框架的功能和性能。

总结

通过本文,你已经学会了如何使用 Jest 进行 JavaScript 单元测试。Jest 的零配置、快照测试、模拟函数和代码覆盖率报告等功能使其成为现代 JavaScript 开发的强大工具。
Jest 测试流程图

Jest 支持快照测试和模拟函数,可以更好地管理和验证代码的行为。
Jest 代码覆盖率报告示意图

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2235515.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【读书笔记/深入理解K8S】集群网络

前言 上一章讲了集群控制器的一个大概的原理&#xff0c;这一章讲一下集群网络。网络是集群通信的载体&#xff0c;因为该书是阿里云团队出品的&#xff0c;所以也以阿里云的集群网络方案为例&#xff0c;其他云厂商的网络集群方案一般来说也大同小异。所以通过本章的学习&…

Varjo核电厂虚拟仿真培训解决方案

虚拟现实技术的融入将帮助核电厂设计验证和操作员培训跟有效的进行。 芬兰的Loviisa工厂是世界上第一个为控制室操作员建造专用VR培训室的核电站。该工厂使用了Varjo混合现实头显设备为员工提供虚拟仿真训练。 案例Fortum: VR为核电厂操纵员培训带来明显优势 与构建物理模拟器相…

推荐一款基于Flash的交互式园林设计工具:Garden Planner

Garden Planner是一款由Artifact Interactive开发的基于Flash的交互式园林设计工具。它允许用户以拖放的方式安排植物、树木、建筑物和各种对象&#xff0c;使园林规划变得简单直观。此外&#xff0c;Garden Planner提供工具来快速创建铺路、路径和围栏&#xff0c;帮助用户设计…

HTML 标签属性——id、class、style 等全局属性详解

文章目录 1. id属性2. class属性3. style属性4. title属性5. lang属性6. dir属性7. accesskey属性8. tabindex属性小结HTML全局属性是一组可以应用于几乎所有HTML元素的特殊属性。这些属性提供了额外的功能和信息,使得网页开发者能够更好地控制元素的行为、样式和可访问性。 …

SpringBoot 整合达梦数据库 Demo

本文将介绍如何在 Spring Boot 项目中整合达梦数据库&#xff0c;并实现基本的用户管理功能。通过以下步骤&#xff0c;我们将创建一个简单的 RESTful API&#xff0c;以便于用户的增删改查&#xff08;CRUD&#xff09;操作。 【点我: 下载整套源码】 1. 创建数据库与数据表 …

高校实验室安全巡检系统设计与实现(源码+定制+开发)高校实验室巡检系统、实验室安全管理平台、实验室安全监控系统、智能实验室巡查系统、高校实验室风险管理

博主介绍&#xff1a; ✌我是阿龙&#xff0c;一名专注于Java技术领域的程序员&#xff0c;全网拥有10W粉丝。作为CSDN特邀作者、博客专家、新星计划导师&#xff0c;我在计算机毕业设计开发方面积累了丰富的经验。同时&#xff0c;我也是掘金、华为云、阿里云、InfoQ等平台…

【系统集成项目管理工程师教程】第4章 信息系统架构

教程内容总结&#xff0c;供参考&#xff0c;有错误请指正&#xff0c;友好交流。 4.架构基础 4.1.1指导思想 4.1.2设计原则 原则内容&#xff1a;包括坚持以人为本、创新引领、问题导向、整体协同、安全可控、科学实施等&#xff0c;这些原则应基于组织的信念和价值观&…

如何学习C++游戏开发

学习C游戏开发是一个涉及多个领域的复杂过程&#xff0c;包括编程、游戏设计、图形学等。 1. **学习C基础**&#xff1a; - 掌握C的基本语法和面向对象编程。 - 学习C标准库&#xff0c;特别是STL&#xff08;标准模板库&#xff09;。 2. **理解游戏开发概念**&#xf…

Socket 和 WebSocket 的应用

Socket&#xff08;套接字&#xff09;是计算机网络中的一个抽象层&#xff0c;它允许应用程序通过网络进行通信。套接字用于跨网络的不同主机上的应用程序之间的数据交换。在互联网中&#xff0c;套接字通常基于 TCP&#xff08;传输控制协议&#xff09;或 UDP&#xff08;用…

mac 本地docker-mysql主从复制部署

mac 本地docker-mysql主从复制部署,服务器同理 1.本地docker启动两个mysql服务.端口号不一样 没有选择挂载到宿主机.只做测试用. 只是端口号不一样容器删掉.就没有数据了. 生产测试,需要挂在 master docker run -d --name mysql-slave -p 3308:3306 \ -e MYSQL_ROOT_PASSWORD…

HTML学习笔记十三

系列笔记目录 第一章 HTML的概述 第二章 URL简介 第三章 网页元素的属性 第四章 html字符编码 第五章 网页的语义结构 第六章 文本标签 第七章 列表标签 第八章 图像标签 第九章 链接标签 第十章 多媒体标签 第十一章 iframe 第十二章 表格标签 第十三章 表单标签 表单标签 系列…

在鱼皮的模拟面试里面学习有感

文章目录 1.上半场1.1.引言1.2.鱼皮的建议 2.下半场2.1中间问题 3.我的总结3.1我的体会3.2我的计划 1.上半场 今天的直播&#xff0c;第一次全程的跟下来&#xff1a;也算是放松一下~~ 1.1.引言 上半场是后来总结的&#xff0c;听的时候没有随手记录&#xff1a; 1&#xf…

思源笔记轻松连接本地Ollama大语言模型,开启AI写作新体验!

文章目录 前言1. 下载运行Ollama框架2. Ollama下载大语言模型3. 思源笔记设置连接Ollama4. 测试笔记智能辅助写作5. 安装Cpolar工具6. 配置Ollama公网地址7. 笔记设置远程连接Ollama8. 固定Ollama公网地址 前言 今天我们要聊聊如何通过cpolar内网穿透技术&#xff0c;把国产笔…

前端学习Day12 CSS盒子的定位(相对定位篇“附练习”)

一、相对定位 使用相对定位的盒子会相对于自身原本的位置&#xff0c;通过偏移指定的距离&#xff0c;到达新的位置。盒子的本体仍处于文档流中。使用相对定位&#xff0c;除了要将 position 属性值设置为 relative 外&#xff0c;还需要指定一定的偏移量。其中&#xff0c;水…

AJ-Report:一款开源且非常强大的数据可视化大屏和报表工具

嗨&#xff0c;大家好&#xff0c;我是小华同学&#xff0c;关注我们获得“最新、最全、最优质”开源项目和工作学习方法 AJ-Report是一个基于Java的开源报表工具&#xff0c;它集成了ECharts、Ant Design Vue等前端技术&#xff0c;致力于为企业提供一站式的数据可视化解决方案…

【深度学习】InstantIR:图片高清化修复

InstantIR——借助即时生成参考的盲图像修复新方法 作者:Jen-Yuan Huang 等 近年来,随着深度学习和计算机视觉技术的飞速发展,图像修复技术取得了令人瞩目的进步。然而,对于未知或复杂退化的图像进行修复,仍然是一个充满挑战的任务。针对这一难题,研究者们提出了 Insta…

MySQL utf8mb3 和 utf8mb4引发的问题

问题描述 Cause: java.sql.SQLException: Incorrect string value: \xF4\x8F\xBB\xBF-b... for column sddd_aaa_ark at row 1 sddd_aaa_ark 存储中文字符时&#xff0c;出现上述问题 原因分析 sddd_aaa_ark在数据库中结构是 utf8字符的最大字节数是3 byte&#xff0c;但是某些…

日语学习的难易程度

日语学习的难易程度是一个相对主观的问题&#xff0c;它受到多种因素的影响&#xff0c;包括个人的语言学习能力、学习方法、学习时间、学习资源的可获得性以及个人对日语文化的兴趣和投入程度等。以下是对日语学习难易程度的一些分析&#xff1a; 优点与易学之处 文字系统&am…

Win10 连接到 Ubuntu 黑屏无法连接 使用Rustdesk显示 No Displays 没有显示器

Win10 连接到 Ubuntu 黑屏无法连接 使用Rustdesk显示 No Displays 没有显示器 解决办法安装虚拟显示器 安装xorg虚拟显示器 $ sudo apt install xserver-xorg-video-dummy # 提示错误依赖使用下面这个试试 $ sudo apt-get install xserver-xorg-video-dummy --fix-missing配…

Ubuntu安装Python并配置pip阿里镜像教程 - 幽络源

背景 因为要部署yolov8项目到ubuntu系统&#xff0c;但是yolov8要求python版本必须大于3.10&#xff0c;因此ubuntu20.04自带的python3.8不可用&#xff0c;需自行安装python&#xff0c;本教程使用python源码编译式安装python3.12.3&#xff0c;原因是apt下载python无法指定目…