QUnit jQuery的TDD框架
在討論jQuery TDD之前,我們先來了解下什么才是一個標準的TDD框架。作為標準的TDD框架,必須滿足這么幾個要求:
1. 即使測試腳本出錯了也要能繼續(xù)運行接下來的腳本
2. 能夠不依賴被測試代碼寫測試用例,即使代碼沒有實現(xiàn)也可以先寫測試用例
3. 能夠顯示詳細的錯誤信息和位置
4. 能夠統(tǒng)計通過和未通過的用例的數(shù)量
5. 有專門的可視化界面用于統(tǒng)計和跟蹤測試用例
6. 易于上手,通過一些簡單的指導(dǎo)就可以馬上開始寫測試代碼。
以上這些要求QUnit都做到了, 這也是我推薦QUnit的原因。
QUnit目前已經(jīng)可以脫離jQuery獨立運行,這也是它成功的另外一個原因,即兼容性好,其實嚴格意義上它已經(jīng)不是一個jQuery的測試框架了,而是JavaScript測試框架。有意思的是你會發(fā)現(xiàn)QUnit的注釋曾經(jīng)發(fā)生過微小的變化,如下
這也說明QUnit的代碼是做過專門的調(diào)整,使之能脫離JQuery運行。
下載Qunit
下載qunit的代碼可以去http://github.com/jquery/qunit,那里的代碼是最新的。
如何使用QUnit
使用QUnit很簡單,只需要下面這些html代碼,初始的設(shè)置就完成了。
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" > <head> <title>My Foo Tests</title> <link href="qunit.css" type="text/css" rel="stylesheet"/> <script language="javascript" src="jquery-1.4.2.js" type="text/javascript" /> <script language="javascript" src="qunit.js" type="text/javascript"/> </head> <body> <h1 id="qunit-header">QUnit Test Suite</h1> <h2 id="qunit-banner"></h2> <div id="qunit-testrunner-toolbar"></div> <h2 id="qunit-userAgent"></h2> <ol id="qunit-tests"></ol> </body> </html>
QUnit不僅僅為你提供了測試腳本函數(shù),還為你的單元測試提供了一個標準化的測試界面,如下圖所示,紅色的表示這個測試用例沒有通過,綠色的表示通過。每一個框比表示一個測試函數(shù),里面可能有多個斷言語句的結(jié)果,標題中(x,y,z)表示總共有z個斷言,y個是正確的,x個是錯誤的。
剛才只是初步看了下界面,現(xiàn)在我們來學(xué)習(xí)如何使用,我從http://github.com/jquery/jquery/raw/master/test/unit/core.js下載了一個core.js的范例測試代碼,這個是jQuery用來測試它的核心模塊的代碼。
在<head></head>中加入<script language="javascript" src="core.js" type="text/javascript"></script>,注意一定要在qunit.js聲明后面,因為core.js中用到了qunit.js定義的函數(shù)。
這時你再運行剛才我們創(chuàng)建的html文件,你就會看到類似上圖的結(jié)果,這就是core.js的測試結(jié)果,是不是一清二楚?如果是測試你自己的函數(shù),你就可以根據(jù)紅色的錯誤提示跟蹤問題所在,直到把所有的測試結(jié)果都變成綠色。
測試腳本怎么寫
測試腳本的寫法,我建議你參考http://docs.jquery.com/Qunit#Reference_Test_Suites,這里面有提到一些測試用例的文件,你可以通過它們來研究怎么寫測試用例,盡管有些測試用例已經(jīng)跑不通了。
比較常用的函數(shù)有:
expect(amount) - 指定某個函數(shù)中會有多少個斷言,通常寫在測試函數(shù)開頭。
module(name) - 模塊是測試函數(shù)的集合,使用該函數(shù)可以在UI中將測試函數(shù)按模塊歸類。
ok(state, message) – 布爾型斷言,message是專門顯示在QUnit界面上,用來區(qū)分不同的斷言的
equals(actual, expected, message) - 相等斷言,actual和expected的值相等時才能通過。
same(actual, expected, message) - 完全相等斷言,和equals的區(qū)別在于它會比較子元素,對于數(shù)組和一些自定義對象的比較十分有用。
這些是最常用的,其他的大家可以自己參考Qunit官方文檔。
第一個QUnit測試用例
假設(shè)我們寫個這樣的函數(shù),計算a+b的結(jié)果,如下
function CalculateAPlusB(a,b) { return a+b; }
在頁面中加入一個單獨的js引用專門用來寫單元測試的function,比如叫test.js
<script language="javascript" src="test.js" type="text/javascript"/>
具體的測試代碼如下
test("basic calculation", function() { equals(CalculateAPlusB(1,5),6,"1+5=6"); equals(CalculateAPlusB(1.2,5.5),6.7,"1.2+5.5=6.7"); equals(CalculateAPlusB(-1,10),9,"-1+10=9"); }); test("pass null test", function() { ok(isNaN(CalculateAPlusB(null,5)),"pass null as the first argument"); ok(isNaN(CalculateAPlusB(5,null)),"pass null as the second argument"); ok(isNaN(CalculateAPlusB(null,null)),"no argument pass in"); });
其中test方法是qunit用來定義測試方法的語句,其第一個參數(shù)表示這個測試用例的名稱,第二個參數(shù)就是具體的實現(xiàn)。equals是用來比較期望值和實際值是否一致,ok是用來判斷結(jié)果是否為真。
如果一切順利,你將看到類似下面的結(jié)果。
這時應(yīng)該恭喜自己,因為所有的測試結(jié)果都是綠顏色的,這表示這些測試都通過了。 當然這里只是舉2個例子,你可以寫更多的測試用例來測試這個方法,比如測測值溢出的情況。
參考資料
http://www.swift-lizard.com/2009/11/24/test-driven-development-with-jquery-qunit/
http://www.agiledata.org/essays/tdd.html
http://www.oncoding.cn/2010/javascript-unit-testing-qunit/
- 淺談測試驅(qū)動開發(fā)TDD之爭
- Android開發(fā)筆記之:對實踐TDD的一些建議說明
- SpringBoot內(nèi)置tomcat調(diào)優(yōu)測試優(yōu)化
- SpringBoot+redis配置及測試的方法
- SpringBoot對Controller進行單元測試的實現(xiàn)代碼 附亂碼解決方案
- 詳解SpringBoot項目的創(chuàng)建與單元測試
- 解決SpringBoot 測試類無法自動注入@Autowired的問題
- Springboot Mybatis-Plus數(shù)據(jù)庫單元測試實戰(zhàn)(三種方式)
- Springboot集成JUnit5優(yōu)雅進行單元測試的示例
- 使用@SpringBootTest注解進行單元測試
- SpringBoot生產(chǎn)環(huán)境和測試環(huán)境配置分離的教程詳解
- Spring Boot web項目的TDD流程
相關(guān)文章
快速學(xué)習(xí)jQuery插件 Cookie插件使用方法
快速學(xué)習(xí)jQuery插件中的Cookie插件使用方法,一個輕量級的cookie插件,可以讀取、寫入、刪除 cookie,感興趣的小伙伴們可以參考一下2015-12-12
一些主流JS框架中DOMReady事件的實現(xiàn)小結(jié)
在實際應(yīng)用中,我們經(jīng)常會遇到這樣的場景,當頁面加載完成后去做一些事情:綁定事件、DOM操作某些結(jié)點等。2011-02-02
解決qrcode.js生成二維碼時必須定義一個空div的問題
這篇文章主要介紹了解決qrcode.js生成二維碼時必須定義一個空div的問題,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-07-07
JQuery Dialog(JS 模態(tài)窗口,可拖拽的DIV)
JQuery Dialog(JS模態(tài)窗口,可拖拽的DIV) 效果實現(xiàn)代碼2010-02-02
easyui中combotree循環(huán)獲取父節(jié)點至根節(jié)點并輸出路徑實現(xiàn)方法
下面小編就為大家?guī)硪黄猠asyui中combotree循環(huán)獲取父節(jié)點至根節(jié)點并輸出路徑實現(xiàn)方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-11-11
jQuery實現(xiàn)根據(jù)滾動條位置加載相應(yīng)內(nèi)容功能
這篇文章主要實現(xiàn)了jQuery根據(jù)滾動條位置加載相應(yīng)內(nèi)容的操作,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-07-07




