The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.
use strict;
use warnings;
use File::Spec;
use Test::More;
use POE qw(Component::SmokeBox::Smoker Component::SmokeBox::Job);

my $jobs = 25;

plan tests => 4 + ( $jobs * 13 );

use_ok('POE::Component::SmokeBox');
my $smoker = POE::Component::SmokeBox::Smoker->new( perl => $^X );
my $smokebox =  POE::Component::SmokeBox->spawn( smokers => [ $smoker ], options => { trace => 0 });
isa_ok( $smokebox, 'POE::Component::SmokeBox' );
ok( scalar $smokebox->queues() == 1, 'There is one jobqueue' );

POE::Session->create(
  package_states => [
    'main' => [qw(_start _stop _results _time_out)],
  ],
  options => { trace => 0 },
);

$poe_kernel->run();
exit 0;

sub _start {
  diag("Starting $jobs jobs, this can take a while\n");
  for ( 1 .. $jobs ) {
     my $job = POE::Component::SmokeBox::Job->new( type => 'Test::Stress', command => 'smoke', module => 'Test-Excess-0.01.tar.gz' );
     $poe_kernel->post( $smokebox->session_id(), 'submit', job => $job, event => '_results', );
     $_[HEAP]->{_jobs}++;
  }
  $poe_kernel->delay( '_time_out', $jobs * 6 );
  return;
}

sub _stop {
  pass('Poco let go of our reference');
  $smokebox->shutdown();
  return;
}

sub _time_out {
  die;
}

sub _results {
  my ($kernel,$heap,$results) = @_[KERNEL,HEAP,ARG0];
  isa_ok( $results->{job}, 'POE::Component::SmokeBox::Job' );
  isa_ok( $results->{result}, 'POE::Component::SmokeBox::Result' );
  ok( $results->{submitted}, 'There was a value for submitted' );
  ok( scalar $results->{result}->results() == 1, 'There was only one result' );
  foreach my $res ( $results->{result}->results() ) {
     ok( ref $res eq 'HASH', 'The result is a hashref' );
     ok( defined $res->{$_}, "There is a '$_' entry" ) for qw(PID status start_time end_time perl log type command);
  }
  $heap->{_jobs}--;
  $kernel->delay( '_time_out' ) if $heap->{_jobs} <= 0;
  return;
}