diff options
author | Jim Meyering <jim@meyering.net> | 2007-08-16 19:18:29 +0200 |
---|---|---|
committer | Jim Meyering <jim@meyering.net> | 2007-08-16 19:18:29 +0200 |
commit | d2e5e366a1d813e5ce2d03e250eb1ebe44473b63 (patch) | |
tree | bead7ed244a8336fa65069cfee3a717a7c044d3e /tests | |
parent | e069d38d35b8f50897f6bdc29cc022cd5efa9749 (diff) | |
download | coreutils-d2e5e366a1d813e5ce2d03e250eb1ebe44473b63.tar.xz |
Consolidate od tests.
* tests/misc/od: Perform od-zero-len's test here.
Include boilerplate code, so tests run in a subdirectory.
* tests/misc/od-zero-len: Remove this file.
Diffstat (limited to 'tests')
-rwxr-xr-x | tests/misc/od | 38 | ||||
-rwxr-xr-x | tests/misc/od-zero-len | 53 |
2 files changed, 37 insertions, 54 deletions
diff --git a/tests/misc/od b/tests/misc/od index aba847458..e5d0c59fd 100755 --- a/tests/misc/od +++ b/tests/misc/od @@ -20,6 +20,20 @@ : ${PERL=perl} : ${srcdir=.} +pwd=`pwd` +t0=`echo "$0"|sed 's,.*/,,'`.tmp; tmp=$t0/$$ +trap 'status=$?; cd "$pwd" && chmod -R u+rwx $t0 && rm -rf $t0 && exit $status' 0 +trap '(exit $?); exit $?' 1 2 13 15 + +framework_failure=0 +mkdir -p $tmp || framework_failure=1 +cd $tmp || framework_failure=1 + +if test $framework_failure = 1; then + echo "$0: failure in testing framework" 1>&2 + (exit 1); exit 1 +fi + PROG=`echo $0|sed 's,.*/,,'`; export PROG $PERL -e 1 > /dev/null 2>&1 || { @@ -28,7 +42,7 @@ $PERL -e 1 > /dev/null 2>&1 || { exit 77 } -exec $PERL -w -I$srcdir/.. -MCoreutils -- - <<\EOF +exec $PERL -w -I$pwd/.. -MCoreutils -- - <<\EOF require 5.003; use strict; @@ -37,6 +51,23 @@ use strict; # Turn off localisation of executable's ouput. @ENV{qw(LANGUAGE LANG LC_ALL)} = ('C') x 3; +# Use a file in /proc whose size is not likely to +# change between the wc and od invocations. +my $proc_file = '/proc/version'; +-f $proc_file + or $proc_file = '/dev/null'; + +# Count the bytes in $proc_file, _by reading_. +my $len = 0; +open FH, '<', $proc_file + or die "$program_name: can't open `$proc_file' for reading: $!\n"; +while (defined (my $line = <FH>)) + { + $len += length $line; + } +close FH; +my $proc_file_byte_count = $len; + my @Tests = ( # Skip the exact length of the input file. @@ -49,6 +80,11 @@ my @Tests = # Skip the sum of the lengths of the first three inputs, printing the 4th. ['j-bug4', '-c -j 3 -An', {IN=>{g=>'a'}}, {IN=>{h=>'b'}}, {IN=>{i=>'c'}}, {IN=>{j=>'d'}}, {OUT=>" d\n"}], + + # Ensure that od -j doesn't fseek across a nonempty file in /proc, + # even if the kernel reports that the file has stat.st_size = 0. + ['j-proc', "-An -c -j $proc_file_byte_count $proc_file", + {IN=>{f2=>'e'}}, {OUT=>" e\n"}], ); my $save_temps = $ENV{DEBUG}; diff --git a/tests/misc/od-zero-len b/tests/misc/od-zero-len deleted file mode 100755 index 42008ce8e..000000000 --- a/tests/misc/od-zero-len +++ /dev/null @@ -1,53 +0,0 @@ -#!/bin/sh -# ensure that od -j doesn't improperly fseek across a nonempty file in /proc - -# Copyright (C) 2007 Free Software Foundation, Inc. - -# This program is free software: you can redistribute it and/or modify -# it under the terms of the GNU General Public License as published by -# the Free Software Foundation, either version 3 of the License, or -# (at your option) any later version. - -# This program 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 General Public License for more details. - -# You should have received a copy of the GNU General Public License -# along with this program. If not, see <http://www.gnu.org/licenses/>. - -if test "$VERBOSE" = yes; then - set -x - od --version -fi - -pwd=`pwd` -t0=`echo "$0"|sed 's,.*/,,'`.tmp; tmp=$t0/$$ -trap 'status=$?; cd "$pwd" && chmod -R u+rwx $t0 && rm -rf $t0 && exit $status' 0 -trap '(exit $?); exit $?' 1 2 13 15 - -framework_failure=0 -mkdir -p $tmp || framework_failure=1 -cd $tmp || framework_failure=1 -printf e > f2 || framework_failure=1 - -if test $framework_failure = 1; then - echo "$0: failure in testing framework" 1>&2 - (exit 1); exit 1 -fi - -# Use a file in /proc whose size is not likely to -# change between the wc and od invocations. -f=/proc/version -test -r $f || f=empty - -fail=0 - -n=`wc -c < $f` || fail=1 -od -An -c -j $n $f f2 > out || fail=1 -echo ' e' > exp || fail=1 - -cmp out exp || fail=1 -test $fail = 1 && diff out exp 2> /dev/null - -(exit $fail); exit $fail |