2014-03-31 14:02:47 +02:00
|
|
|
/*
|
2015-02-08 18:51:25 +01:00
|
|
|
* Copyright (C) 2014 Martine Lenders
|
2014-03-31 14:02:47 +02:00
|
|
|
*
|
2014-07-31 19:45:27 +02:00
|
|
|
* This file is subject to the terms and conditions of the GNU Lesser
|
|
|
|
* General Public License v2.1. See the file LICENSE in the top level
|
|
|
|
* directory for more details.
|
2014-03-31 14:02:47 +02:00
|
|
|
*/
|
|
|
|
#include <string.h>
|
|
|
|
|
2014-11-27 22:30:14 +01:00
|
|
|
#include "embUnit.h"
|
2014-03-31 14:02:47 +02:00
|
|
|
|
2014-07-29 09:21:11 +02:00
|
|
|
#include "priority_queue.h"
|
2014-03-31 14:02:47 +02:00
|
|
|
|
|
|
|
#include "tests-core.h"
|
|
|
|
|
|
|
|
#define Q_LEN (4)
|
|
|
|
|
2014-07-29 09:52:33 +02:00
|
|
|
static priority_queue_t q = PRIORITY_QUEUE_INIT;
|
2014-07-29 09:21:11 +02:00
|
|
|
static priority_queue_node_t qe[Q_LEN];
|
2014-03-31 14:02:47 +02:00
|
|
|
|
|
|
|
static void set_up(void)
|
|
|
|
{
|
2014-07-29 09:52:33 +02:00
|
|
|
priority_queue_init(&q);
|
|
|
|
for (unsigned i = 0; i < sizeof(qe)/sizeof(priority_queue_node_t); ++i) {
|
|
|
|
priority_queue_node_init(&(qe[i]));
|
|
|
|
}
|
2014-03-31 14:02:47 +02:00
|
|
|
}
|
|
|
|
|
2014-07-29 09:21:11 +02:00
|
|
|
static void test_priority_queue_remove_head_empty(void)
|
2014-03-31 14:02:47 +02:00
|
|
|
{
|
2014-07-29 09:21:11 +02:00
|
|
|
priority_queue_t *root = &q;
|
|
|
|
priority_queue_node_t *res;
|
2014-03-31 14:02:47 +02:00
|
|
|
|
2014-07-29 09:21:11 +02:00
|
|
|
res = priority_queue_remove_head(root);
|
2014-03-31 14:02:47 +02:00
|
|
|
|
|
|
|
TEST_ASSERT_NULL(res);
|
|
|
|
}
|
|
|
|
|
2014-07-29 09:21:11 +02:00
|
|
|
static void test_priority_queue_remove_head_one(void)
|
2014-03-31 14:02:47 +02:00
|
|
|
{
|
2014-07-29 09:21:11 +02:00
|
|
|
priority_queue_t *root = &q;
|
|
|
|
priority_queue_node_t *elem = &(qe[1]), *res;
|
2014-03-31 14:02:47 +02:00
|
|
|
|
|
|
|
elem->data = 62801;
|
|
|
|
|
2014-07-29 09:21:11 +02:00
|
|
|
priority_queue_add(root, elem);
|
2014-03-31 14:02:47 +02:00
|
|
|
|
2014-07-29 09:21:11 +02:00
|
|
|
res = priority_queue_remove_head(root);
|
2014-03-31 14:02:47 +02:00
|
|
|
|
|
|
|
TEST_ASSERT(res == elem);
|
|
|
|
TEST_ASSERT_EQUAL_INT(62801, res->data);
|
|
|
|
|
2014-07-29 09:21:11 +02:00
|
|
|
res = priority_queue_remove_head(root);
|
2014-03-31 14:02:47 +02:00
|
|
|
|
|
|
|
TEST_ASSERT_NULL(res);
|
|
|
|
}
|
|
|
|
|
2014-07-29 09:21:11 +02:00
|
|
|
static void test_priority_queue_add_one(void)
|
2014-03-31 14:02:47 +02:00
|
|
|
{
|
2014-07-29 09:21:11 +02:00
|
|
|
priority_queue_t *root = &q;
|
|
|
|
priority_queue_node_t *elem = &(qe[1]);
|
2014-03-31 14:02:47 +02:00
|
|
|
|
|
|
|
elem->data = 7317;
|
|
|
|
elem->priority = 713643658;
|
|
|
|
|
2014-07-29 09:21:11 +02:00
|
|
|
priority_queue_add(root, elem);
|
2014-03-31 14:02:47 +02:00
|
|
|
|
2014-05-07 00:41:21 +02:00
|
|
|
TEST_ASSERT(root->first == elem);
|
|
|
|
TEST_ASSERT_EQUAL_INT(7317, root->first->data);
|
|
|
|
TEST_ASSERT_EQUAL_INT(713643658, root->first->priority);
|
2014-03-31 14:02:47 +02:00
|
|
|
|
2014-05-07 00:41:21 +02:00
|
|
|
TEST_ASSERT_NULL(root->first->next);
|
2014-03-31 14:02:47 +02:00
|
|
|
}
|
|
|
|
|
2014-07-29 09:21:11 +02:00
|
|
|
static void test_priority_queue_add_two_equal(void)
|
2014-03-31 14:02:47 +02:00
|
|
|
{
|
2014-07-29 09:21:11 +02:00
|
|
|
priority_queue_t *root = &q;
|
|
|
|
priority_queue_node_t *elem1 = &(qe[1]), *elem2 = &(qe[2]);
|
2014-03-31 14:02:47 +02:00
|
|
|
|
|
|
|
elem1->data = 27088;
|
|
|
|
elem1->priority = 14202;
|
|
|
|
|
|
|
|
elem2->data = 4356;
|
|
|
|
elem2->priority = 14202;
|
|
|
|
|
2014-07-29 09:21:11 +02:00
|
|
|
priority_queue_add(root, elem1);
|
|
|
|
priority_queue_add(root, elem2);
|
2014-03-31 14:02:47 +02:00
|
|
|
|
2014-05-07 00:41:21 +02:00
|
|
|
TEST_ASSERT(root->first == elem1);
|
|
|
|
TEST_ASSERT_EQUAL_INT(27088, root->first->data);
|
|
|
|
TEST_ASSERT_EQUAL_INT(14202, root->first->priority);
|
2014-03-31 14:02:47 +02:00
|
|
|
|
2014-05-07 00:41:21 +02:00
|
|
|
TEST_ASSERT(root->first->next == elem2);
|
|
|
|
TEST_ASSERT_EQUAL_INT(4356, root->first->next->data);
|
|
|
|
TEST_ASSERT_EQUAL_INT(14202, root->first->next->priority);
|
2014-03-31 14:02:47 +02:00
|
|
|
|
2014-05-07 00:41:21 +02:00
|
|
|
TEST_ASSERT_NULL(root->first->next->next);
|
2014-03-31 14:02:47 +02:00
|
|
|
}
|
|
|
|
|
2014-07-29 09:21:11 +02:00
|
|
|
static void test_priority_queue_add_two_distinct(void)
|
2014-03-31 14:02:47 +02:00
|
|
|
{
|
2014-07-29 09:21:11 +02:00
|
|
|
priority_queue_t *root = &q;
|
|
|
|
priority_queue_node_t *elem1 = &(qe[1]), *elem2 = &(qe[2]);
|
2014-03-31 14:02:47 +02:00
|
|
|
|
|
|
|
elem1->data = 46421;
|
|
|
|
elem1->priority = 4567;
|
|
|
|
|
|
|
|
elem2->data = 43088;
|
|
|
|
elem2->priority = 1234;
|
|
|
|
|
2014-07-29 09:21:11 +02:00
|
|
|
priority_queue_add(root, elem1);
|
|
|
|
priority_queue_add(root, elem2);
|
2014-03-31 14:02:47 +02:00
|
|
|
|
2014-05-07 00:41:21 +02:00
|
|
|
TEST_ASSERT(root->first == elem2);
|
|
|
|
TEST_ASSERT_EQUAL_INT(43088, root->first->data);
|
|
|
|
TEST_ASSERT_EQUAL_INT(1234, root->first->priority);
|
2014-03-31 14:02:47 +02:00
|
|
|
|
2014-05-07 00:41:21 +02:00
|
|
|
TEST_ASSERT(root->first->next == elem1);
|
|
|
|
TEST_ASSERT_EQUAL_INT(46421, root->first->next->data);
|
|
|
|
TEST_ASSERT_EQUAL_INT(4567, root->first->next->priority);
|
2014-03-31 14:02:47 +02:00
|
|
|
|
2014-05-07 00:41:21 +02:00
|
|
|
TEST_ASSERT_NULL(root->first->next->next);
|
2014-03-31 14:02:47 +02:00
|
|
|
}
|
|
|
|
|
2014-07-29 09:21:11 +02:00
|
|
|
static void test_priority_queue_remove_one(void)
|
2014-03-31 14:02:47 +02:00
|
|
|
{
|
2014-07-29 09:21:11 +02:00
|
|
|
priority_queue_t *root = &q;
|
|
|
|
priority_queue_node_t *elem1 = &(qe[1]), *elem2 = &(qe[2]), *elem3 = &(qe[3]);
|
2014-03-31 14:02:47 +02:00
|
|
|
|
2014-07-29 09:21:11 +02:00
|
|
|
priority_queue_add(root, elem1);
|
|
|
|
priority_queue_add(root, elem2);
|
|
|
|
priority_queue_add(root, elem3);
|
|
|
|
priority_queue_remove(root, elem2);
|
2014-03-31 14:02:47 +02:00
|
|
|
|
2014-05-07 00:41:21 +02:00
|
|
|
TEST_ASSERT(root->first == elem1);
|
|
|
|
TEST_ASSERT(root->first->next == elem3);
|
|
|
|
TEST_ASSERT_NULL(root->first->next->next);
|
2014-03-31 14:02:47 +02:00
|
|
|
}
|
|
|
|
|
2014-07-29 09:21:11 +02:00
|
|
|
Test *tests_core_priority_queue_tests(void)
|
2014-03-31 14:02:47 +02:00
|
|
|
{
|
|
|
|
EMB_UNIT_TESTFIXTURES(fixtures) {
|
2014-07-29 09:21:11 +02:00
|
|
|
new_TestFixture(test_priority_queue_remove_head_empty),
|
|
|
|
new_TestFixture(test_priority_queue_remove_head_one),
|
|
|
|
new_TestFixture(test_priority_queue_add_one),
|
|
|
|
new_TestFixture(test_priority_queue_add_two_equal),
|
|
|
|
new_TestFixture(test_priority_queue_add_two_distinct),
|
|
|
|
new_TestFixture(test_priority_queue_remove_one),
|
2014-03-31 14:02:47 +02:00
|
|
|
};
|
|
|
|
|
2014-07-29 09:21:11 +02:00
|
|
|
EMB_UNIT_TESTCALLER(core_priority_queue_tests, set_up, NULL,
|
2014-03-31 14:02:47 +02:00
|
|
|
fixtures);
|
|
|
|
|
2014-07-29 09:21:11 +02:00
|
|
|
return (Test *)&core_priority_queue_tests;
|
2014-03-31 14:02:47 +02:00
|
|
|
}
|