xUnit单元测试核心三步:建项目、写方法、运行验证;它轻量且约定优于配置,无需属性标记,靠方法名和结构识别测试。
在 C# 中用 xUnit 做单元测试,核心就三步:建测试项目、写测试方法、运行验证。它比 MSTest 更轻量、更强调“约定优于配置”,不依赖属性标记(如 [TestMethod]),而是靠方法名和结构自动识别测试。
推荐用 .NET CLI 或 Visual Studio 创建标准 xUnit 项目,它会自动引用 xunit、xunit.runner.visualstudio 和 Microsoft.NET.Test.Sdk:
dotnet new xunit -n MyProject.Tests
dotnet add reference ../MyProject/MyProject.csproj
net8.0),避免运行时报错xUnit 使用 [Fact] 标记无参的普通测试,用 [Theory] + [InlineData] 做数据驱动测试。方法必须是 public、无返回值、无参数(Fact)或参数与 InlineData 匹配(Theory):
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, 5, 5)]
[InlineData(-2, 2, 0)]
public void Add_HandlesMultipleInputs(int a, int b, int expected)
{
var calc = new Calculator();
Assert.Equal(expected, calc.Add(a, b));
}}
注意:x

Unit 不支持 [TestInitialize] / [TestCleanup],改用构造函数和 IDisposable 实现“每测试实例”级清理(不是每个方法前/后)。
3. 运行与调试测试
无需额外安装插件,在终端或 VS 中都能直接运行:
dotnet test
dotnet test --filter "FullyQualifiedName~CalculatorTests"
xUnit 的 Assert 类简洁直接,常用方法有:
Assert.Equal(expected, actual) —— 推荐用于值类型、字符串、简单对象(会深度比较)Assert.True(condition) / Assert.False(condition)
Assert.Throws(() => method()) —— 验证异常抛出Assert.Contains(item, collection)、Assert.Empty(list)
若需共享上下文(如数据库连接、Mock 对象),可用 IClassFixture 实现“每个测试类一次初始化”,比构造函数更可控。
基本上就这些。xUnit 上手快,重点在于写清楚“给什么输入、期望什么输出”,而不是折腾框架本身。不复杂但容易忽略的是:测试方法名尽量表达意图(比如 Divide_ByZero_ThrowsDivideByZeroException),这比注释还管用。