Vue Test Utils

Vue Test Utils笔记

test

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');
    })
})
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,393评论 5 467
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,790评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,391评论 0 330
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,703评论 1 270
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,613评论 5 359
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,003评论 1 275
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,507评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,158评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,300评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,256评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,274评论 1 328
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,984评论 3 316
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,569评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,662评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,899评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,268评论 2 345
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,840评论 2 339

推荐阅读更多精彩内容