Browse Source
Sometimes it is convient for a Porcelain to be able to checkout all unmerged files in all stages so that an external merge tool can be executed by the Porcelain or the end-user. Using git-unpack-file on each stage individually incurs a rather high penalty due to the need to fork for each file version obtained. git-checkout-index -a --stage=all will now do the same thing, but faster. Signed-off-by: Shawn O. Pearce <spearce@spearce.org> Signed-off-by: Junio C Hamano <junkio@cox.net>maint


7 changed files with 371 additions and 27 deletions
@ -0,0 +1,212 @@
@@ -0,0 +1,212 @@
|
||||
#!/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 \ |
||||
'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 |
Loading…
Reference in new issue