目录

前置条件

Moq

xUnit

TDD

实践

创建项目

红灯

绿灯

重构

单元测试一些最佳实践

总结


前置条件

Moq

安装Moq包

Install-Package Moq

Moq是一个Mocking库,通过它可以轻易地模拟对象来进行测试。在我们的例子中,我们将使用Moq来模拟一个数据库访问类。

xUnit

xUnit是一个基于.NET平台的测试框架。它提供了各种测试机制,例如类、测试函数、断言等等。在我们的例子中,我们将使用xUnit来编写C#代码的测试用例。

TDD

测试驱动开发 (TDD) 是一种软件开发过程或方法,开发人员基本上通过单元测试开始创建软件——与传统方法不同,传统方法是开发软件,最后才创建测试用例以确保成功实施.

TDD的三个步骤是红绿重构

  • 红灯指的是先编写单元测试,此时还没有写任何具体实现代码,所以单元测试编译都通不过。
  • 绿灯指根据编写的单元测试,实现代码,目标是刚好可以让测试通过。
  • 重构是指的在保证了实现的代码可以通过单元测试,有了单元测试的保障之后,重构代码。重复上述的三个红绿重构步骤。

实践

创建项目

dotnet new sln -n Tdd

dotnet new console -o src/Calculator

dotnet new xunit -o test/Calculator.Tests

dotnet sln add src/Calculator

dotnet sln add test/Calculator.Tests

红灯

由于TDD是测试先行,此次我们模拟开发一个简单的计算器。所以先写单元测试。

using Moq;

namespace Calculator.Tests;

public class CalculatorTests
{
[Fact]
public void Calculate_WhenCalled_ReturnsNumber()
{
Mock<ICalculator> calculatorMock = new();
var num1 = It.IsAny<int>();
var num2 = It.IsAny<int>();
var res = It.IsAny<int>();
calculatorMock.Setup(c => c.Calculate(num1, num2)).Returns(res); var result = calculatorMock.Object.Calculate(num1, num2); Assert.Equal(res, result);
}
}

测试方法先准备了三个参数,使用了Moq的It.IsAny<>()方法,这个方法可以方便的创建一个对象。然后是Mock<>泛型方法用来模拟接口,通过Setup设置模拟的接口的参数传什么,返回什么结果。

最后访问了calculatorMock对象的Object,相当于是模拟的ICalculator对象。

单元测试编写完之后,是一片红,无法编译的。因为目前没有具体实现代码。所以我们完成了TDD的第一步,红灯。

绿灯

TDD的第二步,绿灯,我们需要根据现有的单元测试,实现代码。让单元测试能够通过。

首先是定义一个ICalculator接口,还有Calculate方法

namespace Calculator;

public interface ICalculator
{
int Calculate(int num1, int num2);
}

运行单元测试,发现可以通过。此时已经完成了第二步,绿灯。

重构

由于本文只是介绍TDD,不涉及复杂的逻辑。重构环节根据具体的业务逻辑实现就好了。

单元测试一些最佳实践

  • 命名遵循  测试方法名_测试方案_预期行为
  • 测试代码避免逻辑,如if,while,for和switch
  • 避免将Mock对象当作字段在整个单元测试方法都依赖,因为这样可能对具体一个Mock对象有状态依赖

总结

在本文中,我们介绍了如何使用xUnit和Moq库实现TDD。通过编写测试代码并在功能代码之前运行它,我们能够快速发现程序中的错误,并提高代码质量。xUnit提供了各种测试机制,如类、测试函数、断言等,Moq库提供了轻松模拟对象的机制。如果您正在寻找一个快速、简单、可靠的开发方法来编写高质量的代码,请尝试TDD。

【C#/.NET】xUnit和Moq实现TDD的更多相关文章

  1. 在XUnit中用Moq怎样模拟EntityFramework Core下的DbSet

    最近在做一个项目的单元测试时,遇到了些问题,解决后,觉得有必要记下来,并分享给需要的人,先简单说一下项目技术框架背景: asp.net core 2.0(for .net core)框架 用Entit ...

  2. TDD in .NET Core - 简介

    本文很多内容来自选自TDD实例一书. 预备知识 最好有一些预备知识,例如xUnit,Moq,如何编写易于测试的代码,这些内容我都写了文章:https://www.cnblogs.com/cgzl/p/ ...

  3. 模拟测试—moq:简单一两句

    在Xunit的基础上,说话模拟测试. 假如我们有这样一个控制器里面有这样一个方法,如图 我们在对Bar测试得时候,如果测试未通过,错误有可能来至于Bar,也有可能错误来至于serverde Foo方法 ...

  4. DotNet 资源大全中文版

    https://blog.csdn.net/fhzh520/article/details/52637545 目录 算法与数据结构(Algorithms and Data structures) 应用 ...

  5. ASP.NET 系列:单元测试

    单元测试可以有效的可以在编码.设计.调试到重构等多方面显著提升我们的工作效率和质量.github上可供参考和学习的各种开源项目众多,NopCommerce.Orchard等以及微软的asp.net m ...

  6. 使用Visual Studio Code开发Asp.Net Core WebApi学习笔记(九)-- 单元测试

    本篇将结合这个系列的例子的基础上演示在Asp.Net Core里如何使用XUnit结合Moq进行单元测试,同时对整个项目进行集成测试. 第一部分.XUnit 修改 Project.json 文件内容, ...

  7. Net Core WebApi单元测试

    单元测试 本篇将结合这个系列的例子的基础上演示在Asp.Net Core里如何使用XUnit结合Moq进行单元测试,同时对整个项目进行集成测试. 第一部分.XUnit 修改 Project.json  ...

  8. 这样入门asp.net core,如何

    本文章主要说明asp.net core的创建和简单使用. 一.使用到的命令 dotnet new :创建项目(解决方案,类库,单元测试等),如:dotnet new web dotnet add pa ...

  9. 用ASP.NET Core 2.1 建立规范的 REST API -- 保护API和其它

    本文介绍如何保护API,无需看前边文章也能明白吧. 预备知识: http://www.cnblogs.com/cgzl/p/9010978.html http://www.cnblogs.com/cg ...

  10. 测试 ASP.NET Core API Controller

    本文需要您了解ASP.NET Core MVC/Web API, xUnit以及Moq相关知识. 这里有xUnit和Moq的介绍: https://www.cnblogs.com/cgzl/p/917 ...

随机推荐

  1. 创建用户认证授权的 kubeconfig 文件

    创建用户认证授权的 kubeconfig 文件 当我们安装好集群后,如果想要把 kubectl 命令交给用户使用,就不得不对用户的身份进行认证和对其权限做出限制. 下面以创建一个 cby 用户并将其绑 ...

  2. 如何将 CentOS 8 转换为 CentOS Stream

    CentOS 未来是不会更新数字版本了.CentOS 项目组,未来会变更为Stream版本,也就是俗称的滚动版本,那么如何将数字版本升级为滚动版本呢? 若需要将其转换为滚动版本,那么即可参考本文进行升 ...

  3. 巧用Nginx配置解决跨域问题

    页面nginx配置 1,前端页面放在域名根目录,比如,http://www.xuecheng.com/ ,对应的nginx配置: #门户 location / { alias D:/Z_lhy/Spr ...

  4. ros-python学习样例笔记

    1.通信基本原理介绍 待写 2.三种通信方式的程序样例(python版) 2.1 topic 通信方式(非自定义和自定义) 2.1.1 创建工作空间和topic功能包 在ubuntu中打开命令行,输入 ...

  5. ORA-19870: error while restoring backup piece 数据库恢复报错

    问题描述:用备份进行DG恢复,恢复过程中报错ORA-19870: error while restoring backup piece /backup/db_BJCCORA_20180724_02t8 ...

  6. DG:RFS[8]: No standby redo logfiles created for thread 2

    环境:两节点的RAC在线搭建DG,处理报错 现象:RFS[8]: No standby redo logfiles created for thread 2 ,thread2 没有建立redo Tue ...

  7. odoo 开发入门教程系列-继承(Inheritance)

    继承(Inheritance) Odoo的一个强大方面是它的模块化.模块专用于业务需求,但模块也可以相互交互.这对于扩展现有模块的功能非常有用.例如,在我们的房地产场景中,我们希望在常规用户视图中直接 ...

  8. GraalVM(云原生时代的Java)和IoT在边缘侧落地与实践

    环顾四周,皆是对手! 云时代的掉队者,由于Java启动的高延时.对资源的高占用.导致在Serverless及FaaS架构下力不从心,在越来越流行的边缘计算.IoT方向上也是难觅踪影; Java语言在业 ...

  9. Vue3实现组件级基类的几种方法

    Vue3的组件有三种代码组织方式 纯Option API (不含setup) option API + setup 纯 setup (即composition API) 对于这三种形式,设置基类的方法 ...

  10. Prism Sample 7 Modules Directory

    这种方式用扫描目录的方式来增加模块,具备最大的灵活性 仍然在App.xaml.cs中增加了以下代码 protected override IModuleCatalog CreateModuleCata ...