From: Nicholas Clark Date: Tue, 13 Mar 2007 22:48:46 +0000 (+0000) Subject: Check that stat and -X favours the file handle over the directory X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=commitdiff_plain;h=20c932f8124a8b3087843039e78e4bb9b7b0dcf8;p=p5sagit%2Fp5-mst-13.2.git Check that stat and -X favours the file handle over the directory handle when using *THINGY{IO} syntax too. p4raw-id: //depot/perl@30572 --- diff --git a/t/op/stat.t b/t/op/stat.t index 2457b07..4ebe55b 100755 --- a/t/op/stat.t +++ b/t/op/stat.t @@ -9,7 +9,7 @@ BEGIN { use Config; use File::Spec; -plan tests => 101; +plan tests => 107; my $Perl = which_perl(); @@ -510,11 +510,23 @@ SKIP: { #PVIO's hold dirhandle information, so let's test them too. SKIP: { - skip "No dirfd()", 3 unless $Config{d_dirfd}; + skip "No dirfd()", 9 unless $Config{d_dirfd}; 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}"); - closedir DIR; + + # 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 $!; } }