X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=t%2Fop%2Fstat.t;h=f00bd284ca86e38333026ebdf3edac22d0d53dd6;hb=21fa6956243df9cb622bebfa0934ea7923519b4f;hp=6eb5c9a0c4fc9b18ba16bdf01e14030f41ee6174;hpb=16ed468695c21630f18883bfbedc3d5170ddc8b2;p=p5sagit%2Fp5-mst-13.2.git diff --git a/t/op/stat.t b/t/op/stat.t index 6eb5c9a..f00bd28 100755 --- a/t/op/stat.t +++ b/t/op/stat.t @@ -9,7 +9,7 @@ BEGIN { use Config; use File::Spec; -plan tests => 82; +plan tests => 107; my $Perl = which_perl(); @@ -30,7 +30,7 @@ $Is_Rhapsody= $^O eq 'rhapsody'; $Is_Dosish = $Is_Dos || $Is_OS2 || $Is_MSWin32 || $Is_NetWare || $Is_Cygwin; -$Is_UFS = $Is_Darwin && (() = `df -t ufs .`) == 2; +$Is_UFS = $Is_Darwin && (() = `df -t ufs . 2>/dev/null`) == 2; my($DEV, $INO, $MODE, $NLINK, $UID, $GID, $RDEV, $SIZE, $ATIME, $MTIME, $CTIME, $BLKSIZE, $BLOCKS) = (0..12); @@ -41,7 +41,7 @@ my $Curdir = File::Spec->curdir; my $tmpfile = 'Op_stat.tmp'; my $tmpfile_link = $tmpfile.'2'; - +chmod 0666, $tmpfile; 1 while unlink $tmpfile; open(FOO, ">$tmpfile") || DIE("Can't open temp test file: $!"); close FOO; @@ -59,7 +59,7 @@ SKIP: { SKIP: { skip "mtime and ctime not reliable", 2 - if $Is_MSWin32 or $Is_NetWare or $Is_Cygwin or $Is_Dos or $Is_MacOS; + if $Is_MSWin32 or $Is_NetWare or $Is_Cygwin or $Is_Dos or $Is_MacOS or $Is_Darwin; ok( $mtime, 'mtime' ); is( $mtime, $ctime, 'mtime == ctime' ); @@ -128,6 +128,8 @@ DIAG # truncate and touch $tmpfile. open(F, ">$tmpfile") || DIE("Can't open temp test file: $!"); +ok(-z \*F, '-z on empty filehandle'); +ok(! -s \*F, ' and -s'); close F; ok(-z $tmpfile, '-z on empty file'); @@ -137,6 +139,11 @@ open(F, ">$tmpfile") || DIE("Can't open temp test file: $!"); print F "hi\n"; close F; +open(F, "<$tmpfile") || DIE("Can't open temp test file: $!"); +ok(!-z *F, '-z on empty filehandle'); +ok( -s *F, ' and -s'); +close F; + ok(! -z $tmpfile, '-z on non-empty file'); ok(-s $tmpfile, ' and -s'); @@ -472,6 +479,58 @@ ok(unlink($f), 'unlink tmp file'); unlink $tmpfile; } +SKIP: { + skip "No dirfd()", 9 unless $Config{d_dirfd} || $Config{d_dir_dd_fd}; + ok(opendir(DIR, "."), 'Can open "." dir') || diag "Can't open '.': $!"; + ok(stat(DIR), "stat() on dirhandle works"); + ok(-d -r _ , "chained -x's on dirhandle"); + ok(-d DIR, "-d on a dirhandle works"); + + # And now for the ambigious bareword case + ok(open(DIR, "TEST"), 'Can open "TEST" dir') + || diag "Can't open 'TEST': $!"; + my $size = (stat(DIR))[7]; + ok(defined $size, "stat() on bareword works"); + is($size, -s "TEST", "size returned by stat of bareword is for the file"); + ok(-f _, "ambiguous bareword uses file handle, not dir handle"); + ok(-f DIR); + closedir DIR or die $!; + close DIR or die $!; +} + +{ + # RT #8244: *FILE{IO} does not behave like *FILE for stat() and -X() operators + ok(open(F, ">", $tmpfile), 'can create temp file'); + my @thwap = stat *F{IO}; + ok(@thwap, "stat(*F{IO}) works"); + ok( -f *F{IO} , "single file tests work with *F{IO}"); + close F; + unlink $tmpfile; + + #PVIO's hold dirhandle information, so let's test them too. + + SKIP: { + skip "No dirfd()", 9 unless $Config{d_dirfd} || $Config{d_dir_dd_fd}; + ok(opendir(DIR, "."), 'Can open "." dir') || diag "Can't open '.': $!"; + ok(stat(*DIR{IO}), "stat() on *DIR{IO} works"); + ok(-d _ , "The special file handle _ is set correctly"); + ok(-d -r *DIR{IO} , "chained -x's on *DIR{IO}"); + + # And now for the ambigious bareword case + ok(open(DIR, "TEST"), 'Can open "TEST" dir') + || diag "Can't open 'TEST': $!"; + my $size = (stat(*DIR{IO}))[7]; + ok(defined $size, "stat() on *THINGY{IO} works"); + is($size, -s "TEST", + "size returned by stat of *THINGY{IO} is for the file"); + ok(-f _, "ambiguous *THINGY{IO} uses file handle, not dir handle"); + ok(-f *DIR{IO}); + closedir DIR or die $!; + close DIR or die $!; + } +} + END { + chmod 0666, $tmpfile; 1 while unlink $tmpfile; }