|
|
|
@ -158,8 +158,7 @@ typedef CCheckQueue<FrozenCleanupCheck> FrozenCleanup_Queue;
|
|
|
|
|
*/
|
|
|
|
|
static void Correct_Queue_range(std::vector<size_t> range)
|
|
|
|
|
{
|
|
|
|
|
auto small_queue = std::make_unique<Correct_Queue>(QUEUE_BATCH_SIZE);
|
|
|
|
|
small_queue->StartWorkerThreads(SCRIPT_CHECK_THREADS);
|
|
|
|
|
auto small_queue = std::make_unique<Correct_Queue>(QUEUE_BATCH_SIZE, SCRIPT_CHECK_THREADS);
|
|
|
|
|
// Make vChecks here to save on malloc (this test can be slow...)
|
|
|
|
|
std::vector<FakeCheckCheckCompletion> vChecks;
|
|
|
|
|
vChecks.reserve(9);
|
|
|
|
@ -217,9 +216,7 @@ BOOST_AUTO_TEST_CASE(test_CheckQueue_Correct_Random)
|
|
|
|
|
/** Test that failing checks are caught */
|
|
|
|
|
BOOST_AUTO_TEST_CASE(test_CheckQueue_Catches_Failure)
|
|
|
|
|
{
|
|
|
|
|
auto fail_queue = std::make_unique<Failing_Queue>(QUEUE_BATCH_SIZE);
|
|
|
|
|
fail_queue->StartWorkerThreads(SCRIPT_CHECK_THREADS);
|
|
|
|
|
|
|
|
|
|
auto fail_queue = std::make_unique<Failing_Queue>(QUEUE_BATCH_SIZE, SCRIPT_CHECK_THREADS);
|
|
|
|
|
for (size_t i = 0; i < 1001; ++i) {
|
|
|
|
|
CCheckQueueControl<FailingCheck> control(fail_queue.get());
|
|
|
|
|
size_t remaining = i;
|
|
|
|
@ -244,9 +241,7 @@ BOOST_AUTO_TEST_CASE(test_CheckQueue_Catches_Failure)
|
|
|
|
|
// future blocks, ie, the bad state is cleared.
|
|
|
|
|
BOOST_AUTO_TEST_CASE(test_CheckQueue_Recovers_From_Failure)
|
|
|
|
|
{
|
|
|
|
|
auto fail_queue = std::make_unique<Failing_Queue>(QUEUE_BATCH_SIZE);
|
|
|
|
|
fail_queue->StartWorkerThreads(SCRIPT_CHECK_THREADS);
|
|
|
|
|
|
|
|
|
|
auto fail_queue = std::make_unique<Failing_Queue>(QUEUE_BATCH_SIZE, SCRIPT_CHECK_THREADS);
|
|
|
|
|
for (auto times = 0; times < 10; ++times) {
|
|
|
|
|
for (const bool end_fails : {true, false}) {
|
|
|
|
|
CCheckQueueControl<FailingCheck> control(fail_queue.get());
|
|
|
|
@ -267,9 +262,7 @@ BOOST_AUTO_TEST_CASE(test_CheckQueue_Recovers_From_Failure)
|
|
|
|
|
// more than once as well
|
|
|
|
|
BOOST_AUTO_TEST_CASE(test_CheckQueue_UniqueCheck)
|
|
|
|
|
{
|
|
|
|
|
auto queue = std::make_unique<Unique_Queue>(QUEUE_BATCH_SIZE);
|
|
|
|
|
queue->StartWorkerThreads(SCRIPT_CHECK_THREADS);
|
|
|
|
|
|
|
|
|
|
auto queue = std::make_unique<Unique_Queue>(QUEUE_BATCH_SIZE, SCRIPT_CHECK_THREADS);
|
|
|
|
|
size_t COUNT = 100000;
|
|
|
|
|
size_t total = COUNT;
|
|
|
|
|
{
|
|
|
|
@ -301,8 +294,7 @@ BOOST_AUTO_TEST_CASE(test_CheckQueue_UniqueCheck)
|
|
|
|
|
// time could leave the data hanging across a sequence of blocks.
|
|
|
|
|
BOOST_AUTO_TEST_CASE(test_CheckQueue_Memory)
|
|
|
|
|
{
|
|
|
|
|
auto queue = std::make_unique<Memory_Queue>(QUEUE_BATCH_SIZE);
|
|
|
|
|
queue->StartWorkerThreads(SCRIPT_CHECK_THREADS);
|
|
|
|
|
auto queue = std::make_unique<Memory_Queue>(QUEUE_BATCH_SIZE, SCRIPT_CHECK_THREADS);
|
|
|
|
|
for (size_t i = 0; i < 1000; ++i) {
|
|
|
|
|
size_t total = i;
|
|
|
|
|
{
|
|
|
|
@ -327,9 +319,8 @@ BOOST_AUTO_TEST_CASE(test_CheckQueue_Memory)
|
|
|
|
|
// have been destructed
|
|
|
|
|
BOOST_AUTO_TEST_CASE(test_CheckQueue_FrozenCleanup)
|
|
|
|
|
{
|
|
|
|
|
auto queue = std::make_unique<FrozenCleanup_Queue>(QUEUE_BATCH_SIZE);
|
|
|
|
|
auto queue = std::make_unique<FrozenCleanup_Queue>(QUEUE_BATCH_SIZE, SCRIPT_CHECK_THREADS);
|
|
|
|
|
bool fails = false;
|
|
|
|
|
queue->StartWorkerThreads(SCRIPT_CHECK_THREADS);
|
|
|
|
|
std::thread t0([&]() {
|
|
|
|
|
CCheckQueueControl<FrozenCleanupCheck> control(queue.get());
|
|
|
|
|
std::vector<FrozenCleanupCheck> vChecks(1);
|
|
|
|
@ -362,7 +353,7 @@ BOOST_AUTO_TEST_CASE(test_CheckQueue_FrozenCleanup)
|
|
|
|
|
/** Test that CCheckQueueControl is threadsafe */
|
|
|
|
|
BOOST_AUTO_TEST_CASE(test_CheckQueueControl_Locks)
|
|
|
|
|
{
|
|
|
|
|
auto queue = std::make_unique<Standard_Queue>(QUEUE_BATCH_SIZE);
|
|
|
|
|
auto queue = std::make_unique<Standard_Queue>(QUEUE_BATCH_SIZE, SCRIPT_CHECK_THREADS);
|
|
|
|
|
{
|
|
|
|
|
std::vector<std::thread> tg;
|
|
|
|
|
std::atomic<int> nThreads {0};
|
|
|
|
|