Javascript单元测试之QUnit
首先去Qunit官网下载。
Qunit有一个js脚本文件和一个css我们在页面中引入它。
<script src="qunit-2.0.1.js"></script>
<link rel="stylesheet" href="qunit-2.0.1.css">
页面中有两段必须的标签。
<div id="qunit"></div>
<div id="qunit-fixture"></div>
不写上这个,页面就是空白的了,这两个标签用来显示测试结果以及其他的东西。
接下来我们可以新建一个js文件来进行简单的测试了。
function add(a, b) {
return a + b;
}QUnit.test( "add test", function( assert ) {
assert.ok( add(2,3) === 6, "add IS 5" );
});
结果如下:
看到圈起来的没
QUnit.test( "add test", function( assert ) {
assert.ok( add(2,3) === 6, "add IS 5" );
});
QUnit.test表示你要测试一段代码,第一个也就是我圈起来的那段,只是用来显示的,第二个参数是一个函数,里面放一个assert参数,这个测试有很多的属性,在这里我们用到的是ok这个函数可以用来测试一个布尔值,第一个写你要测试的,如果相等表示通过,否则会报错,第二个也是用来显示的。
如果是通过的会是这样的。
如果你想比较两个值是否相等而不是比较布尔值,可以用equal函数。
QUnit.test( "test", function( assert ) {
assert.equal( 555 , 555 , "IS 555 ?" );
});
n1:实际值
n2:希望值
n3:看看而已
如果这样:
QUnit.test( "test", function( assert ) {
assert.equal( '555' , 555 , "IS 555 ?" );
});
因为equal用的是Javascript中的==比较,所以会隐式转换。
如果不想这样我们可以使用deepEqual函数
QUnit.test( "test", function( assert ) {
assert.deepEqual( '555' , 555 , "IS 555 ?" );
});
deepEqual和equal函数功能差不多,不过它用的是===全等。
如果是异步的话这些就有些无能为力了,不管QUnit提供了几个函数可以解决。
QUnit.test( "test", function( assert ) {
var done = assert.async();
var qunit = document.getElementById('qunit');
qunit.onclick = function(){
assert.ok( true , "IS 555 ?" );
done();
};});
assert.async函数用来创建一个异步操作它会返回一个函数,这个可以在你测试的下方执行一下done();
但是正如QUnit官方说的:
Call assert.async()
for each operation. Each done
callback can be called at most once.
调用每个操作async()断言,每个所做的回调可以至多被调用一次。
也就是说只能执行一次,看这个。
会多一次的,也就是说如果你想执行多次这样还不行,但是有一个叫啥断言的东西,我们来看看。
QUnit.test( "test", function( assert ) {
assert.expect(5);
var done = assert.async(5);
var qunit = document.getElementById('qunit');
qunit.onclick = function(){
assert.ok( true , "istrue" );
done();
};});
assert.expect(5);这里写你要测试的次数,var done = assert.async(5);也要加上次数。
我也醉了为什么要限制这个。
QUnit官网:http://api.qunitjs.com/
刷去吧。
Javascript单元测试之QUnit的更多相关文章
- 单元测试之Qunit
单元测试之Qunit 前言 因为公司开发了一套javascript SDK需要测试,在网上找了很久,找到了JQuery团队开发的QUnit,和基于JUnit的JsUnit,还有一些还没有看,先讲讲QU ...
- JS自动化测试 单元测试之Qunit
前言 因为公司开发了一套javascript SDK需要测试,在网上找了很久,找到了JQuery团队开发的QUnit,和基于JUnit的JsUnit,还有一些还没有看,先讲讲QUnit吧 下载 登录J ...
- iOS 单元测试之XCTest详解(一)
iOS 单元测试之XCTest详解(一) http://blog.csdn.net/hello_hwc/article/details/46671053 原创blog,转载请注明出处 blog.csd ...
- 玩转单元测试之Testing Spring MVC Controllers
玩转单元测试之 Testing Spring MVC Controllers 转载注明出处:http://www.cnblogs.com/wade-xu/p/4311657.html The Spri ...
- 玩转单元测试之WireMock -- Web服务模拟器
玩转单元测试之WireMock -- Web服务模拟器 WireMock 是一个灵活的库用于 Web 服务测试,和其他测试工具不同的是,WireMock 创建一个实际的 HTTP服务器来运行你的 We ...
- 单元测试之NSNull 检测
本文主要讲 单元测试之NSNull 检测,在现实开发中,我们最烦的往往就是服务端返回的数据中隐藏着NSNull的数据,一般我们的做法是通过[data isKindOfClass:[NSNull cla ...
- [转载]单元测试之道(使用NUnit)
首先来看下面几个场景你是否熟悉 1.你正在开发一个系统,你不断地编码-编译-调试-编码-编译-调试……终于,你负责的功能模块从上到下全部完成且编译通过!你长出一口气,怀着激动而又忐忑的心情点击界面上的 ...
- 单元测试之道(使用NUnit)
首先来看下面几个场景你是否熟悉 1.你正在开发一个系统,你不断地编码-编译-调试-编码-编译-调试……终于,你负责的功能模块从上到下全部完成且编译通过!你长出一口气,怀着激动而 又忐忑的心情点击界面上 ...
- 使用VisualStudio进行单元测试之二
借着工作忙的借口,偷了两天懒,今天继续单元测试之旅.前面说了如何进行一个最简单的单元测试,这次呢就跟大家一起来熟悉一下,在visual studio中如何进行数据驱动的单元测试. 开始之前先来明确一下 ...
随机推荐
- Linux命令之route - 显示和操作IP路由表
转自: http://codingstandards.iteye.com/blog/1125312 用途说明 route命令用于显示和操作IP路由表(show / manipulate the IP ...
- HTML与CSS基础知识补遗(一)
开始从零基础系统地学习前端知识了,虽说html和css多少了解一些,但是学着还是能发现很多新大陆.... 一. HTML中head标签 1. <meta>标签: meta标签里是一些基础的 ...
- 在Web应用中接入微信支付的流程之极简清晰版
在Web应用中接入微信支付的流程之极简清晰版 背景: 在Web应用中接入微信支付,我以为只是调用几个API稍作调试即可. 没想到微信的API和官方文档里隐坑无数,致我抱着怀疑人生的心情悲愤踩遍了丫们布 ...
- myeclise连接oracle数据库实现登录
package A; import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatem ...
- DB_oracle学习笔记_概念分析
概念分析: 1. 数据库(Database): 数据库是一个文件集合,包括数据文件,临时文件,重做日志文件和控制文件.也可以说数据库是物理操作系统文件或磁盘集合.数据库可以由多个实例(sc ...
- Export GridView Data to Excel. 从GridView导出数据到Excel的奇怪问题解析
GridView导出函数内容如下 string attachment = "attachment; filename=Contacts.xls"; Respo ...
- 安装 webpack
安装 webpack看好webpack 对自动压缩和文件名自动md5更名,可解决客户端缓存问题.我的安装环境为 centos linux,root用户 1.安装Node及NPM.到NodeJS官网安装 ...
- Attic 0.8.1 发布,备份程序
Attic 0.8.1 修复了昨天刚发布的 Attic 0.8 的一个段错误. Attic 是一个可以保证文件不重复的备份程序.Attic 的主要目标是提供一个高效和安全的方法来备份数据.重复数据删除 ...
- 写了一个简单的NodeJS实现的进程间通信的例子
1. cluster介绍 大家都知道nodejs是一个单进程单线程的服务器引擎,不管有多么的强大硬件,只能利用到单个CPU进行计算.所以,有人开发了第三方的cluster,让node可以利用多核CPU ...
- OAuth 2.0 授权原理
出处:http://www.cnblogs.com/neutra/archive/2012/07/26/2609300.html 最近在做第三方接入的,初步定下使用OAuth2协议,花了些时间对OAu ...