Refactors the API's demand editing functions
This commit is contained in:
@@ -25,8 +25,3 @@ add_executable(test_filemanager ./test_filemanager.cpp
|
||||
target_include_directories(test_filemanager PUBLIC ../../src/)
|
||||
target_link_libraries(test_filemanager ${Boost_LIBRARIES})
|
||||
|
||||
|
||||
add_executable(test_list ./test_list.cpp
|
||||
../../src/util/list.c)
|
||||
target_include_directories(test_list PUBLIC ../../src/)
|
||||
target_link_libraries(test_list ${Boost_LIBRARIES})
|
||||
|
||||
@@ -1,248 +0,0 @@
|
||||
/*
|
||||
******************************************************************************
|
||||
Project: OWA EPANET
|
||||
Version: 2.2
|
||||
Module: util/list.h
|
||||
Description: Generic list
|
||||
https://gist.github.com/pseudomuto/6334796#file-sample_app-c
|
||||
Accessed: April 9, 2019
|
||||
Authors: David Muto, Modified by Michael E. Tryby
|
||||
Copyright: see AUTHORS
|
||||
License: see LICENSE
|
||||
Last Updated: 04/09/2019
|
||||
******************************************************************************
|
||||
*/
|
||||
|
||||
#include <stdlib.h>
|
||||
#include <string.h>
|
||||
#include <time.h>
|
||||
|
||||
#define BOOST_TEST_MODULE list
|
||||
#include <boost/test/unit_test.hpp>
|
||||
|
||||
#include "util/list.h"
|
||||
|
||||
|
||||
boost::test_tools::predicate_result check_string(std::string test, std::string ref)
|
||||
{
|
||||
if (ref.compare(test) == 0)
|
||||
return true;
|
||||
else
|
||||
return false;
|
||||
}
|
||||
|
||||
int *get_int_data(list_node_t *lnode) {
|
||||
return (int *)get_data(lnode);
|
||||
}
|
||||
|
||||
bool iterate_int(list_node_t *lnode)
|
||||
{
|
||||
printf("At Key: %d Found value: %d\n", get_key(lnode), *get_int_data(lnode));
|
||||
return true;
|
||||
}
|
||||
|
||||
|
||||
BOOST_AUTO_TEST_SUITE(test_list)
|
||||
|
||||
|
||||
BOOST_AUTO_TEST_CASE(test_create_delete) {
|
||||
|
||||
list_t *list;
|
||||
list = create_list(sizeof(int), NULL);
|
||||
|
||||
delete_list(list);
|
||||
}
|
||||
|
||||
|
||||
BOOST_AUTO_TEST_CASE(test_int_list){
|
||||
|
||||
int i, numbers = 10;
|
||||
list_t *list = NULL;
|
||||
|
||||
int key[10 + 1];
|
||||
|
||||
srand((unsigned int)time(0));
|
||||
|
||||
list = create_list(sizeof(int), NULL);
|
||||
|
||||
for(i = 1; i <= numbers; i++) {
|
||||
key[i] = append_list(list, &i);
|
||||
}
|
||||
BOOST_CHECK(size_list(list) == 10);
|
||||
|
||||
listIterator iterator = (listIterator)iterate_int;
|
||||
for_each_list(list, iterator);
|
||||
|
||||
list_node_t *lnode = search_list(list, key[5]);
|
||||
BOOST_CHECK(get_key(lnode) == key[5]);
|
||||
|
||||
delete_list(list);
|
||||
}
|
||||
|
||||
|
||||
inline char *get_string_data(list_node_t *lnode)
|
||||
{
|
||||
return *(char **)get_data(lnode);
|
||||
}
|
||||
|
||||
bool iterate_string(list_node_t *lnode)
|
||||
{
|
||||
printf("Found string value: %s\n", get_string_data(lnode));
|
||||
return true;
|
||||
}
|
||||
|
||||
void free_string(void *data)
|
||||
{
|
||||
free(*(char **)data);
|
||||
}
|
||||
|
||||
struct FixtureStrings{
|
||||
FixtureStrings() {
|
||||
list = NULL;
|
||||
|
||||
int numNames = 5;
|
||||
const char *names[] = { "David", "Kevin", "Michael", "Craig", "Jimi" };
|
||||
|
||||
list = create_list(sizeof(char *), free_string);
|
||||
|
||||
char *name;
|
||||
for (int i = 0; i < numNames; i++) {
|
||||
name = strdup(names[i]);
|
||||
append_list(list, &name);
|
||||
}
|
||||
}
|
||||
~FixtureStrings() {
|
||||
delete_list(list);
|
||||
}
|
||||
list_t *list;
|
||||
};
|
||||
|
||||
BOOST_FIXTURE_TEST_CASE(test_string_list, FixtureStrings) {
|
||||
|
||||
BOOST_CHECK(size_list(list) == 5);
|
||||
|
||||
listIterator iterator = (listIterator)iterate_string;
|
||||
for_each_list(list, iterator);
|
||||
}
|
||||
|
||||
|
||||
BOOST_FIXTURE_TEST_CASE(test_head_list, FixtureStrings) {
|
||||
|
||||
BOOST_CHECK(check_string(get_string_data(head_list(list, false)), "David"));
|
||||
BOOST_CHECK(size_list(list) == 5);
|
||||
|
||||
list_node_t *lnode = head_list(list, true);
|
||||
BOOST_CHECK(check_string(get_string_data(lnode), "David"));
|
||||
delete_node(list, lnode);
|
||||
|
||||
BOOST_CHECK(check_string(get_string_data(head_list(list, false)), "Kevin"));
|
||||
BOOST_CHECK(size_list(list) == 4);
|
||||
}
|
||||
|
||||
|
||||
BOOST_FIXTURE_TEST_CASE(test_tail_list, FixtureStrings) {
|
||||
|
||||
BOOST_CHECK(check_string(get_string_data(tail_list(list)), "Jimi"));
|
||||
BOOST_CHECK(size_list(list) == 5);
|
||||
}
|
||||
|
||||
|
||||
typedef struct test_data_s {
|
||||
int num;
|
||||
char *name;
|
||||
} test_data_t;
|
||||
|
||||
test_data_t *create_test_data(int number, const char *name){
|
||||
|
||||
test_data_t *data = (test_data_t *)malloc(sizeof(test_data_t));
|
||||
data->num = number;
|
||||
if (name)
|
||||
data->name = strdup(name);
|
||||
else
|
||||
data->name = NULL;
|
||||
|
||||
return data;
|
||||
}
|
||||
|
||||
void delete_test_data(void *data) {
|
||||
|
||||
test_data_t *test_data = *(test_data_t **)data;
|
||||
|
||||
if (test_data->name)
|
||||
free(test_data->name);
|
||||
|
||||
free(test_data);
|
||||
}
|
||||
|
||||
inline test_data_t *get_test_data(list_node_t *lnode)
|
||||
{
|
||||
return *(test_data_t **)get_data(lnode);
|
||||
}
|
||||
|
||||
bool iterate_test_data(list_node_t *lnode)
|
||||
{
|
||||
test_data_t *test_data = get_test_data(lnode);
|
||||
|
||||
printf("Found number: %i name: %s\n", test_data->num, test_data->name);
|
||||
return true;
|
||||
}
|
||||
|
||||
|
||||
char *get_name(list_node_t *lnode)
|
||||
{
|
||||
return get_test_data(lnode)->name;
|
||||
}
|
||||
|
||||
BOOST_AUTO_TEST_CASE(test_struct_list){
|
||||
|
||||
int key, head_key, tail_key;
|
||||
|
||||
list_t *list = NULL;
|
||||
list = create_list(sizeof(test_data_t *), delete_test_data);
|
||||
|
||||
|
||||
test_data_t *data = create_test_data(1, "David");
|
||||
head_key = append_list(list, &data);
|
||||
|
||||
data = create_test_data(2, "Kevin");
|
||||
key = append_list(list, &data);
|
||||
|
||||
data = create_test_data(3, "Michael");
|
||||
append_list(list, &data);
|
||||
|
||||
data = create_test_data(4, "Craig");
|
||||
append_list(list, &data);
|
||||
|
||||
data = create_test_data(5, "Jimi");
|
||||
tail_key = append_list(list, &data);
|
||||
|
||||
BOOST_CHECK(size_list(list) == 5);
|
||||
|
||||
listIterator iterator = (listIterator)iterate_test_data;
|
||||
for_each_list(list, iterator);
|
||||
|
||||
|
||||
// locate a list node by a key
|
||||
printf("Found %s!\n", get_name(search_list(list, key)));
|
||||
|
||||
printf("Removing Kevin\n");
|
||||
remove_node(list, key);
|
||||
for_each_list(list, iterator);
|
||||
|
||||
printf("Removing David\n");
|
||||
remove_node(list, head_key);
|
||||
for_each_list(list, iterator);
|
||||
|
||||
printf("Removing Jimi\n");
|
||||
remove_node(list, tail_key);
|
||||
for_each_list(list, iterator);
|
||||
|
||||
list_node_t *lnode = head_list(list, true);
|
||||
delete_node(list, lnode);
|
||||
|
||||
delete_list(list);
|
||||
}
|
||||
|
||||
// TODO: search for an index and return data
|
||||
|
||||
BOOST_AUTO_TEST_SUITE_END()
|
||||
Reference in New Issue
Block a user