C#怎么进行单元测试 C# xUnit测试项目创建方法

推荐在C#中使用xUnit进行单元测试,因其轻量、现代且官方推荐,更契合.NET Core/.NET 5+项目;需正确创建测试项目、引用被测项目、编写带[Fact]/[Theory]特性的测试方法,并通过Test Explorer或dotnet test运行。

在C#中做单元测试,推荐用 xUnit(轻量、现代、官方推荐),比 NUnit 和 MSTest 更契合 .NET Core/.NET 5+ 项目。创建一个 xUnit 测试项目很简单,关键是要和被测项目正确引用、结构清晰、测试写得可维护。

新建 xUnit 测试项目

用命令行或 Visual Studio 都能快速创建:

  • Visual Studio 中:右键解决方案 → “添加” → “新建项目” → 搜索 “xUnit Test Project” → 选“.NET xUnit Test Project”(确保目标框架与被测项目一致,如 .NET 6 或 .NET 8)→ 命名并创建
  • 命令行(.NET CLI)dotnet new xunit -n MyProject.Tests → 然后用 dotnet sln add MyProject.Tests/MyProject.Tests.csproj 加入解决方案

引用被测项目

测试项目必须引用你要测的业务项目(比如叫 MyApp.Core),否则没法访问类和方法:

  • 右键测试项目 → “添加项目引用” → 勾选你的主项目
  • 或命令行:dotnet add MyProject.Tests/MyProject.Tests.csproj reference MyApp.Core/App.Core.csproj
  • 确认 .csproj 文件里有类似

写第一个测试方法

xUnit 使用 [Fact] 标记普通测试,用 [Theory] + [InlineData] 做参数化测试。别忘了 using xunit:

using Xunit;
using MyApp.Core;

public class CalculatorTests { [Fact] public void Add_ReturnsCorrectResult() { var calc = new Calculator(); var result = calc.Add(2, 3); Assert.Equal(5, result); }

[Theory]
[InlineData(1, 1, 2)]
[InlineData(0, 0, 0)]
[InlineData(-1, 1, 0)]
public void Add_HandlesMultipleCases(int a, int b, int expected)
{
    var calc = new Calculator();
    Assert.Equal(expected, calc.Add(a, b));
}

}

运行和调试测试

测试写完后,不用手动编译运行:

  • Visual Studio:打开“测试资源管理器”(Test → Windows → Test Explorer),点击“运行全部”或单个测试
  • 命令行:dotnet test(在测试项目目录下执行)
  • 调试测试:在测试方法内打断点 → 右键 → “调试测试”,和调试业务代码一样

基本上就这些。xUnit 结构干净、无冗余基类、强调不可变和函数式风格,适合现代 C# 项目。只要项目引用对了、测试方法加了正确特性、断言写清楚,就能跑起来。