]> git.ipfire.org Git - thirdparty/git.git/commitdiff
Merge branch 'hd/show-one-mergetag-fix'
authorJunio C Hamano <gitster@pobox.com>
Mon, 9 Mar 2020 18:21:21 +0000 (11:21 -0700)
committerJunio C Hamano <gitster@pobox.com>
Mon, 9 Mar 2020 18:21:21 +0000 (11:21 -0700)
"git show" and others gave an object name in raw format in its
error output, which has been corrected to give it in hex.

* hd/show-one-mergetag-fix:
  show_one_mergetag: print non-parent in hex form.

log-tree.c
t/t4202-log.sh

index 5425ae931f5e3c36970c68cf447f14056b5deeb3..52127427ffeace62621a3761dc540a174671f4a5 100644 (file)
@@ -516,7 +516,7 @@ static int show_one_mergetag(struct commit *commit,
                            "merged tag '%s'\n", tag->tag);
        else if ((nth = which_parent(&tag->tagged->oid, commit)) < 0)
                strbuf_addf(&verify_message, "tag %s names a non-parent %s\n",
-                                   tag->tag, tag->tagged->oid.hash);
+                                   tag->tag, oid_to_hex(&tag->tagged->oid));
        else
                strbuf_addf(&verify_message,
                            "parent #%d, tagged '%s'\n", nth + 1, tag->tag);
index 4694b6d0ce7170e141c17082285772730e499b3e..0f766ba65f598c105bbce6f8f3aa2d4cda1c0de3 100755 (executable)
@@ -1607,6 +1607,26 @@ test_expect_success GPG 'log --graph --show-signature for merged tag' '
        grep "^| | gpg: Good signature" actual
 '
 
+test_expect_success GPG 'log --graph --show-signature for merged tag in shallow clone' '
+       test_when_finished "git reset --hard && git checkout master" &&
+       git checkout -b plain-shallow master &&
+       echo aaa >bar &&
+       git add bar &&
+       git commit -m bar_commit &&
+       git checkout --detach master &&
+       echo bbb >baz &&
+       git add baz &&
+       git commit -m baz_commit &&
+       git tag -s -m signed_tag_msg signed_tag_shallow &&
+       hash=$(git rev-parse HEAD) &&
+       git checkout plain-shallow &&
+       git merge --no-ff -m msg signed_tag_shallow &&
+       git clone --depth 1 --no-local . shallow &&
+       test_when_finished "rm -rf shallow" &&
+       git -C shallow log --graph --show-signature -n1 plain-shallow >actual &&
+       grep "tag signed_tag_shallow names a non-parent $hash" actual
+'
+
 test_expect_success GPGSM 'log --graph --show-signature for merged tag x509' '
        test_when_finished "git reset --hard && git checkout master" &&
        test_config gpg.format x509 &&