karma+webpack搭建vue单元测试环境的方法示例


Posted in Javascript onMay 24, 2018

最近做了一次关于vue组件自动化测试的分享,现在将vue组件单元测试环境搭建过程整理一下。这次搭建的测试环境和开发环境隔离,所以理论上适用所有使用vue的开发环境。

准备

这篇文章的重点在于搭建测试环境,所以我随便写了个webpack的vue开发环境。

代码地址:https://github.com/MarxJiao/vue-karma-test

目录结构如下

karma+webpack搭建vue单元测试环境的方法示例

目录结构

app.vue和child.vue代码

karma+webpack搭建vue单元测试环境的方法示例

app.vue

karma+webpack搭建vue单元测试环境的方法示例

child.vue

运行效果如下:

 karma+webpack搭建vue单元测试环境的方法示例

运行效果

测试环境搭建

注意:这里使用的是webpack 1.x的版本,后面有介绍webpack 2+版本的配置,思路大同小异。

安装karma

因为karma是要在命令中运行的,所以先安装karma-cli:npm install -g karma-cli

安装karma:npm install karma --save-dev

在项目根目录执行:karma init

这时会提示使用的测试框架,我们可以使用键盘的上下左右来选择框架,有jasmine、mocha、qunit、nodeunit、nunit可供选择,如果想用其他框架也可以自己填写。这里我们使用jasmine作为测试框架,jasmine自带断言库,就不用引入其它的库了。

karma+webpack搭建vue单元测试环境的方法示例

选择框架

之后提示是否使用require.js,这里我们不使用。

karma+webpack搭建vue单元测试环境的方法示例

use require.js

选择浏览器,可以多选。单元测试只需要能运行js的环境就好了,不需要界面,所以我们选择PhantomJS。注意PhantomJS需要提前安装在电脑上,phantomjs安装包。嫌麻烦的话选择chrome最方便了。

karma+webpack搭建vue单元测试环境的方法示例

选择浏览器

填写测试脚本存放位置,支持通用匹配。我们放在test/unit目录下,并以.spec.js结尾。

karma+webpack搭建vue单元测试环境的方法示例

脚本文件

这时会提示没有匹配的文件,因为我们还没开始写测试用例,所以先忽略。

karma+webpack搭建vue单元测试环境的方法示例

提示没匹配到文件

是否有需要排除的符合前面格式的问文件?直接跳过。

karma+webpack搭建vue单元测试环境的方法示例

排除文件

是否让karma监控所有文件,并在文件修改时自动执行测试。因为是搭环境阶段,我们先选no。

karma+webpack搭建vue单元测试环境的方法示例

是否开启watch

之后按回车,我们就能看到在项目根目录已经生成了karma的配置文件karma.conf.js。

 karma+webpack搭建vue单元测试环境的方法示例

目录

安装依赖

执行上面的操作可以看到karma为我们安装了如下依赖,karma-jasmine是karma的jasmine插件,karma-phantomjs-launcher是打开phantomjs的插件

karma+webpack搭建vue单元测试环境的方法示例

karma自己安装的依赖

测试框架选择jasmine,安装jasmine-core

使用webpack打包vue组件,需要安装webpack、karma-webpack、vue-loader、vue-template-compiler、css-loader

使用bable处理ES6语法,安装babel-core、babel-loader、babel-preset-es2015

执行:npm install --save-dev jasmine-core webpack karma-webpack vue-loader vue-template-compiler css-loader babel-core babel-loader babel-preset-es2015

修改配置文件

先在karma.conf.js顶部引用webpack

karma+webpack搭建vue单元测试环境的方法示例

karma.conf.js

在配置项中加入webpack配置

karma+webpack搭建vue单元测试环境的方法示例

karma.conf.js

在预处理选项中添加webpack处理的文件。这里我们用webpack处理测试用例。

karma+webpack搭建vue单元测试环境的方法示例

karma.conf.js

编写第一个测试

编写一个测试用例来运行,我们先测试下app.vue文件加载后title值是否符合预期。新建test文件夹,test文件夹下建立unit文件夹,unit文件夹下建立app.spec.js文件。目录结构如下:

karma+webpack搭建vue单元测试环境的方法示例

目录

app.spec.js内容如下

karma+webpack搭建vue单元测试环境的方法示例

test/unit/app.spec.js

在当前目录打开命令行,输入karma start,这时karma会启动一个服务来监听测试。

karma+webpack搭建vue单元测试环境的方法示例

karma start

不要关闭当前命令窗口,再打开一个命令窗口,输入karma run,这时我们会看到测试通过的提示。

karma+webpack搭建vue单元测试环境的方法示例

karma run

查看测试覆盖率

单元测试属于白盒测试,测试覆盖率也是测试指标之一。karma提供了karma-coverage来查看测试覆盖率。

安装karma-coverage:npm install karma-coverage --save-dev

配置覆盖率,在预处理的文件上加coverage

karma+webpack搭建vue单元测试环境的方法示例

karma.conf.js

在报告中使用coverage

karma+webpack搭建vue单元测试环境的方法示例

karma.conf.js

配置覆盖率报告的查看方式

karma+webpack搭建vue单元测试环境的方法示例

karma.conf.js

再次执行karma start和karma run,我们能看到生成了覆盖率查看文件夹

karma+webpack搭建vue单元测试环境的方法示例

目录

在浏览器中打开上图中的index.html我们能看到覆盖率已经生成。

karma+webpack搭建vue单元测试环境的方法示例

index.html

点击「unit/」我们看到app.spec.js代码有3036行,测试覆盖率是打包之后文件的覆盖率,

karma+webpack搭建vue单元测试环境的方法示例

unit/index.html

点开文件,果然是打包之后的代码。这个覆盖率显然不是我们想要测试的源文件的覆盖率。

karma+webpack搭建vue单元测试环境的方法示例

unit/app.spec.js

怎么办呢?想想开发时浏览器打开的也是编译后的文件,我们怎么定位源码呢?

Bingo! sourcemap。

当然这里只用sourcemap是不够的,测试覆盖率神器isparta闪亮登场。

安装:npm install --save-dev isparta isparta-loader

修改vue的js loader

karma+webpack搭建vue单元测试环境的方法示例

karma.conf.js

再次执行karma start和karma run,我们能看到测试覆盖率文件已经能找到源文件了,并且覆盖率只有js代码,并不包括无关的template和style,简直太好用了有没有。

karma+webpack搭建vue单元测试环境的方法示例

index.html

karma+webpack搭建vue单元测试环境的方法示例

src/index.html

karma+webpack搭建vue单元测试环境的方法示例

src/app.vue.html

等等,怎么还有那个3000多行的文件,这个覆盖率没有用,能去掉吗?答案是肯定的。我们只需要把karma.conf.js中preprocessors的coverage去掉即可。

karma+webpack搭建vue单元测试环境的方法示例

karma.conf.js

再次执行karma start和karma run,我们能看到覆盖率的文件变成这样了。

karma+webpack搭建vue单元测试环境的方法示例

index.html

最后我们可以把karma的watch模式打开,之后只需要运行karma start就能监控文件变动并自动执行测试了。

karma+webpack搭建vue单元测试环境的方法示例

karma.conf.js

至此karma+webpack搭建的vue单元测试环境就已经ready了。

文章图片较多,略显拖沓,不妥之处欢迎吐槽,欢迎拍砖。

关于如何写测试脚本,请看这篇文章Vue单元测试case写法。

更新webpack2

以上内容基于webpack 1.x 版本,如果使用webpack 2以上版本的话,需要将isparta-loader换成istanbul-instrumenter-loader,并使用karma-coverage-istanbul-reporter 生成测试报告。配置方法:https://github.com/MarxJiao/vue-karma-test/blob/webpack2/karma.conf.js

相关链接

Karma官网

Vue Unit Testing

isparta loader

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
javascript的对话框详解与参数
Mar 08 Javascript
jQuery ul标签下拉菜单演示代码
Dec 11 Javascript
jquery中get,post和ajax方法的使用小结
Feb 04 Javascript
c#+jquery实现获取radio和checkbox的值
Sep 12 Javascript
JavaScript结合HTML DOM实现联动菜单
Apr 05 Javascript
AngularJS折叠菜单实现方法示例
May 18 Javascript
thinkjs 文件上传功能实例代码
Nov 08 Javascript
vue组件中使用props传递数据的实例详解
Apr 08 Javascript
JavaScript事件冒泡与事件捕获实例分析
Aug 01 Javascript
Vue条件循环判断+计算属性+绑定样式v-bind的实例
Sep 18 Javascript
使用Node.js在深度学习中做图片预处理的方法
Sep 18 Javascript
vue自定义插件封装,实现简易的elementUi的Message和MessageBox的示例
Nov 20 Vue.js
react实现点击选中的li高亮的示例代码
May 24 #Javascript
浅谈Webpack 是如何加载模块的
May 24 #Javascript
jquery.onoff实现简单的开关按钮功能(推荐)
May 24 #jQuery
详解javascript中的变量提升和函数提升
May 24 #Javascript
JavaScript轮播停留效果的实现思路
May 24 #Javascript
vue2单元测试环境搭建
May 24 #Javascript
Vue+mui实现图片的本地缓存示例代码
May 24 #Javascript
You might like
php自定义时间转换函数示例
2016/12/07 PHP
jQuery 选择器理解
2010/03/16 Javascript
JS实现self的resend
2010/07/22 Javascript
Jquery从头学起第四讲 jquery入门教程
2010/08/01 Javascript
有关js的变量作用域和this指针的讨论
2010/12/16 Javascript
Javascript的各种节点操作实例演示代码
2012/06/27 Javascript
jquery 淡入淡出效果的简单实现
2014/02/07 Javascript
jquery操作checked属性以及disabled属性的多种方法
2014/06/20 Javascript
jquery中post方法用法实例
2014/10/21 Javascript
原生Js实现简易烟花爆炸效果的方法
2015/03/20 Javascript
整理Javascript事件响应学习笔记
2015/12/02 Javascript
实用jquery操作表单元素的简单代码
2016/07/04 Javascript
nodejs基础应用
2017/02/03 NodeJs
gulp教程_从入门到项目中快速上手使用方法
2017/09/14 Javascript
html中通过JS获取JSON数据并加载的方法
2017/11/30 Javascript
打通前后端构建一个Vue+Express的开发环境
2018/07/17 Javascript
解决vue中修改export default中脚本报一大堆错的问题
2018/08/27 Javascript
策略模式实现 Vue 动态表单验证的方法
2019/09/16 Javascript
[48:48]VGJ.T vs Liquid 2018国际邀请赛小组赛BO2 第二场 8.19
2018/08/21 DOTA
django1.8使用表单上传文件的实现方法
2016/11/04 Python
Python 十六进制整数与ASCii编码字符串相互转换方法
2018/07/09 Python
python pexpect ssh 远程登录服务器的方法
2019/02/14 Python
Python操作redis和mongoDB的方法
2019/12/19 Python
Python实现括号匹配方法详解
2020/02/10 Python
Java Unsafe类实现原理及测试代码
2020/09/15 Python
Python实现手势识别
2020/10/21 Python
CSS3实现时间轴效果
2016/07/11 HTML / CSS
详解基于canvas的视频遮罩插件
2018/01/04 HTML / CSS
Amaze UI 文件选择域的示例代码
2020/08/26 HTML / CSS
英国家庭、花园、汽车和移动解决方案:Easylife Group
2018/05/23 全球购物
制定岗位职责的原则
2013/11/08 职场文书
yy生日主持词
2014/03/20 职场文书
爱情寄语大全
2014/04/09 职场文书
继承公证书格式
2015/01/26 职场文书
python opencv人脸识别考勤系统的完整源码
2021/04/26 Python
一文弄懂MySQL中redo log与binlog的区别
2022/02/15 MySQL