mirror of
git://git.sv.gnu.org/coreutils.git
synced 2026-02-15 20:02:10 +02:00
* tests/check.mk (TESTS_ENVIRONMENT): Save and restore TMPDIR around envvar-check, so that the few scripts that require $TMPDIR don't fail. This is also good to let a user's default TMPDIR setting be used e.g., in the search for an 'other-partition'. FIXME: this is pretty ugly. maybe undo it and find a better way. (TESTS_ENVIRONMENT): Invoke perl scripts with $(PERL), and use -T if the script requires that. Otherwise, use $(SHELL). * tests/misc/md5sum-newline: Create a file whose name contains a newline in Perl (resort to using "system", since open refuses). Fix old brokenness exposed by this change: * tests/du/files0-from: Correct test not to rely on stdin being attached to a non-tty. * tests/misc/sort (3g, 3h, 3i): Likewise: add explicit empty input file. Avoid warnings about using qw()-around-commas. * tests/rm/fail-eperm: Now that this test is run from a temporary subdirectory, adjust the full name of the "rm" program we're going to run. Change #!/bin/sh to #!/usr/bin/perl, and factor out the few lines of boilerplate code to invoke perl. Do not "require 5.00x"; a configure-time Perl test handles that * tests/dd/skip-seek: * tests/misc/base64: * tests/misc/basename: * tests/misc/cut: * tests/misc/date: * tests/misc/dircolors: * tests/misc/dirname: * tests/misc/expand: * tests/misc/expr: * tests/misc/factor: * tests/misc/fmt: * tests/misc/fold: * tests/misc/head: * tests/misc/head-elide-tail: * tests/misc/join: * tests/misc/ls-misc: * tests/misc/md5sum: * tests/misc/md5sum-newline: * tests/misc/mktemp: * tests/misc/od: * tests/misc/paste: * tests/misc/pr: * tests/misc/printf-cov: * tests/misc/seq: * tests/misc/sha1sum: * tests/misc/sha1sum-vec: * tests/misc/sha224sum: * tests/misc/sha256sum: * tests/misc/sha384sum: * tests/misc/sha512sum: * tests/misc/sort-merge: * tests/misc/stat-printf: * tests/misc/sum: * tests/misc/tac: * tests/misc/tail: * tests/misc/test: * tests/misc/test-diag: * tests/misc/tr: * tests/misc/tsort: * tests/misc/tty-eof: * tests/misc/unexpand: * tests/misc/uniq: * tests/misc/wc: * tests/misc/wc-files0-from: * tests/misc/xstrtol: * tests/mv/i-1: * tests/pr/pr-tests: * tests/rm/empty-name: * tests/rm/fail-eperm: * tests/rm/unreadable:
111 lines
2.9 KiB
Perl
Executable File
111 lines
2.9 KiB
Perl
Executable File
#!/usr/bin/perl
|
|
# Test whether programs exit upon a single EOF from a tty.
|
|
# Ensure that e.g., cat exits upon a single EOF (^D) from a tty.
|
|
# Do the same for all programs that can read stdin,
|
|
# require no arguments and that write to standard output.
|
|
|
|
# Copyright (C) 2003, 2006, 2007, 2008 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/>.
|
|
|
|
use strict;
|
|
(my $ME = $0) =~ s|.*/||;
|
|
|
|
# Some older versions of Expect.pm (e.g. 1.07) lack the log_user method,
|
|
# so check for that, too.
|
|
eval { require Expect; Expect->require_version('1.11') };
|
|
$@ and (warn "$ME: this script requires Perl's Expect package >=1.11\n"),
|
|
exit 77;
|
|
|
|
{
|
|
my $fail = 0;
|
|
my @stdin_reading_commands = qw(
|
|
base64
|
|
cat
|
|
cksum
|
|
dd
|
|
expand
|
|
fmt
|
|
fold
|
|
head
|
|
md5sum
|
|
nl
|
|
od
|
|
paste
|
|
pr
|
|
ptx
|
|
sha1sum
|
|
sha224sum
|
|
sha256sum
|
|
sha384sum
|
|
sha512sum
|
|
shuf
|
|
sort
|
|
sum
|
|
tac
|
|
tail
|
|
tee
|
|
tsort
|
|
unexpand
|
|
uniq
|
|
wc
|
|
);
|
|
my $stderr = 'tty-eof.err';
|
|
foreach my $cmd ((@stdin_reading_commands), 'cut -f2')
|
|
{
|
|
my $exp = new Expect;
|
|
$exp->log_user(0);
|
|
$exp->spawn("$cmd 2> $stderr")
|
|
or (warn "$ME: cannot run `$cmd': $!\n"), $fail=1, next;
|
|
# No input for cut -f2.
|
|
$cmd =~ /^cut/
|
|
or $exp->send("a b\n");
|
|
$exp->send("\cD"); # This is Control-D. FIXME: what if that's not EOF?
|
|
$exp->expect (0, '-re', "^a b\\r?\$");
|
|
my $found = $exp->expect (1, '-re', "^.+\$");
|
|
$found and warn "F: $found: " . $exp->exp_match () . "\n";
|
|
$exp->expect(1, 'eof');
|
|
# Expect no output from cut, since we gave it no input.
|
|
defined $found || $cmd =~ /^cut/
|
|
or (warn "$ME: $cmd didn't produce expected output\n"),
|
|
$fail=1, next;
|
|
defined $exp->exitstatus
|
|
or (warn "$ME: $cmd didn't exit after ^D from standard input\n"),
|
|
$fail=1, next;
|
|
my $s = $exp->exitstatus;
|
|
$s == 0
|
|
or (warn "$ME: $cmd exited with status $s (expected 0)\n"),
|
|
$fail=1;
|
|
$exp->hard_close();
|
|
|
|
# dd normally writes to stderr. If it exits successfully, we're done.
|
|
$cmd eq 'dd' && $s == 0
|
|
and next;
|
|
|
|
if (-s $stderr)
|
|
{
|
|
warn "$ME: $cmd wrote to stderr:\n";
|
|
system "cat $stderr";
|
|
$fail = 1;
|
|
}
|
|
}
|
|
continue
|
|
{
|
|
unlink $stderr
|
|
or warn "$ME: failed to remove stderr file from $cmd, $stderr: $!\n";
|
|
}
|
|
|
|
exit $fail
|
|
}
|