]>
iEval git - gruntmaster-daemon.git/blob - t/01-jobs.t
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
=> {
33 my $loglevel = $ENV{TEST_LOG_LEVEL
} // ($ENV{TEST_VERBOSE
} ?
'TRACE' : 'OFF');
34 my $log_conf = <<CONF;
35 log4perl.category.Gruntmaster.Daemon = $loglevel, stderr
37 log4perl.appender.stderr = Log::Log4perl::Appender::Screen
38 log4perl.appender.stderr.layout = Log::Log4perl::Layout::PatternLayout
39 log4perl.appender.stderr.layout.ConversionPattern = [\%d] [\%F{1}:\%M{1}:\%L] [\%p] \%m\%n
41 Log
::Log4perl
->init(\
$log_conf);
43 $ENV{PATH
} = getcwd
. ':' . $ENV{PATH
};
48 if (defined $meta->{results
}) {
49 delete $meta->{results
}[$_]{time} for keys @
{$meta->{results
}};
51 is
$meta->{result
}, $meta->{expected_result
}, "Result is correct";
52 is
$meta->{result_text
}, $meta->{expected_result_text
}, "Result text is correct";
53 is_deeply
$meta->{results
}, $meta->{expected_results
}, "Results are correct";
56 my @problems = exists $ENV{TEST_PROBLEMS
} ?
map {"t/problems/$_"} split ' ', $ENV{TEST_PROBLEMS
} : <t
/problems/*>;
57 @problems = grep { $_ !~ /hello/ } @problems unless $ENV{RELEASE_TESTING
} || $ENV{TEST_PROBLEMS
};
59 plan tests
=> 3 * sum
map { my @temp = <$_/tests/*>; scalar @temp } @problems;
60 note
"Problems to be tested: " . join ', ', @problems;
62 my $tempdir = tempdir
"gruntmasterd-testingXXXX", TMPDIR
=> 1, CLEANUP
=> 1;
67 for my $problem (@problems) {
68 my $pbmeta = LoadFile
"$problem/meta.yml";
69 for (1 .. $pbmeta->{testcnt
}) {
70 $pbmeta->{infile
}[$_ - 1] = read_file
"$problem/$_.in" if $pbmeta->{generator
} eq 'File';
71 $pbmeta->{okfile
}[$_ - 1] = read_file
"$problem/$_.ok" if $pbmeta->{runner
} eq 'File';
73 if (exists $pbmeta->{files
}) {
74 $_->{content
} = read_file
"$problem/$_->{name}" for values %{$pbmeta->{files
}}
78 local $TODO = $pbmeta->{todo
} if exists $pbmeta->{todo
};
79 note
"Now testing problem $pbmeta->{name} ($pbmeta->{description})";
81 for my $source (<$problem/tests
/*>) {
83 my $meta = LoadFile
"$source/meta.yml";
84 my $compiler = COMPILER
->{$meta->{files
}{prog
}{format
}};
85 skip
"$compiler not found in path", 3 unless $ENV{GRUNTMASTER_VM
} || which
$compiler;
86 local $TODO = $meta->{todo
} if exists $meta->{todo
};
87 $meta->{files
}{prog
}{content
} = read_file
"$source/$meta->{files}{prog}{name}";
88 $meta = merge
$meta, $pbmeta;
89 note
"Running $meta->{test_name} ($meta->{test_description})...";
90 my $savedcwd = getcwd
;
92 Gruntmaster
::Daemon
::process
$meta;
This page took 0.063874 seconds and 4 git commands to generate.