6 use Gruntmaster
::Daemon
;
9 use File
::Basename qw
/fileparse/;
10 use File
::Slurp qw
/read_file/;
11 use File
::Temp qw
/tempdir/;
12 use File
::Which qw
/which/;
13 use Hash
::Merge qw
/merge/;
14 use List
::Util qw
/sum/;
17 use YAML
::Tiny qw
/LoadFile/;
19 ##################################################
21 use constant COMPILER
=> {
41 my %needs_fork = map { $_ => 1 } qw
/GOLANG GOLFSCRIPT GCCGO JAVA JULIA RUBY/;
43 my $loglevel = $ENV{TEST_LOG_LEVEL
} // ($ENV{TEST_VERBOSE
} ?
'TRACE' : 'OFF');
44 my $log_conf = <<CONF;
45 log4perl.category.Gruntmaster.Daemon = $loglevel, stderr
47 log4perl.appender.stderr = Log::Log4perl::Appender::Screen
48 log4perl.appender.stderr.layout = Log::Log4perl::Layout::PatternLayout
49 log4perl.appender.stderr.layout.ConversionPattern = [\%d] [\%F{1}:\%M{1}:\%L] [\%p] \%m\%n
51 Log
::Log4perl
->init(\
$log_conf);
53 $ENV{PATH
} = getcwd
. ':' . $ENV{PATH
};
58 if (defined $meta->{results
}) {
59 delete $meta->{results
}[$_]{time} for keys @
{$meta->{results
}};
61 my $desc = $meta->{name
} . ': ' . $meta->{test_name
};
62 is
$meta->{result
}, $meta->{expected_result
}, "Result is correct ($desc)";
63 is
$meta->{result_text
}, $meta->{expected_result_text
}, "Result text is correct ($desc)";
64 is_deeply
$meta->{results
}, $meta->{expected_results
}, "Results are correct ($desc)";
67 my @problems = exists $ENV{TEST_PROBLEMS
} ?
map {"t/problems/$_"} split ' ', $ENV{TEST_PROBLEMS
} : <t
/problems/*>;
68 @problems = grep { $_ !~ /hello/ } @problems unless $ENV{RELEASE_TESTING
} || $ENV{TEST_PROBLEMS
};
70 plan tests
=> 3 * sum
map { my @temp = <$_/tests/*>; scalar @temp } @problems;
71 note
"Problems to be tested: " . join ', ', @problems;
73 my $tempdir = tempdir
"gruntmasterd-testingXXXX", TMPDIR
=> 1, CLEANUP
=> 1;
78 for my $problem (@problems) {
79 my $pbmeta = LoadFile
"$problem/meta.yml";
80 for (1 .. $pbmeta->{testcnt
}) {
81 $pbmeta->{infile
}[$_ - 1] = read_file
"$problem/$_.in" if $pbmeta->{generator
} eq 'File';
82 $pbmeta->{okfile
}[$_ - 1] = read_file
"$problem/$_.ok" if $pbmeta->{runner
} && $pbmeta->{runner
} eq 'File';
84 if (exists $pbmeta->{files
}) {
85 $_->{content
} = read_file
"$problem/$_->{name}" for values %{$pbmeta->{files
}}
89 note
"Now testing problem $pbmeta->{name} ($pbmeta->{description})";
91 for my $source (<$problem/tests
/*>) {
93 my $meta = LoadFile
"$source/meta.yml";
94 if ($meta->{files
}{prog
}) {
95 my $format = $meta->{files
}{prog
}{format
};
96 my $compiler = COMPILER
->{$format};
97 skip
"$compiler not found in path", 3 unless $ENV{GRUNTMASTER_VM
} || which
$compiler;
98 skip
"$format requires multiple processes. Set GRUNTMASTER_KILL_USER and GRUNTMASTER_SUDO to allow multiple processes.", 3 if !$ENV{GRUNTMASTER_KILL_USER
} && $needs_fork{$format};
99 $meta->{files
}{prog
}{content
} = read_file
"$source/$meta->{files}{prog}{name}";
101 $meta = merge
$meta, $pbmeta;
102 local $TODO = $meta->{todo
} if exists $meta->{todo
};
103 note
"Running $meta->{test_name} ($meta->{test_description})...";
104 my $savedcwd = getcwd
;
106 Gruntmaster
::Daemon
::process
$meta;
This page took 0.03104 seconds and 5 git commands to generate.