|
|
@ -32,7 +32,7 @@ int test_multiqueue()
|
|
|
|
TESTASSERT(multiqueue.nof_queues() == 0);
|
|
|
|
TESTASSERT(multiqueue.nof_queues() == 0);
|
|
|
|
|
|
|
|
|
|
|
|
// test push/pop and size for one queue
|
|
|
|
// test push/pop and size for one queue
|
|
|
|
queue_handle<int> qid1 = multiqueue.add_queue();
|
|
|
|
queue_handle<int> qid1 = multiqueue.add_queue(true);
|
|
|
|
TESTASSERT(qid1.active());
|
|
|
|
TESTASSERT(qid1.active());
|
|
|
|
TESTASSERT(qid1.size() == 0 and qid1.empty());
|
|
|
|
TESTASSERT(qid1.size() == 0 and qid1.empty());
|
|
|
|
TESTASSERT(multiqueue.nof_queues() == 1);
|
|
|
|
TESTASSERT(multiqueue.nof_queues() == 1);
|
|
|
@ -45,7 +45,7 @@ int test_multiqueue()
|
|
|
|
TESTASSERT(number == 2 and qid1.empty());
|
|
|
|
TESTASSERT(number == 2 and qid1.empty());
|
|
|
|
|
|
|
|
|
|
|
|
// test push/pop and size for two queues
|
|
|
|
// test push/pop and size for two queues
|
|
|
|
queue_handle<int> qid2 = multiqueue.add_queue();
|
|
|
|
queue_handle<int> qid2 = multiqueue.add_queue(true);
|
|
|
|
TESTASSERT(qid2.active());
|
|
|
|
TESTASSERT(qid2.active());
|
|
|
|
TESTASSERT(multiqueue.nof_queues() == 2 and qid1.active());
|
|
|
|
TESTASSERT(multiqueue.nof_queues() == 2 and qid1.active());
|
|
|
|
TESTASSERT(qid2.try_push(3).has_value());
|
|
|
|
TESTASSERT(qid2.try_push(3).has_value());
|
|
|
@ -55,7 +55,7 @@ int test_multiqueue()
|
|
|
|
// check if erasing a queue breaks anything
|
|
|
|
// check if erasing a queue breaks anything
|
|
|
|
qid1.reset();
|
|
|
|
qid1.reset();
|
|
|
|
TESTASSERT(multiqueue.nof_queues() == 1 and not qid1.active());
|
|
|
|
TESTASSERT(multiqueue.nof_queues() == 1 and not qid1.active());
|
|
|
|
qid1 = multiqueue.add_queue();
|
|
|
|
qid1 = multiqueue.add_queue(true);
|
|
|
|
TESTASSERT(qid1.empty() and qid1.active());
|
|
|
|
TESTASSERT(qid1.empty() and qid1.active());
|
|
|
|
TESTASSERT(qid2.size() == 1 and not qid2.empty());
|
|
|
|
TESTASSERT(qid2.size() == 1 and not qid2.empty());
|
|
|
|
multiqueue.wait_pop(&number);
|
|
|
|
multiqueue.wait_pop(&number);
|
|
|
@ -89,15 +89,15 @@ int test_multiqueue()
|
|
|
|
|
|
|
|
|
|
|
|
// check that adding a queue of different capacity works
|
|
|
|
// check that adding a queue of different capacity works
|
|
|
|
{
|
|
|
|
{
|
|
|
|
qid1 = multiqueue.add_queue();
|
|
|
|
qid1 = multiqueue.add_queue(true);
|
|
|
|
qid2 = multiqueue.add_queue();
|
|
|
|
qid2 = multiqueue.add_queue(true);
|
|
|
|
|
|
|
|
|
|
|
|
// remove first queue again
|
|
|
|
// remove first queue again
|
|
|
|
qid1.reset();
|
|
|
|
qid1.reset();
|
|
|
|
TESTASSERT(multiqueue.nof_queues() == 1);
|
|
|
|
TESTASSERT(multiqueue.nof_queues() == 1);
|
|
|
|
|
|
|
|
|
|
|
|
// add queue with non-default capacity
|
|
|
|
// add queue with non-default capacity
|
|
|
|
auto qid3 = multiqueue.add_queue(10);
|
|
|
|
auto qid3 = multiqueue.add_queue(10, true);
|
|
|
|
TESTASSERT(qid3.capacity() == 10);
|
|
|
|
TESTASSERT(qid3.capacity() == 10);
|
|
|
|
|
|
|
|
|
|
|
|
// make sure neither a new queue index is returned
|
|
|
|
// make sure neither a new queue index is returned
|
|
|
@ -117,7 +117,7 @@ int test_multiqueue_threading()
|
|
|
|
|
|
|
|
|
|
|
|
int capacity = 4, number = 0, start_number = 2, nof_pushes = capacity + 1;
|
|
|
|
int capacity = 4, number = 0, start_number = 2, nof_pushes = capacity + 1;
|
|
|
|
multiqueue_handler<int> multiqueue(capacity);
|
|
|
|
multiqueue_handler<int> multiqueue(capacity);
|
|
|
|
auto qid1 = multiqueue.add_queue();
|
|
|
|
auto qid1 = multiqueue.add_queue(true);
|
|
|
|
auto push_blocking_func = [](queue_handle<int>* qid, int start_value, int nof_pushes, bool* is_running) {
|
|
|
|
auto push_blocking_func = [](queue_handle<int>* qid, int start_value, int nof_pushes, bool* is_running) {
|
|
|
|
for (int i = 0; i < nof_pushes; ++i) {
|
|
|
|
for (int i = 0; i < nof_pushes; ++i) {
|
|
|
|
qid->push(start_value + i);
|
|
|
|
qid->push(start_value + i);
|
|
|
@ -165,7 +165,7 @@ int test_multiqueue_threading2()
|
|
|
|
|
|
|
|
|
|
|
|
int capacity = 4, start_number = 2, nof_pushes = capacity + 1;
|
|
|
|
int capacity = 4, start_number = 2, nof_pushes = capacity + 1;
|
|
|
|
multiqueue_handler<int> multiqueue(capacity);
|
|
|
|
multiqueue_handler<int> multiqueue(capacity);
|
|
|
|
auto qid1 = multiqueue.add_queue();
|
|
|
|
auto qid1 = multiqueue.add_queue(true);
|
|
|
|
auto push_blocking_func = [](queue_handle<int>* qid, int start_value, int nof_pushes, bool* is_running) {
|
|
|
|
auto push_blocking_func = [](queue_handle<int>* qid, int start_value, int nof_pushes, bool* is_running) {
|
|
|
|
for (int i = 0; i < nof_pushes; ++i) {
|
|
|
|
for (int i = 0; i < nof_pushes; ++i) {
|
|
|
|
qid->push(start_value + i);
|
|
|
|
qid->push(start_value + i);
|
|
|
@ -199,7 +199,7 @@ int test_multiqueue_threading3()
|
|
|
|
|
|
|
|
|
|
|
|
int capacity = 4;
|
|
|
|
int capacity = 4;
|
|
|
|
multiqueue_handler<int> multiqueue(capacity);
|
|
|
|
multiqueue_handler<int> multiqueue(capacity);
|
|
|
|
auto qid1 = multiqueue.add_queue();
|
|
|
|
auto qid1 = multiqueue.add_queue(true);
|
|
|
|
auto pop_blocking_func = [&multiqueue](bool* success) {
|
|
|
|
auto pop_blocking_func = [&multiqueue](bool* success) {
|
|
|
|
int number = 0;
|
|
|
|
int number = 0;
|
|
|
|
bool ret = multiqueue.wait_pop(&number);
|
|
|
|
bool ret = multiqueue.wait_pop(&number);
|
|
|
@ -235,10 +235,10 @@ int test_multiqueue_threading4()
|
|
|
|
|
|
|
|
|
|
|
|
int capacity = 4;
|
|
|
|
int capacity = 4;
|
|
|
|
multiqueue_handler<int> multiqueue(capacity);
|
|
|
|
multiqueue_handler<int> multiqueue(capacity);
|
|
|
|
auto qid1 = multiqueue.add_queue();
|
|
|
|
auto qid1 = multiqueue.add_queue(true);
|
|
|
|
auto qid2 = multiqueue.add_queue();
|
|
|
|
auto qid2 = multiqueue.add_queue(true);
|
|
|
|
auto qid3 = multiqueue.add_queue();
|
|
|
|
auto qid3 = multiqueue.add_queue(true);
|
|
|
|
auto qid4 = multiqueue.add_queue();
|
|
|
|
auto qid4 = multiqueue.add_queue(true);
|
|
|
|
std::mutex mutex;
|
|
|
|
std::mutex mutex;
|
|
|
|
int last_number = -1;
|
|
|
|
int last_number = -1;
|
|
|
|
auto pop_blocking_func = [&multiqueue, &last_number, &mutex](bool* success) {
|
|
|
|
auto pop_blocking_func = [&multiqueue, &last_number, &mutex](bool* success) {
|
|
|
|