C#单元测试通过独立验证方法逻辑提升代码质量,常用框架为xUnit和NUnit。xUnit设计现代,适用于ASP.NET Core项目,使用[Fact]和[Theory]特性编写测试;NUnit语法传统,功能丰富,采用[Test]和[TestCase]标记测试方法。两者均支持Visual Studio和.NET CLI运行测试,推荐保持测试独立、快速、可重复,避免外部依赖,必要时使用mock隔离。选择框架应基于团队习惯与项目需求。

C#的单元测试是验证代码中最小功能单元(通常是方法)是否按预期工作的过程。通过编写独立的测试方法,开发者可以在不依赖外部系统的情况下快速验证逻辑正确性,提高代码质量并支持重构。
单元测试框架简介
在C#生态中,xUnit和NUnit是最常用的两个单元测试框架。它们都运行在.NET平台,并与Visual Studio、.NET CLI和主流CI工具集成良好。xUnit.net 是较新的框架,设计更现代化,被广泛用于ASP.NET Core项目。它强调简洁性和可扩展性。
NUnit 是一个成熟的测试框架,语法接近经典JUnit,拥有丰富的断言和属性支持,适合习惯传统风格的团队。
使用xUnit编写测试
1. 创建类库项目并添加xUnit包:- 运行命令
dotnet new xunit -n MyProject.Tests创建带xUnit的测试项目 - 或手动添加包引用:
xUnit使用特性来标识测试。每个测试方法用 [Fact] 标记;带参数的测试使用 [Theory] 和数据源如 [InlineData]。
示例:
public class CalculatorTests
{
[Fact]
public void Add_TwoPositiveNumbers_ReturnsCorrectSum()
{
var calc = new Calculator();
int result = calc.Add(3, 5);
Assert.Equal(8, result);
}
[Theory]
[InlineData(2, 3, 5)]
[InlineData(-1, 1, 0)]
[InlineData(0, 0, 0)]
public void Add_WithVariousInputs_ReturnsExpected(int a, int b, int expected)
{
var calc = new Calculator();
int result = calc.Add(a, b);
Assert.Equal(expected, result);
}
}
使用NUnit编写测试
1. 创建项目并安装NUnit:- 创建项目后添加包:
- 同时需要测试适配器包以便在IDE中发现测试
NUnit使用 [Test] 标记单个测试方法,[TestCase] 提供参数化测试能力。
示例:
using NUnit.Framework;
[TestFixture]
public class CalculatorTests
{
[Test]
public void Add_TwoPositiveNumbers_ReturnsCorrectSum()
{
var calc = new Calculator();
int result = calc.Add(3, 5);
Assert.AreEqual(8, result);
}
[TestCase(2, 3, 5)]
[TestCase(-1, 1, 0)]
[TestCase(0, 0, 0)]
public void Add_WithVariousInputs_ReturnsExpected(int a, int b, int expected)
{
var calc = new Calculator();
int result = calc.Add(a, b);
Assert.AreEqual(expected, result);
}
}
运行测试
可通过多种方式执行测试:- 在Visual Studio中使用“测试资源管理器”
- 使用 .NET CLI:运行
dotnet test - 集成到CI流程中自动执行
测试应保持独立、快速、可重复。避免测试之间有依赖关系,不要访问数据库或网络等外部资源(如有需要,使用mock对象隔离)。
基本上就这些。选择xUnit还是NUnit取决于团队习惯和项目需求,两者都能有效支撑高质量的C#开发实践。










