/* * Copyright (C) 2014 Intel Corporation. All rights reserved. * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2.1 of the License, or (at your option) any later version. * * 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 * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, see . */ #include #include #include #include #include #include #include #include "testsuite.h" static int test_array_append1(const struct test *t) { struct array array; const char *c1 = "test1"; array_init(&array, 2); array_append(&array, c1); assert_return(array.count == 1, EXIT_FAILURE); assert_return(array.array[0] == c1, EXIT_FAILURE); array_free_array(&array); return 0; } DEFINE_TEST(test_array_append1, .description = "test simple array append"); static int test_array_append2(const struct test *t) { struct array array; const char *c1 = "test1"; const char *c2 = "test2"; const char *c3 = "test3"; array_init(&array, 2); array_append(&array, c1); array_append(&array, c2); array_append(&array, c3); assert_return(array.count == 3, EXIT_FAILURE); assert_return(array.array[0] == c1, EXIT_FAILURE); assert_return(array.array[1] == c2, EXIT_FAILURE); assert_return(array.array[2] == c3, EXIT_FAILURE); array_free_array(&array); return 0; } DEFINE_TEST(test_array_append2, .description = "test array append over step"); static int test_array_append_unique(const struct test *t) { struct array array; const char *c1 = "test1"; const char *c2 = "test2"; const char *c3 = "test3"; array_init(&array, 2); array_append_unique(&array, c1); array_append_unique(&array, c2); array_append_unique(&array, c3); array_append_unique(&array, c3); array_append_unique(&array, c2); array_append_unique(&array, c1); assert_return(array.count == 3, EXIT_FAILURE); assert_return(array.array[0] == c1, EXIT_FAILURE); assert_return(array.array[1] == c2, EXIT_FAILURE); assert_return(array.array[2] == c3, EXIT_FAILURE); array_free_array(&array); return 0; } DEFINE_TEST(test_array_append_unique, .description = "test array append unique"); static int strptrcmp(const void *pa, const void *pb) { const char *a = *(const char **)pa; const char *b = *(const char **)pb; return strcmp(a, b); } static int test_array_sort(const struct test *t) { struct array array; const char *c1 = "test1"; const char *c2 = "test2"; const char *c3 = "test3"; array_init(&array, 2); array_append(&array, c1); array_append(&array, c2); array_append(&array, c3); array_append(&array, c2); array_append(&array, c3); array_append(&array, c1); array_sort(&array, strptrcmp); assert_return(array.count == 6, EXIT_FAILURE); assert_return(array.array[0] == c1, EXIT_FAILURE); assert_return(array.array[1] == c1, EXIT_FAILURE); assert_return(array.array[2] == c2, EXIT_FAILURE); assert_return(array.array[3] == c2, EXIT_FAILURE); assert_return(array.array[4] == c3, EXIT_FAILURE); assert_return(array.array[5] == c3, EXIT_FAILURE); array_free_array(&array); return 0; } DEFINE_TEST(test_array_sort, .description = "test array sort"); static int test_array_remove_at(const struct test *t) { struct array array; const char *c1 = "test1"; const char *c2 = "test2"; const char *c3 = "test3"; array_init(&array, 2); array_append(&array, c1); array_append(&array, c2); array_append(&array, c3); array_remove_at(&array, 2); assert_return(array.count == 2, EXIT_FAILURE); assert_return(array.array[0] == c1, EXIT_FAILURE); assert_return(array.array[1] == c2, EXIT_FAILURE); array_remove_at(&array, 0); assert_return(array.count == 1, EXIT_FAILURE); assert_return(array.array[0] == c2, EXIT_FAILURE); array_remove_at(&array, 0); assert_return(array.count == 0, EXIT_FAILURE); array_append(&array, c1); array_append(&array, c2); array_append(&array, c3); array_remove_at(&array, 1); assert_return(array.count == 2, EXIT_FAILURE); assert_return(array.array[0] == c1, EXIT_FAILURE); assert_return(array.array[1] == c3, EXIT_FAILURE); array_free_array(&array); return 0; } DEFINE_TEST(test_array_remove_at, .description = "test array remove at"); static int test_array_pop(const struct test *t) { struct array array; const char *c1 = "test1"; const char *c2 = "test2"; const char *c3 = "test3"; array_init(&array, 2); array_append(&array, c1); array_append(&array, c2); array_append(&array, c3); array_pop(&array); assert_return(array.count == 2, EXIT_FAILURE); assert_return(array.array[0] == c1, EXIT_FAILURE); assert_return(array.array[1] == c2, EXIT_FAILURE); array_pop(&array); array_pop(&array); assert_return(array.count == 0, EXIT_FAILURE); array_free_array(&array); return 0; } DEFINE_TEST(test_array_pop, .description = "test array pop"); TESTSUITE_MAIN();