ZOMBIES:如何在軟件開發(fā)中實現(xiàn)業(yè)務(wù)需求(四)
在前面的文章中,我已經(jīng)解釋了為什么將編程問題看作一整群喪尸來處理是錯誤的。我用 ZOMBIES 方法來解釋為什么循序漸進(jìn)地處理問題更好。
ZOMBIES 表示以下首字母縮寫:
- Z – 最簡場景(Zero)
- O – 單元素場景(One)
- M – 多元素場景(Many or more complex)
- B – 邊界行為(Boundary behaviors)
- I – 接口定義(Interface definition)
- E – 處理特殊行為(Exercise exceptional behavior)
- S – 簡單場景用簡單的解決方案(Simple scenarios, simple solutions)
在系列的前三篇文章中,我展示了 ZOMBIES 方法的前五項。第一篇中 實現(xiàn)了最簡場景,它為代碼提供了最簡可行路徑。第二篇文章中執(zhí)行了 單元素場景和多元素場景上的測試。第三篇中介紹了 邊界和接口。在本文中,我將帶你了解倒數(shù)第二個方法:處理特殊行為。
處理特殊行為
在開發(fā)一個電子購物應(yīng)用時,你需要從產(chǎn)品負(fù)責(zé)人或贊助商那里了解需要采用什么銷售策略。
毫無疑問,與任何電子商業(yè)活動一樣,你需要通過制定銷售策略來誘導(dǎo)顧客進(jìn)行消費。假設(shè)有如下的銷售策略:訂單金額超過 ¥500 時可以享受一定的折扣優(yōu)惠。
現(xiàn)在將這個銷售策略轉(zhuǎn)換為可運行期望:
[Fact]
public void Add2ItemsTotal600GrandTotal540() {
var expectedGrandTotal = 540.00;
var actualGrandTotal = 0.00;
Assert.Equal(expectedGrandTotal, actualGrandTotal);
}
這個正面樣例表示的銷售策略是,如果訂單總額為 ¥600.00,那么 shoppingAPI
會將其減價為 ¥540.00。上面的代碼偽造了一個失敗驗證用例。現(xiàn)在修改它,讓它能夠通過測試:
[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);
}
在這個正樣例中,你向購物框加入一件價值 ¥200 的商品和一件價值 ¥400 的商品,使總價達(dá)到 ¥600 。當(dāng)調(diào)用 CalculateGrandTotal()
方法時,你期望總價是 ¥540。
這個微測試能夠通過嗎?
[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,但計算結(jié)果為 ¥600。為什么會這樣呢?那是因為你還沒有告訴系統(tǒng)在訂單總價大于 ¥500 時怎么進(jìn)行折扣計算。
現(xiàn)在來實現(xiàn)折扣計算邏輯。根據(jù)上面的正樣例可知,當(dāng)訂單總價為 ¥600(超過了營銷策略的閾值 ¥500)時,期望的最終總價為 ¥540。也就是說系統(tǒng)需要從訂單總額中減去 ¥60。剛好是是原訂單總價的 10%。因此該銷售規(guī)則就是當(dāng)訂單總額超過 ¥500 時享受九折優(yōu)惠。
在 ShippingAPI
類中實現(xiàn)該處理邏輯:
private double Calculate10PercentDiscount(double total) {
double discount = 0.00;
if(total > 500.00) {
discount = (total/100) * 10;
}
return discount;
}
首先,檢查訂單總額是否大于 ¥500 。如果是,則計算出總額的 10%。
你還需要告訴系統(tǒng)怎么從訂單總額中減去 10%。改動非常直接:
return grandTotal - Calculate10PercentDiscount(grandTotal);
到此,所有測試都能夠通過。你又一次享受到系統(tǒng)處于穩(wěn)態(tài)的歡愉。你的代碼通過處理特殊行為實現(xiàn)了需要的銷售策略。
最后一步
現(xiàn)在我已經(jīng)介紹完 ZOMBIE 了,只剩下 S 了。我將會在最后一篇中介紹它。