X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=senf%2FPPI%2FActiveFeeder.test.cc;h=995f477a0403defa3bba0bc49eb42fde5e62fcaa;hb=6dfb1a69bf12258f6f8117f5e4c257c4e0367a29;hp=90d3722bf83e58f1e434650a32f2fcf2354bfd40;hpb=26610f603ebdd465307b9621f532c1fe19fd5571;p=senf.git diff --git a/senf/PPI/ActiveFeeder.test.cc b/senf/PPI/ActiveFeeder.test.cc index 90d3722..995f477 100644 --- a/senf/PPI/ActiveFeeder.test.cc +++ b/senf/PPI/ActiveFeeder.test.cc @@ -30,37 +30,50 @@ #include "ActiveFeeder.hh" #include "DebugModules.hh" #include "Setup.hh" +#include "CloneSource.hh" +#include +#include #include #include #define prefix_ ///////////////////////////////cc.p//////////////////////////////////////// - namespace debug = senf::ppi::module::debug; namespace ppi = senf::ppi; namespace module = senf::ppi::module; +namespace scheduler = senf::scheduler; + +namespace { + void timeout() { + scheduler::terminate(); + } + + void run(senf::ClockService::clock_type t) { + scheduler::TimerEvent timeoutTimer ("timeoutTimer", &timeout, + senf::ClockService::now() + t); + ppi::run(); + } +} BOOST_AUTO_UNIT_TEST(activeFeeder) { - debug::PassiveSource source; + senf::PacketData::byte data[] = { 0xab }; + senf::Packet p (senf::DataPacket::create(data)); + + module::CloneSource source (p); debug::PassiveSink sink; module::ActiveFeeder feeder; - ppi::connect(source,feeder); - ppi::connect(feeder,sink); - - for (unsigned i (0); i < 500; ++i) - source.submit(senf::DataPacket::create()); + ppi::connect( source, feeder ); + ppi::connect( feeder, sink ); - senf::ClockService::clock_type start (senf::ClockService::now()); - ppi::run(); - std::cerr << "ActiveFeeder: " - << (500*1e9)/(senf::ClockService::now()-start) + senf::ClockService::clock_type start (senf::ClockService::now()); + run( senf::ClockService::seconds(1)); + std::cerr << "\nActiveFeeder: " + << (sink.size()*1e9)/(senf::ClockService::now()-start) << " packets/s" << std::endl; - - BOOST_CHECK_EQUAL( source.size(), 0u ); - BOOST_CHECK_EQUAL( sink.size(), 500u ); + BOOST_CHECK( sink.size() > 0); } ///////////////////////////////cc.e////////////////////////////////////////