fcdeque.cpp 8.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289
  1. // Copyright (c) 2006-2018 Maxim Khizhinsky
  2. //
  3. // Distributed under the Boost Software License, Version 1.0. (See accompanying
  4. // file LICENSE or copy at http://www.boost.org/LICENSE_1_0.txt)
  5. #include <cds_test/ext_gtest.h>
  6. #include <cds/container/fcdeque.h>
  7. #include <boost/container/deque.hpp>
  8. namespace {
  9. class FCDeque: public ::testing::Test
  10. {
  11. protected:
  12. template <class Deque>
  13. void test( Deque& dq )
  14. {
  15. size_t const c_nSize = 100;
  16. int total_sum = 0;
  17. // push_front/pop_front
  18. for ( int i = 0; i < static_cast<int>( c_nSize ); ++i ) {
  19. EXPECT_TRUE( dq.push_front( i ));
  20. total_sum += i;
  21. }
  22. EXPECT_EQ( dq.size(), c_nSize );
  23. int sum = 0;
  24. dq.apply( [&sum]( typename Deque::deque_type const& d )
  25. {
  26. for ( auto const& el : d )
  27. sum += el;
  28. }
  29. );
  30. EXPECT_EQ( sum, total_sum );
  31. size_t nCount = 0;
  32. int val;
  33. while ( !dq.empty()) {
  34. EXPECT_TRUE( dq.pop_front( val ));
  35. ++nCount;
  36. EXPECT_EQ( static_cast<int>(c_nSize - nCount), val );
  37. }
  38. EXPECT_EQ( nCount, c_nSize );
  39. // push_back/pop_back
  40. for ( int i = 0; i < static_cast<int>( c_nSize ); ++i )
  41. EXPECT_TRUE( dq.push_back( i ));
  42. EXPECT_EQ( dq.size(), c_nSize );
  43. nCount = 0;
  44. while ( !dq.empty()) {
  45. EXPECT_TRUE( dq.pop_back( val ));
  46. ++nCount;
  47. EXPECT_EQ( static_cast<int>(c_nSize - nCount), val );
  48. }
  49. EXPECT_EQ( nCount, c_nSize );
  50. // push_back/pop_front
  51. for ( int i = 0; i < static_cast<int>( c_nSize ); ++i )
  52. EXPECT_TRUE( dq.push_back( i ));
  53. EXPECT_EQ( dq.size(), c_nSize );
  54. nCount = 0;
  55. while ( !dq.empty()) {
  56. EXPECT_TRUE( dq.pop_front( val ));
  57. EXPECT_EQ( static_cast<int>( nCount ), val );
  58. ++nCount;
  59. }
  60. EXPECT_EQ( nCount, c_nSize );
  61. // push_front/pop_back
  62. for ( int i = 0; i < static_cast<int>( c_nSize ); ++i )
  63. EXPECT_TRUE( dq.push_front( i ));
  64. EXPECT_EQ( dq.size(), c_nSize );
  65. nCount = 0;
  66. while ( !dq.empty()) {
  67. EXPECT_TRUE( dq.pop_back( val ));
  68. EXPECT_EQ( static_cast<int>( nCount ), val );
  69. ++nCount;
  70. }
  71. EXPECT_EQ( nCount, c_nSize );
  72. // clear
  73. for ( int i = 0; i < static_cast<int>( c_nSize ); ++i )
  74. EXPECT_TRUE( dq.push_front( i ));
  75. EXPECT_EQ( dq.size(), c_nSize );
  76. EXPECT_FALSE( dq.empty());
  77. dq.clear();
  78. EXPECT_TRUE( dq.empty());
  79. }
  80. };
  81. TEST_F( FCDeque, std )
  82. {
  83. typedef cds::container::FCDeque<int> deque_type;
  84. deque_type dq;
  85. test( dq );
  86. }
  87. TEST_F( FCDeque, std_empty_wait_strategy )
  88. {
  89. typedef cds::container::FCDeque<int, std::deque<int>,
  90. cds::container::fcdeque::make_traits<
  91. cds::opt::wait_strategy< cds::algo::flat_combining::wait_strategy::empty >
  92. >::type
  93. > deque_type;
  94. deque_type dq;
  95. test( dq );
  96. }
  97. TEST_F( FCDeque, std_multi_mutex_multi_condvar )
  98. {
  99. typedef cds::container::FCDeque<int, std::deque<int>,
  100. cds::container::fcdeque::make_traits<
  101. cds::opt::wait_strategy< cds::algo::flat_combining::wait_strategy::multi_mutex_multi_condvar<>>
  102. >::type
  103. > deque_type;
  104. deque_type dq;
  105. test( dq );
  106. }
  107. TEST_F( FCDeque, std_elimination )
  108. {
  109. typedef cds::container::FCDeque<int, std::deque<int>,
  110. cds::container::fcdeque::make_traits<
  111. cds::opt::enable_elimination< true >
  112. >::type
  113. > deque_type;
  114. deque_type dq;
  115. test( dq );
  116. }
  117. TEST_F( FCDeque, std_elimination_single_mutex_single_condvar )
  118. {
  119. typedef cds::container::FCDeque<int, std::deque<int>,
  120. cds::container::fcdeque::make_traits<
  121. cds::opt::enable_elimination< true >
  122. , cds::opt::wait_strategy< cds::algo::flat_combining::wait_strategy::single_mutex_single_condvar<3>>
  123. >::type
  124. > deque_type;
  125. deque_type dq;
  126. test( dq );
  127. }
  128. TEST_F( FCDeque, std_statistics )
  129. {
  130. typedef cds::container::FCDeque<int, std::deque<int>,
  131. cds::container::fcdeque::make_traits<
  132. cds::opt::stat< cds::container::fcdeque::stat<> >
  133. >::type
  134. > deque_type;
  135. deque_type dq;
  136. test( dq );
  137. }
  138. TEST_F( FCDeque, std_stat_single_mutex_multi_condvar )
  139. {
  140. typedef cds::container::FCDeque<int, std::deque<int>,
  141. cds::container::fcdeque::make_traits<
  142. cds::opt::stat< cds::container::fcdeque::stat<> >
  143. , cds::opt::wait_strategy< cds::algo::flat_combining::wait_strategy::single_mutex_multi_condvar<2>>
  144. >::type
  145. > deque_type;
  146. deque_type dq;
  147. test( dq );
  148. }
  149. TEST_F( FCDeque, std_mutex )
  150. {
  151. struct deque_traits : public
  152. cds::container::fcdeque::make_traits<
  153. cds::opt::enable_elimination< true >
  154. >::type
  155. {
  156. typedef std::mutex lock_type;
  157. };
  158. typedef cds::container::FCDeque<int, std::deque<int>, deque_traits > deque_type;
  159. deque_type dq;
  160. test( dq );
  161. }
  162. TEST_F( FCDeque, boost )
  163. {
  164. typedef cds::container::FCDeque<int, boost::container::deque<int> > deque_type;
  165. deque_type dq;
  166. test( dq );
  167. }
  168. TEST_F( FCDeque, boost_empty_wait_strategy )
  169. {
  170. typedef cds::container::FCDeque<int, boost::container::deque<int>,
  171. cds::container::fcdeque::make_traits<
  172. cds::opt::wait_strategy< cds::algo::flat_combining::wait_strategy::empty >
  173. >::type
  174. > deque_type;
  175. deque_type dq;
  176. test( dq );
  177. }
  178. TEST_F( FCDeque, boost_single_mutex_single_condvar )
  179. {
  180. typedef cds::container::FCDeque<int, boost::container::deque<int>,
  181. cds::container::fcdeque::make_traits<
  182. cds::opt::wait_strategy< cds::algo::flat_combining::wait_strategy::single_mutex_single_condvar<>>
  183. >::type
  184. > deque_type;
  185. deque_type dq;
  186. test( dq );
  187. }
  188. TEST_F( FCDeque, boost_elimination )
  189. {
  190. typedef cds::container::FCDeque<int, boost::container::deque<int>,
  191. cds::container::fcdeque::make_traits<
  192. cds::opt::enable_elimination< true >
  193. >::type
  194. > deque_type;
  195. deque_type dq;
  196. test( dq );
  197. }
  198. TEST_F( FCDeque, boost_elimination_single_mutex_multi_condvar )
  199. {
  200. typedef cds::container::FCDeque<int, boost::container::deque<int>,
  201. cds::container::fcdeque::make_traits<
  202. cds::opt::enable_elimination< true >
  203. ,cds::opt::wait_strategy< cds::algo::flat_combining::wait_strategy::single_mutex_multi_condvar<5>>
  204. >::type
  205. > deque_type;
  206. deque_type dq;
  207. test( dq );
  208. }
  209. TEST_F( FCDeque, boost_statistics )
  210. {
  211. typedef cds::container::FCDeque<int, boost::container::deque<int>,
  212. cds::container::fcdeque::make_traits<
  213. cds::opt::stat< cds::container::fcdeque::stat<> >
  214. >::type
  215. > deque_type;
  216. deque_type dq;
  217. test( dq );
  218. }
  219. TEST_F( FCDeque, boost_mutex )
  220. {
  221. typedef cds::container::FCDeque<int, boost::container::deque<int>,
  222. cds::container::fcdeque::make_traits<
  223. cds::opt::enable_elimination< true >
  224. ,cds::opt::lock_type< std::mutex >
  225. >::type
  226. > deque_type;
  227. deque_type dq;
  228. test( dq );
  229. }
  230. TEST_F( FCDeque, boost_mutex_multi_mutex_multi_condvar )
  231. {
  232. typedef cds::container::FCDeque<int, boost::container::deque<int>,
  233. cds::container::fcdeque::make_traits<
  234. cds::opt::enable_elimination< true >
  235. , cds::opt::lock_type< std::mutex >
  236. , cds::opt::wait_strategy< cds::algo::flat_combining::wait_strategy::multi_mutex_multi_condvar<>>
  237. >::type
  238. > deque_type;
  239. deque_type dq;
  240. test( dq );
  241. }
  242. } // namespace