每当我尝试 assert_equal 两个对象时,我总是会遇到这样的错误:
No visible difference in the User#inspect output.
You should look at the implementation of #== on User or its members.
Time 和 Array 也发生过这种情况。 Minitest 文档对此也没有说太多。
我使用的是 Ruby 2.0.0,但我使用的是 2.2.0,同样的事情发生了。也使用最新的 minitest。
此外,我正在运行 Ubuntu 14.10。
最佳答案
关于留言
当断言失败时显示这条消息,有点不是错误,但 MiniTest 未能找到对象之间的差异。
diff
在两个对象上运行 #inspect
并在其上运行 diff 工具。如果没有差异,则会显示此消息。
原则上,您希望两个不相等的对象在检查时具有不同的输出。但这并不是一成不变的,而且 ruby 标准库中的一些类并没有满足这个属性,比如 Time
。当涉及到您自己的类时,也许您已经编写了自定义的 #inspect
方法?
关于 Time
,inspect 只显示秒,不显示分数,但相等看分数,所以两个时间对象可能不相等,但在检查时看起来仍然相同。
关于Array
,如果其中包含的对象可以不相等但在检查时看起来相同,这将导致显示消息。
如果在检查输出不同的情况下仍收到此消息,则 diff 工具有问题。 MiniTest 尝试对使用哪个 diff 工具进行一些有根据的猜测。您可以通过打印 MiniTest::Assertions.diff
检查所选的 diff 工具。
关于对象相等
如果真正的问题是您的对象并不像您期望的那样相等,您应该查看 ==
方法是如何在相应的类中定义的。默认实现查看实例化时赋予每个对象的对象 ID,如果例如处理表示数据库行的对象,这可能不是您想要的。
关于ruby - Minitest 断言在检查时失败,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28697610/