]> git.ipfire.org Git - thirdparty/git.git/blame - t/t5503-tagfollow.sh
Merge branch 'jk/clone-b'
[thirdparty/git.git] / t / t5503-tagfollow.sh
CommitLineData
cf7f929a
SP
1#!/bin/sh
2
3test_description='test automatic tag following'
4
5. ./test-lib.sh
6
8b02c64a
JS
7case $(uname -s) in
8*MINGW*)
9 say "GIT_DEBUG_SEND_PACK not supported - skipping tests"
10 test_done
8b02c64a
JS
11esac
12
cf7f929a
SP
13# End state of the repository:
14#
15# T - tag1 S - tag2
16# / /
17# L - A ------ O ------ B
18# \ \ \
19# \ C - origin/cat \
20# origin/master master
21
22test_expect_success setup '
23 test_tick &&
24 echo ichi >file &&
25 git add file &&
26 git commit -m L &&
27 L=$(git rev-parse --verify HEAD) &&
28
29 (
30 mkdir cloned &&
31 cd cloned &&
32 git init-db &&
33 git remote add -f origin ..
34 ) &&
35
36 test_tick &&
37 echo A >file &&
38 git add file &&
39 git commit -m A &&
40 A=$(git rev-parse --verify HEAD)
41'
42
43U=UPLOAD_LOG
44
45cat - <<EOF >expect
46#S
47want $A
48#E
49EOF
50test_expect_success 'fetch A (new commit : 1 connection)' '
51 rm -f $U
52 (
53 cd cloned &&
54 GIT_DEBUG_SEND_PACK=3 git fetch 3>../$U &&
55 test $A = $(git rev-parse --verify origin/master)
56 ) &&
57 test -s $U &&
58 cut -d" " -f1,2 $U >actual &&
3af82863 59 test_cmp expect actual
cf7f929a
SP
60'
61
62test_expect_success "create tag T on A, create C on branch cat" '
63 git tag -a -m tag1 tag1 $A &&
64 T=$(git rev-parse --verify tag1) &&
65
66 git checkout -b cat &&
67 echo C >file &&
68 git add file &&
69 git commit -m C &&
70 C=$(git rev-parse --verify HEAD) &&
71 git checkout master
72'
73
74cat - <<EOF >expect
75#S
76want $C
77want $T
78#E
79EOF
80test_expect_success 'fetch C, T (new branch, tag : 1 connection)' '
81 rm -f $U
82 (
83 cd cloned &&
84 GIT_DEBUG_SEND_PACK=3 git fetch 3>../$U &&
85 test $C = $(git rev-parse --verify origin/cat) &&
86 test $T = $(git rev-parse --verify tag1) &&
87 test $A = $(git rev-parse --verify tag1^0)
88 ) &&
89 test -s $U &&
90 cut -d" " -f1,2 $U >actual &&
3af82863 91 test_cmp expect actual
cf7f929a
SP
92'
93
94test_expect_success "create commits O, B, tag S on B" '
95 test_tick &&
96 echo O >file &&
97 git add file &&
98 git commit -m O &&
99
100 test_tick &&
101 echo B >file &&
102 git add file &&
103 git commit -m B &&
104 B=$(git rev-parse --verify HEAD) &&
105
106 git tag -a -m tag2 tag2 $B &&
107 S=$(git rev-parse --verify tag2)
108'
109
110cat - <<EOF >expect
111#S
112want $B
113want $S
114#E
115EOF
116test_expect_success 'fetch B, S (commit and tag : 1 connection)' '
117 rm -f $U
118 (
119 cd cloned &&
120 GIT_DEBUG_SEND_PACK=3 git fetch 3>../$U &&
121 test $B = $(git rev-parse --verify origin/master) &&
122 test $B = $(git rev-parse --verify tag2^0) &&
123 test $S = $(git rev-parse --verify tag2)
124 ) &&
125 test -s $U &&
126 cut -d" " -f1,2 $U >actual &&
3af82863 127 test_cmp expect actual
cf7f929a
SP
128'
129
41fa7d2e
SP
130cat - <<EOF >expect
131#S
132want $B
133want $S
134#E
135EOF
136test_expect_success 'new clone fetch master and tags' '
137 git branch -D cat
138 rm -f $U
139 (
140 mkdir clone2 &&
141 cd clone2 &&
142 git init &&
143 git remote add origin .. &&
144 GIT_DEBUG_SEND_PACK=3 git fetch 3>../$U &&
145 test $B = $(git rev-parse --verify origin/master) &&
146 test $S = $(git rev-parse --verify tag2) &&
147 test $B = $(git rev-parse --verify tag2^0) &&
148 test $T = $(git rev-parse --verify tag1) &&
149 test $A = $(git rev-parse --verify tag1^0)
150 ) &&
151 test -s $U &&
152 cut -d" " -f1,2 $U >actual &&
3af82863 153 test_cmp expect actual
41fa7d2e
SP
154'
155
cf7f929a 156test_done