如何使用Jest进行单元测试

这篇具有很好参考价值的文章主要介绍了如何使用Jest进行单元测试。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

Jest 是一种流行的 JavaScript 测试框架,它具有易用性和高效性。Jest 支持测试各种 JavaScript 应用程序,包括 React、Vue、Node.js 等。在本文中,我们将介绍如何使用 Jest 进行单元测试。

## 1. 安装 Jest

首先,我们需要在项目中安装 Jest。可以使用 npm 或 yarn 安装 Jest:

```
npm install --save-dev jest
```

或者

```
yarn add --dev jest
```

## 2. 编写测试用例

在开始编写测试用例之前,我们需要了解一些 Jest 的概念:

- 测试套件(test suite):一组相关的测试用例。
- 测试用例(test case):测试一个特定功能的代码块。
- 断言(assertion):用于验证测试用例的结果是否符合预期。

接下来,让我们来编写一个简单的测试用例。假设我们有一个名为 `sum.js` 的文件,其中包含一个用于求两个数字和的函数:

```js
function sum(a, b) {
  return a + b;
}

module.exports = sum;
```

我们可以编写一个名为 `sum.test.js` 的测试用例,测试这个函数是否正确:

```js
const sum = require('./sum');

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

这个测试用例使用 `test` 函数定义,它接受两个参数:第一个参数是测试用例的描述信息,第二个参数是测试用例的函数体。在函数体中,我们使用 `expect` 和 `toBe` 函数来断言 `sum(1, 2)` 的返回值是否等于 `3`。

## 3. 运行测试

编写测试用例后,我们需要运行测试。可以通过在终端中执行以下命令来运行测试:

```
npm run test
```

或者

```
yarn test
```

Jest 会自动搜索项目中所有的测试文件,并运行它们。测试结果将显示在终端中,类似于下面的输出:

```
 PASS  ./sum.test.js
  ✓ adds 1 + 2 to equal 3 (3ms)

Test Suites: 1 passed, 1 total
Tests:       1 passed, 1 total
Snapshots:   0 total
Time:        1.442s
Ran all test suites.
```

## 4. 常用的 Jest 断言

Jest 提供了许多有用的断言函数,用于验证测试用例的结果。以下是一些常用的 Jest 断言函数:

- `expect(value).toBe(expected)`:验证 `value` 是否等于 `expected`。
- `expect(value).toEqual(expected)`:验证 `value` 是否等于 `expected`,使用深度比较。
- `expect(value).not.toBe(expected)`:验证 `value` 是否不等于 `expected`。
- `expect(value).toBeNull()`:验证 `value` 是否为 `null`。
- `expect(value).toBeTruthy()`:验证`value` 是否为真值,等价于 `expect(!!value).toBe(true)`。
- `expect(value).toBeFalsy()`:验证 `value` 是否为假值,等价于 `expect(!!value).toBe(false)`。
- `expect(value).toBeDefined()`:验证 `value` 是否已定义。
- `expect(value).toBeUndefined()`:验证 `value` 是否未定义。
- `expect(value).toBeGreaterThan(expected)`:验证 `value` 是否大于 `expected`。
- `expect(value).toBeGreaterThanOrEqual(expected)`:验证 `value` 是否大于或等于 `expected`。
- `expect(value).toBeLessThan(expected)`:验证 `value` 是否小于 `expected`。
- `expect(value).toBeLessThanOrEqual(expected)`:验证 `value` 是否小于或等于 `expected`。
- `expect(value).toMatch(pattern)`:验证 `value` 是否匹配给定的正则表达式。
- `expect(value).toContain(expected)`:验证 `value` 是否包含 `expected`。
- `expect(fn).toThrow(error)`:验证 `fn` 是否抛出错误,且错误信息匹配给定的正则表达式或字符串。

以上只是 Jest 断言函数的一部分,更多的断言函数可以在 Jest 官方文档中找到。

## 5. 使用 Jest Mock

在编写测试用例时,我们经常需要使用 Mock 来模拟函数或模块的行为。Jest 提供了内置的 Mock 功能,可以方便地创建和使用 Mock。

以下是一个例子,我们将使用 Mock 来模拟 `axios` 库,从而测试一个用于获取数据的函数:

```js
const axios = require('axios');

function fetchData() {
  return axios.get('https://jsonplaceholder.typicode.com/todos/1').then(res => res.data);
}

module.exports = fetchData;
```

我们可以使用 `jest.mock` 函数来创建 `axios` 的 Mock:

```js
const axios = require('axios');
const fetchData = require('./fetchData');

jest.mock('axios');

test('fetchData returns the data from server', () => {
  const data = {
    userId: 1,
    id: 1,
    title: 'delectus aut autem',
    completed: false,
  };
  axios.get.mockResolvedValue({ data });

  return fetchData().then(response => expect(response).toEqual(data));
});
```

在这个测试用例中,我们使用 `jest.mock` 函数来创建 `axios` 的 Mock。然后,我们使用 `axios.get.mockResolvedValue` 函数来指定 Mock 的返回值。最后,我们使用 `fetchData` 函数来获取数据,并使用 `expect` 函数来验证数据是否正确。

## 6. 使用 Jest Snapshots

Jest 还提供了快照测试(Snapshot Testing)功能,用于验证组件的渲染结果是否与预期一致。快照测试会在第一次运行测试时生成一个快照文件,并在后续运行测试时将渲染结果与快照文件进行比较。

以下是一个例子,我们将使用快照测试来验证一个 React 组件的渲染结果:

```jsx
// MyComponent.js
import React from 'react';

function MyComponent(props) {
  return (
    <div>
      <h1

      {props.title}
      <ul>
        {props.items.map(item => (
          <li key={item.id}>{item.text}</li>
        ))}
      </ul>
    </div>
  );
}

export default MyComponent;
```

```jsx
// MyComponent.test.js
import React from 'react';
import renderer from 'react-test-renderer';
import MyComponent from './MyComponent';

test('MyComponent renders correctly', () => {
  const component = renderer.create(
    <MyComponent
      title="My Component"
      items={[{ id: 1, text: 'Item 1' }, { id: 2, text: 'Item 2' }]}
    />
  );
  const tree = component.toJSON();
  expect(tree).toMatchSnapshot();
});
```

在这个测试用例中,我们使用 `renderer.create` 函数来创建 `MyComponent` 组件的实例,并将其渲染为 JSON 树。然后,我们使用 `expect` 函数来验证 JSON 树是否与快照文件匹配。

如果 JSON 树与快照文件不匹配,Jest 将会输出一个错误信息,并提示你是否要更新快照文件。

## 7. Jest 配置

Jest 提供了许多配置选项,用于自定义测试环境和测试行为。可以在 `package.json` 或 `jest.config.js` 中配置 Jest。

以下是一个例子,我们可以在 `jest.config.js` 文件中配置 Jest:

```js
module.exports = {
  testEnvironment: 'node',
  testMatch: ['**/__tests__/**/*.test.js'],
  collectCoverageFrom: ['src/**/*.js'],
};
```

在这个配置文件中,我们指定了以下配置选项:

- `testEnvironment`:指定测试运行的环境,可以是 `node` 或 `jsdom` 等。
- `testMatch`:指定测试文件的匹配模式。
- `collectCoverageFrom`:指定要收集覆盖率信息的文件。

## 结论

Jest 是一种功能强大的 JavaScript 测试框架,它提供了易用性和高效性,能够帮助我们轻松编写和运行测试用例。本文介绍了 Jest 的基本使用方法和常用功能,包括编写测试用例、运行测试、使用 Mock 和快照测试等。同时,我们也了解了 Jest 的配置选项,帮助我们更好地定制化测试环境和测试行为。文章来源地址https://www.toymoban.com/news/detail-689192.html

到了这里,关于如何使用Jest进行单元测试的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 快速上手 Jest 单元测试框架:使用 Jest Preset 加速配置,灵活应对项目需求

    Jest preset 参数的作用是提供一个预先定义好的配置集合,以便于快速开始使用 Jest 单元测试框架。你可以选择现有的 preset,如 jest-preset-angular 、 create-react-app 或自定义 preset,以根据你的项目需求自动应用一系列配置。 使用示例: 先安装一个现有的 preset,例如 jest-preset-angul

    2024年02月06日
    浏览(36)
  • 在单元测试中使用Jest模拟VS Code extension API

    对VS Code extension进行单元测试时通常会遇到一个问题,代码中所使用的VS Code编辑器的功能都依赖于 vscode 库,但是我们在单元测试中并没有添加对 vscode 库的依赖,所以导致运行单元测试时出错。由于 vscode 库是作为第三方依赖被引入到我们的VS Code extension中的,所以它并不受

    2024年02月14日
    浏览(46)
  • Jest单元测试(一)

    Jest是Facebook一套开源的 JavaScript 测试框架,它自动集成了断言、JSDom、覆盖率报告等测试工具。 他适用但不局限于使用以下技术的项目:Babel, TypeScript, Node, React, Angular, Vue 官网地址:https://jestjs.io/en/ 使用 yarn 安装 Jest︰ 或 npm: 注:Jest的文档统一使用yarn命令,不过使用npm也

    2024年02月16日
    浏览(44)
  • vue jest单元测试

    vue-test-utils 提供了两种方式用于渲染,或者说 加载(mount) 一个组件 — mount 和 shallowMount 。一个组件无论使用这两种方法的哪个都会返回一个 wrapper ,也就是一个包含了 Vue 组件 的对象,辅以一些对测试有用的方法。 mount : 会渲染子组件 shallowMount :会加载子组件,不会被

    2024年02月05日
    浏览(38)
  • vue 引入jest 单元测试

    为什么要搞单元测试,好处有什么。 提测需要, 代码覆盖率达到95%,分支覆盖率达到100% ,不达到要求,不给测。 确保代码正确性。单元测试可以检测和发现代码中的错误,在开发期间及时纠正。 提高代码质量。进行单元测试可以思考更多场景,添加边界测试用例,找到更

    2024年01月18日
    浏览(45)
  • Jest单元测试Vue项目实践

    ​ 做单元测试的优点: 1.减少bug避免低级错误 2.提高代码运行质量 3.快速定位问题 4.减少调试时间,提高开发效率 5.便于重构 Jest安装: 配置 vueCli内置了一套jest配置预置文件,一般情况下直接引用即可,如有特殊配置可见下文配置释意。 配置项目释意 module.exports = { 相关

    2024年02月12日
    浏览(43)
  • vue+jest 单元测试配置+用例

    目录 目录 1 Jest 说明文档 2 1、 搭建node环境包 2 这里安装环境是node 18,npm 9.5.0。 2 Test Runner 2 2、 安装jest 3 Jest安装步骤 4 项目的根目录下创建一个.babelrc 配置文件: 4 在项目的根目录下创建 jest.config.js 4 3、 全局设定 5 预处理和后处理 5 方法 6 4、 断言 6 真假断言 6 数字断言

    2024年02月07日
    浏览(40)
  • jest单元测试支持ts文件方案

    jest配置 jest配置如下: 额外配置说明: 其中transform增加了jest的es6处理能力。默认情况下jest只能处理require文件,当配置tranform后可以对impoet文件进行处理 prese和testEnvironment为jest增加ts处理能力 注意jest文件应当放在需要进行单元测试的目录,jest将按照其配置文件所子目录按照

    2024年02月14日
    浏览(36)
  • Jest:给你的 React 项目加上单元测试

    大家好,我是前端西瓜哥。 Jest 是一款轻量的 JavaScript 测试框架,它的卖点是简单好用,由 facebook 出品。本文就简单讲讲如何使用 Jest 对 React 组件进行测试。 单元测试 (Unit Testing),指的是对程序中的模块(最小单位)进行检查和验证。比如一个函数、一个类、一个组件,

    2024年02月09日
    浏览(42)
  • vue-cli 项目集成 Jest 单元测试

    前端单元测试对于保证代码质量和稳定性是非常重要的。 为什么需要单元测试: 检测bug; 提升回归效率; 保证代码质量。  ①、Mocha 比较灵活成熟,但没有内部集成,需要自主选择断言库和监听库。。 ②、Jasmine 是 Jest 的底层库,助攻 BDD(即行为驱动开发)断言库与异步测

    2024年01月17日
    浏览(75)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包