成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

變異測試:基于故障的試驗

開發 測試
基于 .NET 的 xUnit.net 測試框架,開發一款自動貓門的邏輯,讓門在白天開放,夜間鎖定。

[[280217]]

基于 .NET 的 xUnit.net 測試框架,開發一款自動貓門的邏輯,讓門在白天開放,夜間鎖定。

在本系列的第一篇文章中,我演示了如何使用設計的故障來確保代碼中的預期結果。在第二篇文章中,我將繼續開發示例項目:一款自動貓門,該門在白天開放,夜間鎖定。

在此提醒一下,你可以按照此處的說明使用 .NET 的 xUnit.net 測試框架。

關于白天時間

回想一下,測試驅動開發(TDD)圍繞著大量的單元測試。

第一篇文章中實現了滿足 Given7pmReturnNighttime 單元測試期望的邏輯。但還沒有完,現在,你需要描述當前時間大于 7 點時期望發生的結果。這是新的單元測試,稱為 Given7amReturnDaylight

  1. [Fact]
  2. public void Given7amReturnDaylight()
  3. {
  4. var expected = "Daylight";
  5. var actual = dayOrNightUtility.GetDayOrNight();
  6. Assert.Equal(expected, actual);
  7. }

現在,新的單元測試失敗了(越早失敗越好!):

  1. Starting test execution, please wait...
  2. [Xunit.net 00:00:01.23] unittest.UnitTest1.Given7amReturnDaylight [FAIL]
  3. Failed unittest.UnitTest1.Given7amReturnDaylight
  4. [...]

期望接收到字符串值是 Daylight,但實際接收到的值是 Nighttime

分析失敗的測試用例

經過仔細檢查,代碼本身似乎已經出現問題。 事實證明,GetDayOrNight 方法的實現是不可測試的!

看看我們面臨的核心挑戰:

  1. GetDayOrNight 依賴隱藏輸入。

    dayOrNight 的值取決于隱藏輸入(它從內置系統時鐘中獲取一天的時間值)。

  2. GetDayOrNight 包含非確定性行為。

    從系統時鐘中獲取到的時間值是不確定的。(因為)該時間取決于你運行代碼的時間點,而這一點我們認為這是不可預測的。

  3. GetDayOrNight API 的質量差。

    該 API 與具體的數據源(系統 DateTime)緊密耦合。

  4. GetDayOrNight 違反了單一責任原則。

    該方法實現同時使用和處理信息。優良作法是一種方法應負責執行一項職責。

  5. GetDayOrNight 有多個更改原因。

    可以想象內部時間源可能會更改的情況。同樣,很容易想象處理邏輯也將改變。這些變化的不同原因必須相互隔離。

  6. 當(我們)嘗試了解 GetDayOrNight 行為時,會發現它的 API 簽名不足。

    最理想的做法就是通過簡單的查看 API 的簽名,就能了解 API 預期的行為類型。

  7. GetDayOrNight 取決于全局共享可變狀態。

    要不惜一切代價避免共享的可變狀態!

  8. 即使在閱讀源代碼之后,也無法預測 GetDayOrNight 方法的行為。

    這是一個嚴重的問題。通過閱讀源代碼,應該始終非常清晰,系統一旦開始運行,便可以預測出其行為。

失敗背后的原則

每當你遇到工程問題時,建議使用久經考驗的分而治之divide and conquer策略。在這種情況下,遵循關注點分離separation of concerns的原則是一種可行的方法。

關注點分離(SoC)是一種用于將計算機程序分為不同模塊的設計原理,以便每個模塊都可以解決一個關注點。關注點是影響計算機程序代碼的一組信息。關注點可以和要優化代碼的硬件的細節一樣概括,也可以和要實例化的類的名稱一樣具體。完美體現 SoC 的程序稱為模塊化程序。

出處

GetDayOrNight 方法應僅與確定日期和時間值表示白天還是夜晚有關。它不應該與尋找該值的來源有關。該問題應留給調用客戶端。

必須將這個問題留給調用客戶端,以獲取當前時間。這種方法符合另一個有價值的工程原理——控制反轉inversion of control。Martin Fowler 在這里詳細探討了這一概念。

框架的一個重要特征是用戶定義的用于定制框架的方法通常來自于框架本身,而不是從用戶的應用程序代碼調用來的。該框架通常在協調和排序應用程序活動中扮演主程序的角色。控制權的這種反轉使框架有能力充當可擴展的框架。用戶提供的方法為框架中的特定應用程序量身制定泛化算法。

Ralph Johnson and Brian Foote

重構測試用例

因此,代碼需要重構。擺脫對內部時鐘的依賴(DateTime 系統實用程序):

  1. DateTime time = new DateTime();

刪除上述代碼(在你的文件中應該是第 7 行)。通過將輸入參數 DateTime 時間添加到 GetDayOrNight 方法,進一步重構代碼。

這是重構的類 DayOrNightUtility.cs

  1. using System;
  2.  
  3. namespace app {
  4. public class DayOrNightUtility {
  5. public string GetDayOrNight(DateTime time) {
  6. string dayOrNight = "Nighttime";
  7. if(time.Hour >= 7 && time.Hour < 19) {
  8. dayOrNight = "Daylight";
  9. }
  10. return dayOrNight;
  11. }
  12. }
  13. }

重構代碼需要更改單元測試。 需要準備 nightHourdayHour 的測試數據,并將這些值傳到GetDayOrNight 方法中。 以下是重構的單元測試:

  1. using System;
  2. using Xunit;
  3. using app;
  4.  
  5. namespace unittest
  6. {
  7. public class UnitTest1
  8. {
  9. DayOrNightUtility dayOrNightUtility = new DayOrNightUtility();
  10. DateTime nightHour = new DateTime(2019, 08, 03, 19, 00, 00);
  11. DateTime dayHour = new DateTime(2019, 08, 03, 07, 00, 00);
  12.  
  13. [Fact]
  14. public void Given7pmReturnNighttime()
  15. {
  16. var expected = "Nighttime";
  17. var actual = dayOrNightUtility.GetDayOrNight(nightHour);
  18. Assert.Equal(expected, actual);
  19. }
  20.  
  21. [Fact]
  22. public void Given7amReturnDaylight()
  23. {
  24. var expected = "Daylight";
  25. var actual = dayOrNightUtility.GetDayOrNight(dayHour);
  26. Assert.Equal(expected, actual);
  27. }
  28.  
  29. }
  30. }

經驗教訓

在繼續開發這種簡單的場景之前,請先回顧復習一下本次練習中所學到的東西。

運行無法測試的代碼,很容易在不經意間制造陷阱。從表面上看,這樣的代碼似乎可以正常工作。但是,遵循測試驅動開發(TDD)的實踐(首先描述期望結果,然后才描述實現),暴露了代碼中的嚴重問題。

這表明 TDD 是確保代碼不會太凌亂的理想方法。TDD 指出了一些問題區域,例如缺乏單一責任和存在隱藏輸入。此外,TDD 有助于刪除不確定性代碼,并用行為明確的完全可測試代碼替換它。

最后,TDD 幫助交付易于閱讀、邏輯易于遵循的代碼。 

責任編輯:龐桂玉 來源: Linux中國
相關推薦

2019-10-21 09:52:51

變異測試單元測試

2021-08-26 05:57:42

Web 安全防火墻安全工具

2011-01-10 13:24:17

2016-12-05 09:50:17

2018-08-30 14:58:12

機器學習磁盤故障

2015-09-22 16:13:50

2011-08-23 14:02:17

2011-05-16 14:13:04

模型測試

2011-07-04 18:12:09

功能測試故障模型

2010-09-01 10:57:18

vSphere服務器虛擬化VMware

2010-11-04 13:46:33

GPON網絡測試華為

2009-09-15 16:50:54

2016-03-28 16:46:36

城市軌道LTE-M解決華為

2009-07-07 17:22:34

光纖鏈路測試故障

2020-11-06 15:05:13

物聯網預測性維護安全

2010-12-28 20:14:53

2009-02-09 14:04:01

2014-07-07 17:19:38

敏捷網絡華為

2011-04-26 16:35:35

噴頭故障噴墨打印

2014-02-10 09:17:50

光纜線路故障
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 久久机热| 国产精品成人国产乱 | 国产在线播放av | 欧美视频一区二区三区 | 日韩精品在线免费 | 欧美a区| 国产精品久久久久久久久久久久久 | 欧美bondage紧缚视频 | 国产美女视频 | av网站在线免费观看 | 精品一区二区三区在线观看 | cao在线 | 中文字幕精品一区二区三区精品 | 免费看a| 精品国产一二三区 | 国产成人精品一区二区三区四区 | 国产精品毛片av | 日韩在线一区二区三区 | 国产欧美日韩综合精品一区二区 | 国产1区| 亚洲欧洲精品在线 | 蜜桃传媒av | 在线日韩视频 | 国产精品精品 | 黄色电影在线免费观看 | 国产一区二区欧美 | 国产9久| 国产日韩一区二区三区 | 国产一区二区在线播放视频 | 伊人久久一区二区 | 国产精品成人一区二区 | 国产小视频在线 | 免费看爱爱视频 | 欧美精品在线播放 | 99精品国自产在线 | 精品成人免费视频 | 国产91一区二区三区 | 丁香综合 | 婷婷久久综合 | 成人午夜激情 | 日韩高清一区二区 |