names.c 4.48 KB
Newer Older
Edward Thomson committed
1 2
#include "clar_libgit2.h"
#include "index.h"
3
#include "git2/sys/index.h"
Edward Thomson committed
4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23
#include "git2/repository.h"
#include "../reset/reset_helpers.h"

static git_repository *repo;
static git_index *repo_index;

#define TEST_REPO_PATH "mergedrepo"
#define TEST_INDEX_PATH TEST_REPO_PATH "/.git/index"

// Fixture setup and teardown
void test_index_names__initialize(void)
{
	repo = cl_git_sandbox_init("mergedrepo");
	git_repository_index(&repo_index, repo);
}

void test_index_names__cleanup(void)
{
	git_index_free(repo_index);
	repo_index = NULL;
nulltoken committed
24

Edward Thomson committed
25 26 27 28 29 30 31 32 33 34
	cl_git_sandbox_cleanup();
}

void test_index_names__add(void)
{
	const git_index_name_entry *conflict_name;

	cl_git_pass(git_index_name_add(repo_index, "ancestor", "ours", "theirs"));
	cl_git_pass(git_index_name_add(repo_index, "ancestor2", "ours2", NULL));
	cl_git_pass(git_index_name_add(repo_index, "ancestor3", NULL, "theirs3"));
nulltoken committed
35

Edward Thomson committed
36
	cl_assert(git_index_name_entrycount(repo_index) == 3);
nulltoken committed
37

Edward Thomson committed
38 39 40 41
	conflict_name = git_index_name_get_byindex(repo_index, 0);
	cl_assert(strcmp(conflict_name->ancestor, "ancestor") == 0);
	cl_assert(strcmp(conflict_name->ours, "ours") == 0);
	cl_assert(strcmp(conflict_name->theirs, "theirs") == 0);
nulltoken committed
42

Edward Thomson committed
43 44 45 46 47 48 49 50 51 52 53 54 55 56
	conflict_name = git_index_name_get_byindex(repo_index, 1);
	cl_assert(strcmp(conflict_name->ancestor, "ancestor2") == 0);
	cl_assert(strcmp(conflict_name->ours, "ours2") == 0);
	cl_assert(conflict_name->theirs == NULL);

	conflict_name = git_index_name_get_byindex(repo_index, 2);
	cl_assert(strcmp(conflict_name->ancestor, "ancestor3") == 0);
	cl_assert(conflict_name->ours == NULL);
	cl_assert(strcmp(conflict_name->theirs, "theirs3") == 0);
}

void test_index_names__roundtrip(void)
{
	const git_index_name_entry *conflict_name;
nulltoken committed
57

Edward Thomson committed
58 59 60
	cl_git_pass(git_index_name_add(repo_index, "ancestor", "ours", "theirs"));
	cl_git_pass(git_index_name_add(repo_index, "ancestor2", "ours2", NULL));
	cl_git_pass(git_index_name_add(repo_index, "ancestor3", NULL, "theirs3"));
nulltoken committed
61

Edward Thomson committed
62 63 64
	cl_git_pass(git_index_write(repo_index));
	git_index_clear(repo_index);
	cl_assert(git_index_name_entrycount(repo_index) == 0);
nulltoken committed
65

66
	cl_git_pass(git_index_read(repo_index, true));
Edward Thomson committed
67
	cl_assert(git_index_name_entrycount(repo_index) == 3);
nulltoken committed
68

Edward Thomson committed
69 70 71 72
	conflict_name = git_index_name_get_byindex(repo_index, 0);
	cl_assert(strcmp(conflict_name->ancestor, "ancestor") == 0);
	cl_assert(strcmp(conflict_name->ours, "ours") == 0);
	cl_assert(strcmp(conflict_name->theirs, "theirs") == 0);
nulltoken committed
73

Edward Thomson committed
74 75 76 77
	conflict_name = git_index_name_get_byindex(repo_index, 1);
	cl_assert(strcmp(conflict_name->ancestor, "ancestor2") == 0);
	cl_assert(strcmp(conflict_name->ours, "ours2") == 0);
	cl_assert(conflict_name->theirs == NULL);
nulltoken committed
78

Edward Thomson committed
79 80 81 82
	conflict_name = git_index_name_get_byindex(repo_index, 2);
	cl_assert(strcmp(conflict_name->ancestor, "ancestor3") == 0);
	cl_assert(conflict_name->ours == NULL);
	cl_assert(strcmp(conflict_name->theirs, "theirs3") == 0);
83 84 85 86 87 88
}

void test_index_names__cleaned_on_reset_hard(void)
{
	git_object *target;

89
	cl_git_pass(git_revparse_single(&target, repo, "3a34580"));
90 91

	test_index_names__add();
92
	cl_git_pass(git_reset(repo, target, GIT_RESET_HARD, NULL, NULL));
93 94 95 96 97 98 99 100 101
	cl_assert(git_index_name_entrycount(repo_index) == 0);

	git_object_free(target);
}

void test_index_names__cleaned_on_reset_mixed(void)
{
	git_object *target;

102
	cl_git_pass(git_revparse_single(&target, repo, "3a34580"));
103 104

	test_index_names__add();
105
	cl_git_pass(git_reset(repo, target, GIT_RESET_MIXED, NULL, NULL));
106 107 108 109 110 111 112 113 114
	cl_assert(git_index_name_entrycount(repo_index) == 0);

	git_object_free(target);
}

void test_index_names__cleaned_on_checkout_tree(void)
{
	git_oid oid;
	git_object *obj;
115
	git_checkout_options opts = GIT_CHECKOUT_OPTIONS_INIT;
116 117 118 119 120 121 122

	opts.checkout_strategy = GIT_CHECKOUT_SAFE | GIT_CHECKOUT_UPDATE_ONLY;

	test_index_names__add();
	git_reference_name_to_id(&oid, repo, "refs/heads/master");
	git_object_lookup(&obj, repo, &oid, GIT_OBJ_ANY);
	git_checkout_tree(repo, obj, &opts);
123
	cl_assert_equal_sz(0, git_index_name_entrycount(repo_index));
124 125 126 127 128 129

	git_object_free(obj);
}

void test_index_names__cleaned_on_checkout_head(void)
{
130
	git_checkout_options opts = GIT_CHECKOUT_OPTIONS_INIT;
131 132 133 134 135

	opts.checkout_strategy = GIT_CHECKOUT_SAFE | GIT_CHECKOUT_UPDATE_ONLY;

	test_index_names__add();
	git_checkout_head(repo, &opts);
136
	cl_assert_equal_sz(0, git_index_name_entrycount(repo_index));
137 138 139 140
}

void test_index_names__retained_on_checkout_index(void)
{
141
	git_checkout_options opts = GIT_CHECKOUT_OPTIONS_INIT;
142 143

	opts.checkout_strategy = GIT_CHECKOUT_SAFE | GIT_CHECKOUT_UPDATE_ONLY;
nulltoken committed
144

145 146 147
	test_index_names__add();
	git_checkout_index(repo, repo_index, &opts);
	cl_assert(git_index_name_entrycount(repo_index) > 0);
Edward Thomson committed
148
}