前端自动化测试-Jest

前端自动化测试

Jest官网:https://jestjs.io

安装方式

npm install --save-dev jest

yarn add --dev jest

cnpm add --save-dev jest

使用方法

所有以 .test.js 结尾的都是测试文件

基础用法示例

num.js:

javascript 复制代码
export function getSum (a, b) {
  return a + b
}

num.test.js:

javascript 复制代码
import { getSum } from './num'

test('功能', () => {
  expect(getSum(1, 2)).toBe(3)
  expect(getSum(3, 2)).toBe(5)
  expect(getSum(3, 4)).toBe(7)
})

运行test测试脚本后结果:

成功时:

报错时:

当有很多测试用例时,只想测某一个时

javascript 复制代码
test.only('B 功能', () => {
  expect(getSum(2, 4)).toBe(6)
})

一些常用断言

javascript 复制代码
test.only('C 功能', () => {
  expect(getSum(2, 4)).toBe(6) // 等于
  expect({ name: 'jack' }).toEqual({ name: 'jack' }) // 对象可以看到的部分是否一致
  expect('ababc').toMatch(/bab/) // 字符串匹配
  expect(4).toBeGreaterThan(3) // 大于
  expect(4).toBeGreaterThanOrEqual(3) // 大于等于
  expect(3).toBeLessThanOrEqual(5) // 小于
  expect(3).toBeLessThanOrEqualOrEqual(5) // 小于等于
})

方法层面的细致测试

javascript 复制代码
describe('模块A', () => {
  test('A 功能', () => {
    console.log('A 功能')
    expect(getSum(1, 2)).toBe(3)
  })

  test('B 功能', () => {
    console.log('B 功能')
    expect(getSum(1, 2)).toBe(3)
  })
})
describe('模块B', () => {
  test('C 功能', () => {
    console.log('C 功能')
    expect(getSum(1, 2)).toBe(3)
  })

  test('D 功能', () => {
    console.log('D 功能')
    expect(getSum(1, 2)).toBe(3)
  })
})

package.json配置

在script下添加 test配置:

javascript 复制代码
"scripts": {
   "test": "jest"
 }

配置Jest ------ jest.config

javascript 复制代码
npx jest --init

1.需不需要用ts生成文件

2.测试环境是什么:jsdom | node

3.是否添加覆盖率报告

4.代码覆盖采用形式:v8 | babel

5.是否需要清除每次模拟的数据

默认识别测试文件:

javascript 复制代码
   testMatch: [
     "**/__tests__/**/*.[jt]s?(x)",
     "**/?(*.)+(spec|test).[tj]s?(x)"
   ],

__tests__文件夹内的js或ts 或

.spec 或 .test 的js 或ts

希望忽略的一些目录

javascript 复制代码
  coveragePathIgnorePatterns: [
    "\\\\node_modules\\\\"
  ],

热启动

package.json配置

javascript 复制代码
"scripts": {
   "test": "jest --watchAll" 
 }

关于Jest中使用babel处理es6转es5

补充相关依赖(babel-jest的套件、babel核心功能、babel运行环境):

javascript 复制代码
yarn add --dev babel-jest @babel/core @babel/preset-env

配置babel.config.js

javascript 复制代码
module.exports = {
 presets: [
   [
     '@babel/preset-env',
     {
       targets: {
         node: 'current'
       }
     }
   ]
 ]
}

生命周期

javascript 复制代码
beforeAll(() => {
   console.log('当前测试模块执行前触发')
})

beforeEach(() => {
   console.log('每次测试前执行')
})

afterAll(() => {
   console.log('当前测试模块执行后触发')
})

afterEach(() => {
   console.log('每次测试后执行')
})

------------------ 未完待续 ------------------

相关推荐
li35744 分钟前
将已有 Vue 项目通过 Electron 打包为桌面客户端的完整步骤
前端·vue.js·electron
Icoolkj28 分钟前
VuePress 与 VitePress 深度对比:特性、差异与选型指南
前端·javascript·vue.js
excel42 分钟前
CNN 分层详解:卷积、池化到全连接的作用与原理
前端
excel1 小时前
CNN 多层设计详解:从边缘到高级特征的逐层学习
前端
西陵2 小时前
Nx带来极致的前端开发体验——任务编排
前端·javascript·架构
大前端helloworld2 小时前
从初中级如何迈入中高级-其实技术只是“入门卷”
前端·面试
东风西巷4 小时前
Balabolka:免费高效的文字转语音软件
前端·人工智能·学习·语音识别·软件需求
萌萌哒草头将军4 小时前
10个 ES2025 新特性速览!🚀🚀🚀
前端·javascript·vue.js
半夏陌离4 小时前
SQL 入门指南:排序与分页查询(ORDER BY 多字段排序、LIMIT 分页实战)
java·前端·数据库