如果我有这样的东西:
ASSERT_TRUE(RANGE(val1, val2, abs_err) || RANGE(val1, val3, abs_err));如何使用ASSERT_NEAR而不是ASSERT_TRUE
我试图将该语句分解为两个ASSERT_NEAR语句,如下所示,但是测试失败了。
ASSERT_NEAR(val1, val2, abs_err);
ASSERT_NEAR(val1, val3, abs_err);发布于 2017-06-22 12:58:34
您的用例是:这两个条件中的任何一个都应该是真的。所以请使用::testing::AnyOf(m1,m2,...)!
与matchers世界中的ASSERT_NEAR(lhs,rhs,max_error)等价的是::testing::DoubleNear(rhs,max_error) --所以您的示例如下所示:
ASSERT_THAT(val1, AnyOf(DoubleNear(val2, abs_err),
DoubleNear(val3, abs_err)));如果需要这两种条件--使用::testing::AllOf --实际上,您的尝试相当于AllOf --这就是它失败的原因。
https://stackoverflow.com/questions/44663629
复制相似问题