summaryrefslogtreecommitdiffstats
path: root/tools
diff options
context:
space:
mode:
Diffstat (limited to 'tools')
-rw-r--r--tools/tools/tinderbox/tbmaster.pl169
1 files changed, 117 insertions, 52 deletions
diff --git a/tools/tools/tinderbox/tbmaster.pl b/tools/tools/tinderbox/tbmaster.pl
index 4aac3d3..e7a4419 100644
--- a/tools/tools/tinderbox/tbmaster.pl
+++ b/tools/tools/tinderbox/tbmaster.pl
@@ -30,11 +30,12 @@
#
use strict;
+use POSIX qw(tzset);
my %CONFIGS = (
# Global settings
'global' => {
- 'TBDIR' => '/home/des/tinderbox',
+ 'LOGDIR' => '/home/des/public_html',
'OPTIONS' => [ '--update', '--verbose' ],
'EMAIL' => 'des',
},
@@ -62,15 +63,17 @@ my %CONFIGS = (
},
# Test setup
'9ball' => {
+ 'OPTIONS' => [ '--verbose' ],
'BRANCHES' => [ 'CURRENT' ],
'TARGETS' => [ 'world', 'generic' ],
'ARCHES' => {
- 'i386' => [ 'i386' ],
+ 'powerpc' => [ 'powerpc' ],
},
'EMAIL' => 'des@ofug.org',
},
);
my %CONFIG = ();
+my $TINDERBOX;
sub report($$$) {
my $recipient = shift;
@@ -88,63 +91,123 @@ sub report($$$) {
}
}
-sub tinderbox($$$$) {
- my $tinderbox = shift;
+sub tinderbox($$$) {
my $branch = shift;
my $arch = shift;
my $machine = shift;
- my $logfile = "$CONFIG{'TBDIR'}/tinderbox-$branch-$arch-$machine.log";
+ # Open log files: one for the full log and one for the summary
+ my $logfile = "$CONFIG{'LOGDIR'}/tinderbox-$branch-$arch-$machine";
+ local (*FULL, *BRIEF);
+ if (!open(FULL, ">", "$logfile.full.$$")) {
+ warn("$logfile.full.$$: $!\n");
+ return undef;
+ }
+ select(FULL);
+ $| = 1;
+ select(STDOUT);
+ if (!open(BRIEF, ">", "$logfile.brief.$$")) {
+ warn("$logfile.brief.$$: $!\n");
+ return undef;
+ }
+ select(BRIEF);
+ $| = 1;
+ select(STDOUT);
- my @args = ($tinderbox, @{$CONFIG{'OPTIONS'}});
+ # Open a pipe for the tinderbox process
+ local (*RPIPE, *WPIPE);
+ if (!pipe(RPIPE, WPIPE)) {
+ warn("pipe(): $!\n");
+ unlink("$logfile.brief.$$");
+ close(BRIEF);
+ unlink("$logfile.full.$$");
+ close(FULL);
+ return undef;
+ }
+
+ # Fork and start the tinderbox
+ my @args = @{$CONFIG{'OPTIONS'}};
push(@args, "--branch=$branch");
push(@args, "--arch=$arch");
push(@args, "--machine=$machine");
- push(@args, "--logfile=$logfile");
push(@args, @{$CONFIG{'TARGETS'}});
+ my $pid = fork();
+ if (!defined($pid)) {
+ warn("fork(): $!\n");
+ unlink("$logfile.brief.$$");
+ close(BRIEF);
+ unlink("$logfile.full.$$");
+ close(FULL);
+ return undef;
+ } elsif ($pid == 0) {
+ close(RPIPE);
+ open(STDOUT, ">&WPIPE");
+ open(STDERR, ">&WPIPE");
+ $| = 1;
+ exec($TINDERBOX, @args);
+ die("child: exec(): $!\n");
+ }
- rename($logfile, "$logfile.old");
- if (system(@args) != 0) {
- my $messages = "";
- my @accumulate;
- my $error = 0;
- local *LOGFILE;
-
- warn("$branch tinderbox failed for $arch/$machine\n");
- if (open(LOGFILE, "<", $logfile)) {
- while (<LOGFILE>) {
- if (m/^TB ---/) {
- if (@accumulate && $error) {
- $messages .= join('', @accumulate);
- }
- $messages .= $_;
- @accumulate = ();
- $error = 0;
- next;
- }
- if (m/\bStop\b/) {
- $error = 1;
- }
- if (@accumulate > 20) {
- shift(@accumulate);
- $accumulate[0] = "[...]";
- }
- push(@accumulate, $_);
+ # Process the output
+ close(WPIPE);
+ my @lines = ();
+ my $error = 0;
+ my $summary = "";
+ while (<RPIPE>) {
+ print(FULL $_);
+ if (/^TB ---/ || /^>>> /) {
+ if ($error) {
+ $summary .= join('', @lines);
+ print(BRIEF join('', @lines));
+ @lines = ();
+ $error = 0;
}
- if (@accumulate && $error) {
- $messages .= join('', @accumulate);
- }
- my $recipient = $CONFIG{'EMAIL'};
- $recipient =~ s/\%\%branch\%\%/$branch/gi;
- $recipient =~ s/\%\%arch\%\%/$arch/gi;
- $recipient =~ s/\%\%machine\%\%/$machine/gi;
- report($recipient,
- "$branch tinderbox failure on $arch/$machine",
- $messages);
- } else {
- warn("$logfile: $!\n");
+ $summary .= $_;
+ print(BRIEF $_);
+ @lines = ();
+ next;
+ }
+ if (/\bStop\b/) {
+ $error = 1;
}
+ if (@lines > 10 && !$error) {
+ shift(@lines);
+ $lines[0] = "[...]\n";
+ }
+ push(@lines, $_);
+ }
+ if ($error) {
+ $summary .= join('', @lines);
+ print(BRIEF join('', @lines));
+ }
+ close(BRIEF);
+ close(FULL);
+
+ # Done...
+ if (waitpid($pid, 0) == -1) {
+ warn("waitpid(): $!");
+ } elsif ($? & 0xff) {
+ warn("tinderbox caught signal ", $? & 0x7f);
+ $error = 1;
+ } elsif ($? >> 8) {
+ warn("tinderbox returned exit code ", $? >> 8);
+ $error = 1;
}
+
+ # Mail out error reports
+ if ($error) {
+ warn("$branch tinderbox failed for $arch/$machine\n");
+ my $recipient = $CONFIG{'EMAIL'};
+ $recipient =~ s/\%\%branch\%\%/$branch/gi;
+ $recipient =~ s/\%\%arch\%\%/$arch/gi;
+ $recipient =~ s/\%\%machine\%\%/$machine/gi;
+ report($recipient,
+ "$branch tinderbox failure on $arch/$machine",
+ $summary);
+ }
+
+ rename("$logfile.full.$$", "$logfile.full");
+ rename("$logfile.brief.$$", "$logfile.brief");
}
sub usage() {
@@ -170,19 +233,21 @@ MAIN:{
unless (exists($CONFIG{$key}));
}
- $ENV{"PATH"} = "";
- my $tinderbox = $0;
- if ($tinderbox =~ m|(.*/)tbmaster(.*)$|) {
- $tinderbox = "${1}tinderbox${2}";
+ $ENV{'TZ'} = "GMT";
+ tzset();
+ $ENV{'PATH'} = "";
+ $TINDERBOX = $0;
+ if ($TINDERBOX =~ m|(.*/)tbmaster(.*)$|) {
+ $TINDERBOX = "${1}tinderbox${2}";
}
- if ($tinderbox eq $0 || ! -x $tinderbox) {
+ if ($TINDERBOX eq $0 || ! -x $TINDERBOX) {
die("where is the tinderbox script?\n");
}
foreach my $branch (sort(@{$CONFIG{'BRANCHES'}})) {
foreach my $arch (sort(keys(%{$CONFIG{'ARCHES'}}))) {
foreach my $machine (sort(@{$CONFIG{'ARCHES'}->{$arch}})) {
- tinderbox($tinderbox, $branch, $arch, $machine);
+ tinderbox($branch, $arch, $machine);
}
}
}
OpenPOWER on IntegriCloud