X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=Packets%2FDefaultBundle%2FEthernetPacket.test.cc;h=f3dca00835558172349035d5bfeee65c22fa0f4b;hb=92f8630b75f3ef50e73c48cde58645dcd1534e27;hp=98404c5590930b34dd0feecf06ec740d194edc03;hpb=f73fa16ed5abdce272ac77f8b8b9ef2b9922c266;p=senf.git diff --git a/Packets/DefaultBundle/EthernetPacket.test.cc b/Packets/DefaultBundle/EthernetPacket.test.cc index 98404c5..f3dca00 100644 --- a/Packets/DefaultBundle/EthernetPacket.test.cc +++ b/Packets/DefaultBundle/EthernetPacket.test.cc @@ -1,8 +1,8 @@ // $Id$ // // Copyright (C) 2006 -// Fraunhofer Institute for Open Communication Systems (FOKUS) -// Competence Center NETwork research (NET), St. Augustin, GERMANY +// Fraunhofer Institute for Open Communication Systems (FOKUS) +// Competence Center NETwork research (NET), St. Augustin, GERMANY // Stefan Bund // // This program is free software; you can redistribute it and/or modify @@ -20,7 +20,8 @@ // Free Software Foundation, Inc., // 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. -// Unit tests +/** \file + \brief EthernetPacket unit tests */ //#include "EthernetPacket.test.hh" //#include "EthernetPacket.test.ih" @@ -38,16 +39,19 @@ BOOST_AUTO_UNIT_TEST(ethernetPacket_parse) { - senf::PacketData::byte data[] = { + senf::PacketData::byte data[] = { 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, // destination MAC 0x07, 0x08, 0x09, 0x0A, 0x0B, 0x0C, // source MAC - 0x10, 0x11 + 0x10, 0x11 }; // EtherType senf::EthernetPacket p (senf::EthernetPacket::create(data)); BOOST_CHECK_EQUAL( p->destination()[3], 0x04 ); BOOST_CHECK_EQUAL( p->source()[0], 0x07 ); BOOST_CHECK_EQUAL( p->type_length(), 0x1011 ); + + std::ostringstream oss (std::ostringstream::out); + SENF_CHECK_NO_THROW( p.dump( oss)); } BOOST_AUTO_UNIT_TEST(ethernetPacket_parse_chain) @@ -58,7 +62,7 @@ BOOST_AUTO_UNIT_TEST(ethernetPacket_parse_chain) 0x81, 0x00, // EtherType: VLan 0x92, 0x34, // VLAN prio, cfi, id 0xab, 0xcd, // EtherType - 0xf0, 0xf1, 0xf2, 0xf3, 0xf4 + 0xf0, 0xf1, 0xf2, 0xf3, 0xf4 }; // Payload senf::EthernetPacket p (senf::EthernetPacket::create(data)); @@ -77,18 +81,18 @@ BOOST_AUTO_UNIT_TEST(ethernetPacket_create) senf::EthernetPacket eth (senf::EthernetPacket::create()); eth->source() = senf::MACAddress::from_string("01:02:03:04:05:06"); eth->destination() = senf::MACAddress::from_string("07:08:09:0a:0b:0c"); - + senf::EthVLanPacket vlan (senf::EthVLanPacket::createAfter(eth)); vlan->priority() = 9u; vlan->cfi() = true; vlan->vlanId() = 0x234u; - eth.finalize(); + eth.finalizeAll(); BOOST_CHECK_EQUAL(eth->type_length(), 0x8100u); BOOST_CHECK_EQUAL(vlan->type(), 0u); senf::IPv4Packet ip (senf::IPv4Packet::createAfter(vlan)); - eth.finalize(); + eth.finalizeAll(); BOOST_CHECK_EQUAL(vlan->type(), 0x0800u); } @@ -97,12 +101,12 @@ BOOST_AUTO_UNIT_TEST(ethernetPacket_llcsnap) senf::EthernetPacket eth (senf::EthernetPacket::create()); eth->source() = senf::MACAddress::from_string("01:02:03:04:05:06"); eth->destination() = senf::MACAddress::from_string("07:08:09:0a:0b:0c"); - + senf::LlcSnapPacket llcsnap (senf::LlcSnapPacket::createAfter(eth)); senf::DataPacket payload (senf::DataPacket::createAfter( llcsnap, std::string("Hello, world!"))); - eth.finalize(); - + eth.finalizeAll(); + BOOST_CHECK_EQUAL( eth->type_length(), 8u + 13u); BOOST_CHECK_EQUAL( llcsnap->dsap(), 0xaa ); BOOST_CHECK_EQUAL( llcsnap->ssap(), 0xaa ); @@ -111,14 +115,14 @@ BOOST_AUTO_UNIT_TEST(ethernetPacket_llcsnap) BOOST_CHECK_EQUAL( llcsnap->type_length(), 0u); senf::IPv4Packet ip (senf::IPv4Packet::createAfter(llcsnap)); - eth.finalize(); + eth.finalizeAll(); BOOST_CHECK_EQUAL(llcsnap->type_length(), 0x0800u); } ///////////////////////////////cc.e//////////////////////////////////////// #undef prefix_ - + // Local Variables: // mode: c++ // fill-column: 100