EXPECT_NO_THROW语句的 gtest 捕获结果
gtest capture result of EXPECT_NO_THROW statement
假设我有一个方法可以创建一个非平凡的可构造对象,该对象被RVO返回给调用方。例如
MyComplexClass value = deserialize();
deserialize
失败时抛出异常,所以我想做类似的事情
EXPECT_NO_THROW(MyComplexClass value = deserialize());
但是,当然,值超出了范围(因为宏引入了 try/catch 块)。而且
MyComplexClass value;
EXPECT_NO_THROW(value = deserialize());
不起作用,因为没有默认构造函数(例如它是 = delete
)。
对此有什么想法吗?我可以做类似的事情
template<typename TResult>
TResult return_assert_no_throw(std::function<TResult()> expression)
{
try
{
return expression();
}
catch (const std::exception & ex)
{
ASSERT_TRUE(false);
}
}
但这似乎有点笨拙,我们丢失了有关异常的信息
拥有虚拟实例的另一种方法是在集合中使用 emplace:
std::vector<MyComplexClass> v;
EXPECT_NO_THROW(v.emplace_back(deserialize()));
// work with v[0] as the value
从更一般的value = deserialize()
所需的语法来看,无论哪种类型的值,它都应该是可复制和/或可移动的。因此,如果您可以创建类的虚拟值/空值实例,您仍然可以使用。您只需将value
初始化为特定的虚拟/金丝雀实例,然后验证值是否正确更改。您可能已经/想要std::swap()
.
你可以
省去EXPECT_NO_THROW
。如果未捕获的异常从测试正文中逸出,Gtest 将无法通过测试。
相关文章:
- 为什么"do while"循环不断退出,即使条件计算结果为 false?
- valgrind-hellgrind与泄漏检查的结果不同
- 用C++20 fmt限制结果的总大小
- 如何返回一个类的两个对象相加的结果
- 使用QProcess执行命令,并将结果存储在QStringList中
- 如果我std::dynamic_pointer_cast并且底层dynamic_cast的结果为null,那么返回的sh
- 在没有定义返回类型的函数中返回布尔值,并将结果保存在无错误的char编译中-为什么
- 序列化,没有库的整数,得到奇怪的结果
- 使用取消引用的指针的多态性会产生意外的结果.为什么?
- 在更改for循环的第三部分后,未使用for循环结果
- 使用++运算符会导致意外的结果
- 在gtest.中使用fff.h模拟系统API
- 为什么在逗号分隔符上下文中将预增量的结果强制转换为void
- C++Brute Force攻击函数不会返回结果
- 你好。。。id_public变量不应该给出结果为 81 和 86 吗?为什么它为两个派生类占用不同的内存位置?
- 算术运算的结果类似于:C浮点变量中的1/3
- ";结果类型必须是可从输入范围的值类型""构造的;创建std::vector时
- 密码登录程序将永远循环并显示不正确的结果
- gtest 如何记录断言的结果
- EXPECT_NO_THROW语句的 gtest 捕获结果