0a53ae4405be8d7657052dacc1d26a946e096084
[senf.git] / Packets / ListBParser.test.cc
1 // $Id$
2 //
3 // Copyright (C) 2007
4 // Fraunhofer Institute for Open Communication Systems (FOKUS)
5 // Competence Center NETwork research (NET), St. Augustin, GERMANY
6 //     Stefan Bund <g0dil@berlios.de>
7 //
8 // This program is free software; you can redistribute it and/or modify
9 // it under the terms of the GNU General Public License as published by
10 // the Free Software Foundation; either version 2 of the License, or
11 // (at your option) any later version.
12 //
13 // This program is distributed in the hope that it will be useful,
14 // but WITHOUT ANY WARRANTY; without even the implied warranty of
15 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
16 // GNU General Public License for more details.
17 //
18 // You should have received a copy of the GNU General Public License
19 // along with this program; if not, write to the
20 // Free Software Foundation, Inc.,
21 // 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
22
23 /** \file
24     \brief ListBParser.test unit tests */
25
26 //#include "ListBParser.test.hh"
27 //#include "ListBParser.test.ih"
28
29 // Custom includes
30 #include "Packets.hh"
31
32 #include "../Utils/auto_unit_test.hh"
33 #include <boost/test/test_tools.hpp>
34
35 #define prefix_
36 ///////////////////////////////cc.p////////////////////////////////////////
37
38 namespace {
39     struct VoidPacket : public senf::PacketTypeBase
40     {};
41
42     struct VectorParser : public senf::PacketParserBase
43     {
44 #       include SENF_PARSER()
45
46         SENF_PARSER_PRIVATE_FIELD( size, senf::UInt8Parser );
47         SENF_PARSER_VEC_N( vec, size, senf::UInt16Parser );
48
49         SENF_PARSER_FINALIZE(VectorParser);
50     };
51
52     typedef senf::ListBParser<VectorParser,senf::UInt16Parser>::parser MyListBParser;
53 }
54
55 BOOST_AUTO_UNIT_TEST(ListBParser)
56 {
57     senf::PacketInterpreterBase::ptr pi (senf::PacketInterpreter<VoidPacket>::create(
58             MyListBParser::init_bytes));
59     
60     MyListBParser p (pi->data().begin(),&pi->data());
61     p.init();
62     BOOST_CHECK_EQUAL( p.size(), 0u );
63     BOOST_CHECK_EQUAL( p.bytes(), 2u );
64     BOOST_CHECK( p.empty() );
65
66     // the mutators are really tested together with the container wrappers since they are based
67     // on the container wrapper. Here we only need one call to make the list larger ...
68
69     p.push_back_space();
70     p = MyListBParser(pi->data().begin(),&pi->data());
71     BOOST_CHECK_EQUAL( p.bytes(), 3u );
72     BOOST_CHECK_EQUAL( p.size(), 1u );
73     BOOST_CHECK( ! p.empty() );
74 }
75
76 BOOST_AUTO_UNIT_TEST(ListBParser_container)
77 {
78     senf::PacketInterpreterBase::ptr pi (senf::PacketInterpreter<VoidPacket>::create(
79             MyListBParser::init_bytes));
80     
81     {
82         MyListBParser::container c (MyListBParser(pi->data().begin(),&pi->data()));
83      
84         BOOST_CHECK_EQUAL( c.size(), 0u );
85         BOOST_CHECK_EQUAL( c.bytes(), 2u );
86         BOOST_CHECK( c.begin() == c.end() );
87         
88         c.shift(c.begin());
89         BOOST_CHECK_EQUAL( c.size(), 1u );
90         BOOST_CHECK_EQUAL( c.bytes(), 3u );
91
92         BOOST_CHECK_EQUAL( c.front().vec().size(), 0u );
93         c.front().vec().push_back(0x1234u);
94         BOOST_CHECK_EQUAL( c.bytes(), 5u );
95
96         {
97             senf::PacketInterpreterBase::ptr pi2 (senf::PacketInterpreter<VoidPacket>::create(
98                     MyListBParser::init_bytes));
99             MyListBParser::container c2 (MyListBParser(pi2->data().begin(),&pi2->data()));
100             c2.push_back_space();
101             {
102                 VectorParser::vec_t::container c2v (c2.front().vec());
103                 c2v.push_back(0x2345u);
104                 c2v.push_back(0x3456u);
105             }
106
107             BOOST_CHECK_EQUAL(c2.size(), 1u);
108             BOOST_CHECK_EQUAL(c2.bytes(), 7u);
109             
110             c.insert(c.end(),c2.back());
111             BOOST_CHECK_EQUAL( c.size(), 2u );
112             BOOST_CHECK_EQUAL( c.bytes(), 10u );
113             BOOST_CHECK_EQUAL( c.back().vec()[0], 0x2345u );
114             BOOST_CHECK_EQUAL( c.back().bytes(), c2.back().bytes() );
115
116             c2.back().vec()[0] << 0x1357u;
117             c.insert(boost::next(c.begin()), 2u, c2.back());
118             BOOST_CHECK_EQUAL( c.size(), 4u );
119             BOOST_CHECK_EQUAL( c.bytes(), 20u );
120             BOOST_CHECK_EQUAL( (*boost::next(c.begin())).vec()[0], 0x1357u ); 
121             BOOST_CHECK_EQUAL( (*boost::next(c.begin(),2)).vec()[0], 0x1357u );
122
123             c2.back().vec()[0] << 0x2468u;
124             c.insert(c.begin(),c2.begin(),c2.end());
125             BOOST_CHECK_EQUAL( c.size(), 5u );
126             BOOST_CHECK_EQUAL( c.bytes(), 25u );
127             BOOST_CHECK_EQUAL( c.front().vec()[0], 0x2468u );
128
129             c.erase(c.begin(),2);
130             BOOST_CHECK_EQUAL( c.size(), 3u );
131             BOOST_CHECK_EQUAL( c.bytes(), 17u );
132             BOOST_CHECK_EQUAL( c.front().vec()[0],0x1357u );
133             BOOST_CHECK_EQUAL( c.back().vec()[0], 0x2345u );
134             
135             c.erase((boost::next(c.begin(),2)),c.end());
136             BOOST_CHECK_EQUAL( c.size(), 2u );
137             BOOST_CHECK_EQUAL( c.bytes(), 12u );
138             BOOST_CHECK_EQUAL( c.front().vec()[0],0x1357u );
139             BOOST_CHECK_EQUAL( c.back().vec()[0], 0x1357u );
140
141             c.clear();
142             BOOST_CHECK_EQUAL( c.size(), 0u );
143             BOOST_CHECK_EQUAL( c.bytes(), 2u );
144        }
145     }
146 }
147
148 namespace {
149     
150     struct TestListParser
151         : public senf::PacketParserBase
152     {
153 #       include SENF_PARSER()
154
155         SENF_PARSER_PRIVATE_FIELD ( size1 , senf::UInt8Parser );
156         SENF_PARSER_PRIVATE_FIELD ( size2 , senf::UInt8Parser );
157         SENF_PARSER_FIELD         ( dummy , senf::UInt32Parser );
158         SENF_PARSER_LIST          ( list1  , bytes(size1) , VectorParser );
159         SENF_PARSER_LIST          ( list2  , bytes(size2) , VectorParser );
160
161         SENF_PARSER_FINALIZE(TestListParser);
162     };
163
164 }
165
166 BOOST_AUTO_UNIT_TEST(listBytesMacro)
167 {
168     unsigned char data[] = { 0x08,                   // size1
169                              0x09,                   // size2
170                              0x01, 0x02, 0x03, 0x04, // dummy
171                              0x01,                   // list1()[0].size()
172                              0x05, 0x06,             // list1().vec()[0]
173                              0x02,                   // list1()[1].size()
174                              0x07, 0x08,             // list1()[1].vec()[0]
175                              0x09, 0x0A,             // list1()[1].vec()[1]
176                              0x00,                   // list2()[0].size()
177                              0x02,                   // list2()[1].size()
178                              0x0B, 0x0C,             // list2()[1].vec()[0]
179                              0x0D, 0x0E,             // list2()[1].vec()[1]
180                              0x01,                   // list2()[2].size()
181                              0x0F, 0x10 };           // list2()[2].vec()[0]
182     
183     senf::DataPacket p (senf::DataPacket::create(data));
184     TestListParser parser (p.data().begin(), &p.data());
185     
186     BOOST_CHECK_EQUAL( parser.list1().size(), 2u );
187     BOOST_CHECK_EQUAL( parser.list2().size(), 3u );
188     BOOST_CHECK_EQUAL( parser.dummy(), 0x01020304u );
189
190     TestListParser::list2_t::container list2 (parser.list2());
191
192     {
193         TestListParser::list1_t::container list (parser.list1());
194         BOOST_CHECK_EQUAL( list.size(), 2u );
195
196         TestListParser::list1_t::container::iterator i (list.begin());
197         BOOST_CHECK_EQUAL( i->vec().size(), 1u );
198         BOOST_CHECK_EQUAL( i->vec()[0], 0x0506u );
199
200         ++i;
201         BOOST_CHECK_EQUAL( i->vec().size(), 2u );
202         BOOST_CHECK_EQUAL( i->vec()[0], 0x0708u );
203         BOOST_CHECK_EQUAL( i->vec()[1], 0x090Au );
204         
205         ++i;
206         BOOST_CHECK( i == list.end() );
207     }
208
209     {
210         TestListParser::list2_t::container list (parser.list2());
211         BOOST_CHECK_EQUAL( list.size(), 3u );
212
213         TestListParser::list2_t::container::iterator i (list.begin());
214         BOOST_CHECK_EQUAL( i->vec().size(), 0u );
215
216         ++i;
217         BOOST_CHECK_EQUAL( i->vec().size(), 2u );
218         BOOST_CHECK_EQUAL( i->vec()[0], 0x0B0Cu );
219         BOOST_CHECK_EQUAL( i->vec()[1], 0x0D0Eu );
220         
221         ++i;
222         BOOST_CHECK_EQUAL( i->vec().size(), 1u );
223         BOOST_CHECK_EQUAL( i->vec()[0], 0x0F10u );
224         
225         ++i;
226         BOOST_CHECK( i == list.end() );
227     }
228
229 }
230
231
232 ///////////////////////////////cc.e////////////////////////////////////////
233 #undef prefix_
234
235 \f
236 // Local Variables:
237 // mode: c++
238 // fill-column: 100
239 // comment-column: 40
240 // c-file-style: "senf"
241 // indent-tabs-mode: nil
242 // ispell-local-dictionary: "american"
243 // compile-command: "scons -u test"
244 // End: