Vue 单元测试 使用mocha+jest
Vue 单元测试
官网:https://vue-test-utils.vuejs.org/zh
定义:
单元测试是用来对一个模块、一个函数或者一个类来进行正确性检验的测试工作。
指令:
package.json文件
- "test:unit": "vue-cli-service test:unit"
测试驱动开发(TDD:Test-Driven Development)
mocha+jest
测试框架 mocha
Mocha官网:https://mochajs.org/使用expect断言语句
chia官网:https://www.chaijs.com/
chia部分方法文档:https://www.chaijs.com/api/assert/
是JavaScript的一种单元测试框架。
mocha的特点主要有:既可以测试简单的JavaScript函数,又可以测试异步代码,因为异步是JavaScript的特性之一;
可以自动运行所有测试,也可以只运行特定的测试;
可以支持before、after、beforeEach和afterEach来编写初始化代码。
参考
断言库 jest
jest
实例 mocha expect方法断言
格式模板
describe 套件
describe('名称',()=>{
<!-- 用例 -->
it('方法描述',()=>{
/* 使用expect 断言语句 */
/* 方法举例 */
expcect(/* 需要检测的方法 */).to.be.equal(/* 检测结果 */)
})
})
描述
it()
测试异步代码 通过将回调(通常称为done)添加到it()
.to.be.equal 是否相等
.to.be.deep.equal 是否严格相等
示例代码
tests\unit\parser.spec.ts
测试各类断言语句执行成功或者失败
/* 编写测试用例 */
import {parser,stringify} from '@/code/parser';
/* 使用mocha(测试工具) +chai(断言库) */
import { expect } from 'chai';
/* 套件 */
describe('mytest1', () => {
/* 用例 */
// 常见的关系 相等 大于/小于 包含和不包含
it('测试parser方法是否可用',()=>{
// deep.equal 表示两个对象是否完全相等(引用空间无所谓)
// .to.be.equal 表示两个对象相等(引用空间无所谓)
expect(parser('name=zfpx')).to.be.deep.equal({name:'zfpx'})
})
it('测试stringify方法是否可用',()=>{
expect(stringify({name:'3px'})).to.be.equal('name=3px')
})
})
/* 断言语句各类 */
describe('测试方法',()=>{
it('相等关系',()=>{
expect(1+1).to.be.equal(2);//相加的值
expect([1,2,3]).to.be.lengthOf(3);//长度
expect(true).to.be.true;//布尔值
})
it('包含',()=>{
expect('zfpx').to.be.contain('zf');//是否包含指定字符
expect('zfpx').to.be.match(/zf/);//是否匹配正则 })
it('大于,小于',()=>{
expect(5).to.be.greaterThan(3)
expect(3).to.be.lessThan(6)
expect(3).to.be.not.greaterThan(5)//不大于3
})
})测试模块是否正确渲染值
src\components\unittest\demo1.vue
<!-- 单元测试:是否能成功显示渲染的组件元素 -->
<template>
<div class="demo1">
<h1>{{ datas }}</h1>
</div>
</template> <script>
export default {
name:'demo1',
props:['datas'],
data () {
return { };
}
} </script>
<style lang='less' scoped>
</style>tests\unit\unit1.spec.ts
import unitdemo1 from '@/components/unittest/demo1.vue';
import Vue from 'vue';
import {expect} from 'chai';
import {mount} from '@vue/test-utils';
/* 写法1 产地属性后能否正常显示结果*/
describe('unitdemo1',()=>{
it('1.传递属性后能否正常显示结果',()=>{
// 原生自己测试vue
// extend 方法可以根据实例创建一个类
let Constructor = Vue.extend(unitdemo1);
// 对组件进行挂载
// vm.$el mocha 测试的时候集成了 jsdom
let vm:any = new Constructor({
propsData:{datas:'hello'}
}).$mount(); /* 检测h1标签内是否包含hello */ expect(vm.$el.querySelector('h1').innerHTML).to.be.contain('hello');
})
})
/* 写法2 使用mount */
describe('unitdemo1',()=>{
it('2.传递属性后能否正常显示结果',()=>{
let wrapper = mount(unitdemo1);
/* 设置 Wrapper vm 的 prop 并强制更新。
https://vue-test-utils.vuejs.org/zh/api/wrapper/setProps.html
*/
wrapper.setProps({datas:'hello'});//设定传递的值为hello
expect(wrapper.find('h1').text()).to.be.contain('hello');
})
})
测试模块内的加法是否执行
src\components\unittest\demo2.vue
<!-- -->
<template>
<div>
<span id="count">{{count}}</span>
<button @click = "increment">+</button>
</div>
</template>
<script>
//这里可以导入其他文件(比如:组件,工具js,第三方插件js,json文件,图片文件等等)
//例如:import 《组件名称》 from '《组件路径》'; export default {
//import引入的组件需要注入到对象中才能使用
components: {},
data() {
//这里存放数据
return {
count:10
};
},
//监听属性 类似于data概念
computed: {},
//监控data中的数据变化
watch: {},
//方法集合
methods: {
increment(){
this.count++
}
},
//生命周期 - 创建完成(可以访问当前this实例)
created() {},
//生命周期 - 挂载完成(可以访问DOM元素)
mounted() {},
beforeCreate() {}, //生命周期 - 创建之前
beforeMount() {}, //生命周期 - 挂载之前
beforeUpdate() {}, //生命周期 - 更新之前
updated() {}, //生命周期 - 更新之后
beforeDestroy() {}, //生命周期 - 销毁之前
destroyed() {}, //生命周期 - 销毁完成
activated() {} //如果页面有keep-alive缓存功能,这个函数会触发
};
</script>
<style lang='lesss' scoped>
/* //@import url(); 引入公共css类 */
</style>
tests\unit\unit2.spec.ts
import unitdemo2 from '@/components/unittest/demo2.vue';
import Vue from 'vue';
import {expect} from 'chai';
import {mount} from '@vue/test-utils'; /* 写法2 使用mount */
describe('测试demo2组件',()=>{
it('单机能否+1',()=>{
let wrapper = mount(unitdemo2);
expect(wrapper.find('#count').text()).to.be.equal('10');
wrapper.find('button').trigger('click');
expect(wrapper.find('#count').text()).to.be.equal('11');
})
})
测试代码执行:npm run test:unit
测试结果
DONE Compiled successfully in 3577ms
[=========================] 100% (completed)
WEBPACK Compiled successfully in 3577ms
MOCHA Testing...
{ name: 'zfpx' }
name=zfpx
mytest1
√ 测试parser方法是否可用
√ 测试stringify方法是否可用
测试方法
√ 相等关系
√ 包含
√ 大于,小于
unitdemo1
√ 1.传递属性后能否正常显示结果
unitdemo1
√ 2.传递属性后能否正常显示结果
测试demo2组件
√ 单机能否+1
8 passing (111ms)
MOCHA Tests completed successfully
Vue 单元测试 使用mocha+jest的更多相关文章
- Vue单元测试Karma+Mocha
Vue单元测试Karma+Mocha Karma是一个基于Node.js的JavaScript测试执行过程管理工具(Test Runner).该工具在Vue中的主要作用是将项目运行在各种主流Web浏览 ...
- 使用Karma、Mocha实现vue单元测试
Karma Karma是一个基于Node.js的JavaScript测试执行过程管理工具(Test Runner).该工具在Vue中的主要作用是将项目运行在各种主流Web浏览器进行测试.换句话说,它是 ...
- 前端单元测试框架-Mocha
引言 随着前端工程化这一概念的产生,项目开发中前端的代码量可谓是'急剧上升',所以在这种情况下,我们如何才能保证代码的质量呢,对于框架,比如React.Vue,因为有自己的语法规则,及时每个开发人员的 ...
- 使用 Jest 进行 Vue 单元测试
本文介绍:1.vue-cli3下jest环境的搭建2.vue组件基本的测试方法 环境配置 vue-cli3 的插件使安装流程变得格外简单,通过 vue ui 启动可视化管理系统,在插件栏,点击 ‘添加 ...
- 学习笔记——在vue中如何配置Jest(一)
最近在搞Jest单元测试,如何在vue中安装和使用jest我就不说了,前一篇文章简单的说了一下在使用jest时遇到的一些问题,但是我觉得并没有真正的解决的很好.后面会在学习过程中更新前面的那篇文章,加 ...
- vue 单元测试
单元测试 配置和工具 任何兼容基于模块的构建系统都可以正常使用,但如果你需要一个具体的建议,可以使用Karma进行自动化测试.它有很多社区版的插件,包括对webpack和browserify的支持. ...
- Vue单元测试vue2-jest-coverage的package.json 配置
依赖的版本很重要,不要出错了 devDependencies:{ "babel-core": "^6.26.3", "babel-jest" ...
- 前端js单元测试 使用mocha、chai、sinon,karma
karma(因果报应) 提供在浏览器上测试 可以同时跑在多个浏览器下 mocha测试框架 其他测试框架还有Jasmine chai断言库 expect = chai.expect sinon ...
- #单元测试#以karma+mocha+chai 为测试框架的Vue webpack项目(二)
学习对vue组件进行单元测试,先参照官网编写组件和测试脚本. 1.简单的组件 组件无依赖,无props 对于无需导入任何依赖,也没有props的,直接编写测试案例即可. /src/testSrc/si ...
随机推荐
- python脚本使用源码安装不同版本的python
# coding=utf-8 import os import sys # 判断是否是root用户 if os.getuid() == 0: pass else: print('当前用户不是root用 ...
- py文件单独调试django ORM的配置
1.新建一个py文件 2.代码环境搭建 import os if __name__ != '__main__': exit() # 加载django项目的配置信息 os.environ.setdefa ...
- Linux记录-批量安装zabbix(转载)
同一文件夹下建立pwd.txt,格式如下: ip username password ip username password #!/bin/bash cat pwd.txt | while read ...
- linux记录-安装elk记录(参考博文)
什么是ELK? 通俗来讲,ELK是由Elasticsearch.Logstash.Kibana .filebeat三个开源软件的组成的一个组合体,这三个软件当中,每个软件用于完成不同的功能,ELK 又 ...
- PAT 甲级 1072 Gas Station (30 分)(dijstra)
1072 Gas Station (30 分) A gas station has to be built at such a location that the minimum distance ...
- 【Leetcode_easy】874. Walking Robot Simulation
problem 874. Walking Robot Simulation solution1: 思路:1)如何表示移动的方向以及移动的位置坐标; 2)障碍物坐标如何检查;3)求解的是最大距离; cl ...
- Django:bootstrap table自定义查询实现
参考:https://jalena.bcsytv.com/archives/tag/bootstrap 背景: bootstrap table在客户端分页方式下,自带有简易的搜索功能,但是功能太单一, ...
- Ubuntu与Window双系统安装的注意事项
UBUNTU与WINDOW双系统安装的注意事项 Ubuntu与Window双系统安装的注意事项 由 匿名 (未验证) 提交于 2019-05-18 10:07:41 登录 发表评论 29 次浏览 ...
- python 爬虫实例(一)
一个简单的爬虫工程 环境: OS:Window10 python:3.7 安装一些库文件 pip install requests pip install beautifulsoup4 pip ins ...
- 《ucore lab8》实验报告
资源 ucore在线实验指导书 我的ucore实验代码 练习1: 完成读文件操作的实现(需要编码) 题目 首先了解打开文件的处理流程,然后参考本实验后续的文件读写操作的过程分析,编写在sfs_inod ...