1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115
|
#!/usr/bin/perl -w
=head1 NAME
timeout.t - Test suite for IPC::Run timeouts
=cut
BEGIN {
if( $ENV{PERL_CORE} ) {
chdir '../lib/IPC/Run' if -d '../lib/IPC/Run';
unshift @INC, 'lib', '../..';
$^X = '../../../t/' . $^X;
}
}
## Separate from run.t so run.t is not too slow.
use strict ;
use Test ;
use IPC::Run qw( harness timeout ) ;
use UNIVERSAL qw( isa ) ;
my $h ;
my $t ;
my $in ;
my $out ;
my $started ;
my @tests = (
sub {
$h = harness( [ $^X ], \$in, \$out, $t = timeout( 1 ) ) ;
ok( isa( $h, 'IPC::Run' ) ) ;
},
sub { ok( !! $t->is_reset ) },
sub { ok( ! $t->is_running ) },
sub { ok( ! $t->is_expired ) },
sub {
$started = time ;
$h->start ;
ok( 1 ) ;
},
sub { ok( ! $t->is_reset ) },
sub { ok( !! $t->is_running ) },
sub { ok( ! $t->is_expired ) },
sub {
$in = '' ;
eval { $h->pump };
# Older perls' Test.pms don't know what to do with qr//s
$@ =~ /IPC::Run: timeout/ ? ok( 1 ) : ok( $@, qr/IPC::Run: timeout/ ) ;
},
sub {
my $elapsed = time - $started ;
$elapsed >= 1 ? ok( 1 ) : ok( $elapsed, ">= 1" ) ;
},
sub { ok( $t->interval, 1 ) },
sub { ok( ! $t->is_reset ) },
sub { ok( ! $t->is_running ) },
sub { ok( !! $t->is_expired ) },
##
## Starting from an expired state
##
sub {
$started = time ;
$h->start ;
ok( 1 ) ;
},
sub { ok( ! $t->is_reset ) },
sub { ok( !! $t->is_running ) },
sub { ok( ! $t->is_expired ) },
sub {
$in = '' ;
eval { $h->pump };
$@ =~ /IPC::Run: timeout/ ? ok( 1 ) : ok( $@, qr/IPC::Run: timeout/ ) ;
},
sub { ok( ! $t->is_reset ) },
sub { ok( ! $t->is_running ) },
sub { ok( !! $t->is_expired ) },
sub {
my $elapsed = time - $started ;
$elapsed >= 1 ? ok( 1 ) : ok( $elapsed, ">= 1" ) ;
},
sub {
$h = harness( [ $^X ], \$in, \$out, timeout( 1 ) ) ;
$started = time ;
$h->start ;
$in = '' ;
eval { $h->pump };
$@ =~ /IPC::Run: timeout/ ? ok( 1 ) : ok( $@, qr/IPC::Run: timeout/ ) ;
},
sub {
my $elapsed = time - $started ;
$elapsed >= 1 ? ok( 1 ) : ok( $elapsed, ">= 1" ) ;
},
) ;
plan tests => scalar @tests ;
$_->() for ( @tests ) ;
|