安装

npm i -g mocha

npm i chai -D //断言库

模块测试

比如有一个add函数

//add.js

function add(a, b){

return a + b

}

module.exports = add

新建一个测试文件add.test.js(一般测试文件命名都是以被测文件后加.test后缀)

describe:称为"测试套件"(test suite),表示一组相关的测试。它是一个函数,第一个参数是测试套件的名称("加法函数的测试"),第二个参数是一个实际执行的函数。

it:称为"测试用例"(test case),表示一个单独的测试,是测试的最小单位。

// add.test.js

var add = require("./add.js")

var expect = require("chai").expect;

describe("add功能测试", function(){

it("1 + 1 = 2", function(){

expect(add(1, 1)).to.be.equal(2) //断言库的用法

});

it("返回值为数字", function(){

expect(add(1, 1)).to.be.a("number")

});

})

chai中的expect模块的语法很接近自然语言的风格,常见的有:

// 相等或不相等

expect(4 + 5).to.be.equal(9);

expect(4 + 5).to.be.not.equal(10);

expect(foo).to.be.deep.equal({ bar: 'baz' });

// 布尔值为true

expect('everthing').to.be.ok;

expect(false).to.not.be.ok;

// typeof

expect('test').to.be.a('string');

expect({ foo: 'bar' }).to.be.an('object');

expect(foo).to.be.an.instanceof(Foo);

// include

expect([1,2,3]).to.include(2);

expect('foobar').to.contain('foo');

expect({ foo: 'bar', hello: 'universe' }).to.include.keys('foo');

// empty

expect([]).to.be.empty;

expect('').to.be.empty;

expect({}).to.be.empty;

// match

expect('foobar').to.match(/^foo/);

以上方法可以很轻松的测试封装的方法和模块

基于浏览器的测试,如ajax

在这里使用我自己的ajax库 baby-ajax

mocha-phantomjs:是一个 通过 PhantomJS 执行 mocha 浏览器环境测试的工具库。它使用 PhantomJS 的浏览器环境,通过事件监听的方式检测 mocha 测试的执行过程。

mocha-phantomjs-core:是 mocha-phantomjs的核心依赖库。作者将它单独提取出来,是因为它也可以支持 SlimerJS。

SlimerJS :基于的 Gecko 内核(Firefox)的与 PhantomJS 的 API 几乎相同的工具,而且SlimerJS在执行过程中默认会启动有界面的浏览器窗体,可以看到整个执行过程

npm i baby-ajax mocha-phantomjs-core mocha-phantomjs -D

在项目目录下创建测试目录

mocha init test

mocha会自己为我们创建测试模板,包含html,css,js

手动引用mocha.js,chai.js,和自己的测试js

//ajax.test.js

var Ajax = require('../example/static/ajax.js');

var expect = require('chai').expect;

expect(Ajax).to.be.an('object');

describe("get测试", function(done){

Ajax.get("./data.json")

.then(function(res){

expect(res).to.have.include.keys("data","status") //返回值必须有两个key,一个是data,一个是status

done()

}, function(){

expect(res).to.have.include.keys("data","status")

done()

})

})

这样就可以在node中模拟浏览器环境,从而可以获取在浏览器中的对象,如window等

总结

使用mocha配合chai以及mocha-phantomjs可以很方便的对函数的执行进行一步一步的监控,数值的类型做限定。但是如果一旦设计到业务逻辑的测试和UI的测试,可能就有点力不从心了,业务功能测试需要数据源的支撑,一味的使用假数据很难覆盖异常情况;而UI的测试虽然可以借助jq的trigger来模拟用户行为,但是这显然是个巨大的任务量,首先要在测试目录下的html写入需要测试的dom元素,再写测试逻辑。可能一个小时就完成的UI需要一天或者更长的时间来写测试逻辑。

前端UI的自动化测试还需慢慢探索,任重而道远。

前端技术交流群:709397872(欢迎加入)

mocha检测c语言,前端测试框架mocha使用小结相关推荐

  1. javascript测试框架mocha

    node测试框架mocha 简单.灵活.有趣,mocha是一个功能丰富的javascript测试框架,运行在node和浏览器中,使异步测试变得更加简单有趣.http://mochajs.org/ 安装 ...

  2. 前端测试框架—jest基本使用

    前端测试框架-jest基本使用 前言 jest 常见匹配器 基本类型 boolean Number String Array,Set 异常 取反 命令行工具使用 异步代码测试方法 钩子函数 分组(钩子 ...

  3. 前端测试框架Jest系列教程 -- Expect(验证)

    写在前面 在编写测试时,我们通常需要检查值是否满足某些条件,Jest中提供的expect允许你访问很多"Matchers",这些"匹配器"允许您验证不同的东西. ...

  4. 前端测试 karma mocha should 都是什么鬼?

    测试TDD和BDD的区别 TDD是测试驱动开发,通过用测试用例来规范约束开发者,编写出质量更高的代码 BDD是行为驱动开发,描述行为路径,就像描述故事,产品和前线业务人员可参与到开发流程中,减轻测试和 ...

  5. 前端测试框架(学习之路)前言

    为什么需要单元测试 正确性:测试可以验证代码的正确性,在上线前做到心里有底 自动化:当然手工也可以测试,通过console可以打印出内部信息,但是这是一次性的事情,下次测试还需要从头来过,效率不能得到 ...

  6. javascript测试框架 Mocha 实例教程

    http://www.ruanyifeng.com/blog/2015/12/a-mocha-tutorial-of-examples.html 转载于:https://www.cnblogs.com ...

  7. 前端测试框架Jest——语法篇

    使用匹配器 使用不同匹配器可以测试输入输出的值是否符合预期.下面介绍一些常见的匹配器. 普通匹配器 最简单的测试值的方法就是看是否精确匹配.首先是toBe() test('two plus two i ...

  8. 前端测试框架 jasmine 的使用

    最近的项目在使用AngulaJs,对JS代码的测试问题就摆在了面前.通过对比我们选择了 Karma  + jasmine ,使用 Jasmine做单元测试 ,Karma 自动化完成,当然了如果使用 K ...

  9. Protractor AngularJS测试框架教程

    Protractor是一个建立在WebDriverJS基础上的端到端(E2E)的AngularJS JavaScript Web应用程序测试框架.Protractor全自动化真实的模拟用户在真正的浏览 ...

最新文章

  1. Forest Program dfs+tanjar仙人掌
  2. 哪些业务流程和RPA更匹配?
  3. 怎样增加网站的百度权重
  4. assign深拷贝_经典前端面试题: Object.assign 是浅拷贝还是深拷贝?实现深拷贝的方法有哪些?...
  5. 【小练习02】CSS--网易产品
  6. python实现api接口的脚本_Zabbix批量添加主机,Python调用api接口方式【脚本定制】...
  7. ANSYS Workbench对称建模
  8. 旋转角度_LG推出新款显示器,可多角度旋转
  9. 无心剑英译林清玄《永恒》
  10. python 求组合数最快方法_快速计算投资组合波动率的方法
  11. ITA结合测试(总结之六:ITA上的时间,与本地时间)
  12. 算法 Tricks(六)— if 条件分支的简化
  13. html经历了几个版本,HTML 的上一个版本诞生于 1999 年. 自从那以后, Web 世界已经经历了巨变....
  14. mysql 导入sql文件的一点问题
  15. Gartner首发中国数据库市场指南,巨杉数据库代表数据库领域厂商入选
  16. 《深度学习》花书-读书笔记汇总贴(汇总19/19)
  17. 手机下拉框是怎么做出来
  18. idea remote debug
  19. nginx代理邮件服务
  20. JavaScript进阶-高级特性及ES6

热门文章

  1. 如何恢复回收站中清空的文件
  2. 中国女士职业套装行业深度调研及投资前景预测研究报告
  3. SourceInsight代码工程
  4. 荣耀9不负众望 科技美学再升级
  5. c# cntk 模型复制_CNTK-分类模型
  6. 成功女人的必修课-会说话的女人最出色之八
  7. 【独家正版】最新网盘源码-城通网盘仿蓝奏云修复版源码 完整测试可用无BUG 有问题全额退
  8. 教程 | 次世代游戏建模制作工作流程,零基础的你速度收藏了!
  9. Chrome安装SwitchyOmega(Mac)
  10. Ubuntu16.04+Gnome3 锁定屏幕快捷键无效解决办法