Browse Source

more tr portability test script fixes

Dealing with NULs is not always safe with tr. On Solaris,
incoming NULs are silently deleted by both the System V and
UCB versions of tr. When converting to NULs, the System V
version works fine, but the UCB version silently ignores the
request to convert the character.

This patch changes all instances of tr using NULs to use
"perl -pe 'y///'" instead.

Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
maint
Jeff King 17 years ago committed by Junio C Hamano
parent
commit
e85fe4d85b
  1. 4
      t/diff-lib.sh
  2. 2
      t/t0020-crlf.sh
  3. 4
      t/t1300-repo-config.sh
  4. 6
      t/t3300-funny-names.sh
  5. 2
      t/t4020-diff-external.sh
  6. 4
      t/t4103-apply-binary.sh
  7. 4
      t/t4116-apply-reverse.sh
  8. 2
      t/t4200-rerere.sh
  9. 2
      t/t5300-pack-object.sh
  10. 4
      test-sha1.sh

4
t/diff-lib.sh

@ -21,8 +21,8 @@ compare_diff_raw_z () { @@ -21,8 +21,8 @@ compare_diff_raw_z () {
# Also we do not check SHA1 hash generation in this test, which
# is a job for t0000-basic.sh

tr '\000' '\012' <"$1" | sed -e "$sanitize_diff_raw_z" >.tmp-1
tr '\000' '\012' <"$2" | sed -e "$sanitize_diff_raw_z" >.tmp-2
perl -pe 'y/\000/\012/' <"$1" | sed -e "$sanitize_diff_raw_z" >.tmp-1
perl -pe 'y/\000/\012/' <"$2" | sed -e "$sanitize_diff_raw_z" >.tmp-2
git diff .tmp-1 .tmp-2 && rm -f .tmp-1 .tmp-2
}


2
t/t0020-crlf.sh

@ -5,7 +5,7 @@ test_description='CRLF conversion' @@ -5,7 +5,7 @@ test_description='CRLF conversion'
. ./test-lib.sh

q_to_nul () {
tr Q '\000'
perl -pe 'y/Q/\000/'
}

q_to_cr () {

4
t/t1300-repo-config.sh

@ -657,12 +657,12 @@ Qsection.sub=section.val4 @@ -657,12 +657,12 @@ Qsection.sub=section.val4
Qsection.sub=section.val5Q
EOF

git config --null --list | tr '\000' 'Q' > result
git config --null --list | perl -pe 'y/\000/Q/' > result
echo >>result

test_expect_success '--null --list' 'cmp result expect'

git config --null --get-regexp 'val[0-9]' | tr '\000' 'Q' > result
git config --null --get-regexp 'val[0-9]' | perl -pe 'y/\000/Q/' > result
echo >>result

test_expect_success '--null --get-regexp' 'cmp result expect'

6
t/t3300-funny-names.sh

@ -54,7 +54,7 @@ echo 'just space @@ -54,7 +54,7 @@ echo 'just space
no-funny
tabs ," (dq) and spaces' >expected
test_expect_success 'git ls-files -z with-funny' \
'git ls-files -z | tr \\000 \\012 >current &&
'git ls-files -z | perl -pe y/\\000/\\012/ >current &&
git diff expected current'

t1=`git write-tree`
@ -83,11 +83,11 @@ test_expect_success 'git diff-tree with-funny' \ @@ -83,11 +83,11 @@ test_expect_success 'git diff-tree with-funny' \
echo 'A
tabs ," (dq) and spaces' >expected
test_expect_success 'git diff-index -z with-funny' \
'git diff-index -z --name-status $t0 | tr \\000 \\012 >current &&
'git diff-index -z --name-status $t0 | perl -pe y/\\000/\\012/ >current &&
git diff expected current'

test_expect_success 'git diff-tree -z with-funny' \
'git diff-tree -z --name-status $t0 $t1 | tr \\000 \\012 >current &&
'git diff-tree -z --name-status $t0 $t1 | perl -pe y/\\000/\\012/ >current &&
git diff expected current'

cat > expected <<\EOF

2
t/t4020-diff-external.sh

@ -99,7 +99,7 @@ test_expect_success 'no diff with -diff' ' @@ -99,7 +99,7 @@ test_expect_success 'no diff with -diff' '
git diff | grep Binary
'

echo NULZbetweenZwords | tr Z '\000' > file
echo NULZbetweenZwords | perl -pe 'y/Z/\000/' > file

test_expect_success 'force diff with "diff"' '
echo >.gitattributes "file diff" &&

4
t/t4103-apply-binary.sh

@ -24,10 +24,10 @@ git update-index --add --remove file1 file2 file4 @@ -24,10 +24,10 @@ git update-index --add --remove file1 file2 file4
git-commit -m 'Initial Version' 2>/dev/null

git-checkout -b binary
tr 'x' '\000' <file1 >file3
perl -pe 'y/x/\000/' <file1 >file3
cat file3 >file4
git add file2
tr '\000' 'v' <file3 >file1
perl -pe 'y/\000/v/' <file3 >file1
rm -f file2
git update-index --add --remove file1 file2 file3 file4
git-commit -m 'Second Version'

4
t/t4116-apply-reverse.sh

@ -12,14 +12,14 @@ test_description='git apply in reverse @@ -12,14 +12,14 @@ test_description='git apply in reverse
test_expect_success setup '

for i in a b c d e f g h i j k l m n; do echo $i; done >file1 &&
tr "ijk" '\''\000\001\002'\'' <file1 >file2 &&
perl -pe "y/ijk/\\000\\001\\002/" <file1 >file2 &&

git add file1 file2 &&
git commit -m initial &&
git tag initial &&

for i in a b c g h i J K L m o n p q; do echo $i; done >file1 &&
tr "mon" '\''\000\001\002'\'' <file1 >file2 &&
perl -pe "y/mon/\\000\\001\\002/" <file1 >file2 &&

git commit -a -m second &&
git tag second &&

2
t/t4200-rerere.sh

@ -129,7 +129,7 @@ test_expect_success 'rerere kicked in' "! grep ======= a1" @@ -129,7 +129,7 @@ test_expect_success 'rerere kicked in' "! grep ======= a1"
test_expect_success 'rerere prefers first change' 'git diff a1 expect'

rm $rr/postimage
echo "$sha1 a1" | tr '\012' '\000' > .git/rr-cache/MERGE_RR
echo "$sha1 a1" | perl -pe 'y/\012/\000/' > .git/rr-cache/MERGE_RR

test_expect_success 'rerere clear' 'git rerere clear'


2
t/t5300-pack-object.sh

@ -15,7 +15,7 @@ test_expect_success \ @@ -15,7 +15,7 @@ test_expect_success \
'rm -f .git/index*
for i in a b c
do
dd if=/dev/zero bs=4k count=1 | tr "\\000" $i >$i &&
dd if=/dev/zero bs=4k count=1 | perl -pe "y/\\000/$i/" >$i &&
git update-index --add $i || return 1
done &&
cat c >d && echo foo >>d && git update-index --add d &&

4
test-sha1.sh

@ -10,7 +10,7 @@ do @@ -10,7 +10,7 @@ do
{
test -z "$pfx" || echo "$pfx"
dd if=/dev/zero bs=1048576 count=$cnt 2>/dev/null |
tr '\000' 'g'
perl -pe 'y/\000/g/'
} | ./test-sha1 $cnt
`
if test "$expect" = "$actual"
@ -55,7 +55,7 @@ do @@ -55,7 +55,7 @@ do
{
test -z "$pfx" || echo "$pfx"
dd if=/dev/zero bs=1048576 count=$cnt 2>/dev/null |
tr '\000' 'g'
perl -pe 'y/\000/g/'
} | sha1sum |
sed -e 's/ .*//'
`

Loading…
Cancel
Save