官术网_书友最值得收藏!

1.4 軟件測試與軟件開發(fā)

軟件開發(fā)與軟件測試都是軟件項目中非常重要的組成部分,軟件開發(fā)是生產(chǎn)制造軟件產(chǎn)品,軟件測試是檢驗軟件產(chǎn)品是否合格,兩者密切合作才能保證軟件產(chǎn)品的質(zhì)量。

1.4.1 軟件測試與軟件開發(fā)的關(guān)系

軟件中出現(xiàn)的問題并不一定都是由編碼引起的,軟件在編碼之前都會經(jīng)過問題定義、需求分析、軟件設(shè)計等階段,軟件中的問題也可能是前期階段引起的,如需求不清晰、軟件設(shè)計有紕漏等,因此在軟件項目的各個階段進行測試是非常有必要的。測試人員從軟件項目規(guī)劃開始就參與其中,了解整個項目的過程,及時查找軟件中存在的問題,改善軟件的質(zhì)量。軟件測試在項目各個階段的作用如下所示。

(1)項目規(guī)劃階段:負責從單元測試到系統(tǒng)測試的整個測試階段的監(jiān)控。

(2)需求分析階段:確定測試需求分析,即確定在項目中需要測試什么,同時制訂系統(tǒng)測試計劃。

(3)概要設(shè)計與詳細設(shè)計階段:制訂單元測試計劃和集成測試計劃。

(4)編碼階段:開發(fā)相應的測試代碼和測試腳本。

(5)測試階段:實施測試并提交相應的測試報告。

軟件測試貫穿軟件項目的整個過程,但它的實施過程與軟件開發(fā)并不相同。軟件開發(fā)是自頂向下、逐步細化的過程,軟件計劃階段定義軟件作用域,軟件需求分析階段建立軟件信息域、功能和性能需求等,軟件設(shè)計階段選定編程語言、設(shè)計模塊接口等;軟件測試與軟件開發(fā)過程相反,它是自底向上、逐步集成的過程,首先進行單元測試,排除模塊內(nèi)部邏輯與功能上的缺陷,然后按照軟件設(shè)計需求將模塊集成并進行集成測試,檢測子系統(tǒng)或系統(tǒng)結(jié)構(gòu)上的錯誤,最后運行完整的系統(tǒng),進行系統(tǒng)測試,檢驗其是否滿足軟件需求。

軟件測試與軟件開發(fā)的關(guān)系可用圖1-11表示,其中圖1-11(b)為圖1-11(a)的細化。

029-00

圖1-11 軟件測試與軟件開發(fā)的關(guān)系

1.4.2 常見的軟件測試模型

在軟件開發(fā)過程中,人們根據(jù)經(jīng)驗教訓并結(jié)合未來軟件的發(fā)展趨勢總結(jié)出了很多軟件開發(fā)模型,如瀑布模型、快速原型模型、迭代模型等,這些模型對軟件開發(fā)過程具有很好的指導作用,但遺憾的是它們對軟件測試并沒有給予足夠的重視,利用這些模型無法更好地指導軟件測試工作。

軟件測試是與軟件開發(fā)緊密相關(guān)的一系列有計劃的活動,是保證軟件質(zhì)量的重要手段,因此人們又相繼設(shè)計了很多軟件測試模型用于指導測試工作。軟件測試模型兼顧了軟件開發(fā)過程,對軟件開發(fā)和測試進行了很好的融合,它既明確了軟件開發(fā)與測試之間的關(guān)系,又使測試過程與開發(fā)過程產(chǎn)生交互,是測試工作的重要參考依據(jù)。

軟件測試模型對測試工作具有指導作用,對測試效果與質(zhì)量都有很大的影響,很多測試專家在實踐中不斷改進創(chuàng)新,創(chuàng)建了很多實用的軟件測試模型。下面介紹幾種比較重要的軟件測試模型。

1. V模型

V模型是由保羅·魯克(Paul Rook)在20世紀80年代提出的,它是軟件測試模型中最具有代表性的模型之一。V模型是瀑布模型的變種,在瀑布模型的后半部分添加了測試工作,如圖1-12所示。

030-01

圖1-12 V模型

V模型描述了基本的開發(fā)過程與測試行為,主要反映了測試活動分析與設(shè)計之間的關(guān)系。它非常明確地表明了測試過程所包含的不同級別,以及測試各階段與開發(fā)各階段所對應的關(guān)系。V模型的左邊是自上而下、逐步細化的開發(fā)過程,右邊是自下而上、逐步集成的過程,這也符合了軟件開發(fā)與軟件測試的關(guān)系。

V模型應用瀑布模型的思想將復雜的測試工作分成了目標明確的小階段來完成,具有階段性、順序性和依賴性,它既包含了對于源代碼的底層測試,也包含了對于軟件需求的高層測試。但是V模型也有一定的局限性,它只有在編碼之后才能開始測試,早期的需求分析等前期工作沒有涵蓋其中,因此它不能發(fā)現(xiàn)需求分析等早期的錯誤,這為后期的系統(tǒng)測試、驗收測試埋下了隱患。

2. W模型

W模型是由V模型演變而來的,它強調(diào)測試應伴隨整個軟件生命周期。其實W模型是一個雙V模型,軟件開發(fā)是一個V模型,而軟件測試是與開發(fā)同步進行的另一個V模型,如圖1-13所示。

030-02

圖1-13 W模型

W模型的測試范圍不僅包括程序,還包括需求分析、軟件設(shè)計等前期工作,這樣有利于盡早地全面發(fā)現(xiàn)問題。但是W模型也有自己的局限性,它將軟件開發(fā)過程分成需求、設(shè)計、編碼、集成等一系列的串行活動,無法支持迭代、自發(fā)性等需要變更調(diào)整的項目。

3. H模型

為了解決V模型與W模型存在的問題,有專家提出了H模型,H模型將測試活動完全獨立了出來,形成一個完全獨立的流程,這個流程將測試準備活動和測試執(zhí)行活動清晰地體現(xiàn)出來。測試流程和其他工作流程是并發(fā)執(zhí)行的,只要某一個工作流程的條件成熟就可以開始進行測試。例如在概要設(shè)計工作流程上完成一個測試,其過程如圖1-14所示。

031-02

圖1-14 H模型

圖1-14只是體現(xiàn)了軟件生命周期中概要設(shè)計層次上的一個測試“微循環(huán)”。在H模型中,測試級別不存在嚴格的次序關(guān)系,軟件生命周期的各階段的測試工作可以反復觸發(fā)、迭代,即不同的測試可以反復迭代地進行。在實際測試工作中,H模型并無太多指導意義,讀者重點是理解其中的設(shè)計意義。

4. X模型

X模型的設(shè)計原理是將程序分成多個片段反復迭代測試,然后將多個片段集成再進行迭代測試,如圖1-15所示。

031-01

圖1-15 X模型

X模型左邊描述的是針對單獨程序片段進行的相互分離的編碼和測試,多個程序片段進行頻繁的交接,在X模型的右上部分,將多個片段集成為一個可執(zhí)行的程序再進行測試。通過集成測試的產(chǎn)品可以進行更大規(guī)模的集成,也可以進行封裝提交給客戶。

在X模型的右下部分還定位了探索性測試,它能夠幫助有經(jīng)驗的測試人員發(fā)現(xiàn)更多測試計劃之外的軟件錯誤,但這對測試人員要求會高一些。

上面共介紹了4種軟件測試模型,在實際測試工作中,測試人員更多的是結(jié)合W模型與H模型進行工作,軟件各個方面的測試內(nèi)容是以W模型為準,而測試周期、測試計劃和進度是以H模型為指導。X模型更多是作為最終測試、熟練性測試的模板,例如對一個業(yè)務測試已經(jīng)有2年時間,則可以使用X模型進行模塊化的、探索性的方向測試。

主站蜘蛛池模板: 廉江市| 曲靖市| 虹口区| 治多县| 荆门市| 济阳县| 昂仁县| 临颍县| 三河市| 隆昌县| 都兰县| 峨山| 龙江县| 邵阳市| 盘锦市| 新宁县| 湟中县| 时尚| 嵊州市| 天等县| 萨嘎县| 金湖县| 威信县| 怀柔区| 石林| 昌吉市| 武威市| 溆浦县| 汕头市| 西充县| 新乡市| 信丰县| 武城县| 兴国县| 桐乡市| 景泰县| 兴山县| 洞头县| 南投县| 扶风县| 通许县|