X-Git-Url: http://git.ieval.ro/?a=blobdiff_plain;f=lib%2FGruntmaster%2FDaemon%2FRunner%2FInteractive.pm;h=9c4580fbf2e033f77eabf0f9ddecb789467d8c6a;hb=ad77b7d3dee6e61405535dd0dabd117398731ad1;hp=5edee04ea2055f533e92d53a3754bf4b98ffe6d5;hpb=5c5cd38ad5b9e3c2b331564bc0b23e9167b7d07a;p=gruntmaster-daemon.git diff --git a/lib/Gruntmaster/Daemon/Runner/Interactive.pm b/lib/Gruntmaster/Daemon/Runner/Interactive.pm index 5edee04..9c4580f 100644 --- a/lib/Gruntmaster/Daemon/Runner/Interactive.pm +++ b/lib/Gruntmaster/Daemon/Runner/Interactive.pm @@ -15,13 +15,14 @@ use Try::Tiny; sub run{ my ($test, $meta) = @_; get_logger->trace("Running on test $test..."); - my $ret = fork // get_logger->logdie("Fork failed: $!"); mkfifo 'fifo1', 0600 or die $! unless -e 'fifo1'; mkfifo 'fifo2', 0600 or die $! unless -e 'fifo2'; + + my $ret = fork // get_logger->logdie("Fork failed: $!"); if ($ret) { $meta->{files}{prog}{run}->($meta->{files}{prog}{name}, fds => [qw/0 fifo1 1 >fifo2/], map {defined $meta->{$_} ? ($_ => $meta->{$_}) : () } qw/timeout mlimit/); - wait; + waitpid $ret, 0; die [WA, "Wrong Answer"] if $?; } else { try {