704a3143d5
Many tests depend on that symbolic links work. This introduces a check that sets the prerequisite tag SYMLINKS if the file system supports symbolic links. Since so many tests have to check for this prerequisite, we do the check in test-lib.sh, so that we don't need to repeat the test in many scripts. To check for 'ln -s' failures, you can use a FAT partition on Linux: $ mkdosfs -C git-on-fat 1000000 $ sudo mount -o loop,uid=j6t,gid=users,shortname=winnt git-on-fat /mnt Clone git to /mnt and $ GIT_SKIP_TESTS='t0001.1[34] t0010 t1301 t403[34] t4129.[47] t5701.7 t7701.3 t9100 t9101.26 t9119 t9124.[67] t9200.10 t9600.6' \ make test (These additionally skipped tests depend on POSIX permissions that FAT on Linux does not provide.) Signed-off-by: Johannes Sixt <j6t@kdbg.org>
213 lines
5.5 KiB
Bash
Executable File
213 lines
5.5 KiB
Bash
Executable File
#!/bin/sh
|
|
#
|
|
# Copyright (c) 2006 Shawn Pearce
|
|
#
|
|
|
|
test_description='git checkout-index --temp test.
|
|
|
|
With --temp flag, git checkout-index writes to temporary merge files
|
|
rather than the tracked path.'
|
|
|
|
. ./test-lib.sh
|
|
|
|
test_expect_success \
|
|
'preparation' '
|
|
mkdir asubdir &&
|
|
echo tree1path0 >path0 &&
|
|
echo tree1path1 >path1 &&
|
|
echo tree1path3 >path3 &&
|
|
echo tree1path4 >path4 &&
|
|
echo tree1asubdir/path5 >asubdir/path5 &&
|
|
git update-index --add path0 path1 path3 path4 asubdir/path5 &&
|
|
t1=$(git write-tree) &&
|
|
rm -f path* .merge_* out .git/index &&
|
|
echo tree2path0 >path0 &&
|
|
echo tree2path1 >path1 &&
|
|
echo tree2path2 >path2 &&
|
|
echo tree2path4 >path4 &&
|
|
git update-index --add path0 path1 path2 path4 &&
|
|
t2=$(git write-tree) &&
|
|
rm -f path* .merge_* out .git/index &&
|
|
echo tree2path0 >path0 &&
|
|
echo tree3path1 >path1 &&
|
|
echo tree3path2 >path2 &&
|
|
echo tree3path3 >path3 &&
|
|
git update-index --add path0 path1 path2 path3 &&
|
|
t3=$(git write-tree)'
|
|
|
|
test_expect_success \
|
|
'checkout one stage 0 to temporary file' '
|
|
rm -f path* .merge_* out .git/index &&
|
|
git read-tree $t1 &&
|
|
git checkout-index --temp -- path1 >out &&
|
|
test $(wc -l <out) = 1 &&
|
|
test $(cut "-d " -f2 out) = path1 &&
|
|
p=$(cut "-d " -f1 out) &&
|
|
test -f $p &&
|
|
test $(cat $p) = tree1path1'
|
|
|
|
test_expect_success \
|
|
'checkout all stage 0 to temporary files' '
|
|
rm -f path* .merge_* out .git/index &&
|
|
git read-tree $t1 &&
|
|
git checkout-index -a --temp >out &&
|
|
test $(wc -l <out) = 5 &&
|
|
for f in path0 path1 path3 path4 asubdir/path5
|
|
do
|
|
test $(grep $f out | cut "-d " -f2) = $f &&
|
|
p=$(grep $f out | cut "-d " -f1) &&
|
|
test -f $p &&
|
|
test $(cat $p) = tree1$f
|
|
done'
|
|
|
|
test_expect_success \
|
|
'prepare 3-way merge' '
|
|
rm -f path* .merge_* out .git/index &&
|
|
git read-tree -m $t1 $t2 $t3'
|
|
|
|
test_expect_success \
|
|
'checkout one stage 2 to temporary file' '
|
|
rm -f path* .merge_* out &&
|
|
git checkout-index --stage=2 --temp -- path1 >out &&
|
|
test $(wc -l <out) = 1 &&
|
|
test $(cut "-d " -f2 out) = path1 &&
|
|
p=$(cut "-d " -f1 out) &&
|
|
test -f $p &&
|
|
test $(cat $p) = tree2path1'
|
|
|
|
test_expect_success \
|
|
'checkout all stage 2 to temporary files' '
|
|
rm -f path* .merge_* out &&
|
|
git checkout-index --all --stage=2 --temp >out &&
|
|
test $(wc -l <out) = 3 &&
|
|
for f in path1 path2 path4
|
|
do
|
|
test $(grep $f out | cut "-d " -f2) = $f &&
|
|
p=$(grep $f out | cut "-d " -f1) &&
|
|
test -f $p &&
|
|
test $(cat $p) = tree2$f
|
|
done'
|
|
|
|
test_expect_success \
|
|
'checkout all stages/one file to nothing' '
|
|
rm -f path* .merge_* out &&
|
|
git checkout-index --stage=all --temp -- path0 >out &&
|
|
test $(wc -l <out) = 0'
|
|
|
|
test_expect_success \
|
|
'checkout all stages/one file to temporary files' '
|
|
rm -f path* .merge_* out &&
|
|
git checkout-index --stage=all --temp -- path1 >out &&
|
|
test $(wc -l <out) = 1 &&
|
|
test $(cut "-d " -f2 out) = path1 &&
|
|
cut "-d " -f1 out | (read s1 s2 s3 &&
|
|
test -f $s1 &&
|
|
test -f $s2 &&
|
|
test -f $s3 &&
|
|
test $(cat $s1) = tree1path1 &&
|
|
test $(cat $s2) = tree2path1 &&
|
|
test $(cat $s3) = tree3path1)'
|
|
|
|
test_expect_success \
|
|
'checkout some stages/one file to temporary files' '
|
|
rm -f path* .merge_* out &&
|
|
git checkout-index --stage=all --temp -- path2 >out &&
|
|
test $(wc -l <out) = 1 &&
|
|
test $(cut "-d " -f2 out) = path2 &&
|
|
cut "-d " -f1 out | (read s1 s2 s3 &&
|
|
test $s1 = . &&
|
|
test -f $s2 &&
|
|
test -f $s3 &&
|
|
test $(cat $s2) = tree2path2 &&
|
|
test $(cat $s3) = tree3path2)'
|
|
|
|
test_expect_success \
|
|
'checkout all stages/all files to temporary files' '
|
|
rm -f path* .merge_* out &&
|
|
git checkout-index -a --stage=all --temp >out &&
|
|
test $(wc -l <out) = 5'
|
|
|
|
test_expect_success \
|
|
'-- path0: no entry' '
|
|
test x$(grep path0 out | cut "-d " -f2) = x'
|
|
|
|
test_expect_success \
|
|
'-- path1: all 3 stages' '
|
|
test $(grep path1 out | cut "-d " -f2) = path1 &&
|
|
grep path1 out | cut "-d " -f1 | (read s1 s2 s3 &&
|
|
test -f $s1 &&
|
|
test -f $s2 &&
|
|
test -f $s3 &&
|
|
test $(cat $s1) = tree1path1 &&
|
|
test $(cat $s2) = tree2path1 &&
|
|
test $(cat $s3) = tree3path1)'
|
|
|
|
test_expect_success \
|
|
'-- path2: no stage 1, have stage 2 and 3' '
|
|
test $(grep path2 out | cut "-d " -f2) = path2 &&
|
|
grep path2 out | cut "-d " -f1 | (read s1 s2 s3 &&
|
|
test $s1 = . &&
|
|
test -f $s2 &&
|
|
test -f $s3 &&
|
|
test $(cat $s2) = tree2path2 &&
|
|
test $(cat $s3) = tree3path2)'
|
|
|
|
test_expect_success \
|
|
'-- path3: no stage 2, have stage 1 and 3' '
|
|
test $(grep path3 out | cut "-d " -f2) = path3 &&
|
|
grep path3 out | cut "-d " -f1 | (read s1 s2 s3 &&
|
|
test -f $s1 &&
|
|
test $s2 = . &&
|
|
test -f $s3 &&
|
|
test $(cat $s1) = tree1path3 &&
|
|
test $(cat $s3) = tree3path3)'
|
|
|
|
test_expect_success \
|
|
'-- path4: no stage 3, have stage 1 and 3' '
|
|
test $(grep path4 out | cut "-d " -f2) = path4 &&
|
|
grep path4 out | cut "-d " -f1 | (read s1 s2 s3 &&
|
|
test -f $s1 &&
|
|
test -f $s2 &&
|
|
test $s3 = . &&
|
|
test $(cat $s1) = tree1path4 &&
|
|
test $(cat $s2) = tree2path4)'
|
|
|
|
test_expect_success \
|
|
'-- asubdir/path5: no stage 2 and 3 have stage 1' '
|
|
test $(grep asubdir/path5 out | cut "-d " -f2) = asubdir/path5 &&
|
|
grep asubdir/path5 out | cut "-d " -f1 | (read s1 s2 s3 &&
|
|
test -f $s1 &&
|
|
test $s2 = . &&
|
|
test $s3 = . &&
|
|
test $(cat $s1) = tree1asubdir/path5)'
|
|
|
|
test_expect_success \
|
|
'checkout --temp within subdir' '
|
|
(cd asubdir &&
|
|
git checkout-index -a --stage=all >out &&
|
|
test $(wc -l <out) = 1 &&
|
|
test $(grep path5 out | cut "-d " -f2) = path5 &&
|
|
grep path5 out | cut "-d " -f1 | (read s1 s2 s3 &&
|
|
test -f ../$s1 &&
|
|
test $s2 = . &&
|
|
test $s3 = . &&
|
|
test $(cat ../$s1) = tree1asubdir/path5)
|
|
)'
|
|
|
|
test_expect_success SYMLINKS \
|
|
'checkout --temp symlink' '
|
|
rm -f path* .merge_* out .git/index &&
|
|
ln -s b a &&
|
|
git update-index --add a &&
|
|
t4=$(git write-tree) &&
|
|
rm -f .git/index &&
|
|
git read-tree $t4 &&
|
|
git checkout-index --temp -a >out &&
|
|
test $(wc -l <out) = 1 &&
|
|
test $(cut "-d " -f2 out) = a &&
|
|
p=$(cut "-d " -f1 out) &&
|
|
test -f $p &&
|
|
test $(cat $p) = b'
|
|
|
|
test_done
|