#!/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 'rebase -Xtheirs from orphan' ' git checkout --orphan orphan-conflicting master~2 && echo "AB $T" >> original && git commit -morphan-conflicting 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