EXPECT_NO_THROW语句的 gtest 捕获结果

gtest capture result of EXPECT_NO_THROW statement

本文关键字:结果 gtest 语句 NO THROW EXPECT      更新时间:2023-10-16

假设我有一个方法可以创建一个非平凡的可构造对象,该对象被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 将无法通过测试。