1#!/bin/sh
2#
3# Copyright (c) 2005 Junio C Hamano
4#
5
6test_description='Two way merge with read-tree -m -u $H $M
7
8This is identical to t1001, but uses -u to update the work tree as well.
9
10'
11. ./test-lib.sh
12
13_x40='[0-9a-f][0-9a-f][0-9a-f][0-9a-f][0-9a-f]'
14_x40="$_x40$_x40$_x40$_x40$_x40$_x40$_x40$_x40"
15compare_change () {
16 sed >current \
17 -e '/^--- /d; /^+++ /d; /^@@ /d;' \
18 -e 's/^\(.[0-7][0-7][0-7][0-7][0-7][0-7]\) '"$_x40"' /\1 X /' "$1"
19 diff -u expected current
20}
21
22check_cache_at () {
23 clean_if_empty=`git-diff-files "$1"`
24 case "$clean_if_empty" in
25 '') echo "$1: clean" ;;
26 ?*) echo "$1: dirty" ;;
27 esac
28 case "$2,$clean_if_empty" in
29 clean,) : ;;
30 clean,?*) false ;;
31 dirty,) false ;;
32 dirty,?*) : ;;
33 esac
34}
35
36test_expect_success \
37 setup \
38 'echo frotz >frotz &&
39 echo nitfol >nitfol &&
40 echo bozbar >bozbar &&
41 echo rezrov >rezrov &&
42 echo yomin >yomin &&
43 git-update-cache --add nitfol bozbar rezrov &&
44 treeH=`git-write-tree` &&
45 echo treeH $treeH &&
46 git-ls-tree $treeH &&
47
48 echo gnusto >bozbar &&
49 git-update-cache --add frotz bozbar --force-remove rezrov &&
50 git-ls-files --stage >M.out &&
51 treeM=`git-write-tree` &&
52 echo treeM $treeM &&
53 git-ls-tree $treeM &&
54 sha1sum bozbar frotz nitfol >M.sha1 &&
55 git-diff-tree $treeH $treeM'
56
57test_expect_success \
58 '1, 2, 3 - no carry forward' \
59 'rm -f .git/index &&
60 git-read-tree -m -u $treeH $treeM &&
61 git-ls-files --stage >1-3.out &&
62 cmp M.out 1-3.out &&
63 sha1sum -c M.sha1 &&
64 check_cache_at bozbar clean &&
65 check_cache_at frotz clean &&
66 check_cache_at nitfol clean'
67
68echo '+100644 X 0 yomin' >expected
69
70test_expect_success \
71 '4 - carry forward local addition.' \
72 'rm -f .git/index &&
73 git-update-cache --add yomin &&
74 git-read-tree -m -u $treeH $treeM &&
75 git-ls-files --stage >4.out || exit
76 diff --unified=0 M.out 4.out >4diff.out
77 compare_change 4diff.out expected &&
78 check_cache_at yomin clean &&
79 sha1sum -c M.sha1 &&
80 echo yomin >yomin1 &&
81 diff yomin yomin1 &&
82 rm -f yomin1'
83
84test_expect_success \
85 '5 - carry forward local addition.' \
86 'rm -f .git/index &&
87 echo yomin >yomin &&
88 git-update-cache --add yomin &&
89 echo yomin yomin >yomin &&
90 git-read-tree -m -u $treeH $treeM &&
91 git-ls-files --stage >5.out || exit
92 diff --unified=0 M.out 5.out >5diff.out
93 compare_change 5diff.out expected &&
94 check_cache_at yomin dirty &&
95 sha1sum -c M.sha1 &&
96 : dirty index should have prevented -u from checking it out. &&
97 echo yomin yomin >yomin1 &&
98 diff yomin yomin1 &&
99 rm -f yomin1'
100
101test_expect_success \
102 '6 - local addition already has the same.' \
103 'rm -f .git/index &&
104 git-update-cache --add frotz &&
105 git-read-tree -m -u $treeH $treeM &&
106 git-ls-files --stage >6.out &&
107 diff --unified=0 M.out 6.out &&
108 check_cache_at frotz clean &&
109 sha1sum -c M.sha1 &&
110 echo frotz >frotz1 &&
111 diff frotz frotz1 &&
112 rm -f frotz1'
113
114test_expect_success \
115 '7 - local addition already has the same.' \
116 'rm -f .git/index &&
117 echo frotz >frotz &&
118 git-update-cache --add frotz &&
119 echo frotz frotz >frotz &&
120 git-read-tree -m -u $treeH $treeM &&
121 git-ls-files --stage >7.out &&
122 diff --unified=0 M.out 7.out &&
123 check_cache_at frotz dirty &&
124 if sha1sum -c M.sha1; then false; else :; fi &&
125 : dirty index should have prevented -u from checking it out. &&
126 echo frotz frotz >frotz1 &&
127 diff frotz frotz1 &&
128 rm -f frotz1'
129
130test_expect_success \
131 '8 - conflicting addition.' \
132 'rm -f .git/index &&
133 echo frotz frotz >frotz &&
134 git-update-cache --add frotz &&
135 if git-read-tree -m -u $treeH $treeM; then false; else :; fi'
136
137test_expect_success \
138 '9 - conflicting addition.' \
139 'rm -f .git/index &&
140 echo frotz frotz >frotz &&
141 git-update-cache --add frotz &&
142 echo frotz >frotz &&
143 if git-read-tree -m -u $treeH $treeM; then false; else :; fi'
144
145test_expect_success \
146 '10 - path removed.' \
147 'rm -f .git/index &&
148 echo rezrov >rezrov &&
149 git-update-cache --add rezrov &&
150 git-read-tree -m -u $treeH $treeM &&
151 git-ls-files --stage >10.out &&
152 cmp M.out 10.out &&
153 sha1sum -c M.sha1'
154
155test_expect_success \
156 '11 - dirty path removed.' \
157 'rm -f .git/index &&
158 echo rezrov >rezrov &&
159 git-update-cache --add rezrov &&
160 echo rezrov rezrov >rezrov &&
161 if git-read-tree -m -u $treeH $treeM; then false; else :; fi'
162
163test_expect_success \
164 '12 - unmatching local changes being removed.' \
165 'rm -f .git/index &&
166 echo rezrov rezrov >rezrov &&
167 git-update-cache --add rezrov &&
168 if git-read-tree -m -u $treeH $treeM; then false; else :; fi'
169
170test_expect_success \
171 '13 - unmatching local changes being removed.' \
172 'rm -f .git/index &&
173 echo rezrov rezrov >rezrov &&
174 git-update-cache --add rezrov &&
175 echo rezrov >rezrov &&
176 if git-read-tree -m -u $treeH $treeM; then false; else :; fi'
177
178cat >expected <<EOF
179-100644 X 0 nitfol
180+100644 X 0 nitfol
181EOF
182
183test_expect_success \
184 '14 - unchanged in two heads.' \
185 'rm -f .git/index &&
186 echo nitfol nitfol >nitfol &&
187 git-update-cache --add nitfol &&
188 git-read-tree -m -u $treeH $treeM &&
189 git-ls-files --stage >14.out || exit
190 diff --unified=0 M.out 14.out >14diff.out
191 compare_change 14diff.out expected &&
192 check_cache_at nitfol clean &&
193 grep -v nitfol M.sha1 | sha1sum -c &&
194 if sha1sum -c M.sha1; then false; else :; fi &&
195 echo nitfol nitfol >nitfol1 &&
196 diff nitfol nitfol1 &&
197 rm -f nitfol1'
198
199test_expect_success \
200 '15 - unchanged in two heads.' \
201 'rm -f .git/index &&
202 echo nitfol nitfol >nitfol &&
203 git-update-cache --add nitfol &&
204 echo nitfol nitfol nitfol >nitfol &&
205 git-read-tree -m -u $treeH $treeM &&
206 git-ls-files --stage >15.out || exit
207 diff --unified=0 M.out 15.out >15diff.out
208 compare_change 15diff.out expected &&
209 check_cache_at nitfol dirty &&
210 grep -v nitfol M.sha1 | sha1sum -c &&
211 if sha1sum -c M.sha1; then false; else :; fi &&
212 echo nitfol nitfol nitfol >nitfol1 &&
213 diff nitfol nitfol1 &&
214 rm -f nitfol1'
215
216test_expect_success \
217 '16 - conflicting local change.' \
218 'rm -f .git/index &&
219 echo bozbar bozbar >bozbar &&
220 git-update-cache --add bozbar &&
221 if git-read-tree -m -u $treeH $treeM; then false; else :; fi'
222
223test_expect_success \
224 '17 - conflicting local change.' \
225 'rm -f .git/index &&
226 echo bozbar bozbar >bozbar &&
227 git-update-cache --add bozbar &&
228 echo bozbar bozbar bozbar >bozbar &&
229 if git-read-tree -m -u $treeH $treeM; then false; else :; fi'
230
231test_expect_success \
232 '18 - local change already having a good result.' \
233 'rm -f .git/index &&
234 echo gnusto >bozbar &&
235 git-update-cache --add bozbar &&
236 git-read-tree -m -u $treeH $treeM &&
237 git-ls-files --stage >18.out &&
238 diff --unified=0 M.out 18.out &&
239 check_cache_at bozbar clean &&
240 sha1sum -c M.sha1'
241
242test_expect_success \
243 '19 - local change already having a good result, further modified.' \
244 'rm -f .git/index &&
245 echo gnusto >bozbar &&
246 git-update-cache --add bozbar &&
247 echo gnusto gnusto >bozbar &&
248 git-read-tree -m -u $treeH $treeM &&
249 git-ls-files --stage >19.out &&
250 diff --unified=0 M.out 19.out &&
251 check_cache_at bozbar dirty &&
252 grep -v bozbar M.sha1 | sha1sum -c &&
253 if sha1sum -c M.sha1; then false; else :; fi &&
254 echo gnusto gnusto >bozbar1 &&
255 diff bozbar bozbar1 &&
256 rm -f bozbar1'
257
258test_expect_success \
259 '20 - no local change, use new tree.' \
260 'rm -f .git/index &&
261 echo bozbar >bozbar &&
262 git-update-cache --add bozbar &&
263 git-read-tree -m -u $treeH $treeM &&
264 git-ls-files --stage >20.out &&
265 diff --unified=0 M.out 20.out &&
266 check_cache_at bozbar clean &&
267 sha1sum -c M.sha1'
268
269test_expect_success \
270 '21 - no local change, dirty cache.' \
271 'rm -f .git/index &&
272 echo bozbar >bozbar &&
273 git-update-cache --add bozbar &&
274 echo gnusto gnusto >bozbar &&
275 if git-read-tree -m -u $treeH $treeM; then false; else :; fi'
276
277# Also make sure we did not break DF vs DF/DF case.
278test_expect_success \
279 'DF vs DF/DF case setup.' \
280 'rm -f .git/index &&
281 echo DF >DF &&
282 git-update-cache --add DF &&
283 treeDF=`git-write-tree` &&
284 echo treeDF $treeDF &&
285 git-ls-tree $treeDF &&
286
287 rm -f DF &&
288 mkdir DF &&
289 echo DF/DF >DF/DF &&
290 git-update-cache --add --remove DF DF/DF &&
291 treeDFDF=`git-write-tree` &&
292 echo treeDFDF $treeDFDF &&
293 git-ls-tree $treeDFDF &&
294 git-ls-files --stage >DFDF.out'
295
296test_expect_success \
297 'DF vs DF/DF case test.' \
298 'rm -f .git/index &&
299 rm -fr DF &&
300 echo DF >DF &&
301 git-update-cache --add DF &&
302 git-read-tree -m -u $treeDF $treeDFDF &&
303 git-ls-files --stage >DFDFcheck.out &&
304 diff --unified=0 DFDF.out DFDFcheck.out &&
305 check_cache_at DF/DF clean'
306
307test_done