From: Peter Prymmer Date: Wed, 11 Jun 2003 09:00:34 +0000 (-0400) Subject: fix vmsish.t #25 by letting $0 find itself in the face of chdir() calls X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=commitdiff_plain;h=ef275d6f08d4a9026701c644c1a428d91f4e0ba3;p=p5sagit%2Fp5-mst-13.2.git fix vmsish.t #25 by letting $0 find itself in the face of chdir() calls Message-ID: p4raw-id: //depot/perl@19741 --- diff --git a/lib/vmsish.t b/lib/vmsish.t index ff3f5b5..aad4a4a 100644 --- a/lib/vmsish.t +++ b/lib/vmsish.t @@ -112,6 +112,19 @@ is($?,0,"outer lex scope of vmsish [POSIX status]"); eval "END { \$ENV{'SYS\$TIMEZONE_DIFFERENTIAL'} = $oldtz; }"; gmtime(0); # Force reset of tz offset } + # This test script might have been invoked in at least one of four different ways: + # perl lib/vmsish.t + # perl [.lib]vmsish.t + # set def [.t] && perl ../lib/vmsish.t + # set def [.t] && perl [-.lib]vmsish.t + # In the following we attempt to find ourselves without resorting to VMS::Filespec. + # Note that the chdir in the BEGIN block above complicates matters. + my $self = $0; + if ( ! -e $self && -e "../$0" ) { $self = "../$0"; } + if ( ! -e $self ) { + $self =~ s/\[//; + $self = "[-$self"; + } { use_ok('vmsish qw(time)'); @@ -121,12 +134,12 @@ is($?,0,"outer lex scope of vmsish [POSIX status]"); $vmstime = time; @vmslocal = localtime($vmstime); @vmsgmtime = gmtime($vmstime); - $vmsmtime = (stat $0)[9]; + $vmsmtime = (stat $self)[9]; } $utctime = time; @utclocal = localtime($vmstime); @utcgmtime = gmtime($vmstime); - $utcmtime = (stat $0)[9]; + $utcmtime = (stat $self)[9]; $offset = $ENV{'SYS$TIMEZONE_DIFFERENTIAL'};