Fluent Assertions BeEquivalentTo 用于在匹配字符串中具有大小写差异的混合对象

Posted

技术标签:

【中文标题】Fluent Assertions BeEquivalentTo 用于在匹配字符串中具有大小写差异的混合对象【英文标题】:Fluent Assertions BeEquivalentTo for mixed object with case difference in matching strings 【发布时间】:2020-07-04 09:43:22 【问题描述】:

我得到了两个具有相同数据的对象,double,long,string 我的问题是对象 A 中的所有字符串都是大写的,对象 B 中的大小写。

objectA.Should.Should().BeEquivalentTo(objectB);

比较失败说

预期成员 stringName 为“Super”,但“SUPER”在“UPER”附近不同

如果我们比较字符串忽略它是全大写或转换全大写字符串,有什么办法可以说?

我可以运行一个 foreach 循环遍历所有内容并进行转换,但我想知道是否可以将我与流利断言的比较包括在内。

【问题讨论】:

【参考方案1】:

你可以这样做:

objectA.Should.Should().BeEquivalentTo(objectB, 
 opt => opt.Using<string>(ctx => ctx.Subject.Should().BeEquivalentTo(ctx.Expectation)).WhenTypeIs<string>());

令人困惑的部分是string 上有一个BeEquivalentTo 进行不区分大小写的比较,它与外部BeEquivalentTo 无关。

【讨论】:

太棒了。我应该添加比较 2 个地址对象,一个是帐户中的简单地址,一个是具有其他属性的帐单地址。【参考方案2】:

如果您只是比较两个对象,我认为您会想要单独比较属性。如果您想比较对象列表,则循环将是执行此操作的最佳方法,正如您所提到的那样。

至于字符串比较,你应该可以像这样比较它们

ObjectA.StringProperty.Should().BeEqulivalentTo(ObjectB.StringProperty);

这将允许忽略字符串大小写。

【讨论】:

嗯,BeEqulivalentTo 听起来确实像 Uper。

以上是关于Fluent Assertions BeEquivalentTo 用于在匹配字符串中具有大小写差异的混合对象的主要内容,如果未能解决你的问题,请参考以下文章

使用 Fluent Assertions 库的多个断言

Fluent Assertions Should().BeEquivalentTo 只有私有字段

Fluent Assertions ShouldBeEquivalentTo 总是以不同的属性传递

Fluent Assertions:大致比较两个 2D 矩形阵列

ShouldBeEquivalentTo 的 C# Fluent Assertions 全局选项

Fluent Assertions:大致比较一个类的属性