圖3 JUnit 運行成功界面
圖3 <u><font color=JUnit 運行成功界面" src="http://www.ibm.com/developerworks/cn/java/j-lo-junit4/figure003.jpg" _fcksavedurl="http://www.ibm.com/developerworks/cn/java/j-lo-junit4/figure003.jpg" _fcksavedurl="http://www.ibm.com/developerworks/cn/java/j-lo-junit4/figure003.jpg" _fcksavedurl="http://www.ibm.com/developerworks/cn/java/j-lo-junit4/figure003.jpg" _fcksavedurl="http://www.ibm.com/developerworks/cn/java/j-lo-junit4/figure003.jpg" />
綠色的進度條提示我們,測試運行通過了。但現在就宣布代碼通過了單元測試還為時過早。記。耗單元測試代碼不是用來證明您是對的,而是為了證明您沒有錯。因此單元測試的范圍要全面,比如對邊界值、正常值、錯誤值得測試;對代碼可能出現的問題要全面預測,而這也正是需求分析、詳細設計環節中要考慮的。顯然,我們的測試才剛剛開始,繼續補充一些對特殊情況的測試:
public class TestWordDealUtil { …… //測試 null 時的處理情況 @Test public void wordFormat4DBNull(){ String target = null; String result = WordDealUtil.wordFormat4DB(target); assertNull(result); } //測試空字符串的處理情況 @Test public void wordFormat4DBEmpty(){ String target = ""; String result = WordDealUtil.wordFormat4DB(target); assertEquals("", result); } //測試當首字母大寫時的情況 @Test public void wordFormat4DBegin(){ String target = "EmployeeInfo"; String result = WordDealUtil.wordFormat4DB(target); assertEquals("employee_info", result); } //測試當尾字母為大寫時的情況 @Test public void wordFormat4DBEnd(){ String target = "employeeInfoA"; String result = WordDealUtil.wordFormat4DB(target); assertEquals("employee_info_a", result); } //測試多個相連字母大寫時的情況 @Test public void wordFormat4DBTogether(){ String target = "employeeAInfo"; String result = WordDealUtil.wordFormat4DB(target); assertEquals("employee_a_info", result); } }
再次運行測試。很遺憾,JUnit 運行界面提示我們有兩個測試情況未通過測試(圖4)——當首字母大寫時得到的處理結果與預期的有偏差,造成測試失敗(failure);而當測試對 null 的處理結果時,則直接拋出了異!獪y試錯誤(error)。顯然,被測試代碼中并沒有對首字母大寫和 null 這兩種特殊情況進行處理,修改如下:
//修改后的方法wordFormat4DB /** * 將Java對象名稱(每個單詞的頭字母大寫)按照 * 數據庫命名的習慣進行格式化 * 格式化后的數據為小寫字母,并且使用下劃線分割命名單詞 * 如果參數name為null,則返回null * * 例如:employeeInfo 經過格式化之后變為 employee_info * * @param name Java對象名稱 */ public static String wordFormat4DB(String name){ if(name == null){ return null; } Pattern p = Pattern.compile("[A-Z]"); Matcher m = p.matcher(name); StringBuffer sb = new StringBuffer(); while(m.find()){ if(m.start() != 0) m.appendReplacement(sb, ("_"+m.group()).toLowerCase()); } return m.appendTail(sb).toString().toLowerCase(); }
圖4 JUnit 運行失敗界面
圖4 <u><font color=JUnit 運行失敗界面" src="http://www.ibm.com/developerworks/cn/java/j-lo-junit4/figure004.jpg" _fcksavedurl="http://www.ibm.com/developerworks/cn/java/j-lo-junit4/figure004.jpg" _fcksavedurl="http://www.ibm.com/developerworks/cn/java/j-lo-junit4/figure004.jpg" _fcksavedurl="http://www.ibm.com/developerworks/cn/java/j-lo-junit4/figure004.jpg" _fcksavedurl="http://www.ibm.com/developerworks/cn/java/j-lo-junit4/figure004.jpg" />
JUnit 將測試失敗的情況分為兩種:failure 和 error。Failure 一般由單元測試使用的斷言方法判斷失敗引起,它表示在測試點發現了問題;而 error 則是由代碼異常引起,這是測試目的之外的發現,它可能產生于測試代碼本身的錯誤(測試代碼也是代碼,同樣無法保證完全沒有缺陷),也可能是被測試代碼中的一個隱藏的bug。
請牢記!
文章來源于領測軟件測試網 http://www.kjueaiud.com/