09f81b3dcfda1bf5b16df2b041e3ef09269f9bb0
[gruntmaster-daemon.git] / t / 01-jobs.t
1 #!/usr/bin/perl -w
2 use v5.14;
3 use strict;
4 use warnings;
5
6 use Gruntmaster::Daemon;
7
8 use Cwd qw/cwd/;
9 use File::Basename qw/fileparse/;
10 use File::Slurp qw/read_file/;
11 use File::Temp qw/tempdir/;
12 use Hash::Merge qw/merge/;
13 use List::Util qw/sum/;
14 use Log::Log4perl;
15 use Test::More;
16 use YAML::Any qw/LoadFile/;
17
18 ##################################################
19
20 my $loglevel = $ENV{TEST_LOG_LEVEL} // ($ENV{TEST_VERBOSE} ? 'TRACE' : 'OFF');
21 my $log_conf = <<CONF;
22 log4perl.category.Gruntmaster.Daemon = $loglevel, stderr
23
24 log4perl.appender.stderr = Log::Log4perl::Appender::Screen
25 log4perl.appender.stderr.layout = Log::Log4perl::Layout::PatternLayout
26 log4perl.appender.stderr.layout.ConversionPattern = [\%d] [\%F{1}:\%M{1}:\%L] [\%p] \%m\%n
27 CONF
28 Log::Log4perl->init(\$log_conf);
29
30 $ENV{PATH} = cwd . ':' . $ENV{PATH};
31
32 sub check_job{
33 my $meta = shift;
34 if (defined $meta->{results}) {
35 delete $meta->{results}[$_]{time} for keys @{$meta->{results}};
36 }
37 is $meta->{result}, $meta->{expected_result}, "Result is correct";
38 is $meta->{result_text}, $meta->{expected_result_text}, "Result text is correct";
39 is_deeply $meta->{results}, $meta->{expected_results}, "Results are correct";
40 }
41
42 my @problems = exists $ENV{TEST_PROBLEMS} ? map {"t/problems/$_"} split ' ', $ENV{TEST_PROBLEMS} : <t/problems/*>;
43 plan tests => 3 * sum map { my @temp = <$_/tests/*>; scalar @temp } @problems;
44 note "Problems to be tested: " . join ', ', @problems;
45
46 my $tempdir = tempdir "gruntmaster-daemon-testingXXXX", TMPDIR => 1, CLEANUP => 1;
47 chmod 0777, $tempdir;
48
49 my $job = 0;
50
51 for my $problem (@problems) {
52 my $pbmeta = LoadFile "$problem/meta.yml";
53 for (1 .. $pbmeta->{testcnt}) {
54 $pbmeta->{infile}[$_ - 1] = read_file "$problem/$_.in" if $pbmeta->{generator} eq 'File';
55 $pbmeta->{okfile}[$_ - 1] = read_file "$problem/$_.ok" if $pbmeta->{runner} eq 'File';
56 }
57 if (exists $pbmeta->{files}) {
58 $_->{content} = read_file "$problem/$_->{name}" for values %{$pbmeta->{files}}
59 }
60
61 TODO: {
62 local $TODO = $pbmeta->{todo} if exists $pbmeta->{todo};
63 note "Now testing problem $pbmeta->{name} ($pbmeta->{description})";
64
65 for my $source (<$problem/tests/*>) {
66 my $meta = LoadFile "$source/meta.yml";
67 $meta->{files}{prog}{content} = read_file "$source/$meta->{files}{prog}{name}";
68 $meta = merge $meta, $pbmeta;
69 note "Running $meta->{test_name} ($meta->{test_description})...";
70 my $savedcwd = cwd;
71 chdir $tempdir;
72 Gruntmaster::Daemon::process $meta;
73 chdir $savedcwd;
74 check_job $meta;
75 }
76 }
77 }
This page took 0.028342 seconds and 4 git commands to generate.