ZOMBIES:如何在軟體開發中實現業務需求(四)
完善你的電商應用,使它能夠正確處理業務規則。
在前面的文章中,我已經解釋了為什麼將編程問題看作一整群喪屍來處理是錯誤的。我用 ZOMBIES 方法來解釋為什麼循序漸進地處理問題更好。
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 方法的前五項。第一篇中 實現了最簡場景,它為代碼提供了最簡可行路徑。第二篇文章中執行了 單元素場景和多元素場景上的測試。第三篇中介紹了 邊界和介面。在本文中,我將帶你了解倒數第二個方法:處理特殊行為。
處理特殊行為
在開發一個電子購物應用時,你需要從產品負責人或贊助商那裡了解需要採用什麼銷售策略。
毫無疑問,與任何電子商業活動一樣,你需要通過制定銷售策略來誘導顧客進行消費。假設有如下的銷售策略:訂單金額超過 ¥500 時可以享受一定的折扣優惠。
現在將這個銷售策略轉換為可運行期望:
[Fact]
public void Add2ItemsTotal600GrandTotal540() {
var expectedGrandTotal = 540.00;
var actualGrandTotal = 0.00;
Assert.Equal(expectedGrandTotal, actualGrandTotal);
}
這個正面樣例表示的銷售策略是,如果訂單總額為 ¥600.00,那麼 shoppingAPI
會將其減價為 ¥540.00。上面的代碼偽造了一個失敗驗證用例。現在修改它,讓它能夠通過測試:
[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 的商品,使總價達到 ¥600 。當調用 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
[...]
很可惜,它失敗了。你期望的結果是 ¥540,但計算結果為 ¥600。為什麼會這樣呢?那是因為你還沒有告訴系統在訂單總價大於 ¥500 時怎麼進行折扣計算。
現在來實現折扣計算邏輯。根據上面的正樣例可知,當訂單總價為 ¥600(超過了營銷策略的閾值 ¥500)時,期望的最終總價為 ¥540。也就是說系統需要從訂單總額中減去 ¥60。剛好是是原訂單總價的 10%。因此該銷售規則就是當訂單總額超過 ¥500 時享受九折優惠。
在 ShippingAPI
類中實現該處理邏輯:
private double Calculate10PercentDiscount(double total) {
double discount = 0.00;
if(total > 500.00) {
discount = (total/100) * 10;
}
return discount;
}
首先,檢查訂單總額是否大於 ¥500 。如果是,則計算出總額的 10%。
你還需要告訴系統怎麼從訂單總額中減去 10%。改動非常直接:
return grandTotal - Calculate10PercentDiscount(grandTotal);
到此,所有測試都能夠通過。你又一次享受到系統處於穩態的歡愉。你的代碼通過處理特殊行為實現了需要的銷售策略。
最後一步
現在我已經介紹完 ZOMBIE 了,只剩下 S 了。我將會在最後一篇中介紹它。
(題圖:MJ/7f8bf5d2-54ce-4d6e-9dbf-13abf6df966a)
via: https://opensource.com/article/21/2/exceptional-behavior
作者:Alex Bunardzic 選題:lujun9972 譯者:toknow-gh 校對:wxy
本文轉載來自 Linux 中國: https://github.com/Linux-CN/archive