Utils/Termlib: Extend the completion API
[senf.git] / Packets / VectorParser.test.cc
index d827bc9..aa554b2 100644 (file)
@@ -20,7 +20,8 @@
 // Free Software Foundation, Inc.,
 // 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
 
-// Unit tests
+/** \file
+    \brief VectorParser unit tests */
 
 //#include "VectorParser.test.hh"
 //#include "VectorParser.test.ih"
@@ -262,9 +263,6 @@ BOOST_AUTO_UNIT_TEST(vectorMacro_parse)
 
 BOOST_AUTO_UNIT_TEST(vectorMacro_create)
 {
-    /*
-     * This test fails with "... is an inaccessible base of ..." error
-     * see bugtracker @ berlios
     TestVectorPacket p (TestVectorPacket::create());
     p->dummy() = 0x01020304u;
     p->vec1().push_back( 0x0506u);
@@ -285,7 +283,91 @@ BOOST_AUTO_UNIT_TEST(vectorMacro_create)
             0x0D, 0x0E };           // vec2[1]
     
     BOOST_CHECK( equal( p.data().begin(), p.data().end(), data ));
-     */
+}
+
+namespace {
+    
+    struct TestVectorBaseParser 
+        : public senf::PacketParserBase
+    {
+#       include SENF_PARSER()
+
+        SENF_PARSER_PRIVATE_FIELD ( size1 , senf::UInt8Parser );
+        SENF_PARSER_FIELD_RO      ( size2 , senf::UInt8Parser );
+        SENF_PARSER_FIELD         ( dummy , senf::UInt32Parser );\
+
+        SENF_PARSER_FINALIZE( TestVectorBaseParser );
+    };
+
+    struct TestVectorDerivedParser
+        : public TestVectorBaseParser
+    {
+#       include SENF_PARSER()
+
+        SENF_PARSER_INHERIT(TestVectorBaseParser);
+
+        SENF_PARSER_VECTOR        ( vec1  , transform(TestTransform, size1) , senf::UInt16Parser );
+        SENF_PARSER_VECTOR        ( vec2  , bytes(size2) , senf::UInt16Parser );
+
+        SENF_PARSER_FINALIZE( TestVectorDerivedParser );
+    };
+
+}
+
+BOOST_AUTO_UNIT_TEST(vectorMacro_inherit)
+{
+    unsigned char data[] = { 0x05,                   // size1
+                             0x04,                   // size2
+                             0x01, 0x02, 0x03, 0x04, // dummy
+                             0x05, 0x06,             // vec1[0]
+                             0x07, 0x08,             // vec1[1]
+                             0x09, 0x0A,             // vec1[2]
+                             0x0B, 0x0C,             // vec2[0]
+                             0x0D, 0x0E };           // vec2[1]
+
+    senf::DataPacket p (senf::DataPacket::create(data));
+    TestVectorDerivedParser parser (p.data().begin(), &p.data());
+    
+    BOOST_CHECK_EQUAL( parser.vec1().size(), 3u );
+    BOOST_CHECK_EQUAL( parser.vec2().size(), 2u );
+    BOOST_CHECK_EQUAL( parser.dummy(), 0x01020304u );
+    BOOST_CHECK_EQUAL( parser.vec1()[0], 0x0506u );
+    BOOST_CHECK_EQUAL( parser.vec1()[1], 0x0708u );
+    BOOST_CHECK_EQUAL( parser.vec1()[2], 0x090Au );
+    BOOST_CHECK_EQUAL( parser.vec2()[0], 0x0B0Cu );
+    BOOST_CHECK_EQUAL( parser.vec2()[1], 0x0D0Eu );
+}
+
+namespace {
+
+    struct TestPacketSizeVectorParser
+        : public senf::PacketParserBase
+    {
+#       include SENF_PARSER()
+
+        SENF_PARSER_VECTOR        ( vec   , packetSize() , senf::UInt16Parser );
+        
+        SENF_PARSER_FINALIZE( TestPacketSizeVectorParser );
+    };
+
+}
+
+BOOST_AUTO_UNIT_TEST(vectorMacro_packetSize)
+{
+    unsigned char data[] = { 0x11, 0x12, 0x13, 0x14, 0x15, 0x16,
+                             0x21, 0x22, 0x23, 0x24, 0x25, 0x26 };
+
+    senf::DataPacket p (senf::DataPacket::create(data));
+    TestPacketSizeVectorParser parser (p.data().begin(), &p.data());
+
+    {
+        BOOST_CHECK_EQUAL( parser.vec().size(), 6u );
+        BOOST_CHECK_EQUAL( parser.vec()[0], 0x1112u );
+        BOOST_CHECK_EQUAL( parser.vec()[1], 0x1314u );
+        BOOST_CHECK_EQUAL( parser.vec()[5], 0x2526u );
+    }
+
+    // The real functionality is already tested in AuxPolixy.test.cc ...
 }
 
 ///////////////////////////////cc.e////////////////////////////////////////