X-Git-Url: http://git.ieval.ro/?p=gruntmaster-daemon.git;a=blobdiff_plain;f=t%2F01-jobs.t;h=3f00b3d0b90f8c81ba6af2b276b9f5cc13f327e9;hp=2365b12dfab7e5097c3a85bf0bfe7a4654f0f2e7;hb=HEAD;hpb=da905f9ea0693b88b7ca37514fbacf4c2383f2bf diff --git a/t/01-jobs.t b/t/01-jobs.t index 2365b12..c37e081 100644 --- a/t/01-jobs.t +++ b/t/01-jobs.t @@ -1,23 +1,49 @@ -#!/usr/bin/perl -w use v5.14; use strict; use warnings; use Gruntmaster::Daemon; -use Cwd qw/cwd/; -use File::Copy qw/copy/; -use File::Copy::Recursive qw/dircopy/; -use File::Path qw/remove_tree/; +use Cwd qw/getcwd/; +use File::Basename qw/fileparse/; +use File::Slurp qw/read_file/; use File::Temp qw/tempdir/; +use File::Which qw/which/; +use FindBin; +use Hash::Merge qw/merge/; use List::Util qw/sum/; use Log::Log4perl; use Test::More; -use YAML::Any qw/LoadFile/; +use YAML::Tiny qw/LoadFile/; ################################################## -my $loglevel = $ENV{TEST_LOG_LEVEL} // 'OFF'; +use constant COMPILER => { + qw/BRAINFUCK bfc + C gcc + CPP g++ + D dmd + GOLFSCRIPT golfscript + MONO gmcs + JAVA javac + JAVASCRIPT node + JULIA julia + PASCAL fpc + GOLANG go + GCCGO gccgo + HASKELL ghc + PERL perl + PHP php + PYTHON python2.7 + RUBY ruby + RUST rustc + OBERON obc + OCAML ocaml + SBCL sbcl/}; + +my %needs_fork = map { $_ => 1 } qw/GOLANG GOLFSCRIPT GCCGO JAVA JAVASCRIPT JULIA RUBY SBCL/; + +my $loglevel = $ENV{TEST_LOG_LEVEL} // ($ENV{TEST_VERBOSE} ? 'TRACE' : 'OFF'); my $log_conf = <init(\$log_conf); -$ENV{PATH}.=':' . cwd; +$ENV{PATH} = getcwd . ':' . $ENV{PATH}; +$ENV{PATH} = "$FindBin::Bin/../blib/script:" . $ENV{PATH}; +umask 0022; sub check_job{ - my $job = shift; - my $meta = LoadFile "$job/meta.yml"; - if (exists $meta->{results}) { - delete $meta->{results}[$_]{time} for keys $meta->{results}; - } - is $meta->{result}, $meta->{expected_result}, "Result is correct"; - is $meta->{result_text}, $meta->{expected_result_text}, "Result text is correct"; - is_deeply $meta->{results}, $meta->{expected_results}, "Results are correct"; + my $meta = shift; + if (defined $meta->{results}) { + delete $meta->{results}[$_]{time} for keys @{$meta->{results}}; + } + my $desc = $meta->{name} . ': ' . $meta->{test_name}; + is $meta->{result}, $meta->{expected_result}, "Result is correct ($desc)"; + is $meta->{result_text}, $meta->{expected_result_text}, "Result text is correct ($desc)"; + is_deeply $meta->{results}, $meta->{expected_results}, "Results are correct ($desc)"; } my @problems = exists $ENV{TEST_PROBLEMS} ? map {"t/problems/$_"} split ' ', $ENV{TEST_PROBLEMS} : ; +@problems = grep { $_ !~ /hello/ } @problems unless $ENV{RELEASE_TESTING} || $ENV{TEST_PROBLEMS}; + plan tests => 3 * sum map { my @temp = <$_/tests/*>; scalar @temp } @problems; note "Problems to be tested: " . join ', ', @problems; -my $tempdir = tempdir CLEANUP => 1; -mkdir "$tempdir/jobs"; -dircopy 't/problems' => "$tempdir/pb"; +my $tempdir = tempdir "gruntmasterd-testingXXXX", TMPDIR => 1, CLEANUP => 1; +chmod 0777, $tempdir; + +my $job = 0; for my $problem (@problems) { - my $meta = LoadFile "$problem/meta.yml"; - TODO: { - local $TODO = $meta->{todo} if exists $meta->{todo}; - note "Now testing problem $meta->{name} ($meta->{description})"; - for my $source (<$problem/tests/*>) { - my $meta = LoadFile "$source/meta.yml"; - note "Running $meta->{test_name} ($meta->{test_description})..."; - dircopy $source => "$tempdir/jobs/job"; - my $savedcwd = cwd; - Gruntmaster::Daemon::process "$tempdir/jobs/job"; - check_job "$tempdir/log/1"; - chdir $savedcwd; - remove_tree "$tempdir/log", "$tempdir/jobs", {keep_root => 1}; + my $pbmeta = LoadFile "$problem/meta.yml"; + for (1 .. $pbmeta->{testcnt}) { + $pbmeta->{infile}[$_ - 1] = read_file "$problem/$_.in" if $pbmeta->{generator} eq 'File'; + $pbmeta->{okfile}[$_ - 1] = read_file "$problem/$_.ok" if $pbmeta->{runner} && $pbmeta->{runner} eq 'File'; + } + if (exists $pbmeta->{files}) { + $_->{content} = read_file "$problem/$_->{name}" for values %{$pbmeta->{files}} + } + + TODO: { + note "Now testing problem $pbmeta->{name} ($pbmeta->{description})"; + + for my $source (<$problem/tests/*>) { + SKIP: { + my $meta = LoadFile "$source/meta.yml"; + if ($meta->{files}{prog}) { + my $format = $meta->{files}{prog}{format}; + my $compiler = COMPILER->{$format}; + skip "$compiler not found in path", 3 unless $ENV{GRUNTMASTER_VM} || which $compiler; + 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}; + $meta->{files}{prog}{content} = read_file "$source/$meta->{files}{prog}{name}"; + } + $meta = merge $meta, $pbmeta; + local $TODO = $meta->{todo} if exists $meta->{todo}; + note "Running $meta->{test_name} ($meta->{test_description})..."; + my $savedcwd = getcwd; + chdir $tempdir; + Gruntmaster::Daemon::process $meta; + chdir $savedcwd; + check_job $meta; + } + } } - } }