qileilove

          blog已經轉移至github,大家請訪問 http://qaseven.github.io/

          走進單元測試二:測試需要從哪些方面著手

           前言

            籠統的來說測試條件無非就是兩個方面:① 正向測試 ,② 反向測試!

            如果單從這兩個方面來思考,肯定出現丟三落四的情況,也就是說不全面,所以應該在上面兩種情況的基礎上再進行具體劃分,那么只要我們能夠遵循這些條件基本上就能做到全面(如果能做到,大約80%的問題應該都解決了),于是就出現了下面要說的六個方面內容!

            前輩們把這些測試條件總結為:Right – BICEP

            1.Right - 做正確的事,可以說是“正向測試”

            這種測試前期任務是要準備足夠的正確數據(前提是要保證數據的正確性,這個很重要),運行代碼后返回的值或產生的影響是要跟自己的預期是一致的!

            注意:如果準備的數據太大或容易丟失,建議把它放在數據文件中,然后讓單元測試讀取這個文件,這種方法會在下一篇會說到!

            2.B - 邊界條件(Boundary)

            邊界條件是測試里面的重中之重,必須要有足夠的認識和重視!

            而它又被分為七個方面的子條件,下面就讓我們來一一熟悉它!

            ①一致性(Conformance)

            數據是否符合我規定的格式(也可以說是非法字符吧)!

            案例:比如我傳入的參數文件名需要的格式是:文件名 + 日期(yy-mm-dd) + 擴展名,那么我就要寫一個測試傳入的文件名為 :“sa#$#$#$#”這樣的格式!

            ②有序性(Ordering)

            這方面主要是對涉及到數組和集合的數據,而且對數據的順序有嚴格要求的函數,需要對它們里面數據的順序進行測試!

            比如:點菜系統菜譜中每道菜的順序,或者去銀行辦理業務的排隊系統等等!

            ③范圍,區間性(Range)

            值是否存在于一個最大值和一個最小值之間,主要是對值類型的數據做的測試!

            這里面還有一個重要的測試點是 → 對數組,集合,以及Table,DataSet中的索引值進行測試,比如索引值不能為負,不能超出索引的范圍等等情況!

            比如:一個通過ID來搜索信息的函數,應該對這個ID進行最大值和最小值的測試!

            ④引用,耦合性(Reference)

            這方面主要是:代碼是否引用了一些不受本身代碼控制的外部因素(比如:調用第三方接口,調用其它模塊的接口等等)!

            對于這些情況我們是沒有辦法控制的,所以在測試的時候只能模擬,而在模擬時我們會用到“Mole”技術,讓它來幫助我們創建一個模擬環境(下一篇會介紹)!

            比如:有的項目會調用銀行接口,這種情況下只能先創造一個虛擬銀行接口,然后再進行測試!

            ⑤存在性(Exist)

            固定的測試,如Null,Empty,非零等等,這些都是必須考慮的!

            ⑥基數性(Cardinality)

            對于這個測試說起來還是蠻難理解,這個測試只有在特定的場合下才會去考慮它!

            它遵循一個原則:“0-1-N”!

            ⑦時間性(Timer)

            對時間比較有依賴的軟件或系統應該在這個方面著重測試!

            主要考慮:事情是否按時間的順序執行,是否在正確的時間執行,是否出現執行事情延誤了!

            相對時間:網站超時,數據更新超時等等!

            絕對時間:不同的client間的時間是否同步!

            并發問題在時間性測試中比較重要!

          3.I - 反向關聯(Inversion)

            在準備數據或者驗證數據時的一種反向思維,涉及到個人的思維方式問題了!

            比如:有個函數對數據庫進行了操作,但是它沒任何返回值也沒有任何提示,如果你是對正確的數據進行了測試,那么你要怎么知道測試結果跟你的預期一致呢,這里你就應該去查找數據庫,看數據庫里面的數據是否有真的改動,這就是一種反向的思維方式!

            4.C - 交叉檢查(Cross)

            用一種數量檢查另一種數量(需要考慮的情況不是很多)!

            5.E - 強制產生錯誤(Error)

            通過代碼強制產生軟件在運行過程中出現的特殊情況!

            可以參考下面幾種測試方面:內存耗光,磁盤用滿,斷電,正在執行更新數據時出現斷網現象,網絡負載嚴重導致癱瘓,系統時間出現導致和國際時間不一致等等一些情況!

            6.P - 性能特性(Property)

            性能測試工具的使用,沒具體研究過性能測試工具,知道的朋友可以說下你們的經驗!

            進行壓力測試,一點一點的加大數據量,10000條,100000條,1000000條這樣進行壓力測試!

            總結:本人對反向關聯和交叉檢查這兩個測試條件不是很理解,知道的朋友可以留言給我,我會把它補充到文章中去!

          相關文章:

          走進單元測試一:初認Unit Test

          走進單元測試三:實戰單元測試



          posted on 2013-08-09 10:45 順其自然EVO 閱讀(170) 評論(0)  編輯  收藏


          只有注冊用戶登錄后才能發表評論。


          網站導航:
           
          <2013年8月>
          28293031123
          45678910
          11121314151617
          18192021222324
          25262728293031
          1234567

          導航

          統計

          常用鏈接

          留言簿(55)

          隨筆分類

          隨筆檔案

          文章分類

          文章檔案

          搜索

          最新評論

          閱讀排行榜

          評論排行榜

          主站蜘蛛池模板: 拉萨市| 南投市| 浦县| 宿迁市| 麦盖提县| 女性| 裕民县| 大余县| 当雄县| 二连浩特市| 界首市| 瓮安县| 西贡区| 兴和县| 林甸县| 鹤壁市| 鄄城县| 临湘市| 黄梅县| 亳州市| 贡山| 石屏县| 屏山县| 招远市| 阜宁县| 库尔勒市| 罗田县| 佛山市| 阿巴嘎旗| 乌兰察布市| 榆社县| 越西县| 方城县| 和平区| 长沙市| 合水县| 含山县| 乐安县| 遵义县| 屏东县| 黔东|