Jest 测试ES类

我们介绍了使用Jest 测试函数,测试异步函数,Mock 函数,那么怎么测试class呢?

引入

首先,我们创建一个class

javascript 复制代码
// 这里,我们写一个类
class util {
    af(a, b) {
        console.log(a, b)
    }

    bf(a, b) {
        console.log(a, b)
    }

    cf(a, b) {
        console.log(a, b)
    }
}


export default util

然后,我们按照以前的经验进行测试

要注意的是,我们这个测试要在所有用例前,实例化util

那么就会是

javascript 复制代码
import Util from "./main"

let util = null;

beforeAll(() => {
    util = new Util()
})

it("测试类", () => {
    expect(util.af("akun", "akun02")).toEqual("akunakun02")
})

正如你看到的, 我们这样也是可以进行测试的,但是,如果这个class里边的方法都异常的复杂,那么你的测试效率是很低的,所以我们接下载要使用Jest 的mock class

Mock

我们创建一个媒介函数,用来调用实例化和使用我们class的方法

javascript 复制代码
// 导入我们自己写的
import Util from "./main"

const demoFunc = (a, b) => {
    // 实例化
    let util = new Util();
    util.af('akun','akun02')
    util.bf('akun','akun02')
}


export default demoFunc

然后,我们进行mock,和测试

javascript 复制代码
// 模拟类  他一看是类,就自动转为mock fn
jest.mock("./main")

import Util from "./main"

import demoFunc from "./MockClass";


it("测试", () => {
    demoFunc();
    // 检查 Util 是否被实例化
    expect(Util).toHaveBeenCalledTimes(1);

    // 查看 mock 类信息
    console.log(Util.mock)  // 查看 mock 类结构
    console.log(Util.mock.instances[0])  // 查看第一次实例化的对象
    expect(Util.mock.instances[0].af).toHaveBeenCalled()
    expect(Util.mock.instances[0].bf).toHaveBeenCalled()
})

在这里,我们使用Jest mock的时候,不论你把这句话放在哪里,他始终会被提升到第一行执行

我们的测试函数也很简单,调用我们媒介函数,然后测试我们的mock的Util是否被执行

在这里要注意,toHaveBeenCalledTimes等API仅使用于Jest Mock的函数,自己写的不算

那这里为什么可以使用呢?

因为,我们的mock会把你的util进行处理,他一看你的文件里边是一个class,那么他就会把所有的变为Jest.fn(),模拟函数

所以你才可以使用API

所以Jest Mock Class 就是这样了,如果你对他的mock不满意,可以创建_Mock_文件夹,创建util.js文件,自己写Mock

相关推荐
Rain50913 分钟前
mini-cc 终端 UI:用 React 写 CLI 是什么体验
前端·人工智能·react.js·ui·架构·前端框架·ai编程
wu85877345718 分钟前
向量数据库不是银弹:从枚举漏检到 ReACT 多轮召回的实践路径
前端·数据库·react.js
meilindehuzi_a20 分钟前
深入理解 JavaScript 执行机制:从编译阶段到调用栈底层实现
开发语言·javascript·ecmascript
古怪今人22 分钟前
[前端]HTML盒模型与尺寸,标准文档流,块级元素、内联元素和行内块,CSS选择器
前端·css
小雨下雨的雨43 分钟前
基于鸿蒙PC Electron框架技术完成的表单验证技术详解
前端·javascript·华为·electron·前端框架·鸿蒙
提子拌饭13344 分钟前
饮料含糖量查询应用 - 鸿蒙PC用Electron框架完整实现
前端·javascript·华为·electron·前端框架·鸿蒙
JustHappy1 小时前
古法编程秘籍(五):什么是进程和线程?从软件到 CPU 的一次完整旅程
前端·后端·代码规范
爱编程的小金1 小时前
前端请求库的下一个进化方向:从 Promise 到策略化
前端·alova·前端请求库·请求策略
hsg771 小时前
简述:Jensen Huang‘s Footsteps网站全内容分析
前端·javascript·数据库
珑墨1 小时前
前端 AI 开发通用skill
前端