Jest 测试框架:构建可靠的测试体系

Jest 测试框架:构建可靠的测试体系

什么是 Jest?

Jest 是 Facebook 开发的 JavaScript 测试框架,具有简洁的 API 和强大的功能。

Jest 的特点

特性 说明
零配置 开箱即用
快照测试 自动生成和比对快照
代码覆盖率 内置覆盖率报告
Mock 功能 强大的 mocking 能力

基础测试

javascript 复制代码
// sum.js
function sum(a, b) {
  return a + b;
}
module.exports = sum;

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

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

匹配器

javascript 复制代码
test('常见匹配器', () => {
  // 相等性
  expect(2 + 2).toBe(4);
  expect({ name: 'John' }).toEqual({ name: 'John' });
  
  // 真值
  expect(null).toBeNull();
  expect(undefined).toBeUndefined();
  expect(1).toBeTruthy();
  
  // 数字
  expect(2).toBeGreaterThan(1);
  expect(1).toBeLessThan(2);
  
  // 字符串
  expect('hello').toMatch(/ello/);
  
  // 数组
  expect([1, 2, 3]).toContain(2);
});

异步测试

javascript 复制代码
// Promise
test('异步测试 - Promise', () => {
  expect.assertions(1);
  return fetchData().then(data => {
    expect(data).toBe('peanut butter');
  });
});

// Async/Await
test('异步测试 - Async/Await', async () => {
  expect.assertions(1);
  const data = await fetchData();
  expect(data).toBe('peanut butter');
});

Mock 函数

javascript 复制代码
const mockFn = jest.fn();

mockFn('hello');
expect(mockFn).toHaveBeenCalled();
expect(mockFn).toHaveBeenCalledWith('hello');

// Mock 返回值
const mockReturn = jest.fn().mockReturnValue('mocked value');
expect(mockReturn()).toBe('mocked value');

Mock 模块

javascript 复制代码
// __mocks__/axios.js
module.exports = {
  get: jest.fn().mockResolvedValue({ data: 'mocked data' })
};

// api.test.js
jest.mock('axios');
const axios = require('axios');

test('mock 模块', async () => {
  await fetchData();
  expect(axios.get).toHaveBeenCalledWith('/api/data');
});

快照测试

javascript 复制代码
test('快照测试', () => {
  const component = renderer.create(<Button />).toJSON();
  expect(component).toMatchSnapshot();
});

测试配置

javascript 复制代码
// jest.config.js
module.exports = {
  testEnvironment: 'jsdom',
  moduleNameMapper: {
    '\\.(css|less)$': '<rootDir>/__mocks__/styleMock.js'
  },
  setupFilesAfterEnv: ['<rootDir>/setupTests.js'],
  coverageThreshold: {
    global: {
      branches: 80,
      functions: 80,
      lines: 80,
      statements: 80
    }
  }
};

测试钩子

javascript 复制代码
beforeAll(() => {
  console.log('所有测试开始前');
});

beforeEach(() => {
  console.log('每个测试开始前');
});

afterEach(() => {
  console.log('每个测试结束后');
});

afterAll(() => {
  console.log('所有测试结束后');
});

代码覆盖率

bash 复制代码
# 生成覆盖率报告
npx jest --coverage

# 查看覆盖率报告
open coverage/lcov-report/index.html

实战案例

javascript 复制代码
// userService.test.js
const UserService = require('./userService');

describe('UserService', () => {
  let service;
  
  beforeEach(() => {
    service = new UserService();
  });
  
  describe('getUser', () => {
    it('应该返回用户信息', async () => {
      const user = await service.getUser(1);
      expect(user.id).toBe(1);
      expect(user.name).toBe('John');
    });
    
    it('应该抛出错误当用户不存在', async () => {
      await expect(service.getUser(999)).rejects.toThrow('User not found');
    });
  });
});

总结

Jest 是一个功能强大的测试框架:

  1. 易于使用:简洁的 API
  2. 功能丰富:快照、mock、覆盖率
  3. 生态完善:与 React、Vue 等框架无缝集成
  4. 社区活跃:大量插件和资源

编写高质量的测试,让你的代码更加可靠。

相关推荐
wait2 小时前
Vibe Coding 开发技巧
前端·javascript·人工智能
bloxed2 小时前
【AI大模型--NumPy-06】随机数生成与蒙特卡洛模拟
人工智能·numpy
szxinmai主板定制专家2 小时前
基于ZYNQ MPSOC图像采集与压缩系统总体设计方案
linux·arm开发·人工智能·嵌入式硬件·fpga开发
GOTXX2 小时前
SenseNova U1 实战体验:API 调用 + OpenClaw 接入全流程
服务器·网络·人工智能·语言模型
生成论实验室2 小时前
用事件关系网络重新理解AI(三):激活函数、微调与元学习
人工智能·学习·算法·语言模型·可信计算技术
Narv工程师2 小时前
嵌入式机器人控制器算力评估:从DMIPS到WCET的完整指南
人工智能·算法·机器学习
searchforAI2 小时前
AI多模态技术:从语音识别到AI结构化笔记是怎么实现的
人工智能·经验分享·笔记·gpt·whisper·语音识别
LCG元2 小时前
RAG - 大模型检索增强生成深度解析:本地知识库 / 企业级落地优化配置
人工智能·算法
用户5191495848452 小时前
WordPress ACF City Selector 插件任意文件上传漏洞利用工具 (CVE-2024-56264)
人工智能·aigc