X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=PPI%2FConnectors.test.cc;h=639f58b90548c66ced14200887712c8078e409e6;hb=6ba573a99f93543ee32292f79865751b3e9b89a4;hp=3a4b621bd645fdb80efe68d1d60377251790110f;hpb=9e64a6d6a4840325f74502ba959ebd56fbb8441c;p=senf.git diff --git a/PPI/Connectors.test.cc b/PPI/Connectors.test.cc index 3a4b621..639f58b 100644 --- a/PPI/Connectors.test.cc +++ b/PPI/Connectors.test.cc @@ -1,8 +1,8 @@ // $Id$ // -// Copyright (C) 2007 -// Fraunhofer Institut fuer offene Kommunikationssysteme (FOKUS) -// Kompetenzzentrum fuer Satelitenkommunikation (SatCom) +// Copyright (C) 2007 +// Fraunhofer Institute for Open Communication Systems (FOKUS) +// Competence Center NETwork research (NET), St. Augustin, GERMANY // Stefan Bund // // This program is free software; you can redistribute it and/or modify @@ -31,7 +31,7 @@ #include "DebugModules.hh" #include "Setup.hh" -#include +#include "../Utils/auto_unit_test.hh" #include #define prefix_ @@ -49,8 +49,8 @@ BOOST_AUTO_UNIT_TEST(connector) // It doesn't matter, which type of connectors we use here since they are all based on // Connector. - debug::ActivePacketSource source; - debug::PassivePacketSink target; + debug::ActiveSource source; + debug::PassiveSink target; ppi::connect(source.output,target.input); ppi::init(); @@ -63,13 +63,13 @@ BOOST_AUTO_UNIT_TEST(connector) BOOST_AUTO_UNIT_TEST(passiveConnector) { - debug::ActivePacketSource source; - debug::PassivePacketSink target; + debug::ActiveSource source; + debug::PassiveSink target; ppi::connect(source.output,target.input); ppi::init(); - // onRequest is implicitly tested within the PassivePacketSink implementation which is tested + // onRequest is implicitly tested within the PassiveSink implementation which is tested // in DebugModules.test.cc target.input.throttle(); @@ -92,8 +92,8 @@ namespace { BOOST_AUTO_UNIT_TEST(activeConnector) { - debug::ActivePacketSource source; - debug::PassivePacketSink target; + debug::ActiveSource source; + debug::PassiveSink target; ppi::connect(source.output,target.input); ppi::init(); @@ -124,16 +124,16 @@ BOOST_AUTO_UNIT_TEST(activeConnector) BOOST_AUTO_UNIT_TEST(inputConnector) { - debug::ActivePacketSource source; - debug::PassivePacketSink target; + debug::ActiveSource source; + debug::PassiveSink target; ppi::connect(source.output,target.input); ppi::init(); - // operator() is implicitly tested within the Active/PassivePacketSink implementation which is + // operator() is implicitly tested within the Active/PassiveSink implementation which is // tested in DebugModules.test.cc - // peek() is implicitly tested within the Active/PassivePacketSink implementation + // peek() is implicitly tested within the Active/PassiveSink implementation BOOST_CHECK_EQUAL ( & target.input.peer(), & source.output ); @@ -144,13 +144,13 @@ BOOST_AUTO_UNIT_TEST(inputConnector) BOOST_AUTO_UNIT_TEST(outputConnector) { - debug::ActivePacketSource source; - debug::PassivePacketSink target; + debug::ActiveSource source; + debug::PassiveSink target; ppi::connect(source.output,target.input); ppi::init(); - // operator() is implicitly tested within the Active/PassivePacketSource implementation which is + // operator() is implicitly tested within the Active/PassiveSource implementation which is // tested in DebugModules.test.cc BOOST_CHECK_EQUAL( & source.output.peer(), & target.input ); @@ -164,7 +164,7 @@ namespace { SENF_PPI_MODULE(PassiveInputTest); public: - ppi::connector::PassiveInput input; + ppi::connector::PassiveInput<> input; PassiveInputTest() : counter() { noroute(input); @@ -181,7 +181,7 @@ namespace { BOOST_AUTO_UNIT_TEST(passiveInput) { - debug::ActivePacketSource source; + debug::ActiveSource source; PassiveInputTest target; ppi::connect(source,target); @@ -224,8 +224,8 @@ BOOST_AUTO_UNIT_TEST(passiveInput) BOOST_AUTO_UNIT_TEST(passiveOutput) { - debug::PassivePacketSource source; - debug::ActivePacketSink target; + debug::PassiveSource source; + debug::ActiveSink target; ppi::connect(source,target); ppi::init(); @@ -245,8 +245,8 @@ BOOST_AUTO_UNIT_TEST(passiveOutput) BOOST_AUTO_UNIT_TEST(activeInput) { - debug::PassivePacketSource source; - debug::ActivePacketSink target; + debug::PassiveSource source; + debug::ActiveSink target; ppi::connect(source,target); ppi::init(); @@ -270,8 +270,8 @@ BOOST_AUTO_UNIT_TEST(activeInput) BOOST_AUTO_UNIT_TEST(activeOutput) { - debug::ActivePacketSource source; - debug::PassivePacketSink target; + debug::ActiveSource source; + debug::PassiveSink target; ppi::connect(source,target); ppi::init(); @@ -284,6 +284,71 @@ BOOST_AUTO_UNIT_TEST(activeOutput) // connect() is tested indirectly via ppi::connect } +namespace { + + class TypedInputTest + : public ppi::module::Module + { + SENF_PPI_MODULE(TypedInputTest); + + public: + ppi::connector::PassiveInput input; + + TypedInputTest() { + noroute(input); + input.onRequest(&TypedInputTest::request); + } + + void request() { + (void) input(); + (void) input.read(); + } + }; + + class TypedOutputTest + : public ppi::module::Module + { + SENF_PPI_MODULE(TypedOutputTest); + + public: + ppi::connector::PassiveOutput output; + + TypedOutputTest() { + noroute(output); + output.onRequest(&TypedOutputTest::request); + } + + void request() { + senf::DataPacket pkg (senf::DataPacket::create()); + output(pkg); + output.write(pkg); + } + }; + +} + +BOOST_AUTO_UNIT_TEST(typedInput) +{ + debug::ActiveSource source; + TypedInputTest target; + + ppi::connect(source,target); + ppi::init(); + + senf::Packet p (senf::DataPacket::create()); + source.submit(p); +} + +BOOST_AUTO_UNIT_TEST(tyepdOutput) +{ + TypedOutputTest source; + debug::ActiveSink target; + + ppi::connect(source,target); + ppi::init(); + + (void) target.request(); +} ///////////////////////////////cc.e//////////////////////////////////////// #undef prefix_