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

  二、通過TDD進(jìn)行重構(gòu))

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

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

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

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

  這樣考慮之后,我發(fā)覺需要重構(gòu)的東西太多了,應(yīng)該怎么入手?首先,我們把SmartAssistor的職責(zé)先剝離出來,用更單一的對象來完成各自的功能。然后,分別將這些對象提煉出各自的接口。還是先寫測試代碼吧,考慮搜索功能,首先需要將對象分離出來:
  [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中運(yùn)行測試代碼,未能通過。然后在程序中創(chuàng)建SearchEngine類型,并實(shí)現(xiàn)ExactSearch和BlurSearch方法。直到在NUnit中運(yùn)行通過,全部顯示綠燈。

更多軟考資料請?jiān)L問:考試吧軟件水平考試欄目

希望與更多網(wǎng)友交流,請進(jìn)入考試吧軟件水平考試論壇

 

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

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