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