File: timeout.t

package info (click to toggle)
libipc-run-perl 0.80-2
  • links: PTS, VCS
  • area: main
  • in suites: lenny
  • size: 452 kB
  • ctags: 186
  • sloc: perl: 5,317; makefile: 44
file content (115 lines) | stat: -rwxr-xr-x 2,128 bytes parent folder | download | duplicates (2)
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 ) ;