X-Git-Url: http://git.ieval.ro/?p=gruntmaster-daemon.git;a=blobdiff_plain;f=lib%2FGruntmaster%2FDaemon%2FRunner%2FInteractive.pm;h=9c4580fbf2e033f77eabf0f9ddecb789467d8c6a;hp=5edee04ea2055f533e92d53a3754bf4b98ffe6d5;hb=2d67a3e68e77b9f85e324b1b5e974758e70e938a;hpb=0890dd25777c65562991248375c8513a8a70ec1e 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 {