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