X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=senf%2FPackets%2FListNParser.test.cc;h=f909cecbbe2ab335791360c5cc9f4b803eb391cf;hb=7ee689fe38d66aa3a0004d55e8708750d35adc0b;hp=a28f765d5ed75f70f1df98d05c9885c4bb02e704;hpb=9cb871b939efe93e35dd96808d25089399acfc46;p=senf.git diff --git a/senf/Packets/ListNParser.test.cc b/senf/Packets/ListNParser.test.cc index a28f765..f909cec 100644 --- a/senf/Packets/ListNParser.test.cc +++ b/senf/Packets/ListNParser.test.cc @@ -33,7 +33,7 @@ #include #define prefix_ -///////////////////////////////cc.p//////////////////////////////////////// +//-///////////////////////////////////////////////////////////////////////////////////////////////// namespace { struct VoidPacket_Type : public senf::PacketTypeBase @@ -48,6 +48,21 @@ namespace { SENF_PARSER_VECTOR( vec, size, senf::UInt16Parser ); SENF_PARSER_FINALIZE(MyVec); + + typedef std::vector value_type; + + value_type value() const { + value_type v (vec().begin(), vec().end()); + return v; + } + void value(value_type const & v) { + vec_t::container container (vec()); + container.clear(); + for (value_type::const_iterator i=v.begin(); i!=v.end(); ++i) + container.push_back( *i); + } + operator value_type() const { return value(); } + MyVec const & operator= (value_type const & other) { value(other); return *this; } }; typedef senf::ListParser< @@ -151,20 +166,44 @@ namespace { static unsigned set(unsigned v) { return 2*v; } }; - struct TestListParser + struct TestListParserBase : public senf::PacketParserBase { # include SENF_PARSER() - SENF_PARSER_PRIVATE_FIELD ( size1 , senf::UInt8Parser ); - SENF_PARSER_PRIVATE_FIELD ( size2 , senf::UInt8Parser ); - SENF_PARSER_FIELD ( dummy , senf::UInt32Parser ); - SENF_PARSER_LIST ( list1 , transform(TestTransform, size1) , MyVec ); - SENF_PARSER_LIST ( list2 , size2 , MyVec ); + SENF_PARSER_FIELD_RO ( size1 , senf::UInt8Parser ); + SENF_PARSER_FIELD_RO ( size2 , senf::UInt8Parser ); + + SENF_PARSER_FINALIZE(TestListParserBase); + }; + + struct TestListParser + : public TestListParserBase + { +# include SENF_PARSER() + SENF_PARSER_INHERIT ( TestListParserBase ); + + SENF_PARSER_FIELD ( dummy , senf::UInt32Parser ); + SENF_PARSER_LIST ( list1 , transform(TestTransform, size1) , MyVec ); + SENF_PARSER_LIST ( list2 , size2 , MyVec ); SENF_PARSER_FINALIZE(TestListParser); }; + struct TestListPacketType + : public senf::PacketTypeBase, + public senf::PacketTypeMixin + { + typedef senf::PacketTypeMixin mixin; + typedef senf::ConcretePacket packet; + typedef TestListParser parser; + + using mixin::nextPacketRange; + using mixin::initSize; + using mixin::init; + }; + typedef senf::ConcretePacket TestListPacket; + } SENF_AUTO_UNIT_TEST(listMacro) @@ -229,10 +268,20 @@ SENF_AUTO_UNIT_TEST(listMacro) ++i; BOOST_CHECK( i == list.end() ); } +} + +SENF_AUTO_UNIT_TEST(listMacro_stress) +{ + TestListPacket testListPacket (TestListPacket::create()); + for (unsigned i=0; i<42; ++i) { + MyVec::value_type vec( 4, 42); + testListPacket->list2().push_back( vec); + } + BOOST_CHECK_EQUAL( testListPacket->list2().size(), 42u ); } -///////////////////////////////cc.e//////////////////////////////////////// +//-///////////////////////////////////////////////////////////////////////////////////////////////// #undef prefix_