代码拉取完成,页面将自动刷新
#include "vc_vector_test.h"
#include <stdlib.h>
#include <string.h>
#include <inttypes.h>
#include "vc_vector.h"
#define ASSERT_EQ(expected, actual) \
do { \
if ((expected) != (actual)) { \
fprintf(stderr, \
"Failed line %u. Expected: %"PRIuMAX". Actual: %"PRIuMAX".\n", \
__LINE__, (uintmax_t)(expected), (uintmax_t)(actual)); \
abort(); \
} \
} while (0)
#define ASSERT_NE(not_expected, actual) \
do { \
if ((not_expected) == (actual)) { \
fprintf(stderr, \
"Failed line %u. Unexpected actual value: %"PRIuMAX".\n", \
__LINE__, (uintmax_t)(actual)); \
abort(); \
} \
} while (0)
#define ASSERT_TRUE(actual) ASSERT_EQ(true, (actual))
#define ASSERT_FALSE(actual) ASSERT_EQ(false, (actual))
#define PRINT_VECTOR(vector, type, format) \
do { \
for (void* i = vc_vector_begin(vector); \
i != vc_vector_end(vector); \
i = vc_vector_next(vector, i)) { \
fprintf(stderr, format, *(type*)i); \
} \
fprintf(stderr, "\n"); \
} while (0)
#define PRINT_VECTOR_INT(vector) PRINT_VECTOR(vector, int, "%d; ")
#define PRINT_VECTOR_STR(vector) PRINT_VECTOR(vector, char *, "%s; ")
char *mystrdup(const char *s) {
size_t size = strlen(s) + 1;
char *copy = malloc(size);
if (copy != NULL)
memcpy(copy, s, size);
return copy;
}
// ----------------------------------------------------------------------------
void test_vc_vector_create() {
const size_t size_of_type = sizeof(int);
const size_t default_count_of_elements = vc_vector_get_default_count_of_elements();
// Creating vector with default count of elements
vc_vector* vector = vc_vector_create(0, size_of_type, NULL);
ASSERT_NE(NULL, vector);
ASSERT_EQ(0, vc_vector_count(vector));
ASSERT_EQ(0, vc_vector_size(vector));
ASSERT_EQ(default_count_of_elements, vc_vector_max_count(vector));
ASSERT_EQ(size_of_type * default_count_of_elements, vc_vector_max_size(vector));
vc_vector_release(vector);
// Creating vector with custom count of elements
const size_t test_count_of_elements = 7;
vector = vc_vector_create(test_count_of_elements, size_of_type, NULL);
ASSERT_NE(NULL, vector);
ASSERT_EQ(0, vc_vector_count(vector));
ASSERT_EQ(0, vc_vector_size(vector));
ASSERT_EQ(test_count_of_elements, vc_vector_max_count(vector));
ASSERT_EQ(size_of_type * test_count_of_elements, vc_vector_max_size(vector));
vc_vector_release(vector);
// Creating vector with zero size of single element
vector = vc_vector_create(0, 0, NULL);
ASSERT_EQ(NULL, vector);
// Creating copy of vector
vector = vc_vector_create(0, size_of_type, NULL);
ASSERT_NE(NULL, vector);
for (int i = 0; (size_t)i < test_count_of_elements; ++i) {
ASSERT_TRUE(vc_vector_push_back(vector, &i));
}
vc_vector* vector_copy = vc_vector_create_copy(vector);
ASSERT_NE(NULL, vector_copy);
ASSERT_TRUE(vc_vector_is_equals(vector, vector_copy));
vc_vector_release(vector_copy);
vc_vector_release(vector);
printf("%s passed.\n", __func__);
}
void test_vc_vector_element_access() {
const int test_num_start = 18;
const int test_num_end = 36;
const size_t size_of_type = sizeof(test_num_start);
vc_vector* vector = vc_vector_create(0, size_of_type, NULL);
ASSERT_NE(0, vector);
for (int i = test_num_start; i <= test_num_end; ++i) {
ASSERT_TRUE(vc_vector_push_back(vector, &i));
}
ASSERT_EQ(test_num_start, *(int*)vc_vector_front(vector));
ASSERT_EQ(test_num_start, *(int*)vc_vector_data(vector));
ASSERT_EQ(test_num_end, *(int*)vc_vector_back(vector));
for (int i = test_num_start, j = 0; i <= test_num_end; ++i, ++j) {
ASSERT_EQ(i, *(int*)vc_vector_at(vector, j));
}
vc_vector_release(vector);
printf("%s passed.\n", __func__);
}
void test_vc_vector_iterators() {
vc_vector* vector = vc_vector_create(0, sizeof(int), NULL);
ASSERT_NE(NULL, vector);
const size_t test_count_of_elements = 23;
for (int i = 0; (size_t)i < test_count_of_elements; ++i) {
ASSERT_TRUE(vc_vector_push_back(vector, &i));
}
int j = 0;
for (void* i = vc_vector_begin(vector);
i != vc_vector_end(vector);
i = vc_vector_next(vector, i), ++j) {
ASSERT_EQ(j, *(int*)i);
}
ASSERT_EQ(test_count_of_elements, (size_t)j);
vc_vector_release(vector);
printf("%s passed.\n", __func__);
}
void test_vc_vector_capacity() {
const size_t size_of_element = sizeof(int);
const float growth_factor = vc_vector_get_growth_factor();
ASSERT_EQ(1.5, growth_factor);
const size_t count_of_elements_initialized = 22;
const size_t max_size_of_vector_initialized = count_of_elements_initialized * size_of_element;
const size_t count_of_elements_ended = 23;
const size_t size_of_vector_ended = count_of_elements_ended * size_of_element;
const size_t max_count_of_vector_ended = count_of_elements_initialized * growth_factor;
const size_t max_size_of_vector_ended = max_count_of_vector_ended * size_of_element;
vc_vector* vector = vc_vector_create(count_of_elements_initialized, size_of_element, NULL);
ASSERT_NE(NULL, vector);
ASSERT_EQ(0, vc_vector_count(vector));
ASSERT_TRUE(vc_vector_empty(vector));
ASSERT_EQ(0, vc_vector_size(vector));
ASSERT_EQ(count_of_elements_initialized, vc_vector_max_count(vector));
ASSERT_EQ(max_size_of_vector_initialized, vc_vector_max_size(vector));
for (int i = 0; (size_t)i < count_of_elements_ended; ++i) {
ASSERT_TRUE(vc_vector_push_back(vector, &i));
}
ASSERT_EQ(count_of_elements_ended, vc_vector_count(vector));
ASSERT_FALSE(vc_vector_empty(vector));
ASSERT_EQ(size_of_vector_ended, vc_vector_size(vector));
ASSERT_EQ(max_count_of_vector_ended, vc_vector_max_count(vector));
ASSERT_EQ(max_size_of_vector_ended, vc_vector_max_size(vector));
const size_t test_reserve_count_fail = 10;
ASSERT_FALSE(vc_vector_reserve_count(vector, test_reserve_count_fail));
const size_t test_reserve_count = 35;
ASSERT_TRUE(vc_vector_reserve_count(vector, test_reserve_count));
ASSERT_EQ(test_reserve_count, vc_vector_max_count(vector));
ASSERT_EQ(test_reserve_count * size_of_element, vc_vector_max_size(vector));
// Second time with the same value
ASSERT_TRUE(vc_vector_reserve_count(vector, test_reserve_count));
ASSERT_EQ(test_reserve_count, vc_vector_max_count(vector));
ASSERT_EQ(test_reserve_count * size_of_element, vc_vector_max_size(vector));
const size_t test_reserve_size = 123 * size_of_element;
ASSERT_TRUE(vc_vector_reserve_size(vector, test_reserve_size));
ASSERT_EQ(test_reserve_size / size_of_element, vc_vector_max_count(vector));
ASSERT_EQ(test_reserve_size, vc_vector_max_size(vector));
vc_vector_release(vector);
printf("%s passed.\n", __func__);
}
void test_vc_vector_modifiers() {
const int begin[] = {
1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20
};
const size_t size_of_element = sizeof(begin[0]);
const size_t count_of_elements = sizeof(begin) / size_of_element;
// After deleting first, last and one middle elements
const int after_deleting_some_elements[] = {
/* 1, */ 2, 3, 4, 5, 6, 7, 8, 9, 10, /* 11, */ 12, 13, 14, 15, 16, 17, 18, 19, /* 20 */
};
// After deleting first 3 elemets from begin, 4 from middle and 3 from end
const int after_deleting_some_ranges[] = {
/* 1, 2, 3, */ 4, 5, 6, 7, 8, /* 9, 10, 11, 12, */ 13, 14, 15, 16, 17, /* 18, 19, 20 */
};
vc_vector* vector = vc_vector_create(0, size_of_element, NULL);
ASSERT_NE(NULL, vector);
// Append test
ASSERT_TRUE(vc_vector_append(vector, begin, count_of_elements));
ASSERT_EQ(count_of_elements, vc_vector_count(vector));
for (size_t i = 0; i < vc_vector_count(vector); ++i) {
ASSERT_EQ(begin[i], *(int*)vc_vector_at(vector, i));
}
// Pop back test
while (vc_vector_count(vector) > 0) {
ASSERT_TRUE(vc_vector_pop_back(vector));
}
ASSERT_TRUE(vc_vector_empty(vector));
// Push back test
for (size_t i = 0; i < count_of_elements; ++i) {
ASSERT_TRUE(vc_vector_push_back(vector, &begin[i]));
}
ASSERT_EQ(count_of_elements, vc_vector_count(vector));
for (size_t i = 0; i < vc_vector_count(vector); ++i) {
ASSERT_EQ(begin[i], *(int*)vc_vector_at(vector, i));
}
// Erase test
vc_vector_clear(vector);
ASSERT_TRUE(vc_vector_append(vector, begin, count_of_elements));
ASSERT_TRUE(vc_vector_erase(vector, 0));
ASSERT_TRUE(vc_vector_erase(vector, vc_vector_count(vector) - 1));
ASSERT_TRUE(vc_vector_erase(vector, vc_vector_count(vector) / 2));
ASSERT_EQ(sizeof(after_deleting_some_elements) / size_of_element, vc_vector_count(vector));
for (size_t i = 0; i < vc_vector_count(vector); ++i) {
ASSERT_EQ(after_deleting_some_elements[i], *(int*)vc_vector_at(vector, i));
}
// Erase range test
vc_vector_clear(vector);
ASSERT_TRUE(vc_vector_append(vector, begin, count_of_elements));
ASSERT_TRUE(vc_vector_erase_range(vector, 0, 3));
ASSERT_TRUE(vc_vector_erase_range(vector, vc_vector_count(vector) - 3, vc_vector_count(vector)));
ASSERT_TRUE(vc_vector_erase_range(vector, vc_vector_count(vector) / 2 - 2, vc_vector_count(vector) / 2 + 2));
ASSERT_EQ(sizeof(after_deleting_some_ranges) / size_of_element, vc_vector_count(vector));
for (size_t i = 0; i < vc_vector_count(vector); ++i) {
ASSERT_EQ(after_deleting_some_ranges[i], *(int*)vc_vector_at(vector, i));
}
// Insert test
vc_vector_clear(vector);
for (size_t i = 1; i < count_of_elements - 1; ++i) {
ASSERT_TRUE(vc_vector_insert(vector, i - 1, &begin[i]));
}
ASSERT_TRUE(vc_vector_insert(vector, 0, &begin[0]));
ASSERT_TRUE(vc_vector_insert(vector, vc_vector_count(vector), &begin[count_of_elements - 1]));
ASSERT_EQ(count_of_elements, vc_vector_count(vector));
for (size_t i = 0; i < vc_vector_count(vector); ++i) {
ASSERT_EQ(begin[i], *(int*)vc_vector_at(vector, i));
}
vc_vector_release(vector);
printf("%s passed.\n", __func__);
}
void test_vc_vector_strfreefunc(void *data) {
free(*(char **)data);
}
void test_vc_vector_with_strfreefunc() {
// creates a vector of pointers to char, i.e. a vector of variable sized strings
vc_vector* vector = vc_vector_create(3, sizeof(char *), test_vc_vector_strfreefunc);
ASSERT_NE(NULL, vector);
char *strs[] = {
mystrdup("abcde"),
mystrdup("edcba"),
mystrdup("1234554321"),
mystrdup("!@#$%"),
mystrdup("not empty string"),
mystrdup(""),
mystrdup("Hello World"),
mystrdup("xxxxx"),
mystrdup("yyyyy")
};
for (size_t i = 0; i < 3; ++i) {
ASSERT_TRUE(vc_vector_push_back(vector, &strs[i]));
}
ASSERT_EQ(3, vc_vector_count(vector));
for (size_t i = 3; i < 6; ++i) {
ASSERT_TRUE(vc_vector_insert(vector, i, &strs[i]));
}
ASSERT_EQ(6, vc_vector_count(vector));
vc_vector_clear(vector); // strs[0-6] were freed
ASSERT_EQ(0, vc_vector_count(vector));
for (size_t i = 6; i < 9; ++i) {
ASSERT_TRUE(vc_vector_push_back(vector, &strs[i]));
}
ASSERT_EQ(3, vc_vector_count(vector));
vc_vector_release(vector);
printf("%s passed.\n", __func__);
}
void vc_vector_run_tests() {
test_vc_vector_create();
test_vc_vector_element_access();
test_vc_vector_iterators();
test_vc_vector_capacity();
test_vc_vector_modifiers();
test_vc_vector_with_strfreefunc();
}
int main() {
vc_vector_run_tests();
printf("Tests passed.\n");
return 0;
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。