]>
iEval git - gruntmaster-daemon.git/blob - t/01-jobs.t
6 use Gruntmaster
::Daemon
;
9 use File
::Copy qw
/copy/;
10 use File
::Copy
::Recursive qw
/dircopy/;
11 use File
::Path qw
/remove_tree/;
12 use File
::Temp qw
/tempdir/;
13 use List
::Util qw
/sum/;
16 use YAML
::Any qw
/LoadFile/;
18 ##################################################
20 my $loglevel = $ENV{TEST_LOG_LEVEL
} // 'OFF';
21 my $log_conf = <<CONF;
22 log4perl.category.Gruntmaster.Daemon = $loglevel, stderr
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
28 Log
::Log4perl
->init(\
$log_conf);
32 my $meta = LoadFile
"$job/meta.yml";
33 if (exists $meta->{results
}) {
34 delete $meta->{results
}[$_]{time} for keys $meta->{results
};
36 is
$meta->{result
}, $meta->{expected_result
}, "Result is correct";
37 is
$meta->{result_text
}, $meta->{expected_result_text
}, "Result text is correct";
38 is_deeply
$meta->{results
}, $meta->{expected_results
}, "Results are correct";
41 my @problems = exists $ENV{TEST_PROBLEMS
} ?
map {"t/problems/$_"} split ' ', $ENV{TEST_PROBLEMS
} : <t
/problems/*>;
42 plan tests
=> 3 * sum
map { my @temp = <$_/tests/*>; scalar @temp } @problems;
43 note
"Problems to be tested: " . join ', ', @problems;
45 my $tempdir = tempdir CLEANUP
=> 1;
46 mkdir "$tempdir/jobs";
47 dircopy
't/problems' => "$tempdir/pb";
49 for my $problem (@problems) {
50 my $meta = LoadFile
"$problem/meta.yml";
52 local $TODO = $meta->{todo
} if exists $meta->{todo
};
53 note
"Now testing problem $meta->{name} ($meta->{description})";
54 for my $source (<$problem/tests
/*>) {
55 my $meta = LoadFile
"$source/meta.yml";
56 note
"Running $meta->{test_name} ($meta->{test_description})...";
57 dircopy
$source => "$tempdir/jobs/job";
59 Gruntmaster
::Daemon
::process
"$tempdir/jobs/job";
60 check_job
"$tempdir/log/1";
62 remove_tree
"$tempdir/log", "$tempdir/jobs", {keep_root
=> 1};
This page took 0.062377 seconds and 4 git commands to generate.