博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
karma+webpack搭建vue单元测试环境
阅读量:6248 次
发布时间:2019-06-22

本文共 2788 字,大约阅读时间需要 9 分钟。

  hot3.png

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

准备

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

代码地址:

目录结构如下

 

08231054_yOdq.png

目录结构

app.vue和child.vue代码

08231054_LDb5.png

app.vue

08231055_GMar.png

child.vue

运行效果如下:

 

08231055_occD.png

运行效果

测试环境搭建

安装karma

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

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

在项目根目录执行:karma init

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

08231055_rvJV.png

选择框架

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

08231055_BpSB.png

use require.js

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

08231055_NXNM.png

选择浏览器

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

08231055_0mXo.png

脚本文件

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

08231055_lfQP.png

提示没匹配到文件

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

08231055_pXfI.png

排除文件

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

08231056_p6Br.png

是否开启watch

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

 

08231056_2VJO.png

目录

安装依赖

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

08231056_S9DS.png

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

08231056_nwWu.png

karma.conf.js

在配置项中加入webpack配置

08231056_HQMX.png

karma.conf.js

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

08231056_0au1.png

karma.conf.js

编写第一个测试

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

08231057_vSXC.png

目录

app.spec.js内容如下

08231057_gAOx.png

test/unit/app.spec.js

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

08231057_78RI.png

karma start

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

08231057_dH3z.png

karma run

查看测试覆盖率

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

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

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

08231057_7jBp.png

karma.conf.js

在报告中使用coverage

08231057_fODJ.png

karma.conf.js

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

08231057_AE11.png

karma.conf.js

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

08231058_Ckjv.png

目录

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

08231058_Wivm.png

index.html

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

08231058_xaMv.png

unit/index.html

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

08231058_KdQ7.png

unit/app.spec.js

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

Bingo! sourcemap。

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

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

修改vue的js loader

08231058_KKWB.png

karma.conf.js

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

08231058_cNip.png

index.html

08231058_aWsI.png

src/index.html

 

08231059_LtAI.png

src/app.vue.html

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

08231059_bz69.png

karma.conf.js

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

08231059_BPMW.png

index.html

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

08231059_ArG6.png

karma.conf.js

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

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

关于如何写测试脚本,会在后续的文章中介绍,敬请期待。

相关链接

转载于:https://my.oschina.net/dawd/blog/822246

你可能感兴趣的文章
oracle 查看用户所在的表空间
查看>>
CentOS配置sshd
查看>>
利用libevent的timer实现定时器interval
查看>>
接口的使用
查看>>
LeetCode 347. Top K Frequent Elements
查看>>
二叉树遍历
查看>>
JAVA 并发
查看>>
Markdown引用微博图床被防盗链不加载响应403完美解决
查看>>
0302思考并回答一些问题
查看>>
Sphinx的介绍和原理探索
查看>>
php中mysql数据库操作类 -李盛鹏 -博客园
查看>>
coreseek增量索引
查看>>
ubuntu更新源(2018最新)
查看>>
python使用小结——iloc与loc的使用
查看>>
linux crontab定时任务运行shell脚本(shell执行sql文件)
查看>>
Python用Pillow(PIL)进行简单的图像操作
查看>>
[51Nod 1584] 加权约数和
查看>>
微信小程序的同步操作
查看>>
Lua中的操作系统库
查看>>
环境变量path的值大于1024的解决办法
查看>>