在重構的時候,仍然不能放棄TDD,只有它才能保證程序的可靠性,重構的正確性。開始重構吧。
首先從行為來考慮。搜索的功能會很復雜嗎?可能會有精確搜索,模糊搜索;可能是在網上搜索,也可能是本機搜索。那么,存儲的功能呢?IO的操作是否頻繁,存儲的要求是否會根據安全級別而逐步升級?再考慮顯示,對于個人智能助理來講,顯示的方式需要多樣化嗎?顯然,以上的行為都是復雜的。
再從抽象性考慮。需要把這些行為抽象出來嗎?也就是說,這些行為的載體是否會有多種類型?顯然,搜索可能會是文件的搜索,可能會是文本的搜索,也可能會是數據庫的搜索;存儲的格式也會有多種多樣,文本文件,xml文件,數據庫文件。顯示的方式可能會通過瀏覽器顯示,也可能會在WinForm中顯示。也許用戶要求是帶滾動條的文本框,也許只是簡單的文本顯示。對象的形式很多吧,需要抽象嗎?顯然是的!
這樣考慮之后,我發覺需要重構的東西太多了,應該怎么入手?首先,我們把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中運行測試代碼,未能通過。然后在程序中創建SearchEngine類型,并實現ExactSearch和BlurSearch方法。直到在NUnit中運行通過,全部顯示綠燈。
文章來源于領測軟件測試網 http://www.kjueaiud.com/