031302620

应课程要求写一篇单元测试工具的博客,但是暂时没用到java,所以不想使用junit(对各种类都不熟悉的也不好谈什么测试),原计划是要用phpunit,但是安装经历了三个小时,查阅各种博客贴吧,乃至使用了翻译工具翻译了好几个国外的社区,安装成功pear,却卡在这个迷之问题上,考虑到明天还有linux实践、图形学实践的作业要交,并且暂时php使用单元测试工具的机会也相对较少(一般用在比较大的项目中),所以换个切入口,找相对容易上手又比较实用(在软工作业马上就可以用到的)Javascript单元测试工具Qunit来上手。

下面进入正文:


一、Qunit的功能介绍

  Qunit是Javascript语言的单元0测试框架,由?Jquery团队成员开发,而且是JQuery的官方测试套件。在Javascript的开发后期检测代码是一件很艰难的事情(尤其是使用浏览器自带的调试器,不能自动话测试),所以单元测试的重要性就体现出来了,而且Qunit还具有以下优点:

  1.界面美观  

  2.上手简单

   只要有web前端相关基础的应该都可以很轻松的使用,而且API的数量很少

  3.测试方便

  • 可以测试Jquery代码,也可以测试原生的Javascript代码;  
  • 不需要依赖其它任何软件包或框架,只要能运行JS的地方就可以,QUnit本身只有一个JS文件和CSS文件,如果需要可以和jQuery等其它框架集成;
  • 不仅支持在浏览器中测试,还支持在Rhino和node.js等后端测试;

二、开始使用Qunit做开发测试

  1.基本测试

    首先做一个最简单的函数测试来了解一下用法:

      

 <!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>QUnit Example</title>
<link rel="stylesheet" href="jquint1.20.0.css">
</head>
<body>
<div id="qunit"></div>
<div id="qunit-fixture"></div>
<script src="jqunit1.20.0.js"></script> </body>
<script type="text/javascript">
//在这里填写需要测试的函数模块
</script>
</html>

    准备一个函数模板,在这里写入第一个要测试的函数a+b;

 <!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>QUnit Example</title>
<link rel="stylesheet" href="jquint1.20.0.css">
</head>
<body>
<div id="qunit"></div>
<div id="qunit-fixture"></div>
<script src="jqunit1.20.0.js"></script> </body>
<script type="text/javascript">
//在这里填写需要测试的函数模块
function add(a, b) {
return a + b;
}
test("Test Method 1", function () {
ok(add(1, 2) == 3, "Test Method 1 Pass");
});
</script>
</html>

然后界面上输出如下结果:

现在可以回头看看函数的内容,add就是一个简单的两个数相加,test函数的两个参数分别表示测试的模块名称和要测试的函数对象,ok是一个断言,当第一个参数为true时表示通过,且显示第二个参数即message。

然后可以修改一下代码,看看无法通过时的输出

     <script type="text/javascript">
//在这里填写需要测试的函数模块
function add(a, b) {
return a + b+100;
}
test("Test Method 1", function () {
ok(add(1, 2) == 3, "Test Method 1 Pass");
});
</script>

这时候会返回一个false,这里可以看到期望值和实际结果。

  2.异步测试

   异步测试的主要应用背景时,当出现类似于定时的测试时,为了方便我们可以让其他的模块先运行处结果:

     <script type="text/javascript">
//在这里填写需要测试的函数模块
function add(a, b) {
return a + b;
}
asyncTest("Test Method 1", function () { setTimeout(function(){
ok(add(1, 2) == 3, "Test Method 1 Pass");
start();
},1500); }); </script>
</html>

3.多块测试

  当测试的模块不止一个时,可以用module这个函数来便于对应:

  <script type="text/javascript">
//在这里填写需要测试的函数模块 module("Test Module 1");
test("Test Part1", function () {
ok(true, "Part1 pass");
}); test("Test Part2", function () {
ok(true, "Part2 pass");
}); module("Test Module 2");
test("Test Part1", function () {
ok(true, "Part1 pass");
}); test("Test Part2", function () {
ok(true, "Part2 pass");
});
</script>

  以上就是使用Quint测试Javascript代码的一般过程(目前主要就是测试函数是否有效)


  暂时写到这里,之后在使用过程继续补充,我要去做linux了

最新文章

  1. Fragment
  2. Java中&quot;\t&quot;表示几个空格
  3. vb.net-三种将datagridview数据导出为excel文件的函数
  4. iOS - OC NSCalendar 日历
  5. java.lang.OutOfMemoryError: unable to create new native thread如何解决
  6. 怎样查看oracle当前的连接数
  7. 返回Json数据浏览器带上&lt;pre&gt;&lt;/pre&gt;标签解决方法
  8. [020] Android模拟器访问本地Web应用
  9. CodeForces 682C Alyona and the Tree (树+dfs)
  10. BZOJ2038: [2009国家集训队]小Z的袜子(hose) -- 莫队算法 ,,分块
  11. Ext JS4百强应用: 用grid.plugin.CellEditing做高级查询 --第10强
  12. 在CDockablePane中嵌入CFormView
  13. 一个opencv 博客 大量文章(老版本编写C )
  14. 兼容低版本JS的Array.map方法
  15. linux编译相关命令
  16. P1678 烦恼的高考志愿(二分)
  17. 【BZOJ2333】【SCOI2011】棘手的操作 treap合并
  18. Learning-Python【6】:Python数据类型(2)—— 列表、元组
  19. Maven项目构建过程练习
  20. 路径或文件名中含有中文的jar文件双击启动不了 -&gt; Java7的Bug?

热门文章

  1. c++函数集锦
  2. DAY4(python)打印字符串以及增删改查
  3. Orchard详解--第七篇 拓展模块(译)
  4. 翻译:MySQL &quot;Got an Error Reading Communication Packet&quot; Errors
  5. BurpSuit添加CA证书拦截HTTPS通信
  6. SQL SERVER 查询表的行数
  7. C# DBHelper类 参考
  8. Ubuntu下永久修改主机名和创建用户
  9. UNIX高级环境编程(14)文件IO - O_DIRECT和O_SYNC详解 &lt; 海棠花溪 &gt;
  10. PHP中判断变量是否存在的方式