单元测试学习笔记

单元测试是软件测试的基础层级,主要针对代码的最小可测试单元进行验证。单元测试可以帮助快速定位问题边界,提升代码可维护性,支持安全的重构操作。

测试对象:

  • 独立函数/方法
  • 纯工具类(如数据处理函数)
  • UI组件(不依赖外部环境的独立组件)
  • 自定义Hooks(React场景)
工具类型 推荐方案 特点
测试框架 Jest/Vitest 零配置、快照测试
DOM测试库 Testing Library 用户行为导向的组件测试
覆盖率统计 Istanbul/NYC 可视化报告生成
Mock解决方案 Jest.fn + MSW 网络请求/定时器模拟

demo:

// 工具函数

export const formatPrice = (num) => {

if (typeof num !== 'number') return '0.00'

return num.toFixed(2).replace(/\B(?=(\d{3})+(?!\d))/g, ',')

}

// 测试用例

test('格式化金额显示', () => {

expect(formatPrice(1234.56)).toBe('1,234.56')

expect(formatPrice(null)).toBe('0.00') // 边界值测试

expect(formatPrice('invalid')).toBe('0.00') // 异常输入处理

})

// React组件测试

import { render, screen } from '@testing-library/react'

test('显示加载状态', () => {

render(<LoadingSpinner visible={true} />)

expect(screen.getByRole('status')).toBeInTheDocument()

expect(screen.queryByText('Loading...')).not.toBeNull()

})

test('隐藏加载状态', () => {

render(<LoadingSpinner visible={false} />)

expect(screen.queryByRole('status')).toBeNull()

})

// vue组合式api测试

import { useCounter } from './counter'

import { ref } from 'vue'

test('计数器功能', () => {

const { count, increment } = useCounter(ref(5))

expect(count.value).toBe(5)

increment()

expect(count.value).toBe(6)

})

相关推荐
芒鸽15 小时前
鸿蒙应用测试实战:从单元测试到自动化测试
华为·单元测试·harmonyos
MC皮蛋侠客1 天前
Google Test 单元测试指南
c++·单元测试·google test
英俊潇洒美少年3 天前
前端 Jest 单元测试零基础实战:模板、提效、避坑、面试题(Vue 项目可用)
前端·vue.js·单元测试
测试员周周7 天前
【Appium 系列】第18节-重试与容错 — 移动端测试的稳定性保障
人工智能·python·功能测试·ui·单元测试·appium·测试用例
测试员周周7 天前
【Appium 系列】第17节-XMind用例转换 — 从思维导图到 YAML
java·服务器·人工智能·单元测试·appium·测试用例·xmind
一路往蓝-Anbo7 天前
第五章:如何对 HAL 库本身进行单元测试?
网络·数据结构·stm32·单片机·嵌入式硬件·单元测试·tdd
计算机安禾7 天前
【c++面向对象编程】第49篇:面向对象的单元测试:用GoogleTest测试类
开发语言·c++·单元测试
测试员周周7 天前
【Appium 系列】第20节-测试项目结构设计 — 从脚本到工程
人工智能·数据挖掘·回归·单元测试·appium·测试用例·测试覆盖率
数字供应链安全产品选型7 天前
2025年Gartner中国安全技术成熟度曲线解读:软件供应链安全从“过热”到“落地”的演进之路
人工智能·web安全·单元测试·软件供应链安全