From: Christian Couder Date: Sat, 19 Jul 2014 15:01:09 +0000 (+0200) Subject: replace: add test for --graft X-Git-Tag: v2.1.0-rc0~2^2~6 X-Git-Url: http://git.osdn.net/view?a=commitdiff_plain;h=adf8e5423891fa9bd04fcb0489ffb5da7025ec07;p=git-core%2Fgit.git replace: add test for --graft Signed-off-by: Christian Couder Signed-off-by: Junio C Hamano --- diff --git a/t/t6050-replace.sh b/t/t6050-replace.sh index fb07ad242..f854dae79 100755 --- a/t/t6050-replace.sh +++ b/t/t6050-replace.sh @@ -8,7 +8,7 @@ exec payload && + sed -n -e '/^$/q' -e '/^parent /p' actual && + shift && + for _parent + do + echo "parent $_parent" + done >expected && + test_cmp expected actual +} + +commit_peeling_shows_parents () +{ + _parent_number=1 + _commit="$1" + shift && + for _parent + do + _found=$(git rev-parse --verify $_commit^$_parent_number) || return 1 + test "$_found" = "$_parent" || return 1 + _parent_number=$(( $_parent_number + 1 )) + done && + test_must_fail git rev-parse --verify $_commit^$_parent_number +} + +commit_has_parents () +{ + commit_buffer_contains_parents "$@" && + commit_peeling_shows_parents "$@" +} + HASH1= HASH2= HASH3= @@ -351,4 +383,15 @@ test_expect_success 'replace ref cleanup' ' test -z "$(git replace)" ' +test_expect_success '--graft with and without already replaced object' ' + test $(git log --oneline | wc -l) = 7 && + git replace --graft $HASH5 && + test $(git log --oneline | wc -l) = 3 && + commit_has_parents $HASH5 && + test_must_fail git replace --graft $HASH5 $HASH4 $HASH3 && + git replace --force -g $HASH5 $HASH4 $HASH3 && + commit_has_parents $HASH5 $HASH4 $HASH3 && + git replace -d $HASH5 +' + test_done