查看全部128種考試
軟件水平考試
 考試動態(tài) 報考指南 歷年真題 模擬試題 復習資料 心得技巧 專業(yè)英語 技術文章 軟考論壇 考試用書
 程序員 軟件設計師 網絡管理員 網絡工程師 系統(tǒng)分析師 數據庫系統(tǒng)工程師
1
2
3
4
5
6
7
8
9
10
yanruijie  
【字體: 從企業(yè)的運行價值鏈說起——我眼中的測試驅動開發(fā)(TDD)
從企業(yè)的運行價值鏈說起——我眼中的測試驅動開發(fā)(TDD)
spks.exam8.com 來源:考試吧(Exam8.com) 更新:2007-1-25 18:11:29 軟件水平考試 考試論壇

  二、通過TDD進行重構)

  “發(fā)現價值”的過程遠遠沒有結束。通過測試代碼,我們從客戶的角度來考慮,會發(fā)現一些問題。在已經實現的代碼中,SmartAssistor類型實現了Search,Store和List的功能。但這些職責是否真的應該由它承擔呢?表面上來看,是這樣的。然而根據OO的思想來看,這個SmartAssistor所承擔的責任是否太多了?它和搜索的結果、顯示的方式耦合度是否太緊密了?這個設計將實現抽象出來了嗎?這些都應該是我們考慮的重點。考慮的時機,可以是設計之初,也可以是重構之時。

  在重構的時候,仍然不能放棄TDD,只有它才能保證程序的可靠性,重構的正確性。開始重構吧。

  首先從行為來考慮。搜索的功能會很復雜嗎?可能會有精確搜索,模糊搜索;可能是在網上搜索,也可能是本機搜索。那么,存儲的功能呢?IO的操作是否頻繁,存儲的要求是否會根據安全級別而逐步升級?再考慮顯示,對于個人智能助理來講,顯示的方式需要多樣化嗎?顯然,以上的行為都是復雜的。

  再從抽象性考慮。需要把這些行為抽象出來嗎?也就是說,這些行為的載體是否會有多種類型?顯然,搜索可能會是文件的搜索,可能會是文本的搜索,也可能會是數據庫的搜索;存儲的格式也會有多種多樣,文本文件,xml文件,數據庫文件。顯示的方式可能會通過瀏覽器顯示,也可能會在WinForm中顯示。也許用戶要求是帶滾動條的文本框,也許只是簡單的文本顯示。對象的形式很多吧,需要抽象嗎?顯然是的!

  這樣考慮之后,我發(fā)覺需要重構的東西太多了,應該怎么入手?首先,我們把SmartAssistor的職責先剝離出來,用更單一的對象來完成各自的功能。然后,分別將這些對象提煉出各自的接口。還是先寫測試代碼吧,考慮搜索功能,首先需要將對象分離出來:
  [Test]
    public void TestSearching()
      {
         SearchEngine engine = new SearchEngine();
         Assert.IsNotNull(engine);
 
          SearchResult result1 = new SearchResult();
          SearchResult result2 = new SearchResult();
          Assert.IsNotNull(result1);
          Assert.IsNotNull(result2);
          result1 = engine.ExactSearch(control.Categaries);
          result2 = engine.BlurSearch(control.Categaries);

          SearchResult tempResult1 = new SearchResult(control.Categaries,”contents”); 
          SearchResult tempResult2 = new SearchResult(control.Categaries,”more contents”); 
 
          Assert.AreEqual(tempResult1,result1);
          Assert.AreEqual(tempResult2,result2);

       }
  在NUnit中運行測試代碼,未能通過。然后在程序中創(chuàng)建SearchEngine類型,并實現ExactSearch和BlurSearch方法。直到在NUnit中運行通過,全部顯示綠燈。

更多軟考資料請訪問:考試吧軟件水平考試欄目

希望與更多網友交流,請進入考試吧軟件水平考試論壇

 

上一頁  [1] [2] [3] [4] 下一頁

轉帖于:軟件水平考試_考試吧
文章搜索  
看了本文的網友還看了:
軟件水平考試權威輔導教材: 訂書電話:010-62168566  更多>>>
網友評論
昵 稱: *  評 分: 1分 2分 3分 4分 5分
標題:   匿名發(fā)表    (共有條評論)查看全部評論>>
版權聲明 -------------------------------------------------------------------------------------
  如果軟件水平考試網所轉載內容不慎侵犯了您的權益,請與我們聯系,我們將會及時處理。如轉載本軟件水平考試網內容,請注明出處。
關于本站  網站聲明  廣告服務  聯系方式  付款方式  站內導航  客服中心  友情鏈接  考試論壇  網站地圖
Copyright © 2004-2008 考試吧軟件水平考試網 All Rights Reserved    
中國科學院研究生院權威支持(北京) 電 話:010-62168566 傳 真:010-62192699
百度大聯盟黃金認證  十佳網絡教育機構  經營許可證號:京ICP060677