X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=senf%2FPPI%2FAnnotationRouter.test.cc;h=651d70ee66728f65493aa3fed9b3ce39700cf72d;hb=93d9568d448749dc187e7622b733a4a3caa319df;hp=670d929ef8cc874da78d112655ec47f1896ef7cd;hpb=26610f603ebdd465307b9621f532c1fe19fd5571;p=senf.git diff --git a/senf/PPI/AnnotationRouter.test.cc b/senf/PPI/AnnotationRouter.test.cc index 670d929..651d70e 100644 --- a/senf/PPI/AnnotationRouter.test.cc +++ b/senf/PPI/AnnotationRouter.test.cc @@ -1,6 +1,6 @@ // $Id$ // -// Copyright (C) 2008 +// Copyright (C) 2008 // Fraunhofer Institute for Open Communication Systems (FOKUS) // Competence Center NETwork research (NET), St. Augustin, GERMANY // Stefan Bund @@ -34,7 +34,11 @@ #include #define prefix_ -///////////////////////////////cc.p//////////////////////////////////////// +//-///////////////////////////////////////////////////////////////////////////////////////////////// +namespace ppi = senf::ppi; +namespace connector = ppi::connector; +namespace module = ppi::module; +namespace debug = module::debug; namespace { struct IntAnnotation { @@ -49,24 +53,29 @@ namespace { std::ostream & operator<<(std::ostream & os, IntAnnotation const & value) { os << value.value; return os; } + + struct AnnotationRouter : public module::AnnotationRouter + { + using module::AnnotationRouter::connectors; + }; } -BOOST_AUTO_UNIT_TEST(annotationRouter) +SENF_AUTO_UNIT_TEST(annotationRouter) { - senf::ppi::module::debug::ActiveSource source; - senf::ppi::module::debug::PassiveSink sink1; - senf::ppi::module::debug::PassiveSink sink2; - - senf::ppi::module::AnnotationRouter router; - - senf::ppi::connect(source, router); - senf::ppi::connect(router, sink1, 1); - senf::ppi::connect(router, sink2, 2); - - BOOST_CHECK_THROW( senf::ppi::connect(router, sink2, 2), - senf::ppi::module::AnnotationRouter::DuplicateKeyException); + debug::ActiveSource source; + debug::PassiveSink sink1; + debug::PassiveSink sink2; - senf::ppi::init(); + AnnotationRouter router; + + ppi::connect(source, router); + ppi::connect(router, 1, sink1); + ppi::connect(router, 2, sink2); + + BOOST_CHECK_THROW( connect(router, 2, sink2), + module::AnnotationRouter::DuplicateKeyException); + + ppi::init(); senf::Packet p1 (senf::DataPacket::create()); p1.annotation() = 1; @@ -81,9 +90,20 @@ BOOST_AUTO_UNIT_TEST(annotationRouter) BOOST_CHECK_EQUAL( sink2.size(), 1u ); BOOST_CHECK( sink1.front() == p1 ); BOOST_CHECK( sink2.front() == p2 ); + BOOST_CHECK_EQUAL(router.connectors().size(), 2u); + + sink1.input.disconnect(); + BOOST_CHECK_EQUAL(router.connectors().size(), 1u); + + senf::ppi::connect(router, 1, sink1); + senf::ppi::init(); + source.submit(p1); + + BOOST_CHECK_EQUAL( sink1.size(), 2u ); + BOOST_CHECK_EQUAL( sink2.size(), 1u ); } -///////////////////////////////cc.e//////////////////////////////////////// +//-///////////////////////////////////////////////////////////////////////////////////////////////// #undef prefix_