Async-Simple-Pool
view release on metacpan or search on metacpan
t/09-pool-partial-results-collect.t view on Meta::CPAN
#!perl -T
use Modern::Perl;
use POSIX;
use Test::Spec;
use Test::Exception;
use Time::HiRes qw/ sleep time /;
plan tests => 11;
my $dev_mode = 0;
# use lib '../lib';
use Data::Dumper;
use Async::Simple::Pool;
warn 'DEVELOPER MODE' if $dev_mode;
my $timeout = $dev_mode ? 0.03 : 0.5;
my $full_cycle_worst_time = 3 * $timeout * 10 * 1.5;
my $worker_delay = $timeout * 10;
my $is_win = $^O =~ /^(dos|os2|MSWin32|NetWare)$/;
describe 'All' => sub {
describe 'process' => sub {
my( $task, @data );
before each => sub {
$task = sub {
my( $data ) = @_;
$data->{ok} = 1;
return $data;
};
@data = map { \%{{ i => $_ }} } 1..20;
};
# break_on => busy/run/done
# flush_data => 0/1
describe 'partial results' => sub {
my $slow_task = sub {
my( $data ) = @_;
sleep $worker_delay;
$data->{ok} = 1;
return $data;
};
it 'check for results with break_on = "done"' => sub {
my $time = time;
my $pool = Async::Simple::Pool->new( $slow_task, \@data );
my $result = $pool->process;
is( scalar( grep $_, @$result ), 20, 'waiting for all tasks by default' );
my $work_time = time - $time;
ok( $work_time < $worker_delay * 3.5, sprintf 'async done work time = %.2f sec', $work_time );
( run in 1.652 second using v1.01-cache-2.11-cpan-97f6503c9c8 )