微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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])

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐