当前位置: 首页 > news >正文

vitest 单元测试应用与配置

vitest 应用与配置

一、简介

Vitest 旨在将自己定位为 Vite 项目的首选测试框架,即使对于不使用 Vite 的项目也是一个可靠的替代方案。它本身也兼容一些Jest的API用法。

二、安装vitest

// npm
npm install -D vitest
// yarn
yarn add -D vitest
// pnpm 
pnpm add -D vitest

注意:vitest的版本应与你的项目依赖兼容,建议使用最新版本以获得最佳性能和功能。

三、配置vitest

Vitest的配置可以通过多种方式实现,包括在package.json中直接配置,或者创建一个专门的配置文件(如vitest.config.ts或vitest.config.js)。

1、在package.json中配置

在package.json的scripts部分添加一个测试脚本:

"scripts":{"test":"vitest"
}

这样就可以通过npm run test 或pnpm test来执行测试了

2、创建配置文件

对于更复杂的配置,你可以创建一个vitest.config.ts或vitest.config.js文件。例如:

/// <reference types="vitest">
import { defineConfig } from "vite";
import vue from "@vitejs/plugin-vue";
import * as path from "path";// https://vitejs.dev/config/
export default defineConfig({// 单元测试test: {globals: true,  //全局注册environment: 'jsdom', // 模拟浏览器环境  },resolve: {//设置别名alias: {"@": path.resolve(__dirname, "src"),},},plugins: [vue()],
});

四、编写测试

在你的Vue项目中,你可以为组件、函数、工具等编写测试。Vitest支持多种测试文件命名方式,但通常建议使用.test.ts或.spec.ts作为测试文件的扩展名。
例如,如果你有一个名为utils.js的文件,你可以创建一个utils.test.ts文件来编写它的测试。

1、函数测试

import { sum } from "../utils/index";
describe('sum', () => {test('should return 0 when num is 0', () => {expect(sum(1, 1)).toEqual(2);});it('should return 1 when num is 1', () => {expect(sum(1, 4)).toEqual(5);});it('should return 1 when num is 2', () => {expect(sum(3, 3)).toBe(6);});
});

最后,运行 npm run test、yarn test 或 pnpm test,具体取决于你的包管理器,Vitest 将打印此消息:

2、组件测试

测试文件

import { describe, it, expect } from 'vitest';
import { mount } from '@vue/test-utils';
import Button from './Button.vue';describe('Button.vue', () => {it('renders props.label when passed', () => {const wrapper = mount(Button, {props: {label: 'Click me',},});expect(wrapper.text()).toContain('Click me');});it('emits a click event when clicked', () => {const wrapper = mount(Button, {props: {label: '测试 Button',},attachToDocument: true,});wrapper.trigger('click');// 验证是否发射了 click 事件expect(wrapper.emitted().click).toBeTruthy();});
});

最后,运行 npm run test、yarn test 或 pnpm test,具体取决于你的包管理器,Vitest 将打印此消息:

错误示例:

报错提醒!!!

原因:vitest是运行在Node.js环境的,没有document对象,因此需要借助jsdom来实现。
jsdom 是一个在 Node.js 环境中使用的纯 JavaScript 实现的 DOM(文档对象模型),它模拟了足够多的浏览器环境,使得你能够在服务器端(如 Node.js 应用程序)中运行那些原本只能在浏览器中运行的脚本。

// npm
npm install -D jsdom
// yarn
yarn add -D jsdom
// pnpm 
pnpm add -D jsdom

五、其他配置

Vitest还提供了许多其他配置选项,如支持TypeScript、模拟DOM环境、生成测试覆盖率报告等。你可以根据项目的具体需求来配置这些选项。

注意事项
  • 确保你的项目依赖(如Vue、Vite等)与Vitest的版本兼容。
  • 在编写测试时,尽量保持测试代码的简洁性和可维护性。
  • 利用Vitest提供的丰富API和插件来增强你的测试体验。

开发者

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • [Spring] Spring Web MVC基础理论
  • Memcached负载均衡:揭秘高效缓存分发策略
  • 基于Flask+Apache+WSGI等模块配置Deep Learning应用功能网站(Ubuntu 22.04服务器)
  • Linux 安装 Docker Compose
  • 百度文心4.0 Turbo开放,领跑国内AI大模型赛道!
  • 【RNN练习】天气预测
  • C# Winform 系统方案目录的管理开发
  • Go语言map并发安全,互斥锁和读写锁谁更优?
  • 【区分vue2和vue3下的element UI Collapse 折叠面板组件,分别详细介绍属性,事件,方法如何使用,并举例】
  • Linux上如何安装ffmpeg视频处理软件
  • ChatGPT对话:如何制作静态网页?
  • 数据结构4.0——串的定义和基本操作
  • ConditionalOnResource注解使用介绍、应用场景以及示例代码
  • element如何实现自定义表头?
  • 图论基础概念(详细讲解)
  • 《剑指offer》分解让复杂问题更简单
  • Android单元测试 - 几个重要问题
  • JavaScript 无符号位移运算符 三个大于号 的使用方法
  • Ruby 2.x 源代码分析:扩展 概述
  • spring boot 整合mybatis 无法输出sql的问题
  • vue2.0一起在懵逼的海洋里越陷越深(四)
  • 大快搜索数据爬虫技术实例安装教学篇
  • 山寨一个 Promise
  • 一道闭包题引发的思考
  • 阿里云服务器如何修改远程端口?
  • ​猴子吃桃问题:每天都吃了前一天剩下的一半多一个。
  • #HarmonyOS:基础语法
  • (160)时序收敛--->(10)时序收敛十
  • (DFS + 剪枝)【洛谷P1731】 [NOI1999] 生日蛋糕
  • (笔试题)合法字符串
  • (草履虫都可以看懂的)PyQt子窗口向主窗口传递参数,主窗口接收子窗口信号、参数。
  • (附源码)spring boot火车票售卖系统 毕业设计 211004
  • (附源码)springboot 校园学生兼职系统 毕业设计 742122
  • (附源码)springboot掌上博客系统 毕业设计063131
  • (七)Flink Watermark
  • (四)JPA - JQPL 实现增删改查
  • (算法设计与分析)第一章算法概述-习题
  • (提供数据集下载)基于大语言模型LangChain与ChatGLM3-6B本地知识库调优:数据集优化、参数调整、Prompt提示词优化实战
  • (推荐)叮当——中文语音对话机器人
  • (转)大道至简,职场上做人做事做管理
  • (转)母版页和相对路径
  • .gitignore不生效的解决方案
  • .net 连接达梦数据库开发环境部署
  • .NET 依赖注入和配置系统
  • .NET/C# 在 64 位进程中读取 32 位进程重定向后的注册表
  • .Net6 Api Swagger配置
  • .net6 webapi log4net完整配置使用流程
  • .Net程序帮助文档制作
  • .net和php怎么连接,php和apache之间如何连接
  • .NET开发不可不知、不可不用的辅助类(一)
  • .NET学习全景图
  • /boot 内存空间不够
  • /proc/vmstat 详解
  • @param注解什么意思_9000字,通俗易懂的讲解下Java注解
  • @SpringBootConfiguration重复加载报错