AnyEvent-Gearman-WorkerPool
view release on metacpan or search on metacpan
t/03-SlotOverwork.t view on Meta::CPAN
package main;
use lib qw( lib t/lib);
use Test::More tests=>5;
use Log::Log4perl qw(:easy);
# Log::Log4perl->easy_init($DEBUG);
use Gear;
use AnyEvent;
use AnyEvent::Gearman;
use AnyEvent::Gearman::WorkerPool::Slot;
use Scalar::Util qw(weaken);
my $port = '9955';
my @js = ("localhost:$port");
my $cv = AE::cv;
my $t = AE::timer 15,0,sub{ $cv->send('timeout')};
use_ok('Gearman::Server');
gstart($port);
my $slot = AnyEvent::Gearman::WorkerPool::Slot->new(
job_servers=>\@js,
libs=>['t/lib','./lib'],
workleft=>1,
worker_package=>'TestWorker',
worker_channel=>'child',
);
$slot->start();
my $cpid = $slot->worker_pid;
my $c = gearman_client @js;
$c->add_task('TestWorker::reverse'=>'HELLO', on_complete=>sub{
my $job = shift;
my $res = shift;
is $res,'OLLEH','client result ok 1';
AE::postpone{
$c->add_task('TestWorker::reverse'=>'HELLO', on_complete=>sub{
my $job = shift;
my $res = shift;
is $res,'OLLEH','client result ok 2';
isnt $slot->worker_pid, $cpid,'worker respawned';
$cv->send;
});
}
});
my $res = $cv->recv;
isnt $res,'timeout','ends successfully';
$slot->stop();
undef($t);
undef($c);
undef($slot);
gstop();
done_testing();
( run in 0.765 second using v1.01-cache-2.11-cpan-39bf76dae61 )