mirror of
https://git.proxmox.com/git/libgit2
synced 2025-05-05 18:33:28 +00:00
175 lines
5.1 KiB
C
175 lines
5.1 KiB
C
#include "clar_libgit2.h"
|
|
#include "config/config_helpers.h"
|
|
|
|
#include "repository.h"
|
|
|
|
static git_remote *_remote;
|
|
static git_repository *_repo;
|
|
|
|
void test_network_remote_rename__initialize(void)
|
|
{
|
|
_repo = cl_git_sandbox_init("testrepo.git");
|
|
|
|
cl_git_pass(git_remote_load(&_remote, _repo, "test"));
|
|
}
|
|
|
|
void test_network_remote_rename__cleanup(void)
|
|
{
|
|
git_remote_free(_remote);
|
|
_remote = NULL;
|
|
|
|
cl_git_sandbox_cleanup();
|
|
}
|
|
|
|
static int dont_call_me_cb(const char *fetch_refspec, void *payload)
|
|
{
|
|
GIT_UNUSED(fetch_refspec);
|
|
GIT_UNUSED(payload);
|
|
|
|
cl_assert(false);
|
|
|
|
return -1;
|
|
}
|
|
|
|
void test_network_remote_rename__renaming_a_remote_moves_related_configuration_section(void)
|
|
{
|
|
assert_config_entry_existence(_repo, "remote.test.fetch", true);
|
|
assert_config_entry_existence(_repo, "remote.just/renamed.fetch", false);
|
|
|
|
cl_git_pass(git_remote_rename(_remote, "just/renamed", dont_call_me_cb, NULL));
|
|
|
|
assert_config_entry_existence(_repo, "remote.test.fetch", false);
|
|
assert_config_entry_existence(_repo, "remote.just/renamed.fetch", true);
|
|
}
|
|
|
|
void test_network_remote_rename__renaming_a_remote_updates_branch_related_configuration_entries(void)
|
|
{
|
|
assert_config_entry_value(_repo, "branch.master.remote", "test");
|
|
|
|
cl_git_pass(git_remote_rename(_remote, "just/renamed", dont_call_me_cb, NULL));
|
|
|
|
assert_config_entry_value(_repo, "branch.master.remote", "just/renamed");
|
|
}
|
|
|
|
void test_network_remote_rename__renaming_a_remote_updates_default_fetchrefspec(void)
|
|
{
|
|
cl_git_pass(git_remote_rename(_remote, "just/renamed", dont_call_me_cb, NULL));
|
|
|
|
assert_config_entry_value(_repo, "remote.just/renamed.fetch", "+refs/heads/*:refs/remotes/just/renamed/*");
|
|
}
|
|
|
|
void test_network_remote_rename__renaming_a_remote_without_a_fetchrefspec_doesnt_create_one(void)
|
|
{
|
|
git_config *config;
|
|
|
|
git_remote_free(_remote);
|
|
cl_git_pass(git_repository_config__weakptr(&config, _repo));
|
|
cl_git_pass(git_config_delete_entry(config, "remote.test.fetch"));
|
|
|
|
cl_git_pass(git_remote_load(&_remote, _repo, "test"));
|
|
|
|
assert_config_entry_existence(_repo, "remote.test.fetch", false);
|
|
|
|
cl_git_pass(git_remote_rename(_remote, "just/renamed", dont_call_me_cb, NULL));
|
|
|
|
assert_config_entry_existence(_repo, "remote.just/renamed.fetch", false);
|
|
}
|
|
|
|
static int ensure_refspecs(const char* refspec_name, void *payload)
|
|
{
|
|
int i = 0;
|
|
bool found = false;
|
|
const char ** exp = (const char **)payload;
|
|
|
|
while (exp[i]) {
|
|
if (strcmp(exp[i++], refspec_name))
|
|
continue;
|
|
|
|
found = true;
|
|
break;
|
|
}
|
|
|
|
cl_assert(found);
|
|
|
|
return 0;
|
|
}
|
|
|
|
void test_network_remote_rename__renaming_a_remote_notifies_of_non_default_fetchrefspec(void)
|
|
{
|
|
git_config *config;
|
|
|
|
char *expected_refspecs[] = {
|
|
"+refs/*:refs/*",
|
|
NULL
|
|
};
|
|
|
|
git_remote_free(_remote);
|
|
cl_git_pass(git_repository_config__weakptr(&config, _repo));
|
|
cl_git_pass(git_config_set_string(config, "remote.test.fetch", "+refs/*:refs/*"));
|
|
cl_git_pass(git_remote_load(&_remote, _repo, "test"));
|
|
|
|
cl_git_pass(git_remote_rename(_remote, "just/renamed", ensure_refspecs, &expected_refspecs));
|
|
|
|
assert_config_entry_value(_repo, "remote.just/renamed.fetch", "+refs/*:refs/*");
|
|
}
|
|
|
|
void test_network_remote_rename__new_name_can_contain_dots(void)
|
|
{
|
|
cl_git_pass(git_remote_rename(_remote, "just.renamed", dont_call_me_cb, NULL));
|
|
cl_assert_equal_s("just.renamed", git_remote_name(_remote));
|
|
}
|
|
|
|
void test_network_remote_rename__new_name_must_conform_to_reference_naming_conventions(void)
|
|
{
|
|
cl_assert_equal_i(
|
|
GIT_EINVALIDSPEC,
|
|
git_remote_rename(_remote, "new@{name", dont_call_me_cb, NULL));
|
|
}
|
|
|
|
void test_network_remote_rename__renamed_name_is_persisted(void)
|
|
{
|
|
git_remote *renamed;
|
|
git_repository *another_repo;
|
|
|
|
cl_git_fail(git_remote_load(&renamed, _repo, "just/renamed"));
|
|
|
|
cl_git_pass(git_remote_rename(_remote, "just/renamed", dont_call_me_cb, NULL));
|
|
|
|
cl_git_pass(git_repository_open(&another_repo, "testrepo.git"));
|
|
cl_git_pass(git_remote_load(&renamed, _repo, "just/renamed"));
|
|
|
|
git_remote_free(renamed);
|
|
git_repository_free(another_repo);
|
|
}
|
|
|
|
void test_network_remote_rename__cannot_overwrite_an_existing_remote(void)
|
|
{
|
|
cl_assert_equal_i(GIT_EEXISTS, git_remote_rename(_remote, "test", dont_call_me_cb, NULL));
|
|
cl_assert_equal_i(GIT_EEXISTS, git_remote_rename(_remote, "test_with_pushurl", dont_call_me_cb, NULL));
|
|
}
|
|
|
|
void test_network_remote_rename__renaming_a_remote_moves_the_underlying_reference(void)
|
|
{
|
|
git_reference *underlying;
|
|
|
|
cl_assert_equal_i(GIT_ENOTFOUND, git_reference_lookup(&underlying, _repo, "refs/remotes/just/renamed"));
|
|
cl_git_pass(git_reference_lookup(&underlying, _repo, "refs/remotes/test/master"));
|
|
git_reference_free(underlying);
|
|
|
|
cl_git_pass(git_remote_rename(_remote, "just/renamed", dont_call_me_cb, NULL));
|
|
|
|
cl_assert_equal_i(GIT_ENOTFOUND, git_reference_lookup(&underlying, _repo, "refs/remotes/test/master"));
|
|
cl_git_pass(git_reference_lookup(&underlying, _repo, "refs/remotes/just/renamed/master"));
|
|
git_reference_free(underlying);
|
|
}
|
|
|
|
void test_network_remote_rename__cannot_rename_an_inmemory_remote(void)
|
|
{
|
|
git_remote *remote;
|
|
|
|
cl_git_pass(git_remote_create_inmemory(&remote, _repo, NULL, "file:///blah"));
|
|
cl_git_fail(git_remote_rename(remote, "newname", NULL, NULL));
|
|
|
|
git_remote_free(remote);
|
|
}
|