2 * This file is free software; you can redistribute it and/or modify
3 * it under the terms of the GNU General Public License, version 2,
4 * as published by the Free Software Foundation.
6 * In addition to the permissions in the GNU General Public License,
7 * the authors give you unlimited permission to link the compiled
8 * version of this file into combinations with other programs,
9 * and to distribute those combinations without any restriction
10 * coming from the use of this file. (The General Public License
11 * restrictions do apply in other respects; for example, they cover
12 * modification of the file, and distribution when not linked into
13 * a combined executable.)
15 * This file is distributed in the hope that it will be useful, but
16 * WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
18 * General Public License for more details.
20 * You should have received a copy of the GNU General Public License
21 * along with this program; see the file COPYING. If not, write to
22 * the Free Software Foundation, 51 Franklin Street, Fifth Floor,
23 * Boston, MA 02110-1301, USA.
26 #include "test_helpers.h"
29 #include "git2/odb_backend.h"
30 #include "repository.h"
37 git_odb_backend
*new_backend(int position
)
41 b
= git__malloc(sizeof(fake_backend
));
45 memset(b
, 0x0, sizeof(fake_backend
));
46 b
->position
= position
;
47 return (git_odb_backend
*)b
;
50 int test_backend_sorting(git_odb
*odb
)
54 for (i
= 0; i
< odb
->backends
.length
; ++i
) {
55 fake_backend
*internal
= *((fake_backend
**)git_vector_get(&odb
->backends
, i
));
60 if (internal
->position
!= (int)i
)
67 BEGIN_TEST(odb0
, "assure that ODB backends are properly sorted")
69 must_pass(git_odb_new(&odb
));
70 must_pass(git_odb_add_backend(odb
, new_backend(0), 5));
71 must_pass(git_odb_add_backend(odb
, new_backend(2), 3));
72 must_pass(git_odb_add_backend(odb
, new_backend(1), 4));
73 must_pass(git_odb_add_backend(odb
, new_backend(3), 1));
74 must_pass(test_backend_sorting(odb
));
78 BEGIN_TEST(odb1
, "assure that alternate backends are properly sorted")
80 must_pass(git_odb_new(&odb
));
81 must_pass(git_odb_add_backend(odb
, new_backend(0), 5));
82 must_pass(git_odb_add_backend(odb
, new_backend(2), 3));
83 must_pass(git_odb_add_backend(odb
, new_backend(1), 4));
84 must_pass(git_odb_add_backend(odb
, new_backend(3), 1));
85 must_pass(git_odb_add_alternate(odb
, new_backend(4), 5));
86 must_pass(git_odb_add_alternate(odb
, new_backend(6), 3));
87 must_pass(git_odb_add_alternate(odb
, new_backend(5), 4));
88 must_pass(git_odb_add_alternate(odb
, new_backend(7), 1));
89 must_pass(test_backend_sorting(odb
));
94 #define STANDARD_REPOSITORY 0
95 #define BARE_REPOSITORY 1
97 static int ensure_repository_init(
98 const char *working_directory
,
100 const char *expected_path_index
,
101 const char *expected_path_repository
,
102 const char *expected_working_directory
)
104 char path_odb
[GIT_PATH_MAX
];
105 git_repository
*repo
;
107 if (gitfo_isdir(working_directory
) == GIT_SUCCESS
)
110 git__joinpath(path_odb
, expected_path_repository
, GIT_OBJECTS_DIR
);
112 if (git_repository_init(&repo
, working_directory
, repository_kind
) < GIT_SUCCESS
)
115 if (repo
->path_workdir
!= NULL
|| expected_working_directory
!= NULL
) {
116 if (git__suffixcmp(repo
->path_workdir
, expected_working_directory
) != 0)
120 if (git__suffixcmp(repo
->path_odb
, path_odb
) != 0)
123 if (git__suffixcmp(repo
->path_repository
, expected_path_repository
) != 0)
126 if (repo
->path_index
!= NULL
|| expected_path_index
!= NULL
) {
127 if (git__suffixcmp(repo
->path_index
, expected_path_index
) != 0)
130 if (git_repository_is_bare(repo
) == 1)
132 } else if (git_repository_is_bare(repo
) == 0)
135 if (git_repository_is_empty(repo
) == 0)
138 git_repository_free(repo
);
139 rmdir_recurs(working_directory
);
144 git_repository_free(repo
);
145 rmdir_recurs(working_directory
);
149 BEGIN_TEST(init0
, "initialize a standard repo")
150 char path_index
[GIT_PATH_MAX
], path_repository
[GIT_PATH_MAX
];
152 git__joinpath(path_repository
, TEMP_REPO_FOLDER
, GIT_DIR
);
153 git__joinpath(path_index
, path_repository
, GIT_INDEX_FILE
);
155 must_pass(ensure_repository_init(TEMP_REPO_FOLDER
, STANDARD_REPOSITORY
, path_index
, path_repository
, TEMP_REPO_FOLDER
));
156 must_pass(ensure_repository_init(TEMP_REPO_FOLDER_NS
, STANDARD_REPOSITORY
, path_index
, path_repository
, TEMP_REPO_FOLDER
));
159 BEGIN_TEST(init1
, "initialize a bare repo")
160 char path_repository
[GIT_PATH_MAX
];
162 git__joinpath(path_repository
, TEMP_REPO_FOLDER
, "");
164 must_pass(ensure_repository_init(TEMP_REPO_FOLDER
, BARE_REPOSITORY
, NULL
, path_repository
, NULL
));
165 must_pass(ensure_repository_init(TEMP_REPO_FOLDER_NS
, BARE_REPOSITORY
, NULL
, path_repository
, NULL
));
168 BEGIN_TEST(init2
, "Initialize and open a bare repo with a relative path escaping out of the current working directory")
169 char path_repository
[GIT_PATH_MAX
];
170 char current_workdir
[GIT_PATH_MAX
];
171 const int mode
= 0755; /* or 0777 ? */
172 git_repository
* repo
;
174 must_pass(gitfo_getcwd(current_workdir
, sizeof(current_workdir
)));
176 git__joinpath(path_repository
, TEMP_REPO_FOLDER
, "a/b/c/");
177 must_pass(gitfo_mkdir_recurs(path_repository
, mode
));
179 must_pass(chdir(path_repository
));
181 must_pass(git_repository_init(&repo
, "../d/e.git", 1));
182 must_pass(git__suffixcmp(repo
->path_repository
, "/a/b/d/e.git/"));
184 git_repository_free(repo
);
186 must_pass(git_repository_open(&repo
, "../d/e.git"));
188 git_repository_free(repo
);
190 must_pass(chdir(current_workdir
));
191 rmdir_recurs(TEMP_REPO_FOLDER
);
194 #define EMPTY_BARE_REPOSITORY_NAME "empty_bare.git"
195 #define EMPTY_BARE_REPOSITORY_FOLDER TEST_RESOURCES "/" EMPTY_BARE_REPOSITORY_NAME "/"
197 BEGIN_TEST(open0
, "Open a bare repository that has just been initialized by git")
198 git_repository
*repo
;
200 must_pass(copydir_recurs(EMPTY_BARE_REPOSITORY_FOLDER
, TEMP_REPO_FOLDER
));
201 must_pass(remove_placeholders(TEMP_REPO_FOLDER
, "dummy-marker.txt"));
203 must_pass(git_repository_open(&repo
, TEMP_REPO_FOLDER
));
204 must_be_true(git_repository_path(repo
) != NULL
);
205 must_be_true(git_repository_workdir(repo
) == NULL
);
207 git_repository_free(repo
);
208 must_pass(rmdir_recurs(TEMP_REPO_FOLDER
));
211 #define SOURCE_EMPTY_REPOSITORY_NAME "empty_standard_repo/.gitted"
212 #define EMPTY_REPOSITORY_NAME "empty_standard_repo/.git"
213 #define EMPTY_REPOSITORY_FOLDER TEST_RESOURCES "/" SOURCE_EMPTY_REPOSITORY_NAME "/"
214 #define DEST_REPOSITORY_FOLDER TEMP_REPO_FOLDER DOT_GIT "/"
216 BEGIN_TEST(open1
, "Open a standard repository that has just been initialized by git")
217 git_repository
*repo
;
219 must_pass(copydir_recurs(EMPTY_REPOSITORY_FOLDER
, DEST_REPOSITORY_FOLDER
));
220 must_pass(remove_placeholders(DEST_REPOSITORY_FOLDER
, "dummy-marker.txt"));
222 must_pass(git_repository_open(&repo
, DEST_REPOSITORY_FOLDER
));
223 must_be_true(git_repository_path(repo
) != NULL
);
224 must_be_true(git_repository_workdir(repo
) != NULL
);
226 git_repository_free(repo
);
227 must_pass(rmdir_recurs(TEMP_REPO_FOLDER
));
231 BEGIN_TEST(open2
, "Open a bare repository with a relative path escaping out of the current working directory")
232 char new_current_workdir
[GIT_PATH_MAX
];
233 char current_workdir
[GIT_PATH_MAX
];
234 char path_repository
[GIT_PATH_MAX
];
236 const int mode
= 0755; /* or 0777 ? */
237 git_repository
* repo
;
239 /* Setup the repository to open */
240 must_pass(gitfo_getcwd(current_workdir
, sizeof(current_workdir
)));
241 strcpy(path_repository
, current_workdir
);
242 git__joinpath_n(path_repository
, 3, path_repository
, TEMP_REPO_FOLDER
, "a/d/e.git");
243 must_pass(copydir_recurs(REPOSITORY_FOLDER
, path_repository
));
245 /* Change the current working directory */
246 git__joinpath(new_current_workdir
, TEMP_REPO_FOLDER
, "a/b/c/");
247 must_pass(gitfo_mkdir_recurs(new_current_workdir
, mode
));
248 must_pass(chdir(new_current_workdir
));
250 must_pass(git_repository_open(&repo
, "../../d/e.git"));
252 git_repository_free(repo
);
254 must_pass(chdir(current_workdir
));
255 rmdir_recurs(TEMP_REPO_FOLDER
);
258 BEGIN_TEST(empty0
, "test if a repository is empty or not")
260 git_repository
*repo_empty
, *repo_normal
;
262 must_pass(git_repository_open(&repo_normal
, REPOSITORY_FOLDER
));
263 must_be_true(git_repository_is_empty(repo_normal
) == 0);
264 git_repository_free(repo_normal
);
266 must_pass(git_repository_open(&repo_empty
, EMPTY_BARE_REPOSITORY_FOLDER
));
267 must_be_true(git_repository_is_empty(repo_empty
) == 1);
268 git_repository_free(repo_empty
);
271 BEGIN_SUITE(repository
)