// Unit test for boost::lexical_cast. // // See http://www.boost.org for most recent version, including documentation. // // Copyright Alexander Nasonov, 2006. // // Distributed under the Boost // Software License, Version 1.0. (See accompanying file // LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt). // // Test round-tripping conversion FPT -> string -> FPT, // where FPT is Floating Point Type. #include #if defined(__INTEL_COMPILER) #pragma warning(disable: 193 383 488 981 1418 1419) #elif defined(BOOST_MSVC) #pragma warning(disable: 4097 4100 4121 4127 4146 4244 4245 4511 4512 4701 4800) #endif #include #include using namespace boost; void test_round_conversion_float(); void test_round_conversion_double(); void test_round_conversion_long_double(); unit_test::test_suite *init_unit_test_suite(int, char *[]) { unit_test::test_suite *suite = BOOST_TEST_SUITE("lexical_cast unit test"); suite->add(BOOST_TEST_CASE(&test_round_conversion_float)); suite->add(BOOST_TEST_CASE(&test_round_conversion_double)); suite->add(BOOST_TEST_CASE(&test_round_conversion_long_double)); return suite; } template void test_round_conversion() { T epsilon = std::numeric_limits::epsilon(); std::string const epsilon_s = boost::lexical_cast(epsilon); BOOST_CHECK(epsilon == lexical_cast(epsilon_s)); T max_ = (std::numeric_limits::max)(); std::string const max_s = boost::lexical_cast(max_); BOOST_CHECK(max_ == lexical_cast(max_s)); T min_ = (std::numeric_limits::min)(); std::string const min_s = boost::lexical_cast(min_); BOOST_CHECK(min_ == lexical_cast(min_s)); T max_div137 = max_ / 137; std::string max_div137_s = boost::lexical_cast(max_div137); BOOST_CHECK(max_div137 == lexical_cast(max_div137_s)); T epsilon_mult137 = epsilon * 137; std::string epsilon_mult137_s(lexical_cast(epsilon_mult137)); BOOST_CHECK(epsilon_mult137 == lexical_cast(epsilon_mult137_s)); } // See bug http://tinyurl.com/vhpvo template void test_msvc_magic_values() { T magic_msvc = 0.00010000433948393407; std::string magic_msvc_s = boost::lexical_cast(magic_msvc); BOOST_CHECK(magic_msvc == lexical_cast(magic_msvc_s)); } void test_round_conversion_float() { test_round_conversion(); } void test_round_conversion_double() { test_round_conversion(); test_msvc_magic_values(); } void test_round_conversion_long_double() { // We do not run tests on compilers with bugs #ifndef BOOST_MATH_NO_LONG_DOUBLE_MATH_FUNCTIONS test_round_conversion(); test_msvc_magic_values(); #endif BOOST_CHECK(true); }