專利名稱:基于控制流圖的單元回歸測試用例集合優(yōu)化方法
技術(shù)領(lǐng)域:
本發(fā)明涉及軟件測試技術(shù),尤其涉及一種基于控制流圖的單元回歸測試用例集合優(yōu)化方法,屬于控制流圖對比技術(shù)在回歸測試中的應(yīng)用。
背景技術(shù):
當(dāng)開發(fā)人員在單元測試過程中發(fā)現(xiàn)軟件故障時,會對代碼進(jìn)行相應(yīng)的修改。被測單元在改動之后,需要重新測試以保證所做的修改達(dá)到了預(yù)期的目的,并且沒有引入新的缺陷,這個過程叫做回歸測試?;貧w測試作為單元測試周期中的一個組成部分,在整個測試過程中占有很大比重,其成本甚至達(dá)到了整個測試成本的一半以上。因此,通過選擇正確的回歸測試策略來改進(jìn)回歸測試的有效性和效率是非常有意義的。
提高回歸測試效率的重心是構(gòu)造精簡而有效的測試用例集合。如果簡單地重測所有用例將會帶來大量不必要的開銷;而部分測試用例又會因?yàn)檐浖粩喔露?。因此,回歸測試只需要根據(jù)修改情況進(jìn)行有選擇性的測試,并根據(jù)測試目標(biāo)考慮補(bǔ)充新的測試用例?,F(xiàn)有的回歸測試策略主要分為三類對基線測試用例庫的約簡,測試用例優(yōu)先級技術(shù)以及測試用例的選擇性復(fù)用。其中,測試用例庫約簡技術(shù)是通過刪除所有冗余測試用例得到測試用例集合的最小約簡子集。而測試用例優(yōu)先級技術(shù)是根據(jù)測試用例對測試目標(biāo)的貢獻(xiàn)程度進(jìn)行比較和排序,優(yōu)先執(zhí)行相對重要的測試用例。雖然測試用例庫約簡技術(shù)和測試用例優(yōu)先級技術(shù)的測試效率較高,但是由于缺乏選擇的針對性,其發(fā)現(xiàn)程序錯誤的能力相比于原有測試用例集可能會有很大的損失,即這種通過減少測試用例來節(jié)省測試精力的策略,在降低成本的同時也增加了測試風(fēng)險(xiǎn)。所述的測試用例的選擇性復(fù)用是圍繞某種準(zhǔn)則從基線測試用例庫中選擇測試用例,目前最常見的選擇準(zhǔn)則是程序修改點(diǎn)與測試用例的相關(guān)性。這種方法能夠保證選擇出的測試用例精度高、針對性強(qiáng),在測試過程中使用這樣的測試用例集合可以同時保證回歸測試的高效性與有效性。
發(fā)明內(nèi)容
有鑒于此,本發(fā)明的主要目的在于提供一種基于控制流圖的單元回歸測試用例集合優(yōu)化方法,根據(jù)代碼中被修改部分篩選和新增測試用例,從而構(gòu)造出回歸測試用例集合,以提高回歸測試的效率,并保證回歸測試的有效性與充分性。為達(dá)到上述目的,本發(fā)明的技術(shù)方案是這樣實(shí)現(xiàn)的
基于控制流圖的單元回歸測試用例集合優(yōu)化方法,該方法包括
A、對比被測單元修改前后的控制流圖,找出代碼中被修改的部分所對應(yīng)的節(jié)點(diǎn),所述節(jié)點(diǎn)簡稱修改點(diǎn);
B、從單元測試用例集合中篩選出執(zhí)行路徑經(jīng)過修改點(diǎn)的測試用例,作為回歸測試用例集合的一部分,記作選擇測試用例集Tselected,并運(yùn)行集合中的所有測試用例;
C、計(jì)算修改點(diǎn)的所有可達(dá)后繼節(jié)點(diǎn),從中選出在步驟B的運(yùn)行過程中未被覆蓋的節(jié)點(diǎn)子集
D、若節(jié)點(diǎn)子集#為空,則執(zhí)行步驟F,否則執(zhí)行步驟E;
E、從節(jié)點(diǎn)子集#中取出一個節(jié)點(diǎn)作為覆蓋目標(biāo)生成測試用例,將其加入到新增測試用例集合Tnew并運(yùn) 行;待運(yùn)行完畢后,更新節(jié)點(diǎn)子集見從中刪除在此次運(yùn)行中已被覆蓋的節(jié)點(diǎn),然后執(zhí)行步驟D ;
F、回歸測試用例集合Tk構(gòu)造完畢,Tr
Tselected ^ ^new0其中,所述步驟A中根據(jù)對比控制流圖的方法找出修改點(diǎn)的具體過程為
Al、在代碼被修改前,將其對應(yīng)的控制流圖備份,記為CFGl ;代碼被修改后,對被測單元重新進(jìn)行靜態(tài)分析,生成控制流圖,記為CFG2 ;控制流圖的節(jié)點(diǎn)包含對應(yīng)的抽象語法樹
信息;
A2、使用深度優(yōu)先搜索算法同時遍歷控制流圖CFGl和CFG2 ;在遍歷過程中成對地對比當(dāng)前遍歷到的控制流圖節(jié)點(diǎn);若其包含的抽象語法樹信息不同,則把它當(dāng)作修改點(diǎn),加入到修改點(diǎn)集合當(dāng)中。其中,步驟A2中使用深度優(yōu)先搜索算法同時遍歷控制流圖CFGl和CFG2,對比當(dāng)前節(jié)點(diǎn)對的抽象語法樹信息;同時還考慮節(jié)點(diǎn)的增加和刪減情況,并作了相應(yīng)處理;其具體過程如下
A21、根據(jù)控制流圖產(chǎn)生時的節(jié)點(diǎn)序號順序,分別取CFGl和CFG2的未訪問過的后繼節(jié)點(diǎn)作為當(dāng)前節(jié)點(diǎn)對,并取當(dāng)前節(jié)點(diǎn)對中CFG2的節(jié)點(diǎn)作為當(dāng)前節(jié)點(diǎn);
A22、若當(dāng)前節(jié)點(diǎn)對為空,當(dāng)父節(jié)點(diǎn)是函數(shù)入口節(jié)點(diǎn)時,遍歷結(jié)束,否則回退到當(dāng)前節(jié)點(diǎn)對的父節(jié)點(diǎn),執(zhí)行步驟A21 ;
A23、若當(dāng)前節(jié)點(diǎn)對中的兩個節(jié)點(diǎn)都不為空,則比較當(dāng)前節(jié)點(diǎn)對中每個節(jié)點(diǎn)包含的抽象語法樹信息,即對應(yīng)的表達(dá)式中的常量、變量、運(yùn)算符信息,若這些信息都相同則執(zhí)行步驟A21 ;若不同,則執(zhí)行步驟A24;
A24、將當(dāng)前節(jié)點(diǎn)作為修改點(diǎn),加入到修改點(diǎn)集合當(dāng)中;如果當(dāng)前節(jié)點(diǎn)對中CFGl的節(jié)點(diǎn)為空,CFG2的節(jié)點(diǎn)不為空,則說明CFG2的節(jié)點(diǎn)是修改后新增的,此時將CFG2非空節(jié)點(diǎn)的父節(jié)點(diǎn)作為修改點(diǎn),加入到修改點(diǎn)集合當(dāng)中;如果CFGl的節(jié)點(diǎn)不為空而CFG2的節(jié)點(diǎn)為空,則說明CFGl中對應(yīng)的代碼已被刪除,把CFGl中被刪除的節(jié)點(diǎn)作為修改點(diǎn),加入到修改點(diǎn)集合中。步驟B中在單元測試過程中使用的測試用例,均以控制流圖節(jié)點(diǎn)標(biāo)號的形式將執(zhí)行路徑記錄于數(shù)據(jù)庫中;遍歷測試用例數(shù)據(jù)庫中的每個測試用例,若其執(zhí)行路徑的標(biāo)號序列中包含了修改點(diǎn)集合中任一修改點(diǎn)的標(biāo)號,則被選擇為回歸測試用例,加入到選擇測試用例集
Tselected 并執(zhí)行。步驟C中,從覆蓋率角度考慮為回歸測試添加新的測試用例;具體為首先,計(jì)算出修改點(diǎn)在控制流圖中的所有可達(dá)后繼節(jié)點(diǎn);然后,從此節(jié)點(diǎn)集合中選出在步驟B的運(yùn)行過程中沒有被覆蓋到的節(jié)點(diǎn),作為需要在回歸測試中被覆蓋的目標(biāo)節(jié)點(diǎn)集合見步驟E中,以節(jié)點(diǎn)集合#中的節(jié)點(diǎn)為覆蓋目標(biāo),進(jìn)行區(qū)間運(yùn)算,生成滿足覆蓋條件的測試用例,并運(yùn)行。同時,更新節(jié)點(diǎn)集合見從中刪除在本次運(yùn)行過程中已覆蓋到的節(jié)點(diǎn)。步驟F中,該回歸測試用例集合由兩部分構(gòu)成選擇測試用例集和新增測試用例集合Tnev,即 'Tr =
Tselected ^ ^new0本發(fā)明所提供的基于控制流圖的單元回歸測試用例集合優(yōu)化方法,具有以下優(yōu)
占-
應(yīng)用該單元回歸測試用例集合優(yōu)化方法進(jìn)行回歸測試,其關(guān)鍵在于提高測試用例選擇精度和測試可信度,本發(fā)明方法在基于控制流圖遍歷的回歸測試用例選擇算法和基于覆蓋要求的測試方法的基礎(chǔ)上,加以改進(jìn)和綜合,能夠達(dá)到以下的目標(biāo)以更少的測試用例提高回歸測試的效率;以篩選相關(guān)測試用例和補(bǔ)充新測試用例的方式提高回歸測試的有效性。
圖I為本發(fā)明的回歸測試用例集合組成圖;
圖2為本發(fā)明的單元回歸測試用例集優(yōu)化策略的應(yīng)用流程示意 圖3為本發(fā)明源程序Testl. Java中函數(shù)f的初始控制流 圖4為本發(fā)明中控制流圖對比過程中CFGl的后繼節(jié)點(diǎn)為空而CFG2的后繼節(jié)點(diǎn)不為空的控制流圖對比 圖5為本發(fā)明中控制流圖對比過程中CFGl的后繼節(jié)點(diǎn)不為空而CFG2的后繼節(jié)點(diǎn)為空的控制流圖對比圖。
具體實(shí)施例方式下面結(jié)合附圖及本發(fā)明的實(shí)施例對本發(fā)明的方法作進(jìn)一步詳細(xì)的說明。本發(fā)明的基本思想是利用回歸測試的第三種策略,即根據(jù)程序修改情況對基線測試用例庫中的測試用例進(jìn)行選擇性復(fù)用,考慮到運(yùn)行原有測試用例可能無法滿足新代碼的測試需求,導(dǎo)致回歸測試不夠充分,因此有必要向回歸測試用例集合中補(bǔ)充新的測試用例。這樣,通過程序控制流圖對比技術(shù)識別出程序中的修改點(diǎn),根據(jù)執(zhí)行路徑經(jīng)過修改點(diǎn)的測試用例在再次運(yùn)行時結(jié)果可能發(fā)生改變的原理對這類測試用例選擇性復(fù)用,并且按照覆蓋需求補(bǔ)充新的測試用例;即回歸測試用例集合包括兩部分復(fù)用測試用例和新增測試用例。在開發(fā)人員對原程序改動較少的情況下,沒有必要將所有單元測試的測試用例進(jìn)行回歸測試。此時,應(yīng)進(jìn)行選擇性回歸測試(selective regression test),即從原測試用例集合中找出部分測試用例來測試。當(dāng)這些測試用例對于修改后的代碼來說,測試并不夠充分的情況下,再生成新的測試用例進(jìn)行測試。因此,回歸測試的重點(diǎn)在于測試用例的選擇與生成。本發(fā)明方法中,優(yōu)化回歸測試用例集合的策略,盡力保證集合中的每個元素都與修改相關(guān)。因此,本發(fā)明的研究內(nèi)容主要為以下兩點(diǎn)
分析回歸測試需要哪些測試用例;
如何篩選或生成這些測試用例。第一點(diǎn),即討論回歸測試中測試用例集合的組成。由于回歸測試的測試目標(biāo)主要包含兩方面,即所做的修改達(dá)到了預(yù)期的目的;軟件的修改沒有引入新的缺陷。為了保證第一個條件成立,需要將與該修改處相關(guān)且在單元測試中執(zhí)行失敗的測試用例重新運(yùn)行,以驗(yàn)證修改后這些測試用例可以通過;同時,為了保證對修改處的測試足夠充分,可能需要新增一部分與之相關(guān)的測試用例。而為了保證第二個條件成立,則需要將與該修改處相關(guān)且在單元測試中執(zhí)行成功的測試用例再重新運(yùn)行一次,以驗(yàn)證這些本來已經(jīng)通過的測試用例在回歸測試中依然通過。因此,回歸測試用例集合Tk可以表示為
Tr ~ Tfajl U Tnew U Tpass - Tselected U Tnew
其中'Tfail表示與該修改處相關(guān)且在單元測試環(huán)節(jié)中執(zhí)行失敗的測試用例集合,Tnew表示需要為修改處新增的 測試用例集合,Tpass表示與該修改處相關(guān)且在單元測試環(huán)節(jié)中執(zhí)行成功的測試用例集合。Tfail和Tpass組合成為選擇測試用例集合Ts+rted。圖I為本發(fā)明的回歸測試用例集合組成圖。在研究分析出回歸測試用例集合的組成后,需要討論如何篩選或者生成符合條件的測試用例。由于回歸測試中測試用例集合主要由兩部分組成選擇測試用例集合T—和為修改處新增的測試用例集合TnOT。所述“選擇測試用例集合”T—即在代碼被修改之后,執(zhí)行結(jié)果可能會受到影響的測試用例。顯而易見,若一個測試用例在執(zhí)行過程中,其執(zhí)行路徑經(jīng)過被修改的語句或判定條件,那么它的執(zhí)行結(jié)果受之影響的可能性非常大。所以,將執(zhí)行路徑經(jīng)過修改點(diǎn)的測試用例等價(jià)為“與修改處相關(guān)的測試用例”。另外,這些測試用例不僅是執(zhí)行結(jié)果可能會受影響,其執(zhí)行路徑也有可能會發(fā)生改變,如某個判定條件的修改。為了保證對修改后的功能進(jìn)行了充分的測試,有必要新增一些測試用例,將與被修改點(diǎn)相關(guān)的所有語句按覆蓋率要求(包括語句、分支、MCDC)至少執(zhí)行一次。這里,將被修改點(diǎn)的相關(guān)節(jié)點(diǎn)定義為被修改點(diǎn)的后繼語句(或表達(dá)式),并且修改點(diǎn)到這些相關(guān)節(jié)點(diǎn)都是可達(dá)的。以下結(jié)合附圖,對本發(fā)明提出的測試用例集合優(yōu)化策略在軟件回歸測試實(shí)施例中的應(yīng)用進(jìn)行解釋和說明。圖2為本發(fā)明單元回歸測試用例集優(yōu)化策略的應(yīng)用流程示意圖。如圖2所示,該方法主要包括
步驟A、對比被測單元修改前后的控制流圖,找出代碼中被修改部分所對應(yīng)的節(jié)點(diǎn),該節(jié)點(diǎn)簡稱為修改點(diǎn)。若要找到被修改語句,就要比較被修改前后的代碼。本發(fā)明采用基于控制流圖的比較方法。這里所使用的控制流圖不僅包含程序控制結(jié)構(gòu)的信息,同時也將每個節(jié)點(diǎn)對應(yīng)的語句(或表達(dá)式)信息一一記錄下來。在對兩個控制流圖進(jìn)行比較時,使用深度優(yōu)先搜索算法進(jìn)行遍歷并采用節(jié)點(diǎn)“成對比較”的方式,即分別從兩個控制流圖的入口節(jié)點(diǎn)開始遍歷,并成對比較其對應(yīng)的抽象語法樹信息是否相同(變量、常量、運(yùn)算符)。當(dāng)抽象語法樹信息不同的節(jié)點(diǎn)時,將其加入到修改點(diǎn)集合中。該方法具體包括如下步驟
Al、備份代碼修改前的控制流圖CFG1,并生成代碼修改后的控制流圖CFG2。被測單元在單元測試過程中,通過靜態(tài)分析獲得了對應(yīng)的抽象語法樹。由抽象語法樹,進(jìn)一步獲得對應(yīng)的控制流圖。因此,控制流圖的節(jié)點(diǎn)包含了代碼對應(yīng)的表達(dá)式信息。為避免在代碼修改后由于重新進(jìn)行靜態(tài)分析,而導(dǎo)致原控制流圖丟失,需要將代碼修改前的控制流圖進(jìn)行備份,記為CFGl。當(dāng)確認(rèn)代碼修改完成時,系統(tǒng)對新代碼重新進(jìn)行靜態(tài)分析,得到新的控制流圖,記為CFG2。此時,被測單元一共有兩個控制流圖,一個是單元測試時的控制流圖CFG1,另一個是開發(fā)人員對代碼進(jìn)行修改后的控制流圖CFG2。這兩個控制流圖完整的保存了代碼修改前后的程序結(jié)構(gòu)與代碼信息。A2、使用深度優(yōu)先搜索算法同時遍歷控制流圖CFGl和CFG2。在遍歷的過程中成對地對比當(dāng)前遍歷到的控制流圖節(jié)點(diǎn);若其包含的抽象語法樹信息不同,則把它當(dāng)作修改點(diǎn),加入到修改點(diǎn)集合當(dāng)中。同時考慮了節(jié)點(diǎn)的增加和刪減情況,并作了相應(yīng)處理。其具體步驟如下
A21、根據(jù)控制流圖產(chǎn)生時的節(jié)點(diǎn)序號順序,分別取CFGl和CFG2的未訪問過的后繼節(jié)點(diǎn)作為當(dāng)前節(jié)點(diǎn)對,并取當(dāng)前節(jié)點(diǎn)對中CFG2的節(jié)點(diǎn)作為當(dāng)前節(jié)點(diǎn)。A22、若當(dāng)前節(jié)點(diǎn)對為空,當(dāng)父節(jié)點(diǎn)是函數(shù)入口節(jié)點(diǎn)時,遍歷結(jié)束,否則回退到當(dāng)前節(jié)點(diǎn)對的父節(jié)點(diǎn),執(zhí)行步驟A21 ;
A23、若當(dāng)前節(jié)點(diǎn)對中的兩個節(jié)點(diǎn)都不為空,則比較當(dāng)前節(jié)點(diǎn)對中每個節(jié)點(diǎn)包含的抽象語法樹信息,即對應(yīng)的表達(dá)式中的常量、變量、運(yùn)算符信息,若這些信息都相同則執(zhí)行步驟A21 ;若不同,則當(dāng)前節(jié)點(diǎn)為修改點(diǎn),加入到修改點(diǎn)集合當(dāng)中。如果當(dāng)前節(jié)點(diǎn)對中CFGl的節(jié)點(diǎn)為空,CFG2的節(jié)點(diǎn)不為空,則說明CFG2的節(jié)點(diǎn)是修改后新增的,將CFG2非空節(jié)點(diǎn)的父節(jié)點(diǎn)作為修改點(diǎn),加入到修改點(diǎn)集合當(dāng)中。如果CFGl的節(jié)點(diǎn)不為空而CFG2的節(jié)點(diǎn)為空,則說明CFGl中對應(yīng)的代碼已被刪除,把CFGl中被刪除的節(jié)點(diǎn)作為修改點(diǎn),加入到修改點(diǎn)集合當(dāng)中。下面本發(fā)明結(jié)合具體實(shí)例對本發(fā)明做進(jìn)一步說明。對于下面的源程序test, c中的函數(shù)f,在被修改前建立的初始控制流圖如附圖3,圖中的節(jié)點(diǎn)與源程序中行號的對應(yīng)關(guān)系如表I所示,其中節(jié)點(diǎn)名字的最后一個數(shù)字標(biāo)識了產(chǎn)生的順序號,邊上標(biāo)識的最后一個數(shù)字標(biāo)識了該邊產(chǎn)生的順序號,以“T”開頭表示為條件表達(dá)式的真分支,以“F”開頭則表示為假分支。函數(shù)f的單元測試用例庫如表2所示,其中包含了每個測試用例的執(zhí)行路徑信息(注路徑節(jié)點(diǎn)不包含終結(jié)符節(jié)點(diǎn),如if_out、func_out)。/#
* 一元二次方程test, c */
I: ^include〈stdio. h〉
2: int f (int a, int b,int c) {
3:int mid 二 b氺b_4氺a氺c;
4:if (mid> 0)
5:printf (〃two real roots \n ;
6:elsei f (mi d==~3)
7:print f (,,one real root\n〃);
8:else
9:print f (〃two complex roots\n〃);
10 :return mid ;
11: I
權(quán)利要求
1.基于控制流圖的單元回歸測試用例集合優(yōu)化方法,其特征在于,該方法包括 A、對比被測單元修改前后的控制流圖,找出代碼中被修改的部分對應(yīng)的節(jié)點(diǎn),即修改占. B、從單元測試用例集合中篩選出執(zhí)行路徑經(jīng)過修改點(diǎn)的測試用例,作為回歸測試用例集合的一部分,記作選擇測試用例集Tselected,并運(yùn)行集合中的所有測試用例; C、計(jì)算修改點(diǎn)的所有可達(dá)后繼節(jié)點(diǎn),從中選出在步驟B的運(yùn)行過程中未被覆蓋的節(jié)點(diǎn)子集 D、若節(jié)點(diǎn)子集#為空,則執(zhí)行步驟F,否則執(zhí)行步驟E; E、從節(jié)點(diǎn)子集#中取出一個節(jié)點(diǎn)作為覆蓋目標(biāo)生成測試用例,將其加入到新增測試用例集合Tnev并運(yùn)行;待運(yùn)行完畢后,更新節(jié)點(diǎn)子集見從中刪除在此次運(yùn)行中已被覆蓋的節(jié)點(diǎn),返回步驟D ; F、回歸測試用例集合Tk構(gòu)造完畢,Tr
2.根據(jù)權(quán)利要求I所述的基于控制流圖的單元回歸測試用例集合優(yōu)化方法,其特征在于,所述步驟A中根據(jù)對比控制流圖的方法找出修改點(diǎn)的具體過程為 Al、在代碼被修改前,將其對應(yīng)的控制流圖備份,記為CFGl ;代碼被修改后,對被測單元重新進(jìn)行靜態(tài)分析,生成控制流圖,記為CFG2 ;控制流圖的節(jié)點(diǎn)包含對應(yīng)的抽象語法樹信息; A2、使用深度優(yōu)先搜索算法同時遍歷控制流圖CFGl和CFG2 ;在遍歷過程中成對地對比當(dāng)前遍歷到的控制流圖節(jié)點(diǎn);若其包含的抽象語法樹信息不同,則把它當(dāng)作修改點(diǎn),加入到修改點(diǎn)集合當(dāng)中。
3.根據(jù)權(quán)利要求2所述基于控制流圖的單元回歸測試用例集合優(yōu)化方法,其特征在于,步驟A2中使用深度優(yōu)先搜索算法同時遍歷控制流圖CFGl和CFG2,對比當(dāng)前節(jié)點(diǎn)對的抽象語法樹信息;同時還考慮節(jié)點(diǎn)的增加和刪減情況,并作了相應(yīng)處理;其具體過程如下 A21、根據(jù)控制流圖產(chǎn)生時的節(jié)點(diǎn)序號順序,分別取CFGl和CFG2的未訪問過的后繼節(jié)點(diǎn)作為當(dāng)前節(jié)點(diǎn)對,并取當(dāng)前節(jié)點(diǎn)對中CFG2的節(jié)點(diǎn)作為當(dāng)前節(jié)點(diǎn); A22、若當(dāng)前節(jié)點(diǎn)對為空,當(dāng)父節(jié)點(diǎn)是函數(shù)入口節(jié)點(diǎn)時,遍歷結(jié)束,否則回退到當(dāng)前節(jié)點(diǎn)對的父節(jié)點(diǎn),執(zhí)行步驟A21 ; A23、若當(dāng)前節(jié)點(diǎn)對中的兩個節(jié)點(diǎn)都不為空,則比較當(dāng)前節(jié)點(diǎn)對中每個節(jié)點(diǎn)包含的抽象語法樹信息,即對應(yīng)的表達(dá)式中的常量、變量、運(yùn)算符信息,若這些信息都相同則執(zhí)行步驟A21 ;若不同,則執(zhí)行步驟A24; A24、將當(dāng)前節(jié)點(diǎn)作為修改點(diǎn),加入到修改點(diǎn)集合當(dāng)中;如果當(dāng)前節(jié)點(diǎn)對中CFGl的節(jié)點(diǎn)為空,CFG2的節(jié)點(diǎn)不為空,則說明CFG2的節(jié)點(diǎn)是修改后新增的,此時將CFG2非空節(jié)點(diǎn)的父節(jié)點(diǎn)作為修改點(diǎn),加入到修改點(diǎn)集合當(dāng)中;如果CFGl的節(jié)點(diǎn)不為空而CFG2的節(jié)點(diǎn)為空,則說明CFGl中對應(yīng)的代碼已被刪除,把CFGl中被刪除的節(jié)點(diǎn)作為修改點(diǎn),加入到修改點(diǎn)集合中。
4.根據(jù)權(quán)利要求I所述的基于控制流圖的單元回歸測試用例集合優(yōu)化方法,其特征在于,步驟B中在單元測試過程中使用的測試用例,均以控制流圖節(jié)點(diǎn)標(biāo)號的形式將執(zhí)行路徑記錄于數(shù)據(jù)庫中;遍歷測試用例數(shù)據(jù)庫中的每個測試用例,若其執(zhí)行路徑的標(biāo)號序列中包含了修改點(diǎn)集合中任一修改點(diǎn)的標(biāo)號,則被選擇為回歸測試用例,加入到選擇測試用例集 Tselected 并執(zhí)行。
5.根據(jù)權(quán)利要求I所述的基于控制流圖的單元回歸測試用例集合優(yōu)化方法,其特征在于,步驟C中,從覆蓋率角度考慮為回歸測試添加新的測試用例;具體為首先,計(jì)算出修改點(diǎn)在控制流圖中的所有可達(dá)后繼節(jié)點(diǎn);然后,從此節(jié)點(diǎn)集合中選出在步驟B的運(yùn)行過程中沒有被覆蓋到的節(jié)點(diǎn),作為需要在回歸測試中被覆蓋的目標(biāo)節(jié)點(diǎn)集合見
6.根據(jù)權(quán)利要求I所述的基于控制流圖的單元回歸測試用例集合優(yōu)化方法,其特征在于,步驟E中,以節(jié)點(diǎn)集合#中的節(jié)點(diǎn)為覆蓋目標(biāo),進(jìn)行區(qū)間運(yùn)算,生成滿足覆蓋條件的測試用例,并運(yùn)行;同時,更新節(jié)點(diǎn)集合見從中刪除在本次運(yùn)行過程中已覆蓋到的節(jié)點(diǎn)。
7.根據(jù)權(quán)利要求I所述的基于控制流圖的單元回歸測試用例集合優(yōu)化方法,其特征在于,步驟F中,該回歸測試用例集合Tr由兩部分構(gòu)成選擇測試用例集和新增測試用例集合Tner,即
全文摘要
本發(fā)明公開了一種基于控制流圖的單元回歸測試用例集合優(yōu)化方法,包括A、在被測單元修改前后的控制流圖中找出被修改部分對應(yīng)的修改點(diǎn);B、篩選出執(zhí)行路徑經(jīng)過修改點(diǎn)的測試用例,作為回歸測試用例集合的一部分即選擇測試用例集Tselected,運(yùn)行集合中的所有測試用例;C、計(jì)算修改點(diǎn)的所有可達(dá)后繼節(jié)點(diǎn),選出步驟B運(yùn)行過程中未被覆蓋的節(jié)點(diǎn)子集N;D、若N為空,執(zhí)行步驟F,否則執(zhí)行步驟E;E、從N中取出一個節(jié)點(diǎn)作為覆蓋目標(biāo)生成測試用例,將其加入新增測試用例集合Tnew并運(yùn)行完畢,更新N,刪除在此次運(yùn)行中已被覆蓋的節(jié)點(diǎn),返回步驟D;F、回歸測試用例集合TR構(gòu)造完畢。應(yīng)用本發(fā)明,能夠提高回歸測試的效率,并保證回歸測試的有效性與充分性。
文檔編號G06F11/36GK102915271SQ201210426628
公開日2013年2月6日 申請日期2012年10月31日 優(yōu)先權(quán)日2012年10月31日
發(fā)明者宮云戰(zhàn), 王雅文, 黃俊飛, 金大海, 蔡敏 申請人:北京郵電大學(xué)