測試和開發(fā)的區(qū)別和關(guān)系是什么
說起軟件開發(fā)與測試,大概很多人都不清楚二者的關(guān)系和區(qū)別吧,今天小編就帶大家看看 軟件測試和軟件開發(fā)的區(qū)別,一起來學(xué)習(xí)!
軟件開發(fā)與軟件測試的區(qū)別
軟件測試主要是發(fā)現(xiàn)問題并查出BUG,發(fā)現(xiàn)軟件中的錯誤,再整理成資料。為軟件開發(fā)開發(fā)人員。軟件開發(fā)主要由開發(fā)人員負(fù)責(zé),編碼工作和一系列文檔,開發(fā)人員中也有很多種,像程序員、系統(tǒng)構(gòu)架師、項目經(jīng)理、系統(tǒng)分析師。他們職責(zé)也是不同的。軟件測試主要由測試人員負(fù)責(zé),查出軟件中的問題告訴開發(fā)人員他們進行修改。軟件開發(fā)是一個創(chuàng)造的過程。要構(gòu)造出一個新的軟件。 軟件測試是一個維護的過程。一般來說,新開發(fā)出一個新的軟件一定是有錯誤或漏洞的,需要經(jīng)過各種測試去發(fā)現(xiàn)問題、解決問題,直到完全沒有問題之后再進入下一個環(huán)節(jié)。故而 一般是先開發(fā)后測試。 軟件開發(fā)工程師需要會編寫代碼實現(xiàn)軟件功能, 軟件測試工程師則除了要知道如何開發(fā)軟件之外,還需要熟悉測試的方法和具備一些測試的能力,最好是能夠糾正錯誤。在薪水收入方面,軟件開發(fā)的跨度非常大,一般1000-4、5萬/月不等 軟件測試的薪資則相對穩(wěn)定,一般為2000-6000/月, 而職業(yè)年限上, 軟件開發(fā)一般為3-5年 ,軟件測試則有可能做到退休。
軟件開發(fā)和測試的關(guān)系
1、沒有軟件開發(fā)也就沒有測試,軟件開發(fā)為軟件測試提供對象。
2、軟件開發(fā)和軟件測試都作為軟件生命周期的重要組成部分
3、軟件開發(fā)和軟件測試都是軟件過程之中的重要活動。
4、軟件測試是保證軟件開發(fā)的產(chǎn)物質(zhì)量的重要手段。
軟件測試的介紹
軟件測試(英語:Software Testing),描述一種用來促進鑒定軟件的正確性、完整性、安全性和質(zhì)量的過程。換句話說,軟件測試是一種實際輸出與預(yù)期輸出間的審核或者比較過程。軟件測試的經(jīng)典定義是:在規(guī)定的條件下對程序進行操作,以發(fā)現(xiàn)程序錯誤,衡量軟件質(zhì)量,并對其是否能滿足設(shè)計要求進行評估的過程。
軟件測試發(fā)展史
軟件測試是伴隨著軟件的產(chǎn)生而產(chǎn)生的。早期的軟件開發(fā)過程中軟件規(guī)模都很小、復(fù)雜程度低,軟件開發(fā)的過程混亂無序、相當(dāng)隨意,測試的含義比較狹窄,開發(fā)人員將測試等同于“調(diào)試”,目的是糾正軟件中已經(jīng)知道的故障,常常由開發(fā)人員自己完成這部分的工作。對測試的投入極少,測試介入也晚,常常是等到形成代碼,產(chǎn)品已經(jīng)基本完成時才進行測試。到了上世紀(jì)80年代初期,軟件和IT行業(yè)進入了大發(fā)展,軟件趨向大型化、高復(fù)雜度,軟件的質(zhì)量越來越重要。這個時候,一些軟件測試的基礎(chǔ)理論和實用技術(shù)開始形成,并且人們開始為軟件開發(fā)設(shè)計了各種流程和管理方法,軟件開發(fā)的方式也逐漸由混亂無序的開發(fā)過程過渡到結(jié)構(gòu)化的開發(fā)過程,以結(jié)構(gòu)化分析與設(shè)計、結(jié)構(gòu)化評審、結(jié)構(gòu)化程序設(shè)計以及結(jié)構(gòu)化測試為特征。人們還將“質(zhì)量”的概念融入其中,軟件測試定義發(fā)生了改變,測試不單純是一個發(fā)現(xiàn)錯誤的過程,而且將測試作為軟件質(zhì)量保證(SQA)的主要職能,包含軟件質(zhì)量評價的內(nèi)容,Bill Hetzel在《軟件測試完全指南》(Complete Guide of Software Testing)一書中指出:“測試是以評價一個程序或者系統(tǒng)屬性為目標(biāo)的任何一種活動。測試是對軟件質(zhì)量的度量。”這個定義至今仍被引用。軟件開發(fā)人員和測試人員開始坐在一起探討軟件工程和測試問題。
軟件測試已有了行業(yè)標(biāo)準(zhǔn)(IEEE/ANSI ),1983年IEEE提出的軟件工程術(shù)語中給軟件測試下的定義是:“使用人工或自動的手段來運行或測定某個軟件系統(tǒng)的過程,其目的在于檢驗它是否滿足規(guī)定的需求或弄清預(yù)期結(jié)果與實際結(jié)果之間的差別”。這個定義明確指出:軟件測試的目的是為了檢驗軟件系統(tǒng)是否滿足需求。它再也不是一個一次性的,而且只是開發(fā)后期的活動,而是與整個開發(fā)流程融合成一體。軟件測試已成為一個專業(yè),需要運用專門的方法和手段,需要專門人才和專家來承擔(dān)。
進入上世紀(jì)90年代,軟件行業(yè)開始迅猛發(fā)展,軟件的規(guī)模變的非常大,在一些大型軟件開發(fā)過程中,測試活動需要花費大量的時間和成本,而當(dāng)時測試的手段幾乎完全都是手工測試,測試的效率非常低;并且隨著軟件復(fù)雜度的提高,出現(xiàn)了很多通過手工方式無法完成測試的情況,盡管在一些大型軟件的開發(fā)過程中,人們嘗試編寫了一些小程序來輔助測試,但是這還是不能滿足大多數(shù)軟件項目的統(tǒng)一需要。于是,很多測試實踐者開始嘗試開發(fā)商業(yè)的測試工具來支持測試,輔助測試人員完成某一類型或某一領(lǐng)域內(nèi)的測試工作,而測試工具逐漸盛行起來。人們普遍意識到,工具不僅僅是有用的,而且要對今天的軟件系統(tǒng)進行充分的測試,工具是必不可少的。測試工具可以進行部分的測試設(shè)計、實現(xiàn)、執(zhí)行和比較的工作。通過運用測試工具,可以達(dá)到提高測試效率的目的。測試工具的發(fā)展,大大提高了軟件測試的自動化程度,讓測試人員從繁瑣和重復(fù)的測試活動中解脫出來,專心從事有意義的測試設(shè)計等活動。采用自動比較技術(shù),還可以自動完成測試用例執(zhí)行結(jié)果的判斷,從而避免人工比對存在的疏漏問題。設(shè)計良好的自動化測試,在某些情況下可以實現(xiàn) “ 夜間測試 ” 和 “ 無人測試 ” 。在大多數(shù)情況下,軟件測試自動化可以減少開支,增加有限時間內(nèi)可執(zhí)行的測試,在執(zhí)行相同數(shù)量測試時節(jié)約測試時間。 而測試工具的選擇和推廣也越來越受到重視。在軟件測試工具平臺方面,商業(yè)化的軟件測試工具已經(jīng)很多,如捕獲/回放工具、Web測試工具、性能測試工具、測試管理工具、代碼測試工具等等,這些都有嚴(yán)格的版權(quán)限制且價格較為昂貴,但由于價格和版權(quán)的限制無法自由使用,當(dāng)然,一些軟件測試工具開發(fā)商對于某些測試工具提供了Beta測試版本以供用戶有限次數(shù)使用。幸運的是,在開放源碼社區(qū)中也出現(xiàn)了許多軟件測試工具,已得到廣泛應(yīng)用且相當(dāng)成熟和完善。
軟件開發(fā)的介紹
軟件開發(fā)是根據(jù)用戶要求建造出軟件系統(tǒng)或者系統(tǒng)中的軟件部分的過程。軟件開發(fā)是一項包括需求捕捉、需求分析、設(shè)計、實現(xiàn)和測試的系統(tǒng)工程。軟件一般是用某種程序設(shè)計語言來實現(xiàn)的。通常采用軟件開發(fā)工具可以進行開發(fā)。軟件分為系統(tǒng)軟件和應(yīng)用軟件,并不只是包括可以在計算機上運行的程序,與這些程序相關(guān)的文件一般也被認(rèn)為是軟件的一部分。 軟件設(shè)計思路和方法的一般過程,包括設(shè)計軟件的功能和實現(xiàn)的算法和方法、軟件的總體結(jié)構(gòu)設(shè)計和模塊設(shè)計、編程和調(diào)試、程序聯(lián)調(diào)和測試以及編寫、提交程序。
軟件開發(fā)階段劃分
計劃
對所要解決的問題進行總體定義,包括了解用戶的要求及現(xiàn)實環(huán)境,從技術(shù)、經(jīng)濟和社會因素等3個方面研究并論證本軟件項目的可行性,編寫可行性研究報告,探討解決問題的方案,并對可供使用的資源(如計算機硬件、系統(tǒng)軟件、人力等)成本,可取得的效益和開發(fā)進度作出估計,制訂完成開發(fā)任務(wù)的實施計劃。
分析
軟件需求分析就是對開發(fā)什么樣的軟件的一個系統(tǒng)的分析與設(shè)想。它是一個對用戶的需求進行去粗取精、去偽存真、正確理解,然后把它用軟件工程開發(fā)語言(形式功能規(guī)約,即需求規(guī)格說明書)表達(dá)出來的過程。本階段的基本任務(wù)是和用戶一起確定要解決的問題,建立軟件的邏輯模型,編寫需求規(guī)格說明書文檔并最終得到用戶的認(rèn)可。需求分析的主要方法有結(jié)構(gòu)化分析方法、數(shù)據(jù)流程圖和數(shù)據(jù)字典等方法。本階段的工作是根據(jù)需求說明書的要求,設(shè)計建立相應(yīng)的軟件系統(tǒng)的體系結(jié)構(gòu),并將整個系統(tǒng)分解成若干個子系統(tǒng)或模塊,定義子系統(tǒng)或模塊間的接口關(guān)系,對各子系統(tǒng)進行具體設(shè)計定義,編寫軟件概要設(shè)計和詳細(xì)設(shè)計說明書,數(shù)據(jù)庫或數(shù)據(jù)結(jié)構(gòu)設(shè)計說明書,組裝測試計劃。在任何軟件或系統(tǒng)開發(fā)的初始階段必須先完全掌握用戶需求,以期能將緊隨的系統(tǒng)開發(fā)過程中哪些功能應(yīng)該落實、采取何種規(guī)格以及設(shè)定哪些限制優(yōu)先加以定位。系統(tǒng)工程師最終將據(jù)此完成設(shè)計方案,在此基礎(chǔ)上對隨后的程序開發(fā)、系統(tǒng)功能和性能的描述及限制作出定義。
設(shè)計
軟件設(shè)計可以分為概要設(shè)計和詳細(xì)設(shè)計兩個階段。實際上軟件設(shè)計的主要任務(wù)就是將軟件分解成模塊是指能實現(xiàn)某個功能的數(shù)據(jù)和程序說明、可執(zhí)行程序的程序單元。可以是一個函數(shù)、過程、子程序、一段帶有程序說明的獨立的程序和數(shù)據(jù),也可以是可組合、可分解和可更換的功能單元。模塊,然后進行模塊設(shè)計。概要設(shè)計就是結(jié)構(gòu)設(shè)計,其主要目標(biāo)就是給出軟件的模塊結(jié)構(gòu),用軟件結(jié)構(gòu)圖表示。詳細(xì)設(shè)計的首要任務(wù)就是設(shè)計模塊的程序流程、算法和數(shù)據(jù)結(jié)構(gòu),次要任務(wù)就是設(shè)計數(shù)據(jù)庫,常用方法還是結(jié)構(gòu)化程序設(shè)計方法。
編碼
軟件編碼是指把軟件設(shè)計轉(zhuǎn)換成計算機可以接受的程序,即寫成以某一程序設(shè)計語言表示的“源程序清單”。充分了解軟件開發(fā)語言、工具的特性和編程風(fēng)格,有助于開發(fā)工具的選擇以及保證軟件產(chǎn)品的開發(fā)質(zhì)量。
當(dāng)前軟件開發(fā)中除在專用場合,已經(jīng)很少使用二十世紀(jì)80年代的高級語言了,取而代之的是面向?qū)ο蟮拈_發(fā)語言。而且面向?qū)ο蟮拈_發(fā)語言和開發(fā)環(huán)境大都合為一體,大大提高了開發(fā)的速度。
測試
軟件測試的目的是以較小的代價發(fā)現(xiàn)盡可能多的錯誤。要實現(xiàn)這個目標(biāo)的關(guān)鍵在于設(shè)計一套出色的測試用例(測試數(shù)據(jù)與功能和預(yù)期的輸出結(jié)果組成了測試用例)。如何才能設(shè)計出一套出色的測試用例,關(guān)鍵在于理解測試方法。不同的測試方法有不同的測試用例設(shè)計方法。兩種常用的測試方法是白盒法測試對象是源程序,依據(jù)的是程序內(nèi)部的的邏輯結(jié)構(gòu)來發(fā)現(xiàn)軟件的編程錯誤、結(jié)構(gòu)錯誤和數(shù)據(jù)錯誤。結(jié)構(gòu)錯誤包括邏輯、數(shù)據(jù)流、初始化等錯誤。用例設(shè)計的關(guān)鍵是以較少的用例覆蓋盡可能多的內(nèi)部程序邏輯結(jié)果。白盒法和黑盒法依據(jù)的是軟件的功能或軟件行為描述,發(fā)現(xiàn)軟件的接口、功能和結(jié)構(gòu)錯誤。其中接口錯誤包括內(nèi)部/外部接口、資源管理、集成化以及系統(tǒng)錯誤。黑盒法用例設(shè)計的關(guān)鍵同樣也是以較少的用例覆蓋模塊輸出和輸入接口。
維護
維護是指在已完成對軟件的研制(分析、設(shè)計、編碼和測試)工作并交付使用以后,對軟件產(chǎn)品所進行的一些軟件工程的活動。即根據(jù)軟件運行的情況,對軟件進行適當(dāng)修改,以適應(yīng)新的要求,以及糾正運行中發(fā)現(xiàn)的錯誤。編寫軟件問題報告、軟件修改報告。
一個中等規(guī)模的軟件,如果研制階段需要一年至二年的時間,在它投入使用以后,其運行或工作時間可能持續(xù)五年至十年。那么它的維護階段也是運行的這五年至十年期間。在這段時間,人們幾乎需要著手解決研制階段所遇到的各種問題,同時還要解決某些維護工作本身特有的問題。做好軟件維護工作,不僅能排除障礙,使軟件能正常工作,而且還可以使它擴展功能,提高性能,為用戶帶來明顯的經(jīng)濟效益。然而遺憾的是,對軟件維護工作的重視往往遠(yuǎn)不如對軟件研制工作的重視。而事實上,和軟件研制工作相比,軟件維護的工作量和成本都要大得多。
在實際開發(fā)過程中,軟件開發(fā)并不是從第一步進行到最后一步,而是在任何階段,在進入下一階段前一般都有一步或幾步的回溯。在測試過程中的問題可能要求修改設(shè)計,用戶可能會提出一些需要來修改需求說明書等。
猜你感興趣:
4.測試人員面試題