setter.c 2.92 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27
#include "clar_libgit2.h"

#include "repository.h"
#include "git2/reflog.h"
#include "reflog.h"
#include "git2/refs.h"

static const char *ref_name = "refs/heads/other";
static const char *ref_master_name = "refs/heads/master";
static const char *ref_test_name = "refs/heads/test";

static git_repository *g_repo;

void test_refs_setter__initialize(void)
{
	g_repo = cl_git_sandbox_init("testrepo");
}

void test_refs_setter__cleanup(void)
{
	cl_git_sandbox_cleanup();
}

void test_refs_setter__update_direct(void)
{
	git_reference *ref, *test_ref, *new_ref;
	git_oid id;
nulltoken committed
28

29 30 31 32 33 34 35 36
	cl_git_pass(git_reference_lookup(&ref, g_repo, ref_master_name));
	cl_assert(git_reference_type(ref) == GIT_REF_OID);
	git_oid_cpy(&id, git_reference_target(ref));
	git_reference_free(ref);

	cl_git_pass(git_reference_lookup(&test_ref, g_repo, ref_test_name));
	cl_assert(git_reference_type(test_ref) == GIT_REF_OID);

37
	cl_git_pass(git_reference_set_target(&new_ref, test_ref, &id, NULL, NULL));
38 39 40 41 42 43

	git_reference_free(test_ref);
	git_reference_free(new_ref);

	cl_git_pass(git_reference_lookup(&test_ref, g_repo, ref_test_name));
	cl_assert(git_reference_type(test_ref) == GIT_REF_OID);
44
	cl_assert_equal_oid(&id, git_reference_target(test_ref));
45 46 47 48 49 50
	git_reference_free(test_ref);
}

void test_refs_setter__update_symbolic(void)
{
	git_reference *head, *new_head;
nulltoken committed
51

52 53 54 55
	cl_git_pass(git_reference_lookup(&head, g_repo, "HEAD"));
	cl_assert(git_reference_type(head) == GIT_REF_SYMBOLIC);
	cl_assert(strcmp(git_reference_symbolic_target(head), ref_master_name) == 0);

56
	cl_git_pass(git_reference_symbolic_set_target(&new_head, head, ref_test_name, NULL, NULL));
57 58
	git_reference_free(new_head);
	git_reference_free(head);
nulltoken committed
59

60 61 62 63 64 65 66 67 68 69 70
	cl_git_pass(git_reference_lookup(&head, g_repo, "HEAD"));
	cl_assert(git_reference_type(head) == GIT_REF_SYMBOLIC);
	cl_assert(strcmp(git_reference_symbolic_target(head), ref_test_name) == 0);
	git_reference_free(head);
}

void test_refs_setter__cant_update_direct_with_symbolic(void)
{
	// Overwrite an existing object id reference with a symbolic one
	git_reference *ref, *new;
	git_oid id;
nulltoken committed
71

72 73 74
	cl_git_pass(git_reference_lookup(&ref, g_repo, ref_master_name));
	cl_assert(git_reference_type(ref) == GIT_REF_OID);
	git_oid_cpy(&id, git_reference_target(ref));
nulltoken committed
75

76
	cl_git_fail(git_reference_symbolic_set_target(&new, ref, ref_name, NULL, NULL));
nulltoken committed
77

78 79 80 81 82 83 84 85
	git_reference_free(ref);
}

void test_refs_setter__cant_update_symbolic_with_direct(void)
{
	// Overwrite an existing symbolic reference with an object id one
	git_reference *ref, *new;
	git_oid id;
nulltoken committed
86

87 88 89 90 91 92
	cl_git_pass(git_reference_lookup(&ref, g_repo, ref_master_name));
	cl_assert(git_reference_type(ref) == GIT_REF_OID);
	git_oid_cpy(&id, git_reference_target(ref));
	git_reference_free(ref);

	/* Create the symbolic ref */
93
	cl_git_pass(git_reference_symbolic_create(&ref, g_repo, ref_name, ref_master_name, 0, NULL, NULL));
94 95

	/* Can't set an OID on a direct ref */
96
	cl_git_fail(git_reference_set_target(&new, ref, &id, NULL, NULL));
nulltoken committed
97

98 99
	git_reference_free(ref);
}