當(dāng)前位置:首頁 > 嵌入式 > 嵌入式軟件
[導(dǎo)讀] 在簡要介紹軟件魯棒性基準(zhǔn)程序測試方法的基礎(chǔ)上,以Linux操作系統(tǒng)內(nèi)核函數(shù)為例,通過對用于分析測試結(jié)果的維度模型進(jìn)行分析,提出了軟件魯棒性的關(guān)聯(lián)測試方法,并給出了相應(yīng)的測試實(shí)例及測試結(jié)果,為Linux操作系統(tǒng)內(nèi)核函數(shù)魯棒性測試提供了更為直觀、有效的方法。

軟件(或軟件構(gòu)件)魯棒性是衡量軟件在異常輸入和應(yīng)力環(huán)境條件下保持正常工作能力的一種度量。魯棒性測試主要用于測試操作系統(tǒng)、應(yīng)用程序、COTS軟件、構(gòu)件及服務(wù)協(xié)議等軟件和協(xié)議的可靠性及健壯性。在操作系統(tǒng)和安全關(guān)鍵軟件等一些重要軟件的測試上尤為重要。對于系統(tǒng)魯棒性的評價(jià)一般有基于測量的方法和基于故障注入的方法,近年來提出了魯棒性基準(zhǔn)程序方法(Robustness Benchmarking)[1]。魯棒性基準(zhǔn)程序(Robustness Benchmark)由一組健壯性測試用例組成。

實(shí)施軟件魯棒性測試的目的是發(fā)現(xiàn)所測代碼的健壯性薄弱環(huán)節(jié),并予以消除或增強(qiáng)抵抗異常情況的能力。增強(qiáng)代碼健壯性的過程包括:(1)確定軟件的激發(fā)健壯性失效的異常值參數(shù),并進(jìn)行測試;(2)分析測試結(jié)果,找出失效原因;(3)寫保護(hù)代碼屏蔽導(dǎo)致失效的異常值;(4)把保護(hù)代碼與軟件模塊相連接[3]。

1 Linux內(nèi)核函數(shù)測試

Linux操作系統(tǒng)體系結(jié)構(gòu)從底層到頂部的順序依次是:內(nèi)核(包含內(nèi)核函數(shù))、系統(tǒng)調(diào)用、內(nèi)建程序(操作系統(tǒng)的命令)。內(nèi)核函數(shù)是內(nèi)核代碼的組成部分,其調(diào)用程序直接運(yùn)行在內(nèi)核空間。內(nèi)核函數(shù)一旦出現(xiàn)異常,將立刻對整個(gè)操作系統(tǒng)產(chǎn)生影響。系統(tǒng)調(diào)用一般對內(nèi)核函數(shù)進(jìn)行封裝,以此作為內(nèi)核與用戶空間的接口。當(dāng)用戶程序使用系統(tǒng)調(diào)用時(shí)會(huì)轉(zhuǎn)到內(nèi)核空間,調(diào)用結(jié)束后又會(huì)返回用戶空間。內(nèi)核函數(shù)的測試結(jié)果一般分類為:函數(shù)錯(cuò)誤碼返回、異常、內(nèi)核掛起、工作負(fù)載夭折、工作負(fù)載結(jié)果不正確、工作負(fù)載完成[1]。

Linux內(nèi)核函數(shù)魯棒性測試的最終目的是要提高系統(tǒng)的健壯性,需要根據(jù)測試結(jié)果生成相應(yīng)的保護(hù)代碼。這方面的研究目前處于初期階段。

2 魯棒性維度分析

典型的魯棒性測試包括模塊化基準(zhǔn)測試和層次化測試兩種主要方法。模塊化基準(zhǔn)測試是對一個(gè)系統(tǒng)進(jìn)行分離測試。它把一個(gè)獨(dú)立的系統(tǒng)看作是一系列組件的集合,如文件系統(tǒng)、內(nèi)存系統(tǒng)、外部交互系統(tǒng)、鎖機(jī)制和多道程序運(yùn)作等,另外還通過一個(gè)監(jiān)視器程序來監(jiān)視和收集測試的結(jié)果。而層次化測試是通過定義一個(gè)清晰的交互層,使測試和對各種模塊進(jìn)行測試的執(zhí)行細(xì)節(jié)相分離。一些測試可以適用于所有模塊,而另一些可能只適合一個(gè)模塊子集。使用層次性結(jié)構(gòu)是分解系統(tǒng)的好方法。通過層次化來對操作系統(tǒng)進(jìn)行測試可以收到較好的效果[2]。

無論采用模塊化基準(zhǔn)測試還是層次化方法,最終都是對操作系統(tǒng)接口函數(shù)采用參數(shù)的組合測試。對魯棒性測試結(jié)果進(jìn)行分析的一種方法是使用維度(Dimensionality)模型。維度有兩種定義:(1)參數(shù)維度,它指的是模塊中參數(shù)的個(gè)數(shù),對于一個(gè)軟件模塊而言,參數(shù)維度被定義為其變量的個(gè)數(shù);(2)魯棒性失效維度,對于引起魯棒性失效的一組特殊參數(shù),那些確實(shí)引起失效的參數(shù)的個(gè)數(shù)被定義為魯棒性失效維數(shù)。

2.1 維度失效

維度失效分一維失效和多維失效。多維失效的參數(shù)一定都是符合條件的系統(tǒng)能夠識別的值。一維失效和多維失效所引發(fā)的原因不同,一維失效是參數(shù)非法,多維失效是參數(shù)組合非法(每個(gè)參數(shù)都是合法的)。當(dāng)一維失效用例被保護(hù)和屏蔽后,會(huì)不會(huì)跳轉(zhuǎn)為多維失效,關(guān)鍵是看其參數(shù)是否構(gòu)成組合關(guān)系。從對其參數(shù)的組合關(guān)系的判定上,可以判斷該失效用例是真維失效用例還是變維失效用例[3]。

基于低維度優(yōu)先的維度模型中失效維度不可能超過參數(shù)維度??赡軐儆谝痪S失效的某個(gè)失效,同時(shí)也可能屬于高維失效。對于這種情況,一般把這個(gè)失效作為低維失效來對待。同時(shí)激發(fā)軟件魯棒性失效所需考慮的最少因素取決于魯棒性失效維數(shù),當(dāng)參數(shù)維度為失效維度時(shí),測試結(jié)果的觀察最為直觀;當(dāng)參數(shù)維度大于失效維度,測試結(jié)果的觀察就不太直觀了。失效維度也可以通過觀察魯棒性測試的響應(yīng)模式得到。

2.2 失效狀態(tài)分析

維度失效狀態(tài)分為三類。(1)真維失效指狀態(tài)失效條件被屏蔽后,測試用例跳轉(zhuǎn)到正常狀態(tài);(2)同維失效指狀態(tài)失效條件被屏蔽后,失效維度保持不變;(3)變維失效指相同條件下產(chǎn)生失效維度升高。由于基于低維度優(yōu)先原則,所以由高維度向低維度的失效躍遷跳變不可能發(fā)生[3]。魯棒性測試用例的失效維度狀態(tài)轉(zhuǎn)變?nèi)鐖D1所示。


現(xiàn)以Linux系統(tǒng)函數(shù)read(fd, buf,count)為實(shí)例進(jìn)行分析,說明上述不同失效維度之間的轉(zhuǎn)變問題。函數(shù)的三個(gè)參數(shù)取值如表1所示。

假設(shè)當(dāng)參數(shù)fd取值errno file,buf取值 Null時(shí),均會(huì)產(chǎn)生一維失效。當(dāng)fd取合法的值,并且buf分配空間小于count時(shí)產(chǎn)生一個(gè)二維失效。此時(shí),對參數(shù)fd取值empty file進(jìn)行保護(hù)屏蔽,則一些測試用例將會(huì)通過測試,如read(empty file,8,1);而另一些用例則維持一維失效不變,如read(empty file,Null,1024);還有一些用例將轉(zhuǎn)化為多維(維度≥2)失效,如read(empty file,1,8)。

3 魯棒性關(guān)聯(lián)測試

當(dāng)參數(shù)維度等于失效維度時(shí),很容易看出是哪些參數(shù)失效。而測試時(shí)維度的跳變,會(huì)給魯棒性測試的分析帶來困難,會(huì)影響測試覆蓋率的問題,還牽扯到測試用例的增加[4]。在魯棒性測試中可以利用參數(shù)的關(guān)聯(lián)性進(jìn)行測試。將傳統(tǒng)的組合測試法分為兩步:關(guān)聯(lián)性測試和非關(guān)聯(lián)性測試。魯棒性關(guān)聯(lián)測試的流程如圖2所示。

在進(jìn)行魯棒性關(guān)聯(lián)測試時(shí),首先進(jìn)行參數(shù)關(guān)聯(lián)性測試,先把待測函數(shù)中有互相作用的參數(shù)進(jìn)行包裝,在測試中人為構(gòu)造參數(shù)維度等于失效維度的情況。例如,函數(shù)f(A,B,C,D,E)中,參數(shù)A、B、C有關(guān)聯(lián)。首先將參數(shù)E和參數(shù)F取合法輸入值,然后測試參數(shù)A、B、C的所有組合。若有失效,必定是一維失效或者三維失效。由于參數(shù)維度等于失效維度,通過分析測試結(jié)果就可以寫出保護(hù)代碼。在對函數(shù)進(jìn)行了充分的關(guān)聯(lián)測試后,再進(jìn)行參數(shù)非關(guān)聯(lián)性測試。取出上例中參數(shù)A、B、C的一個(gè)合法組合,對參數(shù)E和參數(shù)F的所有用例分別進(jìn)行測試。若有失效,必定是一維失效,這樣也很容易分析測試結(jié)果和寫出保護(hù)代碼。

通過對函數(shù)的參數(shù)關(guān)聯(lián)性進(jìn)行測試可得出結(jié)論,只有當(dāng)函數(shù)所有參數(shù)都發(fā)生關(guān)聯(lián)作用時(shí),魯棒性關(guān)聯(lián)測試所需用例的個(gè)數(shù)才會(huì)等于傳統(tǒng)組合測試所需的用例個(gè)數(shù)[5]。所以,在覆蓋率不變的情況下,若采用魯棒性關(guān)聯(lián)測試法,可以有效減少測試用例個(gè)數(shù),并且還能夠消除維度失效跳變帶來的影響。

4 測試實(shí)例

實(shí)際測試中測試環(huán)境為DELL的DIMENSION 4700,操作系統(tǒng)為Redhat Linux 8.0,系統(tǒng)內(nèi)核為2.2.24。實(shí)測以read()函數(shù)參數(shù)組合表為例,其表中組合測試用例的個(gè)數(shù)為5×5×5=125個(gè)。進(jìn)行關(guān)聯(lián)測試時(shí)先對其參數(shù)的關(guān)聯(lián)性進(jìn)行分析,通過分析可以得知它的三個(gè)參數(shù)中只有buf和count有關(guān)聯(lián)。

實(shí)測中首先進(jìn)行關(guān)聯(lián)性測試,對read()函數(shù)的參數(shù)fd取正常值,測試參數(shù)buf和count的所有組合,測試結(jié)果如表2所示。共使用了25個(gè)測試用例。

在對上述測試結(jié)果進(jìn)行屏蔽失效后,轉(zhuǎn)入第二步,對參數(shù)fd進(jìn)行非關(guān)聯(lián)性測試,即針對fd與(buf+count)的組合進(jìn)行測試。對buf與count的組合取合法值后,針對參數(shù)fd的所有取值分別測試,這時(shí)只會(huì)發(fā)生一維失效,測試用例個(gè)數(shù)是5個(gè),其結(jié)果如表3所示。

由上述測試實(shí)例可見,傳統(tǒng)組合測試法需要125個(gè)用例,而關(guān)聯(lián)測試只需要30個(gè)用例,兩者最終完成的函數(shù)測試覆蓋率相同。由此可見,關(guān)聯(lián)測試是對傳統(tǒng)的組合測試的一種有效改進(jìn)。傳統(tǒng)的參數(shù)組合測試忽略了參數(shù)之間的關(guān)系,結(jié)果導(dǎo)致測試用例大量增加,覆蓋率卻有可能降低,同時(shí)還由于產(chǎn)生了維度跳轉(zhuǎn)而給測試增加了困難[6]。采用關(guān)聯(lián)測試可以避免上述問題的產(chǎn)生。使用關(guān)聯(lián)測試時(shí)對參數(shù)之間關(guān)系進(jìn)行分析,還有可能發(fā)現(xiàn)傳統(tǒng)的組合測試沒有測到的失效用例,這樣關(guān)聯(lián)測試的覆蓋率相對于傳統(tǒng)組合測試來說,只會(huì)提高而不會(huì)降低,這對于Linux內(nèi)核函數(shù)的魯棒性提升十分有效。

理論分析和實(shí)例應(yīng)用的結(jié)果表明,在Linux內(nèi)核函數(shù)的魯棒性測試中采用關(guān)聯(lián)測試來代替?zhèn)鹘y(tǒng)的組合測試,可以在保證測試覆蓋率的同時(shí),使所需的測試用例大大減少,而且函數(shù)中相關(guān)聯(lián)的參數(shù)個(gè)數(shù)越少優(yōu)勢越明顯。現(xiàn)實(shí)中Linux內(nèi)核函數(shù)的參數(shù)之間關(guān)聯(lián)性較少,因此在其魯棒性測試中關(guān)聯(lián)測試方法具有很好的實(shí)際應(yīng)用價(jià)值。

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運(yùn)營商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡稱"軟通動(dòng)力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉