Mat*_*cek 7 unit-testing fluent-assertions
我有一个测试验证方法的集合输出.测试的这种变化通过:
[TestMethod, TestCategory("BVT")]
public void TheStatusesAreReturned()
{
var expectedUnprocessedStatuses = new List<FileUploadStatus>
{
FileUploadStatus.InProcess,
FileUploadStatus.Pending,
};
Sut.GetUnprocessedStatuses()
.Should()
.BeEquivalentTo(expectedUnprocessedStatuses);
}
Run Code Online (Sandbox Code Playgroud)
测试的这种变化失败,错误"预期项目[0]为InProcess,但发现待定":
[TestMethod, TestCategory("BVT")]
public void TheStatusesAreReturned2()
{
var expectedUnprocessedStatuses = new List<FileUploadStatus>
{
FileUploadStatus.InProcess,
FileUploadStatus.Pending,
};
Sut.GetUnprocessedStatuses()
.ShouldBeEquivalentTo(expectedUnprocessedStatuses);
}
Run Code Online (Sandbox Code Playgroud)
显然,ShouldBeEquivalentTo
关心收集项目的顺序,而BeEquivalentTo
不是.为什么两种方法之间的等效概念不同?
Den*_*men 12
你说的没错.应该().BeEquivalentTo()使用单个项目Equals()实现来验证等效性,并且从版本1开始就已经存在.FA 2.0中引入的较新的ShouldBeEquivalentTo()正在进行深入的结构比较,并报告任何差异.对于2.1我默认情况下会将行为更改为集合等效