单元测试怎么做
单元测试是软件开发中非常重要的一部分,能够确保代码的正确性、可靠性和可维护性。对于 Vue 项目来说,单元测试主要关注的是测试组件及其相关功能是否正常。下面是如何在 Vue 项目中进行单元测试的详细步骤,包括测试框架的选择、测试工具的配置、如何写测试用例等。
1. 选择单元测试框架
在 Vue 项目中,常用的单元测试框架有以下几种:
Jest:Jest 是一个非常流行的 JavaScript 测试框架,适用于 Vue 项目,提供了简单易用的 API,支持快照测试、模拟、异步测试等功能。
Mocha:Mocha 是一个灵活的 JavaScript 测试框架,配合 Chai 断言库和 Sinon 模拟库使用。
Karma:Karma 是一个测试运行器,通常与 Jasmine 配合使用。
2. 安装和配置 Jest
以 Jest 为例,下面是如何在 Vue 项目中安装和配置 Jest 来进行单元测试。
2.1 安装 Jest 和相关依赖
首先,你需要安装 Jest、Vue Test Utils(Vue 的官方测试工具)以及一些配套的依赖:
npm install --save-dev jest vue-jest @vue/test-utils babel-jest
这些依赖的作用是:
jest: Jest 测试框架本身。
vue-jest: 用于处理 .vue 文件,使 Jest 可以理解并测试 Vue 组件。
@vue/test-utils: Vue 官方的测试工具,提供了一些 API 来挂载组件并进行操作。
babel-jest: 让 Jest 支持 Babel 编译,支持 ES6/JSX 语法。
2.2 配置 Jest
在项目根目录下创建一个 jest.config.js 文件,配置 Jest 相关选项:
module.exports = {transform: {'^.+\\.vue$': 'vue-jest', // 处理 .vue 文件'^.+\\.js$': 'babel-jest', // 处理 JavaScript 文件},moduleFileExtensions: ['js', 'vue', 'json'], // 支持的文件扩展名testEnvironment: 'jsdom', // 适用于浏览器环境的测试
};
2.3 配置 Babel
如果你使用了 ES6/JSX 或 Vue 3 特性,需要确保 Babel 配置正常。创建一个 .babelrc 或 babel.config.js 文件:
{"presets": ["@babel/preset-env"]
}
2.4 配置 package.json 中的测试脚本
在 package.json 中添加 Jest 的测试命令:json
{"scripts": {"test": "jest" // 运行 Jest 测试}
}
3. 编写单元测试
3.1 测试 Vue 组件
Vue Test Utils 提供了对 Vue 组件进行单元测试的基本 API。你可以通过 mount() 或 shallowMount() 来挂载组件,并对组件进行断言。
例如,假设有一个简单的 HelloWorld.vue 组件:
<template><div><h1>{{ message }}</h1><button @click="changeMessage">Change Message</button></div>
</template><script>
export default {data() {return {message: 'Hello, World!'};},methods: {changeMessage() {this.message = 'Hello, Vue!';}}
};
</script>
可以使用 Jest 和 Vue Test Utils 来为该组件编写单元测试:
import { shallowMount } from '@vue/test-utils';
import HelloWorld from '@/components/HelloWorld.vue';describe('HelloWorld.vue', () => {it('renders props.message when passed', () => {const wrapper = shallowMount(HelloWorld);expect(wrapper.text()).toContain('Hello, World!');});it('changes message when button is clicked', async () => {const wrapper = shallowMount(HelloWorld);await wrapper.find('button').trigger('click');expect(wrapper.text()).toContain('Hello, Vue!');});
});
3.2 解释代码
shallowMount:Vue Test Utils 提供的一个方法,用于挂载组件并返回一个 wrapper 对象。shallowMount 不会渲染子组件,这样可以提高测试速度。如果需要渲染子组件,可以使用 mount()。
wrapper.text():获取组件渲染后的文本内容。
wrapper.find(‘button’):查找组件中的按钮元素。
trigger(‘click’):模拟按钮的点击事件。
3.3 异步测试
如果组件有异步操作,可以使用 async/await 或 done() 来处理异步逻辑。例如,假设有一个组件发起异步请求:
<template><div><p v-if="message">{{ message }}</p><button @click="fetchMessage">Fetch Message</button></div>
</template><script>
export default {data() {return {message: null,};},methods: {async fetchMessage() {const response = await fetch('https://api.example.com/message');this.message = await response.json();}}
};
</script>
相应的单元测试:
import { shallowMount } from '@vue/test-utils';
import HelloWorld from '@/components/HelloWorld.vue';global.fetch = jest.fn(() =>Promise.resolve({json: () => Promise.resolve('Hello, Async World!'),})
);describe('HelloWorld.vue', () => {it('fetches message when button is clicked', async () => {const wrapper = shallowMount(HelloWorld);await wrapper.find('button').trigger('click');await wrapper.vm.$nextTick(); // 等待 Vue 更新 DOMexpect(wrapper.text()).toContain('Hello, Async World!');});
});
在这个测试中,使用了 jest.fn() 来模拟 fetch 方法的行为,并通过 async/await 等待异步操作完成。
4. 运行单元测试
完成单元测试编写后,可以通过以下命令运行测试:
npm run test
Jest 会自动查找项目中的所有测试文件(默认情况下,测试文件以 .test.js 或 .spec.js 结尾)并执行测试。运行完毕后,Jest 会输出测试结果。
- 断言库
Jest 内置了一些常用的断言方法,如:
expect(value).toBe(expected):严格相等判断
expect(value).toContain(expected):检查字符串或数组中是否包含某个值
expect(value).toBeTruthy():判断值是否为真
expect(value).toHaveBeenCalled():检查函数是否被调用
如果你使用 Mocha + Chai,也可以使用 expect、should、assert 等不同的断言风格。
6. 测试覆盖率
Jest 还可以生成代码覆盖率报告,这对于检测哪些代码没有被测试到非常有帮助。你可以通过添加 --coverage 标志来启用覆盖率报告:
npm run test -- --coverage
- CI/CD 集成
为了确保代码质量,建议将单元测试集成到 CI/CD 流程中。在 GitHub Actions、GitLab CI 或其他 CI 工具中配置测试脚本,可以在每次代码提交或合并时自动运行测试。
总结
Vue 项目的单元测试可以通过 Jest 和 Vue Test Utils 来完成,具体步骤包括:
安装 Jest 和 Vue Test Utils。
配置 Jest 和 Babel,支持 ES6 及 Vue 组件测试。
编写单元测试,使用 shallowMount 或 mount 挂载 Vue 组件,并对组件的输出进行断言。
运行测试,确保组件功能符合预期。
可以配置 CI/CD 流程,自动运行测试,确保每次提交的代码是经过验证的。
相关文章:
单元测试怎么做
单元测试是软件开发中非常重要的一部分,能够确保代码的正确性、可靠性和可维护性。对于 Vue 项目来说,单元测试主要关注的是测试组件及其相关功能是否正常。下面是如何在 Vue 项目中进行单元测试的详细步骤,包括测试框架的选择、测试工具的配…...

移动应用开发 实验二:标准身高计算器
文章目录 准备工作一,创建Android Studio项目二,创建活动模块三,设计用户界面(一)设置页面布局(二)添加标题文本控件(三)设计体重输入框(四)设计性…...

金华迪加现场大屏互动系统 mobile.do.php 任意文件上传漏洞复现
0x01 产品描述: 金华迪加现场大屏互动系统是由金华迪加网络科技有限公司开发的一款专注于增强活动现场互动性的系统。该系统设计用于提供高质量的现场互动体验,支持各种大型活动,如企业年会、产品发布会、展览展示等。其主要功能包…...
使用 pd.ExcelWriter 创建多工作表 Excel 文件的详细教程
with pd.ExcelWriter(...) as writer 可以将多个内容写入一个 Excel 文件中。具体地说,它创建了一个Excel 文件写入器,使得我们可以在一个文件中创建多个工作表(Sheet)。 with pd.ExcelWriter("模型指标和损失值.xlsx")…...

驱动-----dht11温湿度传感器
单总线:只用一根线。 复位信号:设置为输出模式,低电平20ms,然后再拉高30us。然后设置为输入模式,dht11会先拉低80us,然后拉高80us表示对接成功 数据0:开始先拉低50us,然后拉高26~28u…...
Docker 基础命令简介
目录 Docker 基础命令 1. Docker 版本信息 2. 获取 Docker 帮助 3. 列出所有运行中的容器 4. 运行一个新的容器 5. 查看容器日志 6. 停止容器 7. 启动已停止的容器 8. 删除容器 9. 列出所有镜像 10. 拉取镜像 11. 构建镜像 12. 删除镜像 13. 执行命令 14. 查看容…...
嵌入式开发之静态库和共享库
静态库 静态库的特点: 默认执行库链接的时候,检索的是Linux的/lib、/usr/lib目录下,如果指定gcc -c .... -L 指定路径 -l指定库文件;c语言分为预编译、编译、汇编、链接四个步骤。链接的时候是把依赖库文件函数的代码拷贝到程序里面,即便是删除库文件。拷贝后的程序依旧…...
关于npm源的切换及相关操作
要查看当前配置的 npm 源(registry),可以使用以下命令: 查看 npm 源 npm config get registry这个命令会返回目前被设置的 npm registry URL,通常情况下是 https://registry.npmjs.org/。 列出所有 npm 配置项 如果…...
vue前端sku实现
this.value.skuStockList [];let skuList this.value.skuStockList;//只有一个属性时if (this.selectProductAttr.length 1) {let attr this.selectProductAttr[0];for (let i 0; i < attr.values.length; i) {skuList.push({spData: JSON.stringify([{key:attr.name,v…...

使用Vue3和Vue2进行开发的区别
使用Vue3和Vue2进行开发的区别 笔者虽然老早就是用vue3进行开发了,但是上次有人问道使用vue3进行开发跟使用vue2进行开发的区别有哪些这个问题的时候,回答的还是有些琐碎,干脆今天专门整理一下,做个记录。 一、再也不用set了 众所…...
爬虫入门urllib 和 request(二)
文章目录 1、urllib介绍2、urllib的基本方法介绍2.1 urllib.Request2.2 response.read() 3、urllib请求百度首页的完整例子4、小结 1、urllib介绍 除了requests模块可以发送请求之外, urllib模块也可以实现请求的发送,只是操作方法略有不同! urllib在python中分为urllib和url…...

【大数据学习 | HBASE】hbase的整体架构
hbase的region存储原理图 首先我们看到hbase的组成分为两个大的部分,分别是hmaster和hregionserver,主节点用于协调数据,regionserver用于真正的去管理表,其中regionserver存在多个,他们共同协调管理全有的表ÿ…...
群控系统服务端开发模式-应用开发-个人资料
群控系统服务端开发模式后端基础框架现在就差个人资料、及权限验证。下面开发个人资料。 一、获取个人信息 1、添加路由 在根目录下route文件夹下面app.php文件中添加如下代码: Route::post(member/personal_data,permission.Member/personalData);// 获取个人信息…...
openssl生成加密,公钥实现非对称加密
私钥用于加密,公钥用于解密 私钥用于颁发token,公钥用于验证token,公钥不能颁发token 私钥和公钥是一对,不能单独使用,利用私钥生成公钥,利用公钥进行解密 使用openssl来生成一对私钥和公钥:ope…...
[CKS] K8S Admission Set Up
最近准备花一周的时间准备CKS考试,在准备考试中发现有一个题目关于Admission。 Whats Admission Kubernetes Admission是Kubernetes集群中一种机制,用于控制和修改集群中的资源对象。它允许您在Kubernetes资源被创建、更新或删除之前,对资源…...

前端学习Day13 CSS盒子的定位(固定定位篇“附练习”)
一、固定定位 固定定位 (position:fixed)其实是绝对定位的子类别,一个设置了 position:fixed 的元素是相对于视窗固定的,就算页面文档发生了滚动,它也会一直待在相同的地方。 ⚠️:固定定位会脱离文档流。…...
Tomcat 启动卡住,日志显示 At least one JAR was scanned for TLDs yet contained no TLDs.
现象 Tomcat 启动后,控制台输出卡在了: At least one JAR was scanned for TLDs yet contained no TLDs. Enable debug logging for this logger for a complete list of JARs that were scanned but no TLDs were found in them. Skipping unneeded JA…...

计算机网络:网络层 —— 移动 IP 技术
文章目录 IPv6IPv6 的诞生背景主要优势IPv6引进的主要变化 IPv6数据报的基本首部IPv6数据报首部与IPv4数据报首部的对比 IPv6数据报的拓展首部IPv6地址IPv6地址空间大小IPv6地址的表示方法 IPv6地址的分类从IPv4向IPv6过渡使用双协议栈使用隧道技术 网际控制报文协议 ICMPv6ICM…...

useCrudSchemas
摘要: useCrudSchemas 不是一个标准的JavaScript或数据库操作库函数,也不是一个广泛认知的术语。它可能是某个特定项目或应用程序中定义的一个自定义函数或方法,用于简化CRUD(创建、读取、更新、删除)操作。 在Web开发…...

SpringBoot3集成Junit5
目录 1. 确保项目中包含相关依赖2. 配置JUnit 53. 编写测试类4、Junit5 新增特性4.1 注解4.2 断言4.3 嵌套测试4.4 总结 在Spring Boot 3中集成JUnit 5的步骤相对简单。以下是你可以按照的步骤: 1. 确保项目中包含相关依赖 首先,确保你的pom.xml文件中…...
conda相比python好处
Conda 作为 Python 的环境和包管理工具,相比原生 Python 生态(如 pip 虚拟环境)有许多独特优势,尤其在多项目管理、依赖处理和跨平台兼容性等方面表现更优。以下是 Conda 的核心好处: 一、一站式环境管理:…...
Java 语言特性(面试系列2)
一、SQL 基础 1. 复杂查询 (1)连接查询(JOIN) 内连接(INNER JOIN):返回两表匹配的记录。 SELECT e.name, d.dept_name FROM employees e INNER JOIN departments d ON e.dept_id d.dept_id; 左…...

376. Wiggle Subsequence
376. Wiggle Subsequence 代码 class Solution { public:int wiggleMaxLength(vector<int>& nums) {int n nums.size();int res 1;int prediff 0;int curdiff 0;for(int i 0;i < n-1;i){curdiff nums[i1] - nums[i];if( (prediff > 0 && curdif…...

令牌桶 滑动窗口->限流 分布式信号量->限并发的原理 lua脚本分析介绍
文章目录 前言限流限制并发的实际理解限流令牌桶代码实现结果分析令牌桶lua的模拟实现原理总结: 滑动窗口代码实现结果分析lua脚本原理解析 限并发分布式信号量代码实现结果分析lua脚本实现原理 双注解去实现限流 并发结果分析: 实际业务去理解体会统一注…...

12.找到字符串中所有字母异位词
🧠 题目解析 题目描述: 给定两个字符串 s 和 p,找出 s 中所有 p 的字母异位词的起始索引。 返回的答案以数组形式表示。 字母异位词定义: 若两个字符串包含的字符种类和出现次数完全相同,顺序无所谓,则互为…...

k8s业务程序联调工具-KtConnect
概述 原理 工具作用是建立了一个从本地到集群的单向VPN,根据VPN原理,打通两个内网必然需要借助一个公共中继节点,ktconnect工具巧妙的利用k8s原生的portforward能力,简化了建立连接的过程,apiserver间接起到了中继节…...

DeepSeek源码深度解析 × 华为仓颉语言编程精粹——从MoE架构到全场景开发生态
前言 在人工智能技术飞速发展的今天,深度学习与大模型技术已成为推动行业变革的核心驱动力,而高效、灵活的开发工具与编程语言则为技术创新提供了重要支撑。本书以两大前沿技术领域为核心,系统性地呈现了两部深度技术著作的精华:…...

相关类相关的可视化图像总结
目录 一、散点图 二、气泡图 三、相关图 四、热力图 五、二维密度图 六、多模态二维密度图 七、雷达图 八、桑基图 九、总结 一、散点图 特点 通过点的位置展示两个连续变量之间的关系,可直观判断线性相关、非线性相关或无相关关系,点的分布密…...

Canal环境搭建并实现和ES数据同步
作者:田超凡 日期:2025年6月7日 Canal安装,启动端口11111、8082: 安装canal-deployer服务端: https://github.com/alibaba/canal/releases/1.1.7/canal.deployer-1.1.7.tar.gz cd /opt/homebrew/etc mkdir canal…...

PLC入门【4】基本指令2(SET RST)
04 基本指令2 PLC编程第四课基本指令(2) 1、运用上接课所学的基本指令完成个简单的实例编程。 2、学习SET--置位指令 3、RST--复位指令 打开软件(FX-TRN-BEG-C),从 文件 - 主画面,“B: 让我们学习基本的”- “B-3.控制优先程序”。 点击“梯形图编辑”…...