t / t7004-tag.shon commit rebase -i: move rebase--helper modes to rebase--interactive (34b4731)
   1#!/bin/sh
   2#
   3# Copyright (c) 2007 Carlos Rica
   4#
   5
   6test_description='git tag
   7
   8Tests for operations with tags.'
   9
  10. ./test-lib.sh
  11. "$TEST_DIRECTORY"/lib-gpg.sh
  12. "$TEST_DIRECTORY"/lib-terminal.sh
  13
  14# creating and listing lightweight tags:
  15
  16tag_exists () {
  17        git show-ref --quiet --verify refs/tags/"$1"
  18}
  19
  20test_expect_success 'listing all tags in an empty tree should succeed' '
  21        git tag -l &&
  22        git tag
  23'
  24
  25test_expect_success 'listing all tags in an empty tree should output nothing' '
  26        test $(git tag -l | wc -l) -eq 0 &&
  27        test $(git tag | wc -l) -eq 0
  28'
  29
  30test_expect_success 'sort tags, ignore case' '
  31        (
  32                git init sort &&
  33                cd sort &&
  34                test_commit initial &&
  35                git tag tag-one &&
  36                git tag TAG-two &&
  37                git tag -l >actual &&
  38                cat >expected <<-\EOF &&
  39                TAG-two
  40                initial
  41                tag-one
  42                EOF
  43                test_cmp expected actual &&
  44                git tag -l -i >actual &&
  45                cat >expected <<-\EOF &&
  46                initial
  47                tag-one
  48                TAG-two
  49                EOF
  50                test_cmp expected actual
  51        )
  52'
  53
  54test_expect_success 'looking for a tag in an empty tree should fail' \
  55        '! (tag_exists mytag)'
  56
  57test_expect_success 'creating a tag in an empty tree should fail' '
  58        test_must_fail git tag mynotag &&
  59        ! tag_exists mynotag
  60'
  61
  62test_expect_success 'creating a tag for HEAD in an empty tree should fail' '
  63        test_must_fail git tag mytaghead HEAD &&
  64        ! tag_exists mytaghead
  65'
  66
  67test_expect_success 'creating a tag for an unknown revision should fail' '
  68        test_must_fail git tag mytagnorev aaaaaaaaaaa &&
  69        ! tag_exists mytagnorev
  70'
  71
  72# commit used in the tests, test_tick is also called here to freeze the date:
  73test_expect_success 'creating a tag using default HEAD should succeed' '
  74        test_config core.logAllRefUpdates true &&
  75        test_tick &&
  76        echo foo >foo &&
  77        git add foo &&
  78        git commit -m Foo &&
  79        git tag mytag &&
  80        test_must_fail git reflog exists refs/tags/mytag
  81'
  82
  83test_expect_success 'creating a tag with --create-reflog should create reflog' '
  84        git log -1 \
  85                --format="format:tag: tagging %h (%s, %cd)%n" \
  86                --date=format:%Y-%m-%d >expected &&
  87        test_when_finished "git tag -d tag_with_reflog" &&
  88        git tag --create-reflog tag_with_reflog &&
  89        git reflog exists refs/tags/tag_with_reflog &&
  90        sed -e "s/^.*   //" .git/logs/refs/tags/tag_with_reflog >actual &&
  91        test_i18ncmp expected actual
  92'
  93
  94test_expect_success 'annotated tag with --create-reflog has correct message' '
  95        git log -1 \
  96                --format="format:tag: tagging %h (%s, %cd)%n" \
  97                --date=format:%Y-%m-%d >expected &&
  98        test_when_finished "git tag -d tag_with_reflog" &&
  99        git tag -m "annotated tag" --create-reflog tag_with_reflog &&
 100        git reflog exists refs/tags/tag_with_reflog &&
 101        sed -e "s/^.*   //" .git/logs/refs/tags/tag_with_reflog >actual &&
 102        test_i18ncmp expected actual
 103'
 104
 105test_expect_success '--create-reflog does not create reflog on failure' '
 106        test_must_fail git tag --create-reflog mytag &&
 107        test_must_fail git reflog exists refs/tags/mytag
 108'
 109
 110test_expect_success 'option core.logAllRefUpdates=always creates reflog' '
 111        test_when_finished "git tag -d tag_with_reflog" &&
 112        test_config core.logAllRefUpdates always &&
 113        git tag tag_with_reflog &&
 114        git reflog exists refs/tags/tag_with_reflog
 115'
 116
 117test_expect_success 'listing all tags if one exists should succeed' '
 118        git tag -l &&
 119        git tag
 120'
 121
 122cat >expect <<EOF
 123mytag
 124EOF
 125test_expect_success 'Multiple -l or --list options are equivalent to one -l option' '
 126        git tag -l -l >actual &&
 127        test_cmp expect actual &&
 128        git tag --list --list >actual &&
 129        test_cmp expect actual &&
 130        git tag --list -l --list >actual &&
 131        test_cmp expect actual
 132'
 133
 134test_expect_success 'listing all tags if one exists should output that tag' '
 135        test $(git tag -l) = mytag &&
 136        test $(git tag) = mytag
 137'
 138
 139# pattern matching:
 140
 141test_expect_success 'listing a tag using a matching pattern should succeed' \
 142        'git tag -l mytag'
 143
 144test_expect_success 'listing a tag with --ignore-case' \
 145        'test $(git tag -l --ignore-case MYTAG) = mytag'
 146
 147test_expect_success \
 148        'listing a tag using a matching pattern should output that tag' \
 149        'test $(git tag -l mytag) = mytag'
 150
 151test_expect_success \
 152        'listing tags using a non-matching pattern should succeed' \
 153        'git tag -l xxx'
 154
 155test_expect_success \
 156        'listing tags using a non-matching pattern should output nothing' \
 157        'test $(git tag -l xxx | wc -l) -eq 0'
 158
 159# special cases for creating tags:
 160
 161test_expect_success \
 162        'trying to create a tag with the name of one existing should fail' \
 163        'test_must_fail git tag mytag'
 164
 165test_expect_success \
 166        'trying to create a tag with a non-valid name should fail' '
 167        test $(git tag -l | wc -l) -eq 1 &&
 168        test_must_fail git tag "" &&
 169        test_must_fail git tag .othertag &&
 170        test_must_fail git tag "other tag" &&
 171        test_must_fail git tag "othertag^" &&
 172        test_must_fail git tag "other~tag" &&
 173        test $(git tag -l | wc -l) -eq 1
 174'
 175
 176test_expect_success 'creating a tag using HEAD directly should succeed' '
 177        git tag myhead HEAD &&
 178        tag_exists myhead
 179'
 180
 181test_expect_success '--force can create a tag with the name of one existing' '
 182        tag_exists mytag &&
 183        git tag --force mytag &&
 184        tag_exists mytag'
 185
 186test_expect_success '--force is moot with a non-existing tag name' '
 187        test_when_finished git tag -d newtag forcetag &&
 188        git tag newtag >expect &&
 189        git tag --force forcetag >actual &&
 190        test_cmp expect actual
 191'
 192
 193# deleting tags:
 194
 195test_expect_success 'trying to delete an unknown tag should fail' '
 196        ! tag_exists unknown-tag &&
 197        test_must_fail git tag -d unknown-tag
 198'
 199
 200cat >expect <<EOF
 201myhead
 202mytag
 203EOF
 204test_expect_success \
 205        'trying to delete tags without params should succeed and do nothing' '
 206        git tag -l > actual && test_cmp expect actual &&
 207        git tag -d &&
 208        git tag -l > actual && test_cmp expect actual
 209'
 210
 211test_expect_success \
 212        'deleting two existing tags in one command should succeed' '
 213        tag_exists mytag &&
 214        tag_exists myhead &&
 215        git tag -d mytag myhead &&
 216        ! tag_exists mytag &&
 217        ! tag_exists myhead
 218'
 219
 220test_expect_success \
 221        'creating a tag with the name of another deleted one should succeed' '
 222        ! tag_exists mytag &&
 223        git tag mytag &&
 224        tag_exists mytag
 225'
 226
 227test_expect_success \
 228        'trying to delete two tags, existing and not, should fail in the 2nd' '
 229        tag_exists mytag &&
 230        ! tag_exists myhead &&
 231        test_must_fail git tag -d mytag anothertag &&
 232        ! tag_exists mytag &&
 233        ! tag_exists myhead
 234'
 235
 236test_expect_success 'trying to delete an already deleted tag should fail' \
 237        'test_must_fail git tag -d mytag'
 238
 239# listing various tags with pattern matching:
 240
 241cat >expect <<EOF
 242a1
 243aa1
 244cba
 245t210
 246t211
 247v0.2.1
 248v1.0
 249v1.0.1
 250v1.1.3
 251EOF
 252test_expect_success 'listing all tags should print them ordered' '
 253        git tag v1.0.1 &&
 254        git tag t211 &&
 255        git tag aa1 &&
 256        git tag v0.2.1 &&
 257        git tag v1.1.3 &&
 258        git tag cba &&
 259        git tag a1 &&
 260        git tag v1.0 &&
 261        git tag t210 &&
 262        git tag -l > actual &&
 263        test_cmp expect actual &&
 264        git tag > actual &&
 265        test_cmp expect actual
 266'
 267
 268cat >expect <<EOF
 269a1
 270aa1
 271cba
 272EOF
 273test_expect_success \
 274        'listing tags with substring as pattern must print those matching' '
 275        rm *a* &&
 276        git tag -l "*a*" > current &&
 277        test_cmp expect current
 278'
 279
 280cat >expect <<EOF
 281v0.2.1
 282v1.0.1
 283EOF
 284test_expect_success \
 285        'listing tags with a suffix as pattern must print those matching' '
 286        git tag -l "*.1" > actual &&
 287        test_cmp expect actual
 288'
 289
 290cat >expect <<EOF
 291t210
 292t211
 293EOF
 294test_expect_success \
 295        'listing tags with a prefix as pattern must print those matching' '
 296        git tag -l "t21*" > actual &&
 297        test_cmp expect actual
 298'
 299
 300cat >expect <<EOF
 301a1
 302EOF
 303test_expect_success \
 304        'listing tags using a name as pattern must print that one matching' '
 305        git tag -l a1 > actual &&
 306        test_cmp expect actual
 307'
 308
 309cat >expect <<EOF
 310v1.0
 311EOF
 312test_expect_success \
 313        'listing tags using a name as pattern must print that one matching' '
 314        git tag -l v1.0 > actual &&
 315        test_cmp expect actual
 316'
 317
 318cat >expect <<EOF
 319v1.0.1
 320v1.1.3
 321EOF
 322test_expect_success \
 323        'listing tags with ? in the pattern should print those matching' '
 324        git tag -l "v1.?.?" > actual &&
 325        test_cmp expect actual
 326'
 327
 328>expect
 329test_expect_success \
 330        'listing tags using v.* should print nothing because none have v.' '
 331        git tag -l "v.*" > actual &&
 332        test_cmp expect actual
 333'
 334
 335cat >expect <<EOF
 336v0.2.1
 337v1.0
 338v1.0.1
 339v1.1.3
 340EOF
 341test_expect_success \
 342        'listing tags using v* should print only those having v' '
 343        git tag -l "v*" > actual &&
 344        test_cmp expect actual
 345'
 346
 347test_expect_success 'tag -l can accept multiple patterns' '
 348        git tag -l "v1*" "v0*" >actual &&
 349        test_cmp expect actual
 350'
 351
 352# Between v1.7.7 & v2.13.0 a fair reading of the git-tag documentation
 353# could leave you with the impression that "-l <pattern> -l <pattern>"
 354# was how we wanted to accept multiple patterns.
 355#
 356# This test should not imply that this is a sane thing to support. but
 357# since the documentation was worded like it was let's at least find
 358# out if we're going to break this long-documented form of taking
 359# multiple patterns.
 360test_expect_success 'tag -l <pattern> -l <pattern> works, as our buggy documentation previously suggested' '
 361        git tag -l "v1*" -l "v0*" >actual &&
 362        test_cmp expect actual
 363'
 364
 365test_expect_success 'listing tags in column' '
 366        COLUMNS=41 git tag -l --column=row >actual &&
 367        cat >expected <<\EOF &&
 368a1      aa1     cba     t210    t211
 369v0.2.1  v1.0    v1.0.1  v1.1.3
 370EOF
 371        test_cmp expected actual
 372'
 373
 374test_expect_success 'listing tags in column with column.*' '
 375        test_config column.tag row &&
 376        test_config column.ui dense &&
 377        COLUMNS=40 git tag -l >actual &&
 378        cat >expected <<\EOF &&
 379a1      aa1   cba     t210    t211
 380v0.2.1  v1.0  v1.0.1  v1.1.3
 381EOF
 382        test_cmp expected actual
 383'
 384
 385test_expect_success 'listing tag with -n --column should fail' '
 386        test_must_fail git tag --column -n
 387'
 388
 389test_expect_success 'listing tags -n in column with column.ui ignored' '
 390        test_config column.ui "row dense" &&
 391        COLUMNS=40 git tag -l -n >actual &&
 392        cat >expected <<\EOF &&
 393a1              Foo
 394aa1             Foo
 395cba             Foo
 396t210            Foo
 397t211            Foo
 398v0.2.1          Foo
 399v1.0            Foo
 400v1.0.1          Foo
 401v1.1.3          Foo
 402EOF
 403        test_cmp expected actual
 404'
 405
 406# creating and verifying lightweight tags:
 407
 408test_expect_success \
 409        'a non-annotated tag created without parameters should point to HEAD' '
 410        git tag non-annotated-tag &&
 411        test $(git cat-file -t non-annotated-tag) = commit &&
 412        test $(git rev-parse non-annotated-tag) = $(git rev-parse HEAD)
 413'
 414
 415test_expect_success 'trying to verify an unknown tag should fail' \
 416        'test_must_fail git tag -v unknown-tag'
 417
 418test_expect_success \
 419        'trying to verify a non-annotated and non-signed tag should fail' \
 420        'test_must_fail git tag -v non-annotated-tag'
 421
 422test_expect_success \
 423        'trying to verify many non-annotated or unknown tags, should fail' \
 424        'test_must_fail git tag -v unknown-tag1 non-annotated-tag unknown-tag2'
 425
 426# creating annotated tags:
 427
 428get_tag_msg () {
 429        git cat-file tag "$1" | sed -e "/BEGIN PGP/q"
 430}
 431
 432# run test_tick before committing always gives the time in that timezone
 433get_tag_header () {
 434cat <<EOF
 435object $2
 436type $3
 437tag $1
 438tagger C O Mitter <committer@example.com> $4 -0700
 439
 440EOF
 441}
 442
 443commit=$(git rev-parse HEAD)
 444time=$test_tick
 445
 446get_tag_header annotated-tag $commit commit $time >expect
 447echo "A message" >>expect
 448test_expect_success \
 449        'creating an annotated tag with -m message should succeed' '
 450        git tag -m "A message" annotated-tag &&
 451        get_tag_msg annotated-tag >actual &&
 452        test_cmp expect actual
 453'
 454
 455get_tag_header annotated-tag-edit $commit commit $time >expect
 456echo "An edited message" >>expect
 457test_expect_success 'set up editor' '
 458        write_script fakeeditor <<-\EOF
 459        sed -e "s/A message/An edited message/g" <"$1" >"$1-"
 460        mv "$1-" "$1"
 461        EOF
 462'
 463test_expect_success \
 464        'creating an annotated tag with -m message --edit should succeed' '
 465        GIT_EDITOR=./fakeeditor git tag -m "A message" --edit annotated-tag-edit &&
 466        get_tag_msg annotated-tag-edit >actual &&
 467        test_cmp expect actual
 468'
 469
 470cat >msgfile <<EOF
 471Another message
 472in a file.
 473EOF
 474get_tag_header file-annotated-tag $commit commit $time >expect
 475cat msgfile >>expect
 476test_expect_success \
 477        'creating an annotated tag with -F messagefile should succeed' '
 478        git tag -F msgfile file-annotated-tag &&
 479        get_tag_msg file-annotated-tag >actual &&
 480        test_cmp expect actual
 481'
 482
 483get_tag_header file-annotated-tag-edit $commit commit $time >expect
 484sed -e "s/Another message/Another edited message/g" msgfile >>expect
 485test_expect_success 'set up editor' '
 486        write_script fakeeditor <<-\EOF
 487        sed -e "s/Another message/Another edited message/g" <"$1" >"$1-"
 488        mv "$1-" "$1"
 489        EOF
 490'
 491test_expect_success \
 492        'creating an annotated tag with -F messagefile --edit should succeed' '
 493        GIT_EDITOR=./fakeeditor git tag -F msgfile --edit file-annotated-tag-edit &&
 494        get_tag_msg file-annotated-tag-edit >actual &&
 495        test_cmp expect actual
 496'
 497
 498cat >inputmsg <<EOF
 499A message from the
 500standard input
 501EOF
 502get_tag_header stdin-annotated-tag $commit commit $time >expect
 503cat inputmsg >>expect
 504test_expect_success 'creating an annotated tag with -F - should succeed' '
 505        git tag -F - stdin-annotated-tag <inputmsg &&
 506        get_tag_msg stdin-annotated-tag >actual &&
 507        test_cmp expect actual
 508'
 509
 510test_expect_success \
 511        'trying to create a tag with a non-existing -F file should fail' '
 512        ! test -f nonexistingfile &&
 513        ! tag_exists notag &&
 514        test_must_fail git tag -F nonexistingfile notag &&
 515        ! tag_exists notag
 516'
 517
 518test_expect_success \
 519        'trying to create tags giving both -m or -F options should fail' '
 520        echo "message file 1" >msgfile1 &&
 521        echo "message file 2" >msgfile2 &&
 522        ! tag_exists msgtag &&
 523        test_must_fail git tag -m "message 1" -F msgfile1 msgtag &&
 524        ! tag_exists msgtag &&
 525        test_must_fail git tag -F msgfile1 -m "message 1" msgtag &&
 526        ! tag_exists msgtag &&
 527        test_must_fail git tag -m "message 1" -F msgfile1 \
 528                -m "message 2" msgtag &&
 529        ! tag_exists msgtag
 530'
 531
 532# blank and empty messages:
 533
 534get_tag_header empty-annotated-tag $commit commit $time >expect
 535test_expect_success \
 536        'creating a tag with an empty -m message should succeed' '
 537        git tag -m "" empty-annotated-tag &&
 538        get_tag_msg empty-annotated-tag >actual &&
 539        test_cmp expect actual
 540'
 541
 542>emptyfile
 543get_tag_header emptyfile-annotated-tag $commit commit $time >expect
 544test_expect_success \
 545        'creating a tag with an empty -F messagefile should succeed' '
 546        git tag -F emptyfile emptyfile-annotated-tag &&
 547        get_tag_msg emptyfile-annotated-tag >actual &&
 548        test_cmp expect actual
 549'
 550
 551printf '\n\n  \n\t\nLeading blank lines\n' >blanksfile
 552printf '\n\t \t  \nRepeated blank lines\n' >>blanksfile
 553printf '\n\n\nTrailing spaces      \t  \n' >>blanksfile
 554printf '\nTrailing blank lines\n\n\t \n\n' >>blanksfile
 555get_tag_header blanks-annotated-tag $commit commit $time >expect
 556cat >>expect <<EOF
 557Leading blank lines
 558
 559Repeated blank lines
 560
 561Trailing spaces
 562
 563Trailing blank lines
 564EOF
 565test_expect_success \
 566        'extra blanks in the message for an annotated tag should be removed' '
 567        git tag -F blanksfile blanks-annotated-tag &&
 568        get_tag_msg blanks-annotated-tag >actual &&
 569        test_cmp expect actual
 570'
 571
 572get_tag_header blank-annotated-tag $commit commit $time >expect
 573test_expect_success \
 574        'creating a tag with blank -m message with spaces should succeed' '
 575        git tag -m "     " blank-annotated-tag &&
 576        get_tag_msg blank-annotated-tag >actual &&
 577        test_cmp expect actual
 578'
 579
 580echo '     ' >blankfile
 581echo ''      >>blankfile
 582echo '  '    >>blankfile
 583get_tag_header blankfile-annotated-tag $commit commit $time >expect
 584test_expect_success \
 585        'creating a tag with blank -F messagefile with spaces should succeed' '
 586        git tag -F blankfile blankfile-annotated-tag &&
 587        get_tag_msg blankfile-annotated-tag >actual &&
 588        test_cmp expect actual
 589'
 590
 591printf '      ' >blanknonlfile
 592get_tag_header blanknonlfile-annotated-tag $commit commit $time >expect
 593test_expect_success \
 594        'creating a tag with -F file of spaces and no newline should succeed' '
 595        git tag -F blanknonlfile blanknonlfile-annotated-tag &&
 596        get_tag_msg blanknonlfile-annotated-tag >actual &&
 597        test_cmp expect actual
 598'
 599
 600# messages with commented lines:
 601
 602cat >commentsfile <<EOF
 603# A comment
 604
 605############
 606The message.
 607############
 608One line.
 609
 610
 611# commented lines
 612# commented lines
 613
 614Another line.
 615# comments
 616
 617Last line.
 618EOF
 619get_tag_header comments-annotated-tag $commit commit $time >expect
 620cat >>expect <<EOF
 621The message.
 622One line.
 623
 624Another line.
 625
 626Last line.
 627EOF
 628test_expect_success \
 629        'creating a tag using a -F messagefile with #comments should succeed' '
 630        git tag -F commentsfile comments-annotated-tag &&
 631        get_tag_msg comments-annotated-tag >actual &&
 632        test_cmp expect actual
 633'
 634
 635get_tag_header comment-annotated-tag $commit commit $time >expect
 636test_expect_success \
 637        'creating a tag with a #comment in the -m message should succeed' '
 638        git tag -m "#comment" comment-annotated-tag &&
 639        get_tag_msg comment-annotated-tag >actual &&
 640        test_cmp expect actual
 641'
 642
 643echo '#comment' >commentfile
 644echo ''         >>commentfile
 645echo '####'     >>commentfile
 646get_tag_header commentfile-annotated-tag $commit commit $time >expect
 647test_expect_success \
 648        'creating a tag with #comments in the -F messagefile should succeed' '
 649        git tag -F commentfile commentfile-annotated-tag &&
 650        get_tag_msg commentfile-annotated-tag >actual &&
 651        test_cmp expect actual
 652'
 653
 654printf '#comment' >commentnonlfile
 655get_tag_header commentnonlfile-annotated-tag $commit commit $time >expect
 656test_expect_success \
 657        'creating a tag with a file of #comment and no newline should succeed' '
 658        git tag -F commentnonlfile commentnonlfile-annotated-tag &&
 659        get_tag_msg commentnonlfile-annotated-tag >actual &&
 660        test_cmp expect actual
 661'
 662
 663# listing messages for annotated non-signed tags:
 664
 665test_expect_success \
 666        'listing the one-line message of a non-signed tag should succeed' '
 667        git tag -m "A msg" tag-one-line &&
 668
 669        echo "tag-one-line" >expect &&
 670        git tag -l | grep "^tag-one-line" >actual &&
 671        test_cmp expect actual &&
 672        git tag -n0 -l | grep "^tag-one-line" >actual &&
 673        test_cmp expect actual &&
 674        git tag -n0 -l tag-one-line >actual &&
 675        test_cmp expect actual &&
 676
 677        git tag -n0 | grep "^tag-one-line" >actual &&
 678        test_cmp expect actual &&
 679        git tag -n0 tag-one-line >actual &&
 680        test_cmp expect actual &&
 681
 682        echo "tag-one-line    A msg" >expect &&
 683        git tag -n1 -l | grep "^tag-one-line" >actual &&
 684        test_cmp expect actual &&
 685        git tag -n -l | grep "^tag-one-line" >actual &&
 686        test_cmp expect actual &&
 687        git tag -n1 -l tag-one-line >actual &&
 688        test_cmp expect actual &&
 689        git tag -n2 -l tag-one-line >actual &&
 690        test_cmp expect actual &&
 691        git tag -n999 -l tag-one-line >actual &&
 692        test_cmp expect actual
 693'
 694
 695test_expect_success 'The -n 100 invocation means -n --list 100, not -n100' '
 696        >expect &&
 697        git tag -n 100 >actual &&
 698        test_cmp expect actual &&
 699
 700        git tag -m "A msg" 100 &&
 701        echo "100             A msg" >expect &&
 702        git tag -n 100 >actual &&
 703        test_cmp expect actual
 704'
 705
 706test_expect_success \
 707        'listing the zero-lines message of a non-signed tag should succeed' '
 708        git tag -m "" tag-zero-lines &&
 709
 710        echo "tag-zero-lines" >expect &&
 711        git tag -l | grep "^tag-zero-lines" >actual &&
 712        test_cmp expect actual &&
 713        git tag -n0 -l | grep "^tag-zero-lines" >actual &&
 714        test_cmp expect actual &&
 715        git tag -n0 -l tag-zero-lines >actual &&
 716        test_cmp expect actual &&
 717
 718        echo "tag-zero-lines  " >expect &&
 719        git tag -n1 -l | grep "^tag-zero-lines" >actual &&
 720        test_cmp expect actual &&
 721        git tag -n -l | grep "^tag-zero-lines" >actual &&
 722        test_cmp expect actual &&
 723        git tag -n1 -l tag-zero-lines >actual &&
 724        test_cmp expect actual &&
 725        git tag -n2 -l tag-zero-lines >actual &&
 726        test_cmp expect actual &&
 727        git tag -n999 -l tag-zero-lines >actual &&
 728        test_cmp expect actual
 729'
 730
 731echo 'tag line one' >annotagmsg
 732echo 'tag line two' >>annotagmsg
 733echo 'tag line three' >>annotagmsg
 734test_expect_success \
 735        'listing many message lines of a non-signed tag should succeed' '
 736        git tag -F annotagmsg tag-lines &&
 737
 738        echo "tag-lines" >expect &&
 739        git tag -l | grep "^tag-lines" >actual &&
 740        test_cmp expect actual &&
 741        git tag -n0 -l | grep "^tag-lines" >actual &&
 742        test_cmp expect actual &&
 743        git tag -n0 -l tag-lines >actual &&
 744        test_cmp expect actual &&
 745
 746        echo "tag-lines       tag line one" >expect &&
 747        git tag -n1 -l | grep "^tag-lines" >actual &&
 748        test_cmp expect actual &&
 749        git tag -n -l | grep "^tag-lines" >actual &&
 750        test_cmp expect actual &&
 751        git tag -n1 -l tag-lines >actual &&
 752        test_cmp expect actual &&
 753
 754        echo "    tag line two" >>expect &&
 755        git tag -n2 -l | grep "^ *tag.line" >actual &&
 756        test_cmp expect actual &&
 757        git tag -n2 -l tag-lines >actual &&
 758        test_cmp expect actual &&
 759
 760        echo "    tag line three" >>expect &&
 761        git tag -n3 -l | grep "^ *tag.line" >actual &&
 762        test_cmp expect actual &&
 763        git tag -n3 -l tag-lines >actual &&
 764        test_cmp expect actual &&
 765        git tag -n4 -l | grep "^ *tag.line" >actual &&
 766        test_cmp expect actual &&
 767        git tag -n4 -l tag-lines >actual &&
 768        test_cmp expect actual &&
 769        git tag -n99 -l | grep "^ *tag.line" >actual &&
 770        test_cmp expect actual &&
 771        git tag -n99 -l tag-lines >actual &&
 772        test_cmp expect actual
 773'
 774
 775test_expect_success 'annotations for blobs are empty' '
 776        blob=$(git hash-object -w --stdin <<-\EOF
 777        Blob paragraph 1.
 778
 779        Blob paragraph 2.
 780        EOF
 781        ) &&
 782        git tag tag-blob $blob &&
 783        echo "tag-blob        " >expect &&
 784        git tag -n1 -l tag-blob >actual &&
 785        test_cmp expect actual
 786'
 787
 788# trying to verify annotated non-signed tags:
 789
 790test_expect_success GPG \
 791        'trying to verify an annotated non-signed tag should fail' '
 792        tag_exists annotated-tag &&
 793        test_must_fail git tag -v annotated-tag
 794'
 795
 796test_expect_success GPG \
 797        'trying to verify a file-annotated non-signed tag should fail' '
 798        tag_exists file-annotated-tag &&
 799        test_must_fail git tag -v file-annotated-tag
 800'
 801
 802test_expect_success GPG \
 803        'trying to verify two annotated non-signed tags should fail' '
 804        tag_exists annotated-tag file-annotated-tag &&
 805        test_must_fail git tag -v annotated-tag file-annotated-tag
 806'
 807
 808# creating and verifying signed tags:
 809
 810get_tag_header signed-tag $commit commit $time >expect
 811echo 'A signed tag message' >>expect
 812echo '-----BEGIN PGP SIGNATURE-----' >>expect
 813test_expect_success GPG 'creating a signed tag with -m message should succeed' '
 814        git tag -s -m "A signed tag message" signed-tag &&
 815        get_tag_msg signed-tag >actual &&
 816        test_cmp expect actual
 817'
 818
 819get_tag_header u-signed-tag $commit commit $time >expect
 820echo 'Another message' >>expect
 821echo '-----BEGIN PGP SIGNATURE-----' >>expect
 822test_expect_success GPG 'sign with a given key id' '
 823
 824        git tag -u committer@example.com -m "Another message" u-signed-tag &&
 825        get_tag_msg u-signed-tag >actual &&
 826        test_cmp expect actual
 827
 828'
 829
 830test_expect_success GPG 'sign with an unknown id (1)' '
 831
 832        test_must_fail git tag -u author@example.com \
 833                -m "Another message" o-signed-tag
 834
 835'
 836
 837test_expect_success GPG 'sign with an unknown id (2)' '
 838
 839        test_must_fail git tag -u DEADBEEF -m "Another message" o-signed-tag
 840
 841'
 842
 843cat >fakeeditor <<'EOF'
 844#!/bin/sh
 845test -n "$1" && exec >"$1"
 846echo A signed tag message
 847echo from a fake editor.
 848EOF
 849chmod +x fakeeditor
 850
 851get_tag_header implied-sign $commit commit $time >expect
 852./fakeeditor >>expect
 853echo '-----BEGIN PGP SIGNATURE-----' >>expect
 854test_expect_success GPG '-u implies signed tag' '
 855        GIT_EDITOR=./fakeeditor git tag -u CDDE430D implied-sign &&
 856        get_tag_msg implied-sign >actual &&
 857        test_cmp expect actual
 858'
 859
 860cat >sigmsgfile <<EOF
 861Another signed tag
 862message in a file.
 863EOF
 864get_tag_header file-signed-tag $commit commit $time >expect
 865cat sigmsgfile >>expect
 866echo '-----BEGIN PGP SIGNATURE-----' >>expect
 867test_expect_success GPG \
 868        'creating a signed tag with -F messagefile should succeed' '
 869        git tag -s -F sigmsgfile file-signed-tag &&
 870        get_tag_msg file-signed-tag >actual &&
 871        test_cmp expect actual
 872'
 873
 874cat >siginputmsg <<EOF
 875A signed tag message from
 876the standard input
 877EOF
 878get_tag_header stdin-signed-tag $commit commit $time >expect
 879cat siginputmsg >>expect
 880echo '-----BEGIN PGP SIGNATURE-----' >>expect
 881test_expect_success GPG 'creating a signed tag with -F - should succeed' '
 882        git tag -s -F - stdin-signed-tag <siginputmsg &&
 883        get_tag_msg stdin-signed-tag >actual &&
 884        test_cmp expect actual
 885'
 886
 887get_tag_header implied-annotate $commit commit $time >expect
 888./fakeeditor >>expect
 889echo '-----BEGIN PGP SIGNATURE-----' >>expect
 890test_expect_success GPG '-s implies annotated tag' '
 891        GIT_EDITOR=./fakeeditor git tag -s implied-annotate &&
 892        get_tag_msg implied-annotate >actual &&
 893        test_cmp expect actual
 894'
 895
 896get_tag_header forcesignannotated-implied-sign $commit commit $time >expect
 897echo "A message" >>expect
 898echo '-----BEGIN PGP SIGNATURE-----' >>expect
 899test_expect_success GPG \
 900        'git tag -s implied if configured with tag.forcesignannotated' \
 901        'test_config tag.forcesignannotated true &&
 902        git tag -m "A message" forcesignannotated-implied-sign &&
 903        get_tag_msg forcesignannotated-implied-sign >actual &&
 904        test_cmp expect actual
 905'
 906
 907test_expect_success GPG \
 908        'lightweight with no message when configured with tag.forcesignannotated' \
 909        'test_config tag.forcesignannotated true &&
 910        git tag forcesignannotated-lightweight &&
 911        tag_exists forcesignannotated-lightweight &&
 912        test_must_fail git tag -v forcesignannotated-no-message
 913'
 914
 915get_tag_header forcesignannotated-annotate $commit commit $time >expect
 916echo "A message" >>expect
 917test_expect_success GPG \
 918        'git tag -a disable configured tag.forcesignannotated' \
 919        'test_config tag.forcesignannotated true &&
 920        git tag -a -m "A message" forcesignannotated-annotate &&
 921        get_tag_msg forcesignannotated-annotate >actual &&
 922        test_cmp expect actual &&
 923        test_must_fail git tag -v forcesignannotated-annotate
 924'
 925
 926get_tag_header forcesignannotated-disabled $commit commit $time >expect
 927echo "A message" >>expect
 928echo '-----BEGIN PGP SIGNATURE-----' >>expect
 929test_expect_success GPG \
 930        'git tag --sign enable GPG sign' \
 931        'test_config tag.forcesignannotated false &&
 932        git tag --sign -m "A message" forcesignannotated-disabled &&
 933        get_tag_msg forcesignannotated-disabled >actual &&
 934        test_cmp expect actual
 935'
 936
 937test_expect_success GPG \
 938        'trying to create a signed tag with non-existing -F file should fail' '
 939        ! test -f nonexistingfile &&
 940        ! tag_exists nosigtag &&
 941        test_must_fail git tag -s -F nonexistingfile nosigtag &&
 942        ! tag_exists nosigtag
 943'
 944
 945test_expect_success GPG 'verifying a signed tag should succeed' \
 946        'git tag -v signed-tag'
 947
 948test_expect_success GPG 'verifying two signed tags in one command should succeed' \
 949        'git tag -v signed-tag file-signed-tag'
 950
 951test_expect_success GPG \
 952        'verifying many signed and non-signed tags should fail' '
 953        test_must_fail git tag -v signed-tag annotated-tag &&
 954        test_must_fail git tag -v file-annotated-tag file-signed-tag &&
 955        test_must_fail git tag -v annotated-tag \
 956                file-signed-tag file-annotated-tag &&
 957        test_must_fail git tag -v signed-tag annotated-tag file-signed-tag
 958'
 959
 960test_expect_success GPG 'verifying a forged tag should fail' '
 961        forged=$(git cat-file tag signed-tag |
 962                sed -e "s/signed-tag/forged-tag/" |
 963                git mktag) &&
 964        git tag forged-tag $forged &&
 965        test_must_fail git tag -v forged-tag
 966'
 967
 968test_expect_success GPG 'verifying a proper tag with --format pass and format accordingly' '
 969        cat >expect <<-\EOF &&
 970        tagname : signed-tag
 971        EOF
 972        git tag -v --format="tagname : %(tag)" "signed-tag" >actual &&
 973        test_cmp expect actual
 974'
 975
 976test_expect_success GPG 'verifying a forged tag with --format should fail silently' '
 977        >expect &&
 978        test_must_fail git tag -v --format="tagname : %(tag)" "forged-tag" >actual &&
 979        test_cmp expect actual
 980'
 981
 982# blank and empty messages for signed tags:
 983
 984get_tag_header empty-signed-tag $commit commit $time >expect
 985echo '-----BEGIN PGP SIGNATURE-----' >>expect
 986test_expect_success GPG \
 987        'creating a signed tag with an empty -m message should succeed' '
 988        git tag -s -m "" empty-signed-tag &&
 989        get_tag_msg empty-signed-tag >actual &&
 990        test_cmp expect actual &&
 991        git tag -v empty-signed-tag
 992'
 993
 994>sigemptyfile
 995get_tag_header emptyfile-signed-tag $commit commit $time >expect
 996echo '-----BEGIN PGP SIGNATURE-----' >>expect
 997test_expect_success GPG \
 998        'creating a signed tag with an empty -F messagefile should succeed' '
 999        git tag -s -F sigemptyfile emptyfile-signed-tag &&
1000        get_tag_msg emptyfile-signed-tag >actual &&
1001        test_cmp expect actual &&
1002        git tag -v emptyfile-signed-tag
1003'
1004
1005printf '\n\n  \n\t\nLeading blank lines\n' > sigblanksfile
1006printf '\n\t \t  \nRepeated blank lines\n' >>sigblanksfile
1007printf '\n\n\nTrailing spaces      \t  \n' >>sigblanksfile
1008printf '\nTrailing blank lines\n\n\t \n\n' >>sigblanksfile
1009get_tag_header blanks-signed-tag $commit commit $time >expect
1010cat >>expect <<EOF
1011Leading blank lines
1012
1013Repeated blank lines
1014
1015Trailing spaces
1016
1017Trailing blank lines
1018EOF
1019echo '-----BEGIN PGP SIGNATURE-----' >>expect
1020test_expect_success GPG \
1021        'extra blanks in the message for a signed tag should be removed' '
1022        git tag -s -F sigblanksfile blanks-signed-tag &&
1023        get_tag_msg blanks-signed-tag >actual &&
1024        test_cmp expect actual &&
1025        git tag -v blanks-signed-tag
1026'
1027
1028get_tag_header blank-signed-tag $commit commit $time >expect
1029echo '-----BEGIN PGP SIGNATURE-----' >>expect
1030test_expect_success GPG \
1031        'creating a signed tag with a blank -m message should succeed' '
1032        git tag -s -m "     " blank-signed-tag &&
1033        get_tag_msg blank-signed-tag >actual &&
1034        test_cmp expect actual &&
1035        git tag -v blank-signed-tag
1036'
1037
1038echo '     ' >sigblankfile
1039echo ''      >>sigblankfile
1040echo '  '    >>sigblankfile
1041get_tag_header blankfile-signed-tag $commit commit $time >expect
1042echo '-----BEGIN PGP SIGNATURE-----' >>expect
1043test_expect_success GPG \
1044        'creating a signed tag with blank -F file with spaces should succeed' '
1045        git tag -s -F sigblankfile blankfile-signed-tag &&
1046        get_tag_msg blankfile-signed-tag >actual &&
1047        test_cmp expect actual &&
1048        git tag -v blankfile-signed-tag
1049'
1050
1051printf '      ' >sigblanknonlfile
1052get_tag_header blanknonlfile-signed-tag $commit commit $time >expect
1053echo '-----BEGIN PGP SIGNATURE-----' >>expect
1054test_expect_success GPG \
1055        'creating a signed tag with spaces and no newline should succeed' '
1056        git tag -s -F sigblanknonlfile blanknonlfile-signed-tag &&
1057        get_tag_msg blanknonlfile-signed-tag >actual &&
1058        test_cmp expect actual &&
1059        git tag -v blanknonlfile-signed-tag
1060'
1061
1062test_expect_success GPG 'signed tag with embedded PGP message' '
1063        cat >msg <<-\EOF &&
1064        -----BEGIN PGP MESSAGE-----
1065
1066        this is not a real PGP message
1067        -----END PGP MESSAGE-----
1068        EOF
1069        git tag -s -F msg confusing-pgp-message &&
1070        git tag -v confusing-pgp-message
1071'
1072
1073# messages with commented lines for signed tags:
1074
1075cat >sigcommentsfile <<EOF
1076# A comment
1077
1078############
1079The message.
1080############
1081One line.
1082
1083
1084# commented lines
1085# commented lines
1086
1087Another line.
1088# comments
1089
1090Last line.
1091EOF
1092get_tag_header comments-signed-tag $commit commit $time >expect
1093cat >>expect <<EOF
1094The message.
1095One line.
1096
1097Another line.
1098
1099Last line.
1100EOF
1101echo '-----BEGIN PGP SIGNATURE-----' >>expect
1102test_expect_success GPG \
1103        'creating a signed tag with a -F file with #comments should succeed' '
1104        git tag -s -F sigcommentsfile comments-signed-tag &&
1105        get_tag_msg comments-signed-tag >actual &&
1106        test_cmp expect actual &&
1107        git tag -v comments-signed-tag
1108'
1109
1110get_tag_header comment-signed-tag $commit commit $time >expect
1111echo '-----BEGIN PGP SIGNATURE-----' >>expect
1112test_expect_success GPG \
1113        'creating a signed tag with #commented -m message should succeed' '
1114        git tag -s -m "#comment" comment-signed-tag &&
1115        get_tag_msg comment-signed-tag >actual &&
1116        test_cmp expect actual &&
1117        git tag -v comment-signed-tag
1118'
1119
1120echo '#comment' >sigcommentfile
1121echo ''         >>sigcommentfile
1122echo '####'     >>sigcommentfile
1123get_tag_header commentfile-signed-tag $commit commit $time >expect
1124echo '-----BEGIN PGP SIGNATURE-----' >>expect
1125test_expect_success GPG \
1126        'creating a signed tag with #commented -F messagefile should succeed' '
1127        git tag -s -F sigcommentfile commentfile-signed-tag &&
1128        get_tag_msg commentfile-signed-tag >actual &&
1129        test_cmp expect actual &&
1130        git tag -v commentfile-signed-tag
1131'
1132
1133printf '#comment' >sigcommentnonlfile
1134get_tag_header commentnonlfile-signed-tag $commit commit $time >expect
1135echo '-----BEGIN PGP SIGNATURE-----' >>expect
1136test_expect_success GPG \
1137        'creating a signed tag with a #comment and no newline should succeed' '
1138        git tag -s -F sigcommentnonlfile commentnonlfile-signed-tag &&
1139        get_tag_msg commentnonlfile-signed-tag >actual &&
1140        test_cmp expect actual &&
1141        git tag -v commentnonlfile-signed-tag
1142'
1143
1144# listing messages for signed tags:
1145
1146test_expect_success GPG \
1147        'listing the one-line message of a signed tag should succeed' '
1148        git tag -s -m "A message line signed" stag-one-line &&
1149
1150        echo "stag-one-line" >expect &&
1151        git tag -l | grep "^stag-one-line" >actual &&
1152        test_cmp expect actual &&
1153        git tag -n0 -l | grep "^stag-one-line" >actual &&
1154        test_cmp expect actual &&
1155        git tag -n0 -l stag-one-line >actual &&
1156        test_cmp expect actual &&
1157
1158        echo "stag-one-line   A message line signed" >expect &&
1159        git tag -n1 -l | grep "^stag-one-line" >actual &&
1160        test_cmp expect actual &&
1161        git tag -n -l | grep "^stag-one-line" >actual &&
1162        test_cmp expect actual &&
1163        git tag -n1 -l stag-one-line >actual &&
1164        test_cmp expect actual &&
1165        git tag -n2 -l stag-one-line >actual &&
1166        test_cmp expect actual &&
1167        git tag -n999 -l stag-one-line >actual &&
1168        test_cmp expect actual
1169'
1170
1171test_expect_success GPG \
1172        'listing the zero-lines message of a signed tag should succeed' '
1173        git tag -s -m "" stag-zero-lines &&
1174
1175        echo "stag-zero-lines" >expect &&
1176        git tag -l | grep "^stag-zero-lines" >actual &&
1177        test_cmp expect actual &&
1178        git tag -n0 -l | grep "^stag-zero-lines" >actual &&
1179        test_cmp expect actual &&
1180        git tag -n0 -l stag-zero-lines >actual &&
1181        test_cmp expect actual &&
1182
1183        echo "stag-zero-lines " >expect &&
1184        git tag -n1 -l | grep "^stag-zero-lines" >actual &&
1185        test_cmp expect actual &&
1186        git tag -n -l | grep "^stag-zero-lines" >actual &&
1187        test_cmp expect actual &&
1188        git tag -n1 -l stag-zero-lines >actual &&
1189        test_cmp expect actual &&
1190        git tag -n2 -l stag-zero-lines >actual &&
1191        test_cmp expect actual &&
1192        git tag -n999 -l stag-zero-lines >actual &&
1193        test_cmp expect actual
1194'
1195
1196echo 'stag line one' >sigtagmsg
1197echo 'stag line two' >>sigtagmsg
1198echo 'stag line three' >>sigtagmsg
1199test_expect_success GPG \
1200        'listing many message lines of a signed tag should succeed' '
1201        git tag -s -F sigtagmsg stag-lines &&
1202
1203        echo "stag-lines" >expect &&
1204        git tag -l | grep "^stag-lines" >actual &&
1205        test_cmp expect actual &&
1206        git tag -n0 -l | grep "^stag-lines" >actual &&
1207        test_cmp expect actual &&
1208        git tag -n0 -l stag-lines >actual &&
1209        test_cmp expect actual &&
1210
1211        echo "stag-lines      stag line one" >expect &&
1212        git tag -n1 -l | grep "^stag-lines" >actual &&
1213        test_cmp expect actual &&
1214        git tag -n -l | grep "^stag-lines" >actual &&
1215        test_cmp expect actual &&
1216        git tag -n1 -l stag-lines >actual &&
1217        test_cmp expect actual &&
1218
1219        echo "    stag line two" >>expect &&
1220        git tag -n2 -l | grep "^ *stag.line" >actual &&
1221        test_cmp expect actual &&
1222        git tag -n2 -l stag-lines >actual &&
1223        test_cmp expect actual &&
1224
1225        echo "    stag line three" >>expect &&
1226        git tag -n3 -l | grep "^ *stag.line" >actual &&
1227        test_cmp expect actual &&
1228        git tag -n3 -l stag-lines >actual &&
1229        test_cmp expect actual &&
1230        git tag -n4 -l | grep "^ *stag.line" >actual &&
1231        test_cmp expect actual &&
1232        git tag -n4 -l stag-lines >actual &&
1233        test_cmp expect actual &&
1234        git tag -n99 -l | grep "^ *stag.line" >actual &&
1235        test_cmp expect actual &&
1236        git tag -n99 -l stag-lines >actual &&
1237        test_cmp expect actual
1238'
1239
1240# tags pointing to objects different from commits:
1241
1242tree=$(git rev-parse HEAD^{tree})
1243blob=$(git rev-parse HEAD:foo)
1244tag=$(git rev-parse signed-tag 2>/dev/null)
1245
1246get_tag_header tree-signed-tag $tree tree $time >expect
1247echo "A message for a tree" >>expect
1248echo '-----BEGIN PGP SIGNATURE-----' >>expect
1249test_expect_success GPG \
1250        'creating a signed tag pointing to a tree should succeed' '
1251        git tag -s -m "A message for a tree" tree-signed-tag HEAD^{tree} &&
1252        get_tag_msg tree-signed-tag >actual &&
1253        test_cmp expect actual
1254'
1255
1256get_tag_header blob-signed-tag $blob blob $time >expect
1257echo "A message for a blob" >>expect
1258echo '-----BEGIN PGP SIGNATURE-----' >>expect
1259test_expect_success GPG \
1260        'creating a signed tag pointing to a blob should succeed' '
1261        git tag -s -m "A message for a blob" blob-signed-tag HEAD:foo &&
1262        get_tag_msg blob-signed-tag >actual &&
1263        test_cmp expect actual
1264'
1265
1266get_tag_header tag-signed-tag $tag tag $time >expect
1267echo "A message for another tag" >>expect
1268echo '-----BEGIN PGP SIGNATURE-----' >>expect
1269test_expect_success GPG \
1270        'creating a signed tag pointing to another tag should succeed' '
1271        git tag -s -m "A message for another tag" tag-signed-tag signed-tag &&
1272        get_tag_msg tag-signed-tag >actual &&
1273        test_cmp expect actual
1274'
1275
1276# usage with rfc1991 signatures
1277get_tag_header rfc1991-signed-tag $commit commit $time >expect
1278echo "RFC1991 signed tag" >>expect
1279echo '-----BEGIN PGP MESSAGE-----' >>expect
1280test_expect_success GPG,RFC1991 \
1281        'creating a signed tag with rfc1991' '
1282        echo "rfc1991" >gpghome/gpg.conf &&
1283        git tag -s -m "RFC1991 signed tag" rfc1991-signed-tag $commit &&
1284        get_tag_msg rfc1991-signed-tag >actual &&
1285        test_cmp expect actual
1286'
1287
1288cat >fakeeditor <<'EOF'
1289#!/bin/sh
1290cp "$1" actual
1291EOF
1292chmod +x fakeeditor
1293
1294test_expect_success GPG,RFC1991 \
1295        'reediting a signed tag body omits signature' '
1296        echo "rfc1991" >gpghome/gpg.conf &&
1297        echo "RFC1991 signed tag" >expect &&
1298        GIT_EDITOR=./fakeeditor git tag -f -s rfc1991-signed-tag $commit &&
1299        test_cmp expect actual
1300'
1301
1302test_expect_success GPG,RFC1991 \
1303        'verifying rfc1991 signature' '
1304        echo "rfc1991" >gpghome/gpg.conf &&
1305        git tag -v rfc1991-signed-tag
1306'
1307
1308test_expect_success GPG,RFC1991 \
1309        'list tag with rfc1991 signature' '
1310        echo "rfc1991" >gpghome/gpg.conf &&
1311        echo "rfc1991-signed-tag RFC1991 signed tag" >expect &&
1312        git tag -l -n1 rfc1991-signed-tag >actual &&
1313        test_cmp expect actual &&
1314        git tag -l -n2 rfc1991-signed-tag >actual &&
1315        test_cmp expect actual &&
1316        git tag -l -n999 rfc1991-signed-tag >actual &&
1317        test_cmp expect actual
1318'
1319
1320rm -f gpghome/gpg.conf
1321
1322test_expect_success GPG,RFC1991 \
1323        'verifying rfc1991 signature without --rfc1991' '
1324        git tag -v rfc1991-signed-tag
1325'
1326
1327test_expect_success GPG,RFC1991 \
1328        'list tag with rfc1991 signature without --rfc1991' '
1329        echo "rfc1991-signed-tag RFC1991 signed tag" >expect &&
1330        git tag -l -n1 rfc1991-signed-tag >actual &&
1331        test_cmp expect actual &&
1332        git tag -l -n2 rfc1991-signed-tag >actual &&
1333        test_cmp expect actual &&
1334        git tag -l -n999 rfc1991-signed-tag >actual &&
1335        test_cmp expect actual
1336'
1337
1338test_expect_success GPG,RFC1991 \
1339        'reediting a signed tag body omits signature' '
1340        echo "RFC1991 signed tag" >expect &&
1341        GIT_EDITOR=./fakeeditor git tag -f -s rfc1991-signed-tag $commit &&
1342        test_cmp expect actual
1343'
1344
1345# try to sign with bad user.signingkey
1346test_expect_success GPG \
1347        'git tag -s fails if gpg is misconfigured (bad key)' \
1348        'test_config user.signingkey BobTheMouse &&
1349        test_must_fail git tag -s -m tail tag-gpg-failure'
1350
1351# try to produce invalid signature
1352test_expect_success GPG \
1353        'git tag -s fails if gpg is misconfigured (bad signature format)' \
1354        'test_config gpg.program echo &&
1355         test_must_fail git tag -s -m tail tag-gpg-failure'
1356
1357
1358# try to verify without gpg:
1359
1360rm -rf gpghome
1361test_expect_success GPG \
1362        'verify signed tag fails when public key is not present' \
1363        'test_must_fail git tag -v signed-tag'
1364
1365test_expect_success \
1366        'git tag -a fails if tag annotation is empty' '
1367        ! (GIT_EDITOR=cat git tag -a initial-comment)
1368'
1369
1370test_expect_success \
1371        'message in editor has initial comment' '
1372        ! (GIT_EDITOR=cat git tag -a initial-comment > actual)
1373'
1374
1375test_expect_success 'message in editor has initial comment: first line' '
1376        # check the first line --- should be empty
1377        echo >first.expect &&
1378        sed -e 1q <actual >first.actual &&
1379        test_i18ncmp first.expect first.actual
1380'
1381
1382test_expect_success \
1383        'message in editor has initial comment: remainder' '
1384        # remove commented lines from the remainder -- should be empty
1385        >rest.expect &&
1386        sed -e 1d -e "/^#/d" <actual >rest.actual &&
1387        test_cmp rest.expect rest.actual
1388'
1389
1390get_tag_header reuse $commit commit $time >expect
1391echo "An annotation to be reused" >> expect
1392test_expect_success \
1393        'overwriting an annoted tag should use its previous body' '
1394        git tag -a -m "An annotation to be reused" reuse &&
1395        GIT_EDITOR=true git tag -f -a reuse &&
1396        get_tag_msg reuse >actual &&
1397        test_cmp expect actual
1398'
1399
1400test_expect_success 'filename for the message is relative to cwd' '
1401        mkdir subdir &&
1402        echo "Tag message in top directory" >msgfile-5 &&
1403        echo "Tag message in sub directory" >subdir/msgfile-5 &&
1404        (
1405                cd subdir &&
1406                git tag -a -F msgfile-5 tag-from-subdir
1407        ) &&
1408        git cat-file tag tag-from-subdir | grep "in sub directory"
1409'
1410
1411test_expect_success 'filename for the message is relative to cwd' '
1412        echo "Tag message in sub directory" >subdir/msgfile-6 &&
1413        (
1414                cd subdir &&
1415                git tag -a -F msgfile-6 tag-from-subdir-2
1416        ) &&
1417        git cat-file tag tag-from-subdir-2 | grep "in sub directory"
1418'
1419
1420# create a few more commits to test --contains
1421
1422hash1=$(git rev-parse HEAD)
1423
1424test_expect_success 'creating second commit and tag' '
1425        echo foo-2.0 >foo &&
1426        git add foo &&
1427        git commit -m second &&
1428        git tag v2.0
1429'
1430
1431hash2=$(git rev-parse HEAD)
1432
1433test_expect_success 'creating third commit without tag' '
1434        echo foo-dev >foo &&
1435        git add foo &&
1436        git commit -m third
1437'
1438
1439hash3=$(git rev-parse HEAD)
1440
1441# simple linear checks of --continue
1442
1443cat > expected <<EOF
1444v0.2.1
1445v1.0
1446v1.0.1
1447v1.1.3
1448v2.0
1449EOF
1450
1451test_expect_success 'checking that first commit is in all tags (hash)' "
1452        git tag -l --contains $hash1 v* >actual &&
1453        test_cmp expected actual
1454"
1455
1456# other ways of specifying the commit
1457test_expect_success 'checking that first commit is in all tags (tag)' "
1458        git tag -l --contains v1.0 v* >actual &&
1459        test_cmp expected actual
1460"
1461
1462test_expect_success 'checking that first commit is in all tags (relative)' "
1463        git tag -l --contains HEAD~2 v* >actual &&
1464        test_cmp expected actual
1465"
1466
1467# All the --contains tests above, but with --no-contains
1468test_expect_success 'checking that first commit is not listed in any tag with --no-contains  (hash)' "
1469        >expected &&
1470        git tag -l --no-contains $hash1 v* >actual &&
1471        test_cmp expected actual
1472"
1473
1474test_expect_success 'checking that first commit is in all tags (tag)' "
1475        git tag -l --no-contains v1.0 v* >actual &&
1476        test_cmp expected actual
1477"
1478
1479test_expect_success 'checking that first commit is in all tags (relative)' "
1480        git tag -l --no-contains HEAD~2 v* >actual &&
1481        test_cmp expected actual
1482"
1483
1484cat > expected <<EOF
1485v2.0
1486EOF
1487
1488test_expect_success 'checking that second commit only has one tag' "
1489        git tag -l --contains $hash2 v* >actual &&
1490        test_cmp expected actual
1491"
1492
1493cat > expected <<EOF
1494v0.2.1
1495v1.0
1496v1.0.1
1497v1.1.3
1498EOF
1499
1500test_expect_success 'inverse of the last test, with --no-contains' "
1501        git tag -l --no-contains $hash2 v* >actual &&
1502        test_cmp expected actual
1503"
1504
1505cat > expected <<EOF
1506EOF
1507
1508test_expect_success 'checking that third commit has no tags' "
1509        git tag -l --contains $hash3 v* >actual &&
1510        test_cmp expected actual
1511"
1512
1513cat > expected <<EOF
1514v0.2.1
1515v1.0
1516v1.0.1
1517v1.1.3
1518v2.0
1519EOF
1520
1521test_expect_success 'conversely --no-contains on the third commit lists all tags' "
1522        git tag -l --no-contains $hash3 v* >actual &&
1523        test_cmp expected actual
1524"
1525
1526# how about a simple merge?
1527
1528test_expect_success 'creating simple branch' '
1529        git branch stable v2.0 &&
1530        git checkout stable &&
1531        echo foo-3.0 > foo &&
1532        git commit foo -m fourth &&
1533        git tag v3.0
1534'
1535
1536hash4=$(git rev-parse HEAD)
1537
1538cat > expected <<EOF
1539v3.0
1540EOF
1541
1542test_expect_success 'checking that branch head only has one tag' "
1543        git tag -l --contains $hash4 v* >actual &&
1544        test_cmp expected actual
1545"
1546
1547cat > expected <<EOF
1548v0.2.1
1549v1.0
1550v1.0.1
1551v1.1.3
1552v2.0
1553EOF
1554
1555test_expect_success 'checking that branch head with --no-contains lists all but one tag' "
1556        git tag -l --no-contains $hash4 v* >actual &&
1557        test_cmp expected actual
1558"
1559
1560test_expect_success 'merging original branch into this branch' '
1561        git merge --strategy=ours master &&
1562        git tag v4.0
1563'
1564
1565cat > expected <<EOF
1566v4.0
1567EOF
1568
1569test_expect_success 'checking that original branch head has one tag now' "
1570        git tag -l --contains $hash3 v* >actual &&
1571        test_cmp expected actual
1572"
1573
1574cat > expected <<EOF
1575v0.2.1
1576v1.0
1577v1.0.1
1578v1.1.3
1579v2.0
1580v3.0
1581EOF
1582
1583test_expect_success 'checking that original branch head with --no-contains lists all but one tag now' "
1584        git tag -l --no-contains $hash3 v* >actual &&
1585        test_cmp expected actual
1586"
1587
1588cat > expected <<EOF
1589v0.2.1
1590v1.0
1591v1.0.1
1592v1.1.3
1593v2.0
1594v3.0
1595v4.0
1596EOF
1597
1598test_expect_success 'checking that initial commit is in all tags' "
1599        git tag -l --contains $hash1 v* >actual &&
1600        test_cmp expected actual
1601"
1602
1603test_expect_success 'checking that --contains can be used in non-list mode' '
1604        git tag --contains $hash1 v* >actual &&
1605        test_cmp expected actual
1606'
1607
1608test_expect_success 'checking that initial commit is in all tags with --no-contains' "
1609        >expected &&
1610        git tag -l --no-contains $hash1 v* >actual &&
1611        test_cmp expected actual
1612"
1613
1614# mixing modes and options:
1615
1616test_expect_success 'mixing incompatibles modes and options is forbidden' '
1617        test_must_fail git tag -a &&
1618        test_must_fail git tag -a -l &&
1619        test_must_fail git tag -s &&
1620        test_must_fail git tag -s -l &&
1621        test_must_fail git tag -m &&
1622        test_must_fail git tag -m -l &&
1623        test_must_fail git tag -m "hlagh" &&
1624        test_must_fail git tag -m "hlagh" -l &&
1625        test_must_fail git tag -F &&
1626        test_must_fail git tag -F -l &&
1627        test_must_fail git tag -f &&
1628        test_must_fail git tag -f -l &&
1629        test_must_fail git tag -a -s -m -F &&
1630        test_must_fail git tag -a -s -m -F -l &&
1631        test_must_fail git tag -l -v &&
1632        test_must_fail git tag -l -d &&
1633        test_must_fail git tag -l -v -d &&
1634        test_must_fail git tag -n 100 -v &&
1635        test_must_fail git tag -l -m msg &&
1636        test_must_fail git tag -l -F some file &&
1637        test_must_fail git tag -v -s &&
1638        test_must_fail git tag --contains tag-tree &&
1639        test_must_fail git tag --contains tag-blob &&
1640        test_must_fail git tag --no-contains tag-tree &&
1641        test_must_fail git tag --no-contains tag-blob &&
1642        test_must_fail git tag --contains --no-contains &&
1643        test_must_fail git tag --no-with HEAD &&
1644        test_must_fail git tag --no-without HEAD
1645'
1646
1647for option in --contains --with --no-contains --without --merged --no-merged --points-at
1648do
1649        test_expect_success "mixing incompatible modes with $option is forbidden" "
1650                test_must_fail git tag -d $option HEAD &&
1651                test_must_fail git tag -d $option HEAD some-tag &&
1652                test_must_fail git tag -v $option HEAD
1653        "
1654        test_expect_success "Doing 'git tag --list-like $option <commit> <pattern> is permitted" "
1655                git tag -n $option HEAD HEAD &&
1656                git tag $option HEAD HEAD &&
1657                git tag $option
1658        "
1659done
1660
1661# check points-at
1662
1663test_expect_success '--points-at can be used in non-list mode' '
1664        echo v4.0 >expect &&
1665        git tag --points-at=v4.0 "v*" >actual &&
1666        test_cmp expect actual
1667'
1668
1669test_expect_success '--points-at is a synonym for --points-at HEAD' '
1670        echo v4.0 >expect &&
1671        git tag --points-at >actual &&
1672        test_cmp expect actual
1673'
1674
1675test_expect_success '--points-at finds lightweight tags' '
1676        echo v4.0 >expect &&
1677        git tag --points-at v4.0 >actual &&
1678        test_cmp expect actual
1679'
1680
1681test_expect_success '--points-at finds annotated tags of commits' '
1682        git tag -m "v4.0, annotated" annotated-v4.0 v4.0 &&
1683        echo annotated-v4.0 >expect &&
1684        git tag -l --points-at v4.0 "annotated*" >actual &&
1685        test_cmp expect actual
1686'
1687
1688test_expect_success '--points-at finds annotated tags of tags' '
1689        git tag -m "describing the v4.0 tag object" \
1690                annotated-again-v4.0 annotated-v4.0 &&
1691        cat >expect <<-\EOF &&
1692        annotated-again-v4.0
1693        annotated-v4.0
1694        EOF
1695        git tag --points-at=annotated-v4.0 >actual &&
1696        test_cmp expect actual
1697'
1698
1699test_expect_success 'multiple --points-at are OR-ed together' '
1700        cat >expect <<-\EOF &&
1701        v2.0
1702        v3.0
1703        EOF
1704        git tag --points-at=v2.0 --points-at=v3.0 >actual &&
1705        test_cmp expect actual
1706'
1707
1708test_expect_success 'lexical sort' '
1709        git tag foo1.3 &&
1710        git tag foo1.6 &&
1711        git tag foo1.10 &&
1712        git tag -l --sort=refname "foo*" >actual &&
1713        cat >expect <<-\EOF &&
1714        foo1.10
1715        foo1.3
1716        foo1.6
1717        EOF
1718        test_cmp expect actual
1719'
1720
1721test_expect_success 'version sort' '
1722        git tag -l --sort=version:refname "foo*" >actual &&
1723        cat >expect <<-\EOF &&
1724        foo1.3
1725        foo1.6
1726        foo1.10
1727        EOF
1728        test_cmp expect actual
1729'
1730
1731test_expect_success 'reverse version sort' '
1732        git tag -l --sort=-version:refname "foo*" >actual &&
1733        cat >expect <<-\EOF &&
1734        foo1.10
1735        foo1.6
1736        foo1.3
1737        EOF
1738        test_cmp expect actual
1739'
1740
1741test_expect_success 'reverse lexical sort' '
1742        git tag -l --sort=-refname "foo*" >actual &&
1743        cat >expect <<-\EOF &&
1744        foo1.6
1745        foo1.3
1746        foo1.10
1747        EOF
1748        test_cmp expect actual
1749'
1750
1751test_expect_success 'configured lexical sort' '
1752        test_config tag.sort "v:refname" &&
1753        git tag -l "foo*" >actual &&
1754        cat >expect <<-\EOF &&
1755        foo1.3
1756        foo1.6
1757        foo1.10
1758        EOF
1759        test_cmp expect actual
1760'
1761
1762test_expect_success 'option override configured sort' '
1763        test_config tag.sort "v:refname" &&
1764        git tag -l --sort=-refname "foo*" >actual &&
1765        cat >expect <<-\EOF &&
1766        foo1.6
1767        foo1.3
1768        foo1.10
1769        EOF
1770        test_cmp expect actual
1771'
1772
1773test_expect_success 'invalid sort parameter on command line' '
1774        test_must_fail git tag -l --sort=notvalid "foo*" >actual
1775'
1776
1777test_expect_success 'invalid sort parameter in configuratoin' '
1778        test_config tag.sort "v:notvalid" &&
1779        test_must_fail git tag -l "foo*"
1780'
1781
1782test_expect_success 'version sort with prerelease reordering' '
1783        test_config versionsort.prereleaseSuffix -rc &&
1784        git tag foo1.6-rc1 &&
1785        git tag foo1.6-rc2 &&
1786        git tag -l --sort=version:refname "foo*" >actual &&
1787        cat >expect <<-\EOF &&
1788        foo1.3
1789        foo1.6-rc1
1790        foo1.6-rc2
1791        foo1.6
1792        foo1.10
1793        EOF
1794        test_cmp expect actual
1795'
1796
1797test_expect_success 'reverse version sort with prerelease reordering' '
1798        test_config versionsort.prereleaseSuffix -rc &&
1799        git tag -l --sort=-version:refname "foo*" >actual &&
1800        cat >expect <<-\EOF &&
1801        foo1.10
1802        foo1.6
1803        foo1.6-rc2
1804        foo1.6-rc1
1805        foo1.3
1806        EOF
1807        test_cmp expect actual
1808'
1809
1810test_expect_success 'version sort with prerelease reordering and common leading character' '
1811        test_config versionsort.prereleaseSuffix -before &&
1812        git tag foo1.7-before1 &&
1813        git tag foo1.7 &&
1814        git tag foo1.7-after1 &&
1815        git tag -l --sort=version:refname "foo1.7*" >actual &&
1816        cat >expect <<-\EOF &&
1817        foo1.7-before1
1818        foo1.7
1819        foo1.7-after1
1820        EOF
1821        test_cmp expect actual
1822'
1823
1824test_expect_success 'version sort with prerelease reordering, multiple suffixes and common leading character' '
1825        test_config versionsort.prereleaseSuffix -before &&
1826        git config --add versionsort.prereleaseSuffix -after &&
1827        git tag -l --sort=version:refname "foo1.7*" >actual &&
1828        cat >expect <<-\EOF &&
1829        foo1.7-before1
1830        foo1.7-after1
1831        foo1.7
1832        EOF
1833        test_cmp expect actual
1834'
1835
1836test_expect_success 'version sort with prerelease reordering, multiple suffixes match the same tag' '
1837        test_config versionsort.prereleaseSuffix -bar &&
1838        git config --add versionsort.prereleaseSuffix -foo-baz &&
1839        git config --add versionsort.prereleaseSuffix -foo-bar &&
1840        git tag foo1.8-foo-bar &&
1841        git tag foo1.8-foo-baz &&
1842        git tag foo1.8 &&
1843        git tag -l --sort=version:refname "foo1.8*" >actual &&
1844        cat >expect <<-\EOF &&
1845        foo1.8-foo-baz
1846        foo1.8-foo-bar
1847        foo1.8
1848        EOF
1849        test_cmp expect actual
1850'
1851
1852test_expect_success 'version sort with prerelease reordering, multiple suffixes match starting at the same position' '
1853        test_config versionsort.prereleaseSuffix -pre &&
1854        git config --add versionsort.prereleaseSuffix -prerelease &&
1855        git tag foo1.9-pre1 &&
1856        git tag foo1.9-pre2 &&
1857        git tag foo1.9-prerelease1 &&
1858        git tag -l --sort=version:refname "foo1.9*" >actual &&
1859        cat >expect <<-\EOF &&
1860        foo1.9-pre1
1861        foo1.9-pre2
1862        foo1.9-prerelease1
1863        EOF
1864        test_cmp expect actual
1865'
1866
1867test_expect_success 'version sort with general suffix reordering' '
1868        test_config versionsort.suffix -alpha &&
1869        git config --add versionsort.suffix -beta &&
1870        git config --add versionsort.suffix ""  &&
1871        git config --add versionsort.suffix -gamma &&
1872        git config --add versionsort.suffix -delta &&
1873        git tag foo1.10-alpha &&
1874        git tag foo1.10-beta &&
1875        git tag foo1.10-gamma &&
1876        git tag foo1.10-delta &&
1877        git tag foo1.10-unlisted-suffix &&
1878        git tag -l --sort=version:refname "foo1.10*" >actual &&
1879        cat >expect <<-\EOF &&
1880        foo1.10-alpha
1881        foo1.10-beta
1882        foo1.10
1883        foo1.10-unlisted-suffix
1884        foo1.10-gamma
1885        foo1.10-delta
1886        EOF
1887        test_cmp expect actual
1888'
1889
1890test_expect_success 'versionsort.suffix overrides versionsort.prereleaseSuffix' '
1891        test_config versionsort.suffix -before &&
1892        test_config versionsort.prereleaseSuffix -after &&
1893        git tag -l --sort=version:refname "foo1.7*" >actual &&
1894        cat >expect <<-\EOF &&
1895        foo1.7-before1
1896        foo1.7
1897        foo1.7-after1
1898        EOF
1899        test_cmp expect actual
1900'
1901
1902test_expect_success 'version sort with very long prerelease suffix' '
1903        test_config versionsort.prereleaseSuffix -very-looooooooooooooooooooooooong-prerelease-suffix &&
1904        git tag -l --sort=version:refname
1905'
1906
1907test_expect_success ULIMIT_STACK_SIZE '--contains and --no-contains work in a deep repo' '
1908        >expect &&
1909        i=1 &&
1910        while test $i -lt 8000
1911        do
1912                echo "commit refs/heads/master
1913committer A U Thor <author@example.com> $((1000000000 + $i * 100)) +0200
1914data <<EOF
1915commit #$i
1916EOF"
1917                test $i = 1 && echo "from refs/heads/master^0"
1918                i=$(($i + 1))
1919        done | git fast-import &&
1920        git checkout master &&
1921        git tag far-far-away HEAD^ &&
1922        run_with_limited_stack git tag --contains HEAD >actual &&
1923        test_cmp expect actual &&
1924        run_with_limited_stack git tag --no-contains HEAD >actual &&
1925        test_line_count "-gt" 10 actual
1926'
1927
1928test_expect_success '--format should list tags as per format given' '
1929        cat >expect <<-\EOF &&
1930        refname : refs/tags/v1.0
1931        refname : refs/tags/v1.0.1
1932        refname : refs/tags/v1.1.3
1933        EOF
1934        git tag -l --format="refname : %(refname)" "v1*" >actual &&
1935        test_cmp expect actual
1936'
1937
1938test_expect_success "set up color tests" '
1939        echo "<RED>v1.0<RESET>" >expect.color &&
1940        echo "v1.0" >expect.bare &&
1941        color_args="--format=%(color:red)%(refname:short) --list v1.0"
1942'
1943
1944test_expect_success '%(color) omitted without tty' '
1945        TERM=vt100 git tag $color_args >actual.raw &&
1946        test_decode_color <actual.raw >actual &&
1947        test_cmp expect.bare actual
1948'
1949
1950test_expect_success TTY '%(color) present with tty' '
1951        test_terminal git tag $color_args >actual.raw &&
1952        test_decode_color <actual.raw >actual &&
1953        test_cmp expect.color actual
1954'
1955
1956test_expect_success '--color overrides auto-color' '
1957        git tag --color $color_args >actual.raw &&
1958        test_decode_color <actual.raw >actual &&
1959        test_cmp expect.color actual
1960'
1961
1962test_expect_success 'color.ui=always overrides auto-color' '
1963        git -c color.ui=always tag $color_args >actual.raw &&
1964        test_decode_color <actual.raw >actual &&
1965        test_cmp expect.color actual
1966'
1967
1968test_expect_success 'setup --merged test tags' '
1969        git tag mergetest-1 HEAD~2 &&
1970        git tag mergetest-2 HEAD~1 &&
1971        git tag mergetest-3 HEAD
1972'
1973
1974test_expect_success '--merged can be used in non-list mode' '
1975        cat >expect <<-\EOF &&
1976        mergetest-1
1977        mergetest-2
1978        EOF
1979        git tag --merged=mergetest-2 "mergetest*" >actual &&
1980        test_cmp expect actual
1981'
1982
1983test_expect_success '--merged is incompatible with --no-merged' '
1984        test_must_fail git tag --merged HEAD --no-merged HEAD
1985'
1986
1987test_expect_success '--merged shows merged tags' '
1988        cat >expect <<-\EOF &&
1989        mergetest-1
1990        mergetest-2
1991        EOF
1992        git tag -l --merged=mergetest-2 mergetest-* >actual &&
1993        test_cmp expect actual
1994'
1995
1996test_expect_success '--no-merged show unmerged tags' '
1997        cat >expect <<-\EOF &&
1998        mergetest-3
1999        EOF
2000        git tag -l --no-merged=mergetest-2 mergetest-* >actual &&
2001        test_cmp expect actual
2002'
2003
2004test_expect_success '--no-merged can be used in non-list mode' '
2005        git tag --no-merged=mergetest-2 mergetest-* >actual &&
2006        test_cmp expect actual
2007'
2008
2009test_expect_success 'ambiguous branch/tags not marked' '
2010        git tag ambiguous &&
2011        git branch ambiguous &&
2012        echo ambiguous >expect &&
2013        git tag -l ambiguous >actual &&
2014        test_cmp expect actual
2015'
2016
2017test_expect_success '--contains combined with --no-contains' '
2018        (
2019                git init no-contains &&
2020                cd no-contains &&
2021                test_commit v0.1 &&
2022                test_commit v0.2 &&
2023                test_commit v0.3 &&
2024                test_commit v0.4 &&
2025                test_commit v0.5 &&
2026                cat >expected <<-\EOF &&
2027                v0.2
2028                v0.3
2029                v0.4
2030                EOF
2031                git tag --contains v0.2 --no-contains v0.5 >actual &&
2032                test_cmp expected actual
2033        )
2034'
2035
2036# As the docs say, list tags which contain a specified *commit*. We
2037# don't recurse down to tags for trees or blobs pointed to by *those*
2038# commits.
2039test_expect_success 'Does --[no-]contains stop at commits? Yes!' '
2040        cd no-contains &&
2041        blob=$(git rev-parse v0.3:v0.3.t) &&
2042        tree=$(git rev-parse v0.3^{tree}) &&
2043        git tag tag-blob $blob &&
2044        git tag tag-tree $tree &&
2045        git tag --contains v0.3 >actual &&
2046        cat >expected <<-\EOF &&
2047        v0.3
2048        v0.4
2049        v0.5
2050        EOF
2051        test_cmp expected actual &&
2052        git tag --no-contains v0.3 >actual &&
2053        cat >expected <<-\EOF &&
2054        v0.1
2055        v0.2
2056        EOF
2057        test_cmp expected actual
2058'
2059
2060test_done