首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >GoogleTest复合试验?

GoogleTest复合试验?
EN

Stack Overflow用户
提问于 2017-06-20 21:53:56
回答 1查看 965关注 0票数 1

如果我有这样的东西:

代码语言:javascript
复制
ASSERT_TRUE(RANGE(val1, val2, abs_err) || RANGE(val1, val3, abs_err));

如何使用ASSERT_NEAR而不是ASSERT_TRUE

我试图将该语句分解为两个ASSERT_NEAR语句,如下所示,但是测试失败了。

代码语言:javascript
复制
ASSERT_NEAR(val1, val2, abs_err);
ASSERT_NEAR(val1, val3, abs_err);
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-06-22 12:58:34

您的用例是:这两个条件中的任何一个都应该是真的。所以请使用::testing::AnyOf(m1,m2,...)

与matchers世界中的ASSERT_NEAR(lhs,rhs,max_error)等价的是::testing::DoubleNear(rhs,max_error) --所以您的示例如下所示:

代码语言:javascript
复制
ASSERT_THAT(val1, AnyOf(DoubleNear(val2, abs_err),
                        DoubleNear(val3, abs_err)));

如果需要这两种条件--使用::testing::AllOf --实际上,您的尝试相当于AllOf --这就是它失败的原因。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/44663629

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档