X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=Socket%2FProtocols%2FRaw%2FMACAddress.test.cc;h=87d0686b6786c74fa114045a3e45680760fcec85;hb=81f84badf27b66dbadec9890646ca1193e998505;hp=86dfa3e2484664c70d82823fbb6d77a7262c1e29;hpb=9c67039f2a8d9c445ce21912ed814743f61b104c;p=senf.git diff --git a/Socket/Protocols/Raw/MACAddress.test.cc b/Socket/Protocols/Raw/MACAddress.test.cc index 86dfa3e..87d0686 100644 --- a/Socket/Protocols/Raw/MACAddress.test.cc +++ b/Socket/Protocols/Raw/MACAddress.test.cc @@ -1,6 +1,8 @@ -// Copyright (C) 2007 -// Fraunhofer Institut fuer offene Kommunikationssysteme (FOKUS) -// Kompetenzzentrum fuer Satelitenkommunikation (SatCom) +// $Id$ +// +// Copyright (C) 2007 +// 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 @@ -19,17 +21,17 @@ // 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. /** \file - \brief MACAddress.test unit tests */ + \brief MACAddress unit tests */ //#include "MACAddress.test.hh" //#include "MACAddress.test.ih" // Custom includes #include -#include #include "MACAddress.hh" +#include "../../../Utils/String.hh" -#include +#include "../../../Utils/auto_unit_test.hh" #include #define prefix_ @@ -37,7 +39,11 @@ BOOST_AUTO_UNIT_TEST(macAddress) { - senf::MACAddress mac (senf::MACAddress::from_string("A1-b2-C3:d4:E5:f6")); + using senf::MACAddress; + using senf::AddressSyntaxException; + + std::string test ("A1-b2-C3:d4:E5:f6"); + MACAddress mac (MACAddress::from_string(test)); BOOST_CHECK_EQUAL( mac[0], 0xA1u ); BOOST_CHECK_EQUAL( mac[1], 0xB2u ); @@ -46,10 +52,25 @@ BOOST_AUTO_UNIT_TEST(macAddress) BOOST_CHECK_EQUAL( mac[4], 0xE5u ); BOOST_CHECK_EQUAL( mac[5], 0xF6u ); - std::stringstream str; - str << mac; - BOOST_CHECK_EQUAL( str.str(), "a1:b2:c3:d4:e5:f6" ); - + { + std::stringstream str; + str >> mac; + BOOST_CHECK( str.fail()); + } + { + std::stringstream str ( "invalid_mac_address"); + str >> mac; + BOOST_CHECK( str.fail()); + } + { + std::stringstream str; + str << mac; + BOOST_CHECK_EQUAL( str.str(), "a1:b2:c3:d4:e5:f6" ); + str >> mac; + BOOST_CHECK( ! str.fail()); + } + + BOOST_CHECK_EQUAL(mac, MACAddress::from_string(test)); BOOST_CHECK( ! mac.local() ); BOOST_CHECK( mac.multicast() ); BOOST_CHECK( ! mac.broadcast() ); @@ -58,34 +79,37 @@ BOOST_AUTO_UNIT_TEST(macAddress) BOOST_CHECK_EQUAL( mac.nic(), 0xd4e5f6u ); BOOST_CHECK_EQUAL( mac.eui64(), 0xa1b2c3fffed4e5f6llu ); - senf::MACAddress mac2; + MACAddress mac2; BOOST_CHECK( ! mac2 ); - mac2 = senf::MACAddress::from_string("ff:ff:ff:ff:ff:ff"); + mac2 = MACAddress::from_string("ff:ff:ff:ff:ff:ff"); BOOST_CHECK( mac2.broadcast() ); - BOOST_CHECK_EQUAL( mac2, senf::MACAddress::Broadcast ); + BOOST_CHECK_EQUAL( mac2, MACAddress::Broadcast ); char data[] = { 0x01,0x02,0x03,0x04,0x05,0x06 }; - mac2 = senf::MACAddress::from_data(data); - BOOST_CHECK_EQUAL( boost::lexical_cast(mac2), "01:02:03:04:05:06" ); + mac2 = MACAddress::from_data(data); + BOOST_CHECK_EQUAL( senf::str(mac2), "01:02:03:04:05:06" ); BOOST_CHECK( mac != mac2 ); mac2 = mac; BOOST_CHECK( mac == mac2 ); - BOOST_CHECK_EQUAL( boost::lexical_cast(mac2), "a1:b2:c3:d4:e5:f6" ); + BOOST_CHECK_EQUAL( senf::str(mac2), "a1:b2:c3:d4:e5:f6" ); - BOOST_CHECK_THROW( senf::MACAddress::from_string("1:2:3:4:5:6"), - senf::MACAddress::SyntaxException ); - BOOST_CHECK_THROW( senf::MACAddress::from_string("01:02:03:04:05"), - senf::MACAddress::SyntaxException ); - BOOST_CHECK_THROW( senf::MACAddress::from_string("01:02:03:04:05:z6"), - senf::MACAddress::SyntaxException ); + BOOST_CHECK_THROW( MACAddress::from_string("1:2:3:4:5:6"), AddressSyntaxException ); + BOOST_CHECK_THROW( MACAddress::from_string("01:02:03:04:05"), AddressSyntaxException ); + // test all invalid ascii ranges + BOOST_CHECK_THROW( MACAddress::from_string("01:02:03:04:05:z6"), AddressSyntaxException ); + BOOST_CHECK_THROW( MACAddress::from_string("01:02:03:04:05:/6"), AddressSyntaxException ); + BOOST_CHECK_THROW( MACAddress::from_string("01:02:03:04:05:@6"), AddressSyntaxException ); + BOOST_CHECK_THROW( MACAddress::from_string("01:02:03:04:05:[6"), AddressSyntaxException ); - BOOST_CHECK_EQUAL( mac, senf::MACAddress::from_eui64(0xa1b2c3fffed4e5f6llu) ); - BOOST_CHECK_THROW( senf::MACAddress::from_eui64(0u), senf::MACAddress::SyntaxException ); + BOOST_CHECK_EQUAL( mac, MACAddress::from_eui64(0xa1b2c3fffed4e5f6llu) ); + BOOST_CHECK_THROW( MACAddress::from_eui64(0u), AddressSyntaxException ); + + BOOST_CHECK_EQUAL( MACAddress(0x1a2b3c4d5e6fULL).uint64(), 0x1a2b3c4d5e6fULL); } ///////////////////////////////cc.e//////////////////////////////////////// #undef prefix_ - + // Local Variables: // mode: c++ // fill-column: 100