二、通過TDD進(jìn)行重構(gòu))
“發(fā)現(xiàn)價(jià)值”的過程遠(yuǎn)遠(yuǎn)沒有結(jié)束。通過測(cè)試代碼,我們從客戶的角度來考慮,會(huì)發(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)吧。
首先從行為來考慮。搜索的功能會(huì)很復(fù)雜嗎?可能會(huì)有精確搜索,模糊搜索;可能是在網(wǎng)上搜索,也可能是本機(jī)搜索。那么,存儲(chǔ)的功能呢?IO的操作是否頻繁,存儲(chǔ)的要求是否會(huì)根據(jù)安全級(jí)別而逐步升級(jí)?再考慮顯示,對(duì)于個(gè)人智能助理來講,顯示的方式需要多樣化嗎?顯然,以上的行為都是復(fù)雜的。
再從抽象性考慮。需要把這些行為抽象出來嗎?也就是說,這些行為的載體是否會(huì)有多種類型?顯然,搜索可能會(huì)是文件的搜索,可能會(huì)是文本的搜索,也可能會(huì)是數(shù)據(jù)庫的搜索;存儲(chǔ)的格式也會(huì)有多種多樣,文本文件,xml文件,數(shù)據(jù)庫文件。顯示的方式可能會(huì)通過瀏覽器顯示,也可能會(huì)在WinForm中顯示。也許用戶要求是帶滾動(dòng)條的文本框,也許只是簡(jiǎn)單的文本顯示。對(duì)象的形式很多吧,需要抽象嗎?顯然是的!
這樣考慮之后,我發(fā)覺需要重構(gòu)的東西太多了,應(yīng)該怎么入手?首先,我們把SmartAssistor的職責(zé)先剝離出來,用更單一的對(duì)象來完成各自的功能。然后,分別將這些對(duì)象提煉出各自的接口。還是先寫測(cè)試代碼吧,考慮搜索功能,首先需要將對(duì)象分離出來:
[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)行測(cè)試代碼,未能通過。然后在程序中創(chuàng)建SearchEngine類型,并實(shí)現(xiàn)ExactSearch和BlurSearch方法。直到在NUnit中運(yùn)行通過,全部顯示綠燈。
更多軟考資料請(qǐng)?jiān)L問:考試吧軟件水平考試欄目
希望與更多網(wǎng)友交流,請(qǐng)進(jìn)入考試吧軟件水平考試論壇
北京 | 天津 | 上海 | 江蘇 | 山東 |
安徽 | 浙江 | 江西 | 福建 | 深圳 |
廣東 | 河北 | 湖南 | 廣西 | 河南 |
海南 | 湖北 | 四川 | 重慶 | 云南 |
貴州 | 西藏 | 新疆 | 陜西 | 山西 |
寧夏 | 甘肅 | 青海 | 遼寧 | 吉林 |
黑龍江 | 內(nèi)蒙古 |