Fix maintainer test when no Parallel::Forker, msg2630.

This commit is contained in:
Wilson Snyder 2019-03-10 12:14:58 -04:00
parent 0eb75a41bb
commit b8ccb7a4c1
2 changed files with 17 additions and 5 deletions

View File

@ -16,6 +16,8 @@ The contributors that suggested a given feature are shown in []. Thanks!
**** Fix MSVC compile error, bug1406. [Benjamin Gartner] **** Fix MSVC compile error, bug1406. [Benjamin Gartner]
**** Fix maintainer test when no Parallel::Forker, msg2630. [Enzo Chi]
* Verilator 4.010 2019-01-27 * Verilator 4.010 2019-01-27

View File

@ -136,6 +136,9 @@ if ($#opt_tests<0) {
if ($#opt_tests>=2 && $opt_jobs>=2) { if ($#opt_tests>=2 && $opt_jobs>=2) {
# Without this tests such as t_debug_sigsegv_bt_bad.pl will occasionally # Without this tests such as t_debug_sigsegv_bt_bad.pl will occasionally
# block on input and cause a SIGSTOP, then a "fg" was needed to resume testing. # block on input and cause a SIGSTOP, then a "fg" was needed to resume testing.
if (!$::Have_Forker) {
print STDERR "driver.pl: NO_FORKER: For faster testing 'sudo cpan install Parallel::Forker'\n";
}
print STDERR "== Many jobs; redirecting STDIN\n"; print STDERR "== Many jobs; redirecting STDIN\n";
open(STDIN, "+>/dev/null"); open(STDIN, "+>/dev/null");
} }
@ -173,9 +176,10 @@ sub one_test {
# Don't put anything other than _exit after _read, # Don't put anything other than _exit after _read,
# as may call _exit via another path # as may call _exit via another path
$test->_exit; $test->_exit;
}, },
run_on_finish => sub { run_on_finish => sub {
my $test = VTest->new(@params); # RUnning in context of parent
my $test = VTest->new(@params);
$test->_read_status; $test->_read_status;
if ($test->ok) { if ($test->ok) {
$OkCnt++; $OkCnt++;
@ -1814,8 +1818,14 @@ sub new {
sub schedule { sub schedule {
my $self = shift; my $self = shift;
my %params = (@_); my %params = (@_);
&{$params{run_on_start}}();
&{$params{run_on_finish}}(); if (my $pid = fork()) { # Parent
waitpid($pid, 0);
} else { # Child
$params{run_on_start}->($self);
exit(0); # Don't close anything
}
$params{run_on_finish}->($self);
return $self; return $self;
} }
sub max_proc {} sub max_proc {}