Commit 9b84447a by nulltoken

clay: migrate a test initializing a repository which path escapes the current working directory

A non migrated yet test has been removed as well as it's mostly redundant.
parent 911ff94e
#include "clar_libgit2.h" #include "clar_libgit2.h"
#include "fileops.h" #include "fileops.h"
#include "repository.h"
enum repo_mode { enum repo_mode {
STANDARD_REPOSITORY = 0, STANDARD_REPOSITORY = 0,
...@@ -75,32 +76,32 @@ void test_repo_init__bare_repo_noslash(void) ...@@ -75,32 +76,32 @@ void test_repo_init__bare_repo_noslash(void)
ensure_repository_init("testrepo.git", 1, "testrepo.git/", NULL); ensure_repository_init("testrepo.git", 1, "testrepo.git/", NULL);
} }
#if 0 void test_repo_init__bare_repo_escaping_current_workdir(void)
BEGIN_TEST(init2, "Initialize and open a bare repo with a relative path escaping out of the current working directory") {
git_buf path_repository = GIT_BUF_INIT; git_buf path_repository = GIT_BUF_INIT;
char current_workdir[GIT_PATH_MAX]; git_buf path_current_workdir = GIT_BUF_INIT;
const mode_t mode = 0777;
git_repository* repo;
must_pass(p_getcwd(current_workdir, sizeof(current_workdir))); cl_git_pass(git_path_prettify_dir(&path_current_workdir, ".", NULL));
must_pass(git_buf_joinpath(&path_repository, TEMP_REPO_FOLDER, "a/b/c/")); cl_git_pass(git_buf_joinpath(&path_repository, git_buf_cstr(&path_current_workdir), "a/b/c"));
must_pass(git_futils_mkdir_r(path_repository.ptr, mode)); cl_git_pass(git_futils_mkdir_r(git_buf_cstr(&path_repository), NULL, GIT_DIR_MODE));
must_pass(chdir(path_repository.ptr)); /* Change the current working directory */
cl_git_pass(chdir(git_buf_cstr(&path_repository)));
git_buf_free(&path_repository); /* Initialize a bare repo with a relative path escaping out of the current working directory */
cl_git_pass(git_repository_init(&_repo, "../d/e.git", 1));
cl_git_pass(git__suffixcmp(git_repository_path(_repo), "/a/b/d/e.git/"));
must_pass(git_repository_init(&repo, "../d/e.git", 1)); git_repository_free(_repo);
must_pass(git__suffixcmp(git_repository_path(_repo), "/a/b/d/e.git/"));
git_repository_free(repo); /* Open a bare repo with a relative path escaping out of the current working directory */
cl_git_pass(git_repository_open(&_repo, "../d/e.git"));
must_pass(git_repository_open(&repo, "../d/e.git")); cl_git_pass(chdir(git_buf_cstr(&path_current_workdir)));
git_repository_free(repo); git_buf_free(&path_current_workdir);
git_buf_free(&path_repository);
must_pass(chdir(current_workdir)); cleanup_repository("a");
must_pass(git_futils_rmdir_r(TEMP_REPO_FOLDER, 1)); }
END_TEST
#endif
...@@ -22,34 +22,3 @@ void test_repo_open__standard_empty_repo(void) ...@@ -22,34 +22,3 @@ void test_repo_open__standard_empty_repo(void)
git_repository_free(repo); git_repository_free(repo);
} }
/* TODO TODO */
#if 0
BEGIN_TEST(open2, "Open a bare repository with a relative path escaping out of the current working directory")
char current_workdir[GIT_PATH_MAX];
git_buf new_current_workdir = GIT_BUF_INIT;
git_buf path_repository = GIT_BUF_INIT;
const mode_t mode = 0777;
git_repository* repo;
/* Setup the repository to open */
must_pass(p_getcwd(current_workdir, sizeof(current_workdir)));
must_pass(git_buf_join_n(&path_repository, 3, current_workdir, TEMP_REPO_FOLDER, "a/d/e.git"));
must_pass(copydir_recurs(REPOSITORY_FOLDER, path_repository.ptr));
git_buf_free(&path_repository);
/* Change the current working directory */
must_pass(git_buf_joinpath(&new_current_workdir, TEMP_REPO_FOLDER, "a/b/c/"));
must_pass(git_futils_mkdir_r(new_current_workdir.ptr, mode));
must_pass(chdir(new_current_workdir.ptr));
git_buf_free(&new_current_workdir);
must_pass(git_repository_open(&repo, "../../d/e.git"));
git_repository_free(repo);
must_pass(chdir(current_workdir));
must_pass(git_futils_rmdir_r(TEMP_REPO_FOLDER, 1));
END_TEST
#endif
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