gpt4 book ai didi

java - AssertJ - 方法 isEqualToComparingFieldByFieldRecursively 不适用于 RuntimeException 对象

转载 作者:行者123 更新时间:2023-11-28 21:21:47 33 4
gpt4 key购买 nike

总结

方法 isEqualToComparingFieldByFieldRecursively 不适用于 RuntimeException 对象。即使我们更改预期的 RuntimeException 中的 RuntimeException 消息,检查也始终返回 true。

无效示例(始终为真)

assertThat(caughtException).as("The Runtime exception")
.usingComparatorForType(ComparatorCollection.getDateComparator(MAX_ALLOWABLE_SEC_FOR_EQ),
LocalDateTime.class)
.usingComparatorForType(ComparatorCollection.getXmlDateComparator(MAX_ALLOWABLE_SEC_FOR_EQ),
XMLGregorianCalendar.class)
.isEqualToComparingFieldByFieldRecursively(expectedResults));
// caughtException.message and expectedResults.message are different but return true

工作示例

assertThat(caughtException).as("The Runtime exception")
.usingComparatorForType(ComparatorCollection.getDateComparator(MAX_ALLOWABLE_SEC_FOR_EQ),
LocalDateTime.class)
.usingComparatorForType(ComparatorCollection.getXmlDateComparator(MAX_ALLOWABLE_SEC_FOR_EQ),
XMLGregorianCalendar.class)
.isEqualToComparingFieldByFieldRecursively(expectedResults)
// The recursively check don't work with the RuntimeException message
.isEqualToComparingOnlyGivenFields(expectedResults, "message");

我们进行了一些测试,第二个示例工作(当我们强制检查属性消息时)。

最佳答案

这是检索要比较的字段的代码的旧限制,它忽略 java.lang 中的任何类型(以避免逐个字段比较 Object)。

这太过激了,需要放宽,已创建此错误以跟踪问题 https://github.com/joel-costigliola/assertj-core/issues/1224 .

关于java - AssertJ - 方法 isEqualToComparingFieldByFieldRecursively 不适用于 RuntimeException 对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49750071/

33 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com