单元测试能够帮助开发人员确保所开发的模块、类以及类中的方法等的正确性,在项目开发过程中,及时进行单元测试能够避免不必要的BUG以及提高测试效率。

在本文中,我们会分别来学习如何使用MSTest、xUnit以及NUnit这些流行的.NET测试框架来对.NET Core项目进行测试。

一、项目创建

首先,创建一个需要测试的项目。在Visual Studio中创建一个.NET Core 类库项目,名为Calc,项目创建成功后,删除自带的Class1.cs,添加一个类Calculator。

Calculator类定义了一个方法Sum,它接受一个或多个整型数值,并返回这些数值的总和。接下来,我们将使用不同的测试框架对这个类库项目进行测试。

二、使用MSTest测试框架

要对项目进行测试,首先应创建测试项目,在“解决方案管理器”中右击解决方案名称Calc,从快捷菜单中添加一个新项目,并选择“MSTest测试项目”,为项目命名为MSTestSample。

创建的MSTest测试项目,会自动引入三个NuGet包。

对于Microsoft.NET.Test.Sdk,无论使用哪种测试框架(MSTest、xUnit、NUnit),都需要引用这个包;而另外两个包,则是MSTest测试框架(MSTest.Framework)和测试适配器(MSTest.TestAdapter),后者用于发现并执行单元执行。

接下来,为测试项目添加对Calc项目的引用。此时,就可以对它进行单元测试了。在UnitTest1.cs中添加测试方法:

几乎所有的测试框架都使用C#特性(Attribute)来标识测试类与测试方法。MSTest测试框架使用[TestClass]和[TestMethod]来分别标识测试类与测试方法。此外,几乎所有的测试框架都包含一个名为Assert的类,它包含若干静态方法,用于验证测试结果,它将决定这个测试方法的成功与否。

除了上图中的AreEqual方法,Assert类的其它方法如下:

Assert.AreNotEqual

Assert.AreSame

Assert.AreNotSame

Assert.IsNull

Assert.IsNotNull

Assert.IsTrue

...

在测试方法中右击,从快捷菜单中可以运行测试。

三、使用xUnit测试框架

以同样的方式创建一个xUnit测试项目,名为xUnitTestSample。为它添加对Calc项目的引用,并将默认的UnitTest1.cs修改如下:

与MSTest和NUnit测试框架不同,在xUnit中,测试类并不需要使用C#特性标识,只有测试方法才需要。

这里包含两个方法,第一个以[Fact]标识以指明它是一个测试方法;第二个使用[Theory]以及[InlineData]特性标识。[Theory]特性不仅指明该方法是一个测试方法,并且使它具有数据驱动测试的功能,而[InlineData]特性用于提供测试数据。[InlineData]特性通过其构造函数为测试方法提供参数;另外,可以在同一个方法上使用多个[InlineData]特性,多个[InlineData]特性将会使测试方法执行多次。

运行xUnit测试方法与前者相同。

四、使用NUnit测试框架

默认情况下,Visual Studio中的新建项目窗口并没有为NUnit测试项目提供创建模板,然而,.NET Core CLI(命令行界面工具)支持创建NUnit测试项目,命令如下:

dotnet new nunit -o <项目名称>

不过,在本例中,我们仍然使用Visual Studio来创建NUnit测试项目。在Visual Studio中创建一个.NET Core控制台应用程序,名为NUnitTestSampe,创建完成后,添加对Calc项目的引用,并添加以下NuGet包。

删除默认创建的Program.cs文件,添加一个类CalcTest,其内容如下:

NUnit测试框架使用[TestFixture]和[Test]属性来分别标识测试类与测试方法。运行NUnit测试方法也与前者相同。

总结

本文讨论了如何为.NET Core项目创建单元测试,并简要地了解了MSTest、xUnit、NUnit三种框架的使用。

.NET Core: 在.NET Core中进行单元测试的更多相关文章

  1. 好代码是管出来的——.Net Core中的单元测试与代码覆盖率

    测试对于软件来说,是保证其质量的一个重要过程,而测试又分为很多种,单元测试.集成测试.系统测试.压力测试等等,不同的测试的测试粒度和测试目标也不同,如单元测试关注每一行代码,集成测试关注的是多个模块是 ...

  2. 使用.NET Core在RESTful API中进行路由操作

    介绍 当列出REST API的最佳实践时,Routing(路由)总是使它位于堆栈的顶部.今天,在这篇文章中,我们将使用特定于.NET Core的REST(web)API来处理路由概念. 对于新手API ...

  3. 【ASP.NET Core】EF Core - “影子属性” 深入浅出经典面试题:从浏览器中输入URL到页面加载发生了什么 - Part 1

    [ASP.NET Core]EF Core - “影子属性”   有朋友说老周近来博客更新较慢,确实有些慢,因为有些 bug 要研究,另外就是老周把部分内容转到直播上面,所以写博客的内容减少了一点. ...

  4. 在ASP.NET Core的startup类中如何使用MemoryCache

    问: 下面的代码,在ASP.NET Core的startup类中创建了一个MemoryCache并且存储了三个键值“entryA”,“entryB”,“entryC”,之后想在Controller中再 ...

  5. Solr 创建core 从MySql数据库中导入数据

    一.创建数据表和数据 在MySql数据中创建mysolrInfo表, 创建字段 id 主键,自动增加 pname :姓名 age :年龄 addtime :增加时间 增加几条数据 二.创建core 当 ...

  6. 在.net core不同的版本中 webabi引用的包不同

    core2.0中: 为了要使用MVC Controller 要安装 Microsoft.AspNetCore.Mvc.Core包 Core2.1中:Microsoft.AspNetCore.App

  7. ASP.NET Core 3.0 WebApi中使用Swagger生成API文档简介

    参考地址,官网:https://docs.microsoft.com/zh-cn/aspnet/core/tutorials/getting-started-with-swashbuckle?view ...

  8. 从ASP.Net Core Web Api模板中移除MVC Razor依赖项

    前言 :本篇文章,我将会介绍如何在不包括MVC / Razor功能和包的情况下,添加最少的依赖项到ASP.NET Core Web API项目中. 一.MVC   VS WebApi (1)在ASP. ...

  9. ASP.NET Core在 .NET Core 3.1 Preview 1中的更新

    .NET Core 3.1 Preview 1现在可用.此版本主要侧重于错误修复,但同时也包含一些新功能. 这是此版本的ASP.NET Core的新增功能: 对Razor components的部分类 ...

  10. [.NET Core]ASP.NET Core中如何解决接收表单时的不支持的媒体类型(HTTP 415 Unsupported Media Type)错误呢?

    [.NET Core]ASP.NET Core中如何解决接收表单时的不支持的媒体类型(HTTP 415 Unsupported Media Type)错误呢? 在ASP.NET Core应用程序中,接 ...

随机推荐

  1. 将wiki人脸数据集的性别信息提取出来制作标签

    import scipy.io as scio dataFile = 'D:\\Users\\a\\Documents\\Tencent Files\\178026882\\FileRecv\\wik ...

  2. 循环神经网络之LSTM和GRU

    看了一些LSTM的博客,都推荐看colah写的博客<Understanding LSTM Networks> 来学习LSTM,我也找来看了,写得还是比较好懂的,它把LSTM的工作流程从输入 ...

  3. Hadoop HA高可用集群搭建(Hadoop+Zookeeper+HBase)

    声明:作者原创,转载注明出处. 作者:帅气陈吃苹果 一.服务器环境 主机名 IP 用户名 密码 安装目录 master188 192.168.29.188 hadoop hadoop /home/ha ...

  4. .NET CAD二次开发学习 对称画线功能

    [CommandMethod("CBline")] //对称画线 public void CBline() { Document doc = Application.Documen ...

  5. vue 中使用promise

    init1(){return new Promise((resolve, reject) => { let data={ dateStr:this.time }; api.get('url', ...

  6. Android6.0 源码修改之 仿IOS添加全屏可拖拽浮窗返回按钮

    前言 之前写过屏蔽系统导航栏功能的文章,具体可看Android6.0 源码修改之屏蔽导航栏虚拟按键(Home和RecentAPP)/动态显示和隐藏NavigationBar 在某些特殊定制的版本中要求 ...

  7. 小程序后端项目【Springboot框架】部署到阿里云服务器【支持https访问】

    前言: 我的后端项目是Java写的,用的Springboot框架.在部署服务器并配置https访问过程中,因为做了一些令人窒息的操作(事后发现),所以老是不能成功. 不成功具体点说就是:域名地址可以正 ...

  8. 织梦dedecms如何修改关键词的字数长度限制

    亲测,这个教程比较完善,百度了很多有些少步骤,或者方法根本不对,导致不成功.这个方法我亲子测试了.奏效. 首先登陆数据库后台,如phpmyadmin,找到相应的数据表dede_archives和ded ...

  9. JournalNode failed to restart

    Install clusterEnable Namenode HAStart RU"Zookeeper" is completed"Core Masters" ...

  10. 为什么MIP-Cache存在

    在去年十月的一篇 博客文章 提到 MIP 加速器是由 MIP-HTML, MIP-JS 和 MIP-Cache 三个模块共同产生加速效果的.MIP-HTML 和 MIP-JS 都是开源的,在 GitH ...