Blame tests/config/rename.c

Packit ae9e2a
#include "clar_libgit2.h"
Packit ae9e2a
#include "config.h"
Packit ae9e2a
Packit ae9e2a
static git_repository *g_repo = NULL;
Packit ae9e2a
static git_config *g_config = NULL;
Packit ae9e2a
Packit ae9e2a
void test_config_rename__initialize(void)
Packit ae9e2a
{
Packit ae9e2a
    g_repo = cl_git_sandbox_init("testrepo.git");
Packit ae9e2a
	cl_git_pass(git_repository_config(&g_config, g_repo));
Packit ae9e2a
}
Packit ae9e2a
Packit ae9e2a
void test_config_rename__cleanup(void)
Packit ae9e2a
{
Packit ae9e2a
	git_config_free(g_config);
Packit ae9e2a
	g_config = NULL;
Packit ae9e2a
Packit ae9e2a
	cl_git_sandbox_cleanup();
Packit ae9e2a
	g_repo = NULL;
Packit ae9e2a
}
Packit ae9e2a
Packit ae9e2a
void test_config_rename__can_rename(void)
Packit ae9e2a
{
Packit ae9e2a
	git_config_entry *ce;
Packit ae9e2a
Packit ae9e2a
	cl_git_pass(git_config_get_entry(
Packit ae9e2a
		&ce, g_config, "branch.track-local.remote"));
Packit ae9e2a
	cl_assert_equal_s(".", ce->value);
Packit ae9e2a
	git_config_entry_free(ce);
Packit ae9e2a
Packit ae9e2a
	cl_git_fail(git_config_get_entry(
Packit ae9e2a
		&ce, g_config, "branch.local-track.remote"));
Packit ae9e2a
Packit ae9e2a
	cl_git_pass(git_config_rename_section(
Packit ae9e2a
		g_repo, "branch.track-local", "branch.local-track"));
Packit ae9e2a
Packit ae9e2a
	cl_git_pass(git_config_get_entry(
Packit ae9e2a
		&ce, g_config, "branch.local-track.remote"));
Packit ae9e2a
	cl_assert_equal_s(".", ce->value);
Packit ae9e2a
	git_config_entry_free(ce);
Packit ae9e2a
Packit ae9e2a
	cl_git_fail(git_config_get_entry(
Packit ae9e2a
		&ce, g_config, "branch.track-local.remote"));
Packit ae9e2a
}
Packit ae9e2a
Packit ae9e2a
void test_config_rename__prevent_overwrite(void)
Packit ae9e2a
{
Packit ae9e2a
	git_config_entry *ce;
Packit ae9e2a
Packit ae9e2a
	cl_git_pass(git_config_set_string(
Packit ae9e2a
		g_config, "branch.local-track.remote", "yellow"));
Packit ae9e2a
Packit ae9e2a
	cl_git_pass(git_config_get_entry(
Packit ae9e2a
		&ce, g_config, "branch.local-track.remote"));
Packit ae9e2a
	cl_assert_equal_s("yellow", ce->value);
Packit ae9e2a
	git_config_entry_free(ce);
Packit ae9e2a
Packit ae9e2a
	cl_git_pass(git_config_rename_section(
Packit ae9e2a
		g_repo, "branch.track-local", "branch.local-track"));
Packit ae9e2a
Packit ae9e2a
	cl_git_pass(git_config_get_entry(
Packit ae9e2a
		&ce, g_config, "branch.local-track.remote"));
Packit ae9e2a
	cl_assert_equal_s(".", ce->value);
Packit ae9e2a
	git_config_entry_free(ce);
Packit ae9e2a
Packit ae9e2a
	/* so, we don't currently prevent overwrite... */
Packit ae9e2a
	/* {
Packit ae9e2a
		const git_error *err;
Packit ae9e2a
		cl_assert((err = giterr_last()) != NULL);
Packit ae9e2a
		cl_assert(err->message != NULL);
Packit ae9e2a
	} */
Packit ae9e2a
}
Packit ae9e2a
Packit ae9e2a
static void assert_invalid_config_section_name(
Packit ae9e2a
	git_repository *repo, const char *name)
Packit ae9e2a
{
Packit ae9e2a
	cl_git_fail_with(
Packit ae9e2a
		git_config_rename_section(repo, "branch.remoteless", name),
Packit ae9e2a
		GIT_EINVALIDSPEC);
Packit ae9e2a
}
Packit ae9e2a
Packit ae9e2a
void test_config_rename__require_a_valid_new_name(void)
Packit ae9e2a
{
Packit ae9e2a
	assert_invalid_config_section_name(g_repo, "");
Packit ae9e2a
	assert_invalid_config_section_name(g_repo, "bra\nch");
Packit ae9e2a
	assert_invalid_config_section_name(g_repo, "branc#");
Packit ae9e2a
	assert_invalid_config_section_name(g_repo, "bra\nch.duh");
Packit ae9e2a
	assert_invalid_config_section_name(g_repo, "branc#.duh");
Packit ae9e2a
}