diff options
author | Yann Dirson <ydirson@altern.org> | 2006-01-08 01:39:48 +0100 |
---|---|---|
committer | Junio C Hamano <junkio@cox.net> | 2006-01-08 12:33:13 -0800 |
commit | e77f489edf3865dbcfd329461355523bb3c21075 (patch) | |
tree | 5bf9ddfab3c0c09f76885659adafe192ad004283 /t/t3401-rebase-partial.sh | |
parent | b91db2707a4a3c48982c5fa052cf7ee3da8616cf (diff) | |
download | git-e77f489edf3865dbcfd329461355523bb3c21075.tar.gz git-e77f489edf3865dbcfd329461355523bb3c21075.tar.xz |
Add a test for rebase when a change was picked upstream
This test exercises the standard feature that makes rebase useful.
Signed-off-by: Yann Dirson <ydirson@altern.org>
Signed-off-by: Junio C Hamano <junkio@cox.net>
Diffstat (limited to 't/t3401-rebase-partial.sh')
-rwxr-xr-x | t/t3401-rebase-partial.sh | 53 |
1 files changed, 53 insertions, 0 deletions
diff --git a/t/t3401-rebase-partial.sh b/t/t3401-rebase-partial.sh new file mode 100755 index 000000000..32dc9c5e7 --- /dev/null +++ b/t/t3401-rebase-partial.sh @@ -0,0 +1,53 @@ +#!/bin/sh +# +# Copyright (c) 2006 Yann Dirson, based on t3400 by Amos Waterland +# + +test_description='git rebase should detect patches integrated upstream + +This test cherry-picks one local change of two into master branch, and +checks that git rebase succeeds with only the second patch in the +local branch. +' +. ./test-lib.sh + +test_expect_success \ + 'prepare repository with topic branch' \ + 'echo First > A && + git-update-index --add A && + git-commit -m "Add A." && + + git-checkout -b my-topic-branch && + + echo Second > B && + git-update-index --add B && + git-commit -m "Add B." && + + echo AnotherSecond > C && + git-update-index --add C && + git-commit -m "Add C." && + + git-checkout -f master && + + echo Third >> A && + git-update-index A && + git-commit -m "Modify A." +' + +test_expect_success \ + 'pick top patch from topic branch into master' \ + 'git-cherry-pick my-topic-branch^0 && + git-checkout -f my-topic-branch +' + +test_debug \ + 'git-cherry master && + git-format-patch -k --stdout --full-index master >/dev/null && + gitk --all & sleep 1 +' + +test_expect_success \ + 'rebase topic branch against new master and check git-am did not get halted' \ + 'git-rebase master && test ! -d .dotest' + +test_done |