我目前正在尝试使用xUnit将两个具有相同项目的列表进行比较,但是在运行时出现错误。
Assert.Equal(expectedList, actualList);
错误:
"Assert.Equal() Failure"
Expected: List<myObject> [myObject { modifier = '+', name = "name", type = "string" }, myObject { modifier = '+', name = "age", type = "int" }]
Actual: List<myObject> [myObject { modifier = '+', name = "name", type = "string" }, myObject { modifier = '+', name = "age", type = "int" }]
这与对象相等有关。
MyObject
没有实现Equals method
。默认情况下,您获得引用相等性。我假设您有两个不同的对象MyObject
。
这意味着您的List拥有相似的对象(意味着具有相同的值),它们不是同一引用,这并不重要,因此您的测试会检查这就是为什么它失败。
internal class MyObject
{
{
public char Modifier { get; set; }
public string Name { get; set; }
public string Type { get; set; }
}
}
[Fact]
public void ListMyObject()
{
var list1 = new List<MyObject>
{
new MyObject{ }
};
var list2 = new List<MyObject>
{
new MyObject{ }
};
Assert.Equal(list1, list2); // Fails
}
当我们更新班级到这个。
internal class MyObject
{
public char Modifier { get; set; }
public string Name { get; set; }
public string Type { get; set; }
//When i add this to my class.
public override bool Equals(object obj)
{
return this.Name == ((MyObject)obj).Name;
}
}
也如乔纳森·蔡斯(Jonathon Chase)的评论中所述。
对于override
该GetHashCode()
方法也是一个好主意。最好从继承,IEquatable<T>
这样可以避免强制转换。
一切都变成绿色。
[Fact]
public void ListMyObject()
{
var list1 = new List<MyObject>
{
new MyObject{ Name = "H" }
};
var list2 = new List<MyObject>
{
new MyObject{ Name = "H" }
};
Assert.Equal(list1, list2); //Passes
}
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句