Imported Upstream version 1.4.5
This commit is contained in:
parent
62d1e7d5fe
commit
6a280f6f24
412 changed files with 168642 additions and 0 deletions
283
tools/tinderbox_build
Executable file
283
tools/tinderbox_build
Executable file
|
@ -0,0 +1,283 @@
|
|||
#!/usr/bin/perl
|
||||
# tinderbox_build.pl
|
||||
# This script builds the nagiosplugins and then sends
|
||||
# logs back to the master tinderbox server
|
||||
#
|
||||
# This script is based on mozilla-unix.pl which comes with tinderbox2
|
||||
#
|
||||
# See http://tinderbox.altinity.org for more details
|
||||
|
||||
require 5.000;
|
||||
|
||||
use strict;
|
||||
use Sys::Hostname;
|
||||
use Cwd;
|
||||
use Time::Local;
|
||||
|
||||
my $Version = '$Revision: 1.3 $';
|
||||
|
||||
my $myhost = hostname;
|
||||
chomp($myhost);
|
||||
my ($host, $junk) = split(/\./, $myhost);
|
||||
|
||||
my $BuildAdministrator = $ENV{TINDERBOX_BUILD_ADMIN} || "$ENV{'USER'}\@$myhost";
|
||||
|
||||
#Default values of cmdline opts
|
||||
my $ReportStatus = 0; # Do not send results to server
|
||||
|
||||
# Set these to what makes sense for your system
|
||||
|
||||
# Set these proper values for your tinderbox server
|
||||
my $Tinderbox_server = 'tinderbox2@tinderbox.altinity.org';
|
||||
|
||||
# These shouldn't really need to be changed
|
||||
my $BuildTree = 'nagiosplug';
|
||||
my $BuildName = '';
|
||||
my $ConfigureArgs = $ENV{CONFIGURE_ARGS};
|
||||
|
||||
my $OS = `uname -s`;
|
||||
my $OSVer = `uname -r`;
|
||||
|
||||
chop($OS, $OSVer);
|
||||
|
||||
if ( $OS eq 'AIX' ) {
|
||||
$OSVer = `uname -v`;
|
||||
chop($OSVer);
|
||||
$OSVer = $OSVer . "." . `uname -r`;
|
||||
chop($OSVer);
|
||||
}
|
||||
|
||||
if ( $OS eq 'IRIX64' ) {
|
||||
$OS = 'IRIX';
|
||||
}
|
||||
|
||||
if ( $OS eq 'SCO_SV' ) {
|
||||
$OS = 'SCOOS';
|
||||
$OSVer = '5.0';
|
||||
}
|
||||
|
||||
if ( "$host" ne "" ) {
|
||||
$BuildName = $host . ' ';
|
||||
}
|
||||
$BuildName .= $OS . ' ' . $OSVer;
|
||||
$_ = $BuildName;
|
||||
s/ /_/g;
|
||||
|
||||
my $logfile = "$_.log";
|
||||
|
||||
sub BuildIt {
|
||||
my ($fe, @felist, $EarlyExit, $LastTime);
|
||||
|
||||
my $StartDir = getcwd();
|
||||
$LastTime = 0;
|
||||
|
||||
print "Starting dir is : $StartDir\n";
|
||||
|
||||
my $EarlyExit = 0;
|
||||
|
||||
chdir("$StartDir");
|
||||
|
||||
my $StartTime = time;
|
||||
if (-e (my $file = "nagios-plugins.spec")) {
|
||||
open F, $file;
|
||||
while (<F>) {
|
||||
if (/^Version: HEAD-(\d\d\d\d)(\d\d)(\d\d)(\d\d)(\d\d)$/) {
|
||||
$StartTime = timegm(0, $5, $4, $3, ($2 - 1), ($1 - 1900));
|
||||
last;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
print "Start time is $StartTime",$/;
|
||||
|
||||
my $CurrentDir = getcwd();
|
||||
if ( $CurrentDir ne $StartDir ) {
|
||||
print "startdir: $StartDir, curdir $CurrentDir\n";
|
||||
die "curdir != startdir";
|
||||
}
|
||||
|
||||
unlink( "$logfile" );
|
||||
|
||||
print "opening $logfile\n";
|
||||
open( LOG, ">$logfile" ) || print "can't open $?\n";
|
||||
print LOG "current dir is -- $host:$CurrentDir\n";
|
||||
print LOG "Build Administrator is $BuildAdministrator\n";
|
||||
&PrintEnv;
|
||||
|
||||
my $BuildStatus;
|
||||
if (&configure) {
|
||||
if (&make) {
|
||||
if (&maketest) {
|
||||
$BuildStatus = "success";
|
||||
} else {
|
||||
$BuildStatus = "test_failed";
|
||||
}
|
||||
} else {
|
||||
$BuildStatus = "build_failed";
|
||||
}
|
||||
} else {
|
||||
$BuildStatus = "busted";
|
||||
}
|
||||
|
||||
print LOG "\nBuild Status = $BuildStatus\n";
|
||||
|
||||
close(LOG);
|
||||
chdir("$StartDir");
|
||||
|
||||
# TV: Leaving this in, because process mail program probably has some
|
||||
# limitation retained
|
||||
|
||||
# this fun line added on 2/5/98. do not remove. Translated to english,
|
||||
# that's "take any line longer than 1000 characters, and split it into less
|
||||
# than 1000 char lines. If any of the resulting lines is
|
||||
# a dot on a line by itself, replace that with a blank line."
|
||||
# This is to prevent cases where a <cr>.<cr> occurs in the log file. Sendmail
|
||||
# interprets that as the end of the mail, and truncates the log before
|
||||
# it gets to Tinderbox. (terry weismann, chris yeh)
|
||||
#
|
||||
# This was replaced by a perl 'port' of the above, writen by
|
||||
# preed@netscape.com; good things: no need for system() call, and now it's
|
||||
# all in perl, so we don't have to do OS checking like before.
|
||||
|
||||
open(LOG, "$logfile") || die "Couldn't open logfile: $!\n";
|
||||
open(OUTLOG, ">${logfile}.last") || die "Couldn't open logfile: $!\n";
|
||||
|
||||
print OUTLOG $/;
|
||||
print OUTLOG "tinderbox: tree: $BuildTree\n";
|
||||
print OUTLOG "tinderbox: builddate: $StartTime\n";
|
||||
print OUTLOG "tinderbox: status: $BuildStatus\n";
|
||||
print OUTLOG "tinderbox: build: $BuildName $fe\n";
|
||||
print OUTLOG "tinderbox: errorparser: unix\n";
|
||||
print OUTLOG "tinderbox: buildfamily: unix\n";
|
||||
print OUTLOG "tinderbox: END\n";
|
||||
print OUTLOG $/;
|
||||
|
||||
while (<LOG>) {
|
||||
my $q = 0;
|
||||
|
||||
for (;;) {
|
||||
my $val = $q * 1000;
|
||||
my $Output = substr($_, $val, 1000);
|
||||
|
||||
last if $Output eq undef;
|
||||
|
||||
$Output =~ s/^\.$//g;
|
||||
$Output =~ s/\n//g;
|
||||
print OUTLOG "$Output\n";
|
||||
$q++;
|
||||
} #EndFor
|
||||
|
||||
} #EndWhile
|
||||
|
||||
close(LOG);
|
||||
close(OUTLOG);
|
||||
|
||||
if ($ReportStatus) {
|
||||
system( "ssh $Tinderbox_server tinderbox_receive < ${logfile}.last" )
|
||||
} else {
|
||||
print <<"EOF"
|
||||
Not sending logs to http://tinderbox.altinity.org
|
||||
If you have SSH keys setup on the tinderbox server, you can manually send
|
||||
with 'ssh $Tinderbox_server tinderbox_receive < ${logfile}.last'
|
||||
EOF
|
||||
}
|
||||
|
||||
unlink("$logfile");
|
||||
print "Finished building for tinderbox",$/;
|
||||
|
||||
} #EndSub-BuildIt
|
||||
|
||||
sub ParseArgs {
|
||||
my($i);
|
||||
|
||||
$i = 0;
|
||||
while( $i < @ARGV ) {
|
||||
if ($ARGV[$i] eq '--version' || $ARGV[$i] eq '-v') {
|
||||
die "$0: version $Version\n";
|
||||
} elsif ($ARGV[$i] eq '-y') {
|
||||
$ReportStatus = 1;
|
||||
} else {
|
||||
&PrintUsage;
|
||||
}
|
||||
|
||||
$i++;
|
||||
} #EndWhile
|
||||
|
||||
} #EndSub-ParseArgs
|
||||
|
||||
sub PrintUsage {
|
||||
die "usage: $0 [-v | --version ] [-t do not send report to tinderbox server]\n";
|
||||
}
|
||||
|
||||
sub PrintEnv {
|
||||
my ($key);
|
||||
foreach $key (keys %ENV) {
|
||||
print LOG "$key = $ENV{$key}\n";
|
||||
print "$key = $ENV{$key}\n";
|
||||
}
|
||||
|
||||
# Print the NPTest variables
|
||||
if (-e "/var/tmp/NPTest.cache") {
|
||||
open F, "/var/tmp/NPTest.cache";
|
||||
print LOG "NPTest variables:\n";
|
||||
print LOG <F>;
|
||||
close F;
|
||||
}
|
||||
|
||||
} #EndSub-PrintEnv
|
||||
|
||||
sub SetupPath {
|
||||
my($Path);
|
||||
$Path = $ENV{PATH};
|
||||
print "Path before: $Path\n";
|
||||
|
||||
if ( $OS eq 'SunOS' ) {
|
||||
$ENV{'PATH'} = '/usr/ccs/bin:' . $ENV{'PATH'};
|
||||
}
|
||||
|
||||
$Path = $ENV{PATH};
|
||||
print "Path After: $Path\n";
|
||||
} #EndSub-SetupPath
|
||||
|
||||
sub configure {
|
||||
# Configure
|
||||
print LOG "./configure $ConfigureArgs\n";
|
||||
open (CONFIGURE, "./configure $ConfigureArgs 2>&1 |") || die "../configure: $!\n";
|
||||
while (<CONFIGURE>) {
|
||||
print $_;
|
||||
print LOG $_;
|
||||
}
|
||||
close(CONFIGURE);
|
||||
return ! $?;
|
||||
}
|
||||
|
||||
sub make {
|
||||
# Building
|
||||
print LOG "make 2>&1\n";
|
||||
open( MAKE, "make 2>&1 |");
|
||||
while ( <MAKE> ) {
|
||||
print $_;
|
||||
print LOG $_;
|
||||
}
|
||||
close( MAKE);
|
||||
return ! $?;
|
||||
}
|
||||
|
||||
sub maketest {
|
||||
# Tests
|
||||
print LOG "LANG=C make test 2>&1\n";
|
||||
open( MAKE, "LANG=C make test 2>&1 |");
|
||||
while ( <MAKE> ) {
|
||||
print $_;
|
||||
print LOG $_;
|
||||
}
|
||||
close( MAKE);
|
||||
return ! $?;
|
||||
}
|
||||
|
||||
# Main function
|
||||
&ParseArgs;
|
||||
&SetupPath;
|
||||
&BuildIt;
|
||||
|
||||
1;
|
Loading…
Add table
Add a link
Reference in a new issue