vue中关于测试的知识介绍

前言

Vue-Cli 推荐两种测试分别是:端到端的测试(E2E) 和 单元测试(Unit Test)


一、端到端(E2E)

端(消费端)到端(产品端)的测试(E2E (End-to-End)), 它用来测试一个应用从头到尾的流程是否和设计时候所想的一样。简而言之,它从一个用户的角度出发,认为整个系统都是黑箱,只有UI会暴露给用户


二、单元测试(Unit Test)

测试驱动开发(TDD: Test-Driven Development), 单元测试是用来对一个模块、一个函数或者一个类来进行正确性检验的测试工作。

Vue中的单元测试中主要使用两个工具分别是( Jest +Karma+ Mocha(Chai) )

Karma

Karma是一 个基于Node.js的JavaScript测试执行过程管理工具( Test Runner)。该工具在Vue中的主要作用是将项目运行在各种主流Web浏览器进行测试。

换句话说,它是一个测试工具,能让你的代码在浏览器环境下测试。

需要它的原因在于,你的代码可能是设计在浏览器端执行的,在node环境下测试可能有些bug暴露不出来;另外,浏览器有兼容问题, karma提供了手段让你的代码自动在多个浏览器( chrome,firefox ,ie等)环境下运行。

如果你的代码只会运行在node端,那么你不需要用karma 。

Mocha

mocha(摩卡)是一个测试框架,在vue-cli中配合。 mocha本身不带断言卡,所以必须先引入断言库,Chai断言库实现单元测试。

Mocha的常用命令和用法不算太多,而Chai断言库可以看Chai.js断言库API中文文档,很简单,多查多用就能很快掌
握。

断言库

所谓“断言” ,就是判断源码的实际执行结果与预期结果是否-致,如果不一致就抛出一个错误。下面这句断言的意思是,调用add(1, 1) ,结果应该等于2.

var expect = require('chai).expect;
expect(1 + 1)).to.be.equal(2);
Chai是一种断言库(http://chaijs.com/)

所有的测试用例( it块)都应该含有一句或多句的断言。 它是编写测试
用例的关键。断言功能由断言库来实现。

常用的关键字如下,具体意义及使用方法,可参考:https://www.jianshu.com/p/f200a75a15d2/

  • to
  • be
  • been
  • is
  • that
  • which
  • and
  • has
  • have
  • with
  • at
  • of
  • same

Jest (一般使用这个,请仔细阅读)

官方提供的单元测试的模块@vue/test-utils,它使用的是Jest风格的expect断言。

具体示例如下:

// 挂载这个组件
const wrapper = shallowMount(MyComponent)
// 这里是一些 Jest 的测试,你也可以使用你喜欢的任何断言库或测试
describe('MyComponent', () => {
  // 检查原始组件选项
  it('has a created hook', () => {
    expect(typeof MyComponent.created).toBe('function')
  })
  // 评估原始组件选项中的函数的结果
  it('sets the correct default data', () => {
    expect(typeof MyComponent.data).toBe('function')
    const defaultData = MyComponent.data()
    expect(defaultData.message).toBe('hello!')
  })
  // 检查 mount 中的组件实例
  it('correctly sets the message when created', () => {
    expect(wrapper.vm.$data.message).toBe('bye!')
  })
  // 创建一个实例并检查渲染输出
  it('renders the correct message', () => {
    expect(wrapper.text()).toBe('bye!')
  })
})

注:

  1. 一个it就相当于一个测试用例
  2. 一个组件一般就对应一个测试文件,文件后以为spec.js结尾
    目录结构如下:

目录结构

  1. jest使用api,可参考官方文件https://vue-test-utils.vuejs.org/api/
  2. 写好后,使用npm run unit指令运行,进行测试
最后,本文关于vue中的测试介绍,就到这。还有不清楚的,可以本文留言,一起讨论

作者:doubleyong

公众号:bug收集

博客:bugshouji.com (专门解决与收集bug的网站)

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

bug收集

谢谢老板的鼓励,我会继续加油

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值