test_test.cpp 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. ///////////////////////////////////////////////////////////////
  2. // Copyright 2011 John Maddock. Distributed under the Boost
  3. // Software License, Version 1.0. (See accompanying file
  4. // LICENSE_1_0.txt or copy at https://www.boost.org/LICENSE_1_0.txt
  5. #ifdef _MSC_VER
  6. #define _SCL_SECURE_NO_WARNINGS
  7. #endif
  8. #include "test.hpp"
  9. #include <boost/multiprecision/cpp_dec_float.hpp>
  10. void proc_that_throws()
  11. {
  12. throw std::runtime_error("");
  13. }
  14. int main()
  15. {
  16. boost::multiprecision::cpp_dec_float_50 a1(1), a2(1), b(3), c(-2);
  17. BOOST_WARN(a1);
  18. BOOST_WARN(a1 == b);
  19. BOOST_CHECK(a1);
  20. BOOST_CHECK(a1 == b);
  21. BOOST_CHECK(boost::detail::test_errors() == 1);
  22. --boost::detail::test_errors();
  23. boost::multiprecision::cpp_dec_float_50 a_tol = a1 + a1 * 100 * std::numeric_limits<boost::multiprecision::cpp_dec_float_50>::epsilon();
  24. boost::multiprecision::cpp_dec_float_50 tol = 100 * std::numeric_limits<boost::multiprecision::cpp_dec_float_50>::epsilon();
  25. BOOST_CHECK_CLOSE(a1, a_tol, tol * 102); // Passes
  26. BOOST_WARN_CLOSE(a1, a_tol, tol * 98); // fails
  27. BOOST_CHECK_CLOSE(a1, a_tol, tol * 98); // fails
  28. BOOST_CHECK(boost::detail::test_errors() == 1);
  29. --boost::detail::test_errors();
  30. BOOST_CHECK_CLOSE_FRACTION(a1, a_tol, tol * 1.02); // Passes
  31. BOOST_WARN_CLOSE_FRACTION(a1, a_tol, tol * 0.98); // fails
  32. BOOST_CHECK_CLOSE_FRACTION(a1, a_tol, tol * 0.98); // fails
  33. BOOST_CHECK(boost::detail::test_errors() == 1);
  34. --boost::detail::test_errors();
  35. BOOST_CHECK_EQUAL(a1, a2);
  36. BOOST_WARN_EQUAL(a1, b);
  37. BOOST_CHECK_EQUAL(a1, b);
  38. BOOST_CHECK(boost::detail::test_errors() == 1);
  39. --boost::detail::test_errors();
  40. BOOST_CHECK_NE(a1, b);
  41. BOOST_WARN_NE(a1, a2);
  42. BOOST_CHECK_NE(a1, a2);
  43. BOOST_CHECK(boost::detail::test_errors() == 1);
  44. --boost::detail::test_errors();
  45. BOOST_CHECK_GT(a1, c);
  46. BOOST_WARN_GT(a1, a2);
  47. BOOST_CHECK_GT(a1, a2);
  48. BOOST_CHECK(boost::detail::test_errors() == 1);
  49. --boost::detail::test_errors();
  50. BOOST_CHECK_LT(a1, b);
  51. BOOST_WARN_LT(a1, a2);
  52. BOOST_CHECK_LT(a1, a2);
  53. BOOST_CHECK(boost::detail::test_errors() == 1);
  54. --boost::detail::test_errors();
  55. BOOST_CHECK_GE(a1, a2);
  56. BOOST_CHECK_GE(a1, c);
  57. BOOST_WARN_GE(a1, b);
  58. BOOST_CHECK_GE(a1, b);
  59. BOOST_CHECK(boost::detail::test_errors() == 1);
  60. --boost::detail::test_errors();
  61. BOOST_CHECK_LE(a1, a2);
  62. BOOST_CHECK_LE(a1, b);
  63. BOOST_WARN_LE(a1, c);
  64. BOOST_CHECK_LE(a1, c);
  65. BOOST_CHECK(boost::detail::test_errors() == 1);
  66. --boost::detail::test_errors();
  67. #ifndef BOOST_NO_EXCEPTIONS
  68. BOOST_CHECK_THROW(proc_that_throws(), std::runtime_error);
  69. BOOST_CHECK_THROW(a1 + b + c, std::runtime_error);
  70. #endif
  71. BOOST_CHECK(boost::detail::test_errors() == 1);
  72. --boost::detail::test_errors();
  73. return boost::report_errors();
  74. }