summaryrefslogtreecommitdiff
path: root/tests-clar/repo/init.c
diff options
context:
space:
mode:
authornulltoken <emeric.fermas@gmail.com>2012-01-25 16:44:21 +0100
committernulltoken <emeric.fermas@gmail.com>2012-01-25 23:05:06 +0100
commit5663e61a0658295defd6ef1fd453d91a94a71d45 (patch)
tree80c1cae7e2d542305b25f944a7c5ae9810af5b0c /tests-clar/repo/init.c
parent9b84447a806911bb93c67533b81f4d121e5ea3f1 (diff)
downloadlibgit2-5663e61a0658295defd6ef1fd453d91a94a71d45.tar.gz
repository: add minimal reinitialization of repository
This currently only ensures that the version of the repository format isn't greater than zero.
Diffstat (limited to 'tests-clar/repo/init.c')
-rw-r--r--tests-clar/repo/init.c36
1 files changed, 36 insertions, 0 deletions
diff --git a/tests-clar/repo/init.c b/tests-clar/repo/init.c
index 7e0a94568..a12a2c2fb 100644
--- a/tests-clar/repo/init.c
+++ b/tests-clar/repo/init.c
@@ -1,6 +1,7 @@
#include "clar_libgit2.h"
#include "fileops.h"
#include "repository.h"
+#include "config.h"
enum repo_mode {
STANDARD_REPOSITORY = 0,
@@ -105,3 +106,38 @@ void test_repo_init__bare_repo_escaping_current_workdir(void)
cleanup_repository("a");
}
+
+void test_repo_init__reinit_bare_repo(void)
+{
+ cl_set_cleanup(&cleanup_repository, "reinit.git");
+
+ /* Initialize the repository */
+ cl_git_pass(git_repository_init(&_repo, "reinit.git", 1));
+ git_repository_free(_repo);
+
+ /* Reinitialize the repository */
+ cl_git_pass(git_repository_init(&_repo, "reinit.git", 1));
+}
+
+void test_repo_init__reinit_too_recent_bare_repo(void)
+{
+ git_config *config;
+
+ /* Initialize the repository */
+ cl_git_pass(git_repository_init(&_repo, "reinit.git", 1));
+ git_repository_config(&config, _repo);
+
+ /*
+ * Hack the config of the repository to make it look like it has
+ * been created by a recenter version of git/libgit2
+ */
+ cl_git_pass(git_config_set_int32(config, "core.repositoryformatversion", 42));
+
+ git_config_free(config);
+ git_repository_free(_repo);
+
+ /* Try to reinitialize the repository */
+ cl_git_fail(git_repository_init(&_repo, "reinit.git", 1));
+
+ cl_fixture_cleanup("reinit.git");
+}