// (C) Copyright Andy Tompkins 2007. Permission to copy, use, modify, sell and // distribute this software is granted provided this copyright notice appears // in all copies. This software is provided "as is" without express or implied // warranty, and with no claim as to its suitability for any purpose. // Distributed under the Boost Software License, Version 1.0. (See // accompanying file LICENSE_1_0.txt or copy at // https://www.boost.org/LICENSE_1_0.txt) // libs/uuid/test/test_uuid.cpp -------------------------------// #include #include #include #include #include #include void test_uuid_equal_array(char const * file, int line, char const * function, boost::uuids::uuid const& lhs, const unsigned char (&rhs)[16]) { for (size_t i=0; i<16; i++) { if ( *(lhs.begin()+i) != rhs[i]) { std::cerr << file << "(" << line << "): uuid " << lhs << " not equal " << "{"; for (size_t j=0; j<16; j++) { if (j != 0) { std::cerr << " "; } std::cerr << std::hex << (int)rhs[j]; } std::cerr << "} in function '" << function << "'" << std::endl; ++boost::detail::test_errors(); return; } } } #define BOOST_TEST_UUID(lhs, rhs) ( test_uuid_equal_array(__FILE__, __LINE__, BOOST_CURRENT_FUNCTION, lhs, rhs) ) int main(int, char*[]) { using namespace boost::uuids; // uuid::static_size BOOST_TEST_EQ(uuid::static_size(), 16U); { // uuid::operator=() uuid u1 = {{0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15}}; uuid u2 = u1; BOOST_TEST_EQ(u2, u1); } { // uuid::begin(), end() uuid u = {{0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15}}; unsigned char values[] = {0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15}; BOOST_TEST_UUID(u, values); } { // uuid::begin() const, end() const const uuid u = {{0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15}}; unsigned char values[] = {0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15}; BOOST_TEST_UUID(u, values); } { // uuid::size() uuid u; // uninitialized BOOST_TEST_EQ(u.size(), 16U); } { // uuid::is_nil() uuid u1 = {{0}}; BOOST_TEST_EQ(u1.is_nil(), true); uuid u2 = {{1,0}}; BOOST_TEST_EQ(u2.is_nil(), false); } { // uuid::variant() struct Test { unsigned char octet7; boost::uuids::uuid::variant_type variant; }; const Test tests[] = { { 0x00, boost::uuids::uuid::variant_ncs } , { 0x10, boost::uuids::uuid::variant_ncs } , { 0x20, boost::uuids::uuid::variant_ncs } , { 0x30, boost::uuids::uuid::variant_ncs } , { 0x40, boost::uuids::uuid::variant_ncs } , { 0x50, boost::uuids::uuid::variant_ncs } , { 0x60, boost::uuids::uuid::variant_ncs } , { 0x70, boost::uuids::uuid::variant_ncs } , { 0x80, boost::uuids::uuid::variant_rfc_4122 } , { 0x90, boost::uuids::uuid::variant_rfc_4122 } , { 0xa0, boost::uuids::uuid::variant_rfc_4122 } , { 0xb0, boost::uuids::uuid::variant_rfc_4122 } , { 0xc0, boost::uuids::uuid::variant_microsoft } , { 0xd0, boost::uuids::uuid::variant_microsoft } , { 0xe0, boost::uuids::uuid::variant_future } , { 0xf0, boost::uuids::uuid::variant_future } }; for (size_t i=0; i= u1); BOOST_TEST(u3 >= u1); BOOST_TEST(u3 >= u3); BOOST_TEST(u2 >= u1); BOOST_TEST(u3 >= u1); } { // ticket 10510 // the uuids in the report uuid u6 = {{0x14,0x5c,0xfc,0x95,0x80,0x50,0x45,0x5a,0x83,0x82,0x44,0xca,0x57,0xc1,0x48,0x3b}}; uuid u7 = {{0x14,0x5c,0xfc,0x95,0x80,0x50,0x45,0x5a,0x83,0x82,0x44,0xca,0x57,0xc1,0x48,0x3c}}; // simple uuids to reproduce problem uuid u8 = {{0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1}}; uuid u9 = {{0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2}}; uuid u10 = {{0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,254}}; uuid u11 = {{0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255}}; // some additional uuids for testing boundary cases uuid u12 = {{0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,1}}; uuid u13 = {{0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,2}}; uuid u14 = {{1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1}}; uuid u15 = {{255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255}}; BOOST_TEST(u6 < u7); BOOST_TEST(!(u7 < u6)); BOOST_TEST(u8 < u9); BOOST_TEST(!(u9 < u8)); BOOST_TEST(u8 < u10); BOOST_TEST(!(u10 < u8)); BOOST_TEST(u8 < u11); BOOST_TEST(!(u11 < u8)); BOOST_TEST(u9 < u10); BOOST_TEST(!(u10 < u9)); BOOST_TEST(u9 < u11); BOOST_TEST(!(u11 < u9)); BOOST_TEST(u10 < u11); BOOST_TEST(!(u11 < u10)); BOOST_TEST(u12 < u13); BOOST_TEST(!(u13 < u12)); BOOST_TEST(u14 < u15); BOOST_TEST(!(u15 < u14)); } { // test hash uuid u1 = {{0}}; uuid u2 = {{1,0}}; uuid u3 = {{255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255}}; boost::hash uuid_hasher; BOOST_TEST_NE(uuid_hasher(u1), uuid_hasher(u2)); BOOST_TEST_NE(uuid_hasher(u1), uuid_hasher(u3)); BOOST_TEST_NE(uuid_hasher(u2), uuid_hasher(u3)); } { // test is_pod BOOST_TEST_EQ(boost::is_pod::value, true); } return boost::report_errors(); }