js单元测试
最近研究了js的单元测试,分享一下心得。
说起单元测试以前还真是不太了解,这次索性了解一番,测试有很多包含单元测试,性能测试,安全测试和功能测试等几方面,本次只介绍一下单元测试。
前端进行单元测试主要是为了提高自己的代码质量,多组测试用例,验证自己的代码是否都能通过,这是在开发中很有必要的。需要倡导的是‘开发者应该吃自己的狗粮’,*——*
单元测试主要包含断言,测试框架,测试用例等几个方面,
断言:
断言是对代码结果的一种判断,如果这种判断和结果是一样的,那么这个断言就是真的,测试就通过了,如果为假的,程序就会终止执行,并出现错误信息。
断言库有很多expect
,should,chai,其次就是node的assert断言,本次主要说assert断言
var assert=require('assert');
assert.equal(Math.max(1,100),100);
一但assert.equal()不满足期望,将会抛出AssertionError异常,整个程序将停止执行。
断言规范中,我们定义一下几种检测方法:
ok()判断结果是否为真,
equal()判断实际值与期望值是否相等,
notEqual():判断实际值与期望值是否不相等
deepEqual():判断实际值与期望值是否深度相等(对象和数组的元素是否相等)
notDeepEqual:判断实际值与期望值是否不深度相等
strictEqual:判断实际值与期望值是否严格相等(===)
notStrictEqual:判断实际值与期望值是否不严格相等(相当于!==)
throws:判断代码块是否抛出异常
市面上的大多断言库都是基于assert模块进行封装和扩展的,这包括著名的should.js断言库
安装:
npm install should --save-dev
测试框架
前面提到断言一旦检查失败,将会抛出异常停止整个应用,这对于大规模的断言检查时并不友好,更通用的就是抛出异常并且继续执行,最后生成测试报告,这任务承担着就是测试框架,优秀的单元测试框架是mocha(发音:摩卡),mocha本身不含有断言库,所以必须先引入断言库,像上面提到的断言库,不限于使用哪种。
安装:
npm install mocha -g(全局安装)
测试风格:
TDD(测试驱动开发)和BDD(行为驱动开发)这两种,他们的不同是什么?
TDD关注多有功能是否被正确的实现,每个功能都具备对于的测试用例;BDD关注整体行为是否符合规格预期,适合自顶向下的设计方式
TDD表达方式偏向于功能说明书的风格;BDD的表达方式更接近于自己的语言习惯
我个人比较习惯BDD风格方式:
主要采用describe和it进行组织,一个测试脚本与所要测试的源码脚本同名,但是后缀名为.test.js
(表示测试)或者.spec.js
(表示规格),比如,add.js
的测试脚本名字就是add.test.js
。
// add.test.js 测试脚本名字
var add = require('../lib/add'); describe('add', function () {
it('6 + 7 = 13', function () {
add(6,7).should.equal(13)
}) it('9 + 10 = 19', function () {
add(9 , 10).should.equal(19)
})
})
一个测试脚本由一个或多个describe测试套件组成,一个测试套件由一个或多个it测试用例组成,
describe
块称为"测试套件"(test suite),表示一组相关的测试。它是一个函数,第一个参数是测试套件的名称("add"),第二个参数是一个实际执行的函数。
it
块称为"测试用例"(test case),表示一个单独的测试,是测试的最小单位。是一个函数,第一个参数是测试用例的名称("6 + 7 = 13"),第二个参数是一个实际执行的函数。
mocha基本用法
有了测试脚本就可以使用mocha运行它
mocha
命令后面紧跟测试脚本的路径和文件名,可以指定多个测试脚本。
mocha file1 file2 file3
注意:mocha默认运行test子目录第一层的测试用例,不会执行更下层的用例。
例如:test文件下有个dir目录,里面有个测试脚本add.test.js,这是执行不到的,为了改变这种行为,就必须加上--recursive
参数,这时test
子目录下面所有的测试用例都会执行。
对于es6,需要经过编译后才可以进行测试,
转码需要安装
npm install babel-core babel-preset-es2015 --save-dev
然后 在根目录下面创建babelrc,配置:
{
"presets": [ "es2015" ]
}
注意,Babel默认不会对Iterator、Generator、Promise、Map、Set等全局对象,以及一些全局对象的方法(比如Object.assign
)转码。如果你想要对这些对象转码,就要安装babel-polyfill
。
npm install babel-polyfill --save-dev
使用时候需要导入
import 'babel-polyfill'
测试工具
karma则属于测试工具,能够模拟各种环境来运行你的测试代码,比如Chrome,Firefox,mobile等等。
(提一下:travis ci,是一个远程免费的持续集成(CI)服务,你可以通过配置绑定你github上的项目,并且配置运行环境,实现只要github上有代码更新,travis就会自动运行构建和测试,并反馈运行结果。)
使用karma
步骤
全局安装 karma
npm install -g karma-cli
安装所有依赖
......
初始化测试
karma init
1. Which testing framework do you want to use ? (mocha)
2. Do you want to use Require.js ? (no)
3. Do you want to capture any browsers automatically ? (Chrome)
4. What is the location of your source and test files ? (https://cdn.bootcss.com/jquery/2.2.4/jquery.js, node_modules/should/should.js, test/**.js)
5. Should any of the files included by the previous patterns be excluded ? ()
6. Do you want Karma to watch all the files and run the tests on change ? (yes)
启动测试
karma start
karma.conf.js:
module.exports = function(config) {
config.set({
basePath: '',
frameworks: ['mocha'], //使用的框架
files: [ //依赖模块
'https://cdn.bootcss.com/jquery/2.2.4/jquery.js',
'node_modules/should/should.js',
'test/**/*.js',
'src/**/*.js'
],
exclude: [//排除文件列表
],
preprocessors: {
},
reporters: ['progress'], port: 9876,//服务端口号 colors: true,//启用或禁用输出报告或者日志中的颜色 logLevel: config.LOG_INFO, autoWatch: true, //启用或禁用自动检测文件变化进行测试 browsers: ['Chrome'], //测试启动的浏览器
singleRun: false,//开启或禁用持续集成模式 设置为true, Karma将打开浏览器,执行测试并最后退出
concurrency: Infinity//并发级别(启动的浏览器数)
})
}
详细了解可以去karma :http://karma-runner.github.io/latest/index.html
js单元测试的更多相关文章
- 啥时候js单元测试变的重要起来?
作为一个菜鸟,开这个专栏其实不合适,但又突然发现这个比以往任何时候都重要,所以还是写写我的感受 首先,在传统的pc上也有大量的web站点和各种项目都有复杂的js,但是基本不做单元测试,为啥呢?因为传统 ...
- JS 单元测试
JS单元测试,我工作时主要以mocha + chai 下面时具体的文档: mocha: https://mochajs.org/#asynchronous-code Chai: http://chai ...
- 玩转Node.js单元测试
代码部署之前,进行一定的单元测试是十分必要的,这样能够有效并且持续保证代码质量.而实践表明,高质量的单元测试还可以帮助我们完善自己的代码.这篇博客将通过一些简单的测试案例,介绍几款Node.js测试模 ...
- 前端测试框架对比(js单元测试框架对比)
前端测试框架对比(js单元测试框架对比) 本文主要目的在于横评业界主流的几款前端框架,顺带说下相关的一些内容. 测试分类 通常应用会有 单元测试(Unit tests) 和 功能测试(Function ...
- 【JS单元测试】Qunit 和 jsCoverage使用方法
近日在网上浏览过很多有关js单元测试相关的文档,工具,但是,针对Qunit 和 jsCoverage使用方法,缺少详细说明,对于初入前端的人来说,很难明白其中的意思,特此整理这篇文章,希望 ...
- js单元测试框架
js单元测试框架 前端测试框架对比(js单元测试框架对比) 本文主要目的在于横评业界主流的几款前端框架,顺带说下相关的一些内容. 测试分类 通常应用会有 单元测试(Unit tests) 和 功能测试 ...
- Qunit 和 jsCoverage使用方法(js单元测试)
Qunit 和 jsCoverage使用方法(js单元测试) 近日在网上浏览过很多有关js单元测试相关的文档,工具,但是,针对Qunit 和 jsCoverage使用方法,缺少详细说明,对于初入前端的 ...
- JS单元测试框架:QUnit
QUnit:jQuery的单元测试框架,但不仅限于jQuery(从这个工具不需要引用jquery.js可以看出) index.html <!-- 官网 http://qunitjs.com/ - ...
- Vue.js—单元测试
Vue.js--测试 这里采用的是Vue官方工具(Vue-CLI)搭建出来的项目,在这个搭建工具中推荐的两种测试分别是 端到端的测试 E2E 单元测试 Unit Test 端到端的测试(E2E) E2 ...
随机推荐
- HashMap初认识
什么是HashSet? 它实现了Set接口,HashSet是Set集合的子类 有哈希表支持的,元素不可重复的哈希码值(实际上是一个HashMap的实例). 它不保证set的迭代顺序(遍历元素的顺序), ...
- bzoj3527: [Zjoi2014]力 卷积+FFT
先写个简要题解:本来去桂林前就想速成一下FFT的,结果一直没有速成成功,然后这几天断断续续看了下,感觉可以写一个简单一点的题了,于是就拿这个题来写,之前式子看着别人的题解都不太推的对,然后早上6点多推 ...
- 寒冬之下,移动开发没人要了? 浅谈 iOS 开发者该 何去何从?
前言: 作者 | 梅梅 文章来源 CSDN 对于移动互联网而言,2018 年像是球场上的一声裁判哨.哨声响起,高潮迭起的上半场结束.本该再创辉煌的下半场,还没开赛却被告之:规则改变.场地收缩.教 ...
- DirectX11 With Windows SDK--15 几何着色器初探
前言 从这一部分开始,感觉就像是踏入了无人深空一样,在之前初学DX11的时候,这部分内容都是基本上跳过的,现在打算重新认真地把它给拾回来. DirectX11 With Windows SDK完整目录 ...
- 6核 CPU导致SQL2005安装时出“无法启动服务”错
周一新买的IBM3650M3的服务器上安装SQL server2005 安装到一半时,报"提示:SQL Server 服务无法启动."错. 换了几个操作系统版本和换了几个版本的sq ...
- 第十三节:Lambda、linq、SQL的相爱相杀(2)
一. Linq开篇 1.Where用法 linq中where的用法与SQL中where的用法基本一致. #region 01-where用法 { //1. where用法 //1.1 查询账号为adm ...
- Node.js实战项目学习系列(2) 开发环境和调试工具
前言 上一节让我们对Node.js有一个初步的了解,那么现在可以开始正式学习下Node.js的开发了,但是任何一门语言要设计到开发,就必须先学习开发环境以及调试.本文将主要讲解这些内容. 本文涉及到的 ...
- 关于并查集的路径压缩(Path Compress)优化
之前在CSDN看到一篇很受欢迎的讲解并查集的博文,其中自然用到了路径压缩: int pre[1000]; int find(int x){ int root = x; while(pre[root]! ...
- 迅为iTOP-4418开发板-Android5.1系统编译补充
基于iTOP-4418开发板-Android5.1系统编译补充 5.6 编译-20181225 日期之后的源码 本文档补充介绍 4418 编译网盘目录 “J:\局域网共享_阮\iTOP4418 开发板 ...
- liblensfun 在 mingw 上编译时遇到的奇怪问题
ffmpeg 2018.07.15 增加 lensfun 滤镜; 这个滤镜需要 liblensfun 库; Website: http://lensfun.sourceforge.net/ Sourc ...