ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/AnyEvent/t/03_child.t
(Generate patch)

Comparing AnyEvent/t/03_child.t (file contents):
Revision 1.10 by root, Fri May 23 16:36:02 2008 UTC vs.
Revision 1.18 by root, Mon Jul 20 06:00:42 2009 UTC

1$|=1; 1use POSIX ();
2
3no warnings;
2 4
3BEGIN { 5BEGIN {
4 # check for broken perls 6 # check for broken perls
5 if ($^O =~ /mswin32/i) { 7 if ($^O =~ /mswin32/i) {
6 my $ok; 8 my $ok;
7 local $SIG{CHLD} = sub { $ok = 1 }; 9 local $SIG{CHLD} = sub { $ok = 1 };
8 kill 'CHLD', 0; 10 kill 'CHLD', 0;
9 11
10 unless ($ok) { 12 unless ($ok) {
11 print <<EOF; 13 print <<EOF;
121..0 # Your perl interpreter is badly BROKEN. Child watchers will not work, ever. Try upgrading to a newer perl or a working perl (cygwin's perl is known to work). If that is not an option, you should be able to use the remaining functionality of AnyEvent, but child watchers WILL NOT WORK. 141..0 # SKIP Your perl interpreter is badly BROKEN. Child watchers will not work, ever. Try upgrading to a newer perl or a working perl (cygwin's perl is known to work). If that is not an option, you should be able to use the remaining functionality of AnyEvent, but child watchers WILL NOT WORK.
13EOF 15EOF
14 exit 0; 16 exit 0;
15 } 17 }
16 } 18 }
17} 19}
18 20
19BEGIN {
20 print "1..7\n"
21}
22
23use AnyEvent; 21use AnyEvent;
24use AnyEvent::Impl::Perl; 22use AnyEvent::Impl::Perl;
25 23
26print "ok 1\n"; 24$| = 1; print "1..50\n";
27 25
28AnyEvent::detect; # force-load event model 26$AnyEvent::MAX_SIGNAL_LATENCY = 0.2;
29 27
30my $pid = fork; 28for my $it ("", 1, 2, 3, 4) {
29 print "ok ${it}1\n";
31 30
31 AnyEvent::detect; # force-load event model
32
33 my $pid = fork;
34
32defined $pid or die "unable to fork"; 35 defined $pid or die "unable to fork";
33 36
34# work around Tk bug until it has been fixed. 37# work around Tk bug until it has been fixed.
35#my $timer = AnyEvent->timer (after => 2, cb => sub { }); 38#my $timer = AnyEvent->timer (after => 2, cb => sub { });
36 39
37my $cv = AnyEvent->condvar; 40 my $cv = AnyEvent->condvar;
38 41
39unless ($pid) { 42 unless ($pid) {
40 print "ok 2\n"; 43 print "ok ${it}2\n";
41 exit 3; 44 POSIX::_exit 3;
42} 45 }
43 46
44my $w = AnyEvent->child (pid => $pid, cb => sub { 47 my $w = AnyEvent->child (pid => $pid, cb => sub {
45 print $pid == $_[0] ? "" : "not ", "ok 3\ # $pid == $_[0]\n"; 48 print $pid == $_[0] ? "" : "not ", "ok ${it}3\ # $pid == $_[0]\n";
46 print 3 == ($_[1] >> 8) ? "" : "not ", "ok 4 # 3 == $_[1] >> 8 ($_[1])\n"; 49 print 3 == ($_[1] >> 8) ? "" : "not ", "ok ${it}4 # 3 == $_[1] >> 8 ($_[1])\n";
47 $cv->broadcast; 50 $cv->broadcast;
48}); 51 });
49 52
50$cv->wait; 53 $cv->wait;
51 54
52my $pid2 = fork || exit 7; 55 my $pid2 = fork || POSIX::_exit 7;
53 56
54my $cv2 = AnyEvent->condvar; 57 my $cv2 = AnyEvent->condvar;
55 58
56my $w2 = AnyEvent->child (pid => 0, cb => sub { 59 my $w2 = AnyEvent->child (pid => 0, cb => sub {
57 print $pid2 == $_[0] ? "" : "not ", "ok 5 # $pid2 == $_[0]\n"; 60 print $pid2 == $_[0] ? "" : "not ", "ok ${it}5 # $pid2 == $_[0]\n";
58 print 7 == ($_[1] >> 8) ? "" : "not ", "ok 6 # 7 == $_[1] >> 8 ($_[1])\n"; 61 print 7 == ($_[1] >> 8) ? "" : "not ", "ok ${it}6 # 7 == $_[1] >> 8 ($_[1])\n";
59 $cv2->broadcast; 62 $cv2->broadcast;
60}); 63 });
61 64
62my $error = AnyEvent->timer (after => 5, cb => sub { 65 my $error = AnyEvent->timer (after => 5, cb => sub {
63 print <<EOF; 66 print <<EOF;
64Bail out! No child exit detected. This is either a bug in AnyEvent or a bug in your Perl (mostly some windows distributions suffer from that): child watchers might not work properly on this platform. You can force installation of this module if you do not rely on child watchers, or you could upgrade to a working version of Perl for your platform.\n"; 67Bail out! No child exit detected. This is either a bug in AnyEvent or a bug in your Perl (mostly some windows distributions suffer from that): child watchers might not work properly on this platform. You can force installation of this module if you do not rely on child watchers, or you could upgrade to a working version of Perl for your platform.\n";
65EOF 68EOF
66 exit 0; 69 exit 0;
67}); 70 });
68 71
69$cv2->wait; 72 $cv2->wait;
70 73
71print "ok 7\n"; 74 print "ok ${it}7\n";
75 print "ok ${it}8\n";
76 print "ok ${it}9\n";
77 print "ok ", $it*10+10, "\n";
78}
72 79
73 80
74 81
75 82

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines