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