期望以确切的对象实例作为参数进行调用

时间:2019-03-04 10:45:58

标签: c++ googletest googlemock

class MyClass
{
    public:
    int state;
};

class SomeClass
{
    virtual MyClass myFunction1() = 0;
    virtual void myFunction2(MyClass) = 0;
};

class MyMock : public SomeClass
{
public:
    MOCK_METHOD0(myFunction1, MyClass());
    MOCK_METHOD1(myFunction2, void(MyClass));
};

TEST_F(/* ... */)
{
    MyMock myMock;
    MyClass myObject;
    EXPECT_CALL(myMock, myFunction1()).WillOnce(Return(myObject));
    EXPECT_CALL(myMock, myFunction2(myObject));
}

编写此代码时,我以为我正在测试myFunction2是否使用的是MyClass返回的myFunction1的确切实例。但是这段代码也通过了:

TEST_F(/* ... */)
{
    MyMock myMock;
    MyClass myObject1;
    MyClass myObject2;
    EXPECT_CALL(myMock, myFunction1()).WillOnce(Return(myObject1));
    EXPECT_CALL(myMock, myFunction2(myObject2));
}

因此,显然第二个EXPECT_CALL()仅检查是否用与myFunction2值相同的任何MyClass对象调用myObject2,而不检查是否是可能与之相同的实例也是有效的测试,但是它测试了不同的行为(更笼统?)​​。

如何检查它是否是同一实例?

1 个答案:

答案 0 :(得分:1)

我之前的评论中有一个答案:您的函数不使用引用/指针,而是一个副本(因此无法比较两个副本的地址)。 myFunction1myFunction2都必须使用引用/指针来进行比较。以下示例测试您的初始设置。

class SomeClass
{
    virtual MyClass* myFunction1() = 0; // pointer!
    virtual void myFunction2(MyClass*) = 0; // pointer!
};

TEST_F(/* ... */)
{
    MyMock myMock;
    MyClass myObject;
    EXPECT_CALL(myMock, myFunction1()).WillOnce(Return(&myObject)); // dereference!
    EXPECT_CALL(myMock, myFunction2(&myObject)); // dereference!
}