From: Peter Prymmer Date: Wed, 1 May 2002 10:12:53 +0000 (-0400) Subject: make lib/User/pwent.t run on VMS X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=commitdiff_plain;h=8a1f71b21b0ce141933227d7faba7022f5ee8ce0;p=p5sagit%2Fp5-mst-13.2.git make lib/User/pwent.t run on VMS Message-ID: p4raw-id: //depot/perl@16305 --- diff --git a/lib/User/pwent.t b/lib/User/pwent.t index 91a85cc..853526c 100644 --- a/lib/User/pwent.t +++ b/lib/User/pwent.t @@ -11,13 +11,18 @@ BEGIN { $haspw = 1 unless $@ && $@ =~ /unimplemented/; unless ($haspw) { print "1..0 # Skip: no getpwuid\n"; exit 0 } use Config; - $haspw = 0 unless $Config{'i_pwd'} eq 'define'; + # VMS's pwd.h struct passwd conflicts with the one in vmsish.h + $haspw = 0 unless ( $Config{'i_pwd'} eq 'define' || $^O eq 'VMS' ); unless ($haspw) { print "1..0 # Skip: no pwd.h\n"; exit 0 } } BEGIN { - our @pwent = getpwuid 0; # This is the function getpwuid. - unless (@pwent) { print "1..0 # Skip: no uid 0\n"; exit 0 } + our $uid = 0; + # On VMS getpwuid(0) may return [$gid,0] UIC info (which may not exist). + # It is better to use the $< uid for testing on VMS instead. + if ( $^O eq 'VMS' ) { $uid = $< ; } + our @pwent = getpwuid $uid; # This is the function getpwuid. + unless (@pwent) { print "1..0 # Skip: no uid $uid\n"; exit 0 } } print "1..9\n"; @@ -26,10 +31,12 @@ use User::pwent; print "ok 1\n"; -my $pwent = getpwuid 0; # This is the OO getpwuid. +my $pwent = getpwuid $uid; # This is the OO getpwuid. -print "not " unless $pwent->uid == 0 || - ($^O eq 'cygwin' && $pwent->uid == 500); # go figure +my $uid_expect = $uid; +if ( $^O eq 'cygwin' ) { $uid_expect = 500; } # go figure + +print "not " unless $pwent->uid == $uid_expect ; print "ok 2\n"; print "not " unless $pwent->name eq $pwent[0];