Commit c44b9170 by Carlos Martín Nieto

tests: resolve the real path for the sandbox in includeIf tests

We put our repository in the temporary directory which makes macOS map the path
into a virtual path. `realpath(3)` can resolve it and we do so during repository
opening, but that makes its path have a different prefix from the sandbox path
clar thinks we have.

Resolve the sandbox path before putting it into the test config files so the
paths match as expected.
parent f7d837c8
...@@ -50,6 +50,7 @@ static void assert_condition_includes(const char *keyword, const char *path, boo ...@@ -50,6 +50,7 @@ static void assert_condition_includes(const char *keyword, const char *path, boo
void test_config_conditionals__gitdir(void) void test_config_conditionals__gitdir(void)
{ {
git_buf path = GIT_BUF_INIT; git_buf path = GIT_BUF_INIT;
char *sandbox_path;
assert_condition_includes("gitdir", ROOT_PREFIX "/", true); assert_condition_includes("gitdir", ROOT_PREFIX "/", true);
assert_condition_includes("gitdir", "empty_standard_repo", true); assert_condition_includes("gitdir", "empty_standard_repo", true);
...@@ -61,31 +62,38 @@ void test_config_conditionals__gitdir(void) ...@@ -61,31 +62,38 @@ void test_config_conditionals__gitdir(void)
assert_condition_includes("gitdir", "empty_stand", false); assert_condition_includes("gitdir", "empty_stand", false);
assert_condition_includes("gitdir", "~/empty_standard_repo", false); assert_condition_includes("gitdir", "~/empty_standard_repo", false);
git_buf_joinpath(&path, clar_sandbox_path(), "/"); sandbox_path = p_realpath(clar_sandbox_path(), NULL);
git_buf_joinpath(&path, sandbox_path, "/");
assert_condition_includes("gitdir", path.ptr, true); assert_condition_includes("gitdir", path.ptr, true);
git_buf_joinpath(&path, clar_sandbox_path(), "/*"); git_buf_joinpath(&path, sandbox_path, "/*");
assert_condition_includes("gitdir", path.ptr, true); assert_condition_includes("gitdir", path.ptr, true);
git_buf_joinpath(&path, clar_sandbox_path(), "empty_standard_repo"); git_buf_joinpath(&path, sandbox_path, "empty_standard_repo");
assert_condition_includes("gitdir", path.ptr, true); assert_condition_includes("gitdir", path.ptr, true);
git_buf_joinpath(&path, clar_sandbox_path(), "Empty_Standard_Repo"); git_buf_joinpath(&path, sandbox_path, "Empty_Standard_Repo");
assert_condition_includes("gitdir", path.ptr, false); assert_condition_includes("gitdir", path.ptr, false);
git__free(sandbox_path);
git_buf_free(&path); git_buf_free(&path);
} }
void test_config_conditionals__gitdir_i(void) void test_config_conditionals__gitdir_i(void)
{ {
git_buf path = GIT_BUF_INIT; git_buf path = GIT_BUF_INIT;
char *sandbox_path;
sandbox_path = p_realpath(clar_sandbox_path(), NULL);
git_buf_joinpath(&path, clar_sandbox_path(), "empty_standard_repo"); git_buf_joinpath(&path, sandbox_path, "empty_standard_repo");
assert_condition_includes("gitdir/i", path.ptr, true); assert_condition_includes("gitdir/i", path.ptr, true);
git_buf_joinpath(&path, clar_sandbox_path(), "EMPTY_STANDARD_REPO"); git_buf_joinpath(&path, sandbox_path, "EMPTY_STANDARD_REPO");
assert_condition_includes("gitdir/i", path.ptr, true); assert_condition_includes("gitdir/i", path.ptr, true);
git__free(sandbox_path);
git_buf_free(&path); git_buf_free(&path);
} }
......
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