diff options
| author | Sander Vrijders <sander.vrijders@intec.ugent.be> | 2017-01-16 16:09:33 +0100 | 
|---|---|---|
| committer | Sander Vrijders <sander.vrijders@intec.ugent.be> | 2017-01-16 16:09:33 +0100 | 
| commit | a5b135e9f409d59668c52be9fac5d94dae8ebe94 (patch) | |
| tree | f504b2fb750fa9228f2a96be3cd6477de09ed49a /src/lib/tests | |
| parent | 4be42017e51ff506da3fbdf6d2682e91a66f02c1 (diff) | |
| parent | fac7ffe8ea9f42ebcf67c011c944d165cbab3e3b (diff) | |
| download | ouroboros-a5b135e9f409d59668c52be9fac5d94dae8ebe94.tar.gz ouroboros-a5b135e9f409d59668c52be9fac5d94dae8ebe94.zip | |
Merged in dstaesse/ouroboros/be-btree (pull request #349)
lib: Add B-tree implementation
Diffstat (limited to 'src/lib/tests')
| -rw-r--r-- | src/lib/tests/CMakeLists.txt | 1 | ||||
| -rw-r--r-- | src/lib/tests/btree_test.c | 80 | 
2 files changed, 81 insertions, 0 deletions
| diff --git a/src/lib/tests/CMakeLists.txt b/src/lib/tests/CMakeLists.txt index 85535399..72455aa2 100644 --- a/src/lib/tests/CMakeLists.txt +++ b/src/lib/tests/CMakeLists.txt @@ -4,6 +4,7 @@ get_filename_component(PARENT_DIR ${PARENT_PATH} NAME)  create_test_sourcelist(${PARENT_DIR}_tests test_suite.c                         # Add new tests here                         bitmap_test.c +                       btree_test.c                         crc32_test.c                         hashtable_test.c                         sha3_test.c diff --git a/src/lib/tests/btree_test.c b/src/lib/tests/btree_test.c new file mode 100644 index 00000000..257a7e37 --- /dev/null +++ b/src/lib/tests/btree_test.c @@ -0,0 +1,80 @@ +/* + * Ouroboros - Copyright (C) 2016 - 2017 + * + * Test of the B-tree implementation + * + *    Dimitri Staessens <dimitri.staessens@intec.ugent.be> + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License version 2 as + * published by the Free Software Foundation. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. + */ + + +#include "btree.h" + +#include <stdio.h> +#include <stdlib.h> + +#define MAX_BTREE_KEY 10000 + +int btree_test(int     argc, +               char ** argv) +{ +        struct btree * tree; + +        int i; + +        (void) argc; +        (void) argv; + +        tree = btree_create(32); +        if (tree == NULL) +                return -1; + +        if (btree_search(tree, 8) != NULL) { +                btree_destroy(tree); +                return -1; +        } + +        for(i = 0; i < MAX_BTREE_KEY; ++i) +                if (btree_insert(tree, i, &argv)) { +                        printf("Failed to add element.\n"); +                        btree_destroy(tree); +                        return -1; +                } + +        for (i = 0; i < MAX_BTREE_KEY / 10; ++i) +                if (btree_search(tree, rand() % MAX_BTREE_KEY) != &argv) { +                        printf("Added element not in tree.\n"); +                        btree_destroy(tree); +                        return -1; +                } + +        for (i = 0; i < MAX_BTREE_KEY / 10; ++i) +                if (btree_remove(tree, i)) { +                        printf("Failed to remove element.\n"); +                        btree_destroy(tree); +                        return -1; +                } + +        for (i = 0; i < MAX_BTREE_KEY / 10; ++i) +                if (btree_search(tree, rand() % MAX_BTREE_KEY / 10) != &argv) { +                        printf("Removed element found in tree.\n"); +                        btree_destroy(tree); +                        return -1; +                } + +        btree_destroy(tree); + +        return 0; +} | 
