summaryrefslogtreecommitdiff
path: root/lib/perl5db
diff options
context:
space:
mode:
authorJarkko Hietaniemi <jhi@iki.fi>2003-09-08 14:07:03 +0000
committerJarkko Hietaniemi <jhi@iki.fi>2003-09-08 14:07:03 +0000
commitcb08c2557abf1c4c87bdbc194618d6c10a9350cc (patch)
treed5b03b31b7403929546eca30fd72e3ed3edf30b9 /lib/perl5db
parente98227050ad91f6c381bce92f17cf9258b638699 (diff)
downloadperl-cb08c2557abf1c4c87bdbc194618d6c10a9350cc.tar.gz
Win32 is playing to hard to get but I do not have
time to chase it, so restore #21072, more or less. I think testing the debugger in UNIX-like places is enough, no need to go into painful contortions trying to "portably" run interactive programs like the debugger. p4raw-id: //depot/perl@21090
Diffstat (limited to 'lib/perl5db')
-rw-r--r--lib/perl5db/de0.t47
1 files changed, 27 insertions, 20 deletions
diff --git a/lib/perl5db/de0.t b/lib/perl5db/de0.t
index 116bbaac61..989c92e56e 100644
--- a/lib/perl5db/de0.t
+++ b/lib/perl5db/de0.t
@@ -3,16 +3,19 @@
BEGIN {
chdir 't' if -d 't';
@INC = '../lib';
- $ENV{PERL5LIB} = '../lib'; # so children will see it too
+ require Config; import Config;
if ($^O eq 'VMS') {
print "1..0 # skip on $^O, no piped open\n";
- exit 0;
+ exit 0;
}
+ $ENV{PERL5LIB} = '../lib'; # so children will see it too
}
use strict;
+use IPC::Open3 qw(open3);
+use IO::Select;
-$| = 1;
+$|=1;
my @prgs;
@@ -28,26 +31,30 @@ plan tests => scalar @prgs;
require "dumpvar.pl";
-use File::Temp qw/tempfile/;
-
-our ($tmpfh, $tmpfile) = tempfile();
-
$ENV{PERLDB_OPTS} = "TTY=0";
-my($ornament1,$ornament2);
+my($ornament1,$ornament2,$wtrfh,$rdrfh);
+open3 $wtrfh, $rdrfh, 0, $^X, "-de0";
+my $ios = IO::Select->new();
+$ios->add($rdrfh);
for (@prgs){
- my($prog, $expected) = split(/\nEXPECT\n?/, $_);
- open my $select, "| $^X -de0 2> $tmpfile" or die $!;
- print $select $prog;
- close $select;
- my $got = do { open my($fh), $tmpfile or die; local $/; <$fh>; };
- $got =~ s/^\s*Loading.*\nEditor.*\n\nEnter.*\n\nmain::\(-e:1\):\s0\n//;
- unless (defined $ornament1) {
- ($ornament1, $ornament2) = $got =~
- /(.*?)0\s+'reserved example for calibrating the ornaments'\n(.*)/
+ my($prog,$expected) = split(/\nEXPECT\n?/, $_);
+ print $wtrfh $prog, "\n";
+ my $got;
+ while ($ios->can_read(0.25)) {
+ last unless sysread $rdrfh, $got, 1024, length($got);
+ }
+ SKIP: {
+ skip("failed to read debugger", 1) unless defined $got;
+ $got =~ s/^\s*Loading.*\r?\n?Editor.*\r?\n?\r?\n?Enter.*\r?\n?\r?\n?main::\(-e:1\):\s+0\r?\n?//;
+ unless (defined $ornament1) {
+ $got =~ s/^\s*Loading.*\r?\n?Editor.*\r?\n?\r?\n?Enter.*\r?\n?\r?\n?main::\(-e:1\):\s+0\r?\n?//;
+ ($ornament1,$ornament2) = $got =~
+ /(.*?)0\s+'reserved example for calibrating the ornaments'\r?\n?(.*)/
+ }
+ $got =~ s/^\Q$ornament1\E//;
+ $got =~ s/\Q$ornament2\E\z//;
+ like($got, qr:$expected:i, $prog);
}
- $got =~ s/^\Q$ornament1\E//;
- $got =~ s/\Q$ornament2\E\z//;
- like($got, qr:$expected:i, $prog);
}
__END__