summaryrefslogtreecommitdiff
path: root/tests-clay/repo/open.c
blob: 05b01ceb29af9a82f1b4f0388dffefa1a7d4098a (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
#include "clay_libgit2.h"
#include "posix.h"

void test_repo_open__bare_empty_repo(void)
{
	git_repository *repo;

	cl_git_pass(git_repository_open(&repo, cl_fixture("empty_bare.git")));
	cl_assert(git_repository_path(repo) != NULL);
	cl_assert(git_repository_workdir(repo) == NULL);

	git_repository_free(repo);
}

void test_repo_open__standard_empty_repo(void)
{
	git_repository *repo;

	cl_git_pass(git_repository_open(&repo, cl_fixture("empty_standard_repo/.gitted")));
	cl_assert(git_repository_path(repo) != NULL);
	cl_assert(git_repository_workdir(repo) != NULL);

	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