我之前寫過一篇XUNit的簡介:使用Xunit來進行單元測試。Xunit在當時確實是一個最簡單易用的測試框架,然而,隨着發展,Xunit也變得復雜了不少,光寫一個最簡單的測試就要導入8個包。
如果在大一點的項目中使用到還罷了,但如果只是隨手想寫一點單元測試引入這一堆包確實看着不大舒服。於是我又看了下MS自家的MS TEST。發現隨着發展,MS自家的MS TEST也改變了不少,雖然以前用過老版MS TEST的朋友基本上能拿着就用,但本文這里仍然簡單的介紹一下,方便新手上路。
目前MS發布了兩個版本的MS TEST:
-
MS TEST V1: V1在.net framework中自帶,引用Microsoft.VisualStudio.QualityTools.UnitTestFramework即可
-
MS TEST V2: V2的版本依賴於兩個包: MSTest.TestFramework和MSTest.TestAdapter
這兩個版本使用起來還是大同小異的,MS TEST V2主要是為了.net core准備的,當然也可以在.net framework上運行,並且新加入了一些擴展。本文這里是針對MS TEST V2進行的介紹。
首先來寫一個簡單的用例:
[TestClass] public class TestClass { [TestMethod] public void TestPass() { Assert.IsTrue(true); } [TestMethod] public void TestFail() { Assert.IsTrue(false); } }
寫完后編譯即可在測試管理器上看到用例,運行它就可以看到結果了:
測試用例聲明:
-
測試用例的類必須是public的,並且用TestClassAttribute標記
-
測試用例必須是public的,並且用TestMethodAttribute標記
Xunit並不需要TestClass聲明,但給測試類聲明也是有好處的,可以對其下的所有測試用例分組。
斷言:
可以用Assert斷言類來檢驗測試是否成功,也可以自己寫幫助類拋異常檢驗。
構建和析構:
和Xunit非常類似,測試框架執行每個測試用例的時候,會創建測試類對象,測試用例執行完后,如果測試類是IDisposable的,會執行Dispose函數。因此,簡單的做法是:
-
在測試用例類的構造函數指向數據構建操作
-
在Dispose函數中指向數據清理操作
另外,也可以通過TestInitialize和TestCleanup兩個Attribute來指定額外的構建和清理函數。通過函數指定的構建和析構函數在測試異步函數的時候還是非常有用的。這樣,一個測試用例執行的順序是
-
構造函數
-
TestInitialize制定的構建函數(如果有)
-
測試用例
-
TestCleanup制定的清理函數(如果有)
-
IDisposable. Dispose函數(如果有)
分組:
分組可以通過TestCategory標記:
[TestClass,TestCategory("MS TEST V2")] public class TestClass
查看方式中要選擇按特征分類:
這個標記也可以放在測試類,也可以放在測試用例上,效果不一樣,請自行嘗試。
參數傳入:
這個是老版本的MS TEST的最大不足了,現在也可以通過DataRowAttribute指定測試用例的參數:
[DataTestMethod] [DataRow(1, 2, 3)] [DataRow(3, 5, 8)] [DataRow(7, 6, 11)] public void AddTest(int n1, int n2, int sum) { Assert.AreEqual(sum, n1 + n2); }
也可以指定多組參數,測試就會執行多次用例。
在MS TEST V2的版本中,還可以通過ITestDataSource接口實現自定義數據源。
異常測試:
異常下現在也和xunit一樣采用斷言的方式捕獲了。
public void TestException() { Assert.ThrowsException<InvalidOperationException>(() => foo()); void foo() { throw new InvalidOperationException(); } }
擴展:
在MS TEST V2中,微軟提供了一定的擴展支持,如下圖所示(這些擴展也大部分支持MS TEST V1)
具體包括如下幾點:
-
特性擴展:
通過繼承TestPropety,可以更方便的為測試用例添加描述。詳情:RFC 001
-
斷言擴展:
通過內置的斷言擴展,可以更簡潔的方式定制自己的斷言API。詳情:RFC 002
-
執行擴展:
MSTest V2允許我們在以下兩個層級加入擴展。
-
測試方法級別:允許創建自己的TestMethod特性,定制執行邏輯
-
測試類級別:允許創建自己的TestClass特性,定制內部所有測試方法的執行邏輯
-
詳情:RFC 003
-
數據驅動擴展:
目前的MS TEST已經支持靜態數據參數DataRow的支持,它的主要特點是:
-
靜態數據不能滿足復雜的場景需要
-
無法為多個用例共享
如果需要更復雜的數據源,可以通過ITestDataSource接口實現。
-
小結:
MSTEST現在也非常簡單易用了。不過感覺Xunit的功能還是要多些,例如XUNIT可以暫時跳過用例,也可以修改用例名稱。我這里對MS TEST V2還處於管中窺豹的階段,后面可能會在一些項目中嘗試試用一下,可能還會寫一些文章繼續介紹它。
參考文章:
網上也有不少好的單元測試的文章可以參考下: