]> git.ipfire.org Git - thirdparty/git.git/blame - t/t7602-merge-octopus-many.sh
The third batch
[thirdparty/git.git] / t / t7602-merge-octopus-many.sh
CommitLineData
5948e2ae
MV
1#!/bin/sh
2
47a528ad 3test_description='git merge
5948e2ae
MV
4
5Testing octopus merge with more than 25 refs.'
6
716a6b2c 7TEST_PASSES_SANITIZE_LEAK=true
5948e2ae
MV
8. ./test-lib.sh
9
10test_expect_success 'setup' '
11 echo c0 > c0.c &&
12 git add c0.c &&
13 git commit -m c0 &&
14 git tag c0 &&
15 i=1 &&
16 while test $i -le 30
17 do
18 git reset --hard c0 &&
19 echo c$i > c$i.c &&
20 git add c$i.c &&
21 git commit -m c$i &&
22 git tag c$i &&
cf60c8f3 23 i=$(expr $i + 1) || return 1
5948e2ae
MV
24 done
25'
26
1c7b76be 27test_expect_success 'merge c1 with c2, c3, c4, ... c29' '
5948e2ae
MV
28 git reset --hard c1 &&
29 i=2 &&
30 refs="" &&
31 while test $i -le 30
32 do
74d2f569 33 refs="$refs c$i" &&
0c51d6b4 34 i=$(expr $i + 1) || return 1
a48fcd83 35 done &&
5948e2ae
MV
36 git merge $refs &&
37 test "$(git rev-parse c1)" != "$(git rev-parse HEAD)" &&
38 i=1 &&
39 while test $i -le 30
40 do
41 test "$(git rev-parse c$i)" = "$(git rev-parse HEAD^$i)" &&
cf60c8f3 42 i=$(expr $i + 1) || return 1
5948e2ae
MV
43 done &&
44 git diff --exit-code &&
45 i=1 &&
46 while test $i -le 30
47 do
48 test -f c$i.c &&
cf60c8f3 49 i=$(expr $i + 1) || return 1
5948e2ae
MV
50 done
51'
52
81334502
SB
53cat >expected <<\EOF
54Trying simple merge with c2
55Trying simple merge with c3
56Trying simple merge with c4
f23101bf 57Merge made by the 'octopus' strategy.
dc801e71
ZJS
58 c2.c | 1 +
59 c3.c | 1 +
60 c4.c | 1 +
7f814632 61 3 files changed, 3 insertions(+)
81334502
SB
62 create mode 100644 c2.c
63 create mode 100644 c3.c
64 create mode 100644 c4.c
65EOF
66
67test_expect_success 'merge output uses pretty names' '
68 git reset --hard c1 &&
69 git merge c2 c3 c4 >actual &&
1108cea7 70 test_cmp expected actual
81334502
SB
71'
72
73cat >expected <<\EOF
833abdc9 74Merge made by the 'recursive' strategy.
dc801e71 75 c5.c | 1 +
7f814632 76 1 file changed, 1 insertion(+)
81334502
SB
77 create mode 100644 c5.c
78EOF
79
e78cbf8c 80test_expect_success 'merge reduces irrelevant remote heads' '
c8c35f6a
EN
81 if test "$GIT_TEST_MERGE_ALGORITHM" = ort
82 then
83 mv expected expected.tmp &&
84 sed s/recursive/ort/ expected.tmp >expected &&
85 rm expected.tmp
86 fi &&
833abdc9 87 GIT_MERGE_VERBOSITY=0 git merge c4 c5 >actual &&
1108cea7 88 test_cmp expected actual
81334502 89'
85bf49f9
SB
90
91cat >expected <<\EOF
92Fast-forwarding to: c1
93Trying simple merge with c2
f23101bf 94Merge made by the 'octopus' strategy.
dc801e71
ZJS
95 c1.c | 1 +
96 c2.c | 1 +
7f814632 97 2 files changed, 2 insertions(+)
85bf49f9
SB
98 create mode 100644 c1.c
99 create mode 100644 c2.c
100EOF
101
102test_expect_success 'merge fast-forward output uses pretty names' '
103 git reset --hard c0 &&
104 git merge c1 c2 >actual &&
1108cea7 105 test_cmp expected actual
85bf49f9
SB
106'
107
5948e2ae 108test_done