3 # Copyright (c) 2007 Lars Hjemli
 
   6 test_description='git merge
 
   8 Testing basic merge operations/option parsing.
 
  17        * [master] Merge commit 'c1'
 
  19        - [master] Merge commit 'c1'
 
  26 +++++++* [c0] commit 0
 
  30 . "$TEST_DIRECTORY"/lib-gpg.sh
 
  32 printf '%s\n' 1 2 3 4 5 6 7 8 9 >file
 
  33 printf '%s\n' '1 X' 2 3 4 5 6 7 8 9 >file.1
 
  34 printf '%s\n' 1 2 3 4 '5 X' 6 7 8 9 >file.5
 
  35 printf '%s\n' 1 2 3 4 5 6 7 8 '9 X' >file.9
 
  36 printf '%s\n' 1 2 3 4 5 6 7 8 '9 Y' >file.9y
 
  37 printf '%s\n' '1 X' 2 3 4 5 6 7 8 9 >result.1
 
  38 printf '%s\n' '1 X' 2 3 4 '5 X' 6 7 8 9 >result.1-5
 
  39 printf '%s\n' '1 X' 2 3 4 '5 X' 6 7 8 '9 X' >result.1-5-9
 
  40 printf '%s\n' 1 2 3 4 5 6 7 8 '9 Z' >result.9z
 
  42 create_merge_msgs () {
 
  43         echo "Merge tag 'c2'" >msg.1-5 &&
 
  44         echo "Merge tags 'c2' and 'c3'" >msg.1-5-9 &&
 
  46                 echo "Squashed commit of the following:" &&
 
  48                 git log --no-merges ^HEAD c1
 
  51                 echo "Squashed commit of the following:" &&
 
  53                 git log --no-merges ^HEAD c2
 
  56                 echo "Squashed commit of the following:" &&
 
  58                 git log --no-merges ^HEAD c2 c3
 
  68         git update-index --refresh &&
 
  69         git diff --exit-code &&
 
  72                 git show -s --pretty=tformat:%s HEAD >msg.act &&
 
  78         echo "$1" >head.expected &&
 
  79         git rev-parse HEAD >head.actual &&
 
  80         test_cmp head.expected head.actual
 
  84         printf '%s\n' "$@" >parents.expected &&
 
  89                 git rev-parse HEAD^$i >>parents.actual &&
 
  93         test_must_fail git rev-parse --verify "HEAD^$i" &&
 
  94         test_cmp parents.expected parents.actual
 
  97 verify_mergeheads () {
 
  98         printf '%s\n' "$@" >mergehead.expected &&
 
 102         done <.git/MERGE_HEAD >mergehead.actual &&
 
 103         test_cmp mergehead.expected mergehead.actual
 
 106 verify_no_mergehead () {
 
 107         ! test -e .git/MERGE_HEAD
 
 110 test_expect_success 'setup' '
 
 113         git commit -m "commit 0" &&
 
 115         c0=$(git rev-parse HEAD) &&
 
 119         git commit -m "commit 1" &&
 
 121         c1=$(git rev-parse HEAD) &&
 
 122         git reset --hard "$c0" &&
 
 126         git commit -m "commit 2" &&
 
 128         c2=$(git rev-parse HEAD) &&
 
 129         git reset --hard "$c0" &&
 
 133         git commit -m "commit 7" &&
 
 135         git reset --hard "$c0" &&
 
 139         git commit -m "commit 3" &&
 
 141         c3=$(git rev-parse HEAD) &&
 
 142         git reset --hard "$c0" &&
 
 146 test_debug 'git log --graph --decorate --oneline --all'
 
 148 test_expect_success 'test option parsing' '
 
 149         test_must_fail git merge -$ c1 &&
 
 150         test_must_fail git merge --no-such c1 &&
 
 151         test_must_fail git merge -s foobar c1 &&
 
 152         test_must_fail git merge -s=foobar c1 &&
 
 153         test_must_fail git merge -m &&
 
 154         test_must_fail git merge --abort foobar &&
 
 155         test_must_fail git merge --abort --quiet &&
 
 156         test_must_fail git merge --continue foobar &&
 
 157         test_must_fail git merge --continue --quiet &&
 
 158         test_must_fail git merge
 
 161 test_expect_success 'merge -h with invalid index' '
 
 167                 test_expect_code 129 git merge -h 2>usage
 
 169         test_i18ngrep "[Uu]sage: git merge" broken/usage
 
 172 test_expect_success 'reject non-strategy with a git-merge-foo name' '
 
 173         test_must_fail git merge -s index c1
 
 176 test_expect_success 'merge c0 with c1' '
 
 177         echo "OBJID HEAD@{0}: merge c1: Fast-forward" >reflog.expected &&
 
 179         git reset --hard c0 &&
 
 181         verify_merge file result.1 &&
 
 184         git reflog -1 >reflog.actual &&
 
 185         sed "s/$_x05[0-9a-f]*/OBJID/g" reflog.actual >reflog.fuzzy &&
 
 186         test_cmp reflog.expected reflog.fuzzy
 
 189 test_debug 'git log --graph --decorate --oneline --all'
 
 191 test_expect_success 'merge c0 with c1 with --ff-only' '
 
 192         git reset --hard c0 &&
 
 193         git merge --ff-only c1 &&
 
 194         git merge --ff-only HEAD c0 c1 &&
 
 195         verify_merge file result.1 &&
 
 199 test_debug 'git log --graph --decorate --oneline --all'
 
 201 test_expect_success 'merge from unborn branch' '
 
 202         git checkout -f master &&
 
 203         test_might_fail git branch -D kid &&
 
 205         echo "OBJID HEAD@{0}: initial pull" >reflog.expected &&
 
 207         git checkout --orphan kid &&
 
 208         test_when_finished "git checkout -f master" &&
 
 211         git merge --ff-only c1 &&
 
 212         verify_merge file result.1 &&
 
 215         git reflog -1 >reflog.actual &&
 
 216         sed "s/$_x05[0-9a-f][0-9a-f]/OBJID/g" reflog.actual >reflog.fuzzy &&
 
 217         test_cmp reflog.expected reflog.fuzzy
 
 220 test_debug 'git log --graph --decorate --oneline --all'
 
 222 test_expect_success 'merge c1 with c2' '
 
 223         git reset --hard c1 &&
 
 226         verify_merge file result.1-5 msg.1-5 &&
 
 227         verify_parents $c1 $c2
 
 230 test_expect_success 'merge --squash c3 with c7' '
 
 231         git reset --hard c3 &&
 
 232         test_must_fail git merge --squash c7 &&
 
 233         cat result.9z >file &&
 
 234         git commit --no-edit -a &&
 
 236         cat >expect <<-EOF &&
 
 237         Squashed commit of the following:
 
 244         git cat-file commit HEAD >raw &&
 
 245         sed -e '1,/^$/d' raw >actual &&
 
 246         test_cmp expect actual
 
 249 test_expect_success 'merge c3 with c7 with commit.cleanup = scissors' '
 
 250         git config commit.cleanup scissors &&
 
 251         git reset --hard c3 &&
 
 252         test_must_fail git merge c7 &&
 
 253         cat result.9z >file &&
 
 254         git commit --no-edit -a &&
 
 256         cat >expect <<-\EOF &&
 
 257         Merge tag '"'"'c7'"'"'
 
 259         # ------------------------ >8 ------------------------
 
 260         # Do not modify or remove the line above.
 
 261         # Everything below it will be ignored.
 
 266         git cat-file commit HEAD >raw &&
 
 267         sed -e '1,/^$/d' raw >actual &&
 
 268         test_i18ncmp expect actual
 
 271 test_expect_success 'merge c3 with c7 with --squash commit.cleanup = scissors' '
 
 272         git config commit.cleanup scissors &&
 
 273         git reset --hard c3 &&
 
 274         test_must_fail git merge --squash c7 &&
 
 275         cat result.9z >file &&
 
 276         git commit --no-edit -a &&
 
 278         cat >expect <<-EOF &&
 
 279         Squashed commit of the following:
 
 283         # ------------------------ >8 ------------------------
 
 284         # Do not modify or remove the line above.
 
 285         # Everything below it will be ignored.
 
 290         git cat-file commit HEAD >raw &&
 
 291         sed -e '1,/^$/d' raw >actual &&
 
 292         test_i18ncmp expect actual
 
 295 test_debug 'git log --graph --decorate --oneline --all'
 
 297 test_expect_success 'merge c1 with c2 and c3' '
 
 298         git reset --hard c1 &&
 
 301         verify_merge file result.1-5-9 msg.1-5-9 &&
 
 302         verify_parents $c1 $c2 $c3
 
 305 test_debug 'git log --graph --decorate --oneline --all'
 
 307 test_expect_success 'merges with --ff-only' '
 
 308         git reset --hard c1 &&
 
 310         test_must_fail git merge --ff-only c2 &&
 
 311         test_must_fail git merge --ff-only c3 &&
 
 312         test_must_fail git merge --ff-only c2 c3 &&
 
 313         git reset --hard c0 &&
 
 318 test_expect_success 'merges with merge.ff=only' '
 
 319         git reset --hard c1 &&
 
 321         test_config merge.ff "only" &&
 
 322         test_must_fail git merge c2 &&
 
 323         test_must_fail git merge c3 &&
 
 324         test_must_fail git merge c2 c3 &&
 
 325         git reset --hard c0 &&
 
 330 test_expect_success 'merge c0 with c1 (no-commit)' '
 
 331         git reset --hard c0 &&
 
 332         git merge --no-commit c1 &&
 
 333         verify_merge file result.1 &&
 
 337 test_debug 'git log --graph --decorate --oneline --all'
 
 339 test_expect_success 'merge c1 with c2 (no-commit)' '
 
 340         git reset --hard c1 &&
 
 341         git merge --no-commit c2 &&
 
 342         verify_merge file result.1-5 &&
 
 344         verify_mergeheads $c2
 
 347 test_debug 'git log --graph --decorate --oneline --all'
 
 349 test_expect_success 'merge c1 with c2 and c3 (no-commit)' '
 
 350         git reset --hard c1 &&
 
 351         git merge --no-commit c2 c3 &&
 
 352         verify_merge file result.1-5-9 &&
 
 354         verify_mergeheads $c2 $c3
 
 357 test_debug 'git log --graph --decorate --oneline --all'
 
 359 test_expect_success 'merge c0 with c1 (squash)' '
 
 360         git reset --hard c0 &&
 
 361         git merge --squash c1 &&
 
 362         verify_merge file result.1 &&
 
 364         verify_no_mergehead &&
 
 365         test_cmp squash.1 .git/SQUASH_MSG
 
 368 test_debug 'git log --graph --decorate --oneline --all'
 
 370 test_expect_success 'merge c0 with c1 (squash, ff-only)' '
 
 371         git reset --hard c0 &&
 
 372         git merge --squash --ff-only c1 &&
 
 373         verify_merge file result.1 &&
 
 375         verify_no_mergehead &&
 
 376         test_cmp squash.1 .git/SQUASH_MSG
 
 379 test_debug 'git log --graph --decorate --oneline --all'
 
 381 test_expect_success 'merge c1 with c2 (squash)' '
 
 382         git reset --hard c1 &&
 
 383         git merge --squash c2 &&
 
 384         verify_merge file result.1-5 &&
 
 386         verify_no_mergehead &&
 
 387         test_cmp squash.1-5 .git/SQUASH_MSG
 
 390 test_debug 'git log --graph --decorate --oneline --all'
 
 392 test_expect_success 'unsuccessful merge of c1 with c2 (squash, ff-only)' '
 
 393         git reset --hard c1 &&
 
 394         test_must_fail git merge --squash --ff-only c2
 
 397 test_debug 'git log --graph --decorate --oneline --all'
 
 399 test_expect_success 'merge c1 with c2 and c3 (squash)' '
 
 400         git reset --hard c1 &&
 
 401         git merge --squash c2 c3 &&
 
 402         verify_merge file result.1-5-9 &&
 
 404         verify_no_mergehead &&
 
 405         test_cmp squash.1-5-9 .git/SQUASH_MSG
 
 408 test_debug 'git log --graph --decorate --oneline --all'
 
 410 test_expect_success 'merge c1 with c2 (no-commit in config)' '
 
 411         git reset --hard c1 &&
 
 412         test_config branch.master.mergeoptions "--no-commit" &&
 
 414         verify_merge file result.1-5 &&
 
 416         verify_mergeheads $c2
 
 419 test_debug 'git log --graph --decorate --oneline --all'
 
 421 test_expect_success 'merge c1 with c2 (log in config)' '
 
 422         git reset --hard c1 &&
 
 423         git merge --log c2 &&
 
 424         git show -s --pretty=tformat:%s%n%b >expect &&
 
 426         test_config branch.master.mergeoptions "--log" &&
 
 427         git reset --hard c1 &&
 
 429         git show -s --pretty=tformat:%s%n%b >actual &&
 
 431         test_cmp expect actual
 
 434 test_expect_success 'merge c1 with c2 (log in config gets overridden)' '
 
 435         git reset --hard c1 &&
 
 437         git show -s --pretty=tformat:%s%n%b >expect &&
 
 439         test_config branch.master.mergeoptions "--no-log" &&
 
 440         test_config merge.log "true" &&
 
 441         git reset --hard c1 &&
 
 443         git show -s --pretty=tformat:%s%n%b >actual &&
 
 445         test_cmp expect actual
 
 448 test_expect_success 'merge c1 with c2 (squash in config)' '
 
 449         git reset --hard c1 &&
 
 450         test_config branch.master.mergeoptions "--squash" &&
 
 452         verify_merge file result.1-5 &&
 
 454         verify_no_mergehead &&
 
 455         test_cmp squash.1-5 .git/SQUASH_MSG
 
 458 test_debug 'git log --graph --decorate --oneline --all'
 
 460 test_expect_success 'override config option -n with --summary' '
 
 461         git reset --hard c1 &&
 
 462         test_config branch.master.mergeoptions "-n" &&
 
 464         git merge --summary c2 >diffstat.txt &&
 
 465         verify_merge file result.1-5 msg.1-5 &&
 
 466         verify_parents $c1 $c2 &&
 
 467         if ! grep "^ file |  *2 +-$" diffstat.txt
 
 469                 echo "[OOPS] diffstat was not generated with --summary"
 
 474 test_expect_success 'override config option -n with --stat' '
 
 475         git reset --hard c1 &&
 
 476         test_config branch.master.mergeoptions "-n" &&
 
 478         git merge --stat c2 >diffstat.txt &&
 
 479         verify_merge file result.1-5 msg.1-5 &&
 
 480         verify_parents $c1 $c2 &&
 
 481         if ! grep "^ file |  *2 +-$" diffstat.txt
 
 483                 echo "[OOPS] diffstat was not generated with --stat"
 
 488 test_debug 'git log --graph --decorate --oneline --all'
 
 490 test_expect_success 'override config option --stat' '
 
 491         git reset --hard c1 &&
 
 492         test_config branch.master.mergeoptions "--stat" &&
 
 494         git merge -n c2 >diffstat.txt &&
 
 495         verify_merge file result.1-5 msg.1-5 &&
 
 496         verify_parents $c1 $c2 &&
 
 497         if grep "^ file |  *2 +-$" diffstat.txt
 
 499                 echo "[OOPS] diffstat was generated"
 
 504 test_debug 'git log --graph --decorate --oneline --all'
 
 506 test_expect_success 'merge c1 with c2 (override --no-commit)' '
 
 507         git reset --hard c1 &&
 
 508         test_config branch.master.mergeoptions "--no-commit" &&
 
 510         git merge --commit c2 &&
 
 511         verify_merge file result.1-5 msg.1-5 &&
 
 512         verify_parents $c1 $c2
 
 515 test_debug 'git log --graph --decorate --oneline --all'
 
 517 test_expect_success 'merge c1 with c2 (override --squash)' '
 
 518         git reset --hard c1 &&
 
 519         test_config branch.master.mergeoptions "--squash" &&
 
 521         git merge --no-squash c2 &&
 
 522         verify_merge file result.1-5 msg.1-5 &&
 
 523         verify_parents $c1 $c2
 
 526 test_debug 'git log --graph --decorate --oneline --all'
 
 528 test_expect_success 'merge c0 with c1 (no-ff)' '
 
 529         git reset --hard c0 &&
 
 531         git merge --no-ff c1 &&
 
 532         verify_merge file result.1 &&
 
 533         verify_parents $c0 $c1
 
 536 test_debug 'git log --graph --decorate --oneline --all'
 
 538 test_expect_success 'merge c0 with c1 (merge.ff=false)' '
 
 539         git reset --hard c0 &&
 
 540         test_config merge.ff "false" &&
 
 543         verify_merge file result.1 &&
 
 544         verify_parents $c0 $c1
 
 546 test_debug 'git log --graph --decorate --oneline --all'
 
 548 test_expect_success 'combine branch.master.mergeoptions with merge.ff' '
 
 549         git reset --hard c0 &&
 
 550         test_config branch.master.mergeoptions "--ff" &&
 
 551         test_config merge.ff "false" &&
 
 554         verify_merge file result.1 &&
 
 558 test_expect_success 'tolerate unknown values for merge.ff' '
 
 559         git reset --hard c0 &&
 
 560         test_config merge.ff "something-new" &&
 
 562         git merge c1 2>message &&
 
 564         test_must_be_empty message
 
 567 test_expect_success 'combining --squash and --no-ff is refused' '
 
 568         git reset --hard c0 &&
 
 569         test_must_fail git merge --squash --no-ff c1 &&
 
 570         test_must_fail git merge --no-ff --squash c1
 
 573 test_expect_success 'option --ff-only overwrites --no-ff' '
 
 574         git merge --no-ff --ff-only c1 &&
 
 575         test_must_fail git merge --no-ff --ff-only c2
 
 578 test_expect_success 'option --no-ff overrides merge.ff=only config' '
 
 579         git reset --hard c0 &&
 
 580         test_config merge.ff only &&
 
 584 test_expect_success 'merge c0 with c1 (ff overrides no-ff)' '
 
 585         git reset --hard c0 &&
 
 586         test_config branch.master.mergeoptions "--no-ff" &&
 
 588         verify_merge file result.1 &&
 
 592 test_expect_success 'merge log message' '
 
 593         git reset --hard c0 &&
 
 594         git merge --no-log c2 &&
 
 595         git show -s --pretty=format:%b HEAD >msg.act &&
 
 596         test_must_be_empty msg.act &&
 
 598         git reset --hard c0 &&
 
 599         test_config branch.master.mergeoptions "--no-ff" &&
 
 600         git merge --no-log c2 &&
 
 601         git show -s --pretty=format:%b HEAD >msg.act &&
 
 602         test_must_be_empty msg.act &&
 
 604         git merge --log c3 &&
 
 605         git show -s --pretty=format:%b HEAD >msg.act &&
 
 606         test_cmp msg.log msg.act &&
 
 608         git reset --hard HEAD^ &&
 
 609         test_config merge.log "yes" &&
 
 611         git show -s --pretty=format:%b HEAD >msg.act &&
 
 612         test_cmp msg.log msg.act
 
 615 test_debug 'git log --graph --decorate --oneline --all'
 
 617 test_expect_success 'merge c1 with c0, c2, c0, and c1' '
 
 618        git reset --hard c1 &&
 
 620        git merge c0 c2 c0 c1 &&
 
 621        verify_merge file result.1-5 &&
 
 622        verify_parents $c1 $c2
 
 625 test_debug 'git log --graph --decorate --oneline --all'
 
 627 test_expect_success 'merge c1 with c0, c2, c0, and c1' '
 
 628        git reset --hard c1 &&
 
 630        git merge c0 c2 c0 c1 &&
 
 631        verify_merge file result.1-5 &&
 
 632        verify_parents $c1 $c2
 
 635 test_debug 'git log --graph --decorate --oneline --all'
 
 637 test_expect_success 'merge c1 with c1 and c2' '
 
 638        git reset --hard c1 &&
 
 641        verify_merge file result.1-5 &&
 
 642        verify_parents $c1 $c2
 
 645 test_debug 'git log --graph --decorate --oneline --all'
 
 647 test_expect_success 'merge fast-forward in a dirty tree' '
 
 648        git reset --hard c0 &&
 
 655 test_debug 'git log --graph --decorate --oneline --all'
 
 657 test_expect_success 'in-index merge' '
 
 658         git reset --hard c0 &&
 
 659         git merge --no-ff -s resolve c1 >out &&
 
 660         test_i18ngrep "Wonderful." out &&
 
 661         verify_parents $c0 $c1
 
 664 test_debug 'git log --graph --decorate --oneline --all'
 
 666 test_expect_success 'refresh the index before merging' '
 
 667         git reset --hard c1 &&
 
 668         cp file file.n && mv -f file.n file &&
 
 672 cat >expected.branch <<\EOF
 
 673 Merge branch 'c5-branch' (early part)
 
 675 cat >expected.tag <<\EOF
 
 679 test_expect_success 'merge early part of c2' '
 
 680         git reset --hard c3 &&
 
 689         git reset --hard c3 &&
 
 694         git branch -f c5-branch c5 &&
 
 695         git merge c5-branch~1 &&
 
 696         git show -s --pretty=tformat:%s HEAD >actual.branch &&
 
 697         git reset --keep HEAD^ &&
 
 699         git show -s --pretty=tformat:%s HEAD >actual.tag &&
 
 700         test_cmp expected.branch actual.branch &&
 
 701         test_cmp expected.tag actual.tag
 
 704 test_debug 'git log --graph --decorate --oneline --all'
 
 706 test_expect_success 'merge --no-ff --no-commit && commit' '
 
 707         git reset --hard c0 &&
 
 708         git merge --no-ff --no-commit c1 &&
 
 709         EDITOR=: git commit &&
 
 710         verify_parents $c0 $c1
 
 713 test_debug 'git log --graph --decorate --oneline --all'
 
 715 test_expect_success 'amending no-ff merge commit' '
 
 716         EDITOR=: git commit --amend &&
 
 717         verify_parents $c0 $c1
 
 720 test_debug 'git log --graph --decorate --oneline --all'
 
 724 # Add a new message string that was not in the template
 
 726         echo "Merge work done on the side branch c1"
 
 729 ) >"$1.tmp" && mv "$1.tmp" "$1"
 
 730 # strip comments and blank lines from end of message
 
 731 sed -e '/^#/d' "$1" | sed -e :a -e '/^\n*$/{$d;N;ba' -e '}' >expected
 
 735 test_expect_success 'merge --no-ff --edit' '
 
 736         git reset --hard c0 &&
 
 737         EDITOR=./editor git merge --no-ff --edit c1 &&
 
 738         verify_parents $c0 $c1 &&
 
 739         git cat-file commit HEAD >raw &&
 
 740         grep "work done on the side branch" raw &&
 
 741         sed "1,/^$/d" >actual raw &&
 
 742         test_cmp expected actual
 
 745 test_expect_success 'merge annotated/signed tag w/o tracking' '
 
 746         test_when_finished "rm -rf dst; git tag -d anno1" &&
 
 747         git tag -a -m "anno c1" anno1 c1 &&
 
 749         git rev-parse c1 >dst/expect &&
 
 751                 # c0 fast-forwards to c1 but because this repository
 
 752                 # is not a "downstream" whose refs/tags follows along
 
 753                 # tag from the "upstream", this pull defaults to --no-ff
 
 757                 git rev-parse HEAD^2 >actual &&
 
 758                 test_cmp expect actual
 
 762 test_expect_success 'merge annotated/signed tag w/ tracking' '
 
 763         test_when_finished "rm -rf dst; git tag -d anno1" &&
 
 764         git tag -a -m "anno c1" anno1 c1 &&
 
 766         git rev-parse c1 >dst/expect &&
 
 768                 # c0 fast-forwards to c1 and because this repository
 
 769                 # is a "downstream" whose refs/tags follows along
 
 770                 # tag from the "upstream", this pull defaults to --ff
 
 772                 git remote add origin .. &&
 
 773                 git pull origin c0 &&
 
 776                 git rev-parse HEAD >actual &&
 
 777                 test_cmp expect actual
 
 781 test_expect_success GPG 'merge --ff-only tag' '
 
 782         git reset --hard c0 &&
 
 783         git commit --allow-empty -m "A newer commit" &&
 
 784         git tag -s -m "A newer commit" signed &&
 
 785         git reset --hard c0 &&
 
 787         git merge --ff-only signed &&
 
 788         git rev-parse signed^0 >expect &&
 
 789         git rev-parse HEAD >actual &&
 
 790         test_cmp expect actual
 
 793 test_expect_success GPG 'merge --no-edit tag should skip editor' '
 
 794         git reset --hard c0 &&
 
 795         git commit --allow-empty -m "A newer commit" &&
 
 796         git tag -f -s -m "A newer commit" signed &&
 
 797         git reset --hard c0 &&
 
 799         EDITOR=false git merge --no-edit --no-ff signed &&
 
 800         git rev-parse signed^0 >expect &&
 
 801         git rev-parse HEAD^2 >actual &&
 
 802         test_cmp expect actual
 
 805 test_expect_success 'set up mod-256 conflict scenario' '
 
 806         # 256 near-identical stanzas...
 
 807         for i in $(test_seq 1 256); do
 
 808                 for j in 1 2 3 4 5; do
 
 813         git commit -m base &&
 
 815         # one side changes the first line of each to "master"
 
 816         sed s/-1/-master/ file >tmp &&
 
 818         git commit -am master &&
 
 820         # and the other to "side"; merging the two will
 
 821         # yield 256 separate conflicts
 
 822         git checkout -b side HEAD^ &&
 
 823         sed s/-1/-side/ file >tmp &&
 
 828 test_expect_success 'merge detects mod-256 conflicts (recursive)' '
 
 830         test_must_fail git merge -s recursive master
 
 833 test_expect_success 'merge detects mod-256 conflicts (resolve)' '
 
 835         test_must_fail git merge -s resolve master
 
 838 test_expect_success 'merge nothing into void' '
 
 842                 git remote add up .. &&
 
 844                 test_must_fail git merge FETCH_HEAD
 
 848 test_expect_success 'merge can be completed with --continue' '
 
 849         git reset --hard c0 &&
 
 850         git merge --no-ff --no-commit c1 &&
 
 851         git merge --continue &&
 
 852         verify_parents $c0 $c1
 
 855 write_script .git/FAKE_EDITOR <<EOF
 
 856 # kill -TERM command added below.
 
 859 test_expect_success EXECKEEPSPID 'killed merge can be completed with --continue' '
 
 860         git reset --hard c0 &&
 
 861         ! "$SHELL_PATH" -c '\''
 
 862           echo kill -TERM $$ >>.git/FAKE_EDITOR
 
 863           GIT_EDITOR=.git/FAKE_EDITOR
 
 865           exec git merge --no-ff --edit c1'\'' &&
 
 866         git merge --continue &&
 
 867         verify_parents $c0 $c1