回歸測試對保證軟件質量具有重要意義。要實現有效的回歸測試,必須解決回歸測試中的兩個主要問題:(1)測試用例的優化選擇;(2)覆蓋率分析。前者決定了回歸測試的效率,好的測試用例的選擇可以用少量的測試用例準確地覆蓋新版本中盡可能多的改動。后者是度量測試的重要指標,通過達到良好的測試覆蓋率,保證了回歸測試的質量。
本文正是通過討論如何優化選擇測試用例,用最小的代價達到最大的覆蓋率,從而找到回歸測試的有效解決方案。
存在的問題
● 測試用例的優化選擇
對測試用例的選擇,測試人員通常有兩種作法。一種是,把相關的或是所有的模塊的測試用例都選出來執行一遍;另一種是,僅針對被 Fixed 的 APAR/Defect 進行檢驗,測試用例很少或是開發新的針對這個 Fixed 的測試用例。這兩種方法都存在不足。第一種方法在測試時間有限的情況下,去執行所有的測試用例,會測試到很多無需再測試的測試用例,從而導致測試資源的浪費;第二種是很難確保 APAR/Defect 改動后,被測系統沒有受到關聯影響,很難保證測試質量。
由于 Bug Fix 或者功能更新后,在新版本發布之前,我們要確保所作改動不會對已有的功能模塊產生負面的影響。用所有的測試用例作回歸測試, 存在著人力與時間成本過高的問題;依靠人的經驗去挑選回歸測試用例,存在著挑選不準確或對程序改動測試覆蓋不全的問題。

圖 1. 測試用例優化選擇問題
● 回歸測試覆蓋率分析
測試用例優化選擇可以有效地解決現有測試用例的覆蓋問題,但在實際測試過程中,我們仍然發現存在著覆蓋不全的問題。即新版本中的某些實現并不能被現有的測試用例所覆蓋。這樣,測試人員需要開發新的測試用例對新的功能進行測試覆蓋。然后對于測試人員來說這并不實際,他們很難依靠測試經驗將代碼中沒有被測試的地方找出來。那么如何更好的得到測試過程中的測試覆蓋率,及測試結束后整個軟件的測試覆蓋率呢,從而使得測試人員可以針對未被測試到的地方設計新的測試用例。這里我們特別針對在版本更新過程中,那些發生了更新卻沒有被覆蓋到的地方。
解決問題
● 原理

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