summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMichael G. Schwern <schwern@pobox.com>2001-09-21 13:59:03 -0400
committerAbhijit Menon-Sen <ams@wiw.org>2001-09-22 03:37:07 +0000
commit5d96a5e070ce49e6f3f6ee787d81f3b944ebff4f (patch)
tree6b8adf33b91a7d75a20376d80efa2b9d3340a76b
parent67ac489efef76ba94d2f040ea58ff87e017e54a4 (diff)
downloadperl-5d96a5e070ce49e6f3f6ee787d81f3b944ebff4f.tar.gz
[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
-rwxr-xr-xt/op/do.t67
1 files changed, 44 insertions, 23 deletions
diff --git a/t/op/do.t b/t/op/do.t
index b70fae1a5d..1d6fb90ef0 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";