X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=senf%2FSocket%2FProtocols%2FINet%2FINet6Address.test.cc;h=e342b27a60748817c3163ce428dd09e48d7037ca;hb=afae50abf125df375ff1610b7a659f9b1da61bc0;hp=11dd1973f8c8956d26c0a593065baad304892725;hpb=5e230d44a5ea8916dc41f4a5b9958a26fbf8e1a0;p=senf.git diff --git a/senf/Socket/Protocols/INet/INet6Address.test.cc b/senf/Socket/Protocols/INet/INet6Address.test.cc index 11dd197..e342b27 100644 --- a/senf/Socket/Protocols/INet/INet6Address.test.cc +++ b/senf/Socket/Protocols/INet/INet6Address.test.cc @@ -29,6 +29,7 @@ // Custom includes #include "INet6Address.hh" #include +#include #include #include @@ -36,47 +37,7 @@ #define prefix_ ///////////////////////////////cc.p//////////////////////////////////////// -namespace { - - template - prefix_ ForwardIterator1 find_if_mask(unsigned bits, ForwardIterator1 b1, - ForwardIterator1 e1, ForwardIterator2 b2, - Function fn) - { - std::cerr << ">>> " << bits << ' ' << e1-b1 << '\n'; - for(; bits>8 && b1 != e1; bits -= 8, ++b1, ++b2) - if (fn(*b1, *b2, boost::lambda::make_const(0xFFu))) - return b1; - std::cerr << ">>> " << bits << ' ' << e1-b1 << '\n'; - if (bits > 0 && b1 != e1) - if (fn( *(b1++), *(b2++), boost::lambda::make_const(~ senf::detail::low_bits_mask(8-bits)))) - return b1; - std::cerr << ">>> " << bits << ' ' << e1-b1 << '\n'; - for(; b1 != e1; ++b1, ++b2) - if (fn(*b1, *b2, boost::lambda::make_const(0u))) - return b1; - return e1; - } - - bool match(senf::INet6Network const & n, senf::INet6Address a) - { - using boost::lambda::_1; - using boost::lambda::_2; - using boost::lambda::_3; - using boost::lambda::ret; - using boost::lambda::constant; - senf::INet6Address na (n.address()); - return find_if_mask( - n.prefix_len(), na.begin(), na.end(), a.begin(), - ( - std::cerr << constant(">> ") << _1 << ' ' << _2 << ' ' << ret(_3) << '\n', - _1 != (_2 & _3) - )) == na.end(); - } - -} - -BOOST_AUTO_UNIT_TEST(inet6Address) +SENF_AUTO_UNIT_TEST(inet6Address) { using senf::INet6Address; using senf::INet4Address; @@ -101,12 +62,12 @@ BOOST_AUTO_UNIT_TEST(inet6Address) BOOST_CHECK_EQUAL( addr1[13], 14 ); BOOST_CHECK_EQUAL( addr1[14], 15 ); BOOST_CHECK_EQUAL( addr1[15], 0 ); - BOOST_CHECK( INet6Address::from_string("www.go6.net") != INet6Address::None ); + SENF_CHECK_NOT_EQUAL( INet6Address::from_string("www.go6.net"), INet6Address::None ); INet6Address addr2; BOOST_CHECK_EQUAL( senf::str(addr2), "::" ); addr2 = INet6Address::from_string("::1"); - BOOST_CHECK( addr1 != addr2 ); - addr1 =INet6Address::from_string("::1"); + SENF_CHECK_NOT_EQUAL( addr1, addr2 ); + addr1 = INet6Address::from_string("::1"); BOOST_CHECK_EQUAL( addr1, addr2 ); addr1 = INet6Address::None; addr2 = INet6Address::from_string("::"); @@ -203,7 +164,7 @@ BOOST_AUTO_UNIT_TEST(inet6Address) } } -BOOST_AUTO_UNIT_TEST(inet6Network) +SENF_AUTO_UNIT_TEST(inet6Network) { using senf::INet6Address; using senf::INet6Network; @@ -219,13 +180,13 @@ BOOST_AUTO_UNIT_TEST(inet6Network) BOOST_CHECK_EQUAL( net2.address(), INet6Address::from_string("2001:db8:1230::") ); BOOST_CHECK_EQUAL( net2.prefix_len(), 44u ); - BOOST_CHECK( net != net2 ); + SENF_CHECK_NOT_EQUAL( net, net2 ); BOOST_CHECK( net.match(INet6Address::from_string("ff14:1234::1")) ); BOOST_CHECK( ! net2.match(INet6Address::from_string("ff13:1234::1")) ); BOOST_CHECK( ! net.match(net2) ); BOOST_CHECK( net2.match(INet6Network("2001:db8:1234::/48")) ); BOOST_CHECK( ! net2.match(INet6Network("2001:db8:1234::/32")) ); - + BOOST_CHECK( ! INet6Network("ff14:1234::1/128").match(INet6Network("ff14:1234::2/128")) ); BOOST_CHECK_EQUAL( senf::str(net2), "2001:db8:1230::/44" ); @@ -235,6 +196,22 @@ BOOST_AUTO_UNIT_TEST(inet6Network) BOOST_CHECK_THROW( INet6Network(""), AddressSyntaxException ); BOOST_CHECK_THROW( INet6Network("2001:db8:1234::/beef"), AddressSyntaxException ); + + { + std::stringstream str; + INet6Network net; + str >> net; + BOOST_CHECK( str.fail()); + } + { + std::stringstream str; + INet6Network net ("2001:db8:1230::/44"); + str << net; + BOOST_CHECK_EQUAL( str.str(), "2001:db8:1230::/44"); + str >> net; + BOOST_CHECK( ! str.fail()); + BOOST_CHECK_EQUAL(net, INet6Network("2001:db8:1230::/44")); + } } ///////////////////////////////cc.e////////////////////////////////////////