]> git.vpit.fr Git - perl/modules/IPC-MorseSignals.git/blob - t/11-speed.t
Importing IPC-MorseSignals-0.02.tar.gz
[perl/modules/IPC-MorseSignals.git] / t / 11-speed.t
1 #!perl -T
2
3 use Test::More tests => 12;
4
5 use POSIX qw/SIGINT SIGTERM SIGKILL EXIT_SUCCESS/;
6
7 use IPC::MorseSignals qw/msend mrecv/;
8
9 my @res;
10
11 sub tryspeed {
12  my ($l, $n) = @_;
13  my $speed = 2 ** 16;
14  my $ok = 0;
15  my $msg = join '', map { chr int rand 256 } 1 .. $l;
16  my $desc;
17  while (($speed >= 1) && ($ok < $n)) {
18   $desc = "$n sends of $l bytes at $speed bits/s";
19   $speed /= 2;
20   $ok = 0;
21   diag("try $desc...");
22 TRY:
23   for (1 .. $n) {
24    pipe my $rdr, my $wtr or die "$desc: pipe() failed : $!";
25    my $pid = fork;
26    if (!defined $pid) {
27     die "$desc: fork() failed : $!";
28    } elsif ($pid == 0) {
29     close $rdr;
30     local @SIG{qw/USR1 USR2/} = mrecv sub {
31      print $wtr $_[0], "\n";
32      close $wtr;
33      exit EXIT_SUCCESS;
34     };
35     1 while 1;
36    }
37    close $wtr or die "$desc: close() failed : $!";
38    eval {
39     local $SIG{ALRM} = sub { die 'alarm' };
40     my $a = (int(100 * (3 * $l) / $speed) || 1);
41     $a = 10 if $a > 10;
42     alarm $a;
43     msend $msg => $pid, $speed;
44     waitpid $pid, 0;
45    };
46    alarm 0;
47    if ($@) {
48     kill SIGINT,  $pid;
49     kill SIGTERM, $pid;
50     kill SIGKILL, $pid;
51     close $rdr or die "$desc: close() failed : $!";
52     last TRY;
53    }
54    my $recv = do { local $/; <$rdr> };
55    close $rdr or die "$desc: close() failed : $!";
56    last TRY unless $recv;
57    chomp $recv;
58    last TRY unless $msg eq $recv;
59    ++$ok;
60   }
61  }
62  $desc = "$l bytes sent $n times";
63  ok($speed, $desc);
64  push @res, $desc . (($speed) ? ' at ' . $speed . ' bits/s' : ' failed');
65 }
66
67 tryspeed 4, 1;
68 tryspeed 4, 5;
69 tryspeed 4, 10;
70 tryspeed 4, 50;
71 tryspeed 16, 1;
72 tryspeed 16, 5;
73 tryspeed 16, 10;
74 tryspeed 64, 1;
75 tryspeed 64, 5;
76 tryspeed 64, 10;
77 tryspeed 256, 1;
78 tryspeed 1024, 1;
79
80 diag '=== Summary ===';
81 diag $_ for @res;