gpt4 book ai didi

c++ - 如何最好地对使用 boost::asio::yield_context 的类进行单元测试?

转载 作者:太空狗 更新时间:2023-10-29 21:42:45 33 4
gpt4 key购买 nike

我有一个使用 boost:asio::yield_context 的类,我想知道如何最好地对其进行单元测试。我得到的类(class)的简化版本:

class Foo {
public:
void Read(boost::asio::yield_context context) {
my_scheduler->WaitOnEvent(BUFFER_HAS_DATA, context);
<...snip...>
callback(data);
}

void Write() {
// write to buffer
my_scheduler->FireEvent(BUFFER_HAS_DATA);
}

void Start() {
my_scheduler->Spawn(boost::bind(&Foo::Read, this, _1));
}
<...snip...>
};

我已经编写了自己的“调度程序”,它包装了 boost asio 功能,所以我有机会在调用实际到达 asio 之前拦截它们。测试是确定性的很重要,所以我希望能够让测试只使用一个线程(所以永远不要真正调用 boost::asio::spawn)并且理想情况下用这样的代码同步测试这个类:

void do_test() {
<...snip...>
unsigned int num_callbacks = 0;
auto callback = [&num_callbacks] (data) {
++num_callbacks;
}
foo->SetCallback(callback);

for (int i = 1; i <= 5; ++i) {
foo->Write();
foo->Read(); // What would I need to pass here?
assert(num_callbacks == i);
}
}

如果我手动创建一个 basic_yield_context,我能否在测试中将它传递给 Foo::Read 并让它按预期工作?如果是这样,我对 basic_yield_context ctor 在这种情况下实际寻找的内容感到有点困惑。如果那行不通,我真的对测试此类代码的更好策略很感兴趣,最好的方法是什么?

谢谢!

最佳答案

我的建议是使用模拟对象来模拟 yield_context 的界面。

有许多库可供您尝试模拟。

用于 boost 的一个很好的方法是 turtle:

http://turtle.sourceforge.net/

GoogleMock 是另一种可能性:

https://code.google.com/p/googlemock/

为了使用这些模拟库之一,您必须修改您的界面以适应模拟。我认为在这种情况下最好的选择是实现 ReadMyScheduler::WaitOnEvent 的方法,因此上下文参数的类型是模板参数(即鸭子类型) :

class Foo {
public:

//! This would be a `duck-type` interface.
template <typename YieldContext>
void Read(YieldContex context) {
//! You would also need one for your my_scheduler type's call to WaitOnEvent.
my_scheduler->WaitOnEvent(BUFFER_HAS_DATA, context);
<...snip...>
callback(data);
}
<...snip...>
};

关于c++ - 如何最好地对使用 boost::asio::yield_context 的类进行单元测试?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25150603/

33 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com