Commit e6d93612 by Edward Thomson

refactor: move utility tests into util

parent 2b09b5d7
...@@ -156,13 +156,25 @@ fi ...@@ -156,13 +156,25 @@ fi
# Run the tests that do not require network connectivity. # Run the tests that do not require network connectivity.
if [ -z "$SKIP_UTILITY_TESTS" ]; then
run_test util
fi
if [ -z "$SKIP_OFFLINE_TESTS" ]; then if [ -z "$SKIP_OFFLINE_TESTS" ]; then
echo "" echo ""
echo "##############################################################################" echo "##############################################################################"
echo "## Running (offline) tests" echo "## Running core tests"
echo "##############################################################################" echo "##############################################################################"
echo ""
echo "Running libgit2 integration (offline) tests"
echo ""
run_test offline run_test offline
echo ""
echo "Running utility tests"
echo ""
run_test util
fi fi
if [ -n "$RUN_INVASIVE_TESTS" ]; then if [ -n "$RUN_INVASIVE_TESTS" ]; then
...@@ -186,7 +198,7 @@ if [ -z "$SKIP_ONLINE_TESTS" ]; then ...@@ -186,7 +198,7 @@ if [ -z "$SKIP_ONLINE_TESTS" ]; then
echo "" echo ""
echo "##############################################################################" echo "##############################################################################"
echo "## Running (online) tests" echo "## Running networking (online) tests"
echo "##############################################################################" echo "##############################################################################"
export GITTEST_REMOTE_REDIRECT_INITIAL="http://localhost:9000/initial-redirect/libgit2/TestGitRepository" export GITTEST_REMOTE_REDIRECT_INITIAL="http://localhost:9000/initial-redirect/libgit2/TestGitRepository"
...@@ -198,9 +210,9 @@ if [ -z "$SKIP_ONLINE_TESTS" ]; then ...@@ -198,9 +210,9 @@ if [ -z "$SKIP_ONLINE_TESTS" ]; then
# Run the online tests that immutably change global state separately # Run the online tests that immutably change global state separately
# to avoid polluting the test environment. # to avoid polluting the test environment.
echo "" echo ""
echo "##############################################################################" echo "Running custom certificate (online_customcert) tests"
echo "## Running (online_customcert) tests" echo ""
echo "##############################################################################"
run_test online_customcert run_test online_customcert
fi fi
......
...@@ -3,3 +3,4 @@ ...@@ -3,3 +3,4 @@
add_subdirectory(headertest) add_subdirectory(headertest)
add_subdirectory(libgit2) add_subdirectory(libgit2)
add_subdirectory(util)
...@@ -12,6 +12,8 @@ These are the unit and integration tests for the libgit2 projects. ...@@ -12,6 +12,8 @@ These are the unit and integration tests for the libgit2 projects.
* `resources` * `resources`
These are the resources for the tests, including files and git These are the resources for the tests, including files and git
repositories. repositories.
* `util`
These are tests of the common utility library.
## Writing tests for libgit2 ## Writing tests for libgit2
......
#include "clar_libgit2.h"
#include "git2/sys/hashsig.h"
#include "futils.h"
#define SIMILARITY_TEST_DATA_1 \
"000\n001\n002\n003\n004\n005\n006\n007\n008\n009\n" \
"010\n011\n012\n013\n014\n015\n016\n017\n018\n019\n" \
"020\n021\n022\n023\n024\n025\n026\n027\n028\n029\n" \
"030\n031\n032\n033\n034\n035\n036\n037\n038\n039\n" \
"040\n041\n042\n043\n044\n045\n046\n047\n048\n049\n"
void test_core_hashsig__similarity_metric(void)
{
git_hashsig *a, *b;
git_str buf = GIT_STR_INIT;
int sim;
/* in the first case, we compare data to itself and expect 100% match */
cl_git_pass(git_str_sets(&buf, SIMILARITY_TEST_DATA_1));
cl_git_pass(git_hashsig_create(&a, buf.ptr, buf.size, GIT_HASHSIG_NORMAL));
cl_git_pass(git_hashsig_create(&b, buf.ptr, buf.size, GIT_HASHSIG_NORMAL));
cl_assert_equal_i(100, git_hashsig_compare(a, b));
git_hashsig_free(a);
git_hashsig_free(b);
/* if we change just a single byte, how much does that change magnify? */
cl_git_pass(git_str_sets(&buf, SIMILARITY_TEST_DATA_1));
cl_git_pass(git_hashsig_create(&a, buf.ptr, buf.size, GIT_HASHSIG_NORMAL));
cl_git_pass(git_str_sets(&buf,
"000\n001\n002\n003\n004\n005\n006\n007\n008\n009\n" \
"010\n011\n012\n013\n014\n015\n016\n017\n018\n019\n" \
"x020x\n021\n022\n023\n024\n025\n026\n027\n028\n029\n" \
"030\n031\n032\n033\n034\n035\n036\n037\n038\n039\n" \
"040\n041\n042\n043\n044\n045\n046\n047\n048\n049\n"
));
cl_git_pass(git_hashsig_create(&b, buf.ptr, buf.size, GIT_HASHSIG_NORMAL));
sim = git_hashsig_compare(a, b);
cl_assert_in_range(95, sim, 100); /* expect >95% similarity */
git_hashsig_free(a);
git_hashsig_free(b);
/* let's try comparing data to a superset of itself */
cl_git_pass(git_str_sets(&buf, SIMILARITY_TEST_DATA_1));
cl_git_pass(git_hashsig_create(&a, buf.ptr, buf.size, GIT_HASHSIG_NORMAL));
cl_git_pass(git_str_sets(&buf, SIMILARITY_TEST_DATA_1
"050\n051\n052\n053\n054\n055\n056\n057\n058\n059\n"));
cl_git_pass(git_hashsig_create(&b, buf.ptr, buf.size, GIT_HASHSIG_NORMAL));
sim = git_hashsig_compare(a, b);
/* 20% lines added ~= 10% lines changed */
cl_assert_in_range(85, sim, 95); /* expect similarity around 90% */
git_hashsig_free(a);
git_hashsig_free(b);
/* what if we keep about half the original data and add half new */
cl_git_pass(git_str_sets(&buf, SIMILARITY_TEST_DATA_1));
cl_git_pass(git_hashsig_create(&a, buf.ptr, buf.size, GIT_HASHSIG_NORMAL));
cl_git_pass(git_str_sets(&buf,
"000\n001\n002\n003\n004\n005\n006\n007\n008\n009\n" \
"010\n011\n012\n013\n014\n015\n016\n017\n018\n019\n" \
"020x\n021\n022\n023\n024\n" \
"x25\nx26\nx27\nx28\nx29\n" \
"x30\nx31\nx32\nx33\nx34\nx35\nx36\nx37\nx38\nx39\n" \
"x40\nx41\nx42\nx43\nx44\nx45\nx46\nx47\nx48\nx49\n"
));
cl_git_pass(git_hashsig_create(&b, buf.ptr, buf.size, GIT_HASHSIG_NORMAL));
sim = git_hashsig_compare(a, b);
/* 50% lines changed */
cl_assert_in_range(40, sim, 60); /* expect in the 40-60% similarity range */
git_hashsig_free(a);
git_hashsig_free(b);
/* lastly, let's check that we can hash file content as well */
cl_git_pass(git_str_sets(&buf, SIMILARITY_TEST_DATA_1));
cl_git_pass(git_hashsig_create(&a, buf.ptr, buf.size, GIT_HASHSIG_NORMAL));
cl_git_pass(git_futils_mkdir("scratch", 0755, GIT_MKDIR_PATH));
cl_git_mkfile("scratch/testdata", SIMILARITY_TEST_DATA_1);
cl_git_pass(git_hashsig_create_fromfile(
&b, "scratch/testdata", GIT_HASHSIG_NORMAL));
cl_assert_equal_i(100, git_hashsig_compare(a, b));
git_hashsig_free(a);
git_hashsig_free(b);
git_str_dispose(&buf);
git_futils_rmdir_r("scratch", NULL, GIT_RMDIR_REMOVE_FILES);
}
void test_core_hashsig__similarity_metric_whitespace(void)
{
git_hashsig *a, *b;
git_str buf = GIT_STR_INIT;
int sim, i, j;
git_hashsig_option_t opt;
const char *tabbed =
" for (s = 0; s < sizeof(sep) / sizeof(char); ++s) {\n"
" separator = sep[s];\n"
" expect = expect_values[s];\n"
"\n"
" for (j = 0; j < sizeof(b) / sizeof(char*); ++j) {\n"
" for (i = 0; i < sizeof(a) / sizeof(char*); ++i) {\n"
" git_str_join(&buf, separator, a[i], b[j]);\n"
" cl_assert_equal_s(*expect, buf.ptr);\n"
" expect++;\n"
" }\n"
" }\n"
" }\n";
const char *spaced =
" for (s = 0; s < sizeof(sep) / sizeof(char); ++s) {\n"
" separator = sep[s];\n"
" expect = expect_values[s];\n"
"\n"
" for (j = 0; j < sizeof(b) / sizeof(char*); ++j) {\n"
" for (i = 0; i < sizeof(a) / sizeof(char*); ++i) {\n"
" git_str_join(&buf, separator, a[i], b[j]);\n"
" cl_assert_equal_s(*expect, buf.ptr);\n"
" expect++;\n"
" }\n"
" }\n"
" }\n";
const char *crlf_spaced2 =
" for (s = 0; s < sizeof(sep) / sizeof(char); ++s) {\r\n"
" separator = sep[s];\r\n"
" expect = expect_values[s];\r\n"
"\r\n"
" for (j = 0; j < sizeof(b) / sizeof(char*); ++j) {\r\n"
" for (i = 0; i < sizeof(a) / sizeof(char*); ++i) {\r\n"
" git_str_join(&buf, separator, a[i], b[j]);\r\n"
" cl_assert_equal_s(*expect, buf.ptr);\r\n"
" expect++;\r\n"
" }\r\n"
" }\r\n"
" }\r\n";
const char *text[3] = { tabbed, spaced, crlf_spaced2 };
/* let's try variations of our own code with whitespace changes */
for (opt = GIT_HASHSIG_NORMAL; opt <= GIT_HASHSIG_SMART_WHITESPACE; ++opt) {
for (i = 0; i < 3; ++i) {
for (j = 0; j < 3; ++j) {
cl_git_pass(git_str_sets(&buf, text[i]));
cl_git_pass(git_hashsig_create(&a, buf.ptr, buf.size, opt));
cl_git_pass(git_str_sets(&buf, text[j]));
cl_git_pass(git_hashsig_create(&b, buf.ptr, buf.size, opt));
sim = git_hashsig_compare(a, b);
if (opt == GIT_HASHSIG_NORMAL) {
if (i == j)
cl_assert_equal_i(100, sim);
else
cl_assert_in_range(0, sim, 30); /* pretty different */
} else {
cl_assert_equal_i(100, sim);
}
git_hashsig_free(a);
git_hashsig_free(b);
}
}
}
git_str_dispose(&buf);
}
...@@ -2,57 +2,9 @@ ...@@ -2,57 +2,9 @@
#include "pool.h" #include "pool.h"
#include "git2/oid.h" #include "git2/oid.h"
void test_core_pool__0(void)
{
int i;
git_pool p;
void *ptr;
git_pool_init(&p, 1);
for (i = 1; i < 10000; i *= 2) {
ptr = git_pool_malloc(&p, i);
cl_assert(ptr != NULL);
cl_assert(git_pool__ptr_in_pool(&p, ptr));
cl_assert(!git_pool__ptr_in_pool(&p, &i));
}
git_pool_clear(&p);
}
void test_core_pool__1(void)
{
int i;
git_pool p;
git_pool_init(&p, 1);
p.page_size = 4000;
for (i = 2010; i > 0; i--)
cl_assert(git_pool_malloc(&p, i) != NULL);
#ifndef GIT_DEBUG_POOL
/* with fixed page size, allocation must end up with these values */
cl_assert_equal_i(591, git_pool__open_pages(&p));
#endif
git_pool_clear(&p);
git_pool_init(&p, 1);
p.page_size = 4120;
for (i = 2010; i > 0; i--)
cl_assert(git_pool_malloc(&p, i) != NULL);
#ifndef GIT_DEBUG_POOL
/* with fixed page size, allocation must end up with these values */
cl_assert_equal_i(sizeof(void *) == 8 ? 575 : 573, git_pool__open_pages(&p));
#endif
git_pool_clear(&p);
}
static char to_hex[] = "0123456789abcdef"; static char to_hex[] = "0123456789abcdef";
void test_core_pool__2(void) void test_core_pool__oid(void)
{ {
git_pool p; git_pool p;
char oid_hex[GIT_OID_HEXSZ]; char oid_hex[GIT_OID_HEXSZ];
...@@ -79,14 +31,3 @@ void test_core_pool__2(void) ...@@ -79,14 +31,3 @@ void test_core_pool__2(void)
#endif #endif
git_pool_clear(&p); git_pool_clear(&p);
} }
void test_core_pool__strndup_limit(void)
{
git_pool p;
git_pool_init(&p, 1);
/* ensure 64 bit doesn't overflow */
cl_assert(git_pool_strndup(&p, "foo", (size_t)-1) == NULL);
git_pool_clear(&p);
}
#include "clar_libgit2.h"
#include "userdiff.h"
static git_regexp regex;
void test_diff_userdiff__cleanup(void)
{
git_regexp_dispose(&regex);
}
void test_diff_userdiff__compile_userdiff_regexps(void)
{
size_t idx;
for (idx = 0; idx < ARRAY_SIZE(builtin_defs); ++idx) {
git_diff_driver_definition ddef = builtin_defs[idx];
cl_git_pass(git_regexp_compile(&regex, ddef.fns, ddef.flags));
git_regexp_dispose(&regex);
cl_git_pass(git_regexp_compile(&regex, ddef.words, 0));
git_regexp_dispose(&regex);
}
}
#include "clar_libgit2.h"
#include "path.h"
static char *gitmodules_altnames[] = {
".gitmodules",
/*
* Equivalent to the ".git\u200cmodules" string from git but hard-coded
* as a UTF-8 sequence
*/
".git\xe2\x80\x8cmodules",
".Gitmodules",
".gitmoduleS",
".gitmodules ",
".gitmodules.",
".gitmodules ",
".gitmodules. ",
".gitmodules .",
".gitmodules..",
".gitmodules ",
".gitmodules. ",
".gitmodules . ",
".gitmodules .",
".Gitmodules ",
".Gitmodules.",
".Gitmodules ",
".Gitmodules. ",
".Gitmodules .",
".Gitmodules..",
".Gitmodules ",
".Gitmodules. ",
".Gitmodules . ",
".Gitmodules .",
"GITMOD~1",
"gitmod~1",
"GITMOD~2",
"gitmod~3",
"GITMOD~4",
"GITMOD~1 ",
"gitmod~2.",
"GITMOD~3 ",
"gitmod~4. ",
"GITMOD~1 .",
"gitmod~2 ",
"GITMOD~3. ",
"gitmod~4 . ",
"GI7EBA~1",
"gi7eba~9",
"GI7EB~10",
"GI7EB~11",
"GI7EB~99",
"GI7EB~10",
"GI7E~100",
"GI7E~101",
"GI7E~999",
"~1000000",
"~9999999",
};
static char *gitmodules_not_altnames[] = {
".gitmodules x",
".gitmodules .x",
" .gitmodules",
"..gitmodules",
"gitmodules",
".gitmodule",
".gitmodules x ",
".gitmodules .x",
"GI7EBA~",
"GI7EBA~0",
"GI7EBA~~1",
"GI7EBA~X",
"Gx7EBA~1",
"GI7EBX~1",
"GI7EB~1",
"GI7EB~01",
"GI7EB~1",
};
void test_path_dotgit__dotgit_modules(void)
{
size_t i;
cl_assert_equal_i(1, git_path_is_gitfile(".gitmodules", strlen(".gitmodules"), GIT_PATH_GITFILE_GITMODULES, GIT_PATH_FS_GENERIC));
cl_assert_equal_i(1, git_path_is_gitfile(".git\xe2\x80\x8cmodules", strlen(".git\xe2\x80\x8cmodules"), GIT_PATH_GITFILE_GITMODULES, GIT_PATH_FS_GENERIC));
for (i = 0; i < ARRAY_SIZE(gitmodules_altnames); i++) {
const char *name = gitmodules_altnames[i];
if (!git_path_is_gitfile(name, strlen(name), GIT_PATH_GITFILE_GITMODULES, GIT_PATH_FS_GENERIC))
cl_fail(name);
}
for (i = 0; i < ARRAY_SIZE(gitmodules_not_altnames); i++) {
const char *name = gitmodules_not_altnames[i];
if (git_path_is_gitfile(name, strlen(name), GIT_PATH_GITFILE_GITMODULES, GIT_PATH_FS_GENERIC))
cl_fail(name);
}
}
void test_path_dotgit__dotgit_modules_symlink(void)
{
cl_assert_equal_b(true, git_path_is_valid(NULL, ".gitmodules", 0, GIT_PATH_REJECT_DOT_GIT_HFS|GIT_PATH_REJECT_DOT_GIT_NTFS));
cl_assert_equal_b(false, git_path_is_valid(NULL, ".gitmodules", S_IFLNK, GIT_PATH_REJECT_DOT_GIT_HFS));
cl_assert_equal_b(false, git_path_is_valid(NULL, ".gitmodules", S_IFLNK, GIT_PATH_REJECT_DOT_GIT_NTFS));
cl_assert_equal_b(false, git_path_is_valid(NULL, ".gitmodules . .::$DATA", S_IFLNK, GIT_PATH_REJECT_DOT_GIT_NTFS));
}
void test_path_dotgit__git_fs_path_is_file(void)
{
cl_git_fail(git_path_is_gitfile("blob", 4, -1, GIT_PATH_FS_HFS));
cl_git_pass(git_path_is_gitfile("blob", 4, GIT_PATH_GITFILE_GITIGNORE, GIT_PATH_FS_HFS));
cl_git_pass(git_path_is_gitfile("blob", 4, GIT_PATH_GITFILE_GITMODULES, GIT_PATH_FS_HFS));
cl_git_pass(git_path_is_gitfile("blob", 4, GIT_PATH_GITFILE_GITATTRIBUTES, GIT_PATH_FS_HFS));
cl_git_fail(git_path_is_gitfile("blob", 4, 3, GIT_PATH_FS_HFS));
}
void test_path_dotgit__isvalid_dot_git(void)
{
cl_assert_equal_b(true, git_path_is_valid(NULL, ".git", 0, 0));
cl_assert_equal_b(true, git_path_is_valid(NULL, ".git/foo", 0, 0));
cl_assert_equal_b(true, git_path_is_valid(NULL, "foo/.git", 0, 0));
cl_assert_equal_b(true, git_path_is_valid(NULL, "foo/.git/bar", 0, 0));
cl_assert_equal_b(true, git_path_is_valid(NULL, "foo/.GIT/bar", 0, 0));
cl_assert_equal_b(true, git_path_is_valid(NULL, "foo/bar/.Git", 0, 0));
cl_assert_equal_b(false, git_path_is_valid(NULL, ".git", 0, GIT_PATH_REJECT_DOT_GIT_LITERAL));
cl_assert_equal_b(false, git_path_is_valid(NULL, ".git/foo", 0, GIT_PATH_REJECT_DOT_GIT_LITERAL));
cl_assert_equal_b(false, git_path_is_valid(NULL, "foo/.git", 0, GIT_PATH_REJECT_DOT_GIT_LITERAL));
cl_assert_equal_b(false, git_path_is_valid(NULL, "foo/.git/bar", 0, GIT_PATH_REJECT_DOT_GIT_LITERAL));
cl_assert_equal_b(false, git_path_is_valid(NULL, "foo/.GIT/bar", 0, GIT_PATH_REJECT_DOT_GIT_LITERAL));
cl_assert_equal_b(false, git_path_is_valid(NULL, "foo/bar/.Git", 0, GIT_PATH_REJECT_DOT_GIT_LITERAL));
cl_assert_equal_b(true, git_path_is_valid(NULL, "!git", 0, 0));
cl_assert_equal_b(true, git_path_is_valid(NULL, "foo/!git", 0, 0));
cl_assert_equal_b(true, git_path_is_valid(NULL, "!git/bar", 0, 0));
cl_assert_equal_b(true, git_path_is_valid(NULL, ".tig", 0, 0));
cl_assert_equal_b(true, git_path_is_valid(NULL, "foo/.tig", 0, 0));
cl_assert_equal_b(true, git_path_is_valid(NULL, ".tig/bar", 0, 0));
}
void test_path_dotgit__isvalid_dotgit_ntfs(void)
{
cl_assert_equal_b(true, git_path_is_valid(NULL, ".git", 0, 0));
cl_assert_equal_b(true, git_path_is_valid(NULL, ".git ", 0, 0));
cl_assert_equal_b(true, git_path_is_valid(NULL, ".git.", 0, 0));
cl_assert_equal_b(true, git_path_is_valid(NULL, ".git.. .", 0, 0));
cl_assert_equal_b(true, git_path_is_valid(NULL, "git~1", 0, 0));
cl_assert_equal_b(true, git_path_is_valid(NULL, "git~1 ", 0, 0));
cl_assert_equal_b(true, git_path_is_valid(NULL, "git~1.", 0, 0));
cl_assert_equal_b(true, git_path_is_valid(NULL, "git~1.. .", 0, 0));
cl_assert_equal_b(false, git_path_is_valid(NULL, ".git", 0, GIT_PATH_REJECT_DOT_GIT_NTFS));
cl_assert_equal_b(false, git_path_is_valid(NULL, ".git ", 0, GIT_PATH_REJECT_DOT_GIT_NTFS));
cl_assert_equal_b(false, git_path_is_valid(NULL, ".git.", 0, GIT_PATH_REJECT_DOT_GIT_NTFS));
cl_assert_equal_b(false, git_path_is_valid(NULL, ".git.. .", 0, GIT_PATH_REJECT_DOT_GIT_NTFS));
cl_assert_equal_b(false, git_path_is_valid(NULL, "git~1", 0, GIT_PATH_REJECT_DOT_GIT_NTFS));
cl_assert_equal_b(false, git_path_is_valid(NULL, "git~1 ", 0, GIT_PATH_REJECT_DOT_GIT_NTFS));
cl_assert_equal_b(false, git_path_is_valid(NULL, "git~1.", 0, GIT_PATH_REJECT_DOT_GIT_NTFS));
cl_assert_equal_b(false, git_path_is_valid(NULL, "git~1.. .", 0, GIT_PATH_REJECT_DOT_GIT_NTFS));
}
void test_path_dotgit__isvalid_dotgit_with_hfs_ignorables(void)
{
cl_assert_equal_b(false, git_path_is_valid(NULL, ".git", 0, GIT_PATH_REJECT_DOT_GIT_HFS));
cl_assert_equal_b(false, git_path_is_valid(NULL, ".git\xe2\x80\x8c", 0, GIT_PATH_REJECT_DOT_GIT_HFS));
cl_assert_equal_b(false, git_path_is_valid(NULL, ".gi\xe2\x80\x8dT", 0, GIT_PATH_REJECT_DOT_GIT_HFS));
cl_assert_equal_b(false, git_path_is_valid(NULL, ".g\xe2\x80\x8eIt", 0, GIT_PATH_REJECT_DOT_GIT_HFS));
cl_assert_equal_b(false, git_path_is_valid(NULL, ".\xe2\x80\x8fgIt", 0, GIT_PATH_REJECT_DOT_GIT_HFS));
cl_assert_equal_b(false, git_path_is_valid(NULL, "\xe2\x80\xaa.gIt", 0, GIT_PATH_REJECT_DOT_GIT_HFS));
cl_assert_equal_b(false, git_path_is_valid(NULL, "\xe2\x80\xab.\xe2\x80\xacG\xe2\x80\xadI\xe2\x80\xaet", 0, GIT_PATH_REJECT_DOT_GIT_HFS));
cl_assert_equal_b(false, git_path_is_valid(NULL, "\xe2\x81\xab.\xe2\x80\xaaG\xe2\x81\xabI\xe2\x80\xact", 0, GIT_PATH_REJECT_DOT_GIT_HFS));
cl_assert_equal_b(false, git_path_is_valid(NULL, "\xe2\x81\xad.\xe2\x80\xaeG\xef\xbb\xbfIT", 0, GIT_PATH_REJECT_DOT_GIT_HFS));
cl_assert_equal_b(true, git_path_is_valid(NULL, ".", 0, GIT_PATH_REJECT_DOT_GIT_HFS));
cl_assert_equal_b(true, git_path_is_valid(NULL, ".g", 0, GIT_PATH_REJECT_DOT_GIT_HFS));
cl_assert_equal_b(true, git_path_is_valid(NULL, ".gi", 0, GIT_PATH_REJECT_DOT_GIT_HFS));
cl_assert_equal_b(true, git_path_is_valid(NULL, " .git", 0, GIT_PATH_REJECT_DOT_GIT_HFS));
cl_assert_equal_b(true, git_path_is_valid(NULL, "..git\xe2\x80\x8c", 0, GIT_PATH_REJECT_DOT_GIT_HFS));
cl_assert_equal_b(true, git_path_is_valid(NULL, ".gi\xe2\x80\x8dT.", 0, GIT_PATH_REJECT_DOT_GIT_HFS));
cl_assert_equal_b(true, git_path_is_valid(NULL, ".g\xe2\x80It", 0, GIT_PATH_REJECT_DOT_GIT_HFS));
cl_assert_equal_b(true, git_path_is_valid(NULL, ".\xe2gIt", 0, GIT_PATH_REJECT_DOT_GIT_HFS));
cl_assert_equal_b(true, git_path_is_valid(NULL, "\xe2\x80\xaa.gi", 0, GIT_PATH_REJECT_DOT_GIT_HFS));
cl_assert_equal_b(true, git_path_is_valid(NULL, ".gi\x80\x8dT", 0, GIT_PATH_REJECT_DOT_GIT_HFS));
cl_assert_equal_b(true, git_path_is_valid(NULL, ".gi\x8dT", 0, GIT_PATH_REJECT_DOT_GIT_HFS));
cl_assert_equal_b(true, git_path_is_valid(NULL, ".g\xe2i\x80T\x8e", 0, GIT_PATH_REJECT_DOT_GIT_HFS));
cl_assert_equal_b(true, git_path_is_valid(NULL, ".git\xe2\x80\xbf", 0, GIT_PATH_REJECT_DOT_GIT_HFS));
cl_assert_equal_b(true, git_path_is_valid(NULL, ".git\xe2\xab\x81", 0, GIT_PATH_REJECT_DOT_GIT_HFS));
}
#include "clar_libgit2.h"
#include "path.h"
void test_path_validate__cleanup(void)
{
cl_git_sandbox_cleanup();
}
void test_path_validate__length(void)
{
cl_must_pass(git_path_validate_length(NULL, "/foo/bar"));
cl_must_pass(git_path_validate_length(NULL, "C:\\Foo\\Bar"));
cl_must_pass(git_path_validate_length(NULL, "\\\\?\\C:\\Foo\\Bar"));
cl_must_pass(git_path_validate_length(NULL, "\\\\?\\C:\\Foo\\Bar"));
cl_must_pass(git_path_validate_length(NULL, "\\\\?\\UNC\\server\\C$\\folder"));
#ifdef GIT_WIN32
/*
* In the absence of a repo configuration, 259 character paths
* succeed. >= 260 character paths fail.
*/
cl_must_pass(git_path_validate_length(NULL, "C:\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\ok.txt"));
cl_must_pass(git_path_validate_length(NULL, "C:\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\260.txt"));
cl_must_fail(git_path_validate_length(NULL, "C:\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\longer_than_260.txt"));
/* count characters, not bytes */
cl_must_pass(git_path_validate_length(NULL, "C:\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\\xc2\xa2\xc2\xa2\xc2\xa2\xc2\xa2\xc2\xa2\xc2\xa2\xc2\xa2\xc2\xa2\xc2\xa2\\260.txt"));
cl_must_fail(git_path_validate_length(NULL, "C:\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\\xc2\xa2\xc2\xa2\xc2\xa2\xc2\xa2\xc2\xa2\xc2\xa2\xc2\xa2\xc2\xa2\xc2\xa2\\long.txt"));
#else
cl_must_pass(git_path_validate_length(NULL, "/c/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/ok.txt"));
cl_must_pass(git_path_validate_length(NULL, "/c/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/260.txt"));
cl_must_pass(git_path_validate_length(NULL, "/c/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/longer_than_260.txt"));
cl_must_pass(git_path_validate_length(NULL, "C:\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\\xc2\xa2\xc2\xa2\xc2\xa2\xc2\xa2\xc2\xa2\xc2\xa2\xc2\xa2\xc2\xa2\xc2\xa2\\260.txt"));
cl_must_pass(git_path_validate_length(NULL, "C:\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\\xc2\xa2\xc2\xa2\xc2\xa2\xc2\xa2\xc2\xa2\xc2\xa2\xc2\xa2\xc2\xa2\xc2\xa2\\long.txt"));
#endif
}
void test_path_validate__length_with_core_longpath(void)
{
#ifdef GIT_WIN32
git_repository *repo;
git_config *config;
repo = cl_git_sandbox_init("empty_bare.git");
cl_git_pass(git_repository_open(&repo, "empty_bare.git"));
cl_git_pass(git_repository_config(&config, repo));
/* fail by default */
cl_must_fail(git_path_validate_length(repo, "/c/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/longer_than_260.txt"));
/* set core.longpaths explicitly on */
cl_git_pass(git_config_set_bool(config, "core.longpaths", 1));
cl_must_pass(git_path_validate_length(repo, "/c/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/longer_than_260.txt"));
/* set core.longpaths explicitly off */
cl_git_pass(git_config_set_bool(config, "core.longpaths", 0));
cl_must_fail(git_path_validate_length(repo, "/c/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/longer_than_260.txt"));
git_config_free(config);
git_repository_free(repo);
#endif
}
# util: the unit tests for libgit2's utility library
set(Python_ADDITIONAL_VERSIONS 3 2.7)
find_package(PythonInterp)
if(NOT PYTHONINTERP_FOUND)
message(FATAL_ERROR "Could not find a python interpeter, which is needed to build the tests. "
"Make sure python is available, or pass -DBUILD_TESTS=OFF to skip building the tests")
ENDIF()
set(CLAR_PATH "${libgit2_SOURCE_DIR}/tests/clar")
set(CLAR_FIXTURES "${libgit2_SOURCE_DIR}/tests/resources/")
set(TEST_PATH "${CMAKE_CURRENT_SOURCE_DIR}")
add_definitions(-DCLAR_FIXTURE_PATH=\"${CLAR_FIXTURES}\")
add_definitions(-DCLAR_TMPDIR=\"libgit2_tests\")
add_definitions(-DCLAR_WIN32_LONGPATHS)
add_definitions(-D_FILE_OFFSET_BITS=64)
# Ensure that we do not use deprecated functions internally
add_definitions(-DGIT_DEPRECATE_HARD)
set(TEST_INCLUDES "${CLAR_PATH}" "${TEST_PATH}" "${CMAKE_CURRENT_BINARY_DIR}")
file(GLOB_RECURSE SRC_TEST ${TEST_PATH}/*.c ${TEST_PATH}/*.h ${TEST_PATH}/*/*.c ${TEST_PATH}/*/*.h)
file(GLOB_RECURSE SRC_CLAR ${CLAR_PATH}/*.c ${CLAR_PATH}/*.h)
if(MSVC_IDE)
list(APPEND SRC_TEST "precompiled.c")
endif()
add_custom_command(
OUTPUT ${CMAKE_CURRENT_BINARY_DIR}/clar.suite ${CMAKE_CURRENT_BINARY_DIR}/clar_suite.h
COMMAND ${PYTHON_EXECUTABLE} ${CLAR_PATH}/generate.py -o "${CMAKE_CURRENT_BINARY_DIR}" -f .
DEPENDS ${SRC_TEST}
WORKING_DIRECTORY ${TEST_PATH})
set_source_files_properties(
${CLAR_PATH}/clar.c
PROPERTIES OBJECT_DEPENDS ${CMAKE_CURRENT_BINARY_DIR}/clar.suite)
add_executable(util_tests ${SRC_CLAR} ${SRC_TEST} ${LIBGIT2_OBJECTS})
set_target_properties(util_tests PROPERTIES C_STANDARD 90)
set_target_properties(util_tests PROPERTIES RUNTIME_OUTPUT_DIRECTORY ${libgit2_BINARY_DIR})
target_include_directories(util_tests PRIVATE ${TEST_INCLUDES} ${LIBGIT2_INCLUDES} ${LIBGIT2_DEPENDENCY_INCLUDES})
target_include_directories(util_tests SYSTEM PRIVATE ${LIBGIT2_SYSTEM_INCLUDES})
target_link_libraries(util_tests ${LIBGIT2_SYSTEM_LIBS})
ide_split_sources(util_tests)
#
# Old versions of gcc require us to declare our test functions; don't do
# this on newer compilers to avoid unnecessary recompilation.
#
if(CMAKE_COMPILER_IS_GNUCC AND CMAKE_CXX_COMPILER_VERSION VERSION_LESS 6.0)
target_compile_options(util_tests PRIVATE -include "clar_suite.h")
endif()
if(MSVC_IDE)
# Precompiled headers
set_target_properties(util_tests PROPERTIES COMPILE_FLAGS "/Yuprecompiled.h /FIprecompiled.h")
set_source_files_properties("precompiled.c" COMPILE_FLAGS "/Ycprecompiled.h")
endif()
function(ADD_CLAR_TEST name)
if(NOT USE_LEAK_CHECKER STREQUAL "OFF")
add_test(${name} "${libgit2_SOURCE_DIR}/script/${USE_LEAK_CHECKER}.sh" "${libgit2_BINARY_DIR}/util_tests" ${ARGN})
else()
add_test(${name} "${libgit2_BINARY_DIR}/util_tests" ${ARGN})
endif()
endfunction(ADD_CLAR_TEST)
enable_testing()
add_clar_test(util -v)
...@@ -15,7 +15,7 @@ static int int_lookup(const void *k, const void *a) ...@@ -15,7 +15,7 @@ static int int_lookup(const void *k, const void *a)
git_array_search(&p, integers, int_lookup, &key)); \ git_array_search(&p, integers, int_lookup, &key)); \
cl_assert_equal_i((n), p); cl_assert_equal_i((n), p);
void test_core_array__bsearch2(void) void test_array__bsearch2(void)
{ {
git_array_t(int) integers = GIT_ARRAY_INIT; git_array_t(int) integers = GIT_ARRAY_INIT;
int *i, key; int *i, key;
......
...@@ -36,7 +36,7 @@ static const char *bad_returns_string(void) ...@@ -36,7 +36,7 @@ static const char *bad_returns_string(void)
return hello_world; return hello_world;
} }
void test_core_assert__argument(void) void test_assert__argument(void)
{ {
cl_git_fail(dummy_fn(NULL)); cl_git_fail(dummy_fn(NULL));
cl_assert(git_error_last()); cl_assert(git_error_last());
...@@ -51,7 +51,7 @@ void test_core_assert__argument(void) ...@@ -51,7 +51,7 @@ void test_core_assert__argument(void)
cl_git_pass(dummy_fn("foo")); cl_git_pass(dummy_fn("foo"));
} }
void test_core_assert__argument_with_non_int_return_type(void) void test_assert__argument_with_non_int_return_type(void)
{ {
const char *foo = "foo"; const char *foo = "foo";
...@@ -66,7 +66,7 @@ void test_core_assert__argument_with_non_int_return_type(void) ...@@ -66,7 +66,7 @@ void test_core_assert__argument_with_non_int_return_type(void)
cl_assert_equal_p(foo, fn_returns_string(foo)); cl_assert_equal_p(foo, fn_returns_string(foo));
} }
void test_core_assert__argument_with_void_return_type(void) void test_assert__argument_with_void_return_type(void)
{ {
const char *foo = "foo"; const char *foo = "foo";
...@@ -80,7 +80,7 @@ void test_core_assert__argument_with_void_return_type(void) ...@@ -80,7 +80,7 @@ void test_core_assert__argument_with_void_return_type(void)
cl_assert_equal_p(NULL, git_error_last()); cl_assert_equal_p(NULL, git_error_last());
} }
void test_core_assert__internal(void) void test_assert__internal(void)
{ {
cl_git_fail(bad_math()); cl_git_fail(bad_math());
cl_assert(git_error_last()); cl_assert(git_error_last());
......
...@@ -35,7 +35,7 @@ static void check_some_bits(git_bitvec *bv, size_t length) ...@@ -35,7 +35,7 @@ static void check_some_bits(git_bitvec *bv, size_t length)
cl_assert_equal_b(i % 3 == 0 || i % 7 == 0, git_bitvec_get(bv, i)); cl_assert_equal_b(i % 3 == 0 || i % 7 == 0, git_bitvec_get(bv, i));
} }
void test_core_bitvec__0(void) void test_bitvec__0(void)
{ {
git_bitvec bv; git_bitvec bv;
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
#include "futils.h" #include "futils.h"
#include "posix.h" #include "posix.h"
void test_core_copy__file(void) void test_copy__file(void)
{ {
struct stat st; struct stat st;
const char *content = "This is some stuff to copy\n"; const char *content = "This is some stuff to copy\n";
...@@ -19,7 +19,7 @@ void test_core_copy__file(void) ...@@ -19,7 +19,7 @@ void test_core_copy__file(void)
cl_git_pass(p_unlink("copy_me")); cl_git_pass(p_unlink("copy_me"));
} }
void test_core_copy__file_in_dir(void) void test_copy__file_in_dir(void)
{ {
struct stat st; struct stat st;
const char *content = "This is some other stuff to copy\n"; const char *content = "This is some other stuff to copy\n";
...@@ -56,7 +56,7 @@ static void assert_hard_link(const char *path) ...@@ -56,7 +56,7 @@ static void assert_hard_link(const char *path)
} }
#endif #endif
void test_core_copy__tree(void) void test_copy__tree(void)
{ {
struct stat st; struct stat st;
const char *content = "File content\n"; const char *content = "File content\n";
......
#ifndef INCLUDE_filter_crlf_h__
#define INCLUDE_filter_crlf_h__
/*
* file content for files in the resources/crlf repository
*/
#define UTF8_BOM "\xEF\xBB\xBF"
#define ALL_CRLF_TEXT_RAW "crlf\r\ncrlf\r\ncrlf\r\ncrlf\r\n"
#define ALL_LF_TEXT_RAW "lf\nlf\nlf\nlf\nlf\n"
#define MORE_CRLF_TEXT_RAW "crlf\r\ncrlf\r\nlf\ncrlf\r\ncrlf\r\n"
#define MORE_LF_TEXT_RAW "lf\nlf\ncrlf\r\nlf\nlf\n"
#define ALL_CRLF_TEXT_AS_CRLF ALL_CRLF_TEXT_RAW
#define ALL_LF_TEXT_AS_CRLF "lf\r\nlf\r\nlf\r\nlf\r\nlf\r\n"
#define MORE_CRLF_TEXT_AS_CRLF "crlf\r\ncrlf\r\nlf\r\ncrlf\r\ncrlf\r\n"
#define MORE_LF_TEXT_AS_CRLF "lf\r\nlf\r\ncrlf\r\nlf\r\nlf\r\n"
#define ALL_CRLF_TEXT_AS_LF "crlf\ncrlf\ncrlf\ncrlf\n"
#define ALL_LF_TEXT_AS_LF ALL_LF_TEXT_RAW
#define MORE_CRLF_TEXT_AS_LF "crlf\ncrlf\nlf\ncrlf\ncrlf\n"
#define MORE_LF_TEXT_AS_LF "lf\nlf\ncrlf\nlf\nlf\n"
#define FEW_UTF8_CRLF_RAW "\xe2\x9a\xbdThe rest is ASCII01.\r\nThe rest is ASCII02.\r\nThe rest is ASCII03.\r\nThe rest is ASCII04.\r\nThe rest is ASCII05.\r\nThe rest is ASCII06.\r\nThe rest is ASCII07.\r\nThe rest is ASCII08.\r\nThe rest is ASCII09.\r\nThe rest is ASCII10.\r\nThe rest is ASCII11.\r\nThe rest is ASCII12.\r\nThe rest is ASCII13.\r\nThe rest is ASCII14.\r\nThe rest is ASCII15.\r\nThe rest is ASCII16.\r\nThe rest is ASCII17.\r\nThe rest is ASCII18.\r\nThe rest is ASCII19.\r\nThe rest is ASCII20.\r\nThe rest is ASCII21.\r\nThe rest is ASCII22.\r\n"
#define FEW_UTF8_LF_RAW "\xe2\x9a\xbdThe rest is ASCII01.\nThe rest is ASCII02.\nThe rest is ASCII03.\nThe rest is ASCII04.\nThe rest is ASCII05.\nThe rest is ASCII06.\nThe rest is ASCII07.\nThe rest is ASCII08.\nThe rest is ASCII09.\nThe rest is ASCII10.\nThe rest is ASCII11.\nThe rest is ASCII12.\nThe rest is ASCII13.\nThe rest is ASCII14.\nThe rest is ASCII15.\nThe rest is ASCII16.\nThe rest is ASCII17.\nThe rest is ASCII18.\nThe rest is ASCII19.\nThe rest is ASCII20.\nThe rest is ASCII21.\nThe rest is ASCII22.\n"
#define MANY_UTF8_CRLF_RAW "Lets sing!\r\n\xe2\x99\xab\xe2\x99\xaa\xe2\x99\xac\xe2\x99\xa9\r\nEat food\r\n\xf0\x9f\x8d\x85\xf0\x9f\x8d\x95\r\n"
#define MANY_UTF8_LF_RAW "Lets sing!\n\xe2\x99\xab\xe2\x99\xaa\xe2\x99\xac\xe2\x99\xa9\nEat food\n\xf0\x9f\x8d\x85\xf0\x9f\x8d\x95\n"
#endif
...@@ -108,7 +108,7 @@ static walk_data dot = { ...@@ -108,7 +108,7 @@ static walk_data dot = {
}; };
/* make sure that the '.' folder is not traversed */ /* make sure that the '.' folder is not traversed */
void test_core_dirent__dont_traverse_dot(void) void test_dirent__dont_traverse_dot(void)
{ {
cl_set_cleanup(&dirent_cleanup__cb, &dot); cl_set_cleanup(&dirent_cleanup__cb, &dot);
setup(&dot); setup(&dot);
...@@ -132,7 +132,7 @@ static walk_data sub = { ...@@ -132,7 +132,7 @@ static walk_data sub = {
}; };
/* traverse a subfolder */ /* traverse a subfolder */
void test_core_dirent__traverse_subfolder(void) void test_dirent__traverse_subfolder(void)
{ {
cl_set_cleanup(&dirent_cleanup__cb, &sub); cl_set_cleanup(&dirent_cleanup__cb, &sub);
setup(&sub); setup(&sub);
...@@ -150,7 +150,7 @@ static walk_data sub_slash = { ...@@ -150,7 +150,7 @@ static walk_data sub_slash = {
}; };
/* traverse a slash-terminated subfolder */ /* traverse a slash-terminated subfolder */
void test_core_dirent__traverse_slash_terminated_folder(void) void test_dirent__traverse_slash_terminated_folder(void)
{ {
cl_set_cleanup(&dirent_cleanup__cb, &sub_slash); cl_set_cleanup(&dirent_cleanup__cb, &sub_slash);
setup(&sub_slash); setup(&sub_slash);
...@@ -171,7 +171,7 @@ static walk_data empty = { ...@@ -171,7 +171,7 @@ static walk_data empty = {
}; };
/* make sure that empty folders are not traversed */ /* make sure that empty folders are not traversed */
void test_core_dirent__dont_traverse_empty_folders(void) void test_dirent__dont_traverse_empty_folders(void)
{ {
cl_set_cleanup(&dirent_cleanup__cb, &empty); cl_set_cleanup(&dirent_cleanup__cb, &empty);
setup(&empty); setup(&empty);
...@@ -199,7 +199,7 @@ static walk_data odd = { ...@@ -199,7 +199,7 @@ static walk_data odd = {
}; };
/* make sure that strange looking filenames ('..c') are traversed */ /* make sure that strange looking filenames ('..c') are traversed */
void test_core_dirent__traverse_weird_filenames(void) void test_dirent__traverse_weird_filenames(void)
{ {
cl_set_cleanup(&dirent_cleanup__cb, &odd); cl_set_cleanup(&dirent_cleanup__cb, &odd);
setup(&odd); setup(&odd);
...@@ -210,7 +210,7 @@ void test_core_dirent__traverse_weird_filenames(void) ...@@ -210,7 +210,7 @@ void test_core_dirent__traverse_weird_filenames(void)
} }
/* test filename length limits */ /* test filename length limits */
void test_core_dirent__length_limits(void) void test_dirent__length_limits(void)
{ {
char *big_filename = (char *)git__malloc(FILENAME_MAX + 1); char *big_filename = (char *)git__malloc(FILENAME_MAX + 1);
memset(big_filename, 'a', FILENAME_MAX + 1); memset(big_filename, 'a', FILENAME_MAX + 1);
...@@ -221,7 +221,7 @@ void test_core_dirent__length_limits(void) ...@@ -221,7 +221,7 @@ void test_core_dirent__length_limits(void)
git__free(big_filename); git__free(big_filename);
} }
void test_core_dirent__empty_dir(void) void test_dirent__empty_dir(void)
{ {
cl_must_pass(p_mkdir("empty_dir", 0777)); cl_must_pass(p_mkdir("empty_dir", 0777));
cl_assert(git_fs_path_is_empty_dir("empty_dir")); cl_assert(git_fs_path_is_empty_dir("empty_dir"));
...@@ -256,7 +256,7 @@ static void handle_next(git_fs_path_diriter *diriter, walk_data *walk) ...@@ -256,7 +256,7 @@ static void handle_next(git_fs_path_diriter *diriter, walk_data *walk)
} }
/* test directory iterator */ /* test directory iterator */
void test_core_dirent__diriter_with_fullname(void) void test_dirent__diriter_with_fullname(void)
{ {
git_fs_path_diriter diriter = GIT_FS_PATH_DIRITER_INIT; git_fs_path_diriter diriter = GIT_FS_PATH_DIRITER_INIT;
int error; int error;
...@@ -276,7 +276,7 @@ void test_core_dirent__diriter_with_fullname(void) ...@@ -276,7 +276,7 @@ void test_core_dirent__diriter_with_fullname(void)
check_counts(&sub); check_counts(&sub);
} }
void test_core_dirent__diriter_at_directory_root(void) void test_dirent__diriter_at_directory_root(void)
{ {
git_fs_path_diriter diriter = GIT_FS_PATH_DIRITER_INIT; git_fs_path_diriter diriter = GIT_FS_PATH_DIRITER_INIT;
const char *sandbox_path, *path; const char *sandbox_path, *path;
......
#include "clar_libgit2.h" #include "clar_libgit2.h"
#include "varint.h" #include "varint.h"
void test_core_encoding__decode(void) void test_encoding__decode(void)
{ {
const unsigned char *buf = (unsigned char *)"AB"; const unsigned char *buf = (unsigned char *)"AB";
size_t size; size_t size;
...@@ -23,7 +23,7 @@ void test_core_encoding__decode(void) ...@@ -23,7 +23,7 @@ void test_core_encoding__decode(void)
} }
void test_core_encoding__encode(void) void test_encoding__encode(void)
{ {
unsigned char buf[100]; unsigned char buf[100];
cl_assert(git_encode_varint(buf, 100, 65) == 1); cl_assert(git_encode_varint(buf, 100, 65) == 1);
......
#include "clar_libgit2.h" #include "clar_libgit2.h"
void test_core_errors__public_api(void) void test_errors__public_api(void)
{ {
char *str_in_error; char *str_in_error;
...@@ -30,7 +30,7 @@ void test_core_errors__public_api(void) ...@@ -30,7 +30,7 @@ void test_core_errors__public_api(void)
#include "util.h" #include "util.h"
#include "posix.h" #include "posix.h"
void test_core_errors__new_school(void) void test_errors__new_school(void)
{ {
char *str_in_error; char *str_in_error;
...@@ -86,7 +86,7 @@ void test_core_errors__new_school(void) ...@@ -86,7 +86,7 @@ void test_core_errors__new_school(void)
git_error_clear(); git_error_clear();
} }
void test_core_errors__restore(void) void test_errors__restore(void)
{ {
git_error_state err_state = {0}; git_error_state err_state = {0};
...@@ -110,7 +110,7 @@ void test_core_errors__restore(void) ...@@ -110,7 +110,7 @@ void test_core_errors__restore(void)
cl_assert_equal_s("Foo: bar", git_error_last()->message); cl_assert_equal_s("Foo: bar", git_error_last()->message);
} }
void test_core_errors__free_state(void) void test_errors__free_state(void)
{ {
git_error_state err_state = {0}; git_error_state err_state = {0};
...@@ -131,7 +131,7 @@ void test_core_errors__free_state(void) ...@@ -131,7 +131,7 @@ void test_core_errors__free_state(void)
cl_assert(git_error_last() == NULL); cl_assert(git_error_last() == NULL);
} }
void test_core_errors__restore_oom(void) void test_errors__restore_oom(void)
{ {
git_error_state err_state = {0}; git_error_state err_state = {0};
const git_error *oom_error = NULL; const git_error *oom_error = NULL;
...@@ -163,7 +163,7 @@ static int test_arraysize_multiply(size_t nelem, size_t size) ...@@ -163,7 +163,7 @@ static int test_arraysize_multiply(size_t nelem, size_t size)
return 0; return 0;
} }
void test_core_errors__integer_overflow_alloc_multiply(void) void test_errors__integer_overflow_alloc_multiply(void)
{ {
cl_git_pass(test_arraysize_multiply(10, 10)); cl_git_pass(test_arraysize_multiply(10, 10));
cl_git_pass(test_arraysize_multiply(1000, 1000)); cl_git_pass(test_arraysize_multiply(1000, 1000));
...@@ -185,7 +185,7 @@ static int test_arraysize_add(size_t one, size_t two) ...@@ -185,7 +185,7 @@ static int test_arraysize_add(size_t one, size_t two)
return 0; return 0;
} }
void test_core_errors__integer_overflow_alloc_add(void) void test_errors__integer_overflow_alloc_add(void)
{ {
cl_git_pass(test_arraysize_add(10, 10)); cl_git_pass(test_arraysize_add(10, 10));
cl_git_pass(test_arraysize_add(1000, 1000)); cl_git_pass(test_arraysize_add(1000, 1000));
...@@ -198,7 +198,7 @@ void test_core_errors__integer_overflow_alloc_add(void) ...@@ -198,7 +198,7 @@ void test_core_errors__integer_overflow_alloc_add(void)
cl_assert_equal_s("Out of memory", git_error_last()->message); cl_assert_equal_s("Out of memory", git_error_last()->message);
} }
void test_core_errors__integer_overflow_sets_oom(void) void test_errors__integer_overflow_sets_oom(void)
{ {
size_t out; size_t out;
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
#include "filebuf.h" #include "filebuf.h"
/* make sure git_filebuf_open doesn't delete an existing lock */ /* make sure git_filebuf_open doesn't delete an existing lock */
void test_core_filebuf__0(void) void test_filebuf__0(void)
{ {
git_filebuf file = GIT_FILEBUF_INIT; git_filebuf file = GIT_FILEBUF_INIT;
int fd; int fd;
...@@ -21,7 +21,7 @@ void test_core_filebuf__0(void) ...@@ -21,7 +21,7 @@ void test_core_filebuf__0(void)
/* make sure GIT_FILEBUF_APPEND works as expected */ /* make sure GIT_FILEBUF_APPEND works as expected */
void test_core_filebuf__1(void) void test_filebuf__1(void)
{ {
git_filebuf file = GIT_FILEBUF_INIT; git_filebuf file = GIT_FILEBUF_INIT;
char test[] = "test"; char test[] = "test";
...@@ -39,7 +39,7 @@ void test_core_filebuf__1(void) ...@@ -39,7 +39,7 @@ void test_core_filebuf__1(void)
/* make sure git_filebuf_write writes large buffer correctly */ /* make sure git_filebuf_write writes large buffer correctly */
void test_core_filebuf__2(void) void test_filebuf__2(void)
{ {
git_filebuf file = GIT_FILEBUF_INIT; git_filebuf file = GIT_FILEBUF_INIT;
char test[] = "test"; char test[] = "test";
...@@ -57,7 +57,7 @@ void test_core_filebuf__2(void) ...@@ -57,7 +57,7 @@ void test_core_filebuf__2(void)
} }
/* make sure git_filebuf_cleanup clears the buffer */ /* make sure git_filebuf_cleanup clears the buffer */
void test_core_filebuf__4(void) void test_filebuf__4(void)
{ {
git_filebuf file = GIT_FILEBUF_INIT; git_filebuf file = GIT_FILEBUF_INIT;
char test[] = "test"; char test[] = "test";
...@@ -73,7 +73,7 @@ void test_core_filebuf__4(void) ...@@ -73,7 +73,7 @@ void test_core_filebuf__4(void)
/* make sure git_filebuf_commit clears the buffer */ /* make sure git_filebuf_commit clears the buffer */
void test_core_filebuf__5(void) void test_filebuf__5(void)
{ {
git_filebuf file = GIT_FILEBUF_INIT; git_filebuf file = GIT_FILEBUF_INIT;
char test[] = "test"; char test[] = "test";
...@@ -93,7 +93,7 @@ void test_core_filebuf__5(void) ...@@ -93,7 +93,7 @@ void test_core_filebuf__5(void)
/* make sure git_filebuf_commit takes umask into account */ /* make sure git_filebuf_commit takes umask into account */
void test_core_filebuf__umask(void) void test_filebuf__umask(void)
{ {
git_filebuf file = GIT_FILEBUF_INIT; git_filebuf file = GIT_FILEBUF_INIT;
char test[] = "test"; char test[] = "test";
...@@ -124,7 +124,7 @@ void test_core_filebuf__umask(void) ...@@ -124,7 +124,7 @@ void test_core_filebuf__umask(void)
cl_must_pass(p_unlink(test)); cl_must_pass(p_unlink(test));
} }
void test_core_filebuf__rename_error(void) void test_filebuf__rename_error(void)
{ {
git_filebuf file = GIT_FILEBUF_INIT; git_filebuf file = GIT_FILEBUF_INIT;
char *dir = "subdir", *test = "subdir/test", *test_lock = "subdir/test.lock"; char *dir = "subdir", *test = "subdir/test", *test_lock = "subdir/test.lock";
...@@ -152,7 +152,7 @@ void test_core_filebuf__rename_error(void) ...@@ -152,7 +152,7 @@ void test_core_filebuf__rename_error(void)
cl_assert_equal_i(false, git_fs_path_exists(test_lock)); cl_assert_equal_i(false, git_fs_path_exists(test_lock));
} }
void test_core_filebuf__symlink_follow(void) void test_filebuf__symlink_follow(void)
{ {
git_filebuf file = GIT_FILEBUF_INIT; git_filebuf file = GIT_FILEBUF_INIT;
const char *dir = "linkdir", *source = "linkdir/link"; const char *dir = "linkdir", *source = "linkdir/link";
...@@ -186,7 +186,7 @@ void test_core_filebuf__symlink_follow(void) ...@@ -186,7 +186,7 @@ void test_core_filebuf__symlink_follow(void)
cl_git_pass(git_futils_rmdir_r(dir, NULL, GIT_RMDIR_REMOVE_FILES)); cl_git_pass(git_futils_rmdir_r(dir, NULL, GIT_RMDIR_REMOVE_FILES));
} }
void test_core_filebuf__symlink_follow_absolute_paths(void) void test_filebuf__symlink_follow_absolute_paths(void)
{ {
git_filebuf file = GIT_FILEBUF_INIT; git_filebuf file = GIT_FILEBUF_INIT;
git_str source = GIT_STR_INIT, target = GIT_STR_INIT; git_str source = GIT_STR_INIT, target = GIT_STR_INIT;
...@@ -214,7 +214,7 @@ void test_core_filebuf__symlink_follow_absolute_paths(void) ...@@ -214,7 +214,7 @@ void test_core_filebuf__symlink_follow_absolute_paths(void)
cl_git_pass(git_futils_rmdir_r("linkdir", NULL, GIT_RMDIR_REMOVE_FILES)); cl_git_pass(git_futils_rmdir_r("linkdir", NULL, GIT_RMDIR_REMOVE_FILES));
} }
void test_core_filebuf__symlink_depth(void) void test_filebuf__symlink_depth(void)
{ {
git_filebuf file = GIT_FILEBUF_INIT; git_filebuf file = GIT_FILEBUF_INIT;
const char *dir = "linkdir", *source = "linkdir/link"; const char *dir = "linkdir", *source = "linkdir/link";
...@@ -231,7 +231,7 @@ void test_core_filebuf__symlink_depth(void) ...@@ -231,7 +231,7 @@ void test_core_filebuf__symlink_depth(void)
cl_git_pass(git_futils_rmdir_r(dir, NULL, GIT_RMDIR_REMOVE_FILES)); cl_git_pass(git_futils_rmdir_r(dir, NULL, GIT_RMDIR_REMOVE_FILES));
} }
void test_core_filebuf__hidden_file(void) void test_filebuf__hidden_file(void)
{ {
#ifndef GIT_WIN32 #ifndef GIT_WIN32
cl_skip(); cl_skip();
...@@ -257,7 +257,7 @@ void test_core_filebuf__hidden_file(void) ...@@ -257,7 +257,7 @@ void test_core_filebuf__hidden_file(void)
#endif #endif
} }
void test_core_filebuf__detects_directory(void) void test_filebuf__detects_directory(void)
{ {
git_filebuf file = GIT_FILEBUF_INIT; git_filebuf file = GIT_FILEBUF_INIT;
......
...@@ -8,7 +8,7 @@ ...@@ -8,7 +8,7 @@
static const char *filename = "core_ftruncate.txt"; static const char *filename = "core_ftruncate.txt";
static int fd = -1; static int fd = -1;
void test_core_ftruncate__initialize(void) void test_ftruncate__initialize(void)
{ {
if (!cl_is_env_set("GITTEST_INVASIVE_FS_SIZE")) if (!cl_is_env_set("GITTEST_INVASIVE_FS_SIZE"))
cl_skip(); cl_skip();
...@@ -16,7 +16,7 @@ void test_core_ftruncate__initialize(void) ...@@ -16,7 +16,7 @@ void test_core_ftruncate__initialize(void)
cl_must_pass((fd = p_open(filename, O_CREAT | O_RDWR, 0644))); cl_must_pass((fd = p_open(filename, O_CREAT | O_RDWR, 0644)));
} }
void test_core_ftruncate__cleanup(void) void test_ftruncate__cleanup(void)
{ {
if (fd < 0) if (fd < 0)
return; return;
...@@ -37,12 +37,12 @@ static void _extend(off64_t i64len) ...@@ -37,12 +37,12 @@ static void _extend(off64_t i64len)
cl_assert(st.st_size == i64len); cl_assert(st.st_size == i64len);
} }
void test_core_ftruncate__2gb(void) void test_ftruncate__2gb(void)
{ {
_extend(0x80000001); _extend(0x80000001);
} }
void test_core_ftruncate__4gb(void) void test_ftruncate__4gb(void)
{ {
_extend(0x100000001); _extend(0x100000001);
} }
...@@ -2,17 +2,17 @@ ...@@ -2,17 +2,17 @@
#include "futils.h" #include "futils.h"
/* Fixture setup and teardown */ /* Fixture setup and teardown */
void test_core_futils__initialize(void) void test_futils__initialize(void)
{ {
cl_must_pass(p_mkdir("futils", 0777)); cl_must_pass(p_mkdir("futils", 0777));
} }
void test_core_futils__cleanup(void) void test_futils__cleanup(void)
{ {
cl_fixture_cleanup("futils"); cl_fixture_cleanup("futils");
} }
void test_core_futils__writebuffer(void) void test_futils__writebuffer(void)
{ {
git_str out = GIT_STR_INIT, git_str out = GIT_STR_INIT,
append = GIT_STR_INIT; append = GIT_STR_INIT;
...@@ -37,7 +37,7 @@ void test_core_futils__writebuffer(void) ...@@ -37,7 +37,7 @@ void test_core_futils__writebuffer(void)
git_str_dispose(&append); git_str_dispose(&append);
} }
void test_core_futils__write_hidden_file(void) void test_futils__write_hidden_file(void)
{ {
#ifndef GIT_WIN32 #ifndef GIT_WIN32
cl_skip(); cl_skip();
...@@ -66,7 +66,7 @@ void test_core_futils__write_hidden_file(void) ...@@ -66,7 +66,7 @@ void test_core_futils__write_hidden_file(void)
#endif #endif
} }
void test_core_futils__recursive_rmdir_keeps_symlink_targets(void) void test_futils__recursive_rmdir_keeps_symlink_targets(void)
{ {
if (!git_fs_path_supports_symlinks(clar_sandbox_path())) if (!git_fs_path_supports_symlinks(clar_sandbox_path()))
cl_skip(); cl_skip();
...@@ -88,7 +88,7 @@ void test_core_futils__recursive_rmdir_keeps_symlink_targets(void) ...@@ -88,7 +88,7 @@ void test_core_futils__recursive_rmdir_keeps_symlink_targets(void)
cl_must_pass(p_unlink("file-target")); cl_must_pass(p_unlink("file-target"));
} }
void test_core_futils__mktmp_umask(void) void test_futils__mktmp_umask(void)
{ {
#ifdef GIT_WIN32 #ifdef GIT_WIN32
cl_skip(); cl_skip();
......
#include "clar_libgit2.h" #include "clar_libgit2.h"
#include "util.h" #include "util.h"
void test_core_hex__fromhex(void) void test_hex__fromhex(void)
{ {
/* Passing cases */ /* Passing cases */
cl_assert(git__fromhex('0') == 0x0); cl_assert(git__fromhex('0') == 0x0);
......
...@@ -7,21 +7,21 @@ static char *nfc = "\xC3\x85\x73\x74\x72\xC3\xB6\x6D"; ...@@ -7,21 +7,21 @@ static char *nfc = "\xC3\x85\x73\x74\x72\xC3\xB6\x6D";
static char *nfd = "\x41\xCC\x8A\x73\x74\x72\x6F\xCC\x88\x6D"; static char *nfd = "\x41\xCC\x8A\x73\x74\x72\x6F\xCC\x88\x6D";
#endif #endif
void test_core_iconv__initialize(void) void test_iconv__initialize(void)
{ {
#ifdef GIT_USE_ICONV #ifdef GIT_USE_ICONV
cl_git_pass(git_fs_path_iconv_init_precompose(&ic)); cl_git_pass(git_fs_path_iconv_init_precompose(&ic));
#endif #endif
} }
void test_core_iconv__cleanup(void) void test_iconv__cleanup(void)
{ {
#ifdef GIT_USE_ICONV #ifdef GIT_USE_ICONV
git_fs_path_iconv_clear(&ic); git_fs_path_iconv_clear(&ic);
#endif #endif
} }
void test_core_iconv__unchanged(void) void test_iconv__unchanged(void)
{ {
#ifdef GIT_USE_ICONV #ifdef GIT_USE_ICONV
const char *data = "Ascii data", *original = data; const char *data = "Ascii data", *original = data;
...@@ -35,7 +35,7 @@ void test_core_iconv__unchanged(void) ...@@ -35,7 +35,7 @@ void test_core_iconv__unchanged(void)
#endif #endif
} }
void test_core_iconv__decomposed_to_precomposed(void) void test_iconv__decomposed_to_precomposed(void)
{ {
#ifdef GIT_USE_ICONV #ifdef GIT_USE_ICONV
const char *data = nfd; const char *data = nfd;
...@@ -61,7 +61,7 @@ void test_core_iconv__decomposed_to_precomposed(void) ...@@ -61,7 +61,7 @@ void test_core_iconv__decomposed_to_precomposed(void)
#endif #endif
} }
void test_core_iconv__precomposed_is_unmodified(void) void test_iconv__precomposed_is_unmodified(void)
{ {
#ifdef GIT_USE_ICONV #ifdef GIT_USE_ICONV
const char *data = nfc; const char *data = nfc;
......
#include "clar_libgit2.h" #include "clar_libgit2.h"
void test_core_init__returns_count(void) void test_init__returns_count(void)
{ {
/* libgit2_tests initializes us first, so we have an existing /* libgit2_tests initializes us first, so we have an existing
* initialization. * initialization.
...@@ -12,7 +12,7 @@ void test_core_init__returns_count(void) ...@@ -12,7 +12,7 @@ void test_core_init__returns_count(void)
cl_assert_equal_i(1, git_libgit2_shutdown()); cl_assert_equal_i(1, git_libgit2_shutdown());
} }
void test_core_init__reinit_succeeds(void) void test_init__reinit_succeeds(void)
{ {
cl_assert_equal_i(0, git_libgit2_shutdown()); cl_assert_equal_i(0, git_libgit2_shutdown());
cl_assert_equal_i(1, git_libgit2_init()); cl_assert_equal_i(1, git_libgit2_init());
...@@ -33,7 +33,7 @@ static void *reinit(void *unused) ...@@ -33,7 +33,7 @@ static void *reinit(void *unused)
} }
#endif #endif
void test_core_init__concurrent_init_succeeds(void) void test_init__concurrent_init_succeeds(void)
{ {
#ifdef GIT_THREADS #ifdef GIT_THREADS
git_thread threads[10]; git_thread threads[10];
......
#include "clar_libgit2.h" #include "clar_libgit2.h"
void test_core_integer__multiply_int64_no_overflow(void) void test_integer__multiply_int64_no_overflow(void)
{ {
#if !defined(git__multiply_int64_overflow) #if !defined(git__multiply_int64_overflow)
int64_t result = 0; int64_t result = 0;
...@@ -169,7 +169,7 @@ void test_core_integer__multiply_int64_no_overflow(void) ...@@ -169,7 +169,7 @@ void test_core_integer__multiply_int64_no_overflow(void)
#endif #endif
} }
void test_core_integer__multiply_int64_overflow(void) void test_integer__multiply_int64_overflow(void)
{ {
#if !defined(git__multiply_int64_overflow) #if !defined(git__multiply_int64_overflow)
int64_t result = 0; int64_t result = 0;
...@@ -239,7 +239,7 @@ void test_core_integer__multiply_int64_overflow(void) ...@@ -239,7 +239,7 @@ void test_core_integer__multiply_int64_overflow(void)
#endif #endif
} }
void test_core_integer__multiply_int64_edge_cases(void) void test_integer__multiply_int64_edge_cases(void)
{ {
#if !defined(git__multiply_int64_overflow) #if !defined(git__multiply_int64_overflow)
int64_t result = 0; int64_t result = 0;
......
...@@ -5,7 +5,7 @@ ...@@ -5,7 +5,7 @@
# include "win32/reparse.h" # include "win32/reparse.h"
#endif #endif
void test_core_link__cleanup(void) void test_link__cleanup(void)
{ {
#ifdef GIT_WIN32 #ifdef GIT_WIN32
RemoveDirectory("lstat_junction"); RemoveDirectory("lstat_junction");
...@@ -195,7 +195,7 @@ static void do_custom_reparse(const char *path) ...@@ -195,7 +195,7 @@ static void do_custom_reparse(const char *path)
#endif #endif
void test_core_link__stat_regular_file(void) void test_link__stat_regular_file(void)
{ {
struct stat st; struct stat st;
...@@ -206,7 +206,7 @@ void test_core_link__stat_regular_file(void) ...@@ -206,7 +206,7 @@ void test_core_link__stat_regular_file(void)
cl_assert_equal_i(24, st.st_size); cl_assert_equal_i(24, st.st_size);
} }
void test_core_link__lstat_regular_file(void) void test_link__lstat_regular_file(void)
{ {
struct stat st; struct stat st;
...@@ -217,7 +217,7 @@ void test_core_link__lstat_regular_file(void) ...@@ -217,7 +217,7 @@ void test_core_link__lstat_regular_file(void)
cl_assert_equal_i(24, st.st_size); cl_assert_equal_i(24, st.st_size);
} }
void test_core_link__stat_symlink(void) void test_link__stat_symlink(void)
{ {
struct stat st; struct stat st;
...@@ -236,7 +236,7 @@ void test_core_link__stat_symlink(void) ...@@ -236,7 +236,7 @@ void test_core_link__stat_symlink(void)
cl_assert_equal_i(39, st.st_size); cl_assert_equal_i(39, st.st_size);
} }
void test_core_link__stat_symlink_directory(void) void test_link__stat_symlink_directory(void)
{ {
struct stat st; struct stat st;
...@@ -253,7 +253,7 @@ void test_core_link__stat_symlink_directory(void) ...@@ -253,7 +253,7 @@ void test_core_link__stat_symlink_directory(void)
cl_assert(S_ISDIR(st.st_mode)); cl_assert(S_ISDIR(st.st_mode));
} }
void test_core_link__stat_symlink_chain(void) void test_link__stat_symlink_chain(void)
{ {
struct stat st; struct stat st;
...@@ -270,7 +270,7 @@ void test_core_link__stat_symlink_chain(void) ...@@ -270,7 +270,7 @@ void test_core_link__stat_symlink_chain(void)
cl_assert_equal_i(39, st.st_size); cl_assert_equal_i(39, st.st_size);
} }
void test_core_link__stat_dangling_symlink(void) void test_link__stat_dangling_symlink(void)
{ {
struct stat st; struct stat st;
...@@ -283,7 +283,7 @@ void test_core_link__stat_dangling_symlink(void) ...@@ -283,7 +283,7 @@ void test_core_link__stat_dangling_symlink(void)
cl_must_fail(p_stat("stat_dangling", &st)); cl_must_fail(p_stat("stat_dangling", &st));
} }
void test_core_link__stat_dangling_symlink_directory(void) void test_link__stat_dangling_symlink_directory(void)
{ {
struct stat st; struct stat st;
...@@ -296,7 +296,7 @@ void test_core_link__stat_dangling_symlink_directory(void) ...@@ -296,7 +296,7 @@ void test_core_link__stat_dangling_symlink_directory(void)
cl_must_fail(p_stat("stat_dangling", &st)); cl_must_fail(p_stat("stat_dangling", &st));
} }
void test_core_link__lstat_symlink(void) void test_link__lstat_symlink(void)
{ {
git_str target_path = GIT_STR_INIT; git_str target_path = GIT_STR_INIT;
struct stat st; struct stat st;
...@@ -323,7 +323,7 @@ void test_core_link__lstat_symlink(void) ...@@ -323,7 +323,7 @@ void test_core_link__lstat_symlink(void)
git_str_dispose(&target_path); git_str_dispose(&target_path);
} }
void test_core_link__lstat_symlink_directory(void) void test_link__lstat_symlink_directory(void)
{ {
git_str target_path = GIT_STR_INIT; git_str target_path = GIT_STR_INIT;
struct stat st; struct stat st;
...@@ -346,7 +346,7 @@ void test_core_link__lstat_symlink_directory(void) ...@@ -346,7 +346,7 @@ void test_core_link__lstat_symlink_directory(void)
git_str_dispose(&target_path); git_str_dispose(&target_path);
} }
void test_core_link__lstat_dangling_symlink(void) void test_link__lstat_dangling_symlink(void)
{ {
struct stat st; struct stat st;
...@@ -362,7 +362,7 @@ void test_core_link__lstat_dangling_symlink(void) ...@@ -362,7 +362,7 @@ void test_core_link__lstat_dangling_symlink(void)
cl_assert_equal_i(strlen("lstat_nonexistent"), st.st_size); cl_assert_equal_i(strlen("lstat_nonexistent"), st.st_size);
} }
void test_core_link__lstat_dangling_symlink_directory(void) void test_link__lstat_dangling_symlink_directory(void)
{ {
struct stat st; struct stat st;
...@@ -378,7 +378,7 @@ void test_core_link__lstat_dangling_symlink_directory(void) ...@@ -378,7 +378,7 @@ void test_core_link__lstat_dangling_symlink_directory(void)
cl_assert_equal_i(strlen("lstat_nonexistent"), st.st_size); cl_assert_equal_i(strlen("lstat_nonexistent"), st.st_size);
} }
void test_core_link__stat_junction(void) void test_link__stat_junction(void)
{ {
#ifdef GIT_WIN32 #ifdef GIT_WIN32
git_str target_path = GIT_STR_INIT; git_str target_path = GIT_STR_INIT;
...@@ -399,7 +399,7 @@ void test_core_link__stat_junction(void) ...@@ -399,7 +399,7 @@ void test_core_link__stat_junction(void)
#endif #endif
} }
void test_core_link__stat_dangling_junction(void) void test_link__stat_dangling_junction(void)
{ {
#ifdef GIT_WIN32 #ifdef GIT_WIN32
git_str target_path = GIT_STR_INIT; git_str target_path = GIT_STR_INIT;
...@@ -419,7 +419,7 @@ void test_core_link__stat_dangling_junction(void) ...@@ -419,7 +419,7 @@ void test_core_link__stat_dangling_junction(void)
#endif #endif
} }
void test_core_link__lstat_junction(void) void test_link__lstat_junction(void)
{ {
#ifdef GIT_WIN32 #ifdef GIT_WIN32
git_str target_path = GIT_STR_INIT; git_str target_path = GIT_STR_INIT;
...@@ -440,7 +440,7 @@ void test_core_link__lstat_junction(void) ...@@ -440,7 +440,7 @@ void test_core_link__lstat_junction(void)
#endif #endif
} }
void test_core_link__lstat_dangling_junction(void) void test_link__lstat_dangling_junction(void)
{ {
#ifdef GIT_WIN32 #ifdef GIT_WIN32
git_str target_path = GIT_STR_INIT; git_str target_path = GIT_STR_INIT;
...@@ -463,7 +463,7 @@ void test_core_link__lstat_dangling_junction(void) ...@@ -463,7 +463,7 @@ void test_core_link__lstat_dangling_junction(void)
#endif #endif
} }
void test_core_link__stat_hardlink(void) void test_link__stat_hardlink(void)
{ {
struct stat st; struct stat st;
...@@ -482,7 +482,7 @@ void test_core_link__stat_hardlink(void) ...@@ -482,7 +482,7 @@ void test_core_link__stat_hardlink(void)
cl_assert_equal_i(26, st.st_size); cl_assert_equal_i(26, st.st_size);
} }
void test_core_link__lstat_hardlink(void) void test_link__lstat_hardlink(void)
{ {
struct stat st; struct stat st;
...@@ -501,7 +501,7 @@ void test_core_link__lstat_hardlink(void) ...@@ -501,7 +501,7 @@ void test_core_link__lstat_hardlink(void)
cl_assert_equal_i(26, st.st_size); cl_assert_equal_i(26, st.st_size);
} }
void test_core_link__stat_reparse_point(void) void test_link__stat_reparse_point(void)
{ {
#ifdef GIT_WIN32 #ifdef GIT_WIN32
struct stat st; struct stat st;
...@@ -519,7 +519,7 @@ void test_core_link__stat_reparse_point(void) ...@@ -519,7 +519,7 @@ void test_core_link__stat_reparse_point(void)
#endif #endif
} }
void test_core_link__lstat_reparse_point(void) void test_link__lstat_reparse_point(void)
{ {
#ifdef GIT_WIN32 #ifdef GIT_WIN32
struct stat st; struct stat st;
...@@ -533,7 +533,7 @@ void test_core_link__lstat_reparse_point(void) ...@@ -533,7 +533,7 @@ void test_core_link__lstat_reparse_point(void)
#endif #endif
} }
void test_core_link__readlink_nonexistent_file(void) void test_link__readlink_nonexistent_file(void)
{ {
char buf[2048]; char buf[2048];
...@@ -541,7 +541,7 @@ void test_core_link__readlink_nonexistent_file(void) ...@@ -541,7 +541,7 @@ void test_core_link__readlink_nonexistent_file(void)
cl_assert_equal_i(ENOENT, errno); cl_assert_equal_i(ENOENT, errno);
} }
void test_core_link__readlink_normal_file(void) void test_link__readlink_normal_file(void)
{ {
char buf[2048]; char buf[2048];
...@@ -550,7 +550,7 @@ void test_core_link__readlink_normal_file(void) ...@@ -550,7 +550,7 @@ void test_core_link__readlink_normal_file(void)
cl_assert_equal_i(EINVAL, errno); cl_assert_equal_i(EINVAL, errno);
} }
void test_core_link__readlink_symlink(void) void test_link__readlink_symlink(void)
{ {
git_str target_path = GIT_STR_INIT; git_str target_path = GIT_STR_INIT;
int len; int len;
...@@ -574,7 +574,7 @@ void test_core_link__readlink_symlink(void) ...@@ -574,7 +574,7 @@ void test_core_link__readlink_symlink(void)
git_str_dispose(&target_path); git_str_dispose(&target_path);
} }
void test_core_link__readlink_dangling(void) void test_link__readlink_dangling(void)
{ {
git_str target_path = GIT_STR_INIT; git_str target_path = GIT_STR_INIT;
int len; int len;
...@@ -597,7 +597,7 @@ void test_core_link__readlink_dangling(void) ...@@ -597,7 +597,7 @@ void test_core_link__readlink_dangling(void)
git_str_dispose(&target_path); git_str_dispose(&target_path);
} }
void test_core_link__readlink_multiple(void) void test_link__readlink_multiple(void)
{ {
git_str target_path = GIT_STR_INIT, git_str target_path = GIT_STR_INIT,
path3 = GIT_STR_INIT, path2 = GIT_STR_INIT, path1 = GIT_STR_INIT; path3 = GIT_STR_INIT, path2 = GIT_STR_INIT, path1 = GIT_STR_INIT;
......
...@@ -14,7 +14,7 @@ static void assert_absent(const char *haystack, const char *needle) ...@@ -14,7 +14,7 @@ static void assert_absent(const char *haystack, const char *needle)
NULL); NULL);
} }
void test_core_memmem__found(void) void test_memmem__found(void)
{ {
assert_found("a", "a", 0); assert_found("a", "a", 0);
assert_found("ab", "a", 0); assert_found("ab", "a", 0);
...@@ -26,7 +26,7 @@ void test_core_memmem__found(void) ...@@ -26,7 +26,7 @@ void test_core_memmem__found(void)
assert_found("abababc", "abc", 4); assert_found("abababc", "abc", 4);
} }
void test_core_memmem__absent(void) void test_memmem__absent(void)
{ {
assert_absent("a", "b"); assert_absent("a", "b");
assert_absent("a", "aa"); assert_absent("a", "aa");
...@@ -36,7 +36,7 @@ void test_core_memmem__absent(void) ...@@ -36,7 +36,7 @@ void test_core_memmem__absent(void)
assert_absent("abcabcabc", "bcac"); assert_absent("abcabcabc", "bcac");
} }
void test_core_memmem__edgecases(void) void test_memmem__edgecases(void)
{ {
assert_absent(NULL, NULL); assert_absent(NULL, NULL);
assert_absent("a", NULL); assert_absent("a", NULL);
......
...@@ -12,7 +12,7 @@ static void cleanup_basic_dirs(void *ref) ...@@ -12,7 +12,7 @@ static void cleanup_basic_dirs(void *ref)
git_futils_rmdir_r("d4", NULL, GIT_RMDIR_EMPTY_HIERARCHY); git_futils_rmdir_r("d4", NULL, GIT_RMDIR_EMPTY_HIERARCHY);
} }
void test_core_mkdir__absolute(void) void test_mkdir__absolute(void)
{ {
git_str path = GIT_STR_INIT; git_str path = GIT_STR_INIT;
...@@ -51,7 +51,7 @@ void test_core_mkdir__absolute(void) ...@@ -51,7 +51,7 @@ void test_core_mkdir__absolute(void)
git_str_dispose(&path); git_str_dispose(&path);
} }
void test_core_mkdir__basic(void) void test_mkdir__basic(void)
{ {
cl_set_cleanup(cleanup_basic_dirs, NULL); cl_set_cleanup(cleanup_basic_dirs, NULL);
...@@ -97,7 +97,7 @@ static void cleanup_basedir(void *ref) ...@@ -97,7 +97,7 @@ static void cleanup_basedir(void *ref)
git_futils_rmdir_r("base", NULL, GIT_RMDIR_EMPTY_HIERARCHY); git_futils_rmdir_r("base", NULL, GIT_RMDIR_EMPTY_HIERARCHY);
} }
void test_core_mkdir__with_base(void) void test_mkdir__with_base(void)
{ {
#define BASEDIR "base/dir/here" #define BASEDIR "base/dir/here"
...@@ -166,7 +166,7 @@ static void check_mode_at_line( ...@@ -166,7 +166,7 @@ static void check_mode_at_line(
"%07o", (int)expected, (int)(actual & 0777)); "%07o", (int)expected, (int)(actual & 0777));
} }
void test_core_mkdir__chmods(void) void test_mkdir__chmods(void)
{ {
struct stat st; struct stat st;
mode_t *old = git__malloc(sizeof(mode_t)); mode_t *old = git__malloc(sizeof(mode_t));
...@@ -226,7 +226,7 @@ void test_core_mkdir__chmods(void) ...@@ -226,7 +226,7 @@ void test_core_mkdir__chmods(void)
check_mode(0777, st.st_mode); check_mode(0777, st.st_mode);
} }
void test_core_mkdir__keeps_parent_symlinks(void) void test_mkdir__keeps_parent_symlinks(void)
{ {
#ifndef GIT_WIN32 #ifndef GIT_WIN32
git_str path = GIT_STR_INIT; git_str path = GIT_STR_INIT;
...@@ -260,7 +260,7 @@ void test_core_mkdir__keeps_parent_symlinks(void) ...@@ -260,7 +260,7 @@ void test_core_mkdir__keeps_parent_symlinks(void)
#endif #endif
} }
void test_core_mkdir__mkdir_path_inside_unwriteable_parent(void) void test_mkdir__mkdir_path_inside_unwriteable_parent(void)
{ {
struct stat st; struct stat st;
mode_t *old; mode_t *old;
......
...@@ -4,12 +4,12 @@ ...@@ -4,12 +4,12 @@
static char *path_save; static char *path_save;
void test_core_path__initialize(void) void test_path__initialize(void)
{ {
path_save = cl_getenv("PATH"); path_save = cl_getenv("PATH");
} }
void test_core_path__cleanup(void) void test_path__cleanup(void)
{ {
cl_setenv("PATH", path_save); cl_setenv("PATH", path_save);
git__free(path_save); git__free(path_save);
...@@ -90,7 +90,7 @@ static void check_setenv(const char* name, const char* value) ...@@ -90,7 +90,7 @@ static void check_setenv(const char* name, const char* value)
} }
/* get the dirname of a path */ /* get the dirname of a path */
void test_core_path__00_dirname(void) void test_path__00_dirname(void)
{ {
check_dirname(NULL, "."); check_dirname(NULL, ".");
check_dirname("", "."); check_dirname("", ".");
...@@ -123,7 +123,7 @@ void test_core_path__00_dirname(void) ...@@ -123,7 +123,7 @@ void test_core_path__00_dirname(void)
} }
/* get the base name of a path */ /* get the base name of a path */
void test_core_path__01_basename(void) void test_path__01_basename(void)
{ {
check_basename(NULL, "."); check_basename(NULL, ".");
check_basename("", "."); check_basename("", ".");
...@@ -140,7 +140,7 @@ void test_core_path__01_basename(void) ...@@ -140,7 +140,7 @@ void test_core_path__01_basename(void)
} }
/* properly join path components */ /* properly join path components */
void test_core_path__05_joins(void) void test_path__05_joins(void)
{ {
check_joinpath("", "", ""); check_joinpath("", "", "");
check_joinpath("", "a", "a"); check_joinpath("", "a", "a");
...@@ -175,7 +175,7 @@ void test_core_path__05_joins(void) ...@@ -175,7 +175,7 @@ void test_core_path__05_joins(void)
} }
/* properly join path components for more than one path */ /* properly join path components for more than one path */
void test_core_path__06_long_joins(void) void test_path__06_long_joins(void)
{ {
check_joinpath_n("", "", "", "", ""); check_joinpath_n("", "", "", "", "");
check_joinpath_n("", "a", "", "", "a/"); check_joinpath_n("", "a", "", "", "a/");
...@@ -230,7 +230,7 @@ check_string_to_dir( ...@@ -230,7 +230,7 @@ check_string_to_dir(
} }
/* convert paths to dirs */ /* convert paths to dirs */
void test_core_path__07_path_to_dir(void) void test_path__07_path_to_dir(void)
{ {
check_path_to_dir("", ""); check_path_to_dir("", "");
check_path_to_dir(".", "./"); check_path_to_dir(".", "./");
...@@ -258,7 +258,7 @@ void test_core_path__07_path_to_dir(void) ...@@ -258,7 +258,7 @@ void test_core_path__07_path_to_dir(void)
} }
/* join path to itself */ /* join path to itself */
void test_core_path__08_self_join(void) void test_path__08_self_join(void)
{ {
git_str path = GIT_STR_INIT; git_str path = GIT_STR_INIT;
size_t asize = 0; size_t asize = 0;
...@@ -302,7 +302,7 @@ static void check_percent_decoding(const char *expected_result, const char *inpu ...@@ -302,7 +302,7 @@ static void check_percent_decoding(const char *expected_result, const char *inpu
git_str_dispose(&buf); git_str_dispose(&buf);
} }
void test_core_path__09_percent_decode(void) void test_path__09_percent_decode(void)
{ {
check_percent_decoding("abcd", "abcd"); check_percent_decoding("abcd", "abcd");
check_percent_decoding("a2%", "a2%"); check_percent_decoding("a2%", "a2%");
...@@ -337,7 +337,7 @@ static void check_fromurl(const char *expected_result, const char *input, int sh ...@@ -337,7 +337,7 @@ static void check_fromurl(const char *expected_result, const char *input, int sh
#define ABS_PATH_MARKER "/" #define ABS_PATH_MARKER "/"
#endif #endif
void test_core_path__10_fromurl(void) void test_path__10_fromurl(void)
{ {
/* Failing cases */ /* Failing cases */
check_fromurl(NULL, "a", 1); check_fromurl(NULL, "a", 1);
...@@ -380,7 +380,7 @@ static int check_one_walkup_step(void *ref, const char *path) ...@@ -380,7 +380,7 @@ static int check_one_walkup_step(void *ref, const char *path)
return 0; return 0;
} }
void test_core_path__11_walkup(void) void test_path__11_walkup(void)
{ {
git_str p = GIT_STR_INIT; git_str p = GIT_STR_INIT;
...@@ -442,7 +442,7 @@ void test_core_path__11_walkup(void) ...@@ -442,7 +442,7 @@ void test_core_path__11_walkup(void)
git_str_dispose(&p); git_str_dispose(&p);
} }
void test_core_path__11a_walkup_cancel(void) void test_path__11a_walkup_cancel(void)
{ {
git_str p = GIT_STR_INIT; git_str p = GIT_STR_INIT;
int cancel[] = { 3, 2, 1, 0 }; int cancel[] = { 3, 2, 1, 0 };
...@@ -478,7 +478,7 @@ void test_core_path__11a_walkup_cancel(void) ...@@ -478,7 +478,7 @@ void test_core_path__11a_walkup_cancel(void)
git_str_dispose(&p); git_str_dispose(&p);
} }
void test_core_path__12_offset_to_path_root(void) void test_path__12_offset_to_path_root(void)
{ {
cl_assert(git_fs_path_root("non/rooted/path") == -1); cl_assert(git_fs_path_root("non/rooted/path") == -1);
cl_assert(git_fs_path_root("/rooted/path") == 0); cl_assert(git_fs_path_root("/rooted/path") == 0);
...@@ -495,7 +495,7 @@ void test_core_path__12_offset_to_path_root(void) ...@@ -495,7 +495,7 @@ void test_core_path__12_offset_to_path_root(void)
#define NON_EXISTING_FILEPATH "i_hope_i_do_not_exist" #define NON_EXISTING_FILEPATH "i_hope_i_do_not_exist"
void test_core_path__13_cannot_prettify_a_non_existing_file(void) void test_path__13_cannot_prettify_a_non_existing_file(void)
{ {
git_str p = GIT_STR_INIT; git_str p = GIT_STR_INIT;
...@@ -506,7 +506,7 @@ void test_core_path__13_cannot_prettify_a_non_existing_file(void) ...@@ -506,7 +506,7 @@ void test_core_path__13_cannot_prettify_a_non_existing_file(void)
git_str_dispose(&p); git_str_dispose(&p);
} }
void test_core_path__14_apply_relative(void) void test_path__14_apply_relative(void)
{ {
git_str p = GIT_STR_INIT; git_str p = GIT_STR_INIT;
...@@ -575,7 +575,7 @@ static void assert_resolve_relative( ...@@ -575,7 +575,7 @@ static void assert_resolve_relative(
cl_assert_equal_s(expected, buf->ptr); cl_assert_equal_s(expected, buf->ptr);
} }
void test_core_path__15_resolve_relative(void) void test_path__15_resolve_relative(void)
{ {
git_str buf = GIT_STR_INIT; git_str buf = GIT_STR_INIT;
...@@ -663,7 +663,7 @@ void test_core_path__15_resolve_relative(void) ...@@ -663,7 +663,7 @@ void test_core_path__15_resolve_relative(void)
#define assert_common_dirlen(i, p, q) \ #define assert_common_dirlen(i, p, q) \
cl_assert_equal_i((i), git_fs_path_common_dirlen((p), (q))); cl_assert_equal_i((i), git_fs_path_common_dirlen((p), (q)));
void test_core_path__16_resolve_relative(void) void test_path__16_resolve_relative(void)
{ {
assert_common_dirlen(0, "", ""); assert_common_dirlen(0, "", "");
assert_common_dirlen(0, "", "bar.txt"); assert_common_dirlen(0, "", "bar.txt");
...@@ -694,7 +694,7 @@ static void fix_path(git_str *s) ...@@ -694,7 +694,7 @@ static void fix_path(git_str *s)
#endif #endif
} }
void test_core_path__find_exe_in_path(void) void test_path__find_exe_in_path(void)
{ {
char *orig_path; char *orig_path;
git_str sandbox_path = GIT_STR_INIT; git_str sandbox_path = GIT_STR_INIT;
......
#include "clar_libgit2.h" #include "clar_libgit2.h"
#include "fs_path.h" #include "fs_path.h"
#include "path.h"
void test_path_core__cleanup(void)
{
cl_git_sandbox_cleanup();
}
static void test_make_relative( static void test_make_relative(
const char *expected_path, const char *expected_path,
...@@ -280,62 +274,6 @@ void test_path_core__isvalid_nt_chars(void) ...@@ -280,62 +274,6 @@ void test_path_core__isvalid_nt_chars(void)
cl_assert_equal_b(false, git_fs_path_is_valid("asdf*bar", GIT_FS_PATH_REJECT_NT_CHARS)); cl_assert_equal_b(false, git_fs_path_is_valid("asdf*bar", GIT_FS_PATH_REJECT_NT_CHARS));
} }
void test_path_core__validate_workdir(void)
{
cl_must_pass(git_path_validate_length(NULL, "/foo/bar"));
cl_must_pass(git_path_validate_length(NULL, "C:\\Foo\\Bar"));
cl_must_pass(git_path_validate_length(NULL, "\\\\?\\C:\\Foo\\Bar"));
cl_must_pass(git_path_validate_length(NULL, "\\\\?\\C:\\Foo\\Bar"));
cl_must_pass(git_path_validate_length(NULL, "\\\\?\\UNC\\server\\C$\\folder"));
#ifdef GIT_WIN32
/*
* In the absence of a repo configuration, 259 character paths
* succeed. >= 260 character paths fail.
*/
cl_must_pass(git_path_validate_length(NULL, "C:\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\ok.txt"));
cl_must_pass(git_path_validate_length(NULL, "C:\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\260.txt"));
cl_must_fail(git_path_validate_length(NULL, "C:\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\longer_than_260.txt"));
/* count characters, not bytes */
cl_must_pass(git_path_validate_length(NULL, "C:\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\\xc2\xa2\xc2\xa2\xc2\xa2\xc2\xa2\xc2\xa2\xc2\xa2\xc2\xa2\xc2\xa2\xc2\xa2\\260.txt"));
cl_must_fail(git_path_validate_length(NULL, "C:\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\\xc2\xa2\xc2\xa2\xc2\xa2\xc2\xa2\xc2\xa2\xc2\xa2\xc2\xa2\xc2\xa2\xc2\xa2\\long.txt"));
#else
cl_must_pass(git_path_validate_length(NULL, "/c/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/ok.txt"));
cl_must_pass(git_path_validate_length(NULL, "/c/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/260.txt"));
cl_must_pass(git_path_validate_length(NULL, "/c/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/longer_than_260.txt"));
cl_must_pass(git_path_validate_length(NULL, "C:\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\\xc2\xa2\xc2\xa2\xc2\xa2\xc2\xa2\xc2\xa2\xc2\xa2\xc2\xa2\xc2\xa2\xc2\xa2\\260.txt"));
cl_must_pass(git_path_validate_length(NULL, "C:\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\aaaaaaaaa\\\xc2\xa2\xc2\xa2\xc2\xa2\xc2\xa2\xc2\xa2\xc2\xa2\xc2\xa2\xc2\xa2\xc2\xa2\\long.txt"));
#endif
}
void test_path_core__validate_workdir_with_core_longpath(void)
{
#ifdef GIT_WIN32
git_repository *repo;
git_config *config;
repo = cl_git_sandbox_init("empty_bare.git");
cl_git_pass(git_repository_open(&repo, "empty_bare.git"));
cl_git_pass(git_repository_config(&config, repo));
/* fail by default */
cl_must_fail(git_path_validate_length(repo, "/c/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/longer_than_260.txt"));
/* set core.longpaths explicitly on */
cl_git_pass(git_config_set_bool(config, "core.longpaths", 1));
cl_must_pass(git_path_validate_length(repo, "/c/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/longer_than_260.txt"));
/* set core.longpaths explicitly off */
cl_git_pass(git_config_set_bool(config, "core.longpaths", 0));
cl_must_fail(git_path_validate_length(repo, "/c/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/aaaaaaaaa/longer_than_260.txt"));
git_config_free(config);
git_repository_free(repo);
#endif
}
static void test_join_unrooted( static void test_join_unrooted(
const char *expected_result, const char *expected_result,
ssize_t expected_rootlen, ssize_t expected_rootlen,
......
#include "clar_libgit2.h"
#include "pool.h"
#include "git2/oid.h"
void test_pool__0(void)
{
int i;
git_pool p;
void *ptr;
git_pool_init(&p, 1);
for (i = 1; i < 10000; i *= 2) {
ptr = git_pool_malloc(&p, i);
cl_assert(ptr != NULL);
cl_assert(git_pool__ptr_in_pool(&p, ptr));
cl_assert(!git_pool__ptr_in_pool(&p, &i));
}
git_pool_clear(&p);
}
void test_pool__1(void)
{
int i;
git_pool p;
git_pool_init(&p, 1);
p.page_size = 4000;
for (i = 2010; i > 0; i--)
cl_assert(git_pool_malloc(&p, i) != NULL);
#ifndef GIT_DEBUG_POOL
/* with fixed page size, allocation must end up with these values */
cl_assert_equal_i(591, git_pool__open_pages(&p));
#endif
git_pool_clear(&p);
git_pool_init(&p, 1);
p.page_size = 4120;
for (i = 2010; i > 0; i--)
cl_assert(git_pool_malloc(&p, i) != NULL);
#ifndef GIT_DEBUG_POOL
/* with fixed page size, allocation must end up with these values */
cl_assert_equal_i(sizeof(void *) == 8 ? 575 : 573, git_pool__open_pages(&p));
#endif
git_pool_clear(&p);
}
void test_pool__strndup_limit(void)
{
git_pool p;
git_pool_init(&p, 1);
/* ensure 64 bit doesn't overflow */
cl_assert(git_pool_strndup(&p, "foo", (size_t)-1) == NULL);
git_pool_clear(&p);
}
...@@ -13,7 +13,7 @@ ...@@ -13,7 +13,7 @@
#include "futils.h" #include "futils.h"
#include "posix.h" #include "posix.h"
void test_core_posix__initialize(void) void test_posix__initialize(void)
{ {
#ifdef GIT_WIN32 #ifdef GIT_WIN32
/* on win32, the WSA context needs to be initialized /* on win32, the WSA context needs to be initialized
...@@ -35,7 +35,7 @@ static bool supports_ipv6(void) ...@@ -35,7 +35,7 @@ static bool supports_ipv6(void)
#endif #endif
} }
void test_core_posix__inet_pton(void) void test_posix__inet_pton(void)
{ {
struct in_addr addr; struct in_addr addr;
struct in6_addr addr6; struct in6_addr addr6;
...@@ -96,7 +96,7 @@ void test_core_posix__inet_pton(void) ...@@ -96,7 +96,7 @@ void test_core_posix__inet_pton(void)
cl_assert_equal_i(EAFNOSUPPORT, errno); cl_assert_equal_i(EAFNOSUPPORT, errno);
} }
void test_core_posix__utimes(void) void test_posix__utimes(void)
{ {
struct p_timeval times[2]; struct p_timeval times[2];
struct stat st; struct stat st;
...@@ -145,7 +145,7 @@ void test_core_posix__utimes(void) ...@@ -145,7 +145,7 @@ void test_core_posix__utimes(void)
cl_must_pass(p_unlink("foo")); cl_must_pass(p_unlink("foo"));
} }
void test_core_posix__unlink_removes_symlink(void) void test_posix__unlink_removes_symlink(void)
{ {
if (!git_fs_path_supports_symlinks(clar_sandbox_path())) if (!git_fs_path_supports_symlinks(clar_sandbox_path()))
clar__skip(); clar__skip();
...@@ -166,7 +166,7 @@ void test_core_posix__unlink_removes_symlink(void) ...@@ -166,7 +166,7 @@ void test_core_posix__unlink_removes_symlink(void)
cl_must_pass(p_rmdir("dir")); cl_must_pass(p_rmdir("dir"));
} }
void test_core_posix__symlink_resolves_to_correct_type(void) void test_posix__symlink_resolves_to_correct_type(void)
{ {
git_str contents = GIT_STR_INIT; git_str contents = GIT_STR_INIT;
...@@ -190,7 +190,7 @@ void test_core_posix__symlink_resolves_to_correct_type(void) ...@@ -190,7 +190,7 @@ void test_core_posix__symlink_resolves_to_correct_type(void)
git_str_dispose(&contents); git_str_dispose(&contents);
} }
void test_core_posix__relative_symlink(void) void test_posix__relative_symlink(void)
{ {
git_str contents = GIT_STR_INIT; git_str contents = GIT_STR_INIT;
...@@ -210,7 +210,7 @@ void test_core_posix__relative_symlink(void) ...@@ -210,7 +210,7 @@ void test_core_posix__relative_symlink(void)
git_str_dispose(&contents); git_str_dispose(&contents);
} }
void test_core_posix__symlink_to_file_across_dirs(void) void test_posix__symlink_to_file_across_dirs(void)
{ {
git_str contents = GIT_STR_INIT; git_str contents = GIT_STR_INIT;
......
...@@ -7,7 +7,7 @@ static int cmp_ints(const void *v1, const void *v2) ...@@ -7,7 +7,7 @@ static int cmp_ints(const void *v1, const void *v2)
return (i1 < i2) ? -1 : (i1 > i2) ? 1 : 0; return (i1 < i2) ? -1 : (i1 > i2) ? 1 : 0;
} }
void test_core_pqueue__items_are_put_in_order(void) void test_pqueue__items_are_put_in_order(void)
{ {
git_pqueue pq; git_pqueue pq;
int i, vals[20]; int i, vals[20];
...@@ -36,7 +36,7 @@ void test_core_pqueue__items_are_put_in_order(void) ...@@ -36,7 +36,7 @@ void test_core_pqueue__items_are_put_in_order(void)
git_pqueue_free(&pq); git_pqueue_free(&pq);
} }
void test_core_pqueue__interleave_inserts_and_pops(void) void test_pqueue__interleave_inserts_and_pops(void)
{ {
git_pqueue pq; git_pqueue pq;
int chunk, v, i, vals[200]; int chunk, v, i, vals[200];
...@@ -70,7 +70,7 @@ void test_core_pqueue__interleave_inserts_and_pops(void) ...@@ -70,7 +70,7 @@ void test_core_pqueue__interleave_inserts_and_pops(void)
git_pqueue_free(&pq); git_pqueue_free(&pq);
} }
void test_core_pqueue__max_heap_size(void) void test_pqueue__max_heap_size(void)
{ {
git_pqueue pq; git_pqueue pq;
int i, vals[100]; int i, vals[100];
...@@ -95,7 +95,7 @@ void test_core_pqueue__max_heap_size(void) ...@@ -95,7 +95,7 @@ void test_core_pqueue__max_heap_size(void)
git_pqueue_free(&pq); git_pqueue_free(&pq);
} }
void test_core_pqueue__max_heap_size_without_comparison(void) void test_pqueue__max_heap_size_without_comparison(void)
{ {
git_pqueue pq; git_pqueue pq;
int i, vals[100] = { 0 }; int i, vals[100] = { 0 };
...@@ -123,7 +123,7 @@ static int cmp_ints_like_commit_time(const void *a, const void *b) ...@@ -123,7 +123,7 @@ static int cmp_ints_like_commit_time(const void *a, const void *b)
return *((const int *)a) < *((const int *)b); return *((const int *)a) < *((const int *)b);
} }
void test_core_pqueue__interleaved_pushes_and_pops(void) void test_pqueue__interleaved_pushes_and_pops(void)
{ {
git_pqueue pq; git_pqueue pq;
int i, j, *val; int i, j, *val;
......
#include "precompiled.h"
#include "common.h"
#include "clar.h"
#include "clar_libgit2.h"
...@@ -38,37 +38,37 @@ static int cmp_str(const void *_a, const void *_b, void *payload) ...@@ -38,37 +38,37 @@ static int cmp_str(const void *_a, const void *_b, void *payload)
return strcmp((const char *) _a, (const char *) _b); return strcmp((const char *) _a, (const char *) _b);
} }
void test_core_qsort__array_with_single_entry(void) void test_qsort__array_with_single_entry(void)
{ {
int a[] = { 10 }; int a[] = { 10 };
assert_sorted(a, cmp_int); assert_sorted(a, cmp_int);
} }
void test_core_qsort__array_with_equal_entries(void) void test_qsort__array_with_equal_entries(void)
{ {
int a[] = { 4, 4, 4, 4 }; int a[] = { 4, 4, 4, 4 };
assert_sorted(a, cmp_int); assert_sorted(a, cmp_int);
} }
void test_core_qsort__sorted_array(void) void test_qsort__sorted_array(void)
{ {
int a[] = { 1, 10 }; int a[] = { 1, 10 };
assert_sorted(a, cmp_int); assert_sorted(a, cmp_int);
} }
void test_core_qsort__unsorted_array(void) void test_qsort__unsorted_array(void)
{ {
int a[] = { 123, 9, 412938, 10, 234, 89 }; int a[] = { 123, 9, 412938, 10, 234, 89 };
assert_sorted(a, cmp_int); assert_sorted(a, cmp_int);
} }
void test_core_qsort__sorting_strings(void) void test_qsort__sorting_strings(void)
{ {
char *a[] = { "foo", "bar", "baz" }; char *a[] = { "foo", "bar", "baz" };
assert_sorted(a, cmp_str); assert_sorted(a, cmp_str);
} }
void test_core_qsort__sorting_big_entries(void) void test_qsort__sorting_big_entries(void)
{ {
struct big_entries a[5]; struct big_entries a[5];
......
...@@ -3,7 +3,6 @@ ...@@ -3,7 +3,6 @@
#include <locale.h> #include <locale.h>
#include "regexp.h" #include "regexp.h"
#include "userdiff.h"
#if LC_ALL > 0 #if LC_ALL > 0
static const char *old_locales[LC_ALL]; static const char *old_locales[LC_ALL];
...@@ -11,14 +10,14 @@ static const char *old_locales[LC_ALL]; ...@@ -11,14 +10,14 @@ static const char *old_locales[LC_ALL];
static git_regexp regex; static git_regexp regex;
void test_core_regexp__initialize(void) void test_regexp__initialize(void)
{ {
#if LC_ALL > 0 #if LC_ALL > 0
memset(&old_locales, 0, sizeof(old_locales)); memset(&old_locales, 0, sizeof(old_locales));
#endif #endif
} }
void test_core_regexp__cleanup(void) void test_regexp__cleanup(void)
{ {
git_regexp_dispose(&regex); git_regexp_dispose(&regex);
} }
...@@ -39,13 +38,13 @@ static void try_set_locale(int category) ...@@ -39,13 +38,13 @@ static void try_set_locale(int category)
} }
void test_core_regexp__compile_ignores_global_locale_ctype(void) void test_regexp__compile_ignores_global_locale_ctype(void)
{ {
try_set_locale(LC_CTYPE); try_set_locale(LC_CTYPE);
cl_git_pass(git_regexp_compile(&regex, "[\xc0-\xff][\x80-\xbf]", 0)); cl_git_pass(git_regexp_compile(&regex, "[\xc0-\xff][\x80-\xbf]", 0));
} }
void test_core_regexp__compile_ignores_global_locale_collate(void) void test_regexp__compile_ignores_global_locale_collate(void)
{ {
#ifdef GIT_WIN32 #ifdef GIT_WIN32
cl_skip(); cl_skip();
...@@ -55,7 +54,7 @@ void test_core_regexp__compile_ignores_global_locale_collate(void) ...@@ -55,7 +54,7 @@ void test_core_regexp__compile_ignores_global_locale_collate(void)
cl_git_pass(git_regexp_compile(&regex, "[\xc0-\xff][\x80-\xbf]", 0)); cl_git_pass(git_regexp_compile(&regex, "[\xc0-\xff][\x80-\xbf]", 0));
} }
void test_core_regexp__regex_matches_digits_with_locale(void) void test_regexp__regex_matches_digits_with_locale(void)
{ {
char c, str[2]; char c, str[2];
...@@ -75,7 +74,7 @@ void test_core_regexp__regex_matches_digits_with_locale(void) ...@@ -75,7 +74,7 @@ void test_core_regexp__regex_matches_digits_with_locale(void)
} }
} }
void test_core_regexp__regex_matches_alphabet_with_locale(void) void test_regexp__regex_matches_alphabet_with_locale(void)
{ {
char c, str[2]; char c, str[2];
...@@ -99,40 +98,25 @@ void test_core_regexp__regex_matches_alphabet_with_locale(void) ...@@ -99,40 +98,25 @@ void test_core_regexp__regex_matches_alphabet_with_locale(void)
} }
} }
void test_core_regexp__compile_userdiff_regexps(void) void test_regexp__simple_search_matches(void)
{
size_t idx;
for (idx = 0; idx < ARRAY_SIZE(builtin_defs); ++idx) {
git_diff_driver_definition ddef = builtin_defs[idx];
cl_git_pass(git_regexp_compile(&regex, ddef.fns, ddef.flags));
git_regexp_dispose(&regex);
cl_git_pass(git_regexp_compile(&regex, ddef.words, 0));
git_regexp_dispose(&regex);
}
}
void test_core_regexp__simple_search_matches(void)
{ {
cl_git_pass(git_regexp_compile(&regex, "a", 0)); cl_git_pass(git_regexp_compile(&regex, "a", 0));
cl_git_pass(git_regexp_search(&regex, "a", 0, NULL)); cl_git_pass(git_regexp_search(&regex, "a", 0, NULL));
} }
void test_core_regexp__case_insensitive_search_matches(void) void test_regexp__case_insensitive_search_matches(void)
{ {
cl_git_pass(git_regexp_compile(&regex, "a", GIT_REGEXP_ICASE)); cl_git_pass(git_regexp_compile(&regex, "a", GIT_REGEXP_ICASE));
cl_git_pass(git_regexp_search(&regex, "A", 0, NULL)); cl_git_pass(git_regexp_search(&regex, "A", 0, NULL));
} }
void test_core_regexp__nonmatching_search_returns_error(void) void test_regexp__nonmatching_search_returns_error(void)
{ {
cl_git_pass(git_regexp_compile(&regex, "a", 0)); cl_git_pass(git_regexp_compile(&regex, "a", 0));
cl_git_fail(git_regexp_search(&regex, "b", 0, NULL)); cl_git_fail(git_regexp_search(&regex, "b", 0, NULL));
} }
void test_core_regexp__search_finds_complete_match(void) void test_regexp__search_finds_complete_match(void)
{ {
git_regmatch matches[1]; git_regmatch matches[1];
...@@ -142,7 +126,7 @@ void test_core_regexp__search_finds_complete_match(void) ...@@ -142,7 +126,7 @@ void test_core_regexp__search_finds_complete_match(void)
cl_assert_equal_i(matches[0].end, 3); cl_assert_equal_i(matches[0].end, 3);
} }
void test_core_regexp__search_finds_correct_offsets(void) void test_regexp__search_finds_correct_offsets(void)
{ {
git_regmatch matches[3]; git_regmatch matches[3];
...@@ -156,7 +140,7 @@ void test_core_regexp__search_finds_correct_offsets(void) ...@@ -156,7 +140,7 @@ void test_core_regexp__search_finds_correct_offsets(void)
cl_assert_equal_i(matches[2].end, 2); cl_assert_equal_i(matches[2].end, 2);
} }
void test_core_regexp__search_finds_empty_group(void) void test_regexp__search_finds_empty_group(void)
{ {
git_regmatch matches[3]; git_regmatch matches[3];
...@@ -170,7 +154,7 @@ void test_core_regexp__search_finds_empty_group(void) ...@@ -170,7 +154,7 @@ void test_core_regexp__search_finds_empty_group(void)
cl_assert_equal_i(matches[2].end, 1); cl_assert_equal_i(matches[2].end, 1);
} }
void test_core_regexp__search_fills_matches_with_first_matching_groups(void) void test_regexp__search_fills_matches_with_first_matching_groups(void)
{ {
git_regmatch matches[2]; git_regmatch matches[2];
...@@ -182,7 +166,7 @@ void test_core_regexp__search_fills_matches_with_first_matching_groups(void) ...@@ -182,7 +166,7 @@ void test_core_regexp__search_fills_matches_with_first_matching_groups(void)
cl_assert_equal_i(matches[1].end, 1); cl_assert_equal_i(matches[1].end, 1);
} }
void test_core_regexp__search_skips_nonmatching_group(void) void test_regexp__search_skips_nonmatching_group(void)
{ {
git_regmatch matches[4]; git_regmatch matches[4];
...@@ -198,7 +182,7 @@ void test_core_regexp__search_skips_nonmatching_group(void) ...@@ -198,7 +182,7 @@ void test_core_regexp__search_skips_nonmatching_group(void)
cl_assert_equal_i(matches[3].end, 2); cl_assert_equal_i(matches[3].end, 2);
} }
void test_core_regexp__search_initializes_trailing_nonmatching_groups(void) void test_regexp__search_initializes_trailing_nonmatching_groups(void)
{ {
git_regmatch matches[3]; git_regmatch matches[3];
......
...@@ -3,7 +3,7 @@ ...@@ -3,7 +3,7 @@
static const char *empty_tmp_dir = "test_gitfo_rmdir_recurs_test"; static const char *empty_tmp_dir = "test_gitfo_rmdir_recurs_test";
void test_core_rmdir__initialize(void) void test_rmdir__initialize(void)
{ {
git_str path = GIT_STR_INIT; git_str path = GIT_STR_INIT;
...@@ -27,14 +27,14 @@ void test_core_rmdir__initialize(void) ...@@ -27,14 +27,14 @@ void test_core_rmdir__initialize(void)
git_str_dispose(&path); git_str_dispose(&path);
} }
void test_core_rmdir__cleanup(void) void test_rmdir__cleanup(void)
{ {
if (git_fs_path_exists(empty_tmp_dir)) if (git_fs_path_exists(empty_tmp_dir))
cl_git_pass(git_futils_rmdir_r(empty_tmp_dir, NULL, GIT_RMDIR_REMOVE_FILES)); cl_git_pass(git_futils_rmdir_r(empty_tmp_dir, NULL, GIT_RMDIR_REMOVE_FILES));
} }
/* make sure empty dir can be deleted recursively */ /* make sure empty dir can be deleted recursively */
void test_core_rmdir__delete_recursive(void) void test_rmdir__delete_recursive(void)
{ {
git_str path = GIT_STR_INIT; git_str path = GIT_STR_INIT;
cl_git_pass(git_str_joinpath(&path, empty_tmp_dir, "/one")); cl_git_pass(git_str_joinpath(&path, empty_tmp_dir, "/one"));
...@@ -48,7 +48,7 @@ void test_core_rmdir__delete_recursive(void) ...@@ -48,7 +48,7 @@ void test_core_rmdir__delete_recursive(void)
} }
/* make sure non-empty dir cannot be deleted recursively */ /* make sure non-empty dir cannot be deleted recursively */
void test_core_rmdir__fail_to_delete_non_empty_dir(void) void test_rmdir__fail_to_delete_non_empty_dir(void)
{ {
git_str file = GIT_STR_INIT; git_str file = GIT_STR_INIT;
...@@ -66,13 +66,13 @@ void test_core_rmdir__fail_to_delete_non_empty_dir(void) ...@@ -66,13 +66,13 @@ void test_core_rmdir__fail_to_delete_non_empty_dir(void)
git_str_dispose(&file); git_str_dispose(&file);
} }
void test_core_rmdir__keep_base(void) void test_rmdir__keep_base(void)
{ {
cl_git_pass(git_futils_rmdir_r(empty_tmp_dir, NULL, GIT_RMDIR_SKIP_ROOT)); cl_git_pass(git_futils_rmdir_r(empty_tmp_dir, NULL, GIT_RMDIR_SKIP_ROOT));
cl_assert(git_fs_path_exists(empty_tmp_dir)); cl_assert(git_fs_path_exists(empty_tmp_dir));
} }
void test_core_rmdir__can_skip_non_empty_dir(void) void test_rmdir__can_skip_non_empty_dir(void)
{ {
git_str file = GIT_STR_INIT; git_str file = GIT_STR_INIT;
...@@ -89,7 +89,7 @@ void test_core_rmdir__can_skip_non_empty_dir(void) ...@@ -89,7 +89,7 @@ void test_core_rmdir__can_skip_non_empty_dir(void)
git_str_dispose(&file); git_str_dispose(&file);
} }
void test_core_rmdir__can_remove_empty_parents(void) void test_rmdir__can_remove_empty_parents(void)
{ {
git_str file = GIT_STR_INIT; git_str file = GIT_STR_INIT;
......
...@@ -3,12 +3,12 @@ ...@@ -3,12 +3,12 @@
#define FIXTURE_DIR "sha1" #define FIXTURE_DIR "sha1"
void test_core_sha1__initialize(void) void test_sha1__initialize(void)
{ {
cl_fixture_sandbox(FIXTURE_DIR); cl_fixture_sandbox(FIXTURE_DIR);
} }
void test_core_sha1__cleanup(void) void test_sha1__cleanup(void)
{ {
cl_fixture_cleanup(FIXTURE_DIR); cl_fixture_cleanup(FIXTURE_DIR);
} }
...@@ -37,7 +37,7 @@ static int sha1_file(unsigned char *out, const char *filename) ...@@ -37,7 +37,7 @@ static int sha1_file(unsigned char *out, const char *filename)
return ret; return ret;
} }
void test_core_sha1__sum(void) void test_sha1__sum(void)
{ {
unsigned char expected[GIT_HASH_SHA1_SIZE] = { unsigned char expected[GIT_HASH_SHA1_SIZE] = {
0x4e, 0x72, 0x67, 0x9e, 0x3e, 0xa4, 0xd0, 0x4e, 0x0c, 0x64, 0x4e, 0x72, 0x67, 0x9e, 0x3e, 0xa4, 0xd0, 0x4e, 0x0c, 0x64,
...@@ -50,7 +50,7 @@ void test_core_sha1__sum(void) ...@@ -50,7 +50,7 @@ void test_core_sha1__sum(void)
} }
/* test that sha1 collision detection works when enabled */ /* test that sha1 collision detection works when enabled */
void test_core_sha1__detect_collision_attack(void) void test_sha1__detect_collision_attack(void)
{ {
unsigned char actual[GIT_HASH_SHA1_SIZE]; unsigned char actual[GIT_HASH_SHA1_SIZE];
unsigned char expected[GIT_HASH_SHA1_SIZE] = { unsigned char expected[GIT_HASH_SHA1_SIZE] = {
......
...@@ -6,7 +6,7 @@ static int name_only_cmp(const void *a, const void *b) ...@@ -6,7 +6,7 @@ static int name_only_cmp(const void *a, const void *b)
return strcmp(a, b); return strcmp(a, b);
} }
void test_core_sortedcache__name_only(void) void test_sortedcache__name_only(void)
{ {
git_sortedcache *sc; git_sortedcache *sc;
void *item; void *item;
...@@ -84,7 +84,7 @@ static void sortedcache_test_struct_free(void *payload, void *item_) ...@@ -84,7 +84,7 @@ static void sortedcache_test_struct_free(void *payload, void *item_)
item->smaller_value = 0; item->smaller_value = 0;
} }
void test_core_sortedcache__in_memory(void) void test_sortedcache__in_memory(void)
{ {
git_sortedcache *sc; git_sortedcache *sc;
sortedcache_test_struct *item; sortedcache_test_struct *item;
...@@ -269,7 +269,7 @@ static void sortedcache_test_reload(git_sortedcache *sc) ...@@ -269,7 +269,7 @@ static void sortedcache_test_reload(git_sortedcache *sc)
git_str_dispose(&buf); git_str_dispose(&buf);
} }
void test_core_sortedcache__on_disk(void) void test_sortedcache__on_disk(void)
{ {
git_sortedcache *sc; git_sortedcache *sc;
sortedcache_test_struct *item; sortedcache_test_struct *item;
......
...@@ -2,14 +2,14 @@ ...@@ -2,14 +2,14 @@
#include "futils.h" #include "futils.h"
#include "posix.h" #include "posix.h"
void test_core_stat__initialize(void) void test_stat__initialize(void)
{ {
cl_git_pass(git_futils_mkdir("root/d1/d2", 0755, GIT_MKDIR_PATH)); cl_git_pass(git_futils_mkdir("root/d1/d2", 0755, GIT_MKDIR_PATH));
cl_git_mkfile("root/file", "whatever\n"); cl_git_mkfile("root/file", "whatever\n");
cl_git_mkfile("root/d1/file", "whatever\n"); cl_git_mkfile("root/d1/file", "whatever\n");
} }
void test_core_stat__cleanup(void) void test_stat__cleanup(void)
{ {
git_futils_rmdir_r("root", NULL, GIT_RMDIR_REMOVE_FILES); git_futils_rmdir_r("root", NULL, GIT_RMDIR_REMOVE_FILES);
} }
...@@ -17,7 +17,7 @@ void test_core_stat__cleanup(void) ...@@ -17,7 +17,7 @@ void test_core_stat__cleanup(void)
#define cl_assert_error(val) \ #define cl_assert_error(val) \
do { err = errno; cl_assert_equal_i((val), err); } while (0) do { err = errno; cl_assert_equal_i((val), err); } while (0)
void test_core_stat__0(void) void test_stat__0(void)
{ {
struct stat st; struct stat st;
int err; int err;
...@@ -94,7 +94,7 @@ void test_core_stat__0(void) ...@@ -94,7 +94,7 @@ void test_core_stat__0(void)
cl_assert_error(ENOTDIR); cl_assert_error(ENOTDIR);
} }
void test_core_stat__root(void) void test_stat__root(void)
{ {
const char *sandbox = clar_sandbox_path(); const char *sandbox = clar_sandbox_path();
git_str root = GIT_STR_INIT; git_str root = GIT_STR_INIT;
......
...@@ -25,12 +25,12 @@ void test_str_oom__initialize(void) ...@@ -25,12 +25,12 @@ void test_str_oom__initialize(void)
oom_alloc.gmalloc = oom_malloc; oom_alloc.gmalloc = oom_malloc;
oom_alloc.grealloc = oom_realloc; oom_alloc.grealloc = oom_realloc;
cl_git_pass(git_libgit2_opts(GIT_OPT_SET_ALLOCATOR, &oom_alloc)); cl_git_pass(git_allocator_setup(&oom_alloc));
} }
void test_str_oom__cleanup(void) void test_str_oom__cleanup(void)
{ {
cl_git_pass(git_libgit2_opts(GIT_OPT_SET_ALLOCATOR, NULL)); cl_git_pass(git_allocator_setup(NULL));
} }
void test_str_oom__grow(void) void test_str_oom__grow(void)
......
#include "clar_libgit2.h" #include "clar_libgit2.h"
/* compare prefixes */ /* compare prefixes */
void test_core_string__0(void) void test_string__0(void)
{ {
cl_assert(git__prefixcmp("", "") == 0); cl_assert(git__prefixcmp("", "") == 0);
cl_assert(git__prefixcmp("a", "") == 0); cl_assert(git__prefixcmp("a", "") == 0);
...@@ -14,7 +14,7 @@ void test_core_string__0(void) ...@@ -14,7 +14,7 @@ void test_core_string__0(void)
} }
/* compare suffixes */ /* compare suffixes */
void test_core_string__1(void) void test_string__1(void)
{ {
cl_assert(git__suffixcmp("", "") == 0); cl_assert(git__suffixcmp("", "") == 0);
cl_assert(git__suffixcmp("a", "") == 0); cl_assert(git__suffixcmp("a", "") == 0);
...@@ -27,7 +27,7 @@ void test_core_string__1(void) ...@@ -27,7 +27,7 @@ void test_core_string__1(void)
} }
/* compare icase sorting with case equality */ /* compare icase sorting with case equality */
void test_core_string__2(void) void test_string__2(void)
{ {
cl_assert(git__strcasesort_cmp("", "") == 0); cl_assert(git__strcasesort_cmp("", "") == 0);
cl_assert(git__strcasesort_cmp("foo", "foo") == 0); cl_assert(git__strcasesort_cmp("foo", "foo") == 0);
...@@ -41,7 +41,7 @@ void test_core_string__2(void) ...@@ -41,7 +41,7 @@ void test_core_string__2(void)
} }
/* compare prefixes with len */ /* compare prefixes with len */
void test_core_string__prefixncmp(void) void test_string__prefixncmp(void)
{ {
cl_assert(git__prefixncmp("", 0, "") == 0); cl_assert(git__prefixncmp("", 0, "") == 0);
cl_assert(git__prefixncmp("a", 1, "") == 0); cl_assert(git__prefixncmp("a", 1, "") == 0);
...@@ -58,7 +58,7 @@ void test_core_string__prefixncmp(void) ...@@ -58,7 +58,7 @@ void test_core_string__prefixncmp(void)
} }
/* compare prefixes with len */ /* compare prefixes with len */
void test_core_string__prefixncmp_icase(void) void test_string__prefixncmp_icase(void)
{ {
cl_assert(git__prefixncmp_icase("", 0, "") == 0); cl_assert(git__prefixncmp_icase("", 0, "") == 0);
cl_assert(git__prefixncmp_icase("a", 1, "") == 0); cl_assert(git__prefixncmp_icase("a", 1, "") == 0);
...@@ -82,7 +82,7 @@ void test_core_string__prefixncmp_icase(void) ...@@ -82,7 +82,7 @@ void test_core_string__prefixncmp_icase(void)
cl_assert(git__prefixncmp_icase("ab", 1, "aa") < 0); cl_assert(git__prefixncmp_icase("ab", 1, "aa") < 0);
} }
void test_core_string__strcmp(void) void test_string__strcmp(void)
{ {
cl_assert(git__strcmp("", "") == 0); cl_assert(git__strcmp("", "") == 0);
cl_assert(git__strcmp("foo", "foo") == 0); cl_assert(git__strcmp("foo", "foo") == 0);
...@@ -103,7 +103,7 @@ void test_core_string__strcmp(void) ...@@ -103,7 +103,7 @@ void test_core_string__strcmp(void)
cl_assert(git__strcmp("\303\215", "\303\255") < 0); cl_assert(git__strcmp("\303\215", "\303\255") < 0);
} }
void test_core_string__strcasecmp(void) void test_string__strcasecmp(void)
{ {
cl_assert(git__strcasecmp("", "") == 0); cl_assert(git__strcasecmp("", "") == 0);
cl_assert(git__strcasecmp("foo", "foo") == 0); cl_assert(git__strcasecmp("foo", "foo") == 0);
...@@ -124,7 +124,7 @@ void test_core_string__strcasecmp(void) ...@@ -124,7 +124,7 @@ void test_core_string__strcasecmp(void)
cl_assert(git__strcasecmp("\303\215", "\303\255") < 0); cl_assert(git__strcasecmp("\303\215", "\303\255") < 0);
} }
void test_core_string__strlcmp(void) void test_string__strlcmp(void)
{ {
const char foo[3] = { 'f', 'o', 'o' }; const char foo[3] = { 'f', 'o', 'o' };
......
...@@ -3,18 +3,18 @@ ...@@ -3,18 +3,18 @@
static git_strmap *g_table; static git_strmap *g_table;
void test_core_strmap__initialize(void) void test_strmap__initialize(void)
{ {
cl_git_pass(git_strmap_new(&g_table)); cl_git_pass(git_strmap_new(&g_table));
cl_assert(g_table != NULL); cl_assert(g_table != NULL);
} }
void test_core_strmap__cleanup(void) void test_strmap__cleanup(void)
{ {
git_strmap_free(g_table); git_strmap_free(g_table);
} }
void test_core_strmap__0(void) void test_strmap__0(void)
{ {
cl_assert(git_strmap_size(g_table) == 0); cl_assert(git_strmap_size(g_table) == 0);
} }
...@@ -40,7 +40,7 @@ static void insert_strings(git_strmap *table, size_t count) ...@@ -40,7 +40,7 @@ static void insert_strings(git_strmap *table, size_t count)
cl_assert_equal_i(git_strmap_size(table), count); cl_assert_equal_i(git_strmap_size(table), count);
} }
void test_core_strmap__inserted_strings_can_be_retrieved(void) void test_strmap__inserted_strings_can_be_retrieved(void)
{ {
char *str; char *str;
int i; int i;
...@@ -57,7 +57,7 @@ void test_core_strmap__inserted_strings_can_be_retrieved(void) ...@@ -57,7 +57,7 @@ void test_core_strmap__inserted_strings_can_be_retrieved(void)
cl_assert(i == 20); cl_assert(i == 20);
} }
void test_core_strmap__deleted_entry_cannot_be_retrieved(void) void test_strmap__deleted_entry_cannot_be_retrieved(void)
{ {
char *str; char *str;
int i; int i;
...@@ -77,7 +77,7 @@ void test_core_strmap__deleted_entry_cannot_be_retrieved(void) ...@@ -77,7 +77,7 @@ void test_core_strmap__deleted_entry_cannot_be_retrieved(void)
cl_assert_equal_i(i, 19); cl_assert_equal_i(i, 19);
} }
void test_core_strmap__inserting_many_keys_succeeds(void) void test_strmap__inserting_many_keys_succeeds(void)
{ {
char *str; char *str;
int i; int i;
...@@ -89,7 +89,7 @@ void test_core_strmap__inserting_many_keys_succeeds(void) ...@@ -89,7 +89,7 @@ void test_core_strmap__inserting_many_keys_succeeds(void)
cl_assert_equal_i(i, 10000); cl_assert_equal_i(i, 10000);
} }
void test_core_strmap__get_succeeds_with_existing_entries(void) void test_strmap__get_succeeds_with_existing_entries(void)
{ {
const char *keys[] = { "foo", "bar", "gobble" }; const char *keys[] = { "foo", "bar", "gobble" };
char *values[] = { "oof", "rab", "elbbog" }; char *values[] = { "oof", "rab", "elbbog" };
...@@ -103,7 +103,7 @@ void test_core_strmap__get_succeeds_with_existing_entries(void) ...@@ -103,7 +103,7 @@ void test_core_strmap__get_succeeds_with_existing_entries(void)
cl_assert_equal_s(git_strmap_get(g_table, "gobble"), "elbbog"); cl_assert_equal_s(git_strmap_get(g_table, "gobble"), "elbbog");
} }
void test_core_strmap__get_returns_null_on_nonexisting_key(void) void test_strmap__get_returns_null_on_nonexisting_key(void)
{ {
const char *keys[] = { "foo", "bar", "gobble" }; const char *keys[] = { "foo", "bar", "gobble" };
char *values[] = { "oof", "rab", "elbbog" }; char *values[] = { "oof", "rab", "elbbog" };
...@@ -115,13 +115,13 @@ void test_core_strmap__get_returns_null_on_nonexisting_key(void) ...@@ -115,13 +115,13 @@ void test_core_strmap__get_returns_null_on_nonexisting_key(void)
cl_assert_equal_p(git_strmap_get(g_table, "other"), NULL); cl_assert_equal_p(git_strmap_get(g_table, "other"), NULL);
} }
void test_core_strmap__set_persists_key(void) void test_strmap__set_persists_key(void)
{ {
cl_git_pass(git_strmap_set(g_table, "foo", "oof")); cl_git_pass(git_strmap_set(g_table, "foo", "oof"));
cl_assert_equal_s(git_strmap_get(g_table, "foo"), "oof"); cl_assert_equal_s(git_strmap_get(g_table, "foo"), "oof");
} }
void test_core_strmap__set_persists_multpile_keys(void) void test_strmap__set_persists_multpile_keys(void)
{ {
cl_git_pass(git_strmap_set(g_table, "foo", "oof")); cl_git_pass(git_strmap_set(g_table, "foo", "oof"));
cl_git_pass(git_strmap_set(g_table, "bar", "rab")); cl_git_pass(git_strmap_set(g_table, "bar", "rab"));
...@@ -129,7 +129,7 @@ void test_core_strmap__set_persists_multpile_keys(void) ...@@ -129,7 +129,7 @@ void test_core_strmap__set_persists_multpile_keys(void)
cl_assert_equal_s(git_strmap_get(g_table, "bar"), "rab"); cl_assert_equal_s(git_strmap_get(g_table, "bar"), "rab");
} }
void test_core_strmap__set_updates_existing_key(void) void test_strmap__set_updates_existing_key(void)
{ {
cl_git_pass(git_strmap_set(g_table, "foo", "oof")); cl_git_pass(git_strmap_set(g_table, "foo", "oof"));
cl_git_pass(git_strmap_set(g_table, "bar", "rab")); cl_git_pass(git_strmap_set(g_table, "bar", "rab"));
...@@ -142,7 +142,7 @@ void test_core_strmap__set_updates_existing_key(void) ...@@ -142,7 +142,7 @@ void test_core_strmap__set_updates_existing_key(void)
cl_assert_equal_s(git_strmap_get(g_table, "foo"), "other"); cl_assert_equal_s(git_strmap_get(g_table, "foo"), "other");
} }
void test_core_strmap__iteration(void) void test_strmap__iteration(void)
{ {
struct { struct {
char *key; char *key;
...@@ -182,7 +182,7 @@ void test_core_strmap__iteration(void) ...@@ -182,7 +182,7 @@ void test_core_strmap__iteration(void)
cl_assert_equal_i(n, ARRAY_SIZE(entries)); cl_assert_equal_i(n, ARRAY_SIZE(entries));
} }
void test_core_strmap__iterating_empty_map_stops_immediately(void) void test_strmap__iterating_empty_map_stops_immediately(void)
{ {
size_t i = 0; size_t i = 0;
......
...@@ -26,7 +26,7 @@ static void assert_l64_fails(const char *string, int base) ...@@ -26,7 +26,7 @@ static void assert_l64_fails(const char *string, int base)
cl_git_fail(git__strntol64(&i, string, strlen(string), NULL, base)); cl_git_fail(git__strntol64(&i, string, strlen(string), NULL, base));
} }
void test_core_strtol__int32(void) void test_strtol__int32(void)
{ {
assert_l32_parses("123", 123, 10); assert_l32_parses("123", 123, 10);
assert_l32_parses(" +123 ", 123, 10); assert_l32_parses(" +123 ", 123, 10);
...@@ -43,7 +43,7 @@ void test_core_strtol__int32(void) ...@@ -43,7 +43,7 @@ void test_core_strtol__int32(void)
assert_l32_fails(" -2147483657 ", 10); assert_l32_fails(" -2147483657 ", 10);
} }
void test_core_strtol__int64(void) void test_strtol__int64(void)
{ {
assert_l64_parses("123", 123, 10); assert_l64_parses("123", 123, 10);
assert_l64_parses(" +123 ", 123, 10); assert_l64_parses(" +123 ", 123, 10);
...@@ -66,7 +66,7 @@ void test_core_strtol__int64(void) ...@@ -66,7 +66,7 @@ void test_core_strtol__int64(void)
assert_l64_fails("-0x8000000000000001", 16); assert_l64_fails("-0x8000000000000001", 16);
} }
void test_core_strtol__base_autodetection(void) void test_strtol__base_autodetection(void)
{ {
assert_l64_parses("0", 0, 0); assert_l64_parses("0", 0, 0);
assert_l64_parses("00", 0, 0); assert_l64_parses("00", 0, 0);
...@@ -78,7 +78,7 @@ void test_core_strtol__base_autodetection(void) ...@@ -78,7 +78,7 @@ void test_core_strtol__base_autodetection(void)
assert_l64_parses("0x18", 24, 0); assert_l64_parses("0x18", 24, 0);
} }
void test_core_strtol__buffer_length_with_autodetection_truncates(void) void test_strtol__buffer_length_with_autodetection_truncates(void)
{ {
int64_t i64; int64_t i64;
...@@ -88,7 +88,7 @@ void test_core_strtol__buffer_length_with_autodetection_truncates(void) ...@@ -88,7 +88,7 @@ void test_core_strtol__buffer_length_with_autodetection_truncates(void)
cl_assert_equal_i(i64, 1); cl_assert_equal_i(i64, 1);
} }
void test_core_strtol__buffer_length_truncates(void) void test_strtol__buffer_length_truncates(void)
{ {
int32_t i32; int32_t i32;
int64_t i64; int64_t i64;
...@@ -100,7 +100,7 @@ void test_core_strtol__buffer_length_truncates(void) ...@@ -100,7 +100,7 @@ void test_core_strtol__buffer_length_truncates(void)
cl_assert_equal_i(i64, 1); cl_assert_equal_i(i64, 1);
} }
void test_core_strtol__buffer_length_with_leading_ws_truncates(void) void test_strtol__buffer_length_with_leading_ws_truncates(void)
{ {
int64_t i64; int64_t i64;
...@@ -110,7 +110,7 @@ void test_core_strtol__buffer_length_with_leading_ws_truncates(void) ...@@ -110,7 +110,7 @@ void test_core_strtol__buffer_length_with_leading_ws_truncates(void)
cl_assert_equal_i(i64, 1); cl_assert_equal_i(i64, 1);
} }
void test_core_strtol__buffer_length_with_leading_sign_truncates(void) void test_strtol__buffer_length_with_leading_sign_truncates(void)
{ {
int64_t i64; int64_t i64;
...@@ -120,7 +120,7 @@ void test_core_strtol__buffer_length_with_leading_sign_truncates(void) ...@@ -120,7 +120,7 @@ void test_core_strtol__buffer_length_with_leading_sign_truncates(void)
cl_assert_equal_i(i64, -1); cl_assert_equal_i(i64, -1);
} }
void test_core_strtol__error_message_cuts_off(void) void test_strtol__error_message_cuts_off(void)
{ {
assert_l32_fails("2147483657foobar", 10); assert_l32_fails("2147483657foobar", 10);
cl_assert(strstr(git_error_last()->message, "2147483657") != NULL); cl_assert(strstr(git_error_last()->message, "2147483657") != NULL);
......
#include "clar_libgit2.h" #include "clar_libgit2.h"
#include "utf8.h" #include "utf8.h"
void test_core_utf8__char_length(void) void test_utf8__char_length(void)
{ {
cl_assert_equal_i(0, git_utf8_char_length("", 0)); cl_assert_equal_i(0, git_utf8_char_length("", 0));
cl_assert_equal_i(1, git_utf8_char_length("$", 1)); cl_assert_equal_i(1, git_utf8_char_length("$", 1));
......
...@@ -4,7 +4,7 @@ ...@@ -4,7 +4,7 @@
#include "vector.h" #include "vector.h"
/* initial size of 1 would cause writing past array bounds */ /* initial size of 1 would cause writing past array bounds */
void test_core_vector__0(void) void test_vector__0(void)
{ {
git_vector x; git_vector x;
int i; int i;
...@@ -17,7 +17,7 @@ void test_core_vector__0(void) ...@@ -17,7 +17,7 @@ void test_core_vector__0(void)
/* don't read past array bounds on remove() */ /* don't read past array bounds on remove() */
void test_core_vector__1(void) void test_vector__1(void)
{ {
git_vector x; git_vector x;
/* make initial capacity exact for our insertions. */ /* make initial capacity exact for our insertions. */
...@@ -37,7 +37,7 @@ static int test_cmp(const void *a, const void *b) ...@@ -37,7 +37,7 @@ static int test_cmp(const void *a, const void *b)
} }
/* remove duplicates */ /* remove duplicates */
void test_core_vector__2(void) void test_vector__2(void)
{ {
git_vector x; git_vector x;
int *ptrs[2]; int *ptrs[2];
...@@ -72,7 +72,7 @@ static int compare_them(const void *a, const void *b) ...@@ -72,7 +72,7 @@ static int compare_them(const void *a, const void *b)
} }
/* insert_sorted */ /* insert_sorted */
void test_core_vector__3(void) void test_vector__3(void)
{ {
git_vector x; git_vector x;
intptr_t i; intptr_t i;
...@@ -95,7 +95,7 @@ void test_core_vector__3(void) ...@@ -95,7 +95,7 @@ void test_core_vector__3(void)
} }
/* insert_sorted with duplicates */ /* insert_sorted with duplicates */
void test_core_vector__4(void) void test_vector__4(void)
{ {
git_vector x; git_vector x;
intptr_t i; intptr_t i;
...@@ -158,7 +158,7 @@ static my_struct *alloc_struct(int value) ...@@ -158,7 +158,7 @@ static my_struct *alloc_struct(int value)
} }
/* insert_sorted with duplicates and special handling */ /* insert_sorted with duplicates and special handling */
void test_core_vector__5(void) void test_vector__5(void)
{ {
git_vector x; git_vector x;
int i; int i;
...@@ -199,7 +199,7 @@ static int remove_ones(const git_vector *v, size_t idx, void *p) ...@@ -199,7 +199,7 @@ static int remove_ones(const git_vector *v, size_t idx, void *p)
} }
/* Test removal based on callback */ /* Test removal based on callback */
void test_core_vector__remove_matching(void) void test_vector__remove_matching(void)
{ {
git_vector x; git_vector x;
size_t i; size_t i;
...@@ -287,7 +287,7 @@ static void assert_vector(git_vector *x, void *expected[], size_t len) ...@@ -287,7 +287,7 @@ static void assert_vector(git_vector *x, void *expected[], size_t len)
cl_assert(expected[i] == x->contents[i]); cl_assert(expected[i] == x->contents[i]);
} }
void test_core_vector__grow_and_shrink(void) void test_vector__grow_and_shrink(void)
{ {
git_vector x = GIT_VECTOR_INIT; git_vector x = GIT_VECTOR_INIT;
void *expected1[] = { void *expected1[] = {
...@@ -379,7 +379,7 @@ void test_core_vector__grow_and_shrink(void) ...@@ -379,7 +379,7 @@ void test_core_vector__grow_and_shrink(void)
git_vector_free(&x); git_vector_free(&x);
} }
void test_core_vector__reverse(void) void test_vector__reverse(void)
{ {
git_vector v = GIT_VECTOR_INIT; git_vector v = GIT_VECTOR_INIT;
size_t i; size_t i;
...@@ -410,7 +410,7 @@ void test_core_vector__reverse(void) ...@@ -410,7 +410,7 @@ void test_core_vector__reverse(void)
git_vector_free(&v); git_vector_free(&v);
} }
void test_core_vector__dup_empty_vector(void) void test_vector__dup_empty_vector(void)
{ {
git_vector v = GIT_VECTOR_INIT; git_vector v = GIT_VECTOR_INIT;
git_vector dup = GIT_VECTOR_INIT; git_vector dup = GIT_VECTOR_INIT;
......
...@@ -26,7 +26,7 @@ static void assert_matches_(const char *string, const char *pattern, ...@@ -26,7 +26,7 @@ static void assert_matches_(const char *string, const char *pattern,
* tests for git-ls-files. * tests for git-ls-files.
*/ */
void test_core_wildmatch__basic_wildmatch(void) void test_wildmatch__basic_wildmatch(void)
{ {
assert_matches("foo", "foo", 1, 1, 1, 1); assert_matches("foo", "foo", 1, 1, 1, 1);
assert_matches("foo", "bar", 0, 0, 0, 0); assert_matches("foo", "bar", 0, 0, 0, 0);
...@@ -58,7 +58,7 @@ void test_core_wildmatch__basic_wildmatch(void) ...@@ -58,7 +58,7 @@ void test_core_wildmatch__basic_wildmatch(void)
assert_matches("]", "]", 1, 1, 1, 1); assert_matches("]", "]", 1, 1, 1, 1);
} }
void test_core_wildmatch__slash_matching_features(void) void test_wildmatch__slash_matching_features(void)
{ {
assert_matches("foo/baz/bar", "foo*bar", 0, 0, 1, 1); assert_matches("foo/baz/bar", "foo*bar", 0, 0, 1, 1);
assert_matches("foo/baz/bar", "foo**bar", 0, 0, 1, 1); assert_matches("foo/baz/bar", "foo**bar", 0, 0, 1, 1);
...@@ -90,7 +90,7 @@ void test_core_wildmatch__slash_matching_features(void) ...@@ -90,7 +90,7 @@ void test_core_wildmatch__slash_matching_features(void)
assert_matches("deep/foo/bar/baz/x", "**/bar/*/*", 1, 1, 1, 1); assert_matches("deep/foo/bar/baz/x", "**/bar/*/*", 1, 1, 1, 1);
} }
void test_core_wildmatch__various_additional(void) void test_wildmatch__various_additional(void)
{ {
assert_matches("acrt", "a[c-c]st", 0, 0, 0, 0); assert_matches("acrt", "a[c-c]st", 0, 0, 0, 0);
assert_matches("acrt", "a[c-c]rt", 1, 1, 1, 1); assert_matches("acrt", "a[c-c]rt", 1, 1, 1, 1);
...@@ -115,7 +115,7 @@ void test_core_wildmatch__various_additional(void) ...@@ -115,7 +115,7 @@ void test_core_wildmatch__various_additional(void)
assert_matches("foo/bar/baz/to", "**/t[o]", 1, 1, 1, 1); assert_matches("foo/bar/baz/to", "**/t[o]", 1, 1, 1, 1);
} }
void test_core_wildmatch__character_classes(void) void test_wildmatch__character_classes(void)
{ {
assert_matches("a1B", "[[:alpha:]][[:digit:]][[:upper:]]", 1, 1, 1, 1); assert_matches("a1B", "[[:alpha:]][[:digit:]][[:upper:]]", 1, 1, 1, 1);
assert_matches("a", "[[:digit:][:upper:][:space:]]", 0, 1, 0, 1); assert_matches("a", "[[:digit:][:upper:][:space:]]", 0, 1, 0, 1);
...@@ -136,7 +136,7 @@ void test_core_wildmatch__character_classes(void) ...@@ -136,7 +136,7 @@ void test_core_wildmatch__character_classes(void)
assert_matches("q", "[a-c[:digit:]x-z]", 0, 0, 0, 0); assert_matches("q", "[a-c[:digit:]x-z]", 0, 0, 0, 0);
} }
void test_core_wildmatch__additional_with_malformed(void) void test_wildmatch__additional_with_malformed(void)
{ {
assert_matches("]", "[\\\\-^]", 1, 1, 1, 1); assert_matches("]", "[\\\\-^]", 1, 1, 1, 1);
assert_matches("[", "[\\\\-^]", 0, 0, 0, 0); assert_matches("[", "[\\\\-^]", 0, 0, 0, 0);
...@@ -190,7 +190,7 @@ void test_core_wildmatch__additional_with_malformed(void) ...@@ -190,7 +190,7 @@ void test_core_wildmatch__additional_with_malformed(void)
assert_matches("-", "[[-\\]]", 0, 0, 0, 0); assert_matches("-", "[[-\\]]", 0, 0, 0, 0);
} }
void test_core_wildmatch__recursion(void) void test_wildmatch__recursion(void)
{ {
assert_matches("-adobe-courier-bold-o-normal--12-120-75-75-m-70-iso8859-1", "-*-*-*-*-*-*-12-*-*-*-m-*-*-*", 1, 1, 1, 1); assert_matches("-adobe-courier-bold-o-normal--12-120-75-75-m-70-iso8859-1", "-*-*-*-*-*-*-12-*-*-*-m-*-*-*", 1, 1, 1, 1);
assert_matches("-adobe-courier-bold-o-normal--12-120-75-75-X-70-iso8859-1", "-*-*-*-*-*-*-12-*-*-*-m-*-*-*", 0, 0, 0, 0); assert_matches("-adobe-courier-bold-o-normal--12-120-75-75-X-70-iso8859-1", "-*-*-*-*-*-*-12-*-*-*-m-*-*-*", 0, 0, 0, 0);
...@@ -210,7 +210,7 @@ void test_core_wildmatch__recursion(void) ...@@ -210,7 +210,7 @@ void test_core_wildmatch__recursion(void)
assert_matches("ab/cXd/efXg/hi", "**/*X*/**/*i", 1, 1, 1, 1); assert_matches("ab/cXd/efXg/hi", "**/*X*/**/*i", 1, 1, 1, 1);
} }
void test_core_wildmatch__pathmatch(void) void test_wildmatch__pathmatch(void)
{ {
assert_matches("foo", "fo", 0, 0, 0, 0); assert_matches("foo", "fo", 0, 0, 0, 0);
assert_matches("foo/bar", "foo/bar", 1, 1, 1, 1); assert_matches("foo/bar", "foo/bar", 1, 1, 1, 1);
...@@ -229,7 +229,7 @@ void test_core_wildmatch__pathmatch(void) ...@@ -229,7 +229,7 @@ void test_core_wildmatch__pathmatch(void)
assert_matches("ab/cXd/efXg/hi", "*Xg*i", 0, 0, 1, 1); assert_matches("ab/cXd/efXg/hi", "*Xg*i", 0, 0, 1, 1);
} }
void test_core_wildmatch__case_sensitivity(void) void test_wildmatch__case_sensitivity(void)
{ {
assert_matches("a", "[A-Z]", 0, 1, 0, 1); assert_matches("a", "[A-Z]", 0, 1, 0, 1);
assert_matches("A", "[A-Z]", 1, 1, 1, 1); assert_matches("A", "[A-Z]", 1, 1, 1, 1);
......
...@@ -41,7 +41,7 @@ static void assert_zlib_equal_( ...@@ -41,7 +41,7 @@ static void assert_zlib_equal_(
#define assert_zlib_equal(E,EL,C,CL) \ #define assert_zlib_equal(E,EL,C,CL) \
assert_zlib_equal_(E, EL, C, CL, #EL " != " #CL, __FILE__, __func__, (int)__LINE__) assert_zlib_equal_(E, EL, C, CL, #EL " != " #CL, __FILE__, __func__, (int)__LINE__)
void test_core_zstream__basic(void) void test_zstream__basic(void)
{ {
git_zstream z = GIT_ZSTREAM_INIT; git_zstream z = GIT_ZSTREAM_INIT;
char out[128]; char out[128];
...@@ -57,7 +57,7 @@ void test_core_zstream__basic(void) ...@@ -57,7 +57,7 @@ void test_core_zstream__basic(void)
assert_zlib_equal(data, strlen(data) + 1, out, outlen); assert_zlib_equal(data, strlen(data) + 1, out, outlen);
} }
void test_core_zstream__fails_on_trailing_garbage(void) void test_zstream__fails_on_trailing_garbage(void)
{ {
git_str deflated = GIT_STR_INIT, inflated = GIT_STR_INIT; git_str deflated = GIT_STR_INIT, inflated = GIT_STR_INIT;
char i = 0; char i = 0;
...@@ -76,7 +76,7 @@ void test_core_zstream__fails_on_trailing_garbage(void) ...@@ -76,7 +76,7 @@ void test_core_zstream__fails_on_trailing_garbage(void)
git_str_dispose(&inflated); git_str_dispose(&inflated);
} }
void test_core_zstream__buffer(void) void test_zstream__buffer(void)
{ {
git_str out = GIT_STR_INIT; git_str out = GIT_STR_INIT;
cl_git_pass(git_zstream_deflatebuf(&out, data, strlen(data) + 1)); cl_git_pass(git_zstream_deflatebuf(&out, data, strlen(data) + 1));
...@@ -140,7 +140,7 @@ static void compress_and_decompress_input_various_ways(git_str *input) ...@@ -140,7 +140,7 @@ static void compress_and_decompress_input_various_ways(git_str *input)
git__free(fixed); git__free(fixed);
} }
void test_core_zstream__big_data(void) void test_zstream__big_data(void)
{ {
git_str in = GIT_STR_INIT; git_str in = GIT_STR_INIT;
size_t scan, target; size_t scan, target;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment