1#!/bin/sh23test_description='read-tree D/F conflict corner cases'45. ./test-lib.sh6. "$TEST_DIRECTORY"/lib-read-tree.sh78maketree () {9(10rm -f .git/index .git/index.lock &&11git clean -d -f -f -q -x &&12name="$1" &&13shift &&14for it15do16path=$(expr "$it" : '\([^:]*\)') &&17mkdir -p $(dirname "$path") &&18echo "$it" >"$path" &&19git update-index --add "$path" || exit20done &&21git tag "$name" $(git write-tree)22)23}2425settree () {26rm -f .git/index .git/index.lock &&27git clean -d -f -f -q -x &&28git read-tree "$1" &&29git checkout-index -f -q -u -a &&30git update-index --refresh31}3233checkindex () {34git ls-files -s |35sed "s|^[0-7][0-7]* $OID_REGEX \([0-3]\) |\1 |" >current &&36cat >expect &&37test_cmp expect current38}3940test_expect_success setup '41maketree O-000 a/b-2/c/d a/b/c/d a/x &&42maketree A-000 a/b-2/c/d a/b/c/d a/x &&43maketree A-001 a/b-2/c/d a/b/c/d a/b/c/e a/x &&44maketree B-000 a/b-2/c/d a/b a/x &&4546maketree O-010 t-0 t/1 t/2 t=3 &&47maketree A-010 t-0 t t=3 &&48maketree B-010 t/1: t=3: &&4950maketree O-020 ds/dma/ioat.c ds/dma/ioat_dca.c &&51maketree A-020 ds/dma/ioat/Makefile ds/dma/ioat/registers.h &&52:53'5455test_expect_success '3-way (1)' '56settree A-000 &&57read_tree_u_must_succeed -m -u O-000 A-000 B-000 &&58checkindex <<-EOF593 a/b600 a/b-2/c/d611 a/b/c/d622 a/b/c/d630 a/x64EOF65'6667test_expect_success '3-way (2)' '68settree A-001 &&69read_tree_u_must_succeed -m -u O-000 A-001 B-000 &&70checkindex <<-EOF713 a/b720 a/b-2/c/d731 a/b/c/d742 a/b/c/d752 a/b/c/e760 a/x77EOF78'7980test_expect_success '3-way (3)' '81settree A-010 &&82read_tree_u_must_succeed -m -u O-010 A-010 B-010 &&83checkindex <<-EOF842 t851 t-0862 t-0871 t/1883 t/1891 t/2900 t=391EOF92'9394test_expect_success '2-way (1)' '95settree O-020 &&96read_tree_u_must_succeed -m -u O-020 A-020 &&97checkindex <<-EOF980 ds/dma/ioat/Makefile990 ds/dma/ioat/registers.h100EOF101'102103test_done