summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorVicent Marti <tanoku@gmail.com>2011-02-07 08:04:32 +0200
committerVicent Marti <tanoku@gmail.com>2011-02-07 08:04:32 +0200
commit2e75e15690bbc34c496cac330ea93a423fded95d (patch)
tree9df55cf48846129c78a70740301b737aaf77ad69
parente85c705f5a12fb29bc614f87d41a1fe26042fb71 (diff)
parent1af8c7488d99e4eeeec31c5a1e7e43cd003983e3 (diff)
downloadlibgit2-2e75e15690bbc34c496cac330ea93a423fded95d.tar.gz
Merge branch 'refs-handling-tests' of https://github.com/nulltoken/libgit2
-rw-r--r--tests/resources/testrepo.git/head-tracker1
-rw-r--r--tests/t10-refs.c50
2 files changed, 47 insertions, 4 deletions
diff --git a/tests/resources/testrepo.git/head-tracker b/tests/resources/testrepo.git/head-tracker
new file mode 100644
index 000000000..40d876b4c
--- /dev/null
+++ b/tests/resources/testrepo.git/head-tracker
@@ -0,0 +1 @@
+ref: HEAD
diff --git a/tests/t10-refs.c b/tests/t10-refs.c
index 2c760676a..9e38d2739 100644
--- a/tests/t10-refs.c
+++ b/tests/t10-refs.c
@@ -60,6 +60,7 @@ BEGIN_TEST("readtag", non_existing_tag_reference_looking_up)
END_TEST
static const char *head_ref_name = "HEAD";
+static const char *head_tracker_sym_ref_name = "head-tracker";
static const char *current_head_target = "refs/heads/master";
static const char *current_master_tip = "be3563ae3f795b2b4353bcce3a527ad0a4f7f644";
@@ -89,25 +90,65 @@ BEGIN_TEST("readsymref", symbolic_reference_looking_up)
git_repository_free(repo);
END_TEST
+BEGIN_TEST("readsymref", nested_symbolic_reference_looking_up)
+ git_repository *repo;
+ git_reference *reference, *resolved_ref;
+ git_object *object;
+ git_oid id;
+
+ must_pass(git_repository_open(&repo, REPOSITORY_FOLDER));
+
+ must_pass(git_repository_lookup_ref(&reference, repo, head_tracker_sym_ref_name));
+ must_be_true(reference->type == GIT_REF_SYMBOLIC);
+ must_be_true(reference->packed == 0);
+ must_be_true(strcmp(reference->name, head_tracker_sym_ref_name) == 0);
+
+ must_pass(git_reference_resolve(&resolved_ref, reference));
+ must_be_true(resolved_ref->type == GIT_REF_OID);
+
+ must_pass(git_repository_lookup(&object, repo, git_reference_oid(resolved_ref), GIT_OBJ_ANY));
+ must_be_true(object != NULL);
+ must_be_true(git_object_type(object) == GIT_OBJ_COMMIT);
+
+ git_oid_mkstr(&id, current_master_tip);
+ must_be_true(git_oid_cmp(&id, git_object_id(object)) == 0);
+
+ git_repository_free(repo);
+END_TEST
+
BEGIN_TEST("readsymref", looking_up_head_then_master)
git_repository *repo;
- git_reference *reference;
+ git_reference *reference, *resolved_ref, *comp_base_ref;
must_pass(git_repository_open(&repo, REPOSITORY_FOLDER));
- must_pass(git_repository_lookup_ref(&reference, repo, head_ref_name));
- must_pass(git_repository_lookup_ref(&reference, repo, current_head_target));
+
+ must_pass(git_repository_lookup_ref(&reference, repo, head_tracker_sym_ref_name));
+ must_pass(git_reference_resolve(&resolved_ref, reference));
+ comp_base_ref = resolved_ref;
+
+ must_pass(git_repository_lookup_ref(&reference, repo, head_ref_name));
+ must_pass(git_reference_resolve(&resolved_ref, reference));
+ must_pass(git_oid_cmp(git_reference_oid(comp_base_ref), git_reference_oid(resolved_ref)));
+
+ must_pass(git_repository_lookup_ref(&reference, repo, current_head_target));
+ must_pass(git_reference_resolve(&resolved_ref, reference));
+ must_pass(git_oid_cmp(git_reference_oid(comp_base_ref), git_reference_oid(resolved_ref)));
git_repository_free(repo);
END_TEST
BEGIN_TEST("readsymref", looking_up_master_then_head)
git_repository *repo;
- git_reference *reference, *master_ref;
+ git_reference *reference, *master_ref, *resolved_ref;
must_pass(git_repository_open(&repo, REPOSITORY_FOLDER));
+
must_pass(git_repository_lookup_ref(&master_ref, repo, current_head_target));
must_pass(git_repository_lookup_ref(&reference, repo, head_ref_name));
+ must_pass(git_reference_resolve(&resolved_ref, reference));
+ must_pass(git_oid_cmp(git_reference_oid(master_ref), git_reference_oid(resolved_ref)));
+
git_repository_free(repo);
END_TEST
@@ -154,6 +195,7 @@ git_testsuite *libgit2_suite_refs(void)
ADD_TEST(suite, "readtag", loose_tag_reference_looking_up);
ADD_TEST(suite, "readtag", non_existing_tag_reference_looking_up);
ADD_TEST(suite, "readsymref", symbolic_reference_looking_up);
+ ADD_TEST(suite, "readsymref", nested_symbolic_reference_looking_up);
ADD_TEST(suite, "readsymref", looking_up_head_then_master);
ADD_TEST(suite, "readsymref", looking_up_master_then_head);
ADD_TEST(suite, "readpackedref", packed_reference_looking_up);