这个测试怎么会失败呢?

[TestMethod]
public void Get_Code()
{
    var expected = new List<int>();
    expected.AddRange(new [] { 100, 400, 200, 900, 2300, 1900 });

    var actual = new List<int>();
    actual.AddRange(new [] { 100, 400, 200, 900, 2300, 1900 });

    Assert.AreEqual(expected, actual);
    // Assert.AreSame(expected, actual)       fails
    // Assert.IsTrue(expected.Equals(actual)) fails
}

要对集合进行断言,你应该使用CollectionAssert:

CollectionAssert.AreEqual(expected, actual);

List<T>不重写Equals,所以if Assert. T。AreEqual只调用Equals,它最终会使用引用相等。


我想这会有帮助

Assert.IsTrue(expected.SequenceEqual(actual));

这个测试比较输入的日期,检查是否是闰年,如果是,输出20个闰年,如果不是, 输出接下来的20个闰年,myTest。Testing引用myTest实例,该实例反过来调用一个名为Testing的List中的值,该List包含所需的计算值。这是我必须做的练习的一部分。

[TestMethod]
        public void TestMethod1()
        {
            int testVal = 2012;
            TestClass myTest = new TestClass();
            var expected = new List<int>();
            expected.Add(2012);
            expected.Add(2016);
            expected.Add(2020);
            expected.Add(2024);
            expected.Add(2028);
            expected.Add(2032);
            expected.Add(2036);
            expected.Add(2040);
            expected.Add(2044);
            expected.Add(2048);
            expected.Add(2052);
            expected.Add(2056);
            expected.Add(2060);
            expected.Add(2064);
            expected.Add(2068);
            expected.Add(2072);
            expected.Add(2076);
            expected.Add(2080);
            expected.Add(2084);
            expected.Add(2088);
            var actual = myTest.Testing(2012);
            CollectionAssert.AreEqual(expected, actual);
        }

我尝试了这个线程中的其他答案,它们对我不起作用,我比较了对象的集合,这些对象的属性中存储了相同的值,但对象是不同的。

方法调用:

CompareIEnumerable(to, emailDeserialized.ToIndividual,
            (x, y) => x.ToName == y.ToName && x.ToEmailAddress == y.ToEmailAddress);

比较方法:

private static void CompareIEnumerable<T>(IEnumerable<T> one, IEnumerable<T> two, Func<T, T, bool> comparisonFunction)
    {
        var oneArray = one as T[] ?? one.ToArray();
        var twoArray = two as T[] ?? two.ToArray();

        if (oneArray.Length != twoArray.Length)
        {
            Assert.Fail("Collections are not same length");
        }

        for (int i = 0; i < oneArray.Length; i++)
        {
            var isEqual = comparisonFunction(oneArray[i], twoArray[i]);
            Assert.IsTrue(isEqual);
        }
    }

如果你想检查每个包含相同的值集合,那么你应该使用:

CollectionAssert.AreEquivalent(expected, actual);

编辑:

“两个集合是等价的,如果它们有相同数量的相同元素,但顺序不同。元素相等是指它们的值相等,而不是指它们指向同一个对象。”——https://msdn.microsoft.com/en-us/library/ms243779.aspx


List<AdminUser> adminDetailsExpected = new List<AdminUser>()
{
new AdminUser  {firstName = "test1" , lastName = "test1" , userId = 
"001test1"  },
new AdminUser {firstName = "test2" , lastName = "test2" , userId = 
"002test2"   }
};

/ /行为

List<AdminUser> adminDetailsActual = RetrieveAdmin(); // your retrieve logic goes here

/ /维护

Assert.AreEqual(adminDetailsExpected.Count, adminDetailsActual.Count);  //Test succeeds if the count matches else fails. This count can be used as a work around to test

流畅断言对数组进行深度比较。