書(shū)接上回:代碼的黑盒測(cè)試(上)|目標(biāo)文件測(cè)試Object File Testing,我們首先介紹了編譯的基本過(guò)程——預(yù)處理(Prepressing)、編譯(compile)、匯編(Assembly)和鏈接(Linking),然后著重介紹了代碼黑盒測(cè)試的第一種方法——VectorCAST/C++的目標(biāo)文件的測(cè)試方法,解決了在無(wú)可用源代碼的情況下,對(duì)其相應(yīng)目標(biāo)文件的測(cè)試。
其實(shí)一個(gè)代碼工程除了開(kāi)發(fā)人員手寫(xiě)代碼外,還包含了很多庫(kù)文件,甚至有的庫(kù)文件或是經(jīng)過(guò)開(kāi)發(fā)人員修改或是直接由開(kāi)發(fā)人員編寫(xiě)的。那么對(duì)于這些文件又該如何測(cè)試呢?請(qǐng)看如下分解!
一、庫(kù)接口測(cè)試
(一)庫(kù)文件
這里的“庫(kù)”,就是庫(kù)文件,一般是指編譯好的二進(jìn)制文件,用于在鏈接階段與目標(biāo)文件一起生成可執(zhí)行文件,或者運(yùn)行可執(zhí)行文件的時(shí)候被加載,以便調(diào)用庫(kù)文件中的某段代碼。
與可執(zhí)行文件不同的是,庫(kù)文件無(wú)法直接執(zhí)行。直觀(guān)上來(lái)看,庫(kù)文件的源代碼中沒(méi)有main函數(shù),而只是一些函數(shù)模塊的定義和實(shí)現(xiàn),沒(méi)有運(yùn)行的入口主函數(shù),無(wú)法直接執(zhí)行。
(二)靜態(tài)庫(kù)與動(dòng)態(tài)庫(kù)
庫(kù)文件可分為靜態(tài)庫(kù)和動(dòng)態(tài)庫(kù)。它們區(qū)別主要體現(xiàn)在程序的鏈接階段——靜態(tài)庫(kù)的代碼是在編譯過(guò)程中被載入程序中的,這就說(shuō)明,只要程序編譯完成,程序就不受靜態(tài)庫(kù)的影響;動(dòng)態(tài)庫(kù)的代碼在編譯的時(shí)候并沒(méi)有被編譯進(jìn)入程序中,只是在程序運(yùn)行時(shí)根據(jù)程序需要?jiǎng)討B(tài)的加載到內(nèi)存中。
(三)相關(guān)文件的一些擴(kuò)展名
- win32平臺(tái)下,靜態(tài)庫(kù)通常后綴為.lib,動(dòng)態(tài)庫(kù)為.dll。
- Linux平臺(tái)下,靜態(tài)庫(kù)通常后綴為.a,動(dòng)態(tài)庫(kù)為.so。
從本質(zhì)上來(lái)說(shuō),由同一段程序編譯出來(lái)的靜態(tài)庫(kù)和動(dòng)態(tài)庫(kù),在功能上是沒(méi)有區(qū)別的;不同之處僅僅在于其名字上,也就是“靜態(tài)”和“動(dòng)態(tài)”。開(kāi)發(fā)人員只需要將.h/.hpp頭文件和.lib/.so文件提交給其他開(kāi)發(fā)人員,他們就可以直接使用.lib/.so文件中定義的函數(shù)了。靜態(tài)庫(kù)和動(dòng)態(tài)庫(kù)的具體使用由開(kāi)發(fā)人員決定。
(四)庫(kù)接口測(cè)試
庫(kù)接口測(cè)試允許客戶(hù)在沒(méi)有可用源代碼的情況下,對(duì)現(xiàn)有庫(kù)文件創(chuàng)建測(cè)試。在測(cè)試時(shí),可以將第三方庫(kù)或者被修改的第三方庫(kù)作為一個(gè)對(duì)象庫(kù)文件和API定義(頭文件)。可以為API創(chuàng)建測(cè)試用例,來(lái)驗(yàn)證應(yīng)用程序庫(kù)函數(shù)的正確性,而無(wú)需訪(fǎng)問(wèn)源代碼。
在代碼開(kāi)發(fā)中,通常會(huì)將一些常用的函數(shù)封裝成一個(gè)庫(kù),提供接口給其它程序文件調(diào)用,省去重復(fù)寫(xiě)該函數(shù)接口。當(dāng)使用該函數(shù)時(shí),只需要直接將所需要的文件鏈接到程序中即可,大大提高了開(kāi)發(fā)效率。依照這個(gè)原理,我們也可以針對(duì)一些代碼程序根據(jù)測(cè)試需要,將某些源代碼編譯生成相應(yīng)的靜態(tài)庫(kù)文件或動(dòng)態(tài)庫(kù)文件,以完成代碼功能測(cè)試。
二、利用VectorCAST/C++進(jìn)行庫(kù)接口測(cè)試
對(duì)于如何使用VectorCAST/C++進(jìn)行靜態(tài)庫(kù)或者動(dòng)態(tài)庫(kù)的單元測(cè)試,下面我們?nèi)允褂蒙掀恼轮械狞c(diǎn)餐服務(wù)程序(采用GCC編譯鏈),來(lái)具體說(shuō)明。
(一)點(diǎn)餐服務(wù)程序的結(jié)構(gòu)內(nèi)容及說(shuō)明


圖 1點(diǎn)餐服務(wù)程序的結(jié)構(gòu)內(nèi)容及說(shuō)明
(二)利用VectorCAST/C++進(jìn)行靜態(tài)庫(kù)接口測(cè)試
1、靜態(tài)庫(kù)文件的生成
對(duì)于這個(gè)點(diǎn)餐主程序manager_driver.c,我們可以將manager.c和database.c分別作為一個(gè)調(diào)用的庫(kù)文件來(lái)使用,也可以一起作為一個(gè)調(diào)用的庫(kù)文件來(lái)使用。本例中,將manager.c和database.c一起作為一個(gè)調(diào)用的庫(kù)文件來(lái)使用。
使用一個(gè)BAT腳本生成靜態(tài)庫(kù)文件,腳本內(nèi)容如下:
set path=%VECTORCAST_DIR%\mingw\bin;%PATH%
gcc -c manager.c
gcc -c database.c
ar rcs manager_driver.lib manager.o database.o
說(shuō)明:無(wú)論靜態(tài)庫(kù),還是動(dòng)態(tài)庫(kù),都是在*.o目標(biāo)文件基礎(chǔ)上生成的。
2、環(huán)境構(gòu)建基本過(guò)程
VectorCAST環(huán)境構(gòu)建的基本過(guò)程在代碼的黑盒測(cè)試(上)|目標(biāo)文件測(cè)試Object File Testing有詳細(xì)說(shuō)明,這里不再贅述,對(duì)于不同的以及需要注意的地方,有如下說(shuō)明:
本例中,我們是利用manager.c和database.c一起生成靜態(tài)庫(kù)文件manager_driver.lib的,所以在構(gòu)建測(cè)試環(huán)境的第3步需要選擇“庫(kù)接口測(cè)試方法”并在“Link Options”添加該文件及所在路徑,如圖2所示。同時(shí)在構(gòu)建測(cè)試環(huán)境的第6步添加需要的頭文件,有manager.h和database.h,如圖3所示。

圖2選擇添加靜態(tài)庫(kù)文件manager_driver.lib

圖3選擇添加頭文件manager.h或database.h
3、測(cè)試用例編寫(xiě)與執(zhí)行
按照上述說(shuō)明成功構(gòu)建測(cè)試環(huán)境。編寫(xiě)測(cè)試用例及執(zhí)行測(cè)試用例,結(jié)果如下圖4所示。


圖4測(cè)試用例編寫(xiě)與執(zhí)行
細(xì)心的小伙伴可以注意到上圖左邊部分只有顯示了執(zhí)行狀態(tài)圖標(biāo),因?yàn)槲覀儾捎玫脑摲N測(cè)試屬于黑盒測(cè)試方法,所以我們?cè)跇?gòu)建環(huán)境的第4步,沒(méi)有勾選“Whitebox”前面的復(fù)選框,自然也沒(méi)有結(jié)構(gòu)覆蓋度圖標(biāo)。
(三)利用VectorCAST/C++進(jìn)行動(dòng)態(tài)庫(kù)接口測(cè)試
1、動(dòng)態(tài)庫(kù)文件的生成
與靜態(tài)庫(kù)文件生成類(lèi)似,將manager.c和database.c一起作為一個(gè)調(diào)用的動(dòng)態(tài)庫(kù)文件來(lái)使用。
使用一個(gè)BAT腳本生成動(dòng)態(tài)庫(kù)文件,腳本內(nèi)容如下:
set path=%VECTORCAST_DIR%\mingw\bin;%PATH%
gcc -c -fPIC manager.c -o manager_dyn.o
gcc -c -fPIC database.c -o database_dyn.o
gcc manager_dyn.o database_dyn.o -shared -o libmanager_drive.dll
2、環(huán)境構(gòu)建基本過(guò)程
動(dòng)態(tài)庫(kù)接口測(cè)試與靜態(tài)庫(kù)接口測(cè)試基本一致,不同的地方如下說(shuō)明:
此例中,我們?nèi)岳胢anager.c和database.c一起生成動(dòng)態(tài)庫(kù)文件manager_driver.dll,所以在構(gòu)建測(cè)試環(huán)境的第3步選擇“庫(kù)接口測(cè)試方法”并在“Link Options”添加該動(dòng)態(tài)庫(kù)dll文件,如圖5所示。后面的操作與靜態(tài)庫(kù)接口測(cè)試一致,故不在贅述。

圖5選擇添加動(dòng)態(tài)庫(kù)文件manager_driver.dll
三、總結(jié)
本文提供了代碼黑盒測(cè)試的第二種方法——庫(kù)接口測(cè)試,可以利用工具為API創(chuàng)建測(cè)試用例,來(lái)驗(yàn)證應(yīng)用程序庫(kù)函數(shù)的正確性,而無(wú)需訪(fǎng)問(wèn)源代碼,感興趣的同學(xué)可以嘗試下。
VectorCAST/C++作為Vector公司的代碼動(dòng)態(tài)測(cè)試工具,支持自動(dòng)生成測(cè)試用例,提供完善的覆蓋度信息,還可以與Git/SVN/Jekins等工具集成等等;后續(xù)也會(huì)為大家?guī)?lái)更多基于VectorCAST/C++的動(dòng)態(tài)測(cè)試相關(guān)內(nèi)容;同時(shí)也歡迎垂詢(xún)和溝通,共同探討測(cè)試相關(guān)問(wèn)題。
北匯信息作為Vector中國(guó)的合作伙伴,始終專(zhuān)注于汽車(chē)電子領(lǐng)域的新技術(shù)和新產(chǎn)品,為整車(chē)廠(chǎng)和零部件企業(yè)提供完整的研發(fā)、測(cè)試解決方案,為工程師在汽車(chē)領(lǐng)域提供“趁手裝備“!
-
測(cè)試
+關(guān)注
關(guān)注
8文章
5613瀏覽量
128254
發(fā)布評(píng)論請(qǐng)先 登錄
“System Level EOS Testing Method”可以翻譯為: “系統(tǒng)級(jí)電性過(guò)應(yīng)力測(cè)試方法”

接口測(cè)試理論、疑問(wèn)收錄與擴(kuò)展相關(guān)知識(shí)點(diǎn)

評(píng)論