diff options
| author | nulltoken <emeric.fermas@gmail.com> | 2012-01-25 16:44:21 +0100 |
|---|---|---|
| committer | nulltoken <emeric.fermas@gmail.com> | 2012-01-25 23:05:06 +0100 |
| commit | 5663e61a0658295defd6ef1fd453d91a94a71d45 (patch) | |
| tree | 80c1cae7e2d542305b25f944a7c5ae9810af5b0c /tests-clar/repo/init.c | |
| parent | 9b84447a806911bb93c67533b81f4d121e5ea3f1 (diff) | |
| download | libgit2-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.c | 36 |
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"); +} |
