Blame tests/submodule/modify.c

Packit Service 20376f
#include "clar_libgit2.h"
Packit Service 20376f
#include "posix.h"
Packit Service 20376f
#include "path.h"
Packit Service 20376f
#include "submodule_helpers.h"
Packit Service 20376f
#include "config/config_helpers.h"
Packit Service 20376f
Packit Service 20376f
static git_repository *g_repo = NULL;
Packit Service 20376f
Packit Service 20376f
#define SM_LIBGIT2_URL    "https://github.com/libgit2/libgit2.git"
Packit Service 20376f
#define SM_LIBGIT2_BRANCH "github-branch"
Packit Service 20376f
#define SM_LIBGIT2        "sm_libgit2"
Packit Service 20376f
Packit Service 20376f
void test_submodule_modify__initialize(void)
Packit Service 20376f
{
Packit Service 20376f
	g_repo = setup_fixture_submod2();
Packit Service 20376f
}
Packit Service 20376f
Packit Service 20376f
static int delete_one_config(const git_config_entry *entry, void *payload)
Packit Service 20376f
{
Packit Service 20376f
	git_config *cfg = payload;
Packit Service 20376f
	return git_config_delete_entry(cfg, entry->name);
Packit Service 20376f
}
Packit Service 20376f
Packit Service 20376f
static int init_one_submodule(
Packit Service 20376f
	git_submodule *sm, const char *name, void *payload)
Packit Service 20376f
{
Packit Service 20376f
	GIT_UNUSED(name);
Packit Service 20376f
	GIT_UNUSED(payload);
Packit Service 20376f
	return git_submodule_init(sm, false);
Packit Service 20376f
}
Packit Service 20376f
Packit Service 20376f
void test_submodule_modify__init(void)
Packit Service 20376f
{
Packit Service 20376f
	git_config *cfg;
Packit Service 20376f
	const char *str;
Packit Service 20376f
Packit Service 20376f
	/* erase submodule data from .git/config */
Packit Service 20376f
	cl_git_pass(git_repository_config(&cfg, g_repo));
Packit Service 20376f
	cl_git_pass(
Packit Service 20376f
		git_config_foreach_match(cfg, "submodule\\..*", delete_one_config, cfg));
Packit Service 20376f
	git_config_free(cfg);
Packit Service 20376f
Packit Service 20376f
	/* confirm no submodule data in config */
Packit Service 20376f
	cl_git_pass(git_repository_config_snapshot(&cfg, g_repo));
Packit Service 20376f
	cl_git_fail_with(GIT_ENOTFOUND, git_config_get_string(&str, cfg, "submodule.sm_unchanged.url"));
Packit Service 20376f
	cl_git_fail_with(GIT_ENOTFOUND, git_config_get_string(&str, cfg, "submodule.sm_changed_head.url"));
Packit Service 20376f
	cl_git_fail_with(GIT_ENOTFOUND, git_config_get_string(&str, cfg, "submodule.sm_added_and_uncommited.url"));
Packit Service 20376f
	git_config_free(cfg);
Packit Service 20376f
Packit Service 20376f
	/* call init and see that settings are copied */
Packit Service 20376f
	cl_git_pass(git_submodule_foreach(g_repo, init_one_submodule, NULL));
Packit Service 20376f
Packit Service 20376f
	/* confirm submodule data in config */
Packit Service 20376f
	cl_git_pass(git_repository_config_snapshot(&cfg, g_repo));
Packit Service 20376f
	cl_git_pass(git_config_get_string(&str, cfg, "submodule.sm_unchanged.url"));
Packit Service 20376f
	cl_assert(git__suffixcmp(str, "/submod2_target") == 0);
Packit Service 20376f
	cl_git_pass(git_config_get_string(&str, cfg, "submodule.sm_changed_head.url"));
Packit Service 20376f
	cl_assert(git__suffixcmp(str, "/submod2_target") == 0);
Packit Service 20376f
	cl_git_pass(git_config_get_string(&str, cfg, "submodule.sm_added_and_uncommited.url"));
Packit Service 20376f
	cl_assert(git__suffixcmp(str, "/submod2_target") == 0);
Packit Service 20376f
	git_config_free(cfg);
Packit Service 20376f
}
Packit Service 20376f
Packit Service 20376f
static int sync_one_submodule(
Packit Service 20376f
	git_submodule *sm, const char *name, void *payload)
Packit Service 20376f
{
Packit Service 20376f
	GIT_UNUSED(name);
Packit Service 20376f
	GIT_UNUSED(payload);
Packit Service 20376f
	return git_submodule_sync(sm);
Packit Service 20376f
}
Packit Service 20376f
Packit Service 20376f
static void assert_submodule_url_is_synced(
Packit Service 20376f
	git_submodule *sm, const char *parent_key, const char *child_key)
Packit Service 20376f
{
Packit Service 20376f
	git_repository *smrepo;
Packit Service 20376f
Packit Service 20376f
	assert_config_entry_value(g_repo, parent_key, git_submodule_url(sm));
Packit Service 20376f
Packit Service 20376f
	cl_git_pass(git_submodule_open(&smrepo, sm));
Packit Service 20376f
	assert_config_entry_value(smrepo, child_key,  git_submodule_url(sm));
Packit Service 20376f
	git_repository_free(smrepo);
Packit Service 20376f
}
Packit Service 20376f
Packit Service 20376f
void test_submodule_modify__sync(void)
Packit Service 20376f
{
Packit Service 20376f
	git_submodule *sm1, *sm2, *sm3;
Packit Service 20376f
	git_config *cfg;
Packit Service 20376f
	const char *str;
Packit Service 20376f
Packit Service 20376f
#define SM1 "sm_unchanged"
Packit Service 20376f
#define SM2 "sm_changed_head"
Packit Service 20376f
#define SM3 "sm_added_and_uncommited"
Packit Service 20376f
Packit Service 20376f
	/* look up some submodules */
Packit Service 20376f
	cl_git_pass(git_submodule_lookup(&sm1, g_repo, SM1));
Packit Service 20376f
	cl_git_pass(git_submodule_lookup(&sm2, g_repo, SM2));
Packit Service 20376f
	cl_git_pass(git_submodule_lookup(&sm3, g_repo, SM3));
Packit Service 20376f
Packit Service 20376f
	/* At this point, the .git/config URLs for the submodules have
Packit Service 20376f
	 * not be rewritten with the absolute paths (although the
Packit Service 20376f
	 * .gitmodules have.  Let's confirm that they DO NOT match
Packit Service 20376f
	 * yet, then we can do a sync to make them match...
Packit Service 20376f
	 */
Packit Service 20376f
Packit Service 20376f
	/* check submodule info does not match before sync */
Packit Service 20376f
	cl_git_pass(git_repository_config_snapshot(&cfg, g_repo));
Packit Service 20376f
	cl_git_pass(git_config_get_string(&str, cfg, "submodule."SM1".url"));
Packit Service 20376f
	cl_assert(strcmp(git_submodule_url(sm1), str) != 0);
Packit Service 20376f
	cl_git_pass(git_config_get_string(&str, cfg, "submodule."SM2".url"));
Packit Service 20376f
	cl_assert(strcmp(git_submodule_url(sm2), str) != 0);
Packit Service 20376f
	cl_git_pass(git_config_get_string(&str, cfg, "submodule."SM3".url"));
Packit Service 20376f
	cl_assert(strcmp(git_submodule_url(sm3), str) != 0);
Packit Service 20376f
	git_config_free(cfg);
Packit Service 20376f
Packit Service 20376f
	/* sync all the submodules */
Packit Service 20376f
	cl_git_pass(git_submodule_foreach(g_repo, sync_one_submodule, NULL));
Packit Service 20376f
Packit Service 20376f
	/* check that submodule config is updated */
Packit Service 20376f
	assert_submodule_url_is_synced(
Packit Service 20376f
		sm1, "submodule."SM1".url", "remote.origin.url");
Packit Service 20376f
	assert_submodule_url_is_synced(
Packit Service 20376f
		sm2, "submodule."SM2".url", "remote.origin.url");
Packit Service 20376f
	assert_submodule_url_is_synced(
Packit Service 20376f
		sm3, "submodule."SM3".url", "remote.origin.url");
Packit Service 20376f
Packit Service 20376f
	git_submodule_free(sm1);
Packit Service 20376f
	git_submodule_free(sm2);
Packit Service 20376f
	git_submodule_free(sm3);
Packit Service 20376f
}
Packit Service 20376f
Packit Service 20376f
void assert_ignore_change(git_submodule_ignore_t ignore)
Packit Service 20376f
{
Packit Service 20376f
	git_submodule *sm;
Packit Service 20376f
Packit Service 20376f
	cl_git_pass(git_submodule_set_ignore(g_repo, "sm_changed_head", ignore));
Packit Service 20376f
Packit Service 20376f
	cl_git_pass(git_submodule_lookup(&sm, g_repo, "sm_changed_head"));
Packit Service 20376f
	cl_assert_equal_i(ignore, git_submodule_ignore(sm));
Packit Service 20376f
	git_submodule_free(sm);
Packit Service 20376f
}
Packit Service 20376f
Packit Service 20376f
void test_submodule_modify__set_ignore(void)
Packit Service 20376f
{
Packit Service 20376f
	assert_ignore_change(GIT_SUBMODULE_IGNORE_UNTRACKED);
Packit Service 20376f
	assert_ignore_change(GIT_SUBMODULE_IGNORE_NONE);
Packit Service 20376f
	assert_ignore_change(GIT_SUBMODULE_IGNORE_ALL);
Packit Service 20376f
}
Packit Service 20376f
Packit Service 20376f
void assert_update_change(git_submodule_update_t update)
Packit Service 20376f
{
Packit Service 20376f
	git_submodule *sm;
Packit Service 20376f
Packit Service 20376f
	cl_git_pass(git_submodule_set_update(g_repo, "sm_changed_head", update));
Packit Service 20376f
Packit Service 20376f
	cl_git_pass(git_submodule_lookup(&sm, g_repo, "sm_changed_head"));
Packit Service 20376f
	cl_assert_equal_i(update, git_submodule_update_strategy(sm));
Packit Service 20376f
	git_submodule_free(sm);
Packit Service 20376f
}
Packit Service 20376f
Packit Service 20376f
void test_submodule_modify__set_update(void)
Packit Service 20376f
{
Packit Service 20376f
	assert_update_change(GIT_SUBMODULE_UPDATE_REBASE);
Packit Service 20376f
	assert_update_change(GIT_SUBMODULE_UPDATE_NONE);
Packit Service 20376f
	assert_update_change(GIT_SUBMODULE_UPDATE_CHECKOUT);
Packit Service 20376f
}
Packit Service 20376f
Packit Service 20376f
void assert_recurse_change(git_submodule_recurse_t recurse)
Packit Service 20376f
{
Packit Service 20376f
	git_submodule *sm;
Packit Service 20376f
Packit Service 20376f
	cl_git_pass(git_submodule_set_fetch_recurse_submodules(g_repo, "sm_changed_head", recurse));
Packit Service 20376f
Packit Service 20376f
	cl_git_pass(git_submodule_lookup(&sm, g_repo, "sm_changed_head"));
Packit Service 20376f
	cl_assert_equal_i(recurse, git_submodule_fetch_recurse_submodules(sm));
Packit Service 20376f
	git_submodule_free(sm);
Packit Service 20376f
}
Packit Service 20376f
Packit Service 20376f
void test_submodule_modify__set_fetch_recurse_submodules(void)
Packit Service 20376f
{
Packit Service 20376f
	assert_recurse_change(GIT_SUBMODULE_RECURSE_YES);
Packit Service 20376f
	assert_recurse_change(GIT_SUBMODULE_RECURSE_NO);
Packit Service 20376f
	assert_recurse_change(GIT_SUBMODULE_RECURSE_ONDEMAND);
Packit Service 20376f
}
Packit Service 20376f
Packit Service 20376f
void test_submodule_modify__set_branch(void)
Packit Service 20376f
{
Packit Service 20376f
	git_submodule *sm;
Packit Service 20376f
Packit Service 20376f
	cl_git_pass(git_submodule_lookup(&sm, g_repo, "sm_changed_head"));
Packit Service 20376f
	cl_assert(git_submodule_branch(sm) == NULL);
Packit Service 20376f
	git_submodule_free(sm);
Packit Service 20376f
Packit Service 20376f
	cl_git_pass(git_submodule_set_branch(g_repo, "sm_changed_head", SM_LIBGIT2_BRANCH));
Packit Service 20376f
	cl_git_pass(git_submodule_lookup(&sm, g_repo, "sm_changed_head"));
Packit Service 20376f
	cl_assert_equal_s(SM_LIBGIT2_BRANCH, git_submodule_branch(sm));
Packit Service 20376f
	git_submodule_free(sm);
Packit Service 20376f
Packit Service 20376f
	cl_git_pass(git_submodule_set_branch(g_repo, "sm_changed_head", NULL));
Packit Service 20376f
	cl_git_pass(git_submodule_lookup(&sm, g_repo, "sm_changed_head"));
Packit Service 20376f
	cl_assert(git_submodule_branch(sm) == NULL);
Packit Service 20376f
	git_submodule_free(sm);
Packit Service 20376f
}
Packit Service 20376f
Packit Service 20376f
void test_submodule_modify__set_url(void)
Packit Service 20376f
{
Packit Service 20376f
	git_submodule *sm;
Packit Service 20376f
Packit Service 20376f
	cl_git_pass(git_submodule_set_url(g_repo, "sm_changed_head", SM_LIBGIT2_URL));
Packit Service 20376f
	cl_git_pass(git_submodule_lookup(&sm, g_repo, "sm_changed_head"));
Packit Service 20376f
	cl_assert_equal_s(SM_LIBGIT2_URL, git_submodule_url(sm));
Packit Service 20376f
	git_submodule_free(sm);
Packit Service 20376f
}