| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175 |
- // Copyright (c) 2006-2018 Maxim Khizhinsky
- //
- // Distributed under the Boost Software License, Version 1.0. (See accompanying
- // file LICENSE or copy at http://www.boost.org/LICENSE_1_0.txt)
- #include "test_intrusive_msqueue.h"
- #include <cds/gc/hp.h>
- #include <cds/intrusive/moir_queue.h>
- #include <vector>
- namespace {
- namespace ci = cds::intrusive;
- typedef cds::gc::HP gc_type;
- class IntrusiveMoirQueue_HP : public cds_test::intrusive_msqueue
- {
- typedef cds_test::intrusive_msqueue base_class;
- protected:
- typedef typename base_class::base_hook_item< ci::msqueue::node<gc_type>> base_item_type;
- typedef typename base_class::member_hook_item< ci::msqueue::node<gc_type>> member_item_type;
- void SetUp()
- {
- typedef ci::MoirQueue< gc_type, base_item_type > queue_type;
- cds::gc::hp::GarbageCollector::Construct( queue_type::c_nHazardPtrCount, 1, 16 );
- cds::threading::Manager::attachThread();
- }
- void TearDown()
- {
- cds::threading::Manager::detachThread();
- cds::gc::hp::GarbageCollector::Destruct( true );
- }
- template <typename V>
- void check_array( V& arr )
- {
- for ( size_t i = 0; i < arr.size() - 1; ++i ) {
- ASSERT_EQ( arr[i].nDisposeCount, 2 );
- }
- ASSERT_EQ( arr.back().nDisposeCount, 1 );
- }
- };
- TEST_F( IntrusiveMoirQueue_HP, defaulted )
- {
- typedef cds::intrusive::MoirQueue< gc_type, base_item_type,
- typename ci::msqueue::make_traits<
- ci::opt::disposer< mock_disposer >
- >::type
- > test_queue;
- std::vector<base_item_type> arr;
- arr.resize(100);
- {
- test_queue q;
- test(q, arr);
- }
- gc_type::scan();
- check_array( arr );
- }
- TEST_F( IntrusiveMoirQueue_HP, base_hook )
- {
- typedef cds::intrusive::MoirQueue< gc_type, base_item_type,
- typename ci::msqueue::make_traits<
- ci::opt::disposer< mock_disposer >
- ,ci::opt::hook< ci::msqueue::base_hook< ci::opt::gc<gc_type>>>
- >::type
- > test_queue;
- std::vector<base_item_type> arr;
- arr.resize(100);
- {
- test_queue q;
- test(q, arr);
- }
- gc_type::scan();
- check_array( arr );
- }
- TEST_F( IntrusiveMoirQueue_HP, base_item_counting )
- {
- typedef cds::intrusive::MoirQueue< gc_type, base_item_type,
- typename ci::msqueue::make_traits<
- ci::opt::disposer< mock_disposer >
- , cds::opt::item_counter< cds::atomicity::item_counter >
- , ci::opt::hook< ci::msqueue::base_hook< ci::opt::gc<gc_type>>>
- >::type
- > test_queue;
- std::vector<base_item_type> arr;
- arr.resize(100);
- {
- test_queue q;
- test(q, arr);
- }
- gc_type::scan();
- check_array( arr );
- }
- TEST_F( IntrusiveMoirQueue_HP, base_stat )
- {
- struct traits : public ci::msqueue::traits
- {
- typedef mock_disposer disposer;
- typedef cds::atomicity::item_counter item_counter;
- typedef ci::msqueue::stat<> stat;
- typedef cds::opt::v::sequential_consistent memory_model;
- };
- typedef cds::intrusive::MoirQueue< gc_type, base_item_type, traits > test_queue;
- std::vector<base_item_type> arr;
- arr.resize(100);
- {
- test_queue q;
- test(q, arr);
- }
- gc_type::scan();
- check_array( arr );
- }
- TEST_F( IntrusiveMoirQueue_HP, member_hook )
- {
- typedef cds::intrusive::MoirQueue< gc_type, member_item_type,
- typename ci::msqueue::make_traits<
- ci::opt::disposer< mock_disposer >
- ,ci::opt::hook< ci::msqueue::member_hook<
- offsetof( member_item_type, hMember ),
- ci::opt::gc<gc_type>
- >>
- >::type
- > test_queue;
- std::vector<member_item_type> arr;
- arr.resize( 100 );
- {
- test_queue q;
- test( q, arr );
- }
- gc_type::scan();
- check_array( arr );
- }
- TEST_F( IntrusiveMoirQueue_HP, member_hook_stat )
- {
- struct traits : public ci::msqueue::traits
- {
- typedef ci::msqueue::member_hook<
- offsetof( member_item_type, hMember ),
- ci::opt::gc<gc_type>
- > hook;
- typedef mock_disposer disposer;
- typedef cds::atomicity::item_counter item_counter;
- typedef ci::msqueue::stat<> stat;
- typedef cds::opt::v::sequential_consistent memory_model;
- };
- typedef cds::intrusive::MoirQueue< gc_type, member_item_type, traits > test_queue;
- std::vector<member_item_type> arr;
- arr.resize( 100 );
- {
- test_queue q;
- test( q, arr );
- }
- gc_type::scan();
- check_array( arr );
- }
- } // namespace
|