青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

牽著老婆滿街逛

嚴(yán)以律己,寬以待人. 三思而后行.
GMail/GTalk: yanglinbo#google.com;
MSN/Email: tx7do#yahoo.com.cn;
QQ: 3 0 3 3 9 6 9 2 0 .

深入淺出單元測(cè)試

作者:老納
一 單元測(cè)試概述
  工廠在組裝一臺(tái)電視機(jī)之前,會(huì)對(duì)每個(gè)元件都進(jìn)行測(cè)試,這,就是單元測(cè)試。
  其實(shí)我們每天都在做單元測(cè)試。你寫(xiě)了一個(gè)函數(shù),除了極簡(jiǎn)單的外,總是要執(zhí)行一下,看看功能是否正常,有時(shí)還要想辦法輸出些數(shù)據(jù),如彈出信息窗口什么的,這,也是單元測(cè)試,老納把這種單元測(cè)試稱為臨時(shí)單元測(cè)試。只進(jìn)行了臨時(shí)單元測(cè)試的軟件,針對(duì)代碼的測(cè)試很不完整,代碼覆蓋率要超過(guò)70%都很困難,未覆蓋的代碼可能遺留大量的細(xì)小的錯(cuò)誤,這些錯(cuò)誤還會(huì)互相影響,當(dāng)BUG暴露出來(lái)的時(shí)候難于調(diào)試,大幅度提高后期測(cè)試和維護(hù)成本,也降低了開(kāi)發(fā)商的競(jìng)爭(zhēng)力。可以說(shuō),進(jìn)行充分的單元測(cè)試,是提高軟件質(zhì)量,降低開(kāi)發(fā)成本的必由之路。
  對(duì)于程序員來(lái)說(shuō),如果養(yǎng)成了對(duì)自己寫(xiě)的代碼進(jìn)行單元測(cè)試的習(xí)慣,不但可以寫(xiě)出高質(zhì)量的代碼,而且還能提高編程水平。
  多數(shù)講述單元測(cè)試的文章都是以Java為例,本文以C++為例,后半部分所介紹的單元測(cè)試工具也只介紹C++單元測(cè)試工具。
  要進(jìn)行充分的單元測(cè)試,應(yīng)專門(mén)編寫(xiě)測(cè)試代碼,并與產(chǎn)品代碼隔離。老納認(rèn)為,比較簡(jiǎn)單的辦法是為產(chǎn)品工程建立對(duì)應(yīng)的測(cè)試工程,為每個(gè)類建立對(duì)應(yīng)的測(cè)試類,為每個(gè)函數(shù)(很簡(jiǎn)單的除外)建立測(cè)試函數(shù)。首先就幾個(gè)概念談?wù)劺霞{的看法。
  一般認(rèn)為,在結(jié)構(gòu)化程序時(shí)代,單元測(cè)試所說(shuō)的單元是指函數(shù),在當(dāng)今的面向?qū)ο髸r(shí)代,單元測(cè)試的所說(shuō)的單元是指類。老納認(rèn)為,以類作為測(cè)試單位,復(fù)雜度高,可操作性較差,因此仍然應(yīng)以函數(shù)作為單元測(cè)試的測(cè)試單位,但可以用一個(gè)測(cè)試類來(lái)組織某個(gè)類的所有測(cè)試函數(shù)。單元測(cè)試不應(yīng)過(guò)分強(qiáng)調(diào)面向?qū)ο螅驗(yàn)榫植看a依然是結(jié)構(gòu)化的。單元測(cè)試的工作量較大,簡(jiǎn)單實(shí)用高效才是硬道理。
  有一種看法是,只測(cè)試類的接口(公有函數(shù)),不測(cè)試其他函數(shù),從面向?qū)ο蠼嵌葋?lái)看,似乎有些道理。老納認(rèn)為,測(cè)試的目的是找錯(cuò)并最終排錯(cuò),因此,只要是包含錯(cuò)誤的可能性較大的函數(shù)都要測(cè)試,跟函數(shù)是否私有沒(méi)有關(guān)系。對(duì)于C++來(lái)說(shuō),可以用一種簡(jiǎn)單的方法區(qū)隔需測(cè)試的函數(shù):簡(jiǎn)單的函數(shù)如數(shù)據(jù)讀寫(xiě)函數(shù)的實(shí)現(xiàn)在頭文件中編寫(xiě)(inline函數(shù)),所有在源文件編寫(xiě)實(shí)現(xiàn)的函數(shù)都要進(jìn)行測(cè)試(構(gòu)造函數(shù)和析構(gòu)函數(shù)除外)。
  什么時(shí)候測(cè)試?XP開(kāi)發(fā)理論講究TDD,即測(cè)試驅(qū)動(dòng)開(kāi)發(fā),先編寫(xiě)測(cè)試代碼,再進(jìn)行開(kāi)發(fā)。老納認(rèn)為,不必過(guò)分強(qiáng)調(diào)先什么后什么,重要的是高效和感覺(jué)舒適。從老納的經(jīng)驗(yàn)來(lái)看,先編寫(xiě)產(chǎn)品函數(shù)的框架,然后編寫(xiě)測(cè)試函數(shù),針對(duì)產(chǎn)品函數(shù)的功能編寫(xiě)測(cè)試用例,然后編寫(xiě)產(chǎn)品函數(shù)的代碼,每寫(xiě)一個(gè)功能點(diǎn)都運(yùn)行測(cè)試,隨時(shí)補(bǔ)充測(cè)試用例。所謂先編寫(xiě)產(chǎn)品函數(shù)的框架,是指先編寫(xiě)函數(shù)空的實(shí)現(xiàn),有返回值的隨便返回一個(gè)值,編譯通后再編寫(xiě)測(cè)試代碼,這時(shí),函數(shù)名、參數(shù)表、返回類型都應(yīng)該確定下來(lái)了,所編寫(xiě)的測(cè)試代碼以后需修改的可能性比較小。
  由誰(shuí)測(cè)試?單元測(cè)試與其他測(cè)試不同,單元測(cè)試可看作是編碼工作的一部分,應(yīng)該由程序員完成,也就是說(shuō),經(jīng)過(guò)了單元測(cè)試的代碼才是已完成的代碼,提交產(chǎn)品代碼時(shí)也要同時(shí)提交測(cè)試代碼。測(cè)試部門(mén)可以作一定程度的審核。
  關(guān)于樁代碼,老納認(rèn)為,單元測(cè)試應(yīng)避免編寫(xiě)樁代碼。樁代碼就是用來(lái)代替某些代碼的代碼,例如,產(chǎn)品函數(shù)或測(cè)試函數(shù)調(diào)用了一個(gè)未編寫(xiě)的函數(shù),可以編寫(xiě)樁函數(shù)來(lái)代替該被調(diào)用的函數(shù),樁代碼也用于實(shí)現(xiàn)測(cè)試隔離。采用由底向上的開(kāi)發(fā)方式進(jìn)行開(kāi)發(fā),先開(kāi)發(fā)的代碼先測(cè)試,可以避免編寫(xiě)樁代碼,這樣做的好處有:減少了工作量;測(cè)試上層函數(shù)時(shí),也是對(duì)下層函數(shù)的間接測(cè)試;當(dāng)下層函數(shù)修改時(shí),通過(guò)回歸測(cè)試可以確認(rèn)修改是否導(dǎo)致上層函數(shù)產(chǎn)生錯(cuò)誤。

二 測(cè)試代碼編寫(xiě)
  下面該說(shuō)說(shuō)如果編寫(xiě)測(cè)試代碼了,以一個(gè)例子來(lái)說(shuō)明,開(kāi)發(fā)環(huán)境是VC6.0。
產(chǎn)品類:
class CMyClass
{
public:
int Add(int i, int j);
CMyClass();
virtual ~CMyClass();
private:
int mAge; //年齡
CString mPhase; //年齡階段,如"少年","青年"
};
建立對(duì)應(yīng)的測(cè)試類CMyClassTester,為了節(jié)約編幅,只列出源文件的代碼:
void CMyClassTester::CaseBegin()
{
//pObj是CMyClassTester類的成員變量,是被測(cè)試類的對(duì)象的指針,
//為求簡(jiǎn)單,所有的測(cè)試類都可以用pObj命名被測(cè)試對(duì)象的指針。
pObj = new CMyClass();
}
void CMyClassTester::CaseEnd()
{
delete pObj;
}
測(cè)試類的函數(shù)CaseBegin()和CaseEnd()建立和銷毀被測(cè)試對(duì)象,每個(gè)測(cè)試用例的開(kāi)頭都要調(diào)用CaseBegin(),結(jié)尾都要調(diào)用CaseEnd()。
接下來(lái),我們建立示例的產(chǎn)品函數(shù):
int CMyClass::Add(int i, int j)
{
return i+j;
}
和對(duì)應(yīng)的測(cè)試函數(shù):
void CMyClassTester::Add_int_int()
{
}
把參數(shù)表作為函數(shù)名的一部分,這樣當(dāng)出現(xiàn)重載的被測(cè)試函數(shù)時(shí),測(cè)試函數(shù)不會(huì)產(chǎn)生命名沖突。下面添加測(cè)試用例:
void CMyClassTester::Add_int_int()
{
//第一個(gè)測(cè)試用例
CaseBegin();{ //1
int i = 0; //2
int j = 0; //3
int ret = pObj->Add(i, j); //4
ASSERT(ret == 0); //5
}CaseEnd(); //6
}
第1和第6行建立和銷毀被測(cè)試對(duì)象,所加的{}是為了讓每個(gè)測(cè)試用例的代碼有一個(gè)獨(dú)立的域,以便多個(gè)測(cè)試用例使用相同的變量名。
第2和第3行是定義輸入數(shù)據(jù),第4行是調(diào)用被測(cè)試函數(shù),這些容易理解,不作進(jìn)一步解釋。第5行是預(yù)期輸出,它的特點(diǎn)是當(dāng)實(shí)際輸出與預(yù)期輸出不同時(shí)自動(dòng)報(bào)錯(cuò),ASSERT是VC的斷言宏,也可以使用其他類似功能的宏,使用測(cè)試工具進(jìn)行單元測(cè)試時(shí),可以使用該工具定義的斷言宏。
  示例中的格式顯得很不簡(jiǎn)潔,2、3、4、5行可以合寫(xiě)為一行:ASSERT(pObj->Add(0, 0) == 0);但這種不簡(jiǎn)潔的格式卻是老納極力推薦的,因?yàn)樗荒苛巳唬子诮⒍鄠€(gè)測(cè)試用例,并且具有很好的適應(yīng)性,同時(shí),也是極佳的代碼文檔,總之,老納建議:輸入數(shù)據(jù)和預(yù)期輸出要自成一塊。
  建立了第一個(gè)測(cè)試用例后,應(yīng)編譯并運(yùn)行測(cè)試,以排除語(yǔ)法錯(cuò)誤,然后,使用拷貝已有的測(cè)試用例并進(jìn)行修改的辦法建立其他測(cè)試用例。由于各個(gè)測(cè)試用例之間的差別往往很小,通常只需修改一兩個(gè)數(shù)據(jù),拷貝修改是最快的建立多個(gè)測(cè)試用例的辦法。

三 測(cè)試用例
  下面說(shuō)說(shuō)測(cè)試用例、輸入數(shù)據(jù)及預(yù)期輸出。輸入數(shù)據(jù)是測(cè)試用例的核心,老納對(duì)輸入數(shù)據(jù)的定義是:被測(cè)試函數(shù)所讀取的外部數(shù)據(jù)及這些數(shù)據(jù)的初始值。外部數(shù)據(jù)是對(duì)于被測(cè)試函數(shù)來(lái)說(shuō)的,實(shí)際上就是除了局部變量以外的其他數(shù)據(jù),老納把這些數(shù)據(jù)分為幾類:參數(shù)、成員變量、全局變量、IO媒體。IO媒體是指文件、數(shù)據(jù)庫(kù)或其他儲(chǔ)存或傳輸數(shù)據(jù)的媒體,例如,被測(cè)試函數(shù)要從文件讀取數(shù)據(jù),那么,文件中的原始數(shù)據(jù)也屬于輸入數(shù)據(jù)。一個(gè)函數(shù)無(wú)論多復(fù)雜,都無(wú)非是對(duì)這幾類數(shù)據(jù)的讀取、計(jì)算和寫(xiě)入。預(yù)期輸出是指:返回值及被測(cè)試函數(shù)所寫(xiě)入的外部數(shù)據(jù)的結(jié)果值。返回值就不用說(shuō)了,被測(cè)試函數(shù)進(jìn)行了寫(xiě)操作的參數(shù)(輸出參數(shù))、成員變量、全局變量、IO媒體,它們的預(yù)期的結(jié)果值都是預(yù)期輸出。一個(gè)測(cè)試用例,就是設(shè)定輸入數(shù)據(jù),運(yùn)行被測(cè)試函數(shù),然后判斷實(shí)際輸出是否符合預(yù)期。下面舉一個(gè)與成員變量有關(guān)的例子:
產(chǎn)品函數(shù):
void CMyClass::Grow(int years)
{
mAge += years;
if(mAge < 10)
mPhase = "兒童";
else if(mAge <20)
mPhase = "少年";
else if(mAge <45)
mPhase = "青年";
else if(mAge <60)
mPhase = "中年";
else
mPhase = "老年";
}
測(cè)試函數(shù)中的一個(gè)測(cè)試用例:
CaseBegin();{
int years = 1;
pObj->mAge = 8;
pObj->Grow(years);
ASSERT( pObj->mAge == 9 );
ASSERT( pObj->mPhase == "兒童" );
}CaseEnd();
在輸入數(shù)據(jù)中對(duì)被測(cè)試類的成員變量mAge進(jìn)行賦值,在預(yù)期輸出中斷言成員變量的值。現(xiàn)在可以看到老納所推薦的格式的好處了吧,這種格式可以適應(yīng)很復(fù)雜的測(cè)試。在輸入數(shù)據(jù)部分還可以調(diào)用其他成員函數(shù),例如:執(zhí)行被測(cè)試函數(shù)前可能需要讀取文件中的數(shù)據(jù)保存到成員變量,或需要連接數(shù)據(jù)庫(kù),老納把這些操作稱為初始化操作。例如,上例中 ASSERT( ...)之前可以加pObj->OpenFile();。為了訪問(wèn)私有的成員變量或成員函數(shù),可以將測(cè)試類定義為產(chǎn)品類的友元類。例如,定義一個(gè)宏:
#define UNIT_TEST(cls) friend class cls##Tester;
然后在產(chǎn)品類聲明中加一行代碼:UNIT_TEST(ClassName)。
  下面談?wù)劀y(cè)試用例設(shè)計(jì)。前面已經(jīng)說(shuō)了,測(cè)試用例的核心是輸入數(shù)據(jù)。預(yù)期輸出是依據(jù)輸入數(shù)據(jù)和程序功能來(lái)確定的,也就是說(shuō),對(duì)于某一程序,輸入數(shù)據(jù)確定了,預(yù)期輸出也就可以確定了,至于生成/銷毀被測(cè)試對(duì)象和運(yùn)行測(cè)試的語(yǔ)句,是所有測(cè)試用例都大同小異的,因此,我們討論測(cè)試用例時(shí),只討論輸入數(shù)據(jù)。
  前面說(shuō)過(guò),輸入數(shù)據(jù)包括四類:參數(shù)、成員變量、全局變量、IO媒體,這四類數(shù)據(jù)中,只要所測(cè)試的程序需要執(zhí)行讀操作的,就要設(shè)定其初始值,其中,前兩類比較常用,后兩類較少用。顯然,把輸入數(shù)據(jù)的所有可能取值都進(jìn)行測(cè)試,是不可能也是無(wú)意義的,我們應(yīng)該用一定的規(guī)則選擇有代表性的數(shù)據(jù)作為輸入數(shù)據(jù),主要有三種:正常輸入,邊界輸入,非法輸入,每種輸入還可以分類,也就是平常說(shuō)的等價(jià)類法,每類取一個(gè)數(shù)據(jù)作為輸入數(shù)據(jù),如果測(cè)試通過(guò),可以肯定同類的其他輸入也是可以通過(guò)的。下面舉例說(shuō)明:
  正常輸入
  例如字符串的Trim函數(shù),功能是將字符串前后的空格去除,那么正常的輸入可以有四類:前面有空格;后面有空格;前后均有空格;前后均無(wú)空格。
  邊界輸入
  上例中空字符串可以看作是邊界輸入。
  再如一個(gè)表示年齡的參數(shù),它的有效范圍是0-100,那么邊界輸入有兩個(gè):0和100。
  非法輸入
  非法輸入是正常取值范圍以外的數(shù)據(jù),或使代碼不能完成正常功能的輸入,如上例中表示年齡的參數(shù),小于0或大于100都是非法輸入,再如一個(gè)進(jìn)行文件操作的函數(shù),非法輸入有這么幾類:文件不存在;目錄不存在;文件正在被其他程序打開(kāi);權(quán)限錯(cuò)誤。
  如果函數(shù)使用了外部數(shù)據(jù),則正常輸入是肯定會(huì)有的,而邊界輸入和非法輸入不是所有函數(shù)都有。一般情況下,即使沒(méi)有設(shè)計(jì)文檔,考慮以上三種輸入也可以找出函數(shù)的基本功能點(diǎn)。實(shí)際上,單元測(cè)試與代碼編寫(xiě)是“一體兩面”的關(guān)系,編碼時(shí)對(duì)上述三種輸入都是必須考慮的,否則代碼的鍵壯性就會(huì)成問(wèn)題。

四 白盒覆蓋
  上面所說(shuō)的測(cè)試數(shù)據(jù)都是針對(duì)程序的功能來(lái)設(shè)計(jì)的,就是所謂的黑盒測(cè)試,另外,單元測(cè)試還需要從另一個(gè)角度來(lái)設(shè)計(jì)測(cè)試數(shù)據(jù),即針對(duì)程序的邏輯結(jié)構(gòu)來(lái)設(shè)計(jì)測(cè)試用例,就是所謂的白盒測(cè)試。在老納看來(lái),如果黑盒測(cè)試是足夠充分的,那么白盒測(cè)試就沒(méi)有必要,可惜“足夠充分”只是一種理想狀態(tài),例如:真的是所有功能點(diǎn)都測(cè)試了嗎?程序的功能點(diǎn)是人為的定義,常常是不全面的;各個(gè)輸入數(shù)據(jù)之間,有些組合可能會(huì)產(chǎn)生問(wèn)題,怎樣保證這些組合都經(jīng)過(guò)了測(cè)試?難于衡量測(cè)試的完整性是黑盒測(cè)試的主要缺陷,而白盒測(cè)試恰恰具有易于衡量測(cè)試完整性的優(yōu)點(diǎn),兩者之間具有極好的互補(bǔ)性,例如:完成功能測(cè)試后統(tǒng)計(jì)語(yǔ)句覆蓋率,如果語(yǔ)句覆蓋未完成,很可能是未覆蓋的語(yǔ)句所對(duì)應(yīng)的功能點(diǎn)未測(cè)試。
  白盒測(cè)試針對(duì)程序的邏輯結(jié)構(gòu)設(shè)計(jì)測(cè)試用例,用邏輯覆蓋率來(lái)衡量測(cè)試的完整性。邏輯單位主要有:語(yǔ)句、分支、條件、條件值、條件值組合,路徑。語(yǔ)句覆蓋就是覆蓋所有的語(yǔ)句,其他類推。另外還有一種判定條件覆蓋,其實(shí)是分支覆蓋與條件覆蓋的組合,在此不作討論。跟條件有關(guān)的覆蓋就有三種,解釋一下:條件覆蓋是指覆蓋所有的條件表達(dá)式,即所有的條件表達(dá)式都計(jì)算了,不考慮計(jì)算結(jié)果;條件值覆蓋是指覆蓋條件的所有可能取值,即每個(gè)條件的取真值和取假值都要計(jì)算一次;條件值組合覆蓋是指覆蓋所有條件取值的所有可能組合。老納做過(guò)一些粗淺的研究,發(fā)現(xiàn)與條件直接有關(guān)的錯(cuò)誤主要是邏輯操作符錯(cuò)誤,例如:||寫(xiě)成&&,漏了寫(xiě)!什么的,采用分支覆蓋與條件覆蓋的組合,基本上可以發(fā)現(xiàn)這些錯(cuò)誤,另一方面,條件值覆蓋與條件值組合覆蓋往往需要大量的測(cè)試用例,因此,在老納看來(lái),條件值覆蓋和條件值組合覆蓋的效費(fèi)比偏低。老納認(rèn)為效費(fèi)比較高且完整性也足夠的測(cè)試要求是這樣的:完成功能測(cè)試,完成語(yǔ)句覆蓋、條件覆蓋、分支覆蓋、路徑覆蓋。做過(guò)單元測(cè)試的朋友恐怕會(huì)對(duì)老納提出的測(cè)試要求給予一個(gè)字的評(píng)價(jià):暈!或者兩個(gè)字的評(píng)價(jià):狂暈!因?yàn)檫@似乎是不可能的要求,要達(dá)到這種測(cè)試完整性,其測(cè)試成本是不可想象的,不過(guò),出家人不打逛語(yǔ),老納之所以提出這種測(cè)試要求,是因?yàn)槔靡恍┕ぞ撸梢栽谳^低的成本下達(dá)到這種測(cè)試要求,后面將會(huì)作進(jìn)一步介紹。
  關(guān)于白盒測(cè)試用例的設(shè)計(jì),程序測(cè)試領(lǐng)域的書(shū)籍一般都有講述,普通方法是畫(huà)出程序的邏輯結(jié)構(gòu)圖如程序流程圖或控制流圖,根據(jù)邏輯結(jié)構(gòu)圖設(shè)計(jì)測(cè)試用例,這些是純粹的白盒測(cè)試,不是老納想推薦的方式。老納所推薦的方法是:先完成黑盒測(cè)試,然后統(tǒng)計(jì)白盒覆蓋率,針對(duì)未覆蓋的邏輯單位設(shè)計(jì)測(cè)試用例覆蓋它,例如,先檢查是否有語(yǔ)句未覆蓋,有的話設(shè)計(jì)測(cè)試用例覆蓋它,然后用同樣方法完成條件覆蓋、分支覆蓋和路徑覆蓋,這樣的話,既檢驗(yàn)了黑盒測(cè)試的完整性,又避免了重復(fù)的工作,達(dá)到非常高的測(cè)試完整性。不過(guò),這些工作可不是手工能完成的,必須借助于工具,后面會(huì)介紹可以完成這些工作的測(cè)試工具。

五 單元測(cè)試工具
  現(xiàn)在開(kāi)始介紹單元測(cè)試工具,老納只介紹三種,都是用于C++語(yǔ)言的。
  首先是CppUnit,這是C++單元測(cè)試工具的鼻祖,免費(fèi)的開(kāi)源的單元測(cè)試框架。由于已有一眾高人寫(xiě)了不少關(guān)于CppUnit的很好的文章,老納就不現(xiàn)丑了,想了解CppUnit的朋友,建議讀一下Cpluser 所作的《CppUnit測(cè)試框架入門(mén)》,網(wǎng)址是:http://blog.csdn.net/cpluser/archive/2004/09/21/111522.aspx。該文也提供了CppUnit的下載地址。
  然后介紹C++Test,這是Parasoft公司的產(chǎn)品。[C++Test是一個(gè)功能強(qiáng)大的自動(dòng)化C/C++單元級(jí)測(cè)試工具,可以自動(dòng)測(cè)試任何C/C++函數(shù)、類,自動(dòng)生成測(cè)試用例、測(cè)試驅(qū)動(dòng)函數(shù)或樁函數(shù),在自動(dòng)化的環(huán)境下極其容易快速的將單元級(jí)的測(cè)試覆蓋率達(dá)到100%]。[]內(nèi)的文字引自http://www.superst.com.cn/softwares_testing_c_cpptest.htm,這是華唐公司的網(wǎng)頁(yè)。老納想寫(xiě)些介紹C++Test的文字,但發(fā)現(xiàn)無(wú)法超越華唐公司的網(wǎng)頁(yè)上的介紹,所以也就省點(diǎn)事了,想了解C++Test的朋友,建議訪問(wèn)該公司的網(wǎng)站。華唐公司代理C++Test,想要購(gòu)買或索取報(bào)價(jià)、試用版都可以找他們。老納幫華唐公司做廣告,不知道會(huì)不會(huì)得點(diǎn)什么好處?
  最后介紹Visual Unit,簡(jiǎn)稱VU,這是國(guó)產(chǎn)的單元測(cè)試工具,據(jù)說(shuō)申請(qǐng)了多項(xiàng)專利,擁有一批創(chuàng)新的技術(shù),不過(guò)老納只關(guān)心是不是有用和好用。[自動(dòng)生成測(cè)試代碼 快速建立功能測(cè)試用例 程序行為一目了然 極高的測(cè)試完整性 高效完成白盒覆蓋 快速排錯(cuò) 高效調(diào)試 詳盡的測(cè)試報(bào)告]。[]內(nèi)的文字是VU開(kāi)發(fā)商的網(wǎng)頁(yè)上摘錄的,網(wǎng)址是:http://www.unitware.cn。前面所述測(cè)試要求:完成功能測(cè)試,完成語(yǔ)句覆蓋、條件覆蓋、分支覆蓋、路徑覆蓋,用VU可以輕松實(shí)現(xiàn),還有一點(diǎn)值得一提:使用VU還能提高編碼的效率,總體來(lái)說(shuō),在完成單元測(cè)試的同時(shí),編碼調(diào)試的時(shí)間可能還會(huì)縮短。算了,不想再講了,老納顯擺理論、介紹經(jīng)驗(yàn)還是有興趣的,因?yàn)榭梢詽M足老納好為人師的虛榮心,但介紹工具就覺(jué)得索然無(wú)味了,畢竟工具好不好用,合不合用,要試過(guò)才知道,還是自己去開(kāi)發(fā)商的網(wǎng)站看吧,可以下載演示版,還有演示課件,老納念經(jīng)去也,阿彌陀佛。

posted on 2006-07-05 22:22 楊粼波 閱讀(207) 評(píng)論(0)  編輯 收藏 引用 所屬分類: 軟件工程

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            久久国产精品毛片| 亚洲欧美日韩一区二区三区在线观看| 欧美一级专区| 国产欧美精品xxxx另类| 香蕉乱码成人久久天堂爱免费| 一区二区三区免费网站| 欧美日韩一级黄| 亚洲天堂av电影| 妖精视频成人观看www| 欧美日韩国产三级| 亚洲一级黄色| 亚洲午夜免费福利视频| 国产精品乱子久久久久| 欧美一二三视频| 午夜亚洲性色福利视频| 国产一区久久久| 久久视频在线视频| 久久一区免费| 亚洲美女黄网| 日韩一区二区精品| 国产精品人人做人人爽人人添| 亚洲第一综合天堂另类专| 亚洲高清资源| 欧美精品一区二区三区蜜桃| 夜夜嗨av一区二区三区网站四季av| 亚洲精品国产精品国自产在线| 欧美另类极品videosbest最新版本 | 亚洲永久字幕| 国产精品久久久久久久久久久久久| 欧美亚洲日本网站| 久久大逼视频| 亚洲精品小视频在线观看| 亚洲乱码国产乱码精品精天堂| 国产精品va在线播放| 欧美一区网站| 久久亚洲精品网站| 一本大道av伊人久久综合| 一本久道久久综合中文字幕| 国产日韩欧美二区| 免费日韩av片| 欧美日韩一本到| 久久久国产精品亚洲一区 | 欧美日韩一区自拍| 久久riav二区三区| 米奇777在线欧美播放| 一区二区三区福利| 欧美大片免费| 欧美特黄一级大片| 久久天天躁狠狠躁夜夜av| 欧美成人午夜激情| 香蕉国产精品偷在线观看不卡| 久久久噜噜噜久久人人看| 亚洲美女诱惑| 性色av一区二区三区| 美女视频黄免费的久久| 加勒比av一区二区| 亚洲久久一区二区| 国内精品久久久久伊人av| 亚洲激情国产| 国产视频久久网| 亚洲三级视频在线观看| 国产视频不卡| 亚洲免费av电影| 激情自拍一区| 亚洲视频香蕉人妖| 最近中文字幕日韩精品| 亚洲欧美国产精品桃花| 亚洲国产电影| 亚洲欧美国产日韩中文字幕| 欧美国产一区二区在线观看| 国产精品亚洲成人| 亚洲人www| 韩国亚洲精品| 亚洲图片在线| 日韩视频不卡| 久久久www成人免费无遮挡大片 | 国产精品久久中文| 欧美高清视频www夜色资源网| 欧美午夜视频在线| 欧美激情亚洲另类| 国产亚洲欧美色| 一区二区三区欧美日韩| 亚洲国产经典视频| 欧美一级成年大片在线观看| 久热成人在线视频| 午夜伦欧美伦电影理论片| 男人天堂欧美日韩| 久久中文字幕一区| 国产精品一区二区久久 | 精品不卡一区| 亚洲午夜未删减在线观看| 亚洲精品乱码久久久久久蜜桃麻豆| 欧美一级欧美一级在线播放| 亚洲午夜成aⅴ人片| 欧美成人精品高清在线播放| 久久综合久久久久88| 国产精品一区=区| 中文av字幕一区| 中文精品在线| 欧美激情第五页| 欧美a级片网| 激情综合亚洲| 欧美一区免费| 欧美一区综合| 国产精品私房写真福利视频| 亚洲免费高清| 国产精品网站一区| 一区二区福利| 亚洲影视中文字幕| 欧美日韩国产综合视频在线观看中文| 欧美国产视频在线观看| 激情成人中文字幕| 欧美在线视频一区二区| 久久精品官网| 国产亚洲亚洲| 欧美一级专区| 国产精品久久久久久久久久尿 | 激情欧美一区| 久久福利影视| 久久夜色精品国产亚洲aⅴ| 国产女人水真多18毛片18精品视频 | 久久在线精品| 激情婷婷久久| 久久久噜噜噜久噜久久| 免费观看成人网| 亚洲国产成人午夜在线一区| 久久久欧美精品| 欧美sm视频| 最新成人在线| 欧美精品一级| 99精品久久久| 亚洲欧美日韩国产| 国产美女精品视频| 欧美专区在线播放| 一区二区三区四区五区在线| 欧美另类在线观看| 日韩视频久久| 一区二区三区日韩欧美| 亚洲综合不卡| 国产精品国产三级国产专区53| 在线中文字幕日韩| 欧美一区二区在线免费播放| 国产日本欧美一区二区三区| 欧美一级淫片aaaaaaa视频| 国产一区二区三区四区老人| 一区二区三区高清| 校园春色国产精品| 国产视频一区欧美| 久久久久久久一区二区| 亚洲电影av| 亚洲精选91| 欧美性猛交视频| 欧美亚洲免费在线| 欧美成人免费在线观看| 99re6热在线精品视频播放速度| 欧美日韩亚洲国产精品| 亚洲一区免费网站| 久久久午夜精品| 亚洲日本在线观看| 欧美午夜a级限制福利片| 亚洲欧美国产三级| 免费视频一区| 一区二区国产日产| 国产欧美日韩精品专区| 久久视频一区二区| 一本色道久久综合亚洲精品不| 欧美一区二区在线免费观看 | 午夜激情综合网| 男女av一区三区二区色多| 99精品免费视频| 免费看的黄色欧美网站| 一本到12不卡视频在线dvd| 欧美一区二区性| 亚洲人成7777| 国产精品尤物| 欧美成人午夜影院| 亚洲欧美激情四射在线日| 免费一级欧美片在线观看| 日韩视频一区二区三区在线播放免费观看| 国产精品多人| 久久野战av| 亚洲精品五月天| 国产午夜亚洲精品理论片色戒| 久久夜色精品国产欧美乱极品| 亚洲乱码精品一二三四区日韩在线 | 亚洲伦理网站| 久久野战av| 亚洲一区三区电影在线观看| 精品999久久久| 国产精品福利网| 乱码第一页成人| 亚洲女人天堂成人av在线| 欧美激情网友自拍| 久久成人免费日本黄色| 亚洲精品在线视频观看| 国产一区二区三区日韩| 欧美日韩大片| 老司机精品久久| 亚洲欧美视频在线| 亚洲精选一区|