我在 gmock 学习。现在我试图模拟名为“task”的类,如下所示:
class MockTask : public Task
{
public:
MOCK_METHOD3(Execute, bool(std::set<std::string> &setDeviceIDs, int timeout, PACKET_DATA *Data));
};
我想在调用 task.excute 时保存结构 pdata,以便我可以验证 pdata->member。这是我的代码:
PAKET_DATA data;
EXPECT_CALL(task, Execute(testing::_, testing::_, testing::_))
.WillOnce(testing::saveArg<2>(&data));
ASSERT_EQ(data->resultcode, 0);
那是对的吗? saveArg 和 saveArgPointee 的区别是什么?
最佳答案
如你所见gmock doc:
对于您的情况,您应该使用SaveArgPointee
-因为要保存指向的数据(PACKET_DATA *Data
)-而不是指针本身...
看这个例子:
struct SomeData { int a; };
class ISomeClass
{
public:
virtual ~ISomeClass() = default;
virtual void foo(SomeData*) = 0;
};
void someFunction(ISomeClass& a)
{
SomeData b{1};
a.foo(&b);
}
class SomeMock : public ISomeClass
{
public:
MOCK_METHOD1(foo, void(SomeData*));
};
要测试
someFunction
,您需要检查传递给foo
的pointee:TEST(TestSomeFoo, shallPassOne)
{
SomeData actualData{};
SomeMock aMock;
EXPECT_CALL(aMock, foo(_)).WillOnce(::testing::SaveArgPointee<0>(&actualData));
someFunction(aMock);
ASSERT_EQ(1, actualData.a);
}
如果您使用
SaveArg
-您将只存储指向不再存在的局部变量的指针:TEST(TestSomeFoo, shallPassOne_DanglingPointer)
{
SomeData* actualData;
SomeMock aMock;
EXPECT_CALL(aMock, foo(_)).WillOnce(::testing::SaveArg<0>(&actualData));
someFunction(aMock);
ASSERT_EQ(1, actualData->a);
}
关于c++ - gmock 中 saveArg 和 saveArgPointee 的区别是什么?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/39323381/