新聞中心
在前面的文章中,我已經(jīng)解釋了為什么將編程問題看作一整群喪尸來處理是錯(cuò)誤的。我用 ZOMBIES 方法來解釋為什么循序漸進(jìn)地處理問題更好。

創(chuàng)新互聯(lián)長期為上千客戶提供的網(wǎng)站建設(shè)服務(wù),團(tuán)隊(duì)從業(yè)經(jīng)驗(yàn)10年,關(guān)注不同地域、不同群體,并針對(duì)不同對(duì)象提供差異化的產(chǎn)品和服務(wù);打造開放共贏平臺(tái),與合作伙伴共同營造健康的互聯(lián)網(wǎng)生態(tài)環(huán)境。為朝陽企業(yè)提供專業(yè)的成都網(wǎng)站設(shè)計(jì)、成都網(wǎng)站制作,朝陽網(wǎng)站改版等技術(shù)服務(wù)。擁有10年豐富建站經(jīng)驗(yàn)和眾多成功案例,為您定制開發(fā)。
ZOMBIES 表示以下首字母縮寫:
- Z – 最簡場(chǎng)景(Zero)
- O – 單元素場(chǎng)景(One)
- M – 多元素場(chǎng)景(Many or more complex)
- B – 邊界行為(Boundary behaviors)
- I – 接口定義(Interface definition)
- E – 處理特殊行為(Exercise exceptional behavior)
- S – 簡單場(chǎng)景用簡單的解決方案(Simple scenarios, simple solutions)
在系列的前三篇文章中,我展示了 ZOMBIES 方法的前五項(xiàng)。第一篇中 實(shí)現(xiàn)了最簡場(chǎng)景,它為代碼提供了最簡可行路徑。第二篇文章中執(zhí)行了 單元素場(chǎng)景和多元素場(chǎng)景上的測(cè)試。第三篇中介紹了 邊界和接口。在本文中,我將帶你了解倒數(shù)第二個(gè)方法:處理特殊行為。
處理特殊行為
在開發(fā)一個(gè)電子購物應(yīng)用時(shí),你需要從產(chǎn)品負(fù)責(zé)人或贊助商那里了解需要采用什么銷售策略。
毫無疑問,與任何電子商業(yè)活動(dòng)一樣,你需要通過制定銷售策略來誘導(dǎo)顧客進(jìn)行消費(fèi)。假設(shè)有如下的銷售策略:訂單金額超過 ¥500 時(shí)可以享受一定的折扣優(yōu)惠。
現(xiàn)在將這個(gè)銷售策略轉(zhuǎn)換為可運(yùn)行期望:
[Fact]
public void Add2ItemsTotal600GrandTotal540() {
var expectedGrandTotal = 540.00;
var actualGrandTotal = 0.00;
Assert.Equal(expectedGrandTotal, actualGrandTotal);
}這個(gè)正面樣例表示的銷售策略是,如果訂單總額為 ¥600.00,那么 shoppingAPI 會(huì)將其減價(jià)為 ¥540.00。上面的代碼偽造了一個(gè)失敗驗(yàn)證用例。現(xiàn)在修改它,讓它能夠通過測(cè)試:
[Fact]
public void Add2ItemsTotal600GrandTotal540() {
var expectedGrandTotal = 540.00;
Hashtable item = new Hashtable();
item.Add("00000001", 200.00);
shoppingAPI.AddItem(item);
Hashtable item2 = new Hashtable();
item2.Add("00000002", 400.00);
shoppingAPI.AddItem(item2);
var actualGrandTotal = shoppingAPI.CalculateGrandTotal();
Assert.Equal(expectedGrandTotal, actualGrandTotal);
}在這個(gè)正樣例中,你向購物框加入一件價(jià)值 ¥200 的商品和一件價(jià)值 ¥400 的商品,使總價(jià)達(dá)到 ¥600 。當(dāng)調(diào)用 CalculateGrandTotal() 方法時(shí),你期望總價(jià)是 ¥540。
這個(gè)微測(cè)試能夠通過嗎?
[xUnit.net 00:00:00.57] tests.UnitTest1.Add2ItemsTotal600GrandTotal540 [FAIL]
X tests.UnitTest1.Add2ItemsTotal600GrandTotal540 [2ms]
Error Message:
Assert.Equal() Failure
Expected: 540
Actual: 600
[...]很可惜,它失敗了。你期望的結(jié)果是 ¥540,但計(jì)算結(jié)果為 ¥600。為什么會(huì)這樣呢?那是因?yàn)槟氵€沒有告訴系統(tǒng)在訂單總價(jià)大于 ¥500 時(shí)怎么進(jìn)行折扣計(jì)算。
現(xiàn)在來實(shí)現(xiàn)折扣計(jì)算邏輯。根據(jù)上面的正樣例可知,當(dāng)訂單總價(jià)為 ¥600(超過了營銷策略的閾值 ¥500)時(shí),期望的最終總價(jià)為 ¥540。也就是說系統(tǒng)需要從訂單總額中減去 ¥60。剛好是是原訂單總價(jià)的 10%。因此該銷售規(guī)則就是當(dāng)訂單總額超過 ¥500 時(shí)享受九折優(yōu)惠。
在 ShippingAPI 類中實(shí)現(xiàn)該處理邏輯:
private double Calculate10PercentDiscount(double total) {
double discount = 0.00;
if(total > 500.00) {
discount = (total/100) * 10;
}
return discount;
}首先,檢查訂單總額是否大于 ¥500 。如果是,則計(jì)算出總額的 10%。
你還需要告訴系統(tǒng)怎么從訂單總額中減去 10%。改動(dòng)非常直接:
return grandTotal - Calculate10PercentDiscount(grandTotal);到此,所有測(cè)試都能夠通過。你又一次享受到系統(tǒng)處于穩(wěn)態(tài)的歡愉。你的代碼通過處理特殊行為實(shí)現(xiàn)了需要的銷售策略。
最后一步
現(xiàn)在我已經(jīng)介紹完 ZOMBIE 了,只剩下 S 了。我將會(huì)在最后一篇中介紹它。
本文名稱:ZOMBIES:如何在軟件開發(fā)中實(shí)現(xiàn)業(yè)務(wù)需求(四)
分享鏈接:http://m.fisionsoft.com.cn/article/ccscseh.html


咨詢
建站咨詢
