X-Git-Url: https://git.librecmc.org/?a=blobdiff_plain;f=src%2Futil%2Ftest_container_heap.c;h=bb5b68a721e3e5a3229a601104e390011eb88c34;hb=8226d9807819dbbc4b05751f4cdd09603832367d;hp=84f992686c1b0e94108478c58b0e8e8021c492ab;hpb=a6e9fbbab174e1c8142827fa5624aa0e59156298;p=oweals%2Fgnunet.git diff --git a/src/util/test_container_heap.c b/src/util/test_container_heap.c index 84f992686..bb5b68a72 100644 --- a/src/util/test_container_heap.c +++ b/src/util/test_container_heap.c @@ -4,7 +4,7 @@ GNUnet is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published - by the Free Software Foundation; either version 2, or (at your + by the Free Software Foundation; either version 3, or (at your option) any later version. GNUnet is distributed in the hope that it will be useful, but @@ -20,94 +20,249 @@ /** * @author Nathan Evans - * @file util/containers/heaptest.c + * @file util/test_container_heap.c * @brief Test of heap operations */ -#include "gnunet_util.h" -#include "gnunet_util_containers.h" -#include "dv.h" +#include "platform.h" +#include "gnunet_common.h" +#include "gnunet_container_lib.h" static int -iterator_callback (void *element, GNUNET_CONTAINER_HeapCost cost, - struct GNUNET_CONTAINER_Heap *root, void *cls) +iterator_callback (void *cls, + struct GNUNET_CONTAINER_HeapNode *node, + void *element, + GNUNET_CONTAINER_HeapCostType cost) { - struct GNUNET_dv_neighbor *node; - node = (struct GNUNET_dv_neighbor *) element; - fprintf (stdout, "%d\n", node->cost); - //fprintf (stdout, "%d\n", ((struct GNUNET_dv_neighbor *)element)->cost); - return GNUNET_OK; } - -int -main (int argc, char **argv) +static int +check () { struct GNUNET_CONTAINER_Heap *myHeap; - struct GNUNET_dv_neighbor *neighbor1; - struct GNUNET_dv_neighbor *neighbor2; - struct GNUNET_dv_neighbor *neighbor3; - struct GNUNET_dv_neighbor *neighbor4; - struct GNUNET_dv_neighbor *neighbor5; - struct GNUNET_dv_neighbor *neighbor6; - - GNUNET_log_setup ("test-container-heap", "WARNING", NULL); - - myHeap = GNUNET_CONTAINER_heap_create (GNUNET_CONTAINER_HEAP_ORDER_MAX); - - neighbor1 = malloc (sizeof (struct GNUNET_dv_neighbor)); - neighbor2 = malloc (sizeof (struct GNUNET_dv_neighbor)); - neighbor3 = malloc (sizeof (struct GNUNET_dv_neighbor)); - neighbor4 = malloc (sizeof (struct GNUNET_dv_neighbor)); - neighbor5 = malloc (sizeof (struct GNUNET_dv_neighbor)); - neighbor6 = malloc (sizeof (struct GNUNET_dv_neighbor)); - - neighbor1->cost = 60; - neighbor2->cost = 50; - neighbor3->cost = 70; - neighbor4->cost = 120; - neighbor5->cost = 100; - neighbor6->cost = 30; - - GNUNET_CONTAINER_heap_insert (myHeap, neighbor1, neighbor1->cost); - GNUNET_CONTAINER_heap_iterate (myHeap, iterator_callback, NULL); + struct GNUNET_CONTAINER_HeapNode *n1; + struct GNUNET_CONTAINER_HeapNode *n2; + struct GNUNET_CONTAINER_HeapNode *n3; + struct GNUNET_CONTAINER_HeapNode *n4; + struct GNUNET_CONTAINER_HeapNode *n5; + struct GNUNET_CONTAINER_HeapNode *n6; + struct GNUNET_CONTAINER_HeapNode *n7; + struct GNUNET_CONTAINER_HeapNode *n8; - fprintf (stdout, "\n"); - GNUNET_CONTAINER_heap_insert (myHeap, neighbor2, neighbor2->cost); + myHeap = GNUNET_CONTAINER_heap_create (GNUNET_CONTAINER_HEAP_ORDER_MIN); + + // GNUNET_CONTAINER_heap_remove_root heap empty, taking if-branch + n1 = GNUNET_CONTAINER_heap_remove_root (myHeap); + GNUNET_assert (NULL == n1); + + // GNUNET_CONTAINER_heap_peek heap empty, taking if-branch + n1 = GNUNET_CONTAINER_heap_peek (myHeap); + GNUNET_assert (NULL == n1); + + // GNUNET_CONTAINER_heap_walk_get_next: heap empty, taking if-branch + n1 = GNUNET_CONTAINER_heap_walk_get_next (myHeap); + GNUNET_assert (NULL == n1); + + n1 = GNUNET_CONTAINER_heap_insert (myHeap, "11", 11); + GNUNET_assert (NULL != n1); + - GNUNET_CONTAINER_heap_iterate (myHeap, iterator_callback, NULL); - fprintf (stdout, "\n"); - GNUNET_CONTAINER_heap_insert (myHeap, neighbor3, neighbor3->cost); + // GNUNET_CONTAINER_heap_peek not empty, taking if-branch + n2 = NULL; + n2 = GNUNET_CONTAINER_heap_peek (myHeap); + GNUNET_assert (NULL != n2); + + // GNUNET_CONTAINER_heap_walk_get_next: 1 element + n1 = NULL; + n1 = GNUNET_CONTAINER_heap_walk_get_next(myHeap); + GNUNET_assert (NULL != n1); + + GNUNET_CONTAINER_heap_iterate (myHeap, &iterator_callback, NULL); + GNUNET_assert (1 == GNUNET_CONTAINER_heap_get_size (myHeap)); + n2 = GNUNET_CONTAINER_heap_insert (myHeap, "78", 78); + GNUNET_assert (2 == GNUNET_CONTAINER_heap_get_size (myHeap)); + GNUNET_assert (0 == strcmp ("78", + GNUNET_CONTAINER_heap_remove_node (myHeap, n2))); + GNUNET_assert (1 == GNUNET_CONTAINER_heap_get_size (myHeap)); + GNUNET_CONTAINER_heap_iterate (myHeap, &iterator_callback, NULL); + + n3 = GNUNET_CONTAINER_heap_insert (myHeap, "15", 5); + GNUNET_CONTAINER_heap_update_cost (myHeap, n3, 15); + GNUNET_assert (2 == GNUNET_CONTAINER_heap_get_size (myHeap)); + GNUNET_CONTAINER_heap_iterate (myHeap, &iterator_callback, NULL); + + n4 = GNUNET_CONTAINER_heap_insert (myHeap, "50", 50); + GNUNET_CONTAINER_heap_update_cost (myHeap, n4, 50); + GNUNET_assert (3 == GNUNET_CONTAINER_heap_get_size (myHeap)); + GNUNET_CONTAINER_heap_iterate (myHeap, &iterator_callback, NULL); - GNUNET_CONTAINER_heap_iterate (myHeap, iterator_callback, NULL); - fprintf (stdout, "\n"); - GNUNET_CONTAINER_heap_insert (myHeap, neighbor4, neighbor4->cost); - - GNUNET_CONTAINER_heap_iterate (myHeap, iterator_callback, NULL); - fprintf (stdout, "\n"); - GNUNET_CONTAINER_heap_insert (myHeap, neighbor5, neighbor5->cost); + n5 = GNUNET_CONTAINER_heap_insert (myHeap, "100", 100); + n6 = GNUNET_CONTAINER_heap_insert (myHeap, "30/200", 30); + GNUNET_assert (5 == GNUNET_CONTAINER_heap_get_size (myHeap)); + GNUNET_CONTAINER_heap_remove_node (myHeap, n5); + GNUNET_assert (0 == strcmp ("11", + GNUNET_CONTAINER_heap_remove_root (myHeap))); /* n1 */ + GNUNET_CONTAINER_heap_update_cost (myHeap, n6, 200); + GNUNET_CONTAINER_heap_remove_node (myHeap, n3); + GNUNET_assert (0 == strcmp ("50", + GNUNET_CONTAINER_heap_remove_root (myHeap))); /* n4 */ + GNUNET_assert (0 == strcmp ("30/200", + GNUNET_CONTAINER_heap_remove_root (myHeap))); /* n6 */ + GNUNET_assert (0 == GNUNET_CONTAINER_heap_get_size (myHeap)); + + GNUNET_CONTAINER_heap_destroy (myHeap); + + // My additions to a complete testcase + // Testing a GNUNET_CONTAINER_HEAP_ORDER_MIN + // Testing remove_node - GNUNET_CONTAINER_heap_iterate (myHeap, iterator_callback, NULL); - fprintf (stdout, "\n"); - GNUNET_CONTAINER_heap_insert (myHeap, neighbor6, neighbor6->cost); + myHeap = GNUNET_CONTAINER_heap_create (GNUNET_CONTAINER_HEAP_ORDER_MIN); + + n1 = GNUNET_CONTAINER_heap_insert (myHeap, "10", 10); + GNUNET_CONTAINER_heap_update_cost (myHeap, n1, 15); + + GNUNET_assert (0 == strcmp ("10", GNUNET_CONTAINER_heap_remove_node (myHeap,n1))); + + n1 = GNUNET_CONTAINER_heap_insert (myHeap, "10", 10); + n2 = GNUNET_CONTAINER_heap_insert (myHeap, "20", 10); - GNUNET_CONTAINER_heap_iterate (myHeap, iterator_callback, NULL); - fprintf (stdout, "\n"); - GNUNET_CONTAINER_heap_remove_node (myHeap, neighbor5); + GNUNET_CONTAINER_heap_walk_get_next (myHeap); + GNUNET_assert (0 == strcmp ("20", GNUNET_CONTAINER_heap_remove_node (myHeap,n2))); + GNUNET_assert (0 == strcmp ("10", GNUNET_CONTAINER_heap_remove_node (myHeap,n1))); + + n1 = GNUNET_CONTAINER_heap_insert (myHeap, "10", 10); + n2 = GNUNET_CONTAINER_heap_insert (myHeap, "20", 10); + n3 = GNUNET_CONTAINER_heap_insert (myHeap, "30", 10); + + GNUNET_CONTAINER_heap_remove_node (myHeap,n2); + GNUNET_CONTAINER_heap_remove_node (myHeap,n1); + GNUNET_assert (0 == strcmp ("30", GNUNET_CONTAINER_heap_remove_root (myHeap))); + + n1 = GNUNET_CONTAINER_heap_insert (myHeap, "10", 10); + n2 = GNUNET_CONTAINER_heap_insert (myHeap, "20", 10); + n3 = GNUNET_CONTAINER_heap_insert (myHeap, "30", 10); - GNUNET_CONTAINER_heap_iterate (myHeap, iterator_callback, NULL); - fprintf (stdout, "\n"); - GNUNET_CONTAINER_heap_remove_root (myHeap); + GNUNET_CONTAINER_heap_remove_node (myHeap,n2); + GNUNET_CONTAINER_heap_remove_node (myHeap,n1); + GNUNET_assert (0 == strcmp ("30", GNUNET_CONTAINER_heap_remove_node (myHeap,n3))); + + n1 = GNUNET_CONTAINER_heap_insert (myHeap, "10", 10); + n2 = GNUNET_CONTAINER_heap_insert (myHeap, "20", 20); + n3 = GNUNET_CONTAINER_heap_insert (myHeap, "30", 30); + + GNUNET_assert (0 == strcmp ("20", GNUNET_CONTAINER_heap_remove_node (myHeap,n2))); + GNUNET_assert (0 == strcmp ("10", GNUNET_CONTAINER_heap_remove_root (myHeap))); + GNUNET_assert (0 == strcmp ("30", GNUNET_CONTAINER_heap_remove_root (myHeap))); + + n1 = GNUNET_CONTAINER_heap_insert (myHeap, "10", 10); + n2 = GNUNET_CONTAINER_heap_insert (myHeap, "20", 20); + n3 = GNUNET_CONTAINER_heap_insert (myHeap, "30", 30); + n4 = GNUNET_CONTAINER_heap_insert (myHeap, "40", 40); + n5 = GNUNET_CONTAINER_heap_insert (myHeap, "50", 50); + n6 = GNUNET_CONTAINER_heap_insert (myHeap, "60", 60); + + // Inserting nodes deeper in the tree with lower costs + n7 = GNUNET_CONTAINER_heap_insert (myHeap, "70", 10); + n8 = GNUNET_CONTAINER_heap_insert (myHeap, "80", 10); + + GNUNET_assert (0 == strcmp ("30", GNUNET_CONTAINER_heap_remove_node (myHeap,n3))); + + // Cleaning up... + GNUNET_assert (0 == strcmp ("60", GNUNET_CONTAINER_heap_remove_node (myHeap,n6))); + GNUNET_assert (0 == strcmp ("50", GNUNET_CONTAINER_heap_remove_node (myHeap,n5))); + + // Testing heap_walk_get_next + GNUNET_CONTAINER_heap_walk_get_next (myHeap); + GNUNET_CONTAINER_heap_walk_get_next (myHeap); + GNUNET_CONTAINER_heap_walk_get_next (myHeap);; + GNUNET_CONTAINER_heap_walk_get_next (myHeap); + GNUNET_CONTAINER_heap_walk_get_next (myHeap); + + GNUNET_assert (0 == strcmp ("10", GNUNET_CONTAINER_heap_remove_node (myHeap,n1))); + GNUNET_assert (0 == strcmp ("20", GNUNET_CONTAINER_heap_remove_node (myHeap,n2))); + GNUNET_assert (0 == strcmp ("40", GNUNET_CONTAINER_heap_remove_node (myHeap,n4))); + GNUNET_assert (0 == strcmp ("70", GNUNET_CONTAINER_heap_remove_node (myHeap,n7))); + GNUNET_assert (0 == strcmp ("80", GNUNET_CONTAINER_heap_remove_node (myHeap,n8))); + + // End Testing remove_node + + // Testing a GNUNET_CONTAINER_HEAP_ORDER_MAX + GNUNET_CONTAINER_heap_destroy (myHeap); + + myHeap = GNUNET_CONTAINER_heap_create (GNUNET_CONTAINER_HEAP_ORDER_MAX); + + n1 = GNUNET_CONTAINER_heap_insert (myHeap, "10", 10); + GNUNET_CONTAINER_heap_update_cost (myHeap, n1, 15); + + GNUNET_assert (0 == strcmp ("10", GNUNET_CONTAINER_heap_remove_node (myHeap,n1))); + + n1 = GNUNET_CONTAINER_heap_insert (myHeap, "10", 10); + n2 = GNUNET_CONTAINER_heap_insert (myHeap, "20", 10); - GNUNET_CONTAINER_heap_iterate (myHeap, iterator_callback, NULL); - fprintf (stdout, "\n"); - GNUNET_CONTAINER_heap_update_cost (myHeap, neighbor6, 200); + GNUNET_CONTAINER_heap_walk_get_next (myHeap); + GNUNET_assert (0 == strcmp ("20", GNUNET_CONTAINER_heap_remove_node (myHeap,n2))); + GNUNET_assert (0 == strcmp ("10", GNUNET_CONTAINER_heap_remove_node (myHeap,n1))); + + n1 = GNUNET_CONTAINER_heap_insert (myHeap, "10", 10); + n2 = GNUNET_CONTAINER_heap_insert (myHeap, "20", 10); + n3 = GNUNET_CONTAINER_heap_insert (myHeap, "30", 10); + + GNUNET_CONTAINER_heap_remove_node (myHeap,n2); + GNUNET_CONTAINER_heap_remove_node (myHeap,n1); + GNUNET_assert (0 == strcmp ("30", GNUNET_CONTAINER_heap_remove_root (myHeap))); + + n1 = GNUNET_CONTAINER_heap_insert (myHeap, "10", 10); + n2 = GNUNET_CONTAINER_heap_insert (myHeap, "20", 10); + n3 = GNUNET_CONTAINER_heap_insert (myHeap, "30", 10); - GNUNET_CONTAINER_heap_iterate (myHeap, iterator_callback, NULL); - fprintf (stdout, "\n"); + GNUNET_CONTAINER_heap_remove_node (myHeap,n2); + GNUNET_CONTAINER_heap_remove_node (myHeap,n1); + GNUNET_assert (0 == strcmp ("30", GNUNET_CONTAINER_heap_remove_node (myHeap,n3))); + + n1 = GNUNET_CONTAINER_heap_insert (myHeap, "10", 10); + n2 = GNUNET_CONTAINER_heap_insert (myHeap, "20", 20); + n3 = GNUNET_CONTAINER_heap_insert (myHeap, "30", 30); + n4 = GNUNET_CONTAINER_heap_insert (myHeap, "40", 40); + n5 = GNUNET_CONTAINER_heap_insert (myHeap, "50", 50); + n6 = GNUNET_CONTAINER_heap_insert (myHeap, "60", 60); + + // Inserting nodes deeper in the tree with lower costs + n7 = GNUNET_CONTAINER_heap_insert (myHeap, "70", 10); + n8 = GNUNET_CONTAINER_heap_insert (myHeap, "80", 10); + + GNUNET_assert (0 == strcmp ("30", GNUNET_CONTAINER_heap_remove_node (myHeap,n3))); + + // Cleaning up... + GNUNET_assert (0 == strcmp ("60", GNUNET_CONTAINER_heap_remove_node (myHeap,n6))); + GNUNET_assert (0 == strcmp ("50", GNUNET_CONTAINER_heap_remove_node (myHeap,n5))); + + // Testing heap_walk_get_next + GNUNET_CONTAINER_heap_walk_get_next (myHeap); + GNUNET_CONTAINER_heap_walk_get_next (myHeap); + GNUNET_CONTAINER_heap_walk_get_next (myHeap);; + GNUNET_CONTAINER_heap_walk_get_next (myHeap); + GNUNET_CONTAINER_heap_walk_get_next (myHeap); + + GNUNET_assert (0 == strcmp ("10", GNUNET_CONTAINER_heap_remove_node (myHeap,n1))); + GNUNET_assert (0 == strcmp ("20", GNUNET_CONTAINER_heap_remove_node (myHeap,n2))); + GNUNET_assert (0 == strcmp ("40", GNUNET_CONTAINER_heap_remove_node (myHeap,n4))); + GNUNET_assert (0 == strcmp ("70", GNUNET_CONTAINER_heap_remove_node (myHeap,n7))); + GNUNET_assert (0 == strcmp ("80", GNUNET_CONTAINER_heap_remove_node (myHeap,n8))); + + // End Testing remove_node + GNUNET_CONTAINER_heap_destroy (myHeap); + return 0; } -/* end of heaptest.c */ + +int +main (int argc, char **argv) +{ + GNUNET_log_setup ("test-container-heap", "WARNING", NULL); + return check(); +} + +/* end of test_container_heap.c */