当前位置:首页 > 文章列表 > 文章 > 前端 > 使用 Vitest 框架创建测试的最佳技术

使用 Vitest 框架创建测试的最佳技术

来源:dev.to 2024-10-11 22:58:04 0浏览 收藏

学习文章要努力,但是不要急!今天的这篇文章《使用 Vitest 框架创建测试的最佳技术》将会介绍到等等知识点,如果你想深入学习文章,可以关注我!我会持续更新相关文章的,希望对大家都能有所帮助!

使用 Vitest 框架创建测试的最佳技术

单元测试、集成测试和端到端测试均由 vitest 支持,vitest 是专为 vite 设计的快速且现代的测试框架。通过与 react 和 vue 等当代 javascript 库的顺利集成,它提供了一种快速有效的方法来编写无需设置的测试。本文将讨论使用 vitest 框架编写可靠、可管理且有效的测试的最佳方法。

1。设置 vitest

在深入研究高级技术之前,让我们使用 vitest 建立一个简单的项目。如果您在项目中使用 vite,vitest 的设计只需最少的设置即可开箱即用。

第 1 步:安装 vitest

要安装 vitest,请在项目目录中运行以下命令:

npm install vitest --save-dev

第 2 步:创建一个简单的测试

安装后,创建一个简单的测试文件来查看 vitest 的运行情况。

import { describe, it, expect } from 'vitest';

describe('math functions', () => {
  it('should add two numbers correctly', () => {
    const sum = 1 + 2;
    expect(sum).tobe(3);
  });
});

使用以下命令运行测试:

npx vitest

2。使用describe 和it blocks 组织测试

describe 和 it 块是 vitest(以及许多其他测试框架,如 jest)的基础。它们有助于逻辑地组织您的测试并使它们更易于阅读。

describe:用于对相关测试进行分组。
it:在描述块中定义单独的测试用例。
这种结构可确保您的测试用例随着测试套件的增长而组织良好且可维护。

describe('user authentication', () => {
  it('should login with valid credentials', () => {
    // test login functionality
  });

  it('should fail to login with invalid credentials', () => {
    // test invalid login functionality
  });
});

3。模拟依赖

在现代应用程序中,测试通常需要模拟 api、数据库或第三方库等外部服务。 vitest 为模拟依赖项提供本机支持,这有助于隔离您想要测试的行为。

模拟 api 调用示例

让我们使用 vitest 的 vi.fn 来模拟一个简单的 api 调用来模拟函数,而无需实际调用外部服务。

import { vi } from 'vitest';
import { fetchuserdata } from './api';

vi.mock('./api', () => ({
  fetchuserdata: vi.fn(),
}));

describe('user api', () => {
  it('should fetch user data correctly', async () => {
    const mockuserdata = { id: 1, name: 'john doe' };
    fetchuserdata.mockresolvedvalueonce(mockuserdata);

    const result = await fetchuserdata(1);
    expect(result).toequal(mockuserdata);
  });
});

在此示例中,我们模拟了 fetchuserdata 函数,使我们能够控制响应并避免进行真正的 api 调用。

4。快照测试

vitest 支持快照测试,当您想要验证组件或函数随时间的输出时,这非常有用。这种技术对于 ui 组件特别有益。

快照测试示例

import { describe, it, expect } from 'vitest';
import { render } from '@testing-library/react';
import mycomponent from './mycomponent';

describe('mycomponent', () => {
  it('should match the snapshot', () => {
    const { container } = render();
    expect(container).tomatchsnapshot();
  });
});

快照测试可确保组件输出保持一致。如果输出发生变化,系统会提示您更新快照,帮助捕获无意的更改。

5。测试异步代码

在测试异步函数时,vitest 提供了处理 promise 的实用程序,可以更轻松地确保异步代码按预期工作。

测试异步函数示例

import { describe, it, expect } from 'vitest';

const fetchdata = async () => {
  return new promise((resolve) => settimeout(() => resolve('data'), 1000));
};

describe('async functions', () => {
  it('should resolve data', async () => {
    const data = await fetchdata();
    expect(data).tobe('data');
  });
});

此技术对于测试 api 请求、计时器或其他异步代码至关重要。

6。代码覆盖率

vitest 支持生成开箱即用的代码覆盖率报告,这可以帮助您了解测试覆盖了多少代码库。它显示了代码的哪些部分已经过测试,哪些部分尚未测试。

启用代码覆盖

要启用代码覆盖率,请将以下内容添加到您的 vitest 配置中:

// vite.config.js or vitest.config.js
export default {
  test: {
    coverage: {
      reporter: ['text', 'html'],
    },
  },
};

运行覆盖范围的测试:

npx vitest --coverage

这将生成一份覆盖率报告,让您可以分析代码的哪些区域需要更多测试。

7。参数化测试

参数化测试是运行具有不同输入和预期输出的单个测试用例的好方法。这减少了代码重复并确保您的函数在各种场景下都能正确运行。

参数化测试示例

describe.each([
  [1, 2, 3],
  [2, 3, 5],
  [5, 5, 10],
])('math operations', (a, b, expected) => {
  it(`should add ${a} and ${b} to equal ${expected}`, () => {
    expect(a + b).tobe(expected);
  });
});

通过使用describe.each,您可以在单个测试用例中迭代不同的输入集和预期输出,使您的测试更加dry(不要重复自己)。

8。使用测试库测试 react 组件

vitest 与 react 测试库配合良好,react 测试库是一种用于测试 react 组件的流行工具。它鼓励测试组件的行为,而不是实现细节。

react 组件测试示例

import { render, screen } from '@testing-library/react';
import { describe, it, expect } from 'vitest';
import MyButton from './MyButton';

describe('MyButton Component', () => {
  it('should render correctly', () => {
    render();
    expect(screen.getByText('Click Me')).toBeInTheDocument();
  });

  it('should call onClick when clicked', () => {
    const handleClick = vi.fn();
    render();
    screen.getByText('Click Me').click();
    expect(handleClick).toHaveBeenCalledTimes(1);
  });
});

使用 vitest 测试 react 组件可确保您的 ui 在与按钮、输入或其他元素交互时按预期运行。

结论

无需设置,vitest 框架即可提供强大、现代的测试体验。您可以通过遵循最佳实践来构建可靠且有效的测试套件,其中包括使用描述块来组织测试、模拟外部服务以及利用快照测试。此外,启用代码覆盖率、测试 react 组件和测试异步代码等方法将保证您的应用程序经过良好的测试和维护。

今天关于《使用 Vitest 框架创建测试的最佳技术》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于的内容请关注golang学习网公众号!

版本声明
本文转载于:dev.to 如有侵犯,请联系study_golang@163.com删除
中国农业科学院与华为技术有限公司达成战略合作协议中国农业科学院与华为技术有限公司达成战略合作协议
上一篇
中国农业科学院与华为技术有限公司达成战略合作协议
如何在Windows上禁用集成显卡
下一篇
如何在Windows上禁用集成显卡
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    542次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    508次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    497次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    484次学习
查看更多
AI推荐
  • AI Make Song:零门槛AI音乐创作平台,助你轻松制作个性化音乐
    AI Make Song
    AI Make Song是一款革命性的AI音乐生成平台,提供文本和歌词转音乐的双模式输入,支持多语言及商业友好版权体系。无论你是音乐爱好者、内容创作者还是广告从业者,都能在这里实现“用文字创造音乐”的梦想。平台已生成超百万首原创音乐,覆盖全球20个国家,用户满意度高达95%。
    17次使用
  • SongGenerator.io:零门槛AI音乐生成器,快速创作高质量音乐
    SongGenerator
    探索SongGenerator.io,零门槛、全免费的AI音乐生成器。无需注册,通过简单文本输入即可生成多风格音乐,适用于内容创作者、音乐爱好者和教育工作者。日均生成量超10万次,全球50国家用户信赖。
    13次使用
  •  BeArt AI换脸:免费在线工具,轻松实现照片、视频、GIF换脸
    BeArt AI换脸
    探索BeArt AI换脸工具,免费在线使用,无需下载软件,即可对照片、视频和GIF进行高质量换脸。体验快速、流畅、无水印的换脸效果,适用于娱乐创作、影视制作、广告营销等多种场景。
    13次使用
  • SEO标题协启动:AI驱动的智能对话与内容生成平台 - 提升创作效率
    协启动
    SEO摘要协启动(XieQiDong Chatbot)是由深圳协启动传媒有限公司运营的AI智能服务平台,提供多模型支持的对话服务、文档处理和图像生成工具,旨在提升用户内容创作与信息处理效率。平台支持订阅制付费,适合个人及企业用户,满足日常聊天、文案生成、学习辅助等需求。
    16次使用
  • Brev AI:零注册门槛的全功能免费AI音乐创作平台
    Brev AI
    探索Brev AI,一个无需注册即可免费使用的AI音乐创作平台,提供多功能工具如音乐生成、去人声、歌词创作等,适用于内容创作、商业配乐和个人创作,满足您的音乐需求。
    18次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码