tests: add a nice reporting status, fix MT test

This commit is contained in:
Gregory Hainaut 2016-01-18 18:54:43 +01:00
parent 00dde7d2cf
commit 157b68a29f
1 changed files with 32 additions and 8 deletions

View File

@ -9,6 +9,7 @@ use File::Find;
use File::Spec; use File::Spec;
use Cwd; use Cwd;
use Cwd 'abs_path'; use Cwd 'abs_path';
use Term::ANSIColor;
sub help { sub help {
# always useful # always useful
@ -19,7 +20,7 @@ my ($o_suite, $o_help, $o_exe, $o_cfg, $o_max_cpu);
$o_max_cpu = 1; $o_max_cpu = 1;
my $status = Getopt::Long::GetOptions( my $status = Getopt::Long::GetOptions(
'cfg=s' => \$o_cfg, 'cfg=s' => \$o_cfg,
'cpu' => \$o_max_cpu, # FIXME not tested 'cpu=i' => \$o_max_cpu,
'exe=s' => \$o_exe, 'exe=s' => \$o_exe,
'help' => \$o_help, 'help' => \$o_help,
'suite=s' => \$o_suite, 'suite=s' => \$o_suite,
@ -48,28 +49,51 @@ $o_cfg = abs_path($o_cfg);
# Round 1: Collect the tests # Round 1: Collect the tests
my $g_test_db; my $g_test_db;
print "Info: search test in $o_suite\n"; print "INFO: search tests in $o_suite and run them in $o_max_cpu CPU)\n";
find({ wanted => \&add_test_cmd_for_elf, no_chdir => 1 }, $o_suite); find({ wanted => \&add_test_cmd_for_elf, no_chdir => 1 }, $o_suite);
# Round 2: Run the tests (later in thread) # Round 2: Run the tests (later in thread)
foreach my $t (keys(%$g_test_db)) { foreach my $test (keys(%$g_test_db)) {
# wait free CPU slot # wait free CPU slot
while( scalar(threads->list() >= $o_max_cpu) ) { while( scalar(threads->list() >= $o_max_cpu) ) {
if (close_joinnable_threads() == 0) { if (close_joinnable_threads() == 0) {
sleep(5); sleep(1); # test are often fast so 1s is more than enough
} }
} }
create_thread($t); create_thread($test);
} }
wait_all_threads(); wait_all_threads();
# Round 3: Collect the results # Round 3: Collect the results (not thread safe)
collect_result();
# Pretty print
print "\n\n Status | ================= Test ======================\n";
foreach my $test (sort(keys(%$g_test_db))) {
my $info = $g_test_db->{$test};
if ($info->{"STATUS"} != 0) {
print color('bold red');
print " KO | $test\n";
} else {
print color('bold green');
print " OK | $test\n";
}
}
print color('reset');
print "\n";
##################################################### #####################################################
sub collect_result { sub collect_result {
foreach my $test (keys(%$g_test_db)) {
my $info = $g_test_db->{$test};
my $out = $info->{"OUT"};
my $exp = $info->{"EXPECTED"};
system("diff $out $exp -q");
$info->{"STATUS"} = $?; # not thread safe
}
} }
sub add_test_cmd_for_elf { sub add_test_cmd_for_elf {
@ -133,7 +157,7 @@ sub run_elf {
# FIXME timeout # FIXME timeout
my $pid = open(my $log, "$o_exe --elf $elf --cfgpath=$cfg |") or die "Impossible to pipe $!"; my $pid = open(my $log, "$o_exe --elf $elf --cfgpath=$cfg |") or die "Impossible to pipe $!";
print "Info: Execute $elf (PID=$pid) with cfg ($cfg)\n"; print "INFO: Execute $elf (PID=$pid) with cfg ($cfg)\n";
while ($line = <$log>) { while ($line = <$log>) {
$line =~ s/\e\[\d+(?>(;\d+)*)m//g; $line =~ s/\e\[\d+(?>(;\d+)*)m//g;