// 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
/** \file
- \brief ListBParser.test unit tests */
+ \brief ListBParser unit tests */
//#include "ListBParser.test.hh"
//#include "ListBParser.test.ih"
# include SENF_PARSER()
SENF_PARSER_PRIVATE_FIELD( size, senf::UInt8Parser );
- SENF_PARSER_VEC_N( vec, size, senf::UInt16Parser );
+ SENF_PARSER_VECTOR( vec, size, senf::UInt16Parser );
SENF_PARSER_FINALIZE(VectorParser);
};
- typedef senf::ListBParser<VectorParser,senf::UInt16Parser>::parser MyListBParser;
+ typedef senf::ListParser<
+ senf::detail::ListBParser_Policy<
+ VectorParser,
+ senf::detail::PrefixAuxParserPolicy<senf::UInt16Parser> > > MyListBParser;
}
BOOST_AUTO_UNIT_TEST(ListBParser)
BOOST_CHECK_EQUAL( p.size(), 0u );
BOOST_CHECK_EQUAL( p.bytes(), 2u );
BOOST_CHECK( p.empty() );
- BOOST_CHECK( p.begin() == p.end() );
// the mutators are really tested together with the container wrappers since they are based
// on the container wrapper. Here we only need one call to make the list larger ...
BOOST_CHECK_EQUAL( p.bytes(), 3u );
BOOST_CHECK_EQUAL( p.size(), 1u );
BOOST_CHECK( ! p.empty() );
- BOOST_CHECK( p.begin() != p.end() );
}
BOOST_AUTO_UNIT_TEST(ListBParser_container)
}
}
+namespace {
+
+ struct TestTransform
+ {
+ typedef unsigned value_type;
+ static unsigned get(unsigned v) { return v/2; }
+ static unsigned set(unsigned v) { return 2*v; }
+ };
+
+ struct TestListParser
+ : 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 , bytes(size1) , VectorParser );
+ SENF_PARSER_LIST ( list2 , transform(TestTransform, bytes(size2)) ,
+ VectorParser );
+
+ SENF_PARSER_FINALIZE(TestListParser);
+ };
+
+}
+
+BOOST_AUTO_UNIT_TEST(listBytesMacro)
+{
+ unsigned char data[] = { 8, // size1
+ 18, // size2
+ 0x01, 0x02, 0x03, 0x04, // dummy
+ 0x01, // list1()[0].size()
+ 0x05, 0x06, // list1().vec()[0]
+ 0x02, // list1()[1].size()
+ 0x07, 0x08, // list1()[1].vec()[0]
+ 0x09, 0x0A, // list1()[1].vec()[1]
+ 0x00, // list2()[0].size()
+ 0x02, // list2()[1].size()
+ 0x0B, 0x0C, // list2()[1].vec()[0]
+ 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 );
+
+ TestListParser::list2_t::container list2 (parser.list2());
+
+ {
+ TestListParser::list1_t::container list (parser.list1());
+ BOOST_CHECK_EQUAL( list.size(), 2u );
+
+ TestListParser::list1_t::container::iterator i (list.begin());
+ BOOST_CHECK_EQUAL( i->vec().size(), 1u );
+ BOOST_CHECK_EQUAL( i->vec()[0], 0x0506u );
+
+ ++i;
+ 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() );
+ }
+
+ {
+ TestListParser::list2_t::container list (parser.list2());
+ BOOST_CHECK_EQUAL( list.size(), 3u );
+
+ TestListParser::list2_t::container::iterator i (list.begin());
+ BOOST_CHECK_EQUAL( i->vec().size(), 0u );
+
+ ++i;
+ 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() );
+ }
+
+}
+
+namespace {
+
+ struct TestPacketSizeList
+ : public senf::PacketParserBase
+ {
+# include SENF_PARSER()
+
+ SENF_PARSER_LIST ( list, packetSize(), VectorParser );
+
+ SENF_PARSER_FINALIZE(TestPacketSizeList);
+ };
+
+
+}
+
+BOOST_AUTO_UNIT_TEST(listBytesParser_packetSize)
+{
+ unsigned char data[] = { 0x01, // list()[0].vec().size()
+ 0x05, 0x06, // list()[0].vec()[0]
+ 0x02, // list()[1].vec().size()
+ 0x07, 0x08, // list()[1].vec()[0]
+ 0x09, 0x0A, // list()[1].vec()[1]
+ 0x00, // list()[2].vec().size()
+ 0x02, // list()[3].vec().size()
+ 0x0B, 0x0C, // list()[3].vec()[0]
+ 0x0D, 0x0E, // list()[3].vec()[1]
+ 0x01, // list()[4].vec().size()
+ 0x0F, 0x10 }; // list()[4].vec()[0]
+
+ senf::DataPacket p (senf::DataPacket::create(data));
+
+ {
+ TestPacketSizeList l (p.data().begin(), &p.data());
+ BOOST_CHECK_EQUAL( l.list().size(), 5u );
+
+ TestPacketSizeList::list_t::container c (l.list());
+ TestPacketSizeList::list_t::container::iterator i (c.begin());
+
+ senf::UInt16Parser::value_type vec0[] = { 0x0506 };
+ senf::UInt16Parser::value_type vec1[] = { 0x0708, 0x090A };
+ senf::UInt16Parser::value_type vec2[] = {};
+ senf::UInt16Parser::value_type vec3[] = { 0x0B0C, 0x0D0E };
+ senf::UInt16Parser::value_type vec4[] = { 0x0F10 };
+
+ BOOST_CHECK_EQUAL_COLLECTIONS( i->vec().begin(), i->vec().end(),
+ vec0, vec0+sizeof(vec0)/sizeof(vec0[0]) );
+ ++ i;
+ BOOST_CHECK_EQUAL_COLLECTIONS( i->vec().begin(), i->vec().end(),
+ vec1, vec1+sizeof(vec1)/sizeof(vec1[0]) );
+ ++ i;
+ BOOST_CHECK_EQUAL_COLLECTIONS( i->vec().begin(), i->vec().end(),
+ vec2, vec2+sizeof(vec2)/sizeof(vec2[0]) );
+ ++ i;
+ BOOST_CHECK_EQUAL_COLLECTIONS( i->vec().begin(), i->vec().end(),
+ vec3, vec3+sizeof(vec3)/sizeof(vec3[0]) );
+
+ ++ i;
+ BOOST_CHECK_EQUAL_COLLECTIONS( i->vec().begin(), i->vec().end(),
+ vec4, vec4+sizeof(vec4)/sizeof(vec4[0]) );
+
+ ++ i;
+ BOOST_CHECK( i == c.end() );
+
+ i = c.begin();
+ ++i;
+ TestPacketSizeList::list_t::value_type::vec_t::container v (i->vec());
+ v.push_back(0xFEFF);
+ }
+
+ {
+ TestPacketSizeList l (p.data().begin(), &p.data());
+ BOOST_CHECK_EQUAL( l.list().size(), 5u );
+ BOOST_CHECK_EQUAL( l.list().bytes(), p.data().size() );
+
+ TestPacketSizeList::list_t::container c (l.list());
+ TestPacketSizeList::list_t::container::iterator i (c.begin());
+
+ senf::UInt16Parser::value_type vec0[] = { 0x0506 };
+ senf::UInt16Parser::value_type vec1[] = { 0x0708, 0x090A, 0xFEFF };
+ senf::UInt16Parser::value_type vec2[] = {};
+ senf::UInt16Parser::value_type vec3[] = { 0x0B0C, 0x0D0E };
+ senf::UInt16Parser::value_type vec4[] = { 0x0F10 };
+
+ BOOST_CHECK_EQUAL_COLLECTIONS( i->vec().begin(), i->vec().end(),
+ vec0, vec0+sizeof(vec0)/sizeof(vec0[0]) );
+ ++ i;
+ BOOST_CHECK_EQUAL_COLLECTIONS( i->vec().begin(), i->vec().end(),
+ vec1, vec1+sizeof(vec1)/sizeof(vec1[0]) );
+ ++ i;
+ BOOST_CHECK_EQUAL_COLLECTIONS( i->vec().begin(), i->vec().end(),
+ vec2, vec2+sizeof(vec2)/sizeof(vec2[0]) );
+ ++ i;
+ BOOST_CHECK_EQUAL_COLLECTIONS( i->vec().begin(), i->vec().end(),
+ vec3, vec3+sizeof(vec3)/sizeof(vec3[0]) );
+
+ ++ i;
+ BOOST_CHECK_EQUAL_COLLECTIONS( i->vec().begin(), i->vec().end(),
+ vec4, vec4+sizeof(vec4)/sizeof(vec4[0]) );
+ ++ i;
+ BOOST_CHECK( i == c.end() );
+ }
+}
+
///////////////////////////////cc.e////////////////////////////////////////
#undef prefix_