aboutsummaryrefslogtreecommitdiffstats
path: root/t/unit-tests/strvec.c
diff options
context:
space:
mode:
authorPatrick Steinhardt <ps@pks.im>2024-12-13 11:41:18 +0100
committerJunio C Hamano <gitster@pobox.com>2024-12-13 06:48:46 -0800
commitc081e7340f5545342f80e77f4578851d77dc9cf6 (patch)
treec00c0631e196f124b95660f8cd994087cae8c15c /t/unit-tests/strvec.c
parent23eeee08d6a22de197b17e791508ddcb3a953dc7 (diff)
downloadgit-c081e7340f5545342f80e77f4578851d77dc9cf6.tar.gz
t/unit-tests: rename clar-based unit tests to have a common prefix
All of the code files for unit tests using the self-grown unit testing framework have a "t-" prefix to their name. This makes it easy to identify them and use globbing in our Makefile and in other places. On the other hand though, our clar-based unit tests have no prefix at all and thus cannot easily be discerned from other files in the unit test directory. Introduce a new "u-" prefix for clar-based unit tests. This prefix will be used in a subsequent commit to easily identify such tests. Signed-off-by: Patrick Steinhardt <ps@pks.im> Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 't/unit-tests/strvec.c')
-rw-r--r--t/unit-tests/strvec.c306
1 files changed, 0 insertions, 306 deletions
diff --git a/t/unit-tests/strvec.c b/t/unit-tests/strvec.c
deleted file mode 100644
index 855b602337..0000000000
--- a/t/unit-tests/strvec.c
+++ /dev/null
@@ -1,306 +0,0 @@
-#include "unit-test.h"
-#include "strbuf.h"
-#include "strvec.h"
-
-#define check_strvec(vec, ...) \
- do { \
- const char *expect[] = { __VA_ARGS__ }; \
- size_t expect_len = ARRAY_SIZE(expect); \
- cl_assert(expect_len > 0); \
- cl_assert_equal_p(expect[expect_len - 1], NULL); \
- cl_assert_equal_i((vec)->nr, expect_len - 1); \
- cl_assert((vec)->nr <= (vec)->alloc); \
- for (size_t i = 0; i < expect_len; i++) \
- cl_assert_equal_s((vec)->v[i], expect[i]); \
- } while (0)
-
-void test_strvec__init(void)
-{
- struct strvec vec = STRVEC_INIT;
-
- cl_assert_equal_p(vec.v, empty_strvec);
- cl_assert_equal_i(vec.nr, 0);
- cl_assert_equal_i(vec.alloc, 0);
-}
-
-void test_strvec__dynamic_init(void)
-{
- struct strvec vec;
-
- strvec_init(&vec);
- cl_assert_equal_p(vec.v, empty_strvec);
- cl_assert_equal_i(vec.nr, 0);
- cl_assert_equal_i(vec.alloc, 0);
-}
-
-void test_strvec__clear(void)
-{
- struct strvec vec = STRVEC_INIT;
-
- strvec_push(&vec, "foo");
- strvec_clear(&vec);
- cl_assert_equal_p(vec.v, empty_strvec);
- cl_assert_equal_i(vec.nr, 0);
- cl_assert_equal_i(vec.alloc, 0);
-}
-
-void test_strvec__push(void)
-{
- struct strvec vec = STRVEC_INIT;
-
- strvec_push(&vec, "foo");
- check_strvec(&vec, "foo", NULL);
-
- strvec_push(&vec, "bar");
- check_strvec(&vec, "foo", "bar", NULL);
-
- strvec_clear(&vec);
-}
-
-void test_strvec__pushf(void)
-{
- struct strvec vec = STRVEC_INIT;
-
- strvec_pushf(&vec, "foo: %d", 1);
- check_strvec(&vec, "foo: 1", NULL);
- strvec_clear(&vec);
-}
-
-void test_strvec__pushl(void)
-{
- struct strvec vec = STRVEC_INIT;
-
- strvec_pushl(&vec, "foo", "bar", "baz", NULL);
- check_strvec(&vec, "foo", "bar", "baz", NULL);
- strvec_clear(&vec);
-}
-
-void test_strvec__pushv(void)
-{
- const char *strings[] = {
- "foo", "bar", "baz", NULL,
- };
- struct strvec vec = STRVEC_INIT;
-
- strvec_pushv(&vec, strings);
- check_strvec(&vec, "foo", "bar", "baz", NULL);
-
- strvec_clear(&vec);
-}
-
-void test_strvec__splice_with_same_size_replacement(void)
-{
- struct strvec vec = STRVEC_INIT;
- const char *replacement[] = { "1" };
-
- strvec_pushl(&vec, "foo", "bar", "baz", NULL);
- strvec_splice(&vec, 1, 1, replacement, ARRAY_SIZE(replacement));
- check_strvec(&vec, "foo", "1", "baz", NULL);
- strvec_clear(&vec);
-}
-
-void test_strvec__splice_with_smaller_replacement(void)
-{
- struct strvec vec = STRVEC_INIT;
- const char *replacement[] = { "1" };
-
- strvec_pushl(&vec, "foo", "bar", "baz", NULL);
- strvec_splice(&vec, 1, 2, replacement, ARRAY_SIZE(replacement));
- check_strvec(&vec, "foo", "1", NULL);
- strvec_clear(&vec);
-}
-
-void test_strvec__splice_with_bigger_replacement(void)
-{
- struct strvec vec = STRVEC_INIT;
- const char *replacement[] = { "1", "2", "3" };
-
- strvec_pushl(&vec, "foo", "bar", "baz", NULL);
- strvec_splice(&vec, 0, 2, replacement, ARRAY_SIZE(replacement));
- check_strvec(&vec, "1", "2", "3", "baz", NULL);
- strvec_clear(&vec);
-}
-
-void test_strvec__splice_with_empty_replacement(void)
-{
- struct strvec vec = STRVEC_INIT;
-
- strvec_pushl(&vec, "foo", "bar", "baz", NULL);
- strvec_splice(&vec, 0, 2, NULL, 0);
- check_strvec(&vec, "baz", NULL);
- strvec_clear(&vec);
-}
-
-void test_strvec__splice_with_empty_original(void)
-{
- struct strvec vec = STRVEC_INIT;
- const char *replacement[] = { "1", "2" };
-
- strvec_pushl(&vec, "foo", "bar", "baz", NULL);
- strvec_splice(&vec, 1, 0, replacement, ARRAY_SIZE(replacement));
- check_strvec(&vec, "foo", "1", "2", "bar", "baz", NULL);
- strvec_clear(&vec);
-}
-
-void test_strvec__splice_at_tail(void)
-{
- struct strvec vec = STRVEC_INIT;
- const char *replacement[] = { "1", "2" };
-
- strvec_pushl(&vec, "foo", "bar", NULL);
- strvec_splice(&vec, 2, 0, replacement, ARRAY_SIZE(replacement));
- check_strvec(&vec, "foo", "bar", "1", "2", NULL);
- strvec_clear(&vec);
-}
-
-void test_strvec__replace_at_head(void)
-{
- struct strvec vec = STRVEC_INIT;
-
- strvec_pushl(&vec, "foo", "bar", "baz", NULL);
- strvec_replace(&vec, 0, "replaced");
- check_strvec(&vec, "replaced", "bar", "baz", NULL);
- strvec_clear(&vec);
-}
-
-void test_strvec__replace_at_tail(void)
-{
- struct strvec vec = STRVEC_INIT;
- strvec_pushl(&vec, "foo", "bar", "baz", NULL);
- strvec_replace(&vec, 2, "replaced");
- check_strvec(&vec, "foo", "bar", "replaced", NULL);
- strvec_clear(&vec);
-}
-
-void test_strvec__replace_in_between(void)
-{
- struct strvec vec = STRVEC_INIT;
-
- strvec_pushl(&vec, "foo", "bar", "baz", NULL);
- strvec_replace(&vec, 1, "replaced");
- check_strvec(&vec, "foo", "replaced", "baz", NULL);
- strvec_clear(&vec);
-}
-
-void test_strvec__replace_with_substring(void)
-{
- struct strvec vec = STRVEC_INIT;
-
- strvec_pushl(&vec, "foo", NULL);
- strvec_replace(&vec, 0, vec.v[0] + 1);
- check_strvec(&vec, "oo", NULL);
- strvec_clear(&vec);
-}
-
-void test_strvec__remove_at_head(void)
-{
- struct strvec vec = STRVEC_INIT;
-
- strvec_pushl(&vec, "foo", "bar", "baz", NULL);
- strvec_remove(&vec, 0);
- check_strvec(&vec, "bar", "baz", NULL);
- strvec_clear(&vec);
-}
-
-void test_strvec__remove_at_tail(void)
-{
- struct strvec vec = STRVEC_INIT;
-
- strvec_pushl(&vec, "foo", "bar", "baz", NULL);
- strvec_remove(&vec, 2);
- check_strvec(&vec, "foo", "bar", NULL);
- strvec_clear(&vec);
-}
-
-void test_strvec__remove_in_between(void)
-{
- struct strvec vec = STRVEC_INIT;
-
- strvec_pushl(&vec, "foo", "bar", "baz", NULL);
- strvec_remove(&vec, 1);
- check_strvec(&vec, "foo", "baz", NULL);
- strvec_clear(&vec);
-}
-
-void test_strvec__pop_empty_array(void)
-{
- struct strvec vec = STRVEC_INIT;
-
- strvec_pop(&vec);
- check_strvec(&vec, NULL);
- strvec_clear(&vec);
-}
-
-void test_strvec__pop_non_empty_array(void)
-{
- struct strvec vec = STRVEC_INIT;
-
- strvec_pushl(&vec, "foo", "bar", "baz", NULL);
- strvec_pop(&vec);
- check_strvec(&vec, "foo", "bar", NULL);
- strvec_clear(&vec);
-}
-
-void test_strvec__split_empty_string(void)
-{
- struct strvec vec = STRVEC_INIT;
-
- strvec_split(&vec, "");
- check_strvec(&vec, NULL);
- strvec_clear(&vec);
-}
-
-void test_strvec__split_single_item(void)
-{
- struct strvec vec = STRVEC_INIT;
-
- strvec_split(&vec, "foo");
- check_strvec(&vec, "foo", NULL);
- strvec_clear(&vec);
-}
-
-void test_strvec__split_multiple_items(void)
-{
- struct strvec vec = STRVEC_INIT;
-
- strvec_split(&vec, "foo bar baz");
- check_strvec(&vec, "foo", "bar", "baz", NULL);
- strvec_clear(&vec);
-}
-
-void test_strvec__split_whitespace_only(void)
-{
- struct strvec vec = STRVEC_INIT;
-
- strvec_split(&vec, " \t\n");
- check_strvec(&vec, NULL);
- strvec_clear(&vec);
-}
-
-void test_strvec__split_multiple_consecutive_whitespaces(void)
-{
- struct strvec vec = STRVEC_INIT;
-
- strvec_split(&vec, "foo\n\t bar");
- check_strvec(&vec, "foo", "bar", NULL);
- strvec_clear(&vec);
-}
-
-void test_strvec__detach(void)
-{
- struct strvec vec = STRVEC_INIT;
- const char **detached;
-
- strvec_push(&vec, "foo");
-
- detached = strvec_detach(&vec);
- cl_assert_equal_s(detached[0], "foo");
- cl_assert_equal_p(detached[1], NULL);
-
- cl_assert_equal_p(vec.v, empty_strvec);
- cl_assert_equal_i(vec.nr, 0);
- cl_assert_equal_i(vec.alloc, 0);
-
- free((char *) detached[0]);
- free(detached);
-}