AnyEvent-Gearman-WorkerPool

 view release on metacpan or  search on metacpan

t/05-SlotManagerWork.t  view on Meta::CPAN

package main;

use lib qw( lib t/lib );
use Test::More tests=>12;
use Gear;
use AnyEvent;
use AnyEvent::Gearman;
use AnyEvent::Gearman::Client;
use AnyEvent::Gearman::WorkerPool;
use Log::Log4perl qw(:easy);
# Log::Log4perl->easy_init($DEBUG);


use Scalar::Util qw(weaken);
my $port = '9955';
my @js = ("localhost:$port");

use_ok('Gearman::Server');
gstart($port);

my $cv = AE::cv;

my $sig = AE::signal 'INT'=> sub{ 
DEBUG "TERM!!";
    $cv->send;
};

my $t = AE::timer 10,0,sub{ $cv->send('timeout')};


my $slotman = AnyEvent::Gearman::WorkerPool->new(
    config=>
    {
        global=>{
            job_servers=>\@js,
            libs=>['t/lib','./lib'],
            max=>3,
            },
        slots=>{
            'TestWorker'=>{
            min=>3, 
            max=>5,
            workleft=>10,
            }
        }
    },
);

$slotman->start();



my $c = gearman_client @js;


$cv->begin( sub{ $cv->send } );
my @tasks;
foreach (1..10 ){
    my $n = $_;
    my $str = "HELLO$n";
    $cv->begin;
    my $res = $c->add_task(
        'TestWorker::reverse'=>$str,



( run in 1.168 second using v1.01-cache-2.11-cpan-39bf76dae61 )