t / t3508-cherry-pick-many-commits.shon commit t3905: abstract away SHA-1-specific constants (f1aae03)
   1#!/bin/sh
   2
   3test_description='test cherry-picking many commits'
   4
   5. ./test-lib.sh
   6
   7check_head_differs_from() {
   8        ! test_cmp_rev HEAD "$1"
   9}
  10
  11check_head_equals() {
  12        test_cmp_rev HEAD "$1"
  13}
  14
  15test_expect_success setup '
  16        echo first > file1 &&
  17        git add file1 &&
  18        test_tick &&
  19        git commit -m "first" &&
  20        git tag first &&
  21
  22        git checkout -b other &&
  23        for val in second third fourth
  24        do
  25                echo $val >> file1 &&
  26                git add file1 &&
  27                test_tick &&
  28                git commit -m "$val" &&
  29                git tag $val
  30        done
  31'
  32
  33test_expect_success 'cherry-pick first..fourth works' '
  34        git checkout -f master &&
  35        git reset --hard first &&
  36        test_tick &&
  37        git cherry-pick first..fourth &&
  38        git diff --quiet other &&
  39        git diff --quiet HEAD other &&
  40        check_head_differs_from fourth
  41'
  42
  43test_expect_success 'cherry-pick three one two works' '
  44        git checkout -f first &&
  45        test_commit one &&
  46        test_commit two &&
  47        test_commit three &&
  48        git checkout -f master &&
  49        git reset --hard first &&
  50        git cherry-pick three one two &&
  51        git diff --quiet three &&
  52        git diff --quiet HEAD three &&
  53        test "$(git log --reverse --format=%s first..)" = "three
  54one
  55two"
  56'
  57
  58test_expect_success 'cherry-pick three one two: fails' '
  59        git checkout -f master &&
  60        git reset --hard first &&
  61        test_must_fail git cherry-pick three one two:
  62'
  63
  64test_expect_success 'output to keep user entertained during multi-pick' '
  65        cat <<-\EOF >expected &&
  66        [master OBJID] second
  67         Author: A U Thor <author@example.com>
  68         Date: Thu Apr 7 15:14:13 2005 -0700
  69         1 file changed, 1 insertion(+)
  70        [master OBJID] third
  71         Author: A U Thor <author@example.com>
  72         Date: Thu Apr 7 15:15:13 2005 -0700
  73         1 file changed, 1 insertion(+)
  74        [master OBJID] fourth
  75         Author: A U Thor <author@example.com>
  76         Date: Thu Apr 7 15:16:13 2005 -0700
  77         1 file changed, 1 insertion(+)
  78        EOF
  79
  80        git checkout -f master &&
  81        git reset --hard first &&
  82        test_tick &&
  83        git cherry-pick first..fourth >actual &&
  84        sed -e "s/$_x05[0-9a-f][0-9a-f]/OBJID/" <actual >actual.fuzzy &&
  85        test_line_count -ge 3 actual.fuzzy &&
  86        test_i18ncmp expected actual.fuzzy
  87'
  88
  89test_expect_success 'cherry-pick --strategy resolve first..fourth works' '
  90        git checkout -f master &&
  91        git reset --hard first &&
  92        test_tick &&
  93        git cherry-pick --strategy resolve first..fourth &&
  94        git diff --quiet other &&
  95        git diff --quiet HEAD other &&
  96        check_head_differs_from fourth
  97'
  98
  99test_expect_success 'output during multi-pick indicates merge strategy' '
 100        cat <<-\EOF >expected &&
 101        Trying simple merge.
 102        [master OBJID] second
 103         Author: A U Thor <author@example.com>
 104         Date: Thu Apr 7 15:14:13 2005 -0700
 105         1 file changed, 1 insertion(+)
 106        Trying simple merge.
 107        [master OBJID] third
 108         Author: A U Thor <author@example.com>
 109         Date: Thu Apr 7 15:15:13 2005 -0700
 110         1 file changed, 1 insertion(+)
 111        Trying simple merge.
 112        [master OBJID] fourth
 113         Author: A U Thor <author@example.com>
 114         Date: Thu Apr 7 15:16:13 2005 -0700
 115         1 file changed, 1 insertion(+)
 116        EOF
 117
 118        git checkout -f master &&
 119        git reset --hard first &&
 120        test_tick &&
 121        git cherry-pick --strategy resolve first..fourth >actual &&
 122        sed -e "s/$_x05[0-9a-f][0-9a-f]/OBJID/" <actual >actual.fuzzy &&
 123        test_i18ncmp expected actual.fuzzy
 124'
 125
 126test_expect_success 'cherry-pick --ff first..fourth works' '
 127        git checkout -f master &&
 128        git reset --hard first &&
 129        test_tick &&
 130        git cherry-pick --ff first..fourth &&
 131        git diff --quiet other &&
 132        git diff --quiet HEAD other &&
 133        check_head_equals fourth
 134'
 135
 136test_expect_success 'cherry-pick -n first..fourth works' '
 137        git checkout -f master &&
 138        git reset --hard first &&
 139        test_tick &&
 140        git cherry-pick -n first..fourth &&
 141        git diff --quiet other &&
 142        git diff --cached --quiet other &&
 143        git diff --quiet HEAD first
 144'
 145
 146test_expect_success 'revert first..fourth works' '
 147        git checkout -f master &&
 148        git reset --hard fourth &&
 149        test_tick &&
 150        git revert first..fourth &&
 151        git diff --quiet first &&
 152        git diff --cached --quiet first &&
 153        git diff --quiet HEAD first
 154'
 155
 156test_expect_success 'revert ^first fourth works' '
 157        git checkout -f master &&
 158        git reset --hard fourth &&
 159        test_tick &&
 160        git revert ^first fourth &&
 161        git diff --quiet first &&
 162        git diff --cached --quiet first &&
 163        git diff --quiet HEAD first
 164'
 165
 166test_expect_success 'revert fourth fourth~1 fourth~2 works' '
 167        git checkout -f master &&
 168        git reset --hard fourth &&
 169        test_tick &&
 170        git revert fourth fourth~1 fourth~2 &&
 171        git diff --quiet first &&
 172        git diff --cached --quiet first &&
 173        git diff --quiet HEAD first
 174'
 175
 176test_expect_success 'cherry-pick -3 fourth works' '
 177        git checkout -f master &&
 178        git reset --hard first &&
 179        test_tick &&
 180        git cherry-pick -3 fourth &&
 181        git diff --quiet other &&
 182        git diff --quiet HEAD other &&
 183        check_head_differs_from fourth
 184'
 185
 186test_expect_success 'cherry-pick --stdin works' '
 187        git checkout -f master &&
 188        git reset --hard first &&
 189        test_tick &&
 190        git rev-list --reverse first..fourth | git cherry-pick --stdin &&
 191        git diff --quiet other &&
 192        git diff --quiet HEAD other &&
 193        check_head_differs_from fourth
 194'
 195
 196test_done