BEGIN {
chdir 't' if -d 't';
@INC = '../lib';
- require './test.pl';
+ require './test.pl'; # for which_perl() etc
}
use Config;
use File::Spec;
-plan tests => 69;
+plan tests => 74;
-my $Perl = which_perl;
+my $Perl = which_perl();
$Is_Amiga = $^O eq 'amigaos';
$Is_Cygwin = $^O eq 'cygwin';
unlink $tmpfile;
-open(FOO, ">$tmpfile") || BAILOUT("Can't open temp test file: $!");
+open(FOO, ">$tmpfile") || DIE("Can't open temp test file: $!");
close FOO;
-open(FOO, ">$tmpfile") || BAILOUT("Can't open temp test file: $!");
+open(FOO, ">$tmpfile") || DIE("Can't open temp test file: $!");
my($nlink, $mtime, $ctime) = (stat(FOO))[$NLINK, $MTIME, $CTIME];
SKIP: {
}
SKIP: {
- skip "mtime and ctime not reliable", 2
+ skip "mtime and ctime not reliable", 2
if $Is_MSWin32 or $Is_NetWare or $Is_Cygwin or $Is_Dos;
ok( $mtime, 'mtime' );
SKIP: {
skip "No link count", 1 if $Config{dont_use_nlink};
+ skip "Cygwin9X fakes hard links by copying", 1
+ if $Config{myuname} =~ /^cygwin_(?:9\d|me)\b/i;
+
is($nlink, 2, 'Link count on hard linked file' );
}
SKIP: {
my $cwd = File::Spec->rel2abs($Curdir);
- skip "Solaris tmpfs has different mtime/ctime link semantics", 2
- if $Is_Solaris and $cwd =~ m#^/tmp# and
+ skip "Solaris tmpfs has different mtime/ctime link semantics", 2
+ if $Is_Solaris and $cwd =~ m#^/tmp# and
$mtime && $mtime == $ctime;
skip "AFS has different mtime/ctime link semantics", 2
if $cwd =~ m#$Config{'afsroot'}/#;
skip "AmigaOS has different mtime/ctime link semantics", 2
if $Is_Amiga;
-
+ # Win32 could pass $mtime test but as FAT and NTFS have
+ # no ctime concept $ctime is ALWAYS == $mtime
+ # expect netware to be the same ...
+ skip "No ctime concept on this OS", 2
+ if $Is_MSWin32;
if( !ok($mtime, 'hard link mtime') ||
!isnt($mtime, $ctime, 'hard link ctime != mtime') ) {
print <<DIAG;
-# Check if you are on a tmpfs of some sort. Building in /tmp sometimes
-# has this problem. Also building on the ClearCase VOBS filesystem may
+# Check if you are on a tmpfs of some sort. Building in /tmp sometimes
+# has this problem. Also building on the ClearCase VOBS filesystem may
# cause this failure.
DIAG
}
}
# truncate and touch $tmpfile.
-open(F, ">$tmpfile") || BAILOUT("Can't open temp test file: $!");
+open(F, ">$tmpfile") || DIE("Can't open temp test file: $!");
close F;
ok(-z $tmpfile, '-z on empty file');
ok(! -s $tmpfile, ' and -s');
-open(F, ">$tmpfile") || BAILOUT("Can't open temp test file: $!");
+open(F, ">$tmpfile") || DIE("Can't open temp test file: $!");
print F "hi\n";
close F;
# Going to try to switch away from root. Might not work.
my $olduid = $>;
eval { $> = 1; };
- skip "Can't test -r or -w meaningfully if you're superuser", 2
+ skip "Can't test -r or -w meaningfully if you're superuser", 2
if $> == 0;
SKIP: {
skip "/dev isn't available to test against", 3
unless -d '/dev' && -r '/dev' && -x '/dev';
- my $LS = $Config{d_readlink} ? "ls -lL" : "ls -l";
- my $CMD = "$LS /dev";
+ my $LS = $Config{d_readlink} ? "ls -lL" : "ls -l";
+ my $CMD = "$LS /dev 2>/dev/null";
my $DEV = qx($CMD);
skip "$CMD failed", 3 if $DEV eq '';
skip "opendir failed: $!", 3 if @DEV == 0;
+ # /dev/stdout might be either character special or a named pipe,
+ # or a symlink, or a socket, depending on which OS and how are
+ # you running the test, so let's censor that one away.
+ # Similar remarks hold for stderr.
+ $DEV =~ s{^[cpls].+?\sstdout$}{}m;
+ @DEV = grep { $_ ne 'stdout' } @DEV;
+ $DEV =~ s{^[cpls].+?\sstderr$}{}m;
+ @DEV = grep { $_ ne 'stderr' } @DEV;
+
+ # /dev/printer is also naughty: in IRIX it shows up as
+ # Srwx-----, not srwx------.
+ $DEV =~ s{^.+?\sprinter$}{}m;
+ @DEV = grep { $_ ne 'printer' } @DEV;
+
+ # If running as root, we will see .files in the ls result,
+ # and readdir() will see them always. Potential for conflict,
+ # so let's weed them out.
+ $DEV =~ s{^.+?\s\..+?$}{}m;
+ @DEV = grep { ! m{^\..+$} } @DEV;
+
my $try = sub {
- my @c1 = eval qq[\$DEV =~ /^$_[0]/mg];
+ my @c1 = eval qq[\$DEV =~ /^$_[0].*/mg];
my @c2 = eval qq[grep { $_[1] "/dev/\$_" } \@DEV];
my $c1 = scalar @c1;
my $c2 = scalar @c2;
- is($c1, $c2, "ls and $_[1] agree on /dev ($c1 $c2)");
+ is($c1, $c2, "ls and $_[1] agreeing on /dev ($c1 $c2)");
};
$try->('b', '-b');
ok(! -S $Curdir, '!-S cwd');
SKIP: {
- skip "No setuid", 3 if $Is_MPE or $Is_Amiga or $Is_Dosish or $Is_Cygwin;
-
my($cnt, $uid);
$cnt = $uid = 0;
}
closedir BIN;
- if( !isnt($cnt, 0, 'found some programs') ||
- !isnt($uid, 0, 'found some setuid programs') ||
- !ok($uid < $cnt, " they're not all setuid") )
- {
- print <<DIAG;
-# The above two tests assume that at least one of these directories
-# are readable, executable and contain at least one setuid file
-# (but aren't all setuid).
-# @bin
-DIAG
- }
+ skip "No setuid programs", 3 if $uid == 0;
+
+ isnt($cnt, 0, 'found some programs');
+ isnt($uid, 0, ' found some setuid programs');
+ ok($uid < $cnt, " they're not all setuid");
}
skip "Test uses unixisms", 2 if $Is_MSWin32 || $Is_NetWare;
skip "No TTY to test -t with", 2 unless -e $TTY;
- open(TTY, $TTY) ||
+ open(TTY, $TTY) ||
warn "Can't open $TTY--run t/TEST outside of make.\n";
ok(-t TTY, '-t');
ok(-c TTY, 'tty is -c');
close(TTY);
}
ok(! -t TTY, '!-t on closed TTY filehandle');
- ok(-t, '-t on STDIN');
+
+ {
+ local $TODO = 'STDIN not a tty when output is to pipe' if $Is_VMS;
+ ok(-t, '-t on STDIN');
+ }
}
my $Null = File::Spec->devnull;
SKIP: {
skip "No null device to test with", 1 unless -e $Null;
+ skip "We know Win32 thinks '$Null' is a TTY", 1 if $Is_MSWin32;
- open(NULL, $Null) or BAIL_OUT("Can't open $Null: $!");
+ open(NULL, $Null) or DIE("Can't open $Null: $!");
ok(! -t NULL, 'null device is not a TTY');
close(NULL);
}
my @r = \stat(".");
is(scalar @r, 13, 'stat returns full 13 elements');
+SKIP: {
+ skip "No lstat", 2 unless $Config{d_lstat};
+
+ stat $0;
+ eval { lstat _ };
+ ok( $@ =~ /^The stat preceding lstat\(\) wasn't an lstat/,
+ 'lstat _ croaks after stat' );
+ eval { -l _ };
+ ok( $@ =~ /^The stat preceding -l _ wasn't an lstat/,
+ '-l _ croaks after stat' );
+
+ eval { lstat STDIN };
+ ok( $@ =~ /^The stat preceding lstat\(\) wasn't an lstat/,
+ 'lstat FILEHANDLE croaks' );
+
+ # bug id 20020124.004
+ # If we have d_lstat, we should have symlink()
+ my $linkname = 'dolzero';
+ symlink $0, $linkname or die "# Can't symlink $0: $!";
+ lstat $linkname;
+ -T _;
+ eval { lstat _ };
+ ok( $@ =~ /^The stat preceding lstat\(\) wasn't an lstat/,
+ 'lstat croaks after -T _' );
+ eval { -l _ };
+ ok( $@ =~ /^The stat preceding -l _ wasn't an lstat/,
+ '-l _ croaks after -T _' );
+ unlink $linkname or print "# unlink $linkname failed: $!\n";
+}