Hi:歡迎來到中國論文網     

所有論文科目分類

中國論文網 > 免費論文 > 理工論文 > 航天工程 >

測試驅動開發技術在航天領域的應用實踐分析

作者:2017-06-17 16:43文章來源:未知
  測試驅動開發技術作為軟件敏捷開發中的一個重要組成部分,在軟件開發實踐中得到了廣泛的應用。本質上,測試驅動開發技術是一種軟件開發技術,而不是一種軟件測試技術,它的作用在于通過測試來驅動開發,以提高軟件的高內聚、低耦合程度,改善軟件設計質量,減少軟件代碼中的缺陷率,提高軟件開發的效率,提升軟件產品的質量。
  測試驅動開發技術相對于傳統的軟件開發流程,是一種開發思維上的轉變。它是一種基于目標驅動的軟件開發思想,與傳統的先編寫代碼再進行調試的開發流程不同,強調在編寫產品代碼之前先思考作為用戶該如何去使用這個功能,先確定如何去用這個目標,并通過測試代碼使目標明確可運行,之后再去思考如何實現這個功能,需要開發人員在用戶與功能開發者之間不斷進行角色切換,多角度思考。先編寫測試代碼,再編寫產品代碼,用測試來驅動開發。
  測試驅動開發技術是隨著敏捷開發技術不斷發展應用起來的,敏捷開發除了測試驅動之外,還包括用戶故事、結對編程、持續集成等要素。本文不針對測試驅動開發在敏捷開發中的實踐,而是將測試驅動開發技術應用于傳統的軟件開發,與傳統的領域開發流程相結合,介紹測試驅動開發技術在領域應用中的實踐。
  1 測試驅動開發
  本節介紹測試驅動開發的概念及測試驅動開發所起到的作用。
  1.1 測試驅動開發概念
  測試驅動開發技術是由Kent Beck于20世紀90年代提出并不斷發展起來的,基本方法是編寫所有產品代碼的目的都是為了使失敗的測試能夠通過。首先編寫一個測試,由于它要運行的功能還不存在,所以它會運行失敗。然后,編寫產品代碼使測試通過。作為結果,一個非常完整的測試用例集就和產品代碼一起發展起來。軟件重構、領域驅動設計、敏捷軟件開發與實踐等技術或實踐均將測試驅動開發作為一個必要條件和實踐原則,它們的一個共同特點是均采用迭代開發思想,在開發過程中不斷對已有產品進行精化和完善。軟件重構關注改善既有代碼的設計,從代碼層面不斷對軟件進行優化,使代碼結構更合理、擴展性更好,可理解性更強。領域驅動設計關注領域模型與代碼實現的綁定,強調軟件各個部分的設計應忠實地反映領域模型,與模型相對應,在開發過程中通過不斷的重構與精煉去獲得和實現深層次的領域模型。敏捷軟件開發與實踐將測試驅動開發作為一個基礎實踐,與其他實踐結合形成一個完整的迭代開發流程。
  1.2 設計作用
  測試驅動開發要求在編寫產品代碼之前先編寫測試,開發人員首先必須站在產品代碼使用者的角度去思考應該怎么去使用這個功能,這個功能應該提供哪些接口供測試代碼來訪問,這種思考方式會促使開發人員先從接口的角度考慮功能模塊的設計,促進功能模塊的接口設計的正確性與合理性,同時會激發開發人員去解除各個功能模塊之間的耦合,這樣才能夠對各功能模塊進行獨立的測試,形成高內聚、低耦合的軟件設計與實現。從一定程度上說,編程就是設計,測試驅動開發可以實現更好的設計。
  1.3 文檔作用
  測試驅動開發的第二個作用是提供精確的功能模塊使用說明文檔。隨著測試驅動開發過程的不斷進行,會建立起一套非常完整的測試用例集,該用例集精確的描述了各個功能模塊的使用方法,功能模塊的使用者通過測試用例可以準確的查看功能模塊的接口及其使用方法,明確功能模塊需要的前置條件及執行結果的后置條件,更好的理解模塊的功能和作用。從一定程度上說,源代碼就是文檔,測試代碼可以提供更準確、可驗證的模塊使用說明文檔。
  1.4 測試作用
  測試驅動開發的第三個作用是測試,測試集是隨著開發過程不斷建立起來的,且均是先編寫測試代碼,后編寫產品代碼,通過這套完整的可運行的測試用例集,可以隨時對產品代碼運行測試用例,對開發過程中運行的所有測試實現可重復的自動化的運行,因此從開發人員角度考慮,可以認為產品代碼的正確性與測試用例是否全部通過是等價的。同時開發人員工作是否完成的標志從編譯是否正確變成了測試用例是否全部通過。
  1.5 基礎設施作用
  一個優秀的軟件架構和軟件產品的產生,需要結合應用領域不斷的進行實踐、重構、優化,包括代碼級別的重構、設計模式級別的重構、領域模型的重構及軟件架構的重構。對一個軟件架構或產品不斷進行不同級別的各種重構,勢必會對已經可以正常工作的軟件代碼造成很大的影響,引入各種各樣的軟件Bug,這也是很多開發人員不愿意或沒有勇氣對已有軟件進行重構或調整的原因。而測試驅動開發技術可以很好的解決這個問題,將測試驅動開發產生的測試代碼作為軟件產品開發的一個重要組成部分與基礎設施,一定程度上,軟件的正確性與測試是否全部通過是等價的。在重構的過程中不斷進行測試,如果因重構引出問題,測試結果會立刻顯示出來,由于每一步的重構動作都是很小的一步,且剛剛進行過修改,印象深刻,結合有問題的測試用例,可以很快地定位問題的原因,確保在不影響軟件正確性的前提下,軟件的各類重構能夠有序進行。
  2 航天領域應用實踐
  航天領域作為一個高風險的行業,對應用軟件的正確性與可靠性提出了更高的要求,要既能滿足航天工程所需的軟件需求及其變更,又要確保軟件的正確性與可靠性。測試驅動開發技術作為軟件開發活動中的一個優秀實踐,可有效提高航天領域軟件產品的正確性與可靠性。
  2.1 工程實踐
  測試驅動開發的工程實踐包括學習測試框架、搭建測試環境、實施測試驅動開發等步驟。測試驅動開發的實踐原則是非常簡單的,重要的是開發人員要從思想上接受這種模式并通過不斷的訓練,使測試驅動開發技術真正融入到日常的軟件開發活動中。
  2.2 學習測試框架
  要應用測試驅動開發技術,首先必須學習一些常用的測試框架及測試的方法。目前C++、Java、C#等主流的程序開發語言都有優秀且開源的測試框架,如xUnit系列測試框架支持Java、C#、C++等語言的測試,GTest是一個支持C++語言的跨平臺的測試框架,提供了支持測試的各項功能。另外,還需要學習對測試框架的初始化、測試用例的建立與退出、支持各種數據類型的聲明和斷言。當然,測試框架也不是必須的,在沒有可直接使用的測試框架的條件下,自己也可以開發一個簡單測試環境,重要的還是測試驅動開發的思想。
  2.3 搭建測試環境
  原則上,測試代碼一般作為一個獨立的可運行的測試項目,與產品代碼所在項目保持獨立。在真正的產品代碼開發之前,先把測試項目運行起來,然后通過編寫測試驅動產品代碼的編寫。測試代碼項目隨著產品代碼項目不斷發展,形成一套完整的測試集。
  2.4 實施測試驅動開發
  測試驅動開發的基本的實施步驟是,首先編寫一個測試,由于它要運行的功能還不存在,所以它會運行失敗。然后,編寫產品代碼使測試通過。每次編寫的產品代碼只需要確保測試能夠通過。在切換到測試代碼的編寫,重復此過程。一般測試代碼與產品代碼的切換非???,通過“編寫測試代碼→運行測試失敗→編寫產品代碼→運行測試成功→重構”的循環模式,推進軟件產品的開發過程。
  2.5 訓練方式
  要將測試驅動開發技術真正應用于開發實踐,使其成為軟件開發人員開發思想的一個必不可少的組成部分,需要進行有效的訓練和刻意的練習,整個過程可分為三個階段:第一階段,強迫自己先寫測試代碼,再寫產品代碼;第二階段,在實踐中應用,有時可能會無意識地轉換回傳統的軟件開發流程,直接去編寫產品代碼,在開發過程中,當意識到這段產品代碼還沒有編寫測試時,應馬上停下來,補充相應的測試代碼,有意識的不斷訓練;第三階段,會自覺的先編寫測試代碼,再編寫產品代碼,如果某一時刻直接去編寫產品代碼,自己會覺得很不舒服,感覺缺少了什么東西或對什么事情不放心,會立刻意識到應該去編寫測試代碼。到該階段,測試驅動開發的思想會真正融入到開發人員的開發思維中,形成一種自覺的開發行為模式。
  2.6 效率問題
  剛開始接觸測試驅動開發的人員都會有編寫測試會不會降低開發效率的問題。傳統的軟件開發模式中,編碼與調試所耗費開發人員時間的比例一般為1∶3,調試會占用開發人員大量的時間,耗費開發人員的精力。測試驅動開發技術會徹底改變這種傳統的工作模式,通過不斷編寫測試用例、頻繁的運行測試,幾乎不再需要進行軟件調試的工作,即使需要調試,也會很快定位并解決問題,因此測試驅動開發會很大地提高軟件開發的效率。
  3 結語
  本文介紹了將測試驅動開發技術應用于傳統的軟件開發流程,并詳細介紹了測試驅動開發在航天工程領域的應用實踐,應用結果表明,測試驅動開發可以有效提高航天軟件的開發效率,確保軟件的正確性與可靠性,提升軟件質量,促進航天軟件的產品化。
 

最近相關

中國論文網

最新更新

熱門推薦

[水利工程]探討水利工程施工管理特點及創新
隨著科學技術的不斷發展,我國工農業生產得到了進一步的發展,因此對水利工程項目也提出更高的要求,不僅要求其能夠有...[全文]
[美術攝影]淺談設計美
藝術設計是一種審美性的設計,是藝術與技術相結合服務于現實生活的手段,實用性與審美性是其重要的兩個特征。設計美學...[全文]
[音樂舞蹈]談武術與舞蹈共同發展之路
自古以來就有舞蹈與武術同源近根的說法,但是至今為止,由于關于武術與舞蹈起源的問題一直缺乏可以證實的材料,眾多學者也...[全文]
[近現代史]十八屆六中全會公報在我市廣大黨員干部中引起強烈響應
10 月24 日至27 日,黨的十八屆六中全會在北京舉行,全會審議通過《關于新形勢下黨內政治生活的若干準則》(以下簡稱《準...[全文]
[文學理論]淺析民間美術造型元素的現代審美
我國民間美術的發展歷程已經延續了數千年之久,民間美術屬于民間傳統文化的重要構成部分之一,并備受社會各界的廣泛支...[全文]
[文學理論]淺析普通高校公共藝術教育的課程體系研究
一、引言 公共藝術課程是為培養社會主義現代化建設所需要的高素質人才而設立的限定性選修課程,對于提高審美素養、培...[全文]
[文學理論]淺析應用型人才培養模式下的文學理論類課程教改探索
近年來,以二、三本院校為主的應用型本科教育普遍重視實踐教學,強化應用型人才培養,將實踐教學作為培養學生實踐能力...[全文]
[文學理論]淺析散文翻譯中的美學問題
散文的定義可從廣義和狹義兩方面來說,廣義上講,散文是一種與詩歌相對的文學體裁 ;從狹義上來說,是一種與詩歌、小說...[全文]
[文學理論]淺析色彩心理應用對品牌建設的重要性
0 前言 對于 CI 設計,有些人還不熟悉,事實上CI對企業品牌的塑造起到積極的推動作用。CI作為企業形象戰略,有其不可低估...[全文]
[文學理論]淺析色彩藝術的心理效應研究
色彩在藝術家的手中,不僅是單純的描繪與填充工具,而是表達藝術家內心世界的重要表現形式。這種心理的表達描述著人們...[全文]
[文學理論]邊緣文化身份下的杜拉斯自傳體小說研究
摘要 作為法國最具有爭議的女作家瑪格麗特杜拉斯,無法歸類是杜拉斯最為明亮的一個標簽,這一標簽閃現出了杜拉斯的邊...[全文]
[文學理論]淺析少數民族宗教藝術的社會美育系統
一、 少數民族宗教藝術的美學表現 (一) 少數民族宗教建筑的美學形式少數民族宗教建筑藝術的美學表現指宗教建筑的形體視...[全文]

熱門標簽

成上人色爱