陜西凌云電器集團有限公司設計所 魏銀英 楊 苗
隨著軟件系統(tǒng)越來越復雜,在產品開發(fā)各階段進行完全的軟件測試也越來越重要,大多數軟件開發(fā)者都已意識到這一點。但考慮到測試費用問題,軟件開發(fā)者往往面臨著在提高產品質量與減少費用之間進行選擇的問題。IPL提供的Cantata測試軟件應這種需要,在合理的費用下提供給軟件開發(fā)者的強有效的軟件測試工具。Cantata可以同時支持C和C++語言的測試,能夠滿足開發(fā)者進行高效的單元和集成測試的需求,該產品不僅能提高產品質量,還能幫助提高生產率。
作為專業(yè)軟件測試工具,Cantata++除包含一些標準的特征之外,還提供了一些新功能:
(1)支持語句、判定和布爾代碼覆蓋率度量;
(2)支持運用白盒測試技術,自動獲取私有類數據;
(3)支持面向對象測試用例的重用;
(4)圖形化和XML形式的結果報告。[1]
軟件質量的好壞很大程度上取決于測試用例的設計質量。不論程序員的編程水平、軟件設計水平有多高,軟件工程化執(zhí)行得多好,如果沒有通過合適質量的測試用例進行測試,其最終軟件質量都是難以保證的。因此,測試用例設計是軟件測試的最核心和最重要的內容之一。[2]
單元測試主要使用白盒測試技術,測試用例的設計方法一般分兩種類型,即測試人員自己編寫測試腳本和借助測試工具生成測試腳本框架后維護測試數據。Cantata++測試工具可用于生成和維護測試腳本,編譯并運行測試可執(zhí)行程序,查看測試結果和覆蓋率數據。
在cantata工具中常見的單元測試用例的實現方法很簡單,不再贅述。本文主要介紹復雜函數實現的單元測試用例的設計方法。如單元測試的被測單元函數使用的函數形參是結構體變量和全局變量是結構體數組且結構體的成員是指針時,在設計測試用例時如何給結構體變量賦值?
Cantata測試工具自動生成的測試用例中,函數形參的默認值都是“NOT_SET”,編譯測試腳本時不能被識別,給函數的形參賦正確的參數值是得到正確的測試結果的前提。設計帶有結構體類型的形參的測試用例時,我們分別做了如下實驗:
(1)按照在C語言中結構體變量成員賦值的方式給測試用例中的結構體變量賦值;
(2)使用改造C語言結構體變量成員賦值的方式把“->”改為“·”給測試用例中的結構體變量賦值。
編譯結果證明兩種賦值方式均不能被正確識別。
Cantata在自動生成測試用例時使用其本身封裝的INITIALISE()函數給全局變量賦初值為0x55,以滿足一般的測試需要。為達到充分測試的目的,需要給全局變量賦相應的數值,當全局變量為結構體類型的數組變量,且其成員為指針時,我們進行了如下實驗:
(1)使用C語言中數組初始化的方式給結構體數組賦值;
(2)一個數組元素一個數據元素的方式給結構體數組賦值;
(3)使用分配內存的方式給結構體數組賦值。
編譯結果證明三種賦值方式均不能被編譯器識別。
結構體形參賦值時是不是因為該形參在賦值之前沒有被分配內存空間所以無法賦值?結構體數組賦值的情況會不會因為cantata測試工具對編碼規(guī)則要求較嚴格,必須按照相應的編程規(guī)則才可以編譯通過?帶著這種疑問我們查閱了大量編程規(guī)則的資料,通過反復實踐,最終找到了解決該兩個問題的辦法。
其一,假設函數形參是如下兩個結構體變量:
struct DIST* StrCount;
struct FILTER* StrFilter;
在測試用例腳本中可以通過下面的方式給結構體變量賦值:
StrCount = malloc(sizeof(struct DIST));
StrFilter = malloc(sizeof(struct FILTER));
memset(DIST_COUNT,0,sizeof(struct DIST));
memset(DIST_FILTER,0,sizeof(struct FILTER));
StrCount->cnt = 100; /*結構體成員賦初值*/
free(StrCount) ;
free(StrFilter) ;/*釋放內存*/
如此賦值后的測試腳本文件加入測試工程后編譯通過,得到了覆蓋率測試結果,函數形參是結構體類型變量的測試用例設計的問題得以解決。
其二,假定定義如下的結構體數組:
PORT_CB g_PortCbTable[10];
其中:PORT_CB 為如下的結構體類型:
typedef struct
{
char num[16]; /* 端口名稱*/
CONNOBJ* pObj; /* 端口句柄指針*/
}PORT_CB;
在測試用例腳本中,修改指針成員變量的方式為:
g_PortCbTable[0].pObj = (CONNOBJ*)-1;
g_PortCbTable[1].pObj = (CONNOBJ*)1U;
g_PortCbTable[2].pObj = (CONNOBJ*)1U;
g_PortCbTable[3].pObj = (CONNOBJ*)1U;
g_PortCbTable[4].pObj = (CONNOBJ*)1U;
g_PortCbTable[5].pObj = (CONNOBJ*)-12;
g_PortCbTable[6].pObj = (CONNOBJ*)2U;
g_PortCbTable[7].pObj = (CONNOBJ*)2U;
g_PortCbTable[8].pObj = (CONNOBJ*)2U;
g_PortCbTable[9].pObj = (CONNOBJ*)2U;
其中有后綴U或無后綴指明所賦常量的類型,強制轉換類型不可以忽略。如此賦值后的測試腳本文件加入測試工程后編譯通過,得到了覆蓋率測試結果,至此全局變量為結構體類型的數組變量,且其成員為指針時,測試用例的設計問題得以解決。
本文介紹了測試工具cantata的功能特性及其在單元測試中的應用,在此基礎上提出了一種復雜單元函數的測試用例設計方法,該方法在類似的軟件測試項目中得到了應用,在實踐中取得了良好效果。
[1]Cantata++ Reference Manual v6.1 2011,3.
[2]周偉明著.軟件測試實踐[M].電子工業(yè)出版社,2008:46.