diff options
Diffstat (limited to 'REORG.TODO/iconvdata/run-iconv-test.sh')
-rwxr-xr-x | REORG.TODO/iconvdata/run-iconv-test.sh | 208 |
1 files changed, 208 insertions, 0 deletions
diff --git a/REORG.TODO/iconvdata/run-iconv-test.sh b/REORG.TODO/iconvdata/run-iconv-test.sh new file mode 100755 index 0000000000..226a2e2d43 --- /dev/null +++ b/REORG.TODO/iconvdata/run-iconv-test.sh @@ -0,0 +1,208 @@ +#!/bin/sh -f +# Run available iconv(1) tests. +# Copyright (C) 1998-2017 Free Software Foundation, Inc. +# This file is part of the GNU C Library. +# Contributed by Ulrich Drepper <drepper@cygnus.com>, 1998. + +# The GNU C Library is free software; you can redistribute it and/or +# modify it under the terms of the GNU Lesser General Public +# License as published by the Free Software Foundation; either +# version 2.1 of the License, or (at your option) any later version. + +# The GNU C Library is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +# Lesser General Public License for more details. + +# You should have received a copy of the GNU Lesser General Public +# License along with the GNU C Library; if not, see +# <http://www.gnu.org/licenses/>. + +set -e + +codir=$1 +test_wrapper_env="$2" +run_program_env="$3" + +# We use always the same temporary file. +temp1=$codir/iconvdata/iconv-test.xxx +temp2=$codir/iconvdata/iconv-test.yyy + +trap "rm -f $temp1 $temp2" 1 2 3 15 + +# We have to have some directories in the library path. +LIBPATH=$codir:$codir/iconvdata + +# How the start the iconv(1) program. +ICONV='$codir/elf/ld.so --library-path $LIBPATH --inhibit-rpath ${from}.so \ + $codir/iconv/iconv_prog' +ICONV="$test_wrapper_env $run_program_env $ICONV" + +# Which echo? +if (echo "testing\c"; echo 1,2,3) | grep c >/dev/null; then + ac_n=-n ac_c= ac_t= +else + ac_n= ac_c='\c' ac_t= +fi + +# We read the file named TESTS. All non-empty lines not starting with +# `#' are interpreted as commands. +failed=0 +while read from to subset targets; do + # Ignore empty and comment lines. + if test -z "$subset" || test "$from" = '#'; then continue; fi + + # Expand the variables now. + PROG=`eval echo $ICONV` + + if test -n "$targets"; then + for t in $targets; do + if test -f testdata/$from; then + echo $ac_n " test data: $from -> $t $ac_c" + $PROG -f $from -t $t testdata/$from < /dev/null > $temp1 || + { if test $? -gt 128; then exit 1; fi + echo "FAILED"; failed=1; continue; } + echo $ac_n "OK$ac_c" + if test -s testdata/$from..$t; then + LC_ALL=C cmp $temp1 testdata/$from..$t > /dev/null 2>&1 || + { echo "/FAILED"; failed=1; continue; } + echo $ac_n "/OK$ac_c" + fi + echo $ac_n " -> $from $ac_c" + $PROG -f $t -t $to -o $temp2 $temp1 < /dev/null || + { if test $? -gt 128; then exit 1; fi + echo "FAILED"; failed=1; continue; } + echo $ac_n "OK$ac_c" + test -s $temp1 && + LC_ALL=C cmp testdata/$from $temp2 > /dev/null 2>&1 || + { echo "/FAILED"; failed=1; continue; } + echo "/OK" + rm -f $temp1 $temp2 + fi + + # Now test some bigger text, entirely in ASCII. If ASCII is no subset + # of the coded character set we convert the text to this coded character + # set. Otherwise we convert to all the TARGETS. + if test $subset = Y; then + echo $ac_n " suntzu: $from -> $t -> $to $ac_c" + $PROG -f $from -t $t testdata/suntzus < /dev/null | + $PROG -f $t -t $to > $temp1 || + { if test $? -gt 128; then exit 1; fi + echo "FAILED"; failed=1; continue; } + echo $ac_n "OK$ac_c" + LC_ALL=C cmp testdata/suntzus $temp1 || + { echo "/FAILED"; failed=1; continue; } + echo "/OK" + fi + rm -f $temp1 + + # And tests where iconv(1) has to handle charmaps. + if test "$t" = UTF8; then tc=UTF-8; else tc="$t"; fi + if test -f ../localedata/charmaps/$from && + test -f ../localedata/charmaps/$tc && + test -f testdata/$from && + ! grep '<U....><U....>' ../localedata/charmaps/$from > /dev/null; then + echo $ac_n "test charmap: $from -> $t $ac_c" + $PROG -f ../localedata/charmaps/$from -t ../localedata/charmaps/$tc \ + testdata/$from < /dev/null > $temp1 || + { if test $? -gt 128; then exit 1; fi + echo "FAILED"; failed=1; continue; } + echo $ac_n "OK$ac_c" + if test -s testdata/$from..$t; then + LC_ALL=C cmp $temp1 testdata/$from..$t > /dev/null 2>&1 || + { echo "/FAILED"; failed=1; continue; } + echo $ac_n "/OK$ac_c" + fi + echo $ac_n " -> $from $ac_c" + $PROG -t ../localedata/charmaps/$from -f ../localedata/charmaps/$tc \ + -o $temp2 $temp1 < /dev/null || + { if test $? -gt 128; then exit 1; fi + echo "FAILED"; failed=1; continue; } + echo $ac_n "OK$ac_c" + test -s $temp1 && + LC_ALL=C cmp testdata/$from $temp2 > /dev/null 2>&1 || + { echo "/FAILED"; failed=1; continue; } + echo "/OK" + rm -f $temp1 $temp2 + fi + done + fi + + if test "$subset" = N; then + echo $ac_n " suntzu: ASCII -> $to -> ASCII $ac_c" + $PROG -f ASCII -t $to testdata/suntzus < /dev/null | + $PROG -f $to -t ASCII > $temp1 || + { if test $? -gt 128; then exit 1; fi + echo "FAILED"; failed=1; continue; } + echo $ac_n "OK$ac_c" + LC_ALL=C cmp testdata/suntzus $temp1 || + { echo "/FAILED"; failed=1; continue; } + echo "/OK" + fi +done < TESTS + +# We read the file named TESTS2. All non-empty lines not starting with +# `#' are interpreted as commands. +while read utf8 from filename; do + # Ignore empty and comment lines. + if test -z "$filename" || test "$utf8" = '#'; then continue; fi + + # Expand the variables now. + PROG=`eval echo $ICONV` + + # Test conversion to the endianness dependent encoding. + echo $ac_n "test encoder: $utf8 -> $from $ac_c" + $PROG -f $utf8 -t $from < testdata/${filename}..${utf8} > $temp1 + LC_ALL=C cmp $temp1 testdata/${filename}..${from}.BE > /dev/null 2>&1 || + LC_ALL=C cmp $temp1 testdata/${filename}..${from}.LE > /dev/null 2>&1 || + { echo "/FAILED"; failed=1; continue; } + echo "OK" + + # Test conversion from the endianness dependent encoding. + echo $ac_n "test decoder: $from -> $utf8 $ac_c" + $PROG -f $from -t $utf8 < testdata/${filename}..${from}.BE > $temp1 + LC_ALL=C cmp $temp1 testdata/${filename}..${utf8} > /dev/null 2>&1 || + { echo "/FAILED"; failed=1; continue; } + $PROG -f $from -t $utf8 < testdata/${filename}..${from}.LE > $temp1 + LC_ALL=C cmp $temp1 testdata/${filename}..${utf8} > /dev/null 2>&1 || + { echo "/FAILED"; failed=1; continue; } + echo "OK" + + # Test byte swapping behaviour. + echo $ac_n "test non-BOM: ${from}BE -> ${from}LE $ac_c" + $PROG -f ${from}BE -t ${from}LE < testdata/${filename}..${from}.BE > $temp1 + LC_ALL=C cmp $temp1 testdata/${filename}..${from}.LE > /dev/null 2>&1 || + { echo "/FAILED"; failed=1; continue; } + echo "OK" + + # Test byte swapping behaviour. + echo $ac_n "test non-BOM: ${from}LE -> ${from}BE $ac_c" + $PROG -f ${from}LE -t ${from}BE < testdata/${filename}..${from}.LE > $temp1 + LC_ALL=C cmp $temp1 testdata/${filename}..${from}.BE > /dev/null 2>&1 || + { echo "/FAILED"; failed=1; continue; } + echo "OK" + +done < TESTS2 + +# Check for crashes in decoders. +printf '\016\377\377\377\377\377\377\377' > $temp1 +for from in $iconv_modules ; do + echo $ac_n "test decoder $from $ac_c" + PROG=`eval echo $ICONV` + if $PROG -f $from -t UTF8 < $temp1 >/dev/null 2>&1 ; then + : # fall through + else + status=$? + if test $status -gt 1 ; then + echo "/FAILED" + failed=1 + continue + fi + fi + echo "OK" +done + +exit $failed +# Local Variables: +# mode:shell-script +# End: |