【发布时间】:2014-08-06 00:44:03
【问题描述】:
我有一个使用 boost:asio::yield_context 的类,我想知道如何最好地对其进行单元测试。我得到的课程的简化版本:
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 在这种情况下实际寻找的内容有点困惑。如果这不起作用,我真的对测试这种代码的更好策略很感兴趣,最好的方法是什么?
谢谢!
【问题讨论】:
标签: c++ unit-testing boost boost-asio