X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=senf%2FPackets%2FListNParser.test.cc;h=f909cecbbe2ab335791360c5cc9f4b803eb391cf;hb=57daeae6f2e924ce3f16f9677c3474f531cba9e5;hp=4d356f1e16e9dd44a76b6962749d1c280969cbfd;hpb=601d1f509f5bb24df167a4dd5a20da67a0af9af8;p=senf.git diff --git a/senf/Packets/ListNParser.test.cc b/senf/Packets/ListNParser.test.cc index 4d356f1..f909cec 100644 --- a/senf/Packets/ListNParser.test.cc +++ b/senf/Packets/ListNParser.test.cc @@ -29,11 +29,11 @@ // Custom includes #include "Packets.hh" -#include "../Utils/auto_unit_test.hh" +#include #include #define prefix_ -///////////////////////////////cc.p//////////////////////////////////////// +//-///////////////////////////////////////////////////////////////////////////////////////////////// namespace { struct VoidPacket_Type : public senf::PacketTypeBase @@ -46,8 +46,23 @@ namespace { SENF_PARSER_PRIVATE_FIELD( size, senf::UInt8Parser ); 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< @@ -57,7 +72,7 @@ namespace { senf::UInt16Parser> > > MyListNParser; } -BOOST_AUTO_UNIT_TEST(ListNParser_container) +SENF_AUTO_UNIT_TEST(ListNParser_container) { VoidPacket vp (VoidPacket::create(MyListNParser::init_bytes)); MyListNParser(vp.data().begin(),&vp.data()).init(); @@ -86,7 +101,7 @@ BOOST_AUTO_UNIT_TEST(ListNParser_container) } } -BOOST_AUTO_UNIT_TEST(ListNParser) +SENF_AUTO_UNIT_TEST(ListNParser) { VoidPacket vp (VoidPacket::create(MyListNParser::init_bytes)); @@ -124,7 +139,7 @@ BOOST_AUTO_UNIT_TEST(ListNParser) BOOST_CHECK_EQUAL( p.size(), 2u ); BOOST_CHECK_EQUAL( p.bytes(), 8u ); BOOST_CHECK_EQUAL( p.back().vec().size(), 0u ); - + p.back().vec().push_front(0x0123u); BOOST_CHECK_EQUAL( p.front().vec().size(), 2u ); BOOST_CHECK_EQUAL( p.back().vec().size(), 1u ); @@ -132,7 +147,7 @@ BOOST_AUTO_UNIT_TEST(ListNParser) p.push_front_space(2u); BOOST_CHECK_EQUAL( p.size(), 4u ); BOOST_CHECK_EQUAL( p.front().vec().size(), 0u); - + p.resize(3u); BOOST_CHECK_EQUAL( p.size(), 3u ); BOOST_CHECK_EQUAL( p.back().vec()[0], 0x1234u ); @@ -143,7 +158,7 @@ BOOST_AUTO_UNIT_TEST(ListNParser) } namespace { - + struct TestTransform { typedef unsigned value_type; @@ -151,23 +166,47 @@ 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; + } -BOOST_AUTO_UNIT_TEST(listMacro) +SENF_AUTO_UNIT_TEST(listMacro) { unsigned char data[] = { 0x04, // size1 0x03, // size2 @@ -183,10 +222,10 @@ BOOST_AUTO_UNIT_TEST(listMacro) 0x0D, 0x0E, // list2()[1].vec()[1] 0x01, // list2()[2].size() 0x0F, 0x10 }; // list2()[2].vec()[0] - + senf::DataPacket p (senf::DataPacket::create(data)); TestListParser parser (p.data().begin(), &p.data()); - + BOOST_CHECK_EQUAL( parser.list1().size(), 2u ); BOOST_CHECK_EQUAL( parser.list2().size(), 3u ); BOOST_CHECK_EQUAL( parser.dummy(), 0x01020304u ); @@ -205,7 +244,7 @@ BOOST_AUTO_UNIT_TEST(listMacro) BOOST_CHECK_EQUAL( i->vec().size(), 2u ); BOOST_CHECK_EQUAL( i->vec()[0], 0x0708u ); BOOST_CHECK_EQUAL( i->vec()[1], 0x090Au ); - + ++i; BOOST_CHECK( i == list.end() ); } @@ -221,18 +260,28 @@ BOOST_AUTO_UNIT_TEST(listMacro) BOOST_CHECK_EQUAL( i->vec().size(), 2u ); BOOST_CHECK_EQUAL( i->vec()[0], 0x0B0Cu ); BOOST_CHECK_EQUAL( i->vec()[1], 0x0D0Eu ); - + ++i; BOOST_CHECK_EQUAL( i->vec().size(), 1u ); BOOST_CHECK_EQUAL( i->vec()[0], 0x0F10u ); - + ++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_