mirror of
https://github.com/git/git.git
synced 2024-11-28 20:44:04 +08:00
f225b21807
This adds a set of tests to make sure that requirements on existing cache entries are checked when a read-tree -m 3-way merge is run with an already populated index file. Signed-off-by: Junio C Hamano <junkio@cox.net> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
159 lines
4.1 KiB
Bash
159 lines
4.1 KiB
Bash
: 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-cache --add $p &&
|
|
git-update-cache --add Z/$p'
|
|
done
|
|
done
|
|
echo This is SS from the original tree. >SS
|
|
test_expect_success \
|
|
'adding test file SS' \
|
|
'git-update-cache --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-cache --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-cache --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-cache $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-cache --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-cache --add LL &&
|
|
git-update-cache 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-cache 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-cache --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-cache -a'
|
|
|
|
to_remove=$(echo ?D Z/?D)
|
|
rm -f $to_remove
|
|
test_expect_success \
|
|
'change in branch B (removal)' \
|
|
"git-update-cache --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-cache $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-cache --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-cache --add LL &&
|
|
git-update-cache 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-cache 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-cache --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-cache --prefix=.orig-O/ -f -q -a &&
|
|
rm -f .git/index &&
|
|
git-read-tree $tree_A &&
|
|
mkdir .orig-A &&
|
|
git-checkout-cache --prefix=.orig-A/ -f -q -a &&
|
|
rm -f .git/index &&
|
|
git-read-tree $tree_B &&
|
|
mkdir .orig-B &&
|
|
git-checkout-cache --prefix=.orig-B/ -f -q -a'
|