Linux中國

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

本文由 LCTT 原創編譯,Linux中國 榮譽推出


本文轉載來自 Linux 中國: https://github.com/Linux-CN/archive

對這篇文章感覺如何?

太棒了
0
不錯
0
愛死了
0
不太好
0
感覺很糟
0
雨落清風。心向陽

    You may also like

    Leave a reply

    您的郵箱地址不會被公開。 必填項已用 * 標註

    此站點使用Akismet來減少垃圾評論。了解我們如何處理您的評論數據

    More in:Linux中國