断言在Visual Studio 2008测试框架中数组相等


81

有没有一种简单的方法可以在单元测试中检查两个数组是否相等(即,具有相同数量的元素,并且每个元素都相同?)。

在Java中,我会使用assertArrayEquals (foo, bar);,但是C#似乎没有等效的东西。我试过了Assert.AreEqual(new string[]{"a", "b"}, MyFunc("ab"));,但是即使函数返回带有“ a”,“ b”的数组,检查仍然失败

这是使用带有内置单元测试框架的Visual Studio 2008 Team Suite。

Answers:


147

是的CollectionAssert.AreEqual,另请参阅CollectionAssert文档


只需记住以下内容,stackoverflow.com/questions/5194966/…可以将对象与之进行显式比较,object.Equals并且IEqualityComparer<T>可能必须定义这些对象才能传递失败的断言。
atconway 2013年

2
我希望它在失败时能给出更详细的信息。“元素数量不同”和“索引0处的元素不匹配”几乎没有用。那是什么?!
恐慌上校

2
CollectionAssert.AreEquivalent(可从Visual Studio 2010获得)可提供更多信息。例如,当元素数不同时,该消息将说明期望的元素数和实际元素数
Dennie,

21

Class1.cs:


namespace ClassLibrary1
{
    public class Class1
    {
        Array arr1 = new[] { 1, 2, 3, 4, 5 };
        public Array getArray()
        {
            return arr1;
        }
    }
}

ArrayEqualTest.cs:


        [TestMethod()]
        public void getArrayTest()
        {
            Class1 target = new Class1(); 
            Array expected = new []{1,2,3,4,5}; 
            Array actual;
            actual = target.getArray();
            CollectionAssert.AreEqual(expected, actual);
            //Assert.IsTrue(expected.S actual, "is the test results");
        }

测试成功,发现错误:


   CollectionAssert.AreEqual failed. (Element at index 3 do not match.)

该死的,我无意中否决了这个答案,现在我不能撤消我的否决了-我得到了“除非修改了这个答案,否则你的投票已经锁定了” :(
Roman Pekar

这个答案看起来并不比前一年更好。
康斯坦丁

3

在.NET 3.5中,可能要考虑Assert.IsTrue(foo.SequenceEqual(bar));-它不会告诉您它在什么索引上有所不同。


1

好的,这是更长的方法...

static void Main(string[] args)
{
    var arr1 = new[] { 1, 2, 3, 4, 5 };
    var arr2 = new[] { 1, 2, 4, 4, 5 };

    Console.WriteLine("Arrays are equal: {0}", equals(arr1, arr2));
}

private static bool equals(IEnumerable arr1, IEnumerable arr2)
{

    var enumerable1 = arr1.OfType<object>();
    var enumerable2 = arr2.OfType<object>();

    if (enumerable1.Count() != enumerable2.Count())
        return false;

    var iter1 = enumerable1.GetEnumerator();
    var iter2 = enumerable2.GetEnumerator();

    while (iter1.MoveNext() && iter2.MoveNext())
    {
        if (!iter1.Current.Equals(iter2.Current))
            return false;
    }

    return true;
}
By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.