mirror of
https://git.proxmox.com/git/libgit2
synced 2025-05-06 09:41:04 +00:00

When we pass the path of a repository to `_bypath()`, we should behave like git and stage it as a `_COMMIT` regardless of whether it is registered a a submodule.
49 lines
1.3 KiB
C
49 lines
1.3 KiB
C
#include "clar_libgit2.h"
|
|
#include "repository.h"
|
|
#include "../submodule/submodule_helpers.h"
|
|
|
|
static git_repository *g_repo;
|
|
static git_index *g_idx;
|
|
|
|
void test_index_bypath__initialize(void)
|
|
{
|
|
g_repo = setup_fixture_submod2();
|
|
cl_git_pass(git_repository_index__weakptr(&g_idx, g_repo));
|
|
}
|
|
|
|
void test_index_bypath__cleanup(void)
|
|
{
|
|
g_repo = NULL;
|
|
g_idx = NULL;
|
|
}
|
|
|
|
void test_index_bypath__add_directory(void)
|
|
{
|
|
cl_git_fail_with(GIT_EDIRECTORY, git_index_add_bypath(g_idx, "just_a_dir"));
|
|
}
|
|
|
|
void test_index_bypath__add_submodule(void)
|
|
{
|
|
unsigned int status;
|
|
const char *sm_name = "sm_changed_head";
|
|
|
|
cl_git_pass(git_submodule_status(&status, g_repo, sm_name, 0));
|
|
cl_assert_equal_i(GIT_SUBMODULE_STATUS_WD_MODIFIED, status & GIT_SUBMODULE_STATUS_WD_MODIFIED);
|
|
cl_git_pass(git_index_add_bypath(g_idx, sm_name));
|
|
cl_git_pass(git_submodule_status(&status, g_repo, sm_name, 0));
|
|
cl_assert_equal_i(0, status & GIT_SUBMODULE_STATUS_WD_MODIFIED);
|
|
}
|
|
|
|
void test_index_bypath__add_submodule_unregistered(void)
|
|
{
|
|
const char *sm_name = "not-submodule";
|
|
const char *sm_head = "68e92c611b80ee1ed8f38314ff9577f0d15b2444";
|
|
const git_index_entry *entry;
|
|
|
|
cl_git_pass(git_index_add_bypath(g_idx, sm_name));
|
|
|
|
cl_assert(entry = git_index_get_bypath(g_idx, sm_name, 0));
|
|
cl_assert_equal_s(sm_head, git_oid_tostr_s(&entry->id));
|
|
cl_assert_equal_s(sm_name, entry->path);
|
|
}
|