summaryrefslogtreecommitdiff
path: root/tests/vector.c
diff options
context:
space:
mode:
authorEuAndreh <eu@euandre.org>2024-05-24 16:56:53 -0300
committerEuAndreh <eu@euandre.org>2024-05-24 16:56:53 -0300
commit1617ac5092036651ae2291f00b267b79d307dc82 (patch)
treed647b4cd19b24fbe7f8da71783b0bacd70d588eb /tests/vector.c
parentsrc/vector.{c,h}: Improve code and tests (diff)
downloadpindaiba-1617ac5092036651ae2291f00b267b79d307dc82.tar.gz
pindaiba-1617ac5092036651ae2291f00b267b79d307dc82.tar.xz
src/vector.h: Add implementation and tests for vector_contains()
Diffstat (limited to 'tests/vector.c')
-rw-r--r--tests/vector.c69
1 files changed, 69 insertions, 0 deletions
diff --git a/tests/vector.c b/tests/vector.c
index 8f4a20c..4d27c7f 100644
--- a/tests/vector.c
+++ b/tests/vector.c
@@ -381,6 +381,70 @@ test_vector_pop_back(void) {
return 0;
}
+static int
+test_vector_contains(void) {
+ int rc = -1;
+
+ const struct Vector *v = NULL;
+
+ test_start("vector_contains()");
+ {
+ testing("empty vector");
+
+ if (vector_new(sizeof(int), &v)) {
+ logerr("vector_new()");
+ goto out;
+ }
+
+ const int value = 1;
+ for (size_t i = 0; i < 100; i++) {
+ assert(!vector_contains(v, &value));
+ }
+
+ vector_free(v);
+ v = NULL;
+
+ test_ok();
+ }
+ {
+ testing("small vectors");
+
+ if (vector_new(sizeof(size_t), &v)) {
+ logerr("vector_new()");
+ goto out;
+ }
+
+ for (size_t i = 0; i < 100U; i++) {
+ if (vector_push_back(v, &i)) {
+ logerr("vector_push_back()");
+ goto out;
+ }
+ }
+
+ const size_t value = 100U;
+ for (size_t i = 0; i < vector_count(v); i++) {
+ assert(!vector_contains(v, &value));
+ }
+
+ for (size_t i = 0; i < vector_count(v); i++) {
+ assert(vector_contains(v, &i));
+ }
+
+ vector_free(v);
+ v = NULL;
+
+ test_ok();
+ }
+
+ rc = 0;
+out:
+ if (v != NULL) {
+ vector_free(v);
+ v = NULL;
+ }
+ return rc;
+}
+
int
main(void) {
@@ -424,6 +488,11 @@ main(void) {
goto out;
}
+ if (test_vector_contains()) {
+ logerr("test_vector_contains()");
+ goto out;
+ }
+
rc = 0;
out:
return !!rc;