2010-06-02 13:58:39 +08:00
|
|
|
#!/bin/sh
|
|
|
|
|
|
|
|
test_description='test cherry-picking many commits'
|
|
|
|
|
|
|
|
. ./test-lib.sh
|
|
|
|
|
2010-07-21 12:25:02 +08:00
|
|
|
check_head_differs_from() {
|
2012-12-22 03:10:10 +08:00
|
|
|
! test_cmp_rev HEAD "$1"
|
2010-07-21 12:25:02 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
check_head_equals() {
|
2012-12-22 03:10:10 +08:00
|
|
|
test_cmp_rev HEAD "$1"
|
2010-07-21 12:25:02 +08:00
|
|
|
}
|
|
|
|
|
2010-06-02 13:58:39 +08:00
|
|
|
test_expect_success setup '
|
|
|
|
echo first > file1 &&
|
|
|
|
git add file1 &&
|
|
|
|
test_tick &&
|
|
|
|
git commit -m "first" &&
|
|
|
|
git tag first &&
|
|
|
|
|
|
|
|
git checkout -b other &&
|
|
|
|
for val in second third fourth
|
|
|
|
do
|
|
|
|
echo $val >> file1 &&
|
|
|
|
git add file1 &&
|
|
|
|
test_tick &&
|
|
|
|
git commit -m "$val" &&
|
|
|
|
git tag $val
|
|
|
|
done
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'cherry-pick first..fourth works' '
|
2012-03-13 13:00:36 +08:00
|
|
|
git checkout -f master &&
|
|
|
|
git reset --hard first &&
|
|
|
|
test_tick &&
|
|
|
|
git cherry-pick first..fourth &&
|
|
|
|
git diff --quiet other &&
|
|
|
|
git diff --quiet HEAD other &&
|
|
|
|
check_head_differs_from fourth
|
|
|
|
'
|
|
|
|
|
2012-08-29 14:15:56 +08:00
|
|
|
test_expect_success 'cherry-pick three one two works' '
|
2012-08-29 14:15:55 +08:00
|
|
|
git checkout -f first &&
|
|
|
|
test_commit one &&
|
|
|
|
test_commit two &&
|
|
|
|
test_commit three &&
|
|
|
|
git checkout -f master &&
|
|
|
|
git reset --hard first &&
|
|
|
|
git cherry-pick three one two &&
|
|
|
|
git diff --quiet three &&
|
|
|
|
git diff --quiet HEAD three &&
|
|
|
|
test "$(git log --reverse --format=%s first..)" = "three
|
|
|
|
one
|
|
|
|
two"
|
|
|
|
'
|
|
|
|
|
2013-04-11 21:06:52 +08:00
|
|
|
test_expect_success 'cherry-pick three one two: fails' '
|
|
|
|
git checkout -f master &&
|
|
|
|
git reset --hard first &&
|
|
|
|
test_must_fail git cherry-pick three one two:
|
|
|
|
'
|
|
|
|
|
2012-03-13 13:00:36 +08:00
|
|
|
test_expect_success 'output to keep user entertained during multi-pick' '
|
2010-08-11 16:36:07 +08:00
|
|
|
cat <<-\EOF >expected &&
|
|
|
|
[master OBJID] second
|
|
|
|
Author: A U Thor <author@example.com>
|
2014-05-02 09:10:01 +08:00
|
|
|
Date: Thu Apr 7 15:14:13 2005 -0700
|
2012-02-01 20:55:07 +08:00
|
|
|
1 file changed, 1 insertion(+)
|
2010-08-11 16:36:07 +08:00
|
|
|
[master OBJID] third
|
|
|
|
Author: A U Thor <author@example.com>
|
2014-05-02 09:10:01 +08:00
|
|
|
Date: Thu Apr 7 15:15:13 2005 -0700
|
2012-02-01 20:55:07 +08:00
|
|
|
1 file changed, 1 insertion(+)
|
2010-08-11 16:36:07 +08:00
|
|
|
[master OBJID] fourth
|
|
|
|
Author: A U Thor <author@example.com>
|
2014-05-02 09:10:01 +08:00
|
|
|
Date: Thu Apr 7 15:16:13 2005 -0700
|
2012-02-01 20:55:07 +08:00
|
|
|
1 file changed, 1 insertion(+)
|
2010-07-14 07:28:12 +08:00
|
|
|
EOF
|
|
|
|
|
|
|
|
git checkout -f master &&
|
|
|
|
git reset --hard first &&
|
|
|
|
test_tick &&
|
2010-08-11 16:36:07 +08:00
|
|
|
git cherry-pick first..fourth >actual &&
|
2012-03-13 13:00:36 +08:00
|
|
|
sed -e "s/$_x05[0-9a-f][0-9a-f]/OBJID/" <actual >actual.fuzzy &&
|
|
|
|
test_line_count -ge 3 actual.fuzzy &&
|
|
|
|
test_i18ncmp expected actual.fuzzy
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'cherry-pick --strategy resolve first..fourth works' '
|
|
|
|
git checkout -f master &&
|
|
|
|
git reset --hard first &&
|
|
|
|
test_tick &&
|
|
|
|
git cherry-pick --strategy resolve first..fourth &&
|
2010-07-14 07:28:12 +08:00
|
|
|
git diff --quiet other &&
|
|
|
|
git diff --quiet HEAD other &&
|
2010-07-21 12:25:02 +08:00
|
|
|
check_head_differs_from fourth
|
2010-07-14 07:28:12 +08:00
|
|
|
'
|
|
|
|
|
2012-03-13 13:00:36 +08:00
|
|
|
test_expect_success 'output during multi-pick indicates merge strategy' '
|
2010-08-11 16:36:07 +08:00
|
|
|
cat <<-\EOF >expected &&
|
|
|
|
Trying simple merge.
|
|
|
|
[master OBJID] second
|
|
|
|
Author: A U Thor <author@example.com>
|
2014-05-02 09:10:01 +08:00
|
|
|
Date: Thu Apr 7 15:14:13 2005 -0700
|
2012-02-01 20:55:07 +08:00
|
|
|
1 file changed, 1 insertion(+)
|
2010-08-11 16:36:07 +08:00
|
|
|
Trying simple merge.
|
|
|
|
[master OBJID] third
|
|
|
|
Author: A U Thor <author@example.com>
|
2014-05-02 09:10:01 +08:00
|
|
|
Date: Thu Apr 7 15:15:13 2005 -0700
|
2012-02-01 20:55:07 +08:00
|
|
|
1 file changed, 1 insertion(+)
|
2010-08-11 16:36:07 +08:00
|
|
|
Trying simple merge.
|
|
|
|
[master OBJID] fourth
|
|
|
|
Author: A U Thor <author@example.com>
|
2014-05-02 09:10:01 +08:00
|
|
|
Date: Thu Apr 7 15:16:13 2005 -0700
|
2012-02-01 20:55:07 +08:00
|
|
|
1 file changed, 1 insertion(+)
|
2010-07-14 07:28:12 +08:00
|
|
|
EOF
|
|
|
|
|
2010-06-14 13:28:50 +08:00
|
|
|
git checkout -f master &&
|
2010-06-02 13:58:39 +08:00
|
|
|
git reset --hard first &&
|
|
|
|
test_tick &&
|
2010-08-11 16:36:07 +08:00
|
|
|
git cherry-pick --strategy resolve first..fourth >actual &&
|
|
|
|
sed -e "s/$_x05[0-9a-f][0-9a-f]/OBJID/" <actual >actual.fuzzy &&
|
2012-03-13 13:00:36 +08:00
|
|
|
test_i18ncmp expected actual.fuzzy
|
2010-06-02 13:58:39 +08:00
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'cherry-pick --ff first..fourth works' '
|
2010-06-14 13:28:50 +08:00
|
|
|
git checkout -f master &&
|
2010-06-02 13:58:39 +08:00
|
|
|
git reset --hard first &&
|
|
|
|
test_tick &&
|
|
|
|
git cherry-pick --ff first..fourth &&
|
|
|
|
git diff --quiet other &&
|
|
|
|
git diff --quiet HEAD other &&
|
2010-07-21 12:25:02 +08:00
|
|
|
check_head_equals fourth
|
2010-06-02 13:58:39 +08:00
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'cherry-pick -n first..fourth works' '
|
2010-06-14 13:28:50 +08:00
|
|
|
git checkout -f master &&
|
2010-06-02 13:58:39 +08:00
|
|
|
git reset --hard first &&
|
|
|
|
test_tick &&
|
|
|
|
git cherry-pick -n first..fourth &&
|
|
|
|
git diff --quiet other &&
|
|
|
|
git diff --cached --quiet other &&
|
|
|
|
git diff --quiet HEAD first
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'revert first..fourth works' '
|
2010-06-14 13:28:50 +08:00
|
|
|
git checkout -f master &&
|
2010-06-02 13:58:39 +08:00
|
|
|
git reset --hard fourth &&
|
|
|
|
test_tick &&
|
|
|
|
git revert first..fourth &&
|
|
|
|
git diff --quiet first &&
|
|
|
|
git diff --cached --quiet first &&
|
|
|
|
git diff --quiet HEAD first
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'revert ^first fourth works' '
|
2010-06-14 13:28:50 +08:00
|
|
|
git checkout -f master &&
|
2010-06-02 13:58:39 +08:00
|
|
|
git reset --hard fourth &&
|
|
|
|
test_tick &&
|
|
|
|
git revert ^first fourth &&
|
|
|
|
git diff --quiet first &&
|
|
|
|
git diff --cached --quiet first &&
|
|
|
|
git diff --quiet HEAD first
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'revert fourth fourth~1 fourth~2 works' '
|
2010-06-14 13:28:50 +08:00
|
|
|
git checkout -f master &&
|
2010-06-02 13:58:39 +08:00
|
|
|
git reset --hard fourth &&
|
|
|
|
test_tick &&
|
|
|
|
git revert fourth fourth~1 fourth~2 &&
|
|
|
|
git diff --quiet first &&
|
|
|
|
git diff --cached --quiet first &&
|
|
|
|
git diff --quiet HEAD first
|
|
|
|
'
|
|
|
|
|
2010-06-30 01:20:53 +08:00
|
|
|
test_expect_success 'cherry-pick -3 fourth works' '
|
2010-06-14 13:28:50 +08:00
|
|
|
git checkout -f master &&
|
2010-06-02 13:58:39 +08:00
|
|
|
git reset --hard first &&
|
|
|
|
test_tick &&
|
|
|
|
git cherry-pick -3 fourth &&
|
|
|
|
git diff --quiet other &&
|
|
|
|
git diff --quiet HEAD other &&
|
2010-07-21 12:25:02 +08:00
|
|
|
check_head_differs_from fourth
|
2010-06-02 13:58:39 +08:00
|
|
|
'
|
|
|
|
|
2010-06-14 13:29:38 +08:00
|
|
|
test_expect_success 'cherry-pick --stdin works' '
|
|
|
|
git checkout -f master &&
|
|
|
|
git reset --hard first &&
|
|
|
|
test_tick &&
|
|
|
|
git rev-list --reverse first..fourth | git cherry-pick --stdin &&
|
|
|
|
git diff --quiet other &&
|
|
|
|
git diff --quiet HEAD other &&
|
2010-07-21 12:25:02 +08:00
|
|
|
check_head_differs_from fourth
|
2010-06-14 13:29:38 +08:00
|
|
|
'
|
|
|
|
|
2010-06-02 13:58:39 +08:00
|
|
|
test_done
|