From 2952a9d0f474547db88f396dd8cc7c62d61993a2 Mon Sep 17 00:00:00 2001 From: Ben Straub Date: Mon, 27 Jan 2014 13:39:48 -0800 Subject: Ensure creating HEAD creates its reflog --- tests/repo/head.c | 21 +++++++++++++++++++++ 1 file changed, 21 insertions(+) (limited to 'tests/repo') diff --git a/tests/repo/head.c b/tests/repo/head.c index df7059fd5..d28f254c3 100644 --- a/tests/repo/head.c +++ b/tests/repo/head.c @@ -217,3 +217,24 @@ void test_repo_head__setting_head_updates_reflog(void) git_reflog_free(log); git_object_free(tag); } + +void test_repo_head__setting_creates_head_ref(void) +{ + git_reference *head; + git_reflog *log; + const git_reflog_entry *entry; + + cl_git_pass(git_reference_lookup(&head, repo, "HEAD")); + cl_git_pass(git_reference_delete(head)); + cl_git_pass(git_reflog_delete(repo, "HEAD")); + + cl_git_pass(git_repository_set_head(repo, "refs/heads/haacked", NULL, "create HEAD")); + + cl_git_pass(git_reflog_read(&log, repo, "HEAD")); + cl_assert_equal_i(1, git_reflog_entrycount(log)); + entry = git_reflog_entry_byindex(log, 0); + cl_assert_equal_s("create HEAD", git_reflog_entry_message(entry)); + + git_reflog_free(log); + git_reference_free(head); +} -- cgit v1.2.3