diff options
author | David Oberhollenzer <david.oberhollenzer@sigma-star.at> | 2021-03-05 15:53:21 +0100 |
---|---|---|
committer | David Oberhollenzer <david.oberhollenzer@sigma-star.at> | 2021-03-06 22:08:36 +0100 |
commit | b950412ca3a91aa37349cf51ebe98cc84767d448 (patch) | |
tree | e3bb062114d019984321a5a21b29818c88c36795 /tests/str_table.c | |
parent | 3fc6bf24b5cc071fc323f08ece541e37578f6369 (diff) |
Cleanup: add some structure to the test directory
Signed-off-by: David Oberhollenzer <david.oberhollenzer@sigma-star.at>
Diffstat (limited to 'tests/str_table.c')
-rw-r--r-- | tests/str_table.c | 84 |
1 files changed, 0 insertions, 84 deletions
diff --git a/tests/str_table.c b/tests/str_table.c deleted file mode 100644 index 7bcf4cc..0000000 --- a/tests/str_table.c +++ /dev/null @@ -1,84 +0,0 @@ -/* SPDX-License-Identifier: GPL-3.0-or-later */ -/* - * str_table.c - * - * Copyright (C) 2019 David Oberhollenzer <goliath@infraroot.at> - */ -#include "config.h" - -#include "str_table.h" -#include "fstream.h" -#include "compat.h" -#include "test.h" - -static char *strings[1000]; - -static int read_strings(void) -{ - istream_t *fp; - ssize_t ret; - char *line; - int i; - - fp = istream_open_file("words.txt"); - TEST_NOT_NULL(fp); - - for (i = 0; i < 1000; ++i) { - ret = istream_get_line(fp, &line, NULL, 0); - TEST_EQUAL_I(ret, 0); - - strings[i] = line; - } - - sqfs_destroy(fp); - return 0; -} - -int main(void) -{ - str_table_t table; - size_t i, j, idx; - const char *str; - - TEST_ASSERT(chdir(TEST_PATH) == 0); - - if (read_strings()) - return EXIT_FAILURE; - - TEST_ASSERT(str_table_init(&table, 64) == 0); - - for (i = 0; i < 1000; ++i) { - TEST_ASSERT(str_table_get_index(&table, strings[i], &idx) == 0); - - TEST_EQUAL_UI(idx, i); - - for (j = 0; j <= i; ++j) { - str = str_table_get_string(&table, j); - - TEST_NOT_NULL(str); - TEST_ASSERT(str != strings[i]); - TEST_STR_EQUAL(str, strings[j]); - } - - for (; j < 1000; ++j) - TEST_NULL(str_table_get_string(&table, j)); - } - - for (i = 0; i < 1000; ++i) { - TEST_ASSERT(str_table_get_index(&table, strings[i], &idx) == 0); - TEST_EQUAL_UI(idx, i); - - str = str_table_get_string(&table, i); - - TEST_NOT_NULL(str); - TEST_ASSERT(str != strings[i]); - TEST_STR_EQUAL(str, strings[i]); - } - - str_table_cleanup(&table); - - for (i = 0; i < 1000; ++i) - free(strings[i]); - - return EXIT_SUCCESS; -} |