From: Michael G. Schwern Date: Fri, 21 Sep 2001 17:59:03 +0000 (-0400) Subject: [REPATCH] Re: [PATCH t/op/do.t] new regression tests for bug ID X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=commitdiff_plain;h=5d96a5e070ce49e6f3f6ee787d81f3b944ebff4f;p=p5sagit%2Fp5-mst-13.2.git [REPATCH] Re: [PATCH t/op/do.t] new regression tests for bug ID 20010920.007 Message-Id: <20010921175903.V5494@blackrider> p4raw-id: //depot/perl@12122 --- diff --git a/t/op/do.t b/t/op/do.t index b70fae1..1d6fb90 100755 --- a/t/op/do.t +++ b/t/op/do.t @@ -4,68 +4,89 @@ sub foo1 { - print $_[0]; + ok($_[0]); 'value'; } sub foo2 { shift; - print $_[0]; + ok($_[0]); $x = 'value'; $x; } +my $test = 1; +sub ok { + my($ok, $name) = @_; + + # You have to do it this way or VMS will get confused. + printf "%s %d%s\n", $ok ? "ok" : "not ok", + $test, + defined $name ? " - $name" : ''; + + printf "# Failed test at line %d\n", (caller)[2] unless $ok; + + $test++; + return $ok; +} + print "1..20\n"; -$_[0] = "not ok 1\n"; -$result = do foo1("ok 1\n"); -print "#2\t:$result: eq :value:\n"; -if ($result eq 'value') { print "ok 2\n"; } else { print "not ok 2\n"; } -if ($_[0] eq "not ok 1\n") { print "ok 3\n"; } else { print "not ok 3\n"; } +# Test do &sub and proper @_ handling. +$_[0] = 0; +$result = do foo1(1); -$_[0] = "not ok 4\n"; -$result = do foo2("not ok 4\n","ok 4\n","not ok 4\n"); -print "#5\t:$result: eq :value:\n"; -if ($result eq 'value') { print "ok 5\n"; } else { print "not ok 5\n"; } -if ($_[0] eq "not ok 4\n") { print "ok 6\n"; } else { print "not ok 6\n"; } +ok( $result eq 'value', ":$result: eq :value:" ); +ok( $_[0] == 0 ); -$result = do{print "ok 7\n"; 'value';}; -print "#8\t:$result: eq :value:\n"; -if ($result eq 'value') { print "ok 8\n"; } else { print "not ok 8\n"; } +$_[0] = 0; +$result = do foo2(0,1,0); +ok( $result eq 'value', ":$result: eq :value:" ); +ok( $_[0] == 0 ); + +$result = do{ ok 1; 'value';}; +ok( $result eq 'value', ":$result: eq :value:" ); sub blather { - print @_; + ok 1 foreach @_; } -do blather("ok 9\n","ok 10\n"); -@x = ("ok 11\n", "ok 12\n"); -@y = ("ok 14\n", "ok 15\n"); -do blather(@x,"ok 13\n",@y); +do blather("ayep","sho nuff"); +@x = ("jeepers", "okydoke"); +@y = ("uhhuh", "yeppers"); +do blather(@x,"noofie",@y); unshift @INC, '.'; if (open(DO, ">$$.16")) { - print DO "print qq{ok 16\n} if defined wantarray && not wantarray\n"; + print DO "ok(1, 'do in scalar context') if defined wantarray && not wantarray\n"; close DO; } my $a = do "$$.16"; if (open(DO, ">$$.17")) { - print DO "print qq{ok 17\n} if defined wantarray && wantarray\n"; + print DO "ok(1, 'do in list context') if defined wantarray && wantarray\n"; close DO; } my @a = do "$$.17"; if (open(DO, ">$$.18")) { - print DO "print qq{ok 18\n} if not defined wantarray\n"; + print DO "ok(1, 'do in void context') if not defined wantarray\n"; close DO; } do "$$.18"; +# bug ID 20010920.007 +eval qq{ do qq(a file that does not exist); }; +ok( !$@ ); + +eval qq{ do uc qq(a file that does not exist); }; +ok( !$@ ); + eval qq{ do qq(a file that does not exist); }; print "not " if $@; print "ok 19\n";