C#怎么进行单元测试 xUnit单元测试框架使用方法

来源:站长查询作者:厦门程序员头衔:程序员
导读:本期聚焦于小伙伴创作的《C#怎么进行单元测试 xUnit单元测试框架使用方法》,敬请观看详情,探索知识的价值。以下视频、文章将为您系统阐述其核心内容与价值。如果您觉得《C#怎么进行单元测试 xUnit单元测试框架使用方法》有用,将其分享出去将是对创作者最好的鼓励。

在C#开发中,单元测试是验证单个代码单元功能正确性的重要手段,xUnit是.NET生态中常用的单元测试框架,支持灵活的测试用例编写和丰富的断言能力,适合各类C#项目的测试需求。

C#怎么进行单元测试 xUnit单元测试框架使用方法

xUnit环境准备

首先需要在C#项目中引入xUnit相关依赖,以.NET 6及以上版本的项目为例,创建测试项目的步骤如下:

  • 在解决方案中新建一个xUnit测试项目,选择xUnit Test Project模板
  • 如果是已有项目,也可以通过NuGet安装xUnit相关包,需要安装的核心包包括xunit和xunit.runner.visualstudio

安装完成后,项目会自动引用xUnit的核心库,无需额外复杂配置即可开始编写测试用例。

编写基础测试用例

xUnit中测试用例通过特性标记实现,不需要继承特定基类,方法上添加[Fact]特性即可标记为无参数的测试用例,添加[Theory]特性可以标记带参数的测试用例。

假设我们有一个简单的计算器类,代码如下:

// 计算器类,提供基础运算方法
public class Calculator
{
    // 两个整数相加的方法
    public int Add(int a, int b)
    {
        return a + b;
    }

    // 两个整数相减的方法
    public int Subtract(int a, int b)
    {
        return a - b;
    }
}

对应的xUnit测试类代码如下:

using Xunit;

// 测试类,通常和被测试类同名加Tests后缀
public class CalculatorTests
{
    // 无参数测试用例,使用Fact特性标记
    [Fact]
    public void Add_TwoNumbers_ReturnsCorrectSum()
    {
        // 准备测试数据
        var calculator = new Calculator();
        int a = 3;
        int b = 5;
        int expected = 8;

        // 执行被测试方法
        int actual = calculator.Add(a, b);

        // 断言结果是否符合预期
        Assert.Equal(expected, actual);
    }

    // 带参数的测试用例,使用Theory特性标记,配合InlineData提供测试数据
    [Theory]
    [InlineData(10, 2, 8)]
    [InlineData(5, 3, 2)]
    [InlineData(0, 0, 0)]
    public void Subtract_TwoNumbers_ReturnsCorrectResult(int a, int b, int expected)
    {
        var calculator = new Calculator();
        int actual = calculator.Subtract(a, b);
        Assert.Equal(expected, actual);
    }
}

常用断言方法

xUnit的Assert类提供了丰富的断言方法,用于验证测试结果是否符合预期,常用的断言方法如下:

断言方法作用说明
Assert.Equal(expected, actual)验证两个值是否相等
Assert.NotEqual(expected, actual)验证两个值是否不相等
Assert.True(condition)验证条件是否为真
Assert.False(condition)验证条件是否为假
Assert.Null(obj)验证对象是否为null
Assert.NotNull(obj)验证对象是否不为null
Assert.Throws<TException>(func)验证执行方法时是否抛出指定类型的异常

例如测试一个会抛出异常的方法,代码示例如下:

using Xunit;

public class ExceptionTests
{
    // 被测试方法,除数为0时抛出DivideByZeroException
    public int Divide(int a, int b)
    {
        if (b == 0)
        {
            throw new DivideByZeroException();
        }
        return a / b;
    }

    [Fact]
    public void Divide_ByZero_ThrowsDivideByZeroException()
    {
        var testObj = new ExceptionTests();
        // 验证调用Divide方法传入0作为除数时,是否抛出DivideByZeroException异常
        Assert.Throws<DivideByZeroException>(() => testObj.Divide(10, 0));
    }
}

执行单元测试

编写完成测试用例后,可以通过多种方式执行测试:

  • 在Visual Studio中,打开测试资源管理器,右键选择要运行的测试项目或单个测试用例,点击运行即可执行测试
  • 如果使用命令行,可以在测试项目目录下执行dotnet test命令,会自动发现并执行所有测试用例,输出测试结果

测试执行完成后,会显示通过和失败的测试用例数量,点击失败的用例可以查看具体的失败原因和堆栈信息,方便定位代码问题。

测试生命周期管理

xUnit中每个测试用例都是独立的,测试类的构造函数会在每个测试用例执行前调用,可以用来初始化测试所需的资源,实现类似其他测试框架中Setup方法的功能。

示例代码如下:

using Xunit;

public class LifecycleTests
{
    private readonly Calculator _calculator;

    // 构造函数,每个测试用例执行前都会调用,初始化测试对象
    public LifecycleTests()
    {
        _calculator = new Calculator();
    }

    [Fact]
    public void Add_Test1()
    {
        // 这里可以直接使用初始化好的_calculator对象
        var result = _calculator.Add(1, 2);
        Assert.Equal(3, result);
    }

    [Fact]
    public void Add_Test2()
    {
        var result = _calculator.Add(4, 5);
        Assert.Equal(9, result);
    }
}

如果需要清理测试资源,可以在测试类中实现IDisposable接口,在Dispose方法中编写清理逻辑,该方法会在每个测试用例执行完成后调用。

C#xUnit单元测试测试框架修改时间:2026-06-30 08:06:14

免责声明:​ 已尽一切努力确保本网站所含信息的准确性。网站内容多为原创整理与精心编撰,观点力求客观中立。本站旨在免费分享,内容仅供个人学习、研究或参考使用。若引用了第三方作品,版权归原作者所有。如内容涉及您的权益,请联系我们处理。
内容垂直聚焦
专注技术核心技术栏目,确保每篇文章深度聚焦于实用技能。从代码技巧到架构设计,为用户提供无干扰的纯技术知识沉淀,精准满足专业提升需求。
知识结构清晰
覆盖从开发到部署的全链路。AI、前端、编程、数据库、服务器、建站、系统层层递进,构建清晰学习路径,帮助用户系统化掌握开发与运维所需的核心技术。
深度技术解析
拒绝泛泛而谈,深入技术细节与实践难点。无论是数据库优化还是服务器配置,均结合真实场景与代码示例进行剖析,致力于提供可直接应用于工作的解决方案。
专业领域覆盖
精准对应开发生命周期。从前端界面到后端编程,从数据库操作到服务器运维,形成完整闭环,一站式满足全栈工程师和运维人员的技术需求。
即学即用高效
内容强调实操性,步骤清晰、代码完整。用户可根据教程直接复现和应用于自身项目,显著缩短从学习到实践的距离,快速解决开发中的具体问题。
持续更新保障
专注既定技术方向进行长期、稳定的内容输出。确保各栏目技术文章持续更新迭代,紧跟主流技术发展趋势,为用户提供经久不衰的学习价值。