單元測試針對程序模塊,進行正确性檢驗的測試。其目的在于發現各模塊内部可能存在的各種差錯。單元測試需要從程序的内部結構出發設計測試用例。多個模塊可以平行地獨立進行單元測試。
①單元測試的内容
模塊接口測試:對通過被測模塊的數據流進行測試。為此,對模塊接口,包括參數表、調用子模塊的參數、全程數據、文件輸入/輸出操作都必須檢查。
局部數據結構測試:設計測試用例檢查數據類型說明、初始化、缺省值等方面的問題,還要查清全程數據對模塊的影響。
路徑測試:選擇适當的測試用例,對模塊中重要的執行路徑進行測試。對基本執行路徑和循環進行測試可以發現大量路徑錯誤。
錯誤處理測試:檢查模塊的錯誤處理功能是否包含有錯誤或缺陷。例如,是否拒絕不合理的輸入;出錯的描述是否難以理解、是否對錯誤定位有誤、是否出錯原因報告有誤、是否對錯誤條件的處理不正确;在對錯誤處理之前錯誤條件是否已經引起系統的幹預等。
邊界測試:要特别注意數據流、控制流中剛好等于、大于或小于确定的比較值時出錯的可能性。對這些地方要仔細地選擇測試用例,認真加以測試。
此外,如果對模塊運行時間有要求的話,還要專門進行關鍵路徑測試,以确定最壞情況下和平均意義下影響模塊運行時間的因素。這類信息對進行性能評價是十分有用的。
②單元測試的步驟
通常單元測試在編碼階段進行。在源程序代碼編制完成,經過評審和驗證,确認沒有語法錯誤之後,就開始進行單元測試的測試用例設計。利用設計文檔,設計可以驗證程序功能、找出程序錯誤的多個測試用例。對于每一組輸入,應有預期的正确結果。
模塊并不是一個獨立的程序,在考慮測試模塊時,同時要考慮它和外界的聯系,用一些輔助模塊去模拟與被測模塊相聯系的其它模塊。這些輔助模塊分為兩種:
驅動模塊:相當于被測模塊的主程序。它接收測試數據,把這些數據傳送給被測模塊,最後輸出實測結果。
樁模塊:用以代替被測模塊調用的子模塊。樁模塊可以做少量的數據操作,不需要把子模塊所有功能都帶進來,但不允許什麼事情也不做。
被測模塊、與它相關的驅動模塊及樁模塊共同構成了一個“測試環境”。
如果一個模塊要完成多種功能,且以程序包或對象類的形式出現,例如Ada中的包,Modula中的模塊,C 中的類。這時可以将這個模塊看成由幾個小程序組成。對其中的每個小程序先進行單元測試要做的工作,對關鍵模塊還要做性能測試。對支持某些标準規程的程序,更要着手進行互聯測試。有人把這種情況特别稱為模塊測試,以區别單元測試。
,