c – 使用Google Mocks,如何在不关心/设置任何调用期望的情况下提供模拟实现

我有一个接口类说:

class MyInterface
{
public:
    virtual int doThing(int x,int y,int z) = 0;
};

我想编写一个模拟实现,以便在我的测试中使用.例如,传统上,不使用谷歌模拟,我会写:

class MyMock : public MyInterface
{
public:
    virtual int doThing(int x,int z)
    {
        if (x == 1)
            return y + z;
        else
            return y - z;
    }
};

我将如何在谷歌模拟中这样做.请注意,我不想(好的,我不需要)设置关于如何调用这个模拟的期望.我只是用它来测试别的东西.

你会怎么做(以及最清晰的方式)?我发现google mocks文档有点过于简洁,无法解决这个问题.

解决方法

包含Google Mock头文件

#include <gmock/gmock.h>

声明一个模拟类:

struct MyMock : MyInterface
{
    MOCK_METHOD3( doThing,int(int x,int z) );
};

将模拟实例化为NiceMock(在未注册调用时不会发出任何警告):

testing::NiceMock<MyMock> mock;

将任何匹配器带到范围:

using testing::_;

使用以下选项之一使用ON_CALL而不是EXPECT_CALL定义认行为:

选项1

硬编码认返回值:

ON_CALL( mock,doThing(_,_,_) ).WillByDefault(testing::Return(0));
//                                     default return value ~~^

选项#2

调用委托给全局函数

int foo(int x,int z)
{
    if (x == 1)
        return y + z;
    else
        return y - z;
}

ON_CALL( mock,_) ).WillByDefault(testing::Invoke(foo));

选项#3

调用委托给lambda表达式(C 11):

ON_CALL( mock,_) ).WillByDefault(testing::Invoke(
    [] (int x,int z)
    { 
        if (x == 1)
            return y + z;
        else
            return y - z;
    }
));

选项#4

使用Boost.Lambda库构建lambda表达式:

#include <boost/lambda/lambda.hpp>
#include <boost/lambda/if.hpp>

using namespace boost::lambda;

ON_CALL( mock,_) ).WillByDefault(testing::Invoke(
    ret<int>(if_then_else(_1 == 1,_2 + _3,_2 - _3))
));

// or: ret<int>(if_(_1 == 1)[_2 + _3].else_[_2 - _3])

相关文章

本程序的编译和运行环境如下(如果有运行方面的问题欢迎在评...
水了一学期的院选修,万万没想到期末考试还有比较硬核的编程...
补充一下,先前文章末尾给出的下载链接的完整代码含有部分C&...
思路如标题所说采用模N取余法,难点是这个除法过程如何实现。...
本篇博客有更新!!!更新后效果图如下: 文章末尾的完整代码...
刚开始学习模块化程序设计时,估计大家都被形参和实参搞迷糊...