




下載本文檔
版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、 單元測(cè)試碼重構(gòu)方法在安全相關(guān)軟件中的應(yīng)用 上官霞南蔣劍沈昕摘 要:結(jié)合目前軟件單元測(cè)試技術(shù)的研究現(xiàn)狀,本文對(duì)提高軟件單元測(cè)試質(zhì)量和效率的測(cè)試模式及方法進(jìn)行了深入的分析和研究,提出了包括如何命名單元測(cè)試用例以便交流出其測(cè)試意圖、如何更有效地進(jìn)行單元測(cè)試組件之間的依賴隔離及如何驗(yàn)證被測(cè)單元的間接輸出以提高代碼行為覆蓋率等測(cè)試碼重構(gòu)方法,并給出了相應(yīng)的技術(shù)措施和具體應(yīng)用。關(guān)鍵詞:模塊依賴;代碼行為覆蓋率;硬編碼測(cè)試替身;可配置的測(cè)試替身一、緒論軟件代碼行為的自動(dòng)驗(yàn)證是最近幾十年開(kāi)發(fā)方法方面最大的進(jìn)展之一,單元測(cè)試是軟件測(cè)試過(guò)程中最基本的測(cè)試,其能
2、夠盡早暴露大量軟件缺陷,降低軟件工程整體開(kāi)發(fā)成本,是前期測(cè)試中公認(rèn)的、最有效的保證軟件質(zhì)量的活動(dòng)之一。測(cè)試不光只能運(yùn)行,還需要對(duì)其進(jìn)行后期維護(hù)。然而目前很多公司級(jí)軟件測(cè)試項(xiàng)目中的測(cè)試壞味道包括模糊測(cè)試、緩慢測(cè)試、脆弱測(cè)試、甚至在產(chǎn)品代碼中包含測(cè)試邏輯等,1由此問(wèn)題導(dǎo)致的高維護(hù)成本表明如果缺少正確的方法,引入單元測(cè)試不一定能提高生產(chǎn)力,因此如何識(shí)別及排除這些壞味道并重構(gòu)測(cè)試,讓測(cè)試變得更易理解和維護(hù)、更健壯及可復(fù)用成為目前亟待解決的問(wèn)題。二、測(cè)試碼重構(gòu)方法本文我們將以嵌入式c語(yǔ)言為例,測(cè)試工具使用c+test,闡述下面提出的幾種測(cè)試碼重構(gòu)方法是如何在安全相關(guān)軟件的單元測(cè)試實(shí)踐中運(yùn)用的。(一)測(cè)試
3、用例命名應(yīng)該能交流出其測(cè)試的意圖一個(gè)好的用例名稱至少需要傳達(dá)以下幾方面信息,包含被測(cè)代碼函數(shù)/方法名、與被測(cè)代碼執(zhí)行相關(guān)的所有輸入值的重要特征及本用例預(yù)期輸出的抽象描述。這樣我們通過(guò)測(cè)試工具ide的用例瀏覽器中可以很清楚的看到每個(gè)用例測(cè)試的不同場(chǎng)景,達(dá)到良好交流其測(cè)試的意圖的目的,比較好的命名方案如下:test_其中:被測(cè)函數(shù)/方法的名稱;:被測(cè)試功能場(chǎng)景的描述;:被測(cè)試場(chǎng)景下的期望行為。(二)測(cè)試中應(yīng)盡可能設(shè)計(jì)可配置的測(cè)試替身,而不是硬編碼的測(cè)試替身測(cè)試替身是出于運(yùn)行測(cè)試這一明確目的而安裝代替實(shí)際組件的任何對(duì)象或組件,對(duì)依賴組件doc的調(diào)用通常返回某個(gè)值、更新其它參數(shù)或拋出異常。2硬編碼的測(cè)
4、試替身由測(cè)試人員將依賴組件每個(gè)用例的返回值直接編碼進(jìn)替身組件中,而可配置的測(cè)試替身它將返回值或異常在用例運(yùn)行時(shí)實(shí)時(shí)傳遞,這樣我們可以以更簡(jiǎn)單的方式控制被測(cè)代碼的間接輸入,并使測(cè)試核心邏輯在用例體可見(jiàn)從而避免出現(xiàn)“神秘訪客”,下面為可配置的測(cè)試替身的實(shí)現(xiàn)。statice_sysbool s_isreceived = e_false;/*可配置的測(cè)試替身 */void setreceivemsgdatastatus(e_sysbool inrecivestatus)s_isreceived = inrecivestatus;e_sysbool isreceivemsgdata(void)retru
5、n isreceived;(三)應(yīng)能驗(yàn)證被測(cè)代碼的間接輸出以減少未測(cè)試的代碼行為很多時(shí)候,被測(cè)代碼sut產(chǎn)生的行為在其自身組件中存儲(chǔ),通過(guò)直接訪問(wèn)組件狀態(tài)可以驗(yàn)證該行為,但是有時(shí)也會(huì)產(chǎn)生一些預(yù)期的副作用,比如有一個(gè)組件里有一個(gè)函數(shù),該函數(shù)什么也沒(méi)返回,或者至少?zèng)]有什么可以用來(lái)確定它是否正確實(shí)現(xiàn)了其功能,在這種情況下,我們別無(wú)選擇,只能從“后門(mén)測(cè)試”,通常程序?qū)τ涗浌收洗a的調(diào)用沒(méi)有返回表示正確完成的信息,確定其是否正常運(yùn)行的唯一方法是,通過(guò)其它某個(gè)接口(一個(gè)允許檢索故障類型的接口)與它交互。static uint32 s_faultcode = 0ul;/*一個(gè)允許檢索故障代碼的接口 */ui
6、nt32getfaultcode(void)return s_faultcode;/*記錄故障代碼接口實(shí)現(xiàn) */uint32recordfalutcode(uint32 infaultcode)s_faultcode = infaultcode;/*測(cè)試用例中驗(yàn)證了記錄故障代碼的行為 */voidtest_checklinkstatus_notreceivedcycleovermaxnum_linkfalut(void)/* pre-condition initialization */setreceivemsgdatastatus(e_false);s_commerrorcount =c_m
7、axcommerrornum;/* tested function call */e_sysbool islinknormal = checklinkstatus();uint32 vfaultcode = getfaultcode();/* post-condition check */cpptest_assert_equal(e_false,islinknormal);cpptest_assert_equal(c_commfalut,vfaultcode);三、結(jié)語(yǔ)本文選擇的幾種測(cè)試碼重構(gòu)方法經(jīng)公司lkj-15c安全認(rèn)證項(xiàng)目中應(yīng)用,證明其可以幫組開(kāi)發(fā)人員在進(jìn)行自動(dòng)化單元測(cè)試實(shí)踐時(shí)在幾種可選項(xiàng)之間做出正確的選擇,最終使我們?cè)O(shè)計(jì)的測(cè)試用例能夠達(dá)到幫助理解被測(cè)代碼、提高設(shè)計(jì)質(zhì)量及降低代碼缺陷引入風(fēng)險(xiǎn)等目標(biāo)。參考文獻(xiàn):1gerard meszaros.xunit test patterns:refactoring test code.addison-we
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 福建漳州三模數(shù)學(xué)試卷
- 廣東高分突破九年級(jí)數(shù)學(xué)試卷
- 肛腸術(shù)后護(hù)理課件
- 高三寫(xiě)不完的數(shù)學(xué)試卷
- 肋骨骨折護(hù)理
- 2024年09月湖北省農(nóng)村信用社聯(lián)合社網(wǎng)絡(luò)信息中心度招考35名勞務(wù)派遣科技專業(yè)人才筆試歷年參考題庫(kù)附帶答案詳解
- 2025至2030袋泡茶市場(chǎng)前景分析及發(fā)展趨勢(shì)分析與未來(lái)投資戰(zhàn)略咨詢研究報(bào)告
- 高血糖引起的并發(fā)癥的早期干預(yù)
- 2025至2030寵物袋運(yùn)動(dòng)衫行業(yè)市場(chǎng)深度研究與戰(zhàn)略咨詢分析報(bào)告
- 2024年山東煙臺(tái)干部學(xué)院招聘教師筆試真題
- 2025屆浙江省杭州濱江區(qū)六校聯(lián)考七年級(jí)英語(yǔ)第二學(xué)期期末質(zhì)量跟蹤監(jiān)視模擬試題含答案
- T/CACEM 39-2024交通企業(yè)標(biāo)準(zhǔn)化評(píng)價(jià)指南
- 車子刮擦協(xié)議書(shū)
- 2025春國(guó)開(kāi)《創(chuàng)業(yè)基礎(chǔ)》形考任務(wù)1-4答案
- 詩(shī)歌鑒賞|蘇軾《鶴嘆》注釋+賞析+試題
- 天航題庫(kù)理論SOP復(fù)習(xí)試題及答案
- 2024年質(zhì)量工程師備考常見(jiàn)問(wèn)答試題及答案
- 檢驗(yàn)檢測(cè)機(jī)構(gòu)質(zhì)量手冊(cè)程序文件質(zhì)量記錄合集(依據(jù)2023年版評(píng)審準(zhǔn)則)
- 2025-2030全球及中國(guó)管道運(yùn)輸服務(wù)行業(yè)市場(chǎng)現(xiàn)狀供需分析及投資評(píng)估規(guī)劃分析研究報(bào)告
- 安慶市桐城經(jīng)開(kāi)區(qū)建設(shè)投資集團(tuán)有限公司招聘筆試題庫(kù)2025
- JJF 2244-2025公共機(jī)構(gòu)重點(diǎn)用能單位能源資源計(jì)量審查規(guī)范
評(píng)論
0/150
提交評(píng)論