Merge branch 'js/windows-tests'
* js/windows-tests: t5602: Work around path mangling on MSYS t5300, t5302, t5303: Do not use /dev/zero t2200, t7004: Avoid glob pattern that also matches files t7300: fix clean up on Windows test-lib: Introduce test_chmod and use it instead of update-index --chmod test-lib: Simplify test counting. test-lib: Replace uses of $(expr ...) by POSIX shell features. Call 'say' outside test_expect_success test suite: Use 'say' to say something instead of 'test_expect_success' t9400, t9401: Do not force hard-linked clone
This commit is contained in:
commit
6066f5ae75
@ -5,7 +5,7 @@ git_svn_id=git""-svn-id
|
|||||||
|
|
||||||
if test -n "$NO_SVN_TESTS"
|
if test -n "$NO_SVN_TESTS"
|
||||||
then
|
then
|
||||||
test_expect_success 'skipping git svn tests, NO_SVN_TESTS defined' :
|
say 'skipping git svn tests, NO_SVN_TESTS defined'
|
||||||
test_done
|
test_done
|
||||||
exit
|
exit
|
||||||
fi
|
fi
|
||||||
@ -17,7 +17,7 @@ SVN_TREE=$GIT_SVN_DIR/svn-tree
|
|||||||
svn >/dev/null 2>&1
|
svn >/dev/null 2>&1
|
||||||
if test $? -ne 1
|
if test $? -ne 1
|
||||||
then
|
then
|
||||||
test_expect_success 'skipping git svn tests, svn not found' :
|
say 'skipping git svn tests, svn not found'
|
||||||
test_done
|
test_done
|
||||||
exit
|
exit
|
||||||
fi
|
fi
|
||||||
@ -41,7 +41,7 @@ then
|
|||||||
else
|
else
|
||||||
err='Perl SVN libraries not found or unusable, skipping test'
|
err='Perl SVN libraries not found or unusable, skipping test'
|
||||||
fi
|
fi
|
||||||
test_expect_success "$err" :
|
say "$err"
|
||||||
test_done
|
test_done
|
||||||
exit
|
exit
|
||||||
fi
|
fi
|
||||||
|
@ -28,7 +28,7 @@ test_expect_success 'tar archive' '
|
|||||||
|
|
||||||
"$UNZIP" -v >/dev/null 2>&1
|
"$UNZIP" -v >/dev/null 2>&1
|
||||||
if [ $? -eq 127 ]; then
|
if [ $? -eq 127 ]; then
|
||||||
echo "Skipping ZIP test, because unzip was not found"
|
say "Skipping ZIP test, because unzip was not found"
|
||||||
test_done
|
test_done
|
||||||
exit
|
exit
|
||||||
fi
|
fi
|
||||||
|
@ -8,6 +8,7 @@ auml=`printf '\xc3\xa4'`
|
|||||||
aumlcdiar=`printf '\x61\xcc\x88'`
|
aumlcdiar=`printf '\x61\xcc\x88'`
|
||||||
|
|
||||||
case_insensitive=
|
case_insensitive=
|
||||||
|
unibad=
|
||||||
test_expect_success 'see if we expect ' '
|
test_expect_success 'see if we expect ' '
|
||||||
|
|
||||||
test_case=test_expect_success
|
test_case=test_expect_success
|
||||||
@ -19,7 +20,6 @@ test_expect_success 'see if we expect ' '
|
|||||||
then
|
then
|
||||||
test_case=test_expect_failure
|
test_case=test_expect_failure
|
||||||
case_insensitive=t
|
case_insensitive=t
|
||||||
say "will test on a case insensitive filesystem"
|
|
||||||
fi &&
|
fi &&
|
||||||
rm -fr junk &&
|
rm -fr junk &&
|
||||||
mkdir junk &&
|
mkdir junk &&
|
||||||
@ -27,13 +27,18 @@ test_expect_success 'see if we expect ' '
|
|||||||
case "$(cd junk && echo *)" in
|
case "$(cd junk && echo *)" in
|
||||||
"$aumlcdiar")
|
"$aumlcdiar")
|
||||||
test_unicode=test_expect_failure
|
test_unicode=test_expect_failure
|
||||||
say "will test on a unicode corrupting filesystem"
|
unibad=t
|
||||||
;;
|
;;
|
||||||
*) ;;
|
*) ;;
|
||||||
esac &&
|
esac &&
|
||||||
rm -fr junk
|
rm -fr junk
|
||||||
'
|
'
|
||||||
|
|
||||||
|
test "$case_insensitive" &&
|
||||||
|
say "will test on a case insensitive filesystem"
|
||||||
|
test "$unibad" &&
|
||||||
|
say "will test on a unicode corrupting filesystem"
|
||||||
|
|
||||||
if test "$case_insensitive"
|
if test "$case_insensitive"
|
||||||
then
|
then
|
||||||
test_expect_success "detection of case insensitive filesystem during repo init" '
|
test_expect_success "detection of case insensitive filesystem during repo init" '
|
||||||
|
@ -70,9 +70,7 @@ test_expect_success setup '
|
|||||||
E=`git rev-parse --verify HEAD:A/B/E` &&
|
E=`git rev-parse --verify HEAD:A/B/E` &&
|
||||||
check_fsck &&
|
check_fsck &&
|
||||||
|
|
||||||
chmod +x C &&
|
test_chmod +x C &&
|
||||||
( test "`git config --bool core.filemode`" != false ||
|
|
||||||
echo executable >>C ) &&
|
|
||||||
git add C &&
|
git add C &&
|
||||||
test_tick && git commit -m dragon &&
|
test_tick && git commit -m dragon &&
|
||||||
L=`git rev-parse --verify HEAD` &&
|
L=`git rev-parse --verify HEAD` &&
|
||||||
|
@ -150,7 +150,7 @@ test_expect_success 'add -u resolves unmerged paths' '
|
|||||||
echo 2 >path3 &&
|
echo 2 >path3 &&
|
||||||
echo 2 >path5 &&
|
echo 2 >path5 &&
|
||||||
git add -u &&
|
git add -u &&
|
||||||
git ls-files -s "path?" >actual &&
|
git ls-files -s path1 path2 path3 path4 path5 path6 >actual &&
|
||||||
{
|
{
|
||||||
echo "100644 $three 0 path1"
|
echo "100644 $three 0 path1"
|
||||||
echo "100644 $one 1 path3"
|
echo "100644 $one 1 path3"
|
||||||
|
@ -83,9 +83,9 @@ test_expect_success 'rebase a single mode change' '
|
|||||||
git checkout -b modechange HEAD^ &&
|
git checkout -b modechange HEAD^ &&
|
||||||
echo 1 > X &&
|
echo 1 > X &&
|
||||||
git add X &&
|
git add X &&
|
||||||
chmod a+x A &&
|
test_chmod +x A &&
|
||||||
test_tick &&
|
test_tick &&
|
||||||
git commit -m modechange A X &&
|
git commit -m modechange &&
|
||||||
GIT_TRACE=1 git rebase master
|
GIT_TRACE=1 git rebase master
|
||||||
'
|
'
|
||||||
|
|
||||||
|
@ -21,10 +21,11 @@ embedded'
|
|||||||
embedded' &&
|
embedded' &&
|
||||||
git commit -m 'add files with tabs and newlines'
|
git commit -m 'add files with tabs and newlines'
|
||||||
else
|
else
|
||||||
say 'Your filesystem does not allow tabs in filenames.'
|
|
||||||
test_tabs=n
|
test_tabs=n
|
||||||
fi"
|
fi"
|
||||||
|
|
||||||
|
test "$test_tabs" = n && say 'Your filesystem does not allow tabs in filenames.'
|
||||||
|
|
||||||
# Later we will try removing an unremovable path to make sure
|
# Later we will try removing an unremovable path to make sure
|
||||||
# git rm barfs, but if the test is run as root that cannot be
|
# git rm barfs, but if the test is run as root that cannot be
|
||||||
# arranged.
|
# arranged.
|
||||||
@ -112,7 +113,7 @@ test_expect_success \
|
|||||||
'test_must_fail git rm -f baz'
|
'test_must_fail git rm -f baz'
|
||||||
chmod 775 .
|
chmod 775 .
|
||||||
else
|
else
|
||||||
test_expect_success 'skipping removal failure (perhaps running as root?)' :
|
say 'skipping removal failure test (perhaps running as root?)'
|
||||||
fi
|
fi
|
||||||
|
|
||||||
test_expect_success \
|
test_expect_success \
|
||||||
|
@ -15,21 +15,10 @@ test_expect_success \
|
|||||||
tree=`git write-tree` &&
|
tree=`git write-tree` &&
|
||||||
echo $tree'
|
echo $tree'
|
||||||
|
|
||||||
if [ "$(git config --get core.filemode)" = false ]
|
test_expect_success \
|
||||||
then
|
'chmod' \
|
||||||
say 'filemode disabled on the filesystem, using update-index --chmod=+x'
|
'test_chmod +x rezrov &&
|
||||||
test_expect_success \
|
git diff-index $tree >current'
|
||||||
'git update-index --chmod=+x' \
|
|
||||||
'git update-index rezrov &&
|
|
||||||
git update-index --chmod=+x rezrov &&
|
|
||||||
git diff-index $tree >current'
|
|
||||||
else
|
|
||||||
test_expect_success \
|
|
||||||
'chmod' \
|
|
||||||
'chmod +x rezrov &&
|
|
||||||
git update-index rezrov &&
|
|
||||||
git diff-index $tree >current'
|
|
||||||
fi
|
|
||||||
|
|
||||||
_x40='[0-9a-f][0-9a-f][0-9a-f][0-9a-f][0-9a-f]'
|
_x40='[0-9a-f][0-9a-f][0-9a-f][0-9a-f][0-9a-f]'
|
||||||
_x40="$_x40$_x40$_x40$_x40$_x40$_x40$_x40$_x40"
|
_x40="$_x40$_x40$_x40$_x40$_x40$_x40$_x40$_x40"
|
||||||
|
@ -101,8 +101,7 @@ do
|
|||||||
'' | '#'*) continue ;;
|
'' | '#'*) continue ;;
|
||||||
esac
|
esac
|
||||||
test=`echo "$cmd" | sed -e 's|[/ ][/ ]*|_|g'`
|
test=`echo "$cmd" | sed -e 's|[/ ][/ ]*|_|g'`
|
||||||
cnt=`expr $test_count + 1`
|
pfx=`printf "%04d" $test_count`
|
||||||
pfx=`printf "%04d" $cnt`
|
|
||||||
expect="$TEST_DIRECTORY/t4013/diff.$test"
|
expect="$TEST_DIRECTORY/t4013/diff.$test"
|
||||||
actual="$pfx-diff.$test"
|
actual="$pfx-diff.$test"
|
||||||
|
|
||||||
|
@ -16,9 +16,7 @@ test_expect_success setup '
|
|||||||
git checkout -b side &&
|
git checkout -b side &&
|
||||||
|
|
||||||
for i in 1 2 5 6 A B C 7 8 9 10; do echo "$i"; done >file &&
|
for i in 1 2 5 6 A B C 7 8 9 10; do echo "$i"; done >file &&
|
||||||
chmod +x elif &&
|
test_chmod +x elif &&
|
||||||
git update-index file elif &&
|
|
||||||
git update-index --chmod=+x elif &&
|
|
||||||
git commit -m "Side changes #1" &&
|
git commit -m "Side changes #1" &&
|
||||||
|
|
||||||
for i in D E F; do echo "$i"; done >>file &&
|
for i in D E F; do echo "$i"; done >>file &&
|
||||||
|
@ -182,7 +182,7 @@ test_expect_success 'git archive --format=zip with --output' \
|
|||||||
|
|
||||||
$UNZIP -v >/dev/null 2>&1
|
$UNZIP -v >/dev/null 2>&1
|
||||||
if [ $? -eq 127 ]; then
|
if [ $? -eq 127 ]; then
|
||||||
echo "Skipping ZIP tests, because unzip was not found"
|
say "Skipping ZIP tests, because unzip was not found"
|
||||||
test_done
|
test_done
|
||||||
exit
|
exit
|
||||||
fi
|
fi
|
||||||
|
@ -13,11 +13,10 @@ TRASH=`pwd`
|
|||||||
test_expect_success \
|
test_expect_success \
|
||||||
'setup' \
|
'setup' \
|
||||||
'rm -f .git/index*
|
'rm -f .git/index*
|
||||||
for i in a b c
|
perl -e "print \"a\" x 4096;" > a &&
|
||||||
do
|
perl -e "print \"b\" x 4096;" > b &&
|
||||||
dd if=/dev/zero bs=4k count=1 | perl -pe "y/\\000/$i/" >$i &&
|
perl -e "print \"c\" x 4096;" > c &&
|
||||||
git update-index --add $i || return 1
|
git update-index --add a b c &&
|
||||||
done &&
|
|
||||||
cat c >d && echo foo >>d && git update-index --add d &&
|
cat c >d && echo foo >>d && git update-index --add d &&
|
||||||
tree=`git write-tree` &&
|
tree=`git write-tree` &&
|
||||||
commit=`git commit-tree $tree </dev/null` && {
|
commit=`git commit-tree $tree </dev/null` && {
|
||||||
@ -221,7 +220,7 @@ test_expect_success \
|
|||||||
test_expect_success \
|
test_expect_success \
|
||||||
'verify-pack catches a corrupted pack signature' \
|
'verify-pack catches a corrupted pack signature' \
|
||||||
'cat test-1-${packname_1}.pack >test-3.pack &&
|
'cat test-1-${packname_1}.pack >test-3.pack &&
|
||||||
dd if=/dev/zero of=test-3.pack count=1 bs=1 conv=notrunc seek=2 &&
|
echo | dd of=test-3.pack count=1 bs=1 conv=notrunc seek=2 &&
|
||||||
if git verify-pack test-3.idx
|
if git verify-pack test-3.idx
|
||||||
then false
|
then false
|
||||||
else :;
|
else :;
|
||||||
@ -230,7 +229,7 @@ test_expect_success \
|
|||||||
test_expect_success \
|
test_expect_success \
|
||||||
'verify-pack catches a corrupted pack version' \
|
'verify-pack catches a corrupted pack version' \
|
||||||
'cat test-1-${packname_1}.pack >test-3.pack &&
|
'cat test-1-${packname_1}.pack >test-3.pack &&
|
||||||
dd if=/dev/zero of=test-3.pack count=1 bs=1 conv=notrunc seek=7 &&
|
echo | dd of=test-3.pack count=1 bs=1 conv=notrunc seek=7 &&
|
||||||
if git verify-pack test-3.idx
|
if git verify-pack test-3.idx
|
||||||
then false
|
then false
|
||||||
else :;
|
else :;
|
||||||
@ -239,7 +238,7 @@ test_expect_success \
|
|||||||
test_expect_success \
|
test_expect_success \
|
||||||
'verify-pack catches a corrupted type/size of the 1st packed object data' \
|
'verify-pack catches a corrupted type/size of the 1st packed object data' \
|
||||||
'cat test-1-${packname_1}.pack >test-3.pack &&
|
'cat test-1-${packname_1}.pack >test-3.pack &&
|
||||||
dd if=/dev/zero of=test-3.pack count=1 bs=1 conv=notrunc seek=12 &&
|
echo | dd of=test-3.pack count=1 bs=1 conv=notrunc seek=12 &&
|
||||||
if git verify-pack test-3.idx
|
if git verify-pack test-3.idx
|
||||||
then false
|
then false
|
||||||
else :;
|
else :;
|
||||||
@ -250,7 +249,7 @@ test_expect_success \
|
|||||||
'l=`wc -c <test-3.idx` &&
|
'l=`wc -c <test-3.idx` &&
|
||||||
l=`expr $l - 20` &&
|
l=`expr $l - 20` &&
|
||||||
cat test-1-${packname_1}.pack >test-3.pack &&
|
cat test-1-${packname_1}.pack >test-3.pack &&
|
||||||
dd if=/dev/zero of=test-3.idx count=20 bs=1 conv=notrunc seek=$l &&
|
printf "%20s" "" | dd of=test-3.idx count=20 bs=1 conv=notrunc seek=$l &&
|
||||||
if git verify-pack test-3.pack
|
if git verify-pack test-3.pack
|
||||||
then false
|
then false
|
||||||
else :;
|
else :;
|
||||||
|
@ -208,7 +208,7 @@ test_expect_success \
|
|||||||
obj=`git hash-object file_001` &&
|
obj=`git hash-object file_001` &&
|
||||||
nr=`index_obj_nr ".git/objects/pack/pack-${pack1}.idx" $obj` &&
|
nr=`index_obj_nr ".git/objects/pack/pack-${pack1}.idx" $obj` &&
|
||||||
chmod +w ".git/objects/pack/pack-${pack1}.idx" &&
|
chmod +w ".git/objects/pack/pack-${pack1}.idx" &&
|
||||||
dd if=/dev/zero of=".git/objects/pack/pack-${pack1}.idx" conv=notrunc \
|
printf xxxx | dd of=".git/objects/pack/pack-${pack1}.idx" conv=notrunc \
|
||||||
bs=1 count=4 seek=$((8 + 256 * 4 + `wc -l <obj-list` * 20 + $nr * 4)) &&
|
bs=1 count=4 seek=$((8 + 256 * 4 + `wc -l <obj-list` * 20 + $nr * 4)) &&
|
||||||
( while read obj
|
( while read obj
|
||||||
do git cat-file -p $obj >/dev/null || exit 1
|
do git cat-file -p $obj >/dev/null || exit 1
|
||||||
|
@ -55,6 +55,8 @@ do_corrupt_object() {
|
|||||||
test_must_fail git verify-pack ${pack}.pack
|
test_must_fail git verify-pack ${pack}.pack
|
||||||
}
|
}
|
||||||
|
|
||||||
|
printf '\0' > zero
|
||||||
|
|
||||||
test_expect_success \
|
test_expect_success \
|
||||||
'initial setup validation' \
|
'initial setup validation' \
|
||||||
'create_test_files &&
|
'create_test_files &&
|
||||||
@ -66,7 +68,7 @@ test_expect_success \
|
|||||||
|
|
||||||
test_expect_success \
|
test_expect_success \
|
||||||
'create corruption in header of first object' \
|
'create corruption in header of first object' \
|
||||||
'do_corrupt_object $blob_1 0 < /dev/zero &&
|
'do_corrupt_object $blob_1 0 < zero &&
|
||||||
test_must_fail git cat-file blob $blob_1 > /dev/null &&
|
test_must_fail git cat-file blob $blob_1 > /dev/null &&
|
||||||
test_must_fail git cat-file blob $blob_2 > /dev/null &&
|
test_must_fail git cat-file blob $blob_2 > /dev/null &&
|
||||||
test_must_fail git cat-file blob $blob_3 > /dev/null'
|
test_must_fail git cat-file blob $blob_3 > /dev/null'
|
||||||
@ -125,7 +127,7 @@ test_expect_success \
|
|||||||
'create corruption in header of first delta' \
|
'create corruption in header of first delta' \
|
||||||
'create_new_pack &&
|
'create_new_pack &&
|
||||||
git prune-packed &&
|
git prune-packed &&
|
||||||
do_corrupt_object $blob_2 0 < /dev/zero &&
|
do_corrupt_object $blob_2 0 < zero &&
|
||||||
git cat-file blob $blob_1 > /dev/null &&
|
git cat-file blob $blob_1 > /dev/null &&
|
||||||
test_must_fail git cat-file blob $blob_2 > /dev/null &&
|
test_must_fail git cat-file blob $blob_2 > /dev/null &&
|
||||||
test_must_fail git cat-file blob $blob_3 > /dev/null'
|
test_must_fail git cat-file blob $blob_3 > /dev/null'
|
||||||
@ -180,7 +182,7 @@ test_expect_success \
|
|||||||
'corruption in delta base reference of first delta (OBJ_REF_DELTA)' \
|
'corruption in delta base reference of first delta (OBJ_REF_DELTA)' \
|
||||||
'create_new_pack &&
|
'create_new_pack &&
|
||||||
git prune-packed &&
|
git prune-packed &&
|
||||||
do_corrupt_object $blob_2 2 < /dev/zero &&
|
do_corrupt_object $blob_2 2 < zero &&
|
||||||
git cat-file blob $blob_1 > /dev/null &&
|
git cat-file blob $blob_1 > /dev/null &&
|
||||||
test_must_fail git cat-file blob $blob_2 > /dev/null &&
|
test_must_fail git cat-file blob $blob_2 > /dev/null &&
|
||||||
test_must_fail git cat-file blob $blob_3 > /dev/null'
|
test_must_fail git cat-file blob $blob_3 > /dev/null'
|
||||||
@ -207,7 +209,7 @@ test_expect_success \
|
|||||||
'corruption #0 in delta base reference of first delta (OBJ_OFS_DELTA)' \
|
'corruption #0 in delta base reference of first delta (OBJ_OFS_DELTA)' \
|
||||||
'create_new_pack --delta-base-offset &&
|
'create_new_pack --delta-base-offset &&
|
||||||
git prune-packed &&
|
git prune-packed &&
|
||||||
do_corrupt_object $blob_2 2 < /dev/zero &&
|
do_corrupt_object $blob_2 2 < zero &&
|
||||||
git cat-file blob $blob_1 > /dev/null &&
|
git cat-file blob $blob_1 > /dev/null &&
|
||||||
test_must_fail git cat-file blob $blob_2 > /dev/null &&
|
test_must_fail git cat-file blob $blob_2 > /dev/null &&
|
||||||
test_must_fail git cat-file blob $blob_3 > /dev/null'
|
test_must_fail git cat-file blob $blob_3 > /dev/null'
|
||||||
@ -259,7 +261,7 @@ test_expect_success \
|
|||||||
|
|
||||||
test_expect_success \
|
test_expect_success \
|
||||||
'... and a redundant pack allows for full recovery too' \
|
'... and a redundant pack allows for full recovery too' \
|
||||||
'do_corrupt_object $blob_2 2 < /dev/zero &&
|
'do_corrupt_object $blob_2 2 < zero &&
|
||||||
git cat-file blob $blob_1 > /dev/null &&
|
git cat-file blob $blob_1 > /dev/null &&
|
||||||
test_must_fail git cat-file blob $blob_2 > /dev/null &&
|
test_must_fail git cat-file blob $blob_2 > /dev/null &&
|
||||||
test_must_fail git cat-file blob $blob_3 > /dev/null &&
|
test_must_fail git cat-file blob $blob_3 > /dev/null &&
|
||||||
|
@ -129,8 +129,7 @@ do
|
|||||||
'' | '#'*) continue ;;
|
'' | '#'*) continue ;;
|
||||||
esac
|
esac
|
||||||
test=`echo "$cmd" | sed -e 's|[/ ][/ ]*|_|g'`
|
test=`echo "$cmd" | sed -e 's|[/ ][/ ]*|_|g'`
|
||||||
cnt=`expr $test_count + 1`
|
pfx=`printf "%04d" $test_count`
|
||||||
pfx=`printf "%04d" $cnt`
|
|
||||||
expect_f="$TEST_DIRECTORY/t5515/fetch.$test"
|
expect_f="$TEST_DIRECTORY/t5515/fetch.$test"
|
||||||
actual_f="$pfx-fetch.$test"
|
actual_f="$pfx-fetch.$test"
|
||||||
expect_r="$TEST_DIRECTORY/t5515/refs.$test"
|
expect_r="$TEST_DIRECTORY/t5515/refs.$test"
|
||||||
|
@ -18,8 +18,8 @@ test_expect_success 'clone calls git upload-pack unqualified with no -u option'
|
|||||||
'
|
'
|
||||||
|
|
||||||
test_expect_success 'clone calls specified git upload-pack with -u option' '
|
test_expect_success 'clone calls specified git upload-pack with -u option' '
|
||||||
GIT_SSH=./not_ssh git clone -u /something/bin/git-upload-pack localhost:/path/to/repo junk
|
GIT_SSH=./not_ssh git clone -u ./something/bin/git-upload-pack localhost:/path/to/repo junk
|
||||||
echo "localhost /something/bin/git-upload-pack '\''/path/to/repo'\''" >expected
|
echo "localhost ./something/bin/git-upload-pack '\''/path/to/repo'\''" >expected
|
||||||
test_cmp expected not_ssh_output
|
test_cmp expected not_ssh_output
|
||||||
'
|
'
|
||||||
|
|
||||||
|
@ -3,9 +3,6 @@
|
|||||||
test_description='merge-recursive: handle file mode'
|
test_description='merge-recursive: handle file mode'
|
||||||
. ./test-lib.sh
|
. ./test-lib.sh
|
||||||
|
|
||||||
# Note that we follow "chmod +x F" with "update-index --chmod=+x F" to
|
|
||||||
# help filesystems that do not have the executable bit.
|
|
||||||
|
|
||||||
test_expect_success 'mode change in one branch: keep changed version' '
|
test_expect_success 'mode change in one branch: keep changed version' '
|
||||||
: >file1 &&
|
: >file1 &&
|
||||||
git add file1 &&
|
git add file1 &&
|
||||||
@ -15,8 +12,7 @@ test_expect_success 'mode change in one branch: keep changed version' '
|
|||||||
git add dummy &&
|
git add dummy &&
|
||||||
git commit -m a &&
|
git commit -m a &&
|
||||||
git checkout -b b1 master &&
|
git checkout -b b1 master &&
|
||||||
chmod +x file1 &&
|
test_chmod +x file1 &&
|
||||||
git update-index --chmod=+x file1 &&
|
|
||||||
git commit -m b1 &&
|
git commit -m b1 &&
|
||||||
git checkout a1 &&
|
git checkout a1 &&
|
||||||
git merge-recursive master -- a1 b1 &&
|
git merge-recursive master -- a1 b1 &&
|
||||||
@ -28,8 +24,7 @@ test_expect_success 'mode change in both branches: expect conflict' '
|
|||||||
git checkout -b a2 master &&
|
git checkout -b a2 master &&
|
||||||
: >file2 &&
|
: >file2 &&
|
||||||
H=$(git hash-object file2) &&
|
H=$(git hash-object file2) &&
|
||||||
chmod +x file2 &&
|
test_chmod +x file2 &&
|
||||||
git update-index --add --chmod=+x file2 &&
|
|
||||||
git commit -m a2 &&
|
git commit -m a2 &&
|
||||||
git checkout -b b2 master &&
|
git checkout -b b2 master &&
|
||||||
: >file2 &&
|
: >file2 &&
|
||||||
|
@ -185,8 +185,9 @@ cba
|
|||||||
EOF
|
EOF
|
||||||
test_expect_success \
|
test_expect_success \
|
||||||
'listing tags with substring as pattern must print those matching' '
|
'listing tags with substring as pattern must print those matching' '
|
||||||
git tag -l "*a*" > actual &&
|
rm *a* &&
|
||||||
test_cmp expect actual
|
git tag -l "*a*" > current &&
|
||||||
|
test_cmp expect current
|
||||||
'
|
'
|
||||||
|
|
||||||
cat >expect <<EOF
|
cat >expect <<EOF
|
||||||
@ -582,7 +583,7 @@ test_expect_success \
|
|||||||
# subsequent tests require gpg; check if it is available
|
# subsequent tests require gpg; check if it is available
|
||||||
gpg --version >/dev/null
|
gpg --version >/dev/null
|
||||||
if [ $? -eq 127 ]; then
|
if [ $? -eq 127 ]; then
|
||||||
echo "gpg not found - skipping tag signing and verification tests"
|
say "gpg not found - skipping tag signing and verification tests"
|
||||||
test_done
|
test_done
|
||||||
exit
|
exit
|
||||||
fi
|
fi
|
||||||
@ -614,7 +615,7 @@ test_expect_success \
|
|||||||
# that version, creation of signed tags using the generated key fails.
|
# that version, creation of signed tags using the generated key fails.
|
||||||
case "$(gpg --version)" in
|
case "$(gpg --version)" in
|
||||||
'gpg (GnuPG) 1.0.6'*)
|
'gpg (GnuPG) 1.0.6'*)
|
||||||
echo "Skipping signed tag tests, because a bug in 1.0.6 version"
|
say "Skipping signed tag tests, because a bug in 1.0.6 version"
|
||||||
test_done
|
test_done
|
||||||
exit
|
exit
|
||||||
;;
|
;;
|
||||||
|
@ -87,30 +87,27 @@ do
|
|||||||
'
|
'
|
||||||
done
|
done
|
||||||
|
|
||||||
|
if ! echo 'echo space > "$1"' > "e space.sh"
|
||||||
|
then
|
||||||
|
say "Skipping; FS does not support spaces in filenames"
|
||||||
|
test_done
|
||||||
|
exit
|
||||||
|
fi
|
||||||
|
|
||||||
test_expect_success 'editor with a space' '
|
test_expect_success 'editor with a space' '
|
||||||
|
|
||||||
if echo "echo space > \"\$1\"" > "e space.sh"
|
chmod a+x "e space.sh" &&
|
||||||
then
|
GIT_EDITOR="./e\ space.sh" git commit --amend &&
|
||||||
chmod a+x "e space.sh" &&
|
test space = "$(git show -s --pretty=format:%s)"
|
||||||
GIT_EDITOR="./e\ space.sh" git commit --amend &&
|
|
||||||
test space = "$(git show -s --pretty=format:%s)"
|
|
||||||
else
|
|
||||||
say "Skipping; FS does not support spaces in filenames"
|
|
||||||
fi
|
|
||||||
|
|
||||||
'
|
'
|
||||||
|
|
||||||
unset GIT_EDITOR
|
unset GIT_EDITOR
|
||||||
test_expect_success 'core.editor with a space' '
|
test_expect_success 'core.editor with a space' '
|
||||||
|
|
||||||
if test -f "e space.sh"
|
git config core.editor \"./e\ space.sh\" &&
|
||||||
then
|
git commit --amend &&
|
||||||
git config core.editor \"./e\ space.sh\" &&
|
test space = "$(git show -s --pretty=format:%s)"
|
||||||
git commit --amend &&
|
|
||||||
test space = "$(git show -s --pretty=format:%s)"
|
|
||||||
else
|
|
||||||
say "Skipping; FS does not support spaces in filenames"
|
|
||||||
fi
|
|
||||||
|
|
||||||
'
|
'
|
||||||
|
|
||||||
|
@ -373,9 +373,9 @@ test_expect_success 'removal failure' '
|
|||||||
|
|
||||||
mkdir foo &&
|
mkdir foo &&
|
||||||
touch foo/bar &&
|
touch foo/bar &&
|
||||||
exec <foo/bar &&
|
(exec <foo/bar &&
|
||||||
chmod 0 foo &&
|
chmod 0 foo &&
|
||||||
test_must_fail git clean -f -d
|
test_must_fail git clean -f -d)
|
||||||
|
|
||||||
'
|
'
|
||||||
chmod 755 foo
|
chmod 755 foo
|
||||||
|
@ -9,7 +9,7 @@ test_description='Test export of commits to CVS'
|
|||||||
cvs >/dev/null 2>&1
|
cvs >/dev/null 2>&1
|
||||||
if test $? -ne 1
|
if test $? -ne 1
|
||||||
then
|
then
|
||||||
test_expect_success 'skipping git cvsexportcommit tests, cvs not found' :
|
say 'skipping git cvsexportcommit tests, cvs not found'
|
||||||
test_done
|
test_done
|
||||||
exit
|
exit
|
||||||
fi
|
fi
|
||||||
|
@ -13,12 +13,12 @@ cvs CLI client via git-cvsserver server'
|
|||||||
cvs >/dev/null 2>&1
|
cvs >/dev/null 2>&1
|
||||||
if test $? -ne 1
|
if test $? -ne 1
|
||||||
then
|
then
|
||||||
test_expect_success 'skipping git-cvsserver tests, cvs not found' :
|
say 'skipping git-cvsserver tests, cvs not found'
|
||||||
test_done
|
test_done
|
||||||
exit
|
exit
|
||||||
fi
|
fi
|
||||||
perl -e 'use DBI; use DBD::SQLite' >/dev/null 2>&1 || {
|
perl -e 'use DBI; use DBD::SQLite' >/dev/null 2>&1 || {
|
||||||
test_expect_success 'skipping git-cvsserver tests, Perl SQLite interface unavailable' :
|
say 'skipping git-cvsserver tests, Perl SQLite interface unavailable'
|
||||||
test_done
|
test_done
|
||||||
exit
|
exit
|
||||||
}
|
}
|
||||||
@ -44,7 +44,7 @@ test_expect_success 'setup' '
|
|||||||
git add secondrootfile &&
|
git add secondrootfile &&
|
||||||
git commit -m "second root") &&
|
git commit -m "second root") &&
|
||||||
git pull secondroot master &&
|
git pull secondroot master &&
|
||||||
git clone -q --local --bare "$WORKDIR/.git" "$SERVERDIR" >/dev/null 2>&1 &&
|
git clone -q --bare "$WORKDIR/.git" "$SERVERDIR" >/dev/null 2>&1 &&
|
||||||
GIT_DIR="$SERVERDIR" git config --bool gitcvs.enabled true &&
|
GIT_DIR="$SERVERDIR" git config --bool gitcvs.enabled true &&
|
||||||
GIT_DIR="$SERVERDIR" git config gitcvs.logfile "$SERVERDIR/gitcvs.log"
|
GIT_DIR="$SERVERDIR" git config gitcvs.logfile "$SERVERDIR/gitcvs.log"
|
||||||
'
|
'
|
||||||
@ -267,7 +267,7 @@ test_expect_success 'gitcvs.ext.dbname' \
|
|||||||
|
|
||||||
rm -fr "$SERVERDIR"
|
rm -fr "$SERVERDIR"
|
||||||
cd "$WORKDIR" &&
|
cd "$WORKDIR" &&
|
||||||
git clone -q --local --bare "$WORKDIR/.git" "$SERVERDIR" >/dev/null 2>&1 &&
|
git clone -q --bare "$WORKDIR/.git" "$SERVERDIR" >/dev/null 2>&1 &&
|
||||||
GIT_DIR="$SERVERDIR" git config --bool gitcvs.enabled true &&
|
GIT_DIR="$SERVERDIR" git config --bool gitcvs.enabled true &&
|
||||||
GIT_DIR="$SERVERDIR" git config gitcvs.logfile "$SERVERDIR/gitcvs.log" ||
|
GIT_DIR="$SERVERDIR" git config gitcvs.logfile "$SERVERDIR/gitcvs.log" ||
|
||||||
exit 1
|
exit 1
|
||||||
|
@ -49,12 +49,12 @@ not_present() {
|
|||||||
cvs >/dev/null 2>&1
|
cvs >/dev/null 2>&1
|
||||||
if test $? -ne 1
|
if test $? -ne 1
|
||||||
then
|
then
|
||||||
test_expect_success 'skipping git-cvsserver tests, cvs not found' :
|
say 'skipping git-cvsserver tests, cvs not found'
|
||||||
test_done
|
test_done
|
||||||
exit
|
exit
|
||||||
fi
|
fi
|
||||||
perl -e 'use DBI; use DBD::SQLite' >/dev/null 2>&1 || {
|
perl -e 'use DBI; use DBD::SQLite' >/dev/null 2>&1 || {
|
||||||
test_expect_success 'skipping git-cvsserver tests, Perl SQLite interface unavailable' :
|
say 'skipping git-cvsserver tests, Perl SQLite interface unavailable'
|
||||||
test_done
|
test_done
|
||||||
exit
|
exit
|
||||||
}
|
}
|
||||||
@ -84,7 +84,7 @@ test_expect_success 'setup' '
|
|||||||
echo "subdir/file.h crlf" >> .gitattributes &&
|
echo "subdir/file.h crlf" >> .gitattributes &&
|
||||||
git add .gitattributes textfile.c binfile.bin mixedUp.c subdir/* &&
|
git add .gitattributes textfile.c binfile.bin mixedUp.c subdir/* &&
|
||||||
git commit -q -m "First Commit" &&
|
git commit -q -m "First Commit" &&
|
||||||
git clone -q --local --bare "$WORKDIR/.git" "$SERVERDIR" >/dev/null 2>&1 &&
|
git clone -q --bare "$WORKDIR/.git" "$SERVERDIR" >/dev/null 2>&1 &&
|
||||||
GIT_DIR="$SERVERDIR" git config --bool gitcvs.enabled true &&
|
GIT_DIR="$SERVERDIR" git config --bool gitcvs.enabled true &&
|
||||||
GIT_DIR="$SERVERDIR" git config gitcvs.logfile "$SERVERDIR/gitcvs.log"
|
GIT_DIR="$SERVERDIR" git config gitcvs.logfile "$SERVERDIR/gitcvs.log"
|
||||||
'
|
'
|
||||||
|
@ -63,18 +63,10 @@ gitweb_run () {
|
|||||||
# gitweb.log is left for debugging
|
# gitweb.log is left for debugging
|
||||||
}
|
}
|
||||||
|
|
||||||
safe_chmod () {
|
|
||||||
chmod "$1" "$2" &&
|
|
||||||
if [ "$(git config --get core.filemode)" = false ]
|
|
||||||
then
|
|
||||||
git update-index --chmod="$1" "$2"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
. ./test-lib.sh
|
. ./test-lib.sh
|
||||||
|
|
||||||
perl -MEncode -e 'decode_utf8("", Encode::FB_CROAK)' >/dev/null 2>&1 || {
|
perl -MEncode -e 'decode_utf8("", Encode::FB_CROAK)' >/dev/null 2>&1 || {
|
||||||
test_expect_success 'skipping gitweb tests, perl version is too old' :
|
say 'skipping gitweb tests, perl version is too old'
|
||||||
test_done
|
test_done
|
||||||
exit
|
exit
|
||||||
}
|
}
|
||||||
@ -242,7 +234,7 @@ test_debug 'cat gitweb.log'
|
|||||||
|
|
||||||
test_expect_success \
|
test_expect_success \
|
||||||
'commitdiff(0): mode change' \
|
'commitdiff(0): mode change' \
|
||||||
'safe_chmod +x new_file &&
|
'test_chmod +x new_file &&
|
||||||
git commit -a -m "Mode changed." &&
|
git commit -a -m "Mode changed." &&
|
||||||
gitweb_run "p=.git;a=commitdiff"'
|
gitweb_run "p=.git;a=commitdiff"'
|
||||||
test_debug 'cat gitweb.log'
|
test_debug 'cat gitweb.log'
|
||||||
@ -281,7 +273,7 @@ test_debug 'cat gitweb.log'
|
|||||||
test_expect_success \
|
test_expect_success \
|
||||||
'commitdiff(0): mode change and modified' \
|
'commitdiff(0): mode change and modified' \
|
||||||
'echo "New line" >> file2 &&
|
'echo "New line" >> file2 &&
|
||||||
safe_chmod +x file2 &&
|
test_chmod +x file2 &&
|
||||||
git commit -a -m "Mode change and modification." &&
|
git commit -a -m "Mode change and modification." &&
|
||||||
gitweb_run "p=.git;a=commitdiff"'
|
gitweb_run "p=.git;a=commitdiff"'
|
||||||
test_debug 'cat gitweb.log'
|
test_debug 'cat gitweb.log'
|
||||||
@ -308,7 +300,7 @@ test_expect_success \
|
|||||||
'commitdiff(0): renamed, mode change and modified' \
|
'commitdiff(0): renamed, mode change and modified' \
|
||||||
'git mv file3 file2 &&
|
'git mv file3 file2 &&
|
||||||
echo "Propter nomen suum." >> file2 &&
|
echo "Propter nomen suum." >> file2 &&
|
||||||
safe_chmod +x file2 &&
|
test_chmod +x file2 &&
|
||||||
git commit -a -m "File rename, mode change and modification." &&
|
git commit -a -m "File rename, mode change and modification." &&
|
||||||
gitweb_run "p=.git;a=commitdiff"'
|
gitweb_run "p=.git;a=commitdiff"'
|
||||||
test_debug 'cat gitweb.log'
|
test_debug 'cat gitweb.log'
|
||||||
@ -425,10 +417,10 @@ test_expect_success \
|
|||||||
git add 03-new &&
|
git add 03-new &&
|
||||||
git mv 04-rename-from 04-rename-to &&
|
git mv 04-rename-from 04-rename-to &&
|
||||||
echo "Changed" >> 04-rename-to &&
|
echo "Changed" >> 04-rename-to &&
|
||||||
safe_chmod +x 05-mode-change &&
|
test_chmod +x 05-mode-change &&
|
||||||
rm -f 06-file-or-symlink && ln -s 01-change 06-file-or-symlink &&
|
rm -f 06-file-or-symlink && ln -s 01-change 06-file-or-symlink &&
|
||||||
echo "Changed and have mode changed" > 07-change-mode-change &&
|
echo "Changed and have mode changed" > 07-change-mode-change &&
|
||||||
safe_chmod +x 07-change-mode-change &&
|
test_chmod +x 07-change-mode-change &&
|
||||||
git commit -a -m "Large commit" &&
|
git commit -a -m "Large commit" &&
|
||||||
git checkout master'
|
git checkout master'
|
||||||
|
|
||||||
|
@ -7,7 +7,7 @@ test_description='perl interface (Git.pm)'
|
|||||||
. ./test-lib.sh
|
. ./test-lib.sh
|
||||||
|
|
||||||
perl -MTest::More -e 0 2>/dev/null || {
|
perl -MTest::More -e 0 2>/dev/null || {
|
||||||
say_color skip "Perl Test::More unavailable, skipping test"
|
say "Perl Test::More unavailable, skipping test"
|
||||||
test_done
|
test_done
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -238,18 +238,25 @@ test_merge () {
|
|||||||
git tag "$1"
|
git tag "$1"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# This function helps systems where core.filemode=false is set.
|
||||||
|
# Use it instead of plain 'chmod +x' to set or unset the executable bit
|
||||||
|
# of a file in the working directory and add it to the index.
|
||||||
|
|
||||||
|
test_chmod () {
|
||||||
|
chmod "$@" &&
|
||||||
|
git update-index --add "--chmod=$@"
|
||||||
|
}
|
||||||
|
|
||||||
# You are not expected to call test_ok_ and test_failure_ directly, use
|
# You are not expected to call test_ok_ and test_failure_ directly, use
|
||||||
# the text_expect_* functions instead.
|
# the text_expect_* functions instead.
|
||||||
|
|
||||||
test_ok_ () {
|
test_ok_ () {
|
||||||
test_count=$(expr "$test_count" + 1)
|
test_success=$(($test_success + 1))
|
||||||
test_success=$(expr "$test_success" + 1)
|
|
||||||
say_color "" " ok $test_count: $@"
|
say_color "" " ok $test_count: $@"
|
||||||
}
|
}
|
||||||
|
|
||||||
test_failure_ () {
|
test_failure_ () {
|
||||||
test_count=$(expr "$test_count" + 1)
|
test_failure=$(($test_failure + 1))
|
||||||
test_failure=$(expr "$test_failure" + 1);
|
|
||||||
say_color error "FAIL $test_count: $1"
|
say_color error "FAIL $test_count: $1"
|
||||||
shift
|
shift
|
||||||
echo "$@" | sed -e 's/^/ /'
|
echo "$@" | sed -e 's/^/ /'
|
||||||
@ -257,13 +264,11 @@ test_failure_ () {
|
|||||||
}
|
}
|
||||||
|
|
||||||
test_known_broken_ok_ () {
|
test_known_broken_ok_ () {
|
||||||
test_count=$(expr "$test_count" + 1)
|
|
||||||
test_fixed=$(($test_fixed+1))
|
test_fixed=$(($test_fixed+1))
|
||||||
say_color "" " FIXED $test_count: $@"
|
say_color "" " FIXED $test_count: $@"
|
||||||
}
|
}
|
||||||
|
|
||||||
test_known_broken_failure_ () {
|
test_known_broken_failure_ () {
|
||||||
test_count=$(expr "$test_count" + 1)
|
|
||||||
test_broken=$(($test_broken+1))
|
test_broken=$(($test_broken+1))
|
||||||
say_color skip " still broken $test_count: $@"
|
say_color skip " still broken $test_count: $@"
|
||||||
}
|
}
|
||||||
@ -279,12 +284,11 @@ test_run_ () {
|
|||||||
}
|
}
|
||||||
|
|
||||||
test_skip () {
|
test_skip () {
|
||||||
this_test=$(expr "./$0" : '.*/\(t[0-9]*\)-[^/]*$')
|
test_count=$(($test_count+1))
|
||||||
this_test="$this_test.$(expr "$test_count" + 1)"
|
|
||||||
to_skip=
|
to_skip=
|
||||||
for skp in $GIT_SKIP_TESTS
|
for skp in $GIT_SKIP_TESTS
|
||||||
do
|
do
|
||||||
case "$this_test" in
|
case $this_test.$test_count in
|
||||||
$skp)
|
$skp)
|
||||||
to_skip=t
|
to_skip=t
|
||||||
esac
|
esac
|
||||||
@ -292,7 +296,6 @@ test_skip () {
|
|||||||
case "$to_skip" in
|
case "$to_skip" in
|
||||||
t)
|
t)
|
||||||
say_color skip >&3 "skipping test: $@"
|
say_color skip >&3 "skipping test: $@"
|
||||||
test_count=$(expr "$test_count" + 1)
|
|
||||||
say_color skip "skip $test_count: $1"
|
say_color skip "skip $test_count: $1"
|
||||||
: true
|
: true
|
||||||
;;
|
;;
|
||||||
@ -370,7 +373,7 @@ test_external () {
|
|||||||
then
|
then
|
||||||
# Announce the script to reduce confusion about the
|
# Announce the script to reduce confusion about the
|
||||||
# test output that follows.
|
# test output that follows.
|
||||||
say_color "" " run $(expr "$test_count" + 1): $descr ($*)"
|
say_color "" " run $test_count: $descr ($*)"
|
||||||
# Run command; redirect its stderr to &4 as in
|
# Run command; redirect its stderr to &4 as in
|
||||||
# test_run_, but keep its stdout on our stdout even in
|
# test_run_, but keep its stdout on our stdout even in
|
||||||
# non-verbose mode.
|
# non-verbose mode.
|
||||||
@ -613,7 +616,8 @@ test_create_repo "$test"
|
|||||||
# in subprocesses like git equals our $PWD (for pathname comparisons).
|
# in subprocesses like git equals our $PWD (for pathname comparisons).
|
||||||
cd -P "$test" || exit 1
|
cd -P "$test" || exit 1
|
||||||
|
|
||||||
this_test=$(expr "./$0" : '.*/\(t[0-9]*\)-[^/]*$')
|
this_test=${0##*/}
|
||||||
|
this_test=${this_test%%-*}
|
||||||
for skp in $GIT_SKIP_TESTS
|
for skp in $GIT_SKIP_TESTS
|
||||||
do
|
do
|
||||||
to_skip=
|
to_skip=
|
||||||
|
Loading…
Reference in New Issue
Block a user