1. 程式人生 > 其它 >白盒測試六種方法的比較

白盒測試六種方法的比較

摘要:白盒測試作為測試人員常用的一種測試方法,越來越受到測試工程師的重視。白盒測試並不是簡單的按照程式碼設計用例,而是需要根據不同的測試需求,結合不同的測試物件,使用適合的方法進行測試。因為對於不同複雜度的程式碼邏輯,可以衍生出許多種執行路徑,只有適當的測試方法,才能幫助我們從程式碼的迷霧森林中找到正確的方向。本文介紹六種白盒子測試方法:語句覆蓋、判定覆蓋、條件覆蓋、判定條件覆蓋、條件組合覆蓋、路徑覆蓋。

白盒測試的概述

  由於邏輯錯誤和不正確假設與一條程式路徑被執行的可能性成反比。由於我們經常相信某邏輯路徑不可能被執行, 而事實上,它可能在正常的情況下被執行。由於程式碼中的筆誤是隨機且無法杜絕的,因此我們要進行

白盒測試

  白盒測試又稱結構測試,透明盒測試、邏輯驅動測試或基於程式碼的測試。白盒測試是一種測試用例設計方法,盒子指的是被測試的軟體,白盒指的是盒子是可視的,你清楚盒子內部的東西以及裡面是如何運作的。

  白盒的測試用例需要做到:

·保證一個模組中的所有獨立路徑至少 被使用一次
·對所有邏輯值均需測試 true 和 false
·在上下邊界及可操作範圍內執行所有迴圈
·檢查內部資料結構以確保其有效性

  白盒測試的目的:通過檢查軟體內部的邏輯結構,對軟體中的邏輯路徑進行覆蓋測試;在程式不同地方設立檢查點,檢查程式的狀態,以確定實際執行狀態與預期狀態是否一致。

  白盒測試的特點:依據軟體設計說明書進行測試、對程式內部細節的嚴密檢驗、針對特定條件設計測試用例、對軟體的邏輯路徑進行覆蓋測試。

  白盒測試的實施步驟:

1.測試計劃階段:根據需求說明書,制定測試進度。
2.測試設計階段:依據程式設計說明書,按照一定規範化的方法進行軟體結構劃分和設計測試用例。
3.測試執行階段:輸入測試用例,得到測試結果。
4.測試總結階段:對比測試的結果和程式碼的預期結果,分析錯誤原因,找到並解決錯誤。

  白盒測試的方法:總體上分為靜態方法和動態方法兩大類。

  靜態分析是一種不通過執行程式而進行測試的技術。靜態分析的關鍵功能是檢查軟體的表示和描述是否一致,沒有衝突或者沒有歧義。

  動態分析的主要特點是當軟體系統在模擬的或真實的環境中執行之前、之中和之後 , 對軟體系統行為的分析。動態分析包含了程式在受控的環境下使用特定的期望結果進行正式的執行。它顯示了一個系統在檢查狀態下是正確還是不正確。在動態分析技術中,最重要的技術是路徑和分支測試。下面要介紹的六種覆蓋測試方法屬於動態分析方法。

  白盒測試的優缺點

  1. 優點

·迫使測試人員去仔細思考軟體的實現
·可以檢測程式碼中的每條分支和路徑
·揭示隱藏在程式碼中的錯誤
·對程式碼的測試比較徹底
·最優化

  2. 缺點

·昂貴
·無法檢測程式碼中遺漏的路徑和資料敏感性錯誤
·不驗證規格的正確性

六種覆蓋方法

  首先為了下文的舉例描述方便,這裡先給出一張程式流程圖。(本文以1995年軟體設計師考試的一道考試題目為例,圖中紅色字母代表程式執行路徑)。

  1、語句覆蓋

  1)主要特點:語句覆蓋是最起碼的結構覆蓋要求,語句覆蓋要求設計足夠多的測試用例,使得程式中每條語句至少被執行一次。

  2)用例設計:(如果此時將A路徑上的語句1—〉T去掉,那麼用例如下)

 

   X  Y  路徑
 1  50  50  OBDE
 2  90  70  OBCE

 

  3)優點:可以很直觀地從原始碼得到測試用例,無須細分每條判定表示式。

  4)缺點:由於這種測試方法僅僅針對程式邏輯中顯式存在的語句,但對於隱藏的條件和可能到達的隱式邏輯分支,是無法測試的。在本例中去掉了語句1—〉T去掉,那麼就少了一條測試路徑。在if結構中若原始碼沒有給出else後面的執行分支,那麼語句覆蓋測試就不會考慮這種情況。但是我們不能排除這種以外的分支不會被執行,而往往這種錯誤會經常出現。再如,在Do-While結構中,語句覆蓋執行其中某一個條件分支。那麼顯然,語句覆蓋對於多分支的邏輯運算是無法全面反映的,它只在乎執行一次,而不考慮其他情況。

  2、判定覆蓋

  1)主要特點:判定覆蓋又稱為分支覆蓋,它要求設計足夠多的測試用例,使得程式中每個判定至少有一次為真值,有一次為假值,即:程式中的每個分支至少執行一次。每個判斷的取真、取假至少執行一次。

  2)用例設計:

 

 

   X  Y  路徑
 1  90  90  OAE
 2  50  50  OBDE
 3  90  70  OBCE

 

 

  3)優點:判定覆蓋比語句覆蓋要多幾乎一倍的測試路徑,當然也就具有比語句覆蓋更強的測試能力。同樣判定覆蓋也具有和語句覆蓋一樣的簡單性,無須細分每個判定就可以得到測試用例。

  4)缺點:往往大部分的判定語句是由多個邏輯條件組合而成(如,判定語句中包含AND、OR、CASE),若僅僅判斷其整個最終結果,而忽略每個條件的取值情況,必然會遺漏部分測試路徑。

  3、條件覆蓋

  1)主要特點:條件覆蓋要求設計足夠多的測試用例,使得判定中的每個條件獲得各種可能的結果,即每個條件至少有一次為真值,有一次為假值。

  2)用例設計:

 

 

   X  Y  路徑
 1  90  70 OBC
 2 40   OBD

 

 

  3)優點:顯然條件覆蓋比判定覆蓋,增加了對符合判定情況的測試,增加了測試路徑。

  4)缺點:要達到條件覆蓋,需要足夠多的測試用例,但條件覆蓋並不能保證判定覆蓋。條件覆蓋只能保證每個條件至少有一次為真,而不考慮所有的判定結果。

4、判定/條件覆蓋

  1)主要特點:設計足夠多的測試用例,使得判定中每個條件的所有可能結果至少出現一次,每個判定本身所有可能結果也至少出現一次。

  2)用例設計:

 

 

   X  Y  路徑
 1  90  90  OAE
 2  50  50  OBDE
 3  90  70  OBCE
 4  70  90  OBCE

 

 

  3)優點:判定/條件覆蓋滿足判定覆蓋準則和條件覆蓋準則,彌補了二者的不足。

  4)缺點:判定/條件覆蓋準則的缺點是未考慮條件的組合情況。

  5、組合覆蓋

  1)主要特點:要求設計足夠多的測試用例,使得每個判定中條件結果的所有可能組合至少出現一次。

  2)用例設計:

 

 

   X  Y  路徑
 1  90  90  OAE
 2  90  70  OBCE
 3  90  30  OBDE
 4  70  90  OBCE
 5  30  90  OBDE
 6  70  70  OBDE
 7  50  50  OBDE

 

 

  3)優點:多重條件覆蓋準則滿足判定覆蓋、條件覆蓋和判定/條件覆蓋準則。更改的判定/條件覆蓋要求設計足夠多的測試用例,使得判定中每個條件的所有可能結果至少出現一次,每個判定本身的所有可能結果也至少出現一次。並且每個條件都顯示能單獨影響判定結果。

  4)缺點:線性地增加了測試用例的數量。

  6、路徑覆蓋

  1)主要特點:設計足夠的測試用例,覆蓋程式中所有可能的路徑。

  2)用例設計:

 

 

   X  Y  路徑
 1  90  90  OAE
 2  50  50  OBDE
 3  90  70  OBCE
 4  70  90  OBCE

 

 

  3)優點:這種測試方法可以對程式進行徹底的測試,比前面五種的覆蓋面都廣。

  4)缺點:由於路徑覆蓋需要對所有可能的路徑進行測試(包括迴圈、條件組合、分支選擇等),那麼需要設計大量、複雜的測試用例,使得工作量呈指數級增長。而在有些情況下,一些執行路徑是不可能被執行的,如:
  If  (!A)B++;
  If  (!A)D--;

  這兩個語句實際只包括了2條執行路徑,即A為真或假時候對B和D的處理,真或假不可能都存在,而路徑覆蓋測試則認為是包含了真與假的4條執行路徑。這樣不僅降低了測試效率,而且大量的測試結果的累積,也為排錯帶來麻煩。

總結

  白盒測試是一種被廣泛使用的邏輯測試方法,是由程式內部邏輯驅動的一種單元測試方法。只有對程式內部十分了解才能進行適度有效的白盒測試。但是貫穿在程式內部的邏輯存在著不確定性和無窮性,尤其對於大規模複雜軟體。因此我們不能窮舉所有的邏輯路徑,即使窮舉也未必會帶來好運(窮舉不能查出程式邏輯規則錯誤,不能查出資料相關錯誤,不能查出程式遺漏的路徑)。

  那麼正確使用白盒測試,就要先從程式碼分析入手,根據不同的程式碼邏輯規則、語句執行情況,選用適合的覆蓋方法。任何一個高效的測試用例,都是針對具體測試場景的。邏輯測試不是片面的測試正確的結果或是測試錯誤的結果,而是儘可能全面地覆蓋每一個邏輯路徑。