|  | : Included from t1000-read-tree-m-3way.sh and others | 
|  | # Original tree. | 
|  | mkdir Z | 
|  | for a in N D M | 
|  | do | 
|  | for b in N D M | 
|  | do | 
|  | p=$a$b | 
|  | echo This is $p from the original tree. >$p | 
|  | echo This is Z/$p from the original tree. >Z/$p | 
|  | test_expect_success \ | 
|  | "adding test file $p and Z/$p" \ | 
|  | 'git update-index --add $p && | 
|  | git update-index --add Z/$p' | 
|  | done | 
|  | done | 
|  | echo This is SS from the original tree. >SS | 
|  | test_expect_success \ | 
|  | 'adding test file SS' \ | 
|  | 'git update-index --add SS' | 
|  | cat >TT <<\EOF | 
|  | This is a trivial merge sample text. | 
|  | Branch A is expected to upcase this word, here. | 
|  | There are some filler lines to avoid diff context | 
|  | conflicts here, | 
|  | like this one, | 
|  | and this one, | 
|  | and this one is yet another one of them. | 
|  | At the very end, here comes another line, that is | 
|  | the word, expected to be upcased by Branch B. | 
|  | This concludes the trivial merge sample file. | 
|  | EOF | 
|  | test_expect_success \ | 
|  | 'adding test file TT' \ | 
|  | 'git update-index --add TT' | 
|  | test_expect_success \ | 
|  | 'prepare initial tree' \ | 
|  | 'tree_O=$(git write-tree)' | 
|  |  | 
|  | ################################################################ | 
|  | # Branch A and B makes the changes according to the above matrix. | 
|  |  | 
|  | ################################################################ | 
|  | # Branch A | 
|  |  | 
|  | to_remove=$(echo D? Z/D?) | 
|  | rm -f $to_remove | 
|  | test_expect_success \ | 
|  | 'change in branch A (removal)' \ | 
|  | 'git update-index --remove $to_remove' | 
|  |  | 
|  | for p in M? Z/M? | 
|  | do | 
|  | echo This is modified $p in the branch A. >$p | 
|  | test_expect_success \ | 
|  | 'change in branch A (modification)' \ | 
|  | "git update-index $p" | 
|  | done | 
|  |  | 
|  | for p in AN AA Z/AN Z/AA | 
|  | do | 
|  | echo This is added $p in the branch A. >$p | 
|  | test_expect_success \ | 
|  | 'change in branch A (addition)' \ | 
|  | "git update-index --add $p" | 
|  | done | 
|  |  | 
|  | echo This is SS from the modified tree. >SS | 
|  | echo This is LL from the modified tree. >LL | 
|  | test_expect_success \ | 
|  | 'change in branch A (addition)' \ | 
|  | 'git update-index --add LL && | 
|  | git update-index SS' | 
|  | mv TT TT- | 
|  | sed -e '/Branch A/s/word/WORD/g' <TT- >TT | 
|  | rm -f TT- | 
|  | test_expect_success \ | 
|  | 'change in branch A (edit)' \ | 
|  | 'git update-index TT' | 
|  |  | 
|  | mkdir DF | 
|  | echo Branch A makes a file at DF/DF, creating a directory DF. >DF/DF | 
|  | test_expect_success \ | 
|  | 'change in branch A (change file to directory)' \ | 
|  | 'git update-index --add DF/DF' | 
|  |  | 
|  | test_expect_success \ | 
|  | 'recording branch A tree' \ | 
|  | 'tree_A=$(git write-tree)' | 
|  |  | 
|  | ################################################################ | 
|  | # Branch B | 
|  | # Start from O | 
|  |  | 
|  | rm -rf [NDMASLT][NDMASLT] Z DF | 
|  | mkdir Z | 
|  | test_expect_success \ | 
|  | 'reading original tree and checking out' \ | 
|  | 'git read-tree $tree_O && | 
|  | git checkout-index -a' | 
|  |  | 
|  | to_remove=$(echo ?D Z/?D) | 
|  | rm -f $to_remove | 
|  | test_expect_success \ | 
|  | 'change in branch B (removal)' \ | 
|  | "git update-index --remove $to_remove" | 
|  |  | 
|  | for p in ?M Z/?M | 
|  | do | 
|  | echo This is modified $p in the branch B. >$p | 
|  | test_expect_success \ | 
|  | 'change in branch B (modification)' \ | 
|  | "git update-index $p" | 
|  | done | 
|  |  | 
|  | for p in NA AA Z/NA Z/AA | 
|  | do | 
|  | echo This is added $p in the branch B. >$p | 
|  | test_expect_success \ | 
|  | 'change in branch B (addition)' \ | 
|  | "git update-index --add $p" | 
|  | done | 
|  | echo This is SS from the modified tree. >SS | 
|  | echo This is LL from the modified tree. >LL | 
|  | test_expect_success \ | 
|  | 'change in branch B (addition and modification)' \ | 
|  | 'git update-index --add LL && | 
|  | git update-index SS' | 
|  | mv TT TT- | 
|  | sed -e '/Branch B/s/word/WORD/g' <TT- >TT | 
|  | rm -f TT- | 
|  | test_expect_success \ | 
|  | 'change in branch B (modification)' \ | 
|  | 'git update-index TT' | 
|  |  | 
|  | echo Branch B makes a file at DF. >DF | 
|  | test_expect_success \ | 
|  | 'change in branch B (addition of a file to conflict with directory)' \ | 
|  | 'git update-index --add DF' | 
|  |  | 
|  | test_expect_success \ | 
|  | 'recording branch B tree' \ | 
|  | 'tree_B=$(git write-tree)' | 
|  |  | 
|  | test_expect_success \ | 
|  | 'keep contents of 3 trees for easy access' \ | 
|  | 'rm -f .git/index && | 
|  | git read-tree $tree_O && | 
|  | mkdir .orig-O && | 
|  | git checkout-index --prefix=.orig-O/ -f -q -a && | 
|  | rm -f .git/index && | 
|  | git read-tree $tree_A && | 
|  | mkdir .orig-A && | 
|  | git checkout-index --prefix=.orig-A/ -f -q -a && | 
|  | rm -f .git/index && | 
|  | git read-tree $tree_B && | 
|  | mkdir .orig-B && | 
|  | git checkout-index --prefix=.orig-B/ -f -q -a' |