• 軟件測試技術
  • 軟件測試博客
  • 軟件測試視頻
  • 開源軟件測試技術
  • 軟件測試論壇
  • 軟件測試沙龍
  • 軟件測試資料下載
  • 軟件測試雜志
  • 軟件測試人才招聘
    暫時沒有公告

字號: | 推薦給好友 上一篇 | 下一篇

軟件單元測試中對代碼的異常進行驗證

發布: 2009-4-08 11:14 | 作者: 不詳 | 來源: 測試時代采編 | 查看: 20次 | 進入軟件測試論壇討論

領測軟件測試網 對異常的驗證是單元測試中一個很重要的環節。

  是不是程序在測試過程中拋出異常,就是bug呢。恰恰相反,在該拋出異常的地方,一定要拋異常,如果沒有拋,反而是bug。

  在測試之前,我們需要熟讀設計文檔,弄清楚程序在什么情況下,會拋出什么異常。舉個例子,比如有一個方法bool InsertUser(),如果插入成功,返回true,如果由于所插入的用戶信息有問題(比如缺少必填的name),是返回false呢,還是直接拋出異常。對于這兩種情況,測試代碼是完全不同的,所以我們必須先搞清楚程序是如何設計的。

  在一般的程序中經常會用try、catch的方式,增強程序的健壯性,但是在測試程序里面,try確要慎用,絕對不能在每個地方都使用try,這是為什么呢?


  還是上面那個例子,當插入的用戶信息有錯時,如果程序會拋出異常,那么我們的測試程序才能使用try,如果返回的是false,那我們就不能使用try。如果這時使用了try,而insertUser出了問題,那測試程序還是會顯示通過,bug就被漏了。

  程序中定義的異常通常都是從Exception這個基類繼承的,如果我們在測試代碼中使用try,卻不能直接catch Exception,而是要指定程序拋出的異常類型,下面是一段正確的測試代碼。


try{
    us.insertUserExtraInfo( user );
    fail("錯誤的參數,沒有拋出異常");
   }catch(RemoteAccessException e){
    //驗證異常信息是否正確的代碼
   }


  這里的RemoteAccessException就是程序定義的類型,我們catch的時候一定要指定這個類型,如果我們catch Exception,那么當程序拋出其他錯誤類型的異常時,我們就把這個bug漏了。

  當成功catch到異常以后,我們還需要對異常的具體信息進行驗證。比如,插入的用戶name沒有填,異常信息應該是“用戶信息錯誤”,如果插入一個已經存在的用戶,那么信息就是“用戶重復”等等。我們在測試程序中catch住異常以后,就需要對這些message進行檢查,確保和我們期望的一樣。如果不檢查,當插入一個已經存在的用戶時,異常信息是“未指定錯誤”,那bug就漏了。

  最后說一下異常信息的驗證,通常情況下我們比對兩個String是否一致就行了,但是有時候,信息中包含了一些變化的信息,如果每次變化的時候,我們都要改代碼,那就太麻煩了。建議使用正則表達式,只驗證message中的關鍵部分。

  舉個例子,有一個異常信息是“程序錯誤 [192.168.1.1:1234] 用戶已經存在”,這里IP的信息有可能變化,那我們就定義一個正則表達式
  程序錯誤\\[[\\d.]+:[\\d]+\\] 用戶已經存在$

  然后使用下面的代碼進行驗證

  Pattern.compile(正則表達式).matcher(實際拋出的異常信息).find(); 

延伸閱讀

文章來源于領測軟件測試網 http://www.anti-gravitydesign.com/

TAG: 代碼 單元 軟件 驗證


關于領測軟件測試網 | 領測軟件測試網合作伙伴 | 廣告服務 | 投稿指南 | 聯系我們 | 網站地圖 | 友情鏈接
版權所有(C) 2003-2010 TestAge(領測軟件測試網)|領測國際科技(北京)有限公司|軟件測試工程師培訓網 All Rights Reserved
北京市海淀區中關村南大街9號北京理工科技大廈1402室 京ICP備10010545號-5
技術支持和業務聯系:info@testage.com.cn 電話:010-51297073

軟件測試 | 領測國際ISTQBISTQB官網TMMiTMMi認證國際軟件測試工程師認證領測軟件測試網

国产97人人超碰caoprom_尤物国产在线一区手机播放_精品国产一区二区三_色天使久久综合给合久久97