FluentAssertions ShouldBeEquivalentTo()与Should().BeEquivalentTo()

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我默认情况下会将行为更改为集合等效

  • 这是一篇旧文章,但自 v2.1 以来 `ShouldBeEquivalentTo` 将忽略集合中项目的顺序。 (2认同)