fix_tickets.cpp 7.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236
  1. /*-----------------------------------------------------------------------------+
  2. Copyright (c) 2011-2011: Joachim Faulhaber
  3. +------------------------------------------------------------------------------+
  4. Distributed under the Boost Software License, Version 1.0.
  5. (See accompanying file LICENCE.txt or copy at
  6. http://www.boost.org/LICENSE_1_0.txt)
  7. +-----------------------------------------------------------------------------*/
  8. #define BOOST_TEST_MODULE icl::fix_icl_after_thread unit test
  9. #include <libs/icl/test/disable_test_warnings.hpp>
  10. #include "../unit_test_unwarned.hpp"
  11. //#define BOOST_ICL_USE_STATIC_BOUNDED_INTERVALS
  12. #include <boost/icl/interval_map.hpp>
  13. #include <boost/icl/split_interval_map.hpp>
  14. #include <boost/icl/separate_interval_set.hpp>
  15. #include <boost/icl/split_interval_set.hpp>
  16. #include <iostream>
  17. using namespace std;
  18. using namespace boost;
  19. using namespace unit_test;
  20. using namespace boost::icl;
  21. BOOST_AUTO_TEST_CASE(ticket_5482)
  22. {
  23. typedef interval_map<int,int,partial_absorber,std::less> m1_t;
  24. typedef interval_map<int,int,partial_absorber,std::greater> m2_t;
  25. m1_t m1;
  26. m2_t m2;
  27. m1.insert(make_pair(m1_t::interval_type(1), 20));
  28. m1.insert(make_pair(m1_t::interval_type(2), 20));
  29. m1.insert(make_pair(m1_t::interval_type(3), 20));
  30. m2.insert(make_pair(m2_t::interval_type(1), 20));
  31. m2.insert(make_pair(m2_t::interval_type(2), 20));
  32. m2.insert(make_pair(m2_t::interval_type(3), 20));
  33. BOOST_CHECK_EQUAL(m1.iterative_size(), m2.iterative_size());
  34. BOOST_CHECK_EQUAL(m1.iterative_size(), 1);
  35. BOOST_CHECK_EQUAL(m2.iterative_size(), 1);
  36. }
  37. #include <boost/cstdint.hpp>
  38. BOOST_AUTO_TEST_CASE(ticket_5559_Denis)
  39. {
  40. //Submitted by Denis
  41. typedef boost::icl::interval_set<boost::uint32_t, std::greater> Set;
  42. const uint32_t ui32_max = (std::numeric_limits<uint32_t>::max)();
  43. Set q1( Set::interval_type::closed(ui32_max, 0) );
  44. Set q5( Set::interval_type::closed(0, 0) );
  45. BOOST_CHECK_EQUAL(q1, q1+q5);
  46. }
  47. //------------------------------------------------------------------------------
  48. // Ticket #6095 Marvin Sielenkemper
  49. //------------------------------------------------------------------------------
  50. BOOST_AUTO_TEST_CASE(ticket_6095_Marvin_Sielenkemper_isEmptyTest)
  51. {
  52. typedef int Value;
  53. typedef boost::icl::interval<Value> Interval;
  54. typedef std::numeric_limits<Value> Limits;
  55. Value const max((Limits::max)());
  56. //Interval::interval_type piff = Interval::open(max, max);
  57. BOOST_CHECK(!icl::is_empty(Interval::open(max - 2, max)));
  58. BOOST_CHECK( icl::is_empty(Interval::open(max - 1, max)));
  59. BOOST_CHECK( icl::is_empty(Interval::open(max, max)));
  60. }
  61. BOOST_AUTO_TEST_CASE(ticket_6095_Marvin_Sielenkemper_totalRangeTest)
  62. {
  63. typedef int Value;
  64. typedef boost::icl::interval<Value> Interval;
  65. typedef std::numeric_limits<Value> Limits;
  66. Value const min((Limits::min)());
  67. Value const max((Limits::max)());
  68. boost::icl::interval_map<Value, int, boost::icl::total_enricher> intervals;
  69. intervals += std::make_pair(Interval::closed(min, max), 0);
  70. intervals += std::make_pair(Interval::right_open(0, 10), 3);
  71. BOOST_CHECK_EQUAL(intervals.iterative_size(), 3);
  72. }
  73. BOOST_AUTO_TEST_CASE(test_ticket_7871)
  74. {
  75. boost::icl::split_interval_map <int, int> a, b;
  76. a = b;
  77. BOOST_CHECK_EQUAL(a, b);
  78. }
  79. //------------------------------------------------------------------------------
  80. // Ticket #11308 Stephen Hewitt
  81. //------------------------------------------------------------------------------
  82. BOOST_AUTO_TEST_CASE(ticket_11308_Stephen_Hewitt_extreme_valued_closed_intervals)
  83. {
  84. typedef boost::icl::closed_interval<boost::uint16_t, std::less> interval_t;
  85. typedef boost::icl::split_interval_set<boost::uint16_t, std::less, interval_t> set_t;
  86. set_t s1, s2;
  87. s1 += interval_t(0x0000, 0x9fff);
  88. s1 += interval_t(0xa000, 0xbfff);
  89. s1 += interval_t(0xc000, 0xffff);
  90. s2 += interval_t(0x0000, 0xffff);
  91. s2 += interval_t(0xa000, 0xbfff);
  92. BOOST_CHECK_EQUAL(s1, s2);
  93. }
  94. BOOST_AUTO_TEST_CASE(extreme_valued_right_open_intervals)
  95. {
  96. typedef boost::icl::right_open_interval<boost::uint16_t, std::less> interval_t;
  97. typedef boost::icl::split_interval_set<boost::uint16_t, std::less, interval_t> set_t;
  98. set_t s1, s2;
  99. s1 += interval_t(0x0000, 0xa000);
  100. s1 += interval_t(0xa000, 0xc000);
  101. s1 += interval_t(0xc000, 0xffff); //Contains 0xfffe as largest element
  102. s2 += interval_t(0x0000, 0xffff);
  103. s2 += interval_t(0xa000, 0xc000);
  104. BOOST_CHECK_EQUAL(s1, s2);
  105. }
  106. BOOST_AUTO_TEST_CASE(extreme_valued_left_open_intervals)
  107. {
  108. typedef boost::icl::left_open_interval<boost::uint16_t, std::less> interval_t;
  109. typedef boost::icl::split_interval_set<boost::uint16_t, std::less, interval_t> set_t;
  110. set_t s1, s2;
  111. s1 += interval_t(0x0000, 0x9fff); //Contains 1 as smallest element
  112. s1 += interval_t(0x9fff, 0xbfff);
  113. s1 += interval_t(0xbfff, 0xffff);
  114. s2 += interval_t(0x0000, 0xffff);
  115. s2 += interval_t(0x9fff, 0xbfff);
  116. BOOST_CHECK_EQUAL(s1, s2);
  117. }
  118. BOOST_AUTO_TEST_CASE(extreme_valued_open_intervals)
  119. {
  120. typedef boost::icl::open_interval<boost::uint16_t, std::less> interval_t;
  121. typedef boost::icl::split_interval_set<boost::uint16_t, std::less, interval_t> set_t;
  122. set_t s1, s2;
  123. s1 += interval_t(0x0000, 0xa000); //Contains 1 as smallest element
  124. s1 += interval_t(0x9fff, 0xc000);
  125. s1 += interval_t(0xbfff, 0xffff); //Contains 0xfffe as largest element
  126. s2 += interval_t(0x0000, 0xffff);
  127. s2 += interval_t(0x9fff, 0xc000);
  128. BOOST_CHECK_EQUAL(s1, s2);
  129. }
  130. BOOST_AUTO_TEST_CASE(test_span_and_hull)
  131. {
  132. typedef closed_interval<int> cl_I_int;
  133. cl_I_int span_1_2 = span< cl_I_int >(1,2);
  134. cl_I_int span_2_1 = span< cl_I_int >(2,1);
  135. BOOST_CHECK_EQUAL(span_1_2, span_2_1);
  136. BOOST_CHECK_EQUAL(hull< cl_I_int >(1,2), hull< cl_I_int >(2,1));
  137. BOOST_CHECK_EQUAL( span< right_open_interval<int> >(2,1)
  138. , construct< right_open_interval<int> >(1,2) );
  139. BOOST_CHECK_EQUAL( hull< right_open_interval<int> >(2,1)
  140. , construct< right_open_interval<int> >(1,3) );
  141. }
  142. BOOST_AUTO_TEST_CASE(test_ticket_11942)
  143. {
  144. boost::icl::split_interval_set<int> intervals;
  145. intervals.insert(boost::icl::discrete_interval<int>(1, 2));
  146. intervals.insert(boost::icl::discrete_interval<int>(2, 3));
  147. intervals.insert(boost::icl::discrete_interval<int>(0, 3));
  148. BOOST_CHECK_EQUAL(intervals.size(), 3);
  149. }
  150. BOOST_AUTO_TEST_CASE(test_ticket_12872)
  151. {
  152. boost::icl::split_interval_set<unsigned> ss
  153. = boost::icl::split_interval_set<unsigned>();
  154. std::vector<std::pair<unsigned, unsigned> > rs;
  155. rs.push_back(make_pair(88, 96));
  156. rs.push_back(make_pair(72, 96));
  157. rs.push_back(make_pair(80, 96));
  158. rs.push_back(make_pair(24, 64));
  159. rs.push_back(make_pair(80, 96));
  160. rs.push_back(make_pair(32, 72));
  161. rs.push_back(make_pair(88, 96));
  162. rs.push_back(make_pair(16, 56));
  163. // {{88, 96}, {72, 96}, {80, 96}, {24, 64}, {80, 96}, {32, 72},
  164. // {88, 96}, {16, 56}};
  165. for(int i=0; i < rs.size(); i++) {
  166. ss.add( boost::icl::interval<unsigned>::right_open(rs[i].first, rs[i].second) );
  167. }
  168. boost::icl::split_interval_map<unsigned, unsigned> im
  169. = boost::icl::split_interval_map<unsigned, unsigned>();
  170. for(int i=0; i < rs.size(); i++) {
  171. im.add( make_pair( boost::icl::interval<unsigned>::right_open(rs[i].first, rs[i].second), 1 ) );
  172. }
  173. BOOST_CHECK_EQUAL(interval_count(ss), interval_count(im));
  174. BOOST_CHECK_EQUAL(icl::size(ss), icl::size(im));
  175. BOOST_CHECK_EQUAL(hull(ss), hull(im));
  176. }
  177. BOOST_AUTO_TEST_CASE(test_ticket_12926)
  178. {
  179. boost::icl::interval_set<int> a;
  180. a.insert(boost::icl::interval<int>::right_open(-100, 100));
  181. a.insert(-50);
  182. BOOST_CHECK_EQUAL(a.size(), 200);
  183. }