推荐在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# 项目。只要项目引用对了、测试方法加了正确特性、断言写清楚,就能跑起来。










