|  | #!/bin/sh | 
|  | # | 
|  | # Copyright (c) 2006 Junio C Hamano | 
|  | # | 
|  |  | 
|  | test_description='git rebase --merge test' | 
|  |  | 
|  | . ./test-lib.sh | 
|  |  | 
|  | T="A quick brown fox | 
|  | jumps over the lazy dog." | 
|  | for i in 1 2 3 4 5 6 7 8 9 10 | 
|  | do | 
|  | echo "$i $T" | 
|  | done >original | 
|  |  | 
|  | test_expect_success setup ' | 
|  | git add original && | 
|  | git commit -m"initial" && | 
|  | git branch side && | 
|  | echo "11 $T" >>original && | 
|  | git commit -a -m"master updates a bit." && | 
|  |  | 
|  | echo "12 $T" >>original && | 
|  | git commit -a -m"master updates a bit more." && | 
|  |  | 
|  | git checkout side && | 
|  | (echo "0 $T" ; cat original) >renamed && | 
|  | git add renamed && | 
|  | git update-index --force-remove original && | 
|  | git commit -a -m"side renames and edits." && | 
|  |  | 
|  | tr "[a-z]" "[A-Z]" <original >newfile && | 
|  | git add newfile && | 
|  | git commit -a -m"side edits further." && | 
|  | git branch second-side && | 
|  |  | 
|  | tr "[a-m]" "[A-M]" <original >newfile && | 
|  | rm -f original && | 
|  | git commit -a -m"side edits once again." && | 
|  |  | 
|  | git branch test-rebase side && | 
|  | git branch test-rebase-pick side && | 
|  | git branch test-reference-pick side && | 
|  | git branch test-conflicts side && | 
|  | git checkout -b test-merge side | 
|  | ' | 
|  |  | 
|  | test_expect_success 'reference merge' ' | 
|  | git merge -s recursive -m "reference merge" master | 
|  | ' | 
|  |  | 
|  | PRE_REBASE=$(git rev-parse test-rebase) | 
|  | test_expect_success rebase ' | 
|  | git checkout test-rebase && | 
|  | GIT_TRACE=1 git rebase --merge master | 
|  | ' | 
|  |  | 
|  | test_expect_success 'test-rebase@{1} is pre rebase' ' | 
|  | test $PRE_REBASE = $(git rev-parse test-rebase@{1}) | 
|  | ' | 
|  |  | 
|  | test_expect_success 'merge and rebase should match' ' | 
|  | git diff-tree -r test-rebase test-merge >difference && | 
|  | if test -s difference | 
|  | then | 
|  | cat difference | 
|  | (exit 1) | 
|  | else | 
|  | echo happy | 
|  | fi | 
|  | ' | 
|  |  | 
|  | test_expect_success 'rebase the other way' ' | 
|  | git reset --hard master && | 
|  | git rebase --merge side | 
|  | ' | 
|  |  | 
|  | test_expect_success 'rebase -Xtheirs' ' | 
|  | git checkout -b conflicting master~2 && | 
|  | echo "AB $T" >> original && | 
|  | git commit -mconflicting original && | 
|  | git rebase -Xtheirs master && | 
|  | grep AB original && | 
|  | ! grep 11 original | 
|  | ' | 
|  |  | 
|  | test_expect_success 'merge and rebase should match' ' | 
|  | git diff-tree -r test-rebase test-merge >difference && | 
|  | if test -s difference | 
|  | then | 
|  | cat difference | 
|  | (exit 1) | 
|  | else | 
|  | echo happy | 
|  | fi | 
|  | ' | 
|  |  | 
|  | test_expect_success 'picking rebase' ' | 
|  | git reset --hard side && | 
|  | git rebase --merge --onto master side^^ && | 
|  | mb=$(git merge-base master HEAD) && | 
|  | if test "$mb" = "$(git rev-parse master)" | 
|  | then | 
|  | echo happy | 
|  | else | 
|  | git show-branch | 
|  | (exit 1) | 
|  | fi && | 
|  | f=$(git diff-tree --name-only HEAD^ HEAD) && | 
|  | g=$(git diff-tree --name-only HEAD^^ HEAD^) && | 
|  | case "$f,$g" in | 
|  | newfile,newfile) | 
|  | echo happy ;; | 
|  | *) | 
|  | echo "$f" | 
|  | echo "$g" | 
|  | (exit 1) | 
|  | esac | 
|  | ' | 
|  |  | 
|  | test_expect_success 'rebase -s funny -Xopt' ' | 
|  | test_when_finished "rm -fr test-bin funny.was.run" && | 
|  | mkdir test-bin && | 
|  | cat >test-bin/git-merge-funny <<-EOF && | 
|  | #!$SHELL_PATH | 
|  | case "\$1" in --opt) ;; *) exit 2 ;; esac | 
|  | shift && | 
|  | >funny.was.run && | 
|  | exec git merge-recursive "\$@" | 
|  | EOF | 
|  | chmod +x test-bin/git-merge-funny && | 
|  | git reset --hard && | 
|  | git checkout -b test-funny master^ && | 
|  | test_commit funny && | 
|  | ( | 
|  | PATH=./test-bin:$PATH | 
|  | git rebase -s funny -Xopt master | 
|  | ) && | 
|  | test -f funny.was.run | 
|  | ' | 
|  |  | 
|  | test_expect_success 'rebase --skip works with two conflicts in a row' ' | 
|  | git checkout second-side  && | 
|  | tr "[A-Z]" "[a-z]" <newfile >tmp && | 
|  | mv tmp newfile && | 
|  | git commit -a -m"edit conflicting with side" && | 
|  | tr "[d-f]" "[D-F]" <newfile >tmp && | 
|  | mv tmp newfile && | 
|  | git commit -a -m"another edit conflicting with side" && | 
|  | test_must_fail git rebase --merge test-conflicts && | 
|  | test_must_fail git rebase --skip && | 
|  | git rebase --skip | 
|  | ' | 
|  |  | 
|  | test_done |