diff options
author | nulltoken <emeric.fermas@gmail.com> | 2013-05-14 16:40:09 +0200 |
---|---|---|
committer | Carlos MartÃn Nieto <cmn@dwim.me> | 2013-11-23 13:35:53 +0100 |
commit | ca84e058505a25b8f789ee1298a83e818b297ecc (patch) | |
tree | c1ca409bf858d69063cf7512c2129d706ea52c78 /tests | |
parent | 14ab0e100e9474c5d1fda37fb0f4eec9ee0e9d13 (diff) | |
download | libgit2-ca84e058505a25b8f789ee1298a83e818b297ecc.tar.gz |
refs: Introduce git_reference_symbolic_set_target_with_log()
Diffstat (limited to 'tests')
-rw-r--r-- | tests/refs/settargetwithlog.c | 39 |
1 files changed, 39 insertions, 0 deletions
diff --git a/tests/refs/settargetwithlog.c b/tests/refs/settargetwithlog.c index 7bdd6d50b..e1f73db56 100644 --- a/tests/refs/settargetwithlog.c +++ b/tests/refs/settargetwithlog.c @@ -53,3 +53,42 @@ void test_refs_settargetwithlog__updating_a_direct_reference_adds_a_reflog_entry git_reference_free(reference); git_signature_free(signature); } + +void test_refs_settargetwithlog__updating_a_symbolic_reference_adds_a_reflog_entry(void) +{ + git_reference *reference, *reference_out; + git_oid id; + git_signature *signature; + git_reflog *reflog; + const git_reflog_entry *entry; + + const char *name = "HEAD"; + const char *message = "You've been logged, mate!"; + + git_oid_fromstr(&id, br2_tip); + + cl_git_pass(git_signature_now(&signature, "foo", "foo@bar")); + + cl_git_pass(git_reference_lookup(&reference, g_repo, name)); + + cl_assert_equal_s( + "refs/heads/master", git_reference_symbolic_target(reference)); + + cl_git_pass(git_reference_symbolic_set_target_with_log(&reference_out, + reference, br2_name, signature, message)); + + cl_assert_equal_s( + br2_name, git_reference_symbolic_target(reference_out)); + + cl_git_pass(git_reflog_read(&reflog, reference)); + + entry = git_reflog_entry_byindex(reflog, 0); + cl_assert(git_oid_streq(&entry->oid_old, master_tip) == 0); + cl_assert(git_oid_streq(&entry->oid_cur, br2_tip) == 0); + cl_assert_equal_s(message, entry->msg); + + git_reflog_free(reflog); + git_reference_free(reference_out); + git_reference_free(reference); + git_signature_free(signature); +} |