单元测试能够帮助开发人员确保所开发的模块、类以及类中的方法等的正确性,在项目开发过程中,及时进行单元测试能够避免不必要的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. javascript && php &&java

    java && javascript && php 轰炸!!!恢复 1.javascript简介 *是基于对象和时间的驱动语言,应用于客户端. -----基于对象: * ...

  2. eShopOnContainers 知多少[6]:持久化事件日志

    1. 引言 事件总线解决了微服务间如何基于集成事件进行异步通信的问题.然而只有事件总线正常运行,微服务之间基于事件的通信才得以运转. 而现实情况是,总有这样或那样的问题,导致事件总线不稳定或不可用,比 ...

  3. jdk源码阅读笔记-AbstractStringBuilder

    AbstractStringBuilder 在java.lang 包中,是一个抽象类,实现 Appendable 接口和 CharSequence 接口,这个类的诞生是为了解决 String 类在创建 ...

  4. MyISAM加锁分析

    为什么加锁 你正在读着你喜欢的女孩递给你的信,看到一半的时候,她的好闺蜜过来瞄了一眼(假设她会隐身术,你看不到她),她想把"我很喜欢你"改成"我不喜欢你",刚把 ...

  5. Java学习路线图分析

     Java学习路线分析图 第一阶段 技术名称 技术内容 J2SE(java基础部分) java开发前奏 计算机基本原理,Java语言发展简史以及开发环境的搭建,体验Java程序的开发,环境变量的设置, ...

  6. .NET(WinCE、WM)转Android开发——Xamarin和Smobiler对比

    对比 WinCE Android 行业场景 扫描分拣.车载.工控 扫描分拣.车载定位 开发语言 C++.C# Java/.NET(Smobiler) 开发环境 Visual Studio Androi ...

  7. 基于Vue2-Calendar改进的日历组件(含中文使用说明)

    一,前言 我是刚学Vue的菜鸟,在使用过程中需要用到日历控件,由于项目中原来是用jQuery写的,因此用了bootstarp的日历控件,但是配合Vue实在有点蛋疼,不够优雅…… 于是网上搜了好久找到了 ...

  8. Android中资源的引用

    R.java简单来说就是资源 R.java会自动收录当前应用中所有的资源,并根据这些资源建立对应的ID,包括:布局资源.控件资源.String资源.Drawable资源等 可以理解把所以资源按规则存放 ...

  9. 2018-12-25 VS Code英汉词典v0.0.8: 批量翻译文件部分命名

    续前文: VS Code英汉词典进化效果演示: 翻译文件所有命名 vscode"英汉词典"插件地址: 官方链接 现在实现的效果比之前的演示差很多, 因为executeDocumen ...

  10. 关于Django报错django.core.exceptions.ImproperlyConfigured: Requested setting DEBUG, but settings are not configure

    报错代码:django.core.exceptions.ImproperlyConfigured: Requested setting DEFAULT_INDEX_TABLESPACE, but se ...