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
=> {
42 my %needs_fork = map { $_ => 1 } qw
/GOLANG GOLFSCRIPT GCCGO JAVA JULIA RUBY/;
44 my $loglevel = $ENV{TEST_LOG_LEVEL
} // ($ENV{TEST_VERBOSE
} ?
'TRACE' : 'OFF');
45 my $log_conf = <<CONF;
46 log4perl.category.Gruntmaster.Daemon = $loglevel, stderr
48 log4perl.appender.stderr = Log::Log4perl::Appender::Screen
49 log4perl.appender.stderr.layout = Log::Log4perl::Layout::PatternLayout
50 log4perl.appender.stderr.layout.ConversionPattern = [\%d] [\%F{1}:\%M{1}:\%L] [\%p] \%m\%n
52 Log
::Log4perl
->init(\
$log_conf);
54 $ENV{PATH
} = getcwd
. ':' . $ENV{PATH
};
59 if (defined $meta->{results
}) {
60 delete $meta->{results
}[$_]{time} for keys @
{$meta->{results
}};
62 my $desc = $meta->{name
} . ': ' . $meta->{test_name
};
63 is
$meta->{result
}, $meta->{expected_result
}, "Result is correct ($desc)";
64 is
$meta->{result_text
}, $meta->{expected_result_text
}, "Result text is correct ($desc)";
65 is_deeply
$meta->{results
}, $meta->{expected_results
}, "Results are correct ($desc)";
68 my @problems = exists $ENV{TEST_PROBLEMS
} ?
map {"t/problems/$_"} split ' ', $ENV{TEST_PROBLEMS
} : <t
/problems/*>;
69 @problems = grep { $_ !~ /hello/ } @problems unless $ENV{RELEASE_TESTING
} || $ENV{TEST_PROBLEMS
};
71 plan tests
=> 3 * sum
map { my @temp = <$_/tests/*>; scalar @temp } @problems;
72 note
"Problems to be tested: " . join ', ', @problems;
74 my $tempdir = tempdir
"gruntmasterd-testingXXXX", TMPDIR
=> 1, CLEANUP
=> 1;
79 for my $problem (@problems) {
80 my $pbmeta = LoadFile
"$problem/meta.yml";
81 for (1 .. $pbmeta->{testcnt
}) {
82 $pbmeta->{infile
}[$_ - 1] = read_file
"$problem/$_.in" if $pbmeta->{generator
} eq 'File';
83 $pbmeta->{okfile
}[$_ - 1] = read_file
"$problem/$_.ok" if $pbmeta->{runner
} && $pbmeta->{runner
} eq 'File';
85 if (exists $pbmeta->{files
}) {
86 $_->{content
} = read_file
"$problem/$_->{name}" for values %{$pbmeta->{files
}}
90 note
"Now testing problem $pbmeta->{name} ($pbmeta->{description})";
92 for my $source (<$problem/tests
/*>) {
94 my $meta = LoadFile
"$source/meta.yml";
95 if ($meta->{files
}{prog
}) {
96 my $format = $meta->{files
}{prog
}{format
};
97 my $compiler = COMPILER
->{$format};
98 skip
"$compiler not found in path", 3 unless $ENV{GRUNTMASTER_VM
} || which
$compiler;
99 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};
100 $meta->{files
}{prog
}{content
} = read_file
"$source/$meta->{files}{prog}{name}";
102 $meta = merge
$meta, $pbmeta;
103 local $TODO = $meta->{todo
} if exists $meta->{todo
};
104 note
"Running $meta->{test_name} ($meta->{test_description})...";
105 my $savedcwd = getcwd
;
107 Gruntmaster
::Daemon
::process
$meta;
This page took 0.033307 seconds and 5 git commands to generate.