|
|
|
#!/bin/sh
|
|
|
|
#
|
|
|
|
# Copyright (c) 2005 Junio C Hamano
|
|
|
|
#
|
|
|
|
|
|
|
|
test_description='Pathnames with funny characters.
|
|
|
|
|
|
|
|
This test tries pathnames with funny characters in the working
|
|
|
|
tree, index, and tree objects.
|
|
|
|
'
|
|
|
|
|
|
|
|
. ./test-lib.sh
|
|
|
|
|
|
|
|
p0='no-funny'
|
|
|
|
p1='tabs ," (dq) and spaces'
|
|
|
|
p2='just space'
|
|
|
|
|
|
|
|
test_expect_success 'setup' '
|
|
|
|
cat >"$p0" <<-\EOF &&
|
|
|
|
1. A quick brown fox jumps over the lazy cat, oops dog.
|
|
|
|
2. A quick brown fox jumps over the lazy cat, oops dog.
|
|
|
|
3. A quick brown fox jumps over the lazy cat, oops dog.
|
|
|
|
EOF
|
|
|
|
|
|
|
|
{ cat "$p0" >"$p1" || :; } &&
|
|
|
|
{ echo "Foo Bar Baz" >"$p2" || :; } &&
|
|
|
|
|
|
|
|
if test -f "$p1" && cmp "$p0" "$p1"
|
|
|
|
then
|
|
|
|
test_set_prereq TABS_IN_FILENAMES
|
|
|
|
fi
|
|
|
|
'
|
|
|
|
|
|
|
|
if ! test_have_prereq TABS_IN_FILENAMES
|
|
|
|
then
|
|
|
|
# since FAT/NTFS does not allow tabs in filenames, skip this test
|
|
|
|
skip_all='Your filesystem does not allow tabs in filenames'
|
|
|
|
test_done
|
|
|
|
fi
|
|
|
|
|
|
|
|
test_expect_success 'setup: populate index and tree' '
|
|
|
|
git update-index --add "$p0" "$p2" &&
|
|
|
|
t0=$(git write-tree)
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'ls-files prints space in filename verbatim' '
|
|
|
|
printf "%s\n" "just space" no-funny >expected &&
|
|
|
|
git ls-files >current &&
|
|
|
|
test_cmp expected current
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'setup: add funny filename' '
|
|
|
|
git update-index --add "$p1" &&
|
|
|
|
t1=$(git write-tree)
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'ls-files quotes funny filename' '
|
|
|
|
cat >expected <<-\EOF &&
|
|
|
|
just space
|
|
|
|
no-funny
|
|
|
|
"tabs\t,\" (dq) and spaces"
|
|
|
|
EOF
|
|
|
|
git ls-files >current &&
|
|
|
|
test_cmp expected current
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'ls-files -z does not quote funny filename' '
|
|
|
|
cat >expected <<-\EOF &&
|
|
|
|
just space
|
|
|
|
no-funny
|
|
|
|
tabs ," (dq) and spaces
|
|
|
|
EOF
|
|
|
|
git ls-files -z >ls-files.z &&
|
|
|
|
"$PERL_PATH" -pe "y/\000/\012/" <ls-files.z >current &&
|
|
|
|
test_cmp expected current
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'ls-tree quotes funny filename' '
|
|
|
|
cat >expected <<-\EOF &&
|
|
|
|
just space
|
|
|
|
no-funny
|
|
|
|
"tabs\t,\" (dq) and spaces"
|
|
|
|
EOF
|
|
|
|
git ls-tree -r $t1 >ls-tree &&
|
|
|
|
sed -e "s/^[^ ]* //" <ls-tree >current &&
|
|
|
|
test_cmp expected current
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'diff-index --name-status quotes funny filename' '
|
|
|
|
cat >expected <<-\EOF &&
|
|
|
|
A "tabs\t,\" (dq) and spaces"
|
|
|
|
EOF
|
|
|
|
git diff-index --name-status $t0 >current &&
|
|
|
|
test_cmp expected current
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'diff-tree --name-status quotes funny filename' '
|
|
|
|
cat >expected <<-\EOF &&
|
|
|
|
A "tabs\t,\" (dq) and spaces"
|
|
|
|
EOF
|
|
|
|
git diff-tree --name-status $t0 $t1 >current &&
|
|
|
|
test_cmp expected current
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'diff-index -z does not quote funny filename' '
|
|
|
|
cat >expected <<-\EOF &&
|
|
|
|
A
|
|
|
|
tabs ," (dq) and spaces
|
|
|
|
EOF
|
|
|
|
git diff-index -z --name-status $t0 >diff-index.z &&
|
|
|
|
"$PERL_PATH" -pe "y/\000/\012/" <diff-index.z >current &&
|
|
|
|
test_cmp expected current
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'diff-tree -z does not quote funny filename' '
|
|
|
|
cat >expected <<-\EOF &&
|
|
|
|
A
|
|
|
|
tabs ," (dq) and spaces
|
|
|
|
EOF
|
|
|
|
git diff-tree -z --name-status $t0 $t1 >diff-tree.z &&
|
|
|
|
"$PERL_PATH" -pe y/\\000/\\012/ <diff-tree.z >current &&
|
|
|
|
test_cmp expected current
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'diff-tree --find-copies-harder quotes funny filename' '
|
|
|
|
cat >expected <<-\EOF &&
|
|
|
|
CNUM no-funny "tabs\t,\" (dq) and spaces"
|
|
|
|
EOF
|
|
|
|
git diff-tree -C --find-copies-harder --name-status $t0 $t1 >out &&
|
|
|
|
sed -e "s/^C[0-9]*/CNUM/" <out >current &&
|
|
|
|
test_cmp expected current
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'setup: remove unfunny index entry' '
|
|
|
|
git update-index --force-remove "$p0"
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'diff-tree -M quotes funny filename' '
|
|
|
|
cat >expected <<-\EOF &&
|
|
|
|
RNUM no-funny "tabs\t,\" (dq) and spaces"
|
|
|
|
EOF
|
|
|
|
git diff-index -M --name-status $t0 >out &&
|
|
|
|
sed -e "s/^R[0-9]*/RNUM/" <out >current &&
|
|
|
|
test_cmp expected current
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'diff-index -M -p quotes funny filename' '
|
|
|
|
cat >expected <<-\EOF &&
|
|
|
|
diff --git a/no-funny "b/tabs\t,\" (dq) and spaces"
|
|
|
|
similarity index NUM%
|
|
|
|
rename from no-funny
|
|
|
|
rename to "tabs\t,\" (dq) and spaces"
|
|
|
|
EOF
|
|
|
|
git diff-index -M -p $t0 >diff &&
|
|
|
|
sed -e "s/index [0-9]*%/index NUM%/" <diff >current &&
|
|
|
|
test_cmp expected current
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'setup: mode change' '
|
|
|
|
chmod +x "$p1"
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'diff-index -M -p with mode change quotes funny filename' '
|
|
|
|
cat >expected <<-\EOF &&
|
|
|
|
diff --git a/no-funny "b/tabs\t,\" (dq) and spaces"
|
|
|
|
old mode 100644
|
|
|
|
new mode 100755
|
|
|
|
similarity index NUM%
|
|
|
|
rename from no-funny
|
|
|
|
rename to "tabs\t,\" (dq) and spaces"
|
|
|
|
EOF
|
|
|
|
git diff-index -M -p $t0 >diff &&
|
|
|
|
sed -e "s/index [0-9]*%/index NUM%/" <diff >current &&
|
|
|
|
test_cmp expected current
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'diffstat for rename quotes funny filename' '
|
|
|
|
cat >expected <<-\EOF &&
|
|
|
|
"tabs\t,\" (dq) and spaces"
|
|
|
|
1 file changed, 0 insertions(+), 0 deletions(-)
|
|
|
|
EOF
|
|
|
|
git diff-index -M -p $t0 >diff &&
|
|
|
|
git apply --stat <diff >diffstat &&
|
|
|
|
sed -e "s/|.*//" -e "s/ *\$//" <diffstat >current &&
|
|
|
|
test_i18ncmp expected current
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'numstat for rename quotes funny filename' '
|
|
|
|
cat >expected <<-\EOF &&
|
|
|
|
0 0 "tabs\t,\" (dq) and spaces"
|
|
|
|
EOF
|
|
|
|
git diff-index -M -p $t0 >diff &&
|
|
|
|
git apply --numstat <diff >current &&
|
|
|
|
test_cmp expected current
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'numstat without -M quotes funny filename' '
|
|
|
|
cat >expected <<-\EOF &&
|
|
|
|
0 3 no-funny
|
|
|
|
3 0 "tabs\t,\" (dq) and spaces"
|
|
|
|
EOF
|
|
|
|
git diff-index -p $t0 >diff &&
|
|
|
|
git apply --numstat <diff >current &&
|
|
|
|
test_cmp expected current
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'numstat for non-git rename diff quotes funny filename' '
|
|
|
|
cat >expected <<-\EOF &&
|
|
|
|
0 3 no-funny
|
|
|
|
3 0 "tabs\t,\" (dq) and spaces"
|
|
|
|
EOF
|
|
|
|
git diff-index -p $t0 >git-diff &&
|
|
|
|
sed -ne "/^[-+@]/p" <git-diff >diff &&
|
|
|
|
git apply --numstat <diff >current &&
|
|
|
|
test_cmp expected current
|
|
|
|
'
|
|
|
|
|
|
|
|
test_done
|