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