3 test_description
='read-tree D/F conflict corner cases'
6 .
"$TEST_DIRECTORY"/lib-read-tree.sh
10 rm -f .git
/index .git
/index.lock
&&
11 git clean
-d -f -f -q -x &&
16 path
=$
(expr "$it" : '\([^:]*\)') &&
17 mkdir
-p $
(dirname "$path") &&
18 echo "$it" >"$path" &&
19 git update-index
--add "$path" ||
exit
21 git tag
"$name" $
(git write-tree
)
26 rm -f .git
/index .git
/index.lock
&&
27 git clean
-d -f -f -q -x &&
29 git checkout-index
-f -q -u -a &&
30 git update-index
--refresh
35 sed "s|^[0-7][0-7]* $_x40 \([0-3]\) |\1 |" >current
&&
37 test_cmp expect current
40 test_expect_success setup
'
41 maketree O-000 a/b-2/c/d a/b/c/d a/x &&
42 maketree A-000 a/b-2/c/d a/b/c/d a/x &&
43 maketree A-001 a/b-2/c/d a/b/c/d a/b/c/e a/x &&
44 maketree B-000 a/b-2/c/d a/b a/x &&
46 maketree O-010 t-0 t/1 t/2 t=3 &&
47 maketree A-010 t-0 t t=3 &&
48 maketree B-010 t/1: t=3: &&
50 maketree O-020 ds/dma/ioat.c ds/dma/ioat_dca.c &&
51 maketree A-020 ds/dma/ioat/Makefile ds/dma/ioat/registers.h &&
55 test_expect_success
'3-way (1)' '
57 read_tree_u_must_succeed -m -u O-000 A-000 B-000 &&
67 test_expect_success
'3-way (2)' '
69 read_tree_u_must_succeed -m -u O-000 A-001 B-000 &&
80 test_expect_success
'3-way (3)' '
82 read_tree_u_must_succeed -m -u O-010 A-010 B-010 &&
94 test_expect_success
'2-way (1)' '
96 read_tree_u_must_succeed -m -u O-020 A-020 &&
98 0 ds/dma/ioat/Makefile
99 0 ds/dma/ioat/registers.h