如何解决Gtest 成员初始化问题
我在理解 GTest 的以下行为时遇到了一些问题。 当夹具类中有一些在初始化列表中初始化的成员并使用它们从夹具初始化另一个成员时,会发生以下行为。
在第一个版本中,调用了 B 的复制构造函数,然后调用了 B 的参数化构造函数。 在第二个版本中,首先调用参数化构造函数,然后调用复制构造函数。 我的理解是,第一个版本和第二个版本中的行为应该相似, 然而,正确的行为仅在第二个版本中才能看到。 如果我想在第一个版本中添加一些成员,我该怎么做?
class ConfigEndpoint
{
ConfigEndpoint (const B& f_bar0 = B(),const B& f_bar1 = B(),const B& f_bar2 = B() )
};
ConfigEndpoint::ConfigEndpoint (const B& f_bar0 = B(),const B& f_bar2 = B() )
: array {f_bar0,f_bar1,f_bar2} {}
Class B has two types of constructors:
// Default one:
B::B()
: m_space(MEMORY),m_type(32BIT),m_isConfigured(false)
{}
// Parametrized one:
B::B(int f_barSpace,int f_barType)
: m_space(f_barSpace),m_type(f_barType),m_isConfigured(true)
{}
**//TestFixture -> version 1.**
class CConfigTest : public ::testing::TestWithParam<std::tuple<driverStartAddress,bool>>
{
public:
CConfigTest() :
bar0(MEMORY,32BIT),bar1(MEMORY,bar2(MEMORY,configEndpoint(bar0,bar1,bar2)
{ }
ConfigEndpoint configEndpoint;
const B bar0;
const B bar1;
const B bar2;
};
**//TestFixture -> version 2.**
class CConfigTest : public ::testing::TestWithParam<std::tuple<driverStartAddress,bool>>
{
public:
CConfigTest()
:
configEndpoint( B(MEMORY,B(MEMORY,32BIT) )
{ }
ConfigEndpoint configEndpoint;
};
解决方法
您尚未描述两个版本中实际发生的情况(即您的期望与观察到的情况)。乍一看:您创建了 bar[1|2|3]
,但您在版本号中传递了 mock_bar[1|2|3]
。 1.
附带说明:class A
中有一个错误:如果不带参数调用它,则会将临时对象绑定到 const &A
。这在堆栈上很好,但不适用于类的成员。更糟糕的是,您不在测试中使用它(因为您在那里传递了正确的引用),因此它只会在生产或某些集成测试中失败。见:
Does a const reference class member prolong the life of a temporary?
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。