Vue Test Utils

VUE中的测试

  • 端到端的测试(E2E)
    • 黑盒测试 从UI界面的角度进行测试 E2E比较少的一般
  • 单元测试(Unit Test)
    • 测试驱动开发 单元测试就是对一个模块,一个函数,或者一个类进行正确性的测试工作
    • Vue中的单元测试主要使用两个工具 分别是(Karma + Mocha

Karma

  • Karma是一个基于Nodejs的js测试管理工具 该工具在vue中主要作用就是将项目运行在各种浏览器web进行测试

Mocha

  • Mocha 是一个测试框架 在vue-cli中配合
  • Mocha 本身不带断言库 所以必须先引入断言库 Chai断言库实现单元测试

断言库

  • 断言 就是判断源代码的实际执行结果是否和预期结果一致 如果不一致就抛出一个错误,

    var expect = require('chai').expect;
    expect(1+1).to.bt.equal(2);
  • chai是一种断言库 所以测试用例都应该含有一句或者多个断言,他是编写测试用例的关键。断言功能由断言库来实现。

Vue 初始化测试

  • npm

  • 我们要测试哪个组件就要保证组件名称和测试文件要保持一致

  • 后缀要加上 spec.js 的后缀 确保是测试文件

    // 引用vue的需要测试的组件
    import Vue from 'vue'
    import HelloWord from '@/components/HelloWorld'
    // 创建测试套件 一个测试组件写一个测试套件
    describe('测试套件的名称',() => {
        // 测试用例 用来测试不同的方法或者显示不同的内容
        it('should render corrent contents', () => {
            // 通过vue来渲染helloWorld
            const Constructor = Vue.extend(HelloWorld)
            const vm = new Constructor().$mount()
            // 判断页面中是否有 msg 渲染出来的内容
            expect(vm.$el.querySelector('.hello h1').textContent).to.equal('Welcome...')
        })
    })
    
  • npm run unit 运行项目

Vue使用测试步骤

  • 初始化项目
  • 测试用例报告
    • 完成了 测试之后 可以查看到 测试用例报告(index.html)

Vue-text-utils

  • 页面引用子组件就是 引入加注册组件就可以有效果展示了

查看功能测试

  • 下载一个 官方的 测试工具包

  • 新建一个 页面名称.spec.js 的测试文件

    // 只要有引用了 就可以不用再引用 Vue 了 
    // 然后引用 vue 的测试工具就可以了
    import { mount } from '@vue/test-utils'
    
    // 引用 需要测试的组件 页面名称.vue
    import todoMVC from '@/components/todoMVC.vue'
    
    // 创建测试套件
    describe('TodoMVC测试套件',()=>{
        // 创建不同的测试用例
        // 测试查看功能的用例
        it('测试查看功能',()=>{
            // 通过 mount 将组件渲染出来
            const wrapper = mount(todoMVC);
            
            // 寻找指定的 DOM元素  
            // console.log(wrapper.find('.todo-list)) 
            // 如果能找到说明 wrapper 就是我们组件里面的内容
            // 通过VM 寻找 data中的数据
            // console.log(wrapper.vm)    // vm就是 vue在处理data的时候包含的所有元素
            // console.log(wrapper.vm.todos)
            
            // 然后通过 expect 做断言
            expect(wrapper.vm.todos.length).to.be.equal(2);
        })
    })
    

    删除功能测试

    // 创建测试套件
    describe('TodoMVC测试套件',()=>{
        // 创建不同的测试用例
        // 测试删除功能的用例
        it('测试查看功能',()=>{
            // 通过mount将组件渲染出来
            const wrapper = mount(todoMVC);
            // 找到删除按钮 做点击事件
            // 删除按钮点击       如果列数变少 就表示删除事件成功了
            console.log(wrapper.find(".destroy"))  // 先打印一下这个button 然后看一下
            // 找到删除按钮
            const delbtn = wrapper.find(".destroy")
            // 删除按钮点击
            delbtn.trigger('click')
            // 验证 todos 中有数据被删除   expect 做断言
            expect(wrapper.vm.todos.length).to.be.equal(1);
        })
    })

    修改功能测试

    @dblclick() 双击修改样式实现方式
    双击的时候传递已给 todo的样式值 然后 判断相等进行样式变动 然后另外一个就已经是不相等了然后就不会改变样式
    
    // 创建测试套件
    describe('TodoMVC测试套件',()=>{
        // 创建不同的测试用例
        // 测试修改功能的用例
        it('测试修改功能',()=>{
            // 通过mount将组件渲染出来
            const wrapper = mount(todoMVC);
            // 找到li标签 -> 然后找到label标签
            const li = wrapper.find("li")
            const label = li.find("label")
            // 给label标签双击事件
            label.trigger('dblclick');
            // 查看label 标签是否含有 editing 样式
            // console.log(li.classes() === "");
            // 判断这个东西是否存在数组里面include判断包含 然后进行 npm run unit 测试
            expect(li.classes()).to.be.include('editing');
        })
    })



作者:glAkihi
链接:https://www.jianshu.com/p/6d9972fa0d12
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。


 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值