|
Packit |
ae9e2a |
#include "clar_libgit2.h"
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
#include "repository.h"
|
|
Packit |
ae9e2a |
#include "git2/reflog.h"
|
|
Packit |
ae9e2a |
#include "reflog.h"
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
static const char *ref_name = "refs/heads/other";
|
|
Packit |
ae9e2a |
static const char *ref_master_name = "refs/heads/master";
|
|
Packit |
ae9e2a |
static const char *ref_branch_name = "refs/heads/branch";
|
|
Packit |
ae9e2a |
static const char *ref_test_name = "refs/heads/test";
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
static git_repository *g_repo;
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
void test_refs_overwrite__initialize(void)
|
|
Packit |
ae9e2a |
{
|
|
Packit |
ae9e2a |
g_repo = cl_git_sandbox_init("testrepo");
|
|
Packit |
ae9e2a |
}
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
void test_refs_overwrite__cleanup(void)
|
|
Packit |
ae9e2a |
{
|
|
Packit |
ae9e2a |
cl_git_sandbox_cleanup();
|
|
Packit |
ae9e2a |
}
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
void test_refs_overwrite__symbolic(void)
|
|
Packit |
ae9e2a |
{
|
|
Packit |
ae9e2a |
// Overwrite an existing symbolic reference
|
|
Packit |
ae9e2a |
git_reference *ref, *branch_ref;
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
/* The target needds to exist and we need to check the name has changed */
|
|
Packit |
ae9e2a |
cl_git_pass(git_reference_symbolic_create(&branch_ref, g_repo, ref_branch_name, ref_master_name, 0, NULL));
|
|
Packit |
ae9e2a |
cl_git_pass(git_reference_symbolic_create(&ref, g_repo, ref_name, ref_branch_name, 0, NULL));
|
|
Packit |
ae9e2a |
git_reference_free(ref);
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
/* Ensure it points to the right place*/
|
|
Packit |
ae9e2a |
cl_git_pass(git_reference_lookup(&ref, g_repo, ref_name));
|
|
Packit |
ae9e2a |
cl_assert(git_reference_type(ref) & GIT_REF_SYMBOLIC);
|
|
Packit |
ae9e2a |
cl_assert_equal_s(git_reference_symbolic_target(ref), ref_branch_name);
|
|
Packit |
ae9e2a |
git_reference_free(ref);
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
/* Ensure we can't create it unless we force it to */
|
|
Packit |
ae9e2a |
cl_git_fail(git_reference_symbolic_create(&ref, g_repo, ref_name, ref_master_name, 0, NULL));
|
|
Packit |
ae9e2a |
cl_git_pass(git_reference_symbolic_create(&ref, g_repo, ref_name, ref_master_name, 1, NULL));
|
|
Packit |
ae9e2a |
git_reference_free(ref);
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
/* Ensure it points to the right place */
|
|
Packit |
ae9e2a |
cl_git_pass(git_reference_lookup(&ref, g_repo, ref_name));
|
|
Packit |
ae9e2a |
cl_assert(git_reference_type(ref) & GIT_REF_SYMBOLIC);
|
|
Packit |
ae9e2a |
cl_assert_equal_s(git_reference_symbolic_target(ref), ref_master_name);
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
git_reference_free(ref);
|
|
Packit |
ae9e2a |
git_reference_free(branch_ref);
|
|
Packit |
ae9e2a |
}
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
void test_refs_overwrite__object_id(void)
|
|
Packit |
ae9e2a |
{
|
|
Packit |
ae9e2a |
// Overwrite an existing object id reference
|
|
Packit |
ae9e2a |
git_reference *ref;
|
|
Packit |
ae9e2a |
git_oid id;
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
cl_git_pass(git_reference_lookup(&ref, g_repo, ref_master_name));
|
|
Packit |
ae9e2a |
cl_assert(git_reference_type(ref) & GIT_REF_OID);
|
|
Packit |
ae9e2a |
git_oid_cpy(&id, git_reference_target(ref));
|
|
Packit |
ae9e2a |
git_reference_free(ref);
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
/* Create it */
|
|
Packit |
ae9e2a |
cl_git_pass(git_reference_create(&ref, g_repo, ref_name, &id, 0, NULL));
|
|
Packit |
ae9e2a |
git_reference_free(ref);
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
cl_git_pass(git_reference_lookup(&ref, g_repo, ref_test_name));
|
|
Packit |
ae9e2a |
cl_assert(git_reference_type(ref) & GIT_REF_OID);
|
|
Packit |
ae9e2a |
git_oid_cpy(&id, git_reference_target(ref));
|
|
Packit |
ae9e2a |
git_reference_free(ref);
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
/* Ensure we can't overwrite unless we force it */
|
|
Packit |
ae9e2a |
cl_git_fail(git_reference_create(&ref, g_repo, ref_name, &id, 0, NULL));
|
|
Packit |
ae9e2a |
cl_git_pass(git_reference_create(&ref, g_repo, ref_name, &id, 1, NULL));
|
|
Packit |
ae9e2a |
git_reference_free(ref);
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
/* Ensure it has been overwritten */
|
|
Packit |
ae9e2a |
cl_git_pass(git_reference_lookup(&ref, g_repo, ref_name));
|
|
Packit |
ae9e2a |
cl_assert_equal_oid(&id, git_reference_target(ref));
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
git_reference_free(ref);
|
|
Packit |
ae9e2a |
}
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
void test_refs_overwrite__object_id_with_symbolic(void)
|
|
Packit |
ae9e2a |
{
|
|
Packit |
ae9e2a |
// Overwrite an existing object id reference with a symbolic one
|
|
Packit |
ae9e2a |
git_reference *ref;
|
|
Packit |
ae9e2a |
git_oid id;
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
cl_git_pass(git_reference_lookup(&ref, g_repo, ref_master_name));
|
|
Packit |
ae9e2a |
cl_assert(git_reference_type(ref) & GIT_REF_OID);
|
|
Packit |
ae9e2a |
git_oid_cpy(&id, git_reference_target(ref));
|
|
Packit |
ae9e2a |
git_reference_free(ref);
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
cl_git_pass(git_reference_create(&ref, g_repo, ref_name, &id, 0, NULL));
|
|
Packit |
ae9e2a |
git_reference_free(ref);
|
|
Packit |
ae9e2a |
cl_git_fail(git_reference_symbolic_create(&ref, g_repo, ref_name, ref_master_name, 0, NULL));
|
|
Packit |
ae9e2a |
cl_git_pass(git_reference_symbolic_create(&ref, g_repo, ref_name, ref_master_name, 1, NULL));
|
|
Packit |
ae9e2a |
git_reference_free(ref);
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
/* Ensure it points to the right place */
|
|
Packit |
ae9e2a |
cl_git_pass(git_reference_lookup(&ref, g_repo, ref_name));
|
|
Packit |
ae9e2a |
cl_assert(git_reference_type(ref) & GIT_REF_SYMBOLIC);
|
|
Packit |
ae9e2a |
cl_assert_equal_s(git_reference_symbolic_target(ref), ref_master_name);
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
git_reference_free(ref);
|
|
Packit |
ae9e2a |
}
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
void test_refs_overwrite__symbolic_with_object_id(void)
|
|
Packit |
ae9e2a |
{
|
|
Packit |
ae9e2a |
// Overwrite an existing symbolic reference with an object id one
|
|
Packit |
ae9e2a |
git_reference *ref;
|
|
Packit |
ae9e2a |
git_oid id;
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
cl_git_pass(git_reference_lookup(&ref, g_repo, ref_master_name));
|
|
Packit |
ae9e2a |
cl_assert(git_reference_type(ref) & GIT_REF_OID);
|
|
Packit |
ae9e2a |
git_oid_cpy(&id, git_reference_target(ref));
|
|
Packit |
ae9e2a |
git_reference_free(ref);
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
/* Create the symbolic ref */
|
|
Packit |
ae9e2a |
cl_git_pass(git_reference_symbolic_create(&ref, g_repo, ref_name, ref_master_name, 0, NULL));
|
|
Packit |
ae9e2a |
git_reference_free(ref);
|
|
Packit |
ae9e2a |
/* It shouldn't overwrite unless we tell it to */
|
|
Packit |
ae9e2a |
cl_git_fail(git_reference_create(&ref, g_repo, ref_name, &id, 0, NULL));
|
|
Packit |
ae9e2a |
cl_git_pass(git_reference_create(&ref, g_repo, ref_name, &id, 1, NULL));
|
|
Packit |
ae9e2a |
git_reference_free(ref);
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
/* Ensure it points to the right place */
|
|
Packit |
ae9e2a |
cl_git_pass(git_reference_lookup(&ref, g_repo, ref_name));
|
|
Packit |
ae9e2a |
cl_assert(git_reference_type(ref) & GIT_REF_OID);
|
|
Packit |
ae9e2a |
cl_assert_equal_oid(&id, git_reference_target(ref));
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
git_reference_free(ref);
|
|
Packit |
ae9e2a |
}
|