我目前还没有成功地模拟一个返回unique_ptr的接口。例如,给定
struct IFoo {
virtual std::unique_ptr<IFoo> foo = 0;
};
int main()
{
MockRepository mocks;
auto foo = mocks.Mock<IFoo>();
mocks.OnCall( foo, IFoo::foo )
.Return( std::unique_ptr<IFoo>() );
}这无法编译,因为Return实现创建了unique_ptr的副本
Call &Return(Y obj) { retVal = new ReturnValueWrapper<Y>(obj); return *this; }并且期望尝试返回unique_ptr
template <typename Z>
Z MockRepository::DoExpectation(base_mock *mock, std::pair<int, int> funcno, const base_tuple &tuple)
{
...
return ((ReturnValueWrapper<Z> *)call->retVal)->rv;
}按照for a similar problem with returned references的建议,我已经尝试过Do。
我也尝试过编写自己的ValueWrapper<T>来生成unique_ptr,但是在某个地方,值总是被复制。现在我已经没有点子了。
发布于 2013-03-02 01:12:30
该问题的一种解决方案是创建一个带有附加方法的派生接口,该方法将返回值作为临时
template <class T>
class TypedReturnValueHolder : public ReturnValueHolder {
public:
virtual T rv() = 0;
};他们修改原始的ReturnValueHolder
template <class T>
class ReturnValueWrapper : public ReturnValueHolder {
public:
typename no_cref<T>::type rv;
ReturnValueWrapper(T rv) : rv(rv) {}
};继承并实现派生接口。
template <class T>
class ReturnValueWrapper : public TypedReturnValueHolder<T> {
typename no_cref<T>::type prv;
public:
ReturnValueWrapper(T rv) : prv(rv) {}
virtual T rv() { return prv; };
};完成此操作后,从DoExpectation返回的内容可以编写为
if (call->retVal)
return ((TypedReturnValueHolder<Z> *)call->retVal)->rv();问题中的示例在重写为使用Do时
mocks.OnCall( foo, IFoo::foo )
.Do( [](){ return std::unique_ptr<IFoo>(); } );然后按照预期进行编译和运行。
https://stackoverflow.com/questions/15160565
复制相似问题