vue项目使用jest单元测试常见问题

介绍

项目是利用vue-cli创建的前端工程项目,在项目中引用jest进行单元测试。
参考:jest官方文档

.toBe(value)问题

toBe() 相当于Object.is(),在判断测试样例返回值和目标值是否一致上,对于Object对象只是判断地址是否一致,如果地址不一致就会判定为两者不相等。对于Object对象的判定,推荐使用toStrictEqual()。

对应源码调用的方法都要进行mock

源码中正常执行过程调用到的方法都要在测试样例里面进行Mock,并且mock 要在源函数被调用之前,比如:

// 源码
scrollToTop() {
   
 	window.scrollTo(0, 0) // 调用了window下的函数
  })
}

// 对应的单元测试样例
test('回到顶部', () => {
   
    window.scrollTo = jest.fn() // 对window下的函数进行mock,即对源码中调用的目标函数进行mock
    wrapper.vm.scrollToTop() // 调用源函数(在mock之后)
    expect(window.scrollTo).toHaveBeenCalledWith(0, 0) // 判定调用的参数
  })

created 调用了函数

为了避免test的时候出现[vue warn]、prototype undefind、或者function undefind的问题,需要在shallowMount()里面对函数进行mock初始化和参数的初始化。
如:

import {
    shallowMount } from '@vue/test-util
  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值