Easy-DotNET Easy-DotNET
🏠首页
  • 知识地图
  • 源码脑图

    • 总览
    • Program
    • WebApplication
    • Host主机
    • WebHost主机
    • 依赖注入
    • Autofac
    • Middleware中间件
    • RateLimiter限制速率
    • 响应缓存、请求解压缩
  • 设计初衷
  • 克隆
  • 类型转换
  • 日期时间
  • IO流
  • 工具类
  • 语言特性
  • 集合类
  • Codec编码
  • 文本操作
  • 数学
  • 图片
  • 网络
  • Emoji表情
  • C# 12
  • C# 11
  • C# 10
  • C# 9.0
  • C# 8.0
  • C# 早期版本
  • C# 教程
  • ORM
  • 定时任务
  • 日志
  • 认证与授权
  • Swagger
  • 对象映射
  • 熔断重试限流
  • 缓存
  • 注册发现
  • 网关
  • GraphQL
  • 更多
  • Docker

    • 简介
    • Adminer
    • Apisix
    • Apollo
    • Cassandra
    • Cerebro
    • ClickHouse
    • Consul
    • EasyMock
    • Elasticsearch
    • Emqx
    • FastDFS
    • Flink
    • Gitlab
    • Jenkins
    • Jrebel
    • MariaDB
    • MySQL
    • Percona
    • Phpmyadmin
    • PostgreSQL
    • Redis
  • Linux

    • 查看Linux系统信息
    • CentOS7调整磁盘分区
    • IO压测
    • 图形化监控工具Cockpit
  • 总览
  • 列表

    • 算法数据结构
    • API
    • 应用框架
    • 应用模板
    • 操作系统
    • 工作流
    • 入门套件
    • 示例
    • 人工智能
    • 程序集
    • Assets
    • 认证授权
    • Blazor
    • 区块链
    • 书籍
    • 自动构建
    • 报表
    • 缓存
    • 日历
    • 聊天
    • CLI
    • CLR
    • CMS
    • 代码分析和指标
    • 代码片段
    • 压缩
    • 持续集成
    • 密码学
    • 数据库
    • 数据库驱动
    • 日期时间
    • 反编译
    • 部署
    • DirectX
    • 分布式计算
    • DLR
    • 文档
    • 电商支付
    • 模拟器
    • 环境管理
    • ETL
    • 事件消息
    • Exception
    • 扩展
    • 函数式编程
    • 游戏引擎
    • GIS
    • Git工具
    • 绘图
    • GraphQL
    • GUI
    • HTML-CSS
    • HTTP
    • IDE
    • 图片处理
    • 安装工具
    • 交互式编程
    • 国际化
    • 互操作性
    • IoC
    • JS引擎
    • 日志
    • 机器学习和数据科学
    • Markdown
    • 邮件
    • 数学
    • 媒体
    • 指标
    • 微型框架
    • 最小化器
    • MVVM
    • 网络
    • 对象映射
    • Office
    • OpenAI
    • ORM
    • 包管理器
    • PDF
    • 性能分析工具
    • 协议
    • 推送通知
    • SQL构建器
    • 消息队列
    • RPC
    • 响应式编程
    • 实时通信
    • 正则表达式
    • 任务调度
    • SDK和API
    • 搜索引擎
    • 序列化
    • SMS
    • 状态机
    • 静态站点生成
    • 强命名
    • 风格指南
    • 模板引擎
    • 测试
    • 工具
    • 交易
    • UI自动测试
    • Visual Studio 插件
    • Web浏览器
    • Web框架
    • WebServers
    • WebSocket
    • Windows服务
    • WPF
    • 解析器
    • 源码生成
    • 其他
    • 资源
  • AspNetCore面试题
  • Elasticsearch面试题
  • MongoDB面试题
  • MySql面试题
  • Nginx面试题
  • RabbitMQ面试题
  • Redis面试题
  • 设计模式
  • 微服务
🧑‍💻.NET Blog
GitHub (opens new window)
🏠首页
  • 知识地图
  • 源码脑图

    • 总览
    • Program
    • WebApplication
    • Host主机
    • WebHost主机
    • 依赖注入
    • Autofac
    • Middleware中间件
    • RateLimiter限制速率
    • 响应缓存、请求解压缩
  • 设计初衷
  • 克隆
  • 类型转换
  • 日期时间
  • IO流
  • 工具类
  • 语言特性
  • 集合类
  • Codec编码
  • 文本操作
  • 数学
  • 图片
  • 网络
  • Emoji表情
  • C# 12
  • C# 11
  • C# 10
  • C# 9.0
  • C# 8.0
  • C# 早期版本
  • C# 教程
  • ORM
  • 定时任务
  • 日志
  • 认证与授权
  • Swagger
  • 对象映射
  • 熔断重试限流
  • 缓存
  • 注册发现
  • 网关
  • GraphQL
  • 更多
  • Docker

    • 简介
    • Adminer
    • Apisix
    • Apollo
    • Cassandra
    • Cerebro
    • ClickHouse
    • Consul
    • EasyMock
    • Elasticsearch
    • Emqx
    • FastDFS
    • Flink
    • Gitlab
    • Jenkins
    • Jrebel
    • MariaDB
    • MySQL
    • Percona
    • Phpmyadmin
    • PostgreSQL
    • Redis
  • Linux

    • 查看Linux系统信息
    • CentOS7调整磁盘分区
    • IO压测
    • 图形化监控工具Cockpit
  • 总览
  • 列表

    • 算法数据结构
    • API
    • 应用框架
    • 应用模板
    • 操作系统
    • 工作流
    • 入门套件
    • 示例
    • 人工智能
    • 程序集
    • Assets
    • 认证授权
    • Blazor
    • 区块链
    • 书籍
    • 自动构建
    • 报表
    • 缓存
    • 日历
    • 聊天
    • CLI
    • CLR
    • CMS
    • 代码分析和指标
    • 代码片段
    • 压缩
    • 持续集成
    • 密码学
    • 数据库
    • 数据库驱动
    • 日期时间
    • 反编译
    • 部署
    • DirectX
    • 分布式计算
    • DLR
    • 文档
    • 电商支付
    • 模拟器
    • 环境管理
    • ETL
    • 事件消息
    • Exception
    • 扩展
    • 函数式编程
    • 游戏引擎
    • GIS
    • Git工具
    • 绘图
    • GraphQL
    • GUI
    • HTML-CSS
    • HTTP
    • IDE
    • 图片处理
    • 安装工具
    • 交互式编程
    • 国际化
    • 互操作性
    • IoC
    • JS引擎
    • 日志
    • 机器学习和数据科学
    • Markdown
    • 邮件
    • 数学
    • 媒体
    • 指标
    • 微型框架
    • 最小化器
    • MVVM
    • 网络
    • 对象映射
    • Office
    • OpenAI
    • ORM
    • 包管理器
    • PDF
    • 性能分析工具
    • 协议
    • 推送通知
    • SQL构建器
    • 消息队列
    • RPC
    • 响应式编程
    • 实时通信
    • 正则表达式
    • 任务调度
    • SDK和API
    • 搜索引擎
    • 序列化
    • SMS
    • 状态机
    • 静态站点生成
    • 强命名
    • 风格指南
    • 模板引擎
    • 测试
    • 工具
    • 交易
    • UI自动测试
    • Visual Studio 插件
    • Web浏览器
    • Web框架
    • WebServers
    • WebSocket
    • Windows服务
    • WPF
    • 解析器
    • 源码生成
    • 其他
    • 资源
  • AspNetCore面试题
  • Elasticsearch面试题
  • MongoDB面试题
  • MySql面试题
  • Nginx面试题
  • RabbitMQ面试题
  • Redis面试题
  • 设计模式
  • 微服务
🧑‍💻.NET Blog
GitHub (opens new window)
npm
  • 简介
  • ORM

    • EFCore
    • Dapper
    • FreeSql
    • SqlSugar
  • 任务调度

    • Hangfire
    • Quartz
    • FluentScheduler
    • Coravel
    • Quartzmin
  • 日志

    • Serilog
    • NLog
    • Log4Net
    • Stackdriver
    • ExceptionLess
  • 身份认证与授权

    • IdentityServer4
    • Identity
    • JWTBearer
    • Auth0
    • OpenIddict
  • Swagger文档

    • Swagger
    • Swashbuckle
    • NSwag
    • ReDoc
  • 对象映射

    • AutoMapper
    • EmitMapper
    • AgileMapper
    • Mapster
  • 消息传递

    • MediatR
    • MassTransit
    • Rebus
    • NServiceBus
  • 熔断重试限流

    • Polly
    • Resilience4j
    • AkkaNET
  • 缓存

    • CsRedis
    • FreeRedis
    • EasyCaching
    • StackExchangeRedis
    • CacheCow
    • NCache
    • Memory
  • 注册发现

    • Consul
    • Nacos
    • Apollo
  • 网关

    • Ocelot
    • Kong
    • Traefik
    • Zuul
  • GraphQL

    • GraphQLPlatform
    • GraphQLdotnet
  • 更多

    • NodaTime
    • FluentAssertions
      • 安装
      • 使用示例
        • 基本使用
        • 集合断言
        • 异常断言
        • 嵌套断言
      • 结论
    • Humanizer
    • 爬虫-AngleSharp
    • 邮件-MailKit
  • NET微服务
  • 更多
一个大西瓜
2023-04-25
目录

FluentAssertions

开源地址

Github:https://github.com/nodatime/nodatime (opens new window)

FluentAssertions 是一个基于 .NET 的开源测试工具库,它提供了一种流畅的、可读性强的测试风格,使得测试代码更加易于编写和维护。本文将介绍 FluentAssertions 的使用方法和示例,以帮助 .NET 开发人员更好地掌握这个工具库。

# 安装

FluentAssertions 可以通过 NuGet 包管理器来安装,只需要在 Visual Studio 中打开 NuGet 包管理器,搜索 "FluentAssertions" 并安装即可。也可以在控制台中使用以下命令来安装:


Install-Package FluentAssertions

# 使用示例

# 基本使用

下面是一个简单的使用示例,展示了如何使用 FluentAssertions 来断言一个变量是否等于期望值:


var actualValue = 10;
actualValue.Should().Be(10);

在这个例子中,我们创建了一个整数变量 actualValue,然后使用 Should() 方法来开始一个断言,并使用 Be() 方法来断言变量是否等于 10。如果 actualValue 不等于 10,该断言将抛出异常,测试失败。

# 集合断言

FluentAssertions 还提供了一些方法来测试集合的内容。下面是一个示例,展示了如何使用 Contain() 方法来测试一个字符串列表是否包含某个特定的字符串:


var fruits = new List<string> { "apple", "banana", "orange" };
fruits.Should().Contain("apple");

在这个例子中,我们创建了一个字符串列表 fruits,然后使用 Contain() 方法来断言列表是否包含字符串 "apple"。如果列表不包含该字符串,该断言将抛出异常,测试失败。

# 异常断言

有时候我们希望测试代码是否能够正确地抛出异常。FluentAssertions 提供了一些方法来测试代码是否抛出了预期的异常。下面是一个示例,展示了如何使用 Throw() 方法来测试一个方法是否抛出了预期的异常:


Action action = () => { throw new Exception("error"); };
action.Should().Throw<Exception>().WithMessage("error");

在这个例子中,我们创建了一个匿名方法 action,该方法会抛出一个异常。然后我们使用 Throw() 方法来断言该方法是否抛出了 Exception 异常,并使用 WithMessage() 方法来断言异常消息是否为 "error"。如果方法未抛出预期的异常,该断言将抛出异常,测试失败。

# 嵌套断言

有时候我们希望测试一个对象的属性是否满足特定条件。FluentAssertions 允许我们使用嵌套断言来测试对象的属性。下面是一个示例,展示了如何使用嵌套断言来测试一个自定义类型的属性:


public class Person
{
    public string Name { get; set; }
    public int Age { get; set; }
}

var person = new Person { Name = "Alice", Age = 30 };
person.Should().Match<Person>(p => p.Name == "Alice" && p.Age == 30);

```swift

在这个例子中,我们创建了一个自定义类型 `Person`,该类型包含两个属性 `Name` 和 `Age`。然后我们创建了一个 `Person` 对象 `person`,并使用 `Match()` 方法来断言 `person` 对象是否满足特定的条件。在这个例子中,我们使用 Lambda 表达式来定义条件,断言 `person` 对象的 `Name` 属性等于 "Alice",`Age` 属性等于 30。如果 `person` 对象的属性不满足条件,该断言将抛出异常,测试失败。

### 自定义断言

有时候我们需要测试一些比较复杂的条件,这时候可以通过编写自定义断言来实现。下面是一个示例,展示了如何编写一个自定义断言来测试一个整数是否为奇数:

```csharp
public class OddNumberAssertion : Assertion<OddNumberAssertion, int>
{
    public AndConstraint<OddNumberAssertion> BeOdd()
    {
        Execute.Assertion
            .ForCondition(Subject % 2 == 1)
            .FailWith("Expected {context:subject} to be odd, but found {0}.", Subject);

        return new AndConstraint<OddNumberAssertion>(this);
    }
}

public static class OddNumberAssertionExtensions
{
    public static OddNumberAssertion Should(this int actualValue)
    {
        return new OddNumberAssertion { Subject = actualValue };
    }
}

var actualValue = 5;
actualValue.Should().BeOdd();

在这个例子中,我们定义了一个自定义断言类 OddNumberAssertion,该类继承自 Assertion<OddNumberAssertion, int>,并提供了一个 BeOdd() 方法来测试一个整数是否为奇数。在 BeOdd() 方法中,我们使用 FluentAssertions 提供的 ForCondition() 方法来定义断言条件,如果条件不满足,该方法将抛出异常。然后我们定义了一个扩展方法 Should(),该方法接收一个整数参数,返回一个 OddNumberAssertion 实例。最后,我们创建了一个整数变量 actualValue,并使用 Should() 方法来断言该变量是否为奇数。如果 actualValue 不是奇数,该断言将抛出异常,测试失败。

# 结论

在本文中,我们介绍了 FluentAssertions 的安装和使用方法,并提供了一些使用示例,包括基本断言、集合断言、异常断言、嵌套断言和自定义断言。FluentAssertions 提供了一种流畅的、可读性强的测试风格,使得测试代码更加易于编写和维护。如果你还没有使用 FluentAssertions,现在是时候尝试一下了!

上次更新: 2023/04/26, 22:10:06
NodaTime
Humanizer

← NodaTime Humanizer→

Theme by Vdoing | Copyright © 2019-2024 一个大西瓜 | MIT License | 苏ICP备2023013501号
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式