use File::Slurp qw/slurp/;
use Gruntmaster::Daemon::Constants qw/WA/;
+use Gruntmaster::Daemon::Format qw/copy_from_vm/;
use Log::Log4perl qw/get_logger/;
use POSIX qw/mkfifo/;
use Try::Tiny;
-our $VERSION = '5999.000_002';
+our $VERSION = '5999.000_005';
##################################################
my ($test, $meta) = @_;
get_logger->trace("Running on test $test...");
- 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) {
- try {
- $meta->{files}{prog}{run}->($meta->{files}{prog}{name}, fds => [qw/0 fifo1 1 >fifo2/], map {defined $meta->{$_} ? ($_ => $meta->{$_}) : () } qw/timeout mlimit/);
- } catch {
- die $_
- } finally {
- waitpid $ret, 0;
- };
- die [WA, "Wrong Answer"] if $?;
- } else {
- try {
- $meta->{files}{ver}{run}->($meta->{files}{ver}{name}, fds => [qw/1 >fifo1 0 fifo2 4 >result/], args => [$test], map {defined $meta->{$_} ? ($_ => $meta->{$_}) : () } qw/timeout mlimit/);
- } catch {
- exit 1;
- };
- exit
- }
-
- unlink 'fifo1';
- unlink 'fifo2';
-
- scalar slurp 'result'
+ my @fds = $ENV{GRUNTMASTER_VM} ? qw,0 ../fifo1 1 >../fifo2, : qw/0 fifo1 1 >fifo2/;
+ $meta->{files}{prog}{run}->($meta->{files}{prog}{name}, nonblocking => 1, fds => \@fds, map { $_ => $meta->{$_} } qw/timeout mlimit/);
+
+ my $fail;
+ @fds = $ENV{GRUNTMASTER_VM} ? qw,1 >../fifo1 0 ../fifo2, : qw/1 >fifo1 0 fifo2/;
+ try {
+ $meta->{files}{ver}{run}->($meta->{files}{ver}{name}, fds => [@fds, qw,3 input 4 >result,], args => [$test], map { $_ => $meta->{$_} } qw/timeout mlimit/);
+ } catch {
+ $fail = [WA, 'Wrong Answer'];
+ };
+
+ try {
+ Gruntmaster::Daemon::Format::execlist_finish(prog => !$fail);
+ } catch {
+ $fail = $_;
+ };
+
+ die $fail if $fail; ## no critic (RequireCarping)
+ copy_from_vm 'result';
+ scalar slurp 'result' or 'Ok'
}
1;