原創|行業資訊|編輯:龔雪|2021-04-12 09:43:33.130|閱讀 228 次
概述:本文將為大家展示一些有趣的東西,以便您可以在單元測試中輕松使用C#功能。
# 界面/圖表報表/文檔/IDE等千款熱門軟控件火熱銷售中 >>
相關鏈接:
Telerik DevCraft包含一個完整的產品棧來構建您下一個Web、移動和桌面應用程序。它使用HTML和每個.NET平臺的UI庫,加快開發速度。Telerik DevCraft提供最完整的工具箱,用于構建現代和面向未來的業務應用程序,目前提供UI for ASP.NET MVC、Kendo UI、UI for ASP.NET AJAX、UI for WPF、UI for Xamarin、Reporting等眾多控件。
根據調查顯示,C#仍然是最受歡迎的編程語言之一,它功能強大,易于學習并且不斷改進和發展。最近幾年這個語言增加了新功能,新版本不斷迭代——C# 7, C# 8, C# 9。
Progress Telerik產品始終與.NET世界中的最新的功能保持同步,C#9和JustMock也不例外。大多數新功能都易于在單元測試和模擬中使用,但是本文將為大家展示一些有趣的東西,以便您可以在單元測試中輕松使用C#功能。
為了說明這些,我們將使用Foo類。
public class Foo { public Foo() { this.Bar = 10; this.DateTime = new DateTime(2021, 1, 1); } public int Bar { get; init; } public DateTime DateTime { get; init; } public bool IsInRange(int i) => i is (>= 1 and <= 10) or (>= 100 and <= 200); } public record Person { public string LastName { get; } public string FirstName { get; } public Person(string first, string last) => (FirstName, LastName) = (first, last); } public record Teacher : Person { public string Subject { get; } public Teacher(string first, string last, string sub) : base(first, last) => Subject = sub; }
注意:要運行示例,您需要從
[TestMethod]
public void TestStaticLocal() { // Arrange var sut = new Foo(); // Here is how to mock the static function Mock.Local.Function.Arrange<int>(sut, "MethodWithStaticLocal", "Add", Arg.Expr.AnyInt, Arg.Expr.AnyInt).Returns(1); // Act var result = sut.MethodWithStaticLocal(); // Assert Mock.Assert(sut); Assert.AreNotEqual(12, result); }
從C#8.0開始,您可以異步創建和使用流。 返回異步流的方法有三個細節:
在下面的示例中,您可以看到這種方法的示例以及如何進行模擬的示例:
[TestMethod]
public async Task TestAsyncEnumFromArray() { // Arrange var expected = new int[] { 10, 20, 30 }; Mock.Arrange(() => Foo.GetAsyncCollection()) .Returns(expected.GetEnumerator().ToAsyncEnumerable<int>()); // Act var result = Foo.GetAsyncCollection(); // Assert Mock.Assert<Foo>(); int index = 0; await foreach (var number in result) { Assert.AreEqual(expected[index++], number); } }
僅Init的設置器提供一致的語法來初始化對象的成員,屬性初始值設定項可清楚表明哪個值正在設置哪個屬性,缺點是這些屬性必須可設置。 從C#9.0開始,可以為屬性和索引器創建init訪問器,而不是設置訪問器。
編寫測試時如何模擬它? 使用JustMock的Mock.NonPublic.ArrangeSet方法。
[TestMethod]
public void TestInit() { // Arrange var fooMock = Mock.Create<Foo>(); bool properyInitCalled = false; Mock.NonPublic.ArrangeSet(fooMock, "Bar", 10) .IgnoreInstance() .DoInstead(() => properyInitCalled = true); // Act var foo = new Foo(); // Assert Assert.IsTrue(properyInitCalled); }
或者
[TestMethod]
public void TestInit2() { // Arrange var fooMock = Mock.Create<Foo>(Constructor.NotMocked); dynamic fooMockWrapper = Mock.NonPublic.Wrap(fooMock); Mock.NonPublic.Arrange(fooMockWrapper.Bar = 10) .IgnoreInstance() .MustBeCalled(); // Act var foo = new Foo(); // Assert Mock.NonPublic.Assert(fooMockWrapper.Bar = 10, Occurs.Once()); }
C#語言的另一個很棒的補充是模式匹配,這位C#開發人員提供了更多的創造力和靈活性!
正如文檔所說,基本上您要查看給定的結構,然后根據其外觀識別并確定其結構,然后就可以立即使用它。
為了向您展示如何使用InRange方法模擬這些功能,這是我們的模式匹配示例,然后是下面的測試:
public bool IsInRange(int i) => i is (>= 1 and <= 10) or (>= 100 and <= 200); ... [TestMethod] public void Mock_PatternMatchingTest() { // Arrange var foo = Mock.Create<Foo>(Behavior.CallOriginal); Mock.Arrange(() => foo.IsInRange(Arg.AnyInt)).Returns(true); // Act var result20 = foo.IsInRange(20); var result150 = foo.IsInRange(150); //Assert Assert.AreEqual(true, result20); Assert.AreEqual(true, result150); }
我知道讀取代碼與運行代碼并不相同,因此要使用它并使用示例,請按照以下步驟操作:
本站文章除注明轉載外,均為本站原創或翻譯。歡迎任何形式的轉載,但請務必注明出處、不得修改原文相關鏈接,如果存在內容上的異議請郵件反饋至chenjj@fc6vip.cn
文章轉載自:慧都網