二、通過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中運行通過,全部顯示綠燈。
更多軟考資料請訪問:考試吧軟件水平考試欄目
希望與更多網友交流,請進入考試吧軟件水平考試論壇
轉帖于:軟件水平考試_考試吧
- 推薦給朋友
- 收藏此頁
·2006年下半年軟考《信息系統(tǒng)監(jiān)理師》試題分析 (2006-11-8 9:02:02)
·2006年下半年軟件水平考試《信息系統(tǒng)監(jiān)理師》試題 (2006-11-6 10:38:41)
·2006年軟件水平《信息系統(tǒng)監(jiān)理師》試題 (2006-5-31 16:49:14)