X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=Packets%2FDefaultBundle%2FUDPPacket.test.cc;h=d9b4eee42e1c1ba2b57e06243f4608434e25b812;hb=d270abd20469df1cac466fe24d8dfa3dc119d987;hp=dd395406d6b250e863097da474c83e959b374e2a;hpb=7cee3cf6c1c6eecdeec08d05e8e2b99d48b1450b;p=senf.git diff --git a/Packets/DefaultBundle/UDPPacket.test.cc b/Packets/DefaultBundle/UDPPacket.test.cc index dd39540..d9b4eee 100644 --- a/Packets/DefaultBundle/UDPPacket.test.cc +++ b/Packets/DefaultBundle/UDPPacket.test.cc @@ -28,6 +28,7 @@ // Custom includes #include "UDPPacket.hh" #include "IPv4Packet.hh" +#include "IPv6Packet.hh" #include "../../Utils/auto_unit_test.hh" #include @@ -35,12 +36,12 @@ #define prefix_ ///////////////////////////////cc.p//////////////////////////////////////// -BOOST_AUTO_UNIT_TEST(udpPacket_packet) +BOOST_AUTO_UNIT_TEST(udpPacket_parse) { - unsigned char data[] = { 0x01, 0x02, 0x03, 0x04, - 0x05, 0x06, 0x07, 0x08 - }; + unsigned char data[] = { + 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08 + }; senf::UDPPacket p (senf::UDPPacket::create(data)); @@ -53,13 +54,15 @@ BOOST_AUTO_UNIT_TEST(udpPacket_packet) SENF_CHECK_NO_THROW( p.dump( oss)); } -BOOST_AUTO_UNIT_TEST(udpPacket_create) +BOOST_AUTO_UNIT_TEST(udpPacket_in_ipv6_create) { - unsigned char data[] = { 0x45, 0x00, 0x00, 0x26, 0x00, 0x00, 0x40, 0x00, - 0x40, 0x11, 0x3c, 0xc5, 0x7f, 0x00, 0x00, 0x01, - 0x7f, 0x00, 0x00, 0x01, 0x5b, 0xa0, 0x30, 0x39, - 0x00, 0x12, 0xfa, 0x6e, 0x54, 0x45, 0x53, 0x54, - 0x2d, 0x57, 0x52, 0x49, 0x54, 0x45 }; + unsigned char data[] = { + 0x45, 0x00, 0x00, 0x26, 0x00, 0x00, 0x40, 0x00, + 0x40, 0x11, 0x3c, 0xc5, 0x7f, 0x00, 0x00, 0x01, + 0x7f, 0x00, 0x00, 0x01, 0x5b, 0xa0, 0x30, 0x39, + 0x00, 0x12, 0xfa, 0x6e, 0x54, 0x45, 0x53, 0x54, + 0x2d, 0x57, 0x52, 0x49, 0x54, 0x45 + }; senf::IPv4Packet ip (senf::IPv4Packet::create()); ip->source() = senf::INet4Address::Loopback; @@ -71,7 +74,7 @@ BOOST_AUTO_UNIT_TEST(udpPacket_create) udp->source() = 23456; udp->destination() = 12345; - senf::DataPacket::createAfter(udp,std::string("TEST-WRITE")); + senf::DataPacket::createAfter(udp, std::string("TEST-WRITE")); // validates, since the checksum is 0 and thus ignored ! BOOST_CHECK( udp->validateChecksum() ); @@ -82,6 +85,47 @@ BOOST_AUTO_UNIT_TEST(udpPacket_create) BOOST_CHECK( udp->validateChecksum() ); } +BOOST_AUTO_UNIT_TEST(udpPacket_in_ipv6_parse) +{ + // captured udp packet generated with mgen send over ipv6 + unsigned char data[] = { + // IPv6 Packet + 0x60, 0x00, 0x00, 0x00, 0x00, 0x32, 0x11, 0x40, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x01, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x01, + // UDP Packet + 0x13, 0x89, 0x13, 0x88, 0x00, 0x32, 0x11, 0x23, + // mgen payload + 0x00, 0x2a, 0x02, 0x00, 0x00, 0x00, 0x00, 0x01, + 0x00, 0x00, 0x00, 0x0b, 0x49, 0xb5, 0x0a, 0x90, + 0x00, 0x09, 0x5b, 0x37, 0x13, 0x88, 0x02, 0x10, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x01, + 0x00, 0x00 + }; + + senf::IPv6Packet ip (senf::IPv6Packet::create(data)); + BOOST_CHECK_EQUAL( ip->length(), 50u ); + BOOST_CHECK_EQUAL( ip->nextHeader(), 0x11 ); + BOOST_CHECK_EQUAL( ip->hopLimit(), 64u ); + BOOST_CHECK_EQUAL( ip->source().value(), senf::INet6Address::Loopback ); + BOOST_CHECK_EQUAL( ip->destination().value(), senf::INet6Address::Loopback ); + + std::ostringstream oss (std::ostringstream::out); + SENF_CHECK_NO_THROW( ip.dump( oss)); + + BOOST_REQUIRE( ip.next().is() ); + senf::UDPPacket udp (ip.next().as()); + + BOOST_CHECK_EQUAL( udp->source(), 5001u ); + BOOST_CHECK_EQUAL( udp->destination(), 5000u ); + BOOST_CHECK_EQUAL( udp->length(), 50u ); + BOOST_CHECK_EQUAL( udp->checksum(), 0x1123 ); + + BOOST_CHECK( udp->validateChecksum() ); +} ///////////////////////////////cc.e//////////////////////////////////////// #undef prefix_