C#使用MSTest進行單元測試

我之前寫過一篇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還處於管中窺豹的階段,後面可能會在一些項目中嘗試試用一下,可能還會寫一些文章繼續介紹它。

以上就是本文的全部內容,希望對大傢的學習有所幫助,也希望大傢多多支持WalkonNet。

推薦閱讀: