diff options
author | Junio C Hamano <gitster@pobox.com> | 2016-11-18 15:21:12 -0800 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2016-11-18 15:21:12 -0800 |
commit | 84679d470d577bcde1b6aa6af36c08a2d77b6e68 (patch) | |
tree | a42f20ac63cfacfcff3a25256592f41c22745961 /t | |
parent | 0b65a8dbdb38962e700ee16776a3042beb489060 (diff) | |
download | git-84679d470d577bcde1b6aa6af36c08a2d77b6e68.tar.gz git-84679d470d577bcde1b6aa6af36c08a2d77b6e68.tar.xz |
for-each-ref: do not segv with %(HEAD) on an unborn branch
The code to flip between "*" and " " prefixes depending on what
branch is checked out used in --format='%(HEAD)' did not consider
that HEAD may resolve to an unborn branch and dereferenced a NULL.
This will become a lot easier to trigger as the codepath will be
used to reimplement "git branch [--list]" in the future.
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 't')
-rwxr-xr-x | t/t6300-for-each-ref.sh | 10 |
1 files changed, 10 insertions, 0 deletions
diff --git a/t/t6300-for-each-ref.sh b/t/t6300-for-each-ref.sh index 19a282302..039509a9c 100755 --- a/t/t6300-for-each-ref.sh +++ b/t/t6300-for-each-ref.sh @@ -553,4 +553,14 @@ test_expect_success 'Verify sort with multiple keys' ' refs/tags/bogo refs/tags/master > actual && test_cmp expected actual ' + +test_expect_success 'do not dereference NULL upon %(HEAD) on unborn branch' ' + test_when_finished "git checkout master" && + git for-each-ref --format="%(HEAD) %(refname:short)" refs/heads/ >actual && + sed -e "s/^\* / /" actual >expect && + git checkout --orphan HEAD && + git for-each-ref --format="%(HEAD) %(refname:short)" refs/heads/ >actual && + test_cmp expect actual +' + test_done |