You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
149 lines
3.0 KiB
149 lines
3.0 KiB
#!/bin/sh |
|
|
|
test_description='more git add -u' |
|
|
|
TEST_PASSES_SANITIZE_LEAK=true |
|
. ./test-lib.sh |
|
|
|
test_expect_success setup ' |
|
>xyzzy && |
|
_empty=$(git hash-object --stdin <xyzzy) && |
|
>yomin && |
|
>caskly && |
|
if test_have_prereq SYMLINKS; then |
|
ln -s frotz nitfol && |
|
T_letter=T |
|
else |
|
printf %s frotz > nitfol && |
|
T_letter=M |
|
fi && |
|
mkdir rezrov && |
|
>rezrov/bozbar && |
|
git add caskly xyzzy yomin nitfol rezrov/bozbar && |
|
|
|
test_tick && |
|
git commit -m initial |
|
|
|
' |
|
|
|
test_expect_success modify ' |
|
rm -f xyzzy yomin nitfol caskly && |
|
# caskly disappears (not a submodule) |
|
mkdir caskly && |
|
# nitfol changes from symlink to regular |
|
>nitfol && |
|
# rezrov/bozbar disappears |
|
rm -fr rezrov && |
|
if test_have_prereq SYMLINKS; then |
|
ln -s xyzzy rezrov |
|
else |
|
printf %s xyzzy > rezrov |
|
fi && |
|
# xyzzy disappears (not a submodule) |
|
mkdir xyzzy && |
|
echo gnusto >xyzzy/bozbar && |
|
# yomin gets replaced with a submodule |
|
mkdir yomin && |
|
>yomin/yomin && |
|
( |
|
cd yomin && |
|
git init && |
|
git add yomin && |
|
git commit -m "sub initial" |
|
) && |
|
yomin=$(GIT_DIR=yomin/.git git rev-parse HEAD) && |
|
# yonk is added and then turned into a submodule |
|
# this should appear as T in diff-files and as A in diff-index |
|
>yonk && |
|
git add yonk && |
|
rm -f yonk && |
|
mkdir yonk && |
|
>yonk/yonk && |
|
( |
|
cd yonk && |
|
git init && |
|
git add yonk && |
|
git commit -m "sub initial" |
|
) && |
|
yonk=$(GIT_DIR=yonk/.git git rev-parse HEAD) && |
|
# zifmia is added and then removed |
|
# this should appear in diff-files but not in diff-index. |
|
>zifmia && |
|
git add zifmia && |
|
rm -f zifmia && |
|
mkdir zifmia && |
|
{ |
|
git ls-tree -r HEAD | |
|
sed -e "s/^/:/" -e " |
|
/ caskly/{ |
|
s/ caskly/ $ZERO_OID D&/ |
|
s/blob/000000/ |
|
} |
|
/ nitfol/{ |
|
s/ nitfol/ $ZERO_OID $T_letter&/ |
|
s/blob/100644/ |
|
} |
|
/ rezrov.bozbar/{ |
|
s/ rezrov.bozbar/ $ZERO_OID D&/ |
|
s/blob/000000/ |
|
} |
|
/ xyzzy/{ |
|
s/ xyzzy/ $ZERO_OID D&/ |
|
s/blob/000000/ |
|
} |
|
/ yomin/{ |
|
s/ yomin/ $ZERO_OID T&/ |
|
s/blob/160000/ |
|
} |
|
" |
|
} >expect && |
|
{ |
|
cat expect && |
|
echo ":100644 160000 $_empty $ZERO_OID T yonk" && |
|
echo ":100644 000000 $_empty $ZERO_OID D zifmia" |
|
} >expect-files && |
|
{ |
|
cat expect && |
|
echo ":000000 160000 $ZERO_OID $ZERO_OID A yonk" |
|
} >expect-index && |
|
{ |
|
echo "100644 $_empty 0 nitfol" && |
|
echo "160000 $yomin 0 yomin" && |
|
echo "160000 $yonk 0 yonk" |
|
} >expect-final |
|
' |
|
|
|
test_expect_success diff-files ' |
|
git diff-files --raw >actual && |
|
test_cmp expect-files actual |
|
' |
|
|
|
test_expect_success diff-index ' |
|
git diff-index --raw HEAD -- >actual && |
|
test_cmp expect-index actual |
|
' |
|
|
|
test_expect_success 'add -u' ' |
|
rm -f ".git/saved-index" && |
|
cp -p ".git/index" ".git/saved-index" && |
|
git add -u && |
|
git ls-files -s >actual && |
|
test_cmp expect-final actual |
|
' |
|
|
|
test_expect_success 'commit -a' ' |
|
if test -f ".git/saved-index" |
|
then |
|
rm -f ".git/index" && |
|
mv ".git/saved-index" ".git/index" |
|
fi && |
|
git commit -m "second" -a && |
|
git ls-files -s >actual && |
|
test_cmp expect-final actual && |
|
rm -f .git/index && |
|
git read-tree HEAD && |
|
git ls-files -s >actual && |
|
test_cmp expect-final actual |
|
' |
|
|
|
test_done
|
|
|