使用QUnit进行自动化单元测试
前言
前阵子由于项目需求接触了java的单元测试JUnit,就顺带着学习了前端的单元测试:Qunit。
既然跟测试有关,不妨介绍一下测试中的黑盒测试、白盒测试以及单元测试。
1、黑盒测试:所谓的黑盒,就是把程序看做一个不能打开的黑盒子,不需要了解程序内部结构和特性,从用户的角度出发,主要针对软件界面以及软件功能进行测试,通过多次的测试,无穷多数的测试情况,检车出程序中的错误。黑盒测试也叫功能测试,它是通过测试来检测每个功能是否都能正常使用。
2、白盒测试:相对于黑盒的看不见,白表示看得见即透明的意思。白盒表示你清楚盒子内部的东西以及里面是如何运作的。这种方法是把测试对象看做一个打开的盒子,允许测试人员利用程序内部的逻辑结构及有关信息,设计或选择测试用例,对程序所有逻辑路径进行测试。通过在不同点检查程序状态,确定实际状态是否与预期的状态一样。因此白盒测试也称为结构测试或逻辑驱动测试。
举个简单的例子:
比如你有一部使用已久的搅拌机(就好比使用多年的代码程序),你想要清洗你的搅拌机(维护,测试有问题模块),你可以从上到下,从里到外,在不拆开搅拌机的前提下,用水冲洗你的搅拌机(这就好比黑盒测试)。你也可以用螺丝刀,把你的搅拌机拆开,一个部位一个部位地清洗(这就好比白盒测试)。
3、那么,什么是单元测试呢?
单元就是相对独立的功能模块。在计算机编程中,单元测试(又称为模块测试)是针对程序模块(软件设计的最小单位)来进行正确性检验的测试工作。程序单元是应用的最小可测试部件。在过程化编程中,一个单元就是单个程序、函数、过程等;对于面向对象编程,最小单元就是方法,包括基类(超类)、抽象类、或者派生类(子类)中的方法。单元测试也算是白盒测试中的一种。
4、好了,讲了这么多题外话,是该回归正题了,讲讲QUnit。
QUnit是jQuery团队开发的JavaScript单元测试工具,功能强大且使用简单。目前所有的JQuery代码都使用QUnit进行测试,原生的JavaScript也可以使用QUnit。最初,John Resig将QUnit设计为jQuery的一部分。2008年,QUnit才有了自己的名字、主页和API文档,也开始允许其他人用它来做单元测试。但当时QUnit还是基于jQuery的。直到2009年,QUnit才可以完全的独立运行。
Qunit的官网:http://qunitjs.com/(如果打不开,尝试翻.墙)
正文
万事从头起,首先使用qunit写一个非常简单的例子,感受一下qunit的使用方法:
只需要加载qunit.css和qunit.js就可以了,这里我已经下载好了,喜欢使用CDN的话也可以使用官方提供的CDN:
https://code.jquery.com/qunit/qunit-2.0.1.js
https://code.jquery.com/qunit/qunit-2.0.1.css
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width">
<link rel="stylesheet" href="css/qunit-2.0.1.css">
<script src="js/qunit-2.0.1.js"></script>
<title>qunit</title>
</head>
<body>
<div id="qunit"></div>
<script>
QUnit.test( "hello test", function( assert ) {
assert.ok( true, "Passed!" );
assert.ok( 1 == "2", "错了兄弟" );
assert.ok( 2 == "2", "Passed!" );
assert.ok( 2 == "3", "啊哦" );
});
</script>
</body>
</html>
运行上述代码后,可以看到一下的页面

这是个很简单的例子。定义了文档类型,包含了QUnit需要的CSS以及JS,定义了一个Script元素,script中的代码为Qunit的测试代码,id为qunit的div是qunit输出的页面,上面有测试结果。test函数定义了一个“hello test”的测试,一旦页面载入完毕,QUnit就会运行test()。传给test()的第二个参数为函数,这才是测试的本身,这里用到的是OK方法,可以看出,ok函数接受了2个参数,第一个参数表示判断,接受一个布尔值或者有判断结果的值(反正是通过或者不通过),第二个参数是输出的信息。如上图。
(本来想要写更详细点,有点事走开了,下次有时间补充,就当是抛砖引玉,有兴趣的读者可以继续研究js的单元测试)
使用QUnit进行自动化单元测试的更多相关文章
- TestNg JAVA 自动化单元测试框架Demo
TestNg TestNg 是java的一个自动化单元测试框架 参考:http://testng.org/doc/index.html 环境准备 既然是java 的自动化单元测试框架,就必须要有jav ...
- Keil中搭建自动化单元测试框架Unity
前言: 虽然一些C++的自动化单元测试框架也能用来C语言单元测试,但那样我们编写C语言程序时需要符合C++的标准,这样有一些C的特性是无法使用的,限制C的特性使用不太好,于是找了一个全部用C实现的自动 ...
- 测者的测试技术手册:AI的自动化单元测试
测者的测试技术手册:AI的自动化单元测试 谈新技术:AI的自动化单元测试
- 搭建Karma+Jasmine的自动化单元测试
最近在打算将以前的代码进行重构,过程中发现自己不写自动化测试代码,而是手动的写,这样并不好,所以就学了Karma+Jasmine的自动化单元测试,以后写代码尽量要写自动化单元测试,也要测一下istan ...
- 学习Karma+Jasmine+istanbul+webpack自动化单元测试
学习Karma+Jasmine+istanbul+webpack自动化单元测试 1-1. 什么是karma? Karma 是一个基于Node.js的Javascript测试执行过程管理工具.该工具可 ...
- 在Python中进行自动化单元测试的教程
From: https://www.jb51.net/article/64119.htm 一.软件测试 大型软件系统的开发是一个很复杂的过程,其中因为人的因素而所产生的错误非常多,因此软件在开发过程必 ...
- Karma和Jasmine自动化单元测试
从零开始nodejs系列文章,将介绍如何利Javascript做为服务端脚本,通过Nodejs框架web开发.Nodejs框架是基于V8的引擎,是目前速度最快的Javascript引擎.chrome浏 ...
- Karma和Jasmine自动化单元测试——本质上还是在要开一个浏览器来做测试
1. Karma的介绍 Karma是Testacular的新名字,在2012年google开源了Testacular,2013年Testacular改名为Karma.Karma是一个让人感到非常神秘的 ...
- 利用Angularjs测试引擎Karma进行自动化单元测试
Karma是Google用于angularjs框架单元测试的js引擎(javascript test runner ), angular1 和angular2项目源码的单元测试都是基于karma和ja ...
随机推荐
- Backbone源码分析(三)
Backbone源码分析(一) Backbone源码分析(二) Backbone中主要的业务逻辑位于Model和Collection,上一篇介绍了Backbone中的Model,这篇文章中将主要探讨C ...
- Webstorm 10 for mac osx 注册机,序列号,kegen
小菜最近get到mac体验机会,早就耳闻mac非常适合做开发,于是迫不及待的安装各种开发工具,不知不觉,轮到前端开发神器webstorm了,看了一下官网的价格,心拔凉拔凉的. 果断搜索注册机,搜到的结 ...
- jsp的 javascript中 嵌套 html 注释
看到公司的代码,我也是蛋疼了,各种乱. 还发现有很多的jsp的 javascript中 嵌套 html 注释, 这个可行? 我之前可是没用过. 后面查找各种资料发现,这个也是可行的,主要是为了兼容不支 ...
- Fig 应用编排
Fig是Docker的应用编排工具,主要用来跟 Docker 一起来构建基于 Docker 的复杂应用,Fig 通过一个配置文件来管理多个Docker容器,非常适合组合使用多个容器进行开发的场景. 说 ...
- iOS-常用的第三方框架的介绍
写iOS 程序的时候往往需要很多第三方框架的支持,可以大大减少工作量,讲重点放在软件本身的逻辑实现上. GitHub 里面有大量优秀的第三方框架,而且 License 对商业很友好.一下摘录一下几乎每 ...
- C#开源日志Nlog入门
c#语言使用的日志比较多,比如:Log4.NLog等,今天我就简单随笔记录哈NLog的使用. 1.NLog的安装: 直接在VS编译器中打开程序包管理器,输入Install-Package NLogin ...
- Azure Service Febric 笔记:Web API应用
1.什么是Service Febric 贴一段微软官方的介绍 Service Fabric 是一种分布式系统平台,可让你轻松打包.部署和管理可缩放.可靠的微服务.Service Fabric 还解决了 ...
- c#字段
1.C#中是不允许用new操作符创建String对象的,编译器会报错. 2.实例字段:使用new对class创建对象直接赋初始值,不适用于struct slass Rect { public int ...
- python中configparser模块
python中的configparse模块的使用 主要用来解析一些常用的配置,比如数据配置等. 例如:有一个dbconfig.ini的文件 [section_db1] db = test_db1 ho ...
- 每天多一点(2016.12.04)》Javascript隐式转换
乱想 javascript为什么需要隐式转换?如果没有会出现什么情况? 找了一圈没有看到关于这个的讨论,只好自己研究了,可能不一定正确,自行辨知. 郁闷就是郁闷在好好的,为什么要搞个隐式转换,一般来讲 ...