… | |
… | |
38 | #my $timer = AnyEvent->timer (after => 2, cb => sub { }); |
38 | #my $timer = AnyEvent->timer (after => 2, cb => sub { }); |
39 | |
39 | |
40 | my $cv = AnyEvent->condvar; |
40 | my $cv = AnyEvent->condvar; |
41 | |
41 | |
42 | unless ($pid) { |
42 | unless ($pid) { |
43 | print "ok ${it}2\n"; |
43 | print "ok ${it}2 # child $$\n"; |
|
|
44 | |
|
|
45 | # POE hits a race condition when the child dies too quickly |
|
|
46 | # because it checks for child exit before installing the signal handler. |
|
|
47 | # seen in version 1.352 - earlier versions had the same bug, but |
|
|
48 | # polled for child exits regularly, so only caused a delay. |
|
|
49 | sleep 1 if $AnyEvent::MODEL eq "POE"; |
|
|
50 | |
44 | POSIX::_exit 3; |
51 | POSIX::_exit 3; |
45 | } |
52 | } |
46 | |
|
|
47 | my $w = AnyEvent->child (pid => $pid, cb => sub { |
53 | my $w = AnyEvent->child (pid => $pid, cb => sub { |
48 | print $pid == $_[0] ? "" : "not ", "ok ${it}3\ # $pid == $_[0]\n"; |
54 | print $pid == $_[0] ? "" : "not ", "ok ${it}3\ # $pid == $_[0]\n"; |
49 | print 3 == ($_[1] >> 8) ? "" : "not ", "ok ${it}4 # 3 == $_[1] >> 8 ($_[1])\n"; |
55 | print 3 == ($_[1] >> 8) ? "" : "not ", "ok ${it}4 # 3 == $_[1] >> 8 ($_[1])\n"; |
50 | $cv->broadcast; |
56 | $cv->broadcast; |
51 | }); |
57 | }); |