【MVC拾遺】MVC的單元測試簡單學習總結

来源:http://www.cnblogs.com/vvjiang/archive/2016/08/14/5771153.html
-Advertisement-
Play Games

關於測試的必要性什麼的已經在 重構與測試 里扯過了。倒也沒必要說,寫的代碼多了自然就明白這個東西重要性。 當時說了坐等被推動去學習單元測試來著,然而等著被人推動的結果就是根本就沒人來推你。o(∩_∩)o 所以還是自己主動來學,主動來總結了。 可測試性設計基礎理論知識 可測試性設計(Design fo ...


關於測試的必要性什麼的已經在 重構與測試 里扯過了。倒也沒必要說,寫的代碼多了自然就明白這個東西重要性。

當時說了坐等被推動去學習單元測試來著,然而等著被人推動的結果就是根本就沒人來推你。o(∩_∩)o

所以還是自己主動來學,主動來總結了。

可測試性設計基礎理論知識

可測試性設計(Design for Testability, DFT)是一種集成電路技術,它將一些特殊結構在設計階段植入電路,以便設計完成後進行測試。

後來這種玩法被應用到了軟體之中。它關註的是在正確的、錯誤的、丟失的和不完整的輸入下的輸出是否符合預期。

具有可測試性的軟體一般是採取鬆散設計,目的是為了方便測試軟體去調用,那麼低耦合就是它的原則了。(話說回來,就算不為了可測試性,低耦合也很重要啊)

比如基於介面來編程,就是眾所周知的降耦合的方法之一,減少測試時的依賴性。

編寫可測試性代碼的時候,也是對代碼結構的一個評審,因為一個在測試中無法輕鬆實例化的類,那麼就必定會存在耦合問題。

測試的代碼也應該保證效率,而低耦合也可以減少一些無用的測試環境的配置,那麼測試代碼的運行速度就會提升,這在大的項目中尤為重要。

如果不能使代碼的結構低耦合,那麼就不是單元測試了,而變為了集成測試。

雖然集成測試同樣有必要,但是不論是運行速度上還是對於問題發生後定位問題的速度上而言,都不如單元測試方便。

關於單元測試

單元測試(unit testing),是指對軟體中的最小可測試單元進行檢查和驗證。

上面是單元測試的百度百科定義。

單元測試包括編寫和運行一個小的程式,以自動的方法實例化測試類以及調用測試方法。

如果我們要手動去寫代碼去測試一個程式,雖然是可行的,但是畢竟耗時耗力,所以執行單元測試的最有效和最常見的方式是使用自動化的測試框架。

這個框架通常包括一個運行時引擎和一個類的框架,用於簡化測試程式的創建。

常用的自動化測試框架有:MSTest、NUnit以及xUnit.net。

MSTest看這名字就直到來自微軟,也就自動集成在VS中了,而為了懶得下別的資源的原因o(︶︿︶)o ,這裡就用MSTest了。

單元測試中有測試固件這麼個概念,實際上就是一個用於測試的類,這個類創建和結束的時候可能還會去設置測試環境和消除測試環境什麼的。(所以我們後面還是就叫測試類吧)

測試方法的典型設計可以總結為:設置、作用和斷言。(簡單來講,第一步設置測試環境,第二步將測試代碼作用於需要測試的代碼上,第三步將輸出結果與預期的斷言進行驗證)

單元測試是由數據驅動的測試,用不同的數據(比如臨界值,錯誤值什麼的)去測試代碼的可靠性。

雖然單元測試也是寫代碼,但是與平常的寫代碼還是有些區別的:

  • 測試範圍儘可能小。就像單一職責原則一樣,目的明確。這樣做不僅有助於快速定位問題,有助於測試代碼的可讀性。
  • 隔離測試。即在測試一個方法時,擺脫該方法所有的依賴性,而專註於測試該方法本身。
  • 偽造和模擬。實際上這個東西就是為了配合隔離測試來的,當一個類確確實實只能依賴於另一個類時,那麼就用偽造和模擬一個對象去替代被依賴的類的對象。
    • 偽造對象就是對一個對象的簡單克隆,提供與原始對象相同的介面,但是返回硬編碼的值。
    • 模擬對象比偽造對象更複雜,它涉及到要去模擬原始對象的一些交互
  • 一個斷言。這個是一個爭議點,就是為了保證測試範圍儘可能小。然而在實際操作中,可能會存在很多相似的測試,所以也可以去在一個測試中運用多個斷言。
  • 測試非公共成員。方法就是給所測試的類添加一個新類,然後這個新類有一些受保護的方法去調用那些要測試的非公共成員。
  • 代碼覆蓋率。用來計算被測試的系統中的代碼有多少被測試代碼測到了,以此來評估測試的可靠性。然而盲目地去提高代碼覆蓋率並不能說明測試的相關性和有效性,測試的關聯性才是重要的。

MVC的單元測試實戰

來吧,到了上點乾貨的時候了,實戰永遠比枯燥的理論有趣多了。

MVC的實現了控制器、視圖、模型的分離,並且不像WebForm那樣對Request和Session這些內部組件過於依賴,使得它成為了一個便於單元測試的框架。

首先創建單元測試項目。

被測試的代碼就是VS2015下,不帶帳號系統的MVC項目。以下為VS自動創建的單元測試項目。

可以看到預設的有一個Controller文件夾,下麵為控制台測試文件。可以聯想到,也可以加一個service或business文件夾去測試代碼的業務邏輯。(通常而言更多的測試其實都是針對業務層,因為控制器的代碼邏輯一般都比較簡單)

那麼看看預設的測試類HomeControllerTest中具體的代碼:

用TestClass特性去標註測試類,TestMethod特性去標註測試方法。

而觀察Index中的代碼:

首先聲明要測試的控制器類,也就是準備好測試環境,

然後用控制器實例去調用要測試的函數,

最後用斷言去判斷返回的結果是否符合預期。

 讓我們再加三個特性的用法

然後啟動測試什麼的也很簡單:

測試的結果會顯示在測試資源管理器中:

很明顯看到被Ignore特性標註的被跳過了測試。還可以選擇測試資源管理器中的測試然後進行單個測試,而不是像之前那樣測試所有。

其實說穿了單元測試這個東西玩法很簡單,需要去掌握的反而是之前的那些理論知識,保證測試的質量和高效。

說起來單元測試麻煩的地方可能也就是去解除依賴性了吧,主要是模擬交互,這個扯起來就麻煩了,百度了一下還有模擬交互的各種框架什麼的,而且一些模擬Http上下文的要用到。

不過我想總會有簡單的解決辦法的,本質上模仿也只是偽造的交互版本而已,那麼將偽造的返回結果豐富多樣化,那麼不就是模仿了嗎?

一點拙見啦~

OK,雖然單元測試是個可以簡單入門的東西,但是難度還是有的。

除了上面寫到的解除依賴性,最重要的還是實施和堅持。

從明天開始慢慢來把它納入項目中吧!

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 配置 hive 與 hbase 整合的目的是利用 HQL 語法實現對 hbase 資料庫的增刪改查操作,基本原理就是利用兩者本身對外的API介面互相進行通信,兩者通信主要是依靠hive_hbase-handler.jar工具類。 但請註意:使用Hive操作HBase中的表,只是提供了便捷性,前面章節 ...
  • HQL語法基於 SqlLine(http://sqlline.sourceforge.net/),DDL主要包含資料庫、函數、視圖的創建、修改、刪除,參考資料:(https://cwiki.apache.org/confluence/display/Hive/LanguageManual+DDL), ...
  • 源代碼如下: typedef struct _IMAGE_NT_HEADERS { +00h DWORD Signature; // 固定為 0x00004550 根據小端存儲為:"PE.." +04h IMAGE_FILE_HEADER FileHeader; +18h IMAGE_OPTIONA... ...
  • ...
  • 我們可以為自己訂製個性化的命令行提示符,Linux系統提示符是用系統變數PS1來定義的,只要按規則修改PS1系統變數的值隨意修改命令行提示符。 ...
  • 編程語言,作為人與電腦溝通的橋梁,有著重要和深遠的意義。有過電腦編程經驗的人,多少學習或掌握過一到多種編程語言。電腦專業領域的編程語言成百上千種,主流的編程語言也有數十種之多。每種編程語言面向的領域和特性都不盡相同,不過歸根結底是為瞭解決人與電腦之間溝通的效率問題,提高電腦的生產力。想必有 ...
  • ************************************************************************************************************ 本文是一個學習日記,如果大家有參考發現其中問題的可以與我聯繫。我們一起學習。希望... ...
  • 遍歷文件夾的子文件夾下的所有文件,將上個月的文件集中到一起,然互壓縮,並copy到伺服器的映射磁碟。 static void Main(string[] args) { //原始文件存放的位置 DirectoryInfo theFolder = new DirectoryInfo(@"E:\Test ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...