]>
git.proxmox.com Git - libgit2.git/blob - tests/refs/branches/iterator.c
e086681e554f9841216a9fe12b4959e5815f16f1
1 #include "clar_libgit2.h"
4 static git_repository
*repo
;
5 static git_reference
*fake_remote
;
7 void test_refs_branches_iterator__initialize(void)
11 cl_fixture_sandbox("testrepo.git");
12 cl_git_pass(git_repository_open(&repo
, "testrepo.git"));
14 cl_git_pass(git_oid_fromstr(&id
, "be3563ae3f795b2b4353bcce3a527ad0a4f7f644"));
15 cl_git_pass(git_reference_create(&fake_remote
, repo
, "refs/remotes/nulltoken/master", &id
, 0, NULL
));
18 void test_refs_branches_iterator__cleanup(void)
20 git_reference_free(fake_remote
);
23 git_repository_free(repo
);
26 cl_fixture_cleanup("testrepo.git");
28 cl_git_sandbox_cleanup();
31 static void assert_retrieval(unsigned int flags
, unsigned int expected_count
)
33 git_branch_iterator
*iter
;
38 cl_git_pass(git_branch_iterator_new(&iter
, repo
, flags
));
39 while ((error
= git_branch_next(&ref
, &type
, iter
)) == 0) {
41 git_reference_free(ref
);
44 git_branch_iterator_free(iter
);
45 cl_assert_equal_i(error
, GIT_ITEROVER
);
46 cl_assert_equal_i(expected_count
, count
);
49 void test_refs_branches_iterator__retrieve_all_branches(void)
51 assert_retrieval(GIT_BRANCH_ALL
, 15);
54 void test_refs_branches_iterator__retrieve_remote_branches(void)
56 assert_retrieval(GIT_BRANCH_REMOTE
, 2);
59 void test_refs_branches_iterator__retrieve_local_branches(void)
61 assert_retrieval(GIT_BRANCH_LOCAL
, 13);
65 const char *branch_name
;
69 static void assert_branch_has_been_found(struct expectations
*findings
, const char* expected_branch_name
)
73 for (pos
= 0; findings
[pos
].branch_name
; ++pos
) {
74 if (strcmp(expected_branch_name
, findings
[pos
].branch_name
) == 0) {
75 cl_assert_equal_i(1, findings
[pos
].encounters
);
80 cl_fail("expected branch not found in list.");
83 static void contains_branches(struct expectations exp
[], git_branch_iterator
*iter
)
89 while ((error
= git_branch_next(&ref
, &type
, iter
)) == 0) {
90 for (pos
= 0; exp
[pos
].branch_name
; ++pos
) {
91 if (strcmp(git_reference_shorthand(ref
), exp
[pos
].branch_name
) == 0)
92 exp
[pos
].encounters
++;
95 git_reference_free(ref
);
98 cl_assert_equal_i(error
, GIT_ITEROVER
);
103 * nulltoken/HEAD -> nulltoken/master
106 void test_refs_branches_iterator__retrieve_remote_symbolic_HEAD_when_present(void)
108 git_branch_iterator
*iter
;
109 struct expectations exp
[] = {
110 { "nulltoken/HEAD", 0 },
111 { "nulltoken/master", 0 },
115 git_reference_free(fake_remote
);
116 cl_git_pass(git_reference_symbolic_create(&fake_remote
, repo
, "refs/remotes/nulltoken/HEAD", "refs/remotes/nulltoken/master", 0, NULL
));
118 assert_retrieval(GIT_BRANCH_REMOTE
, 3);
120 cl_git_pass(git_branch_iterator_new(&iter
, repo
, GIT_BRANCH_REMOTE
));
121 contains_branches(exp
, iter
);
122 git_branch_iterator_free(iter
);
124 assert_branch_has_been_found(exp
, "nulltoken/HEAD");
125 assert_branch_has_been_found(exp
, "nulltoken/master");
128 void test_refs_branches_iterator__mix_of_packed_and_loose(void)
130 git_branch_iterator
*iter
;
131 struct expectations exp
[] = {
133 { "origin/HEAD", 0 },
134 { "origin/master", 0 },
135 { "origin/packed", 0 },
140 r2
= cl_git_sandbox_init("testrepo2");
142 cl_git_pass(git_branch_iterator_new(&iter
, r2
, GIT_BRANCH_ALL
));
143 contains_branches(exp
, iter
);
145 git_branch_iterator_free(iter
);
147 assert_branch_has_been_found(exp
, "master");
148 assert_branch_has_been_found(exp
, "origin/HEAD");
149 assert_branch_has_been_found(exp
, "origin/master");
150 assert_branch_has_been_found(exp
, "origin/packed");