libtbsetup.pm 1.52 KB
Newer Older
1
#!/usr/bin/perl -w
Leigh Stoller's avatar
Leigh Stoller committed
2
use POSIX;
3

4 5 6 7 8 9
package libtbsetup;
use Exporter;
@ISA = "Exporter";
@EXPORT =
    qw ( tbs_initdbi tbs_initlog tbs_prefix tbs_out tbs_exec );

10 11 12 13 14 15 16 17 18 19
# This has the common functionality for tbprerun/tbrun/tbend.

# tbs_initdbi(dbname) - Initializes a DBI connection to the testbed database
#                       Returns the database handle.
# tbs_prefix(s) - Returns the file prefix.  I.e. strips off \..+$ from the end.
# tbs_out(s) - Spits s out to stdout and LOGFILE.
# tbs_exec(s) - Acts like system except STDOUT and STDERR are both spat out
#               through tbs_out.  Returns 1 on failure and 0 on success.

my $LOGFILE;
20
my $logging = 0;
21
my $dostamp = 0;
22 23 24 25 26 27 28 29 30 31

sub tbs_initdbi {
    my($dbname) = $_[0];
    return DBI->connect("DBI:mysql:database=$dbname;host=localhost") 
	|| die "Could not connect to DB.\n";
};

sub tbs_initlog {
    my($logfile) = $_[0];

32 33 34
    # Turn off line buffering.
    $| = 1; 

35
    open(LOGFILE,">>$logfile") || do {
36 37 38
	print STDERR "Could not open $logfile for writing.\n";
	exit(1);
    };
39
    $logging = 1;
40 41 42 43 44 45 46 47 48 49 50
}

sub tbs_prefix {
    my($s) = $_[0];
    my($prefix);
    ($prefix) = ($s =~ /^(.+)\.[^.]+$/);
    return $prefix;
};

sub tbs_out {
    my($s) = $_[0];
51 52 53 54 55 56 57
    if ($dostamp) {
	my $t = ctime(time);
	print $t;
	if ($logging) {
	    print LOGFILE $t;
	}
    }
58
    print $s;
59 60 61
    if ($logging) {
	print LOGFILE $s;
    }
62 63 64 65 66 67 68 69
};

sub tbs_exec {
    my($cmd) = $_[0];
    open(EXEC,"$cmd 2>&1|") || return 1;
    while (<EXEC>) {
	&tbs_out($_);
    }
70 71 72
    close(EXEC) or
	return $! ? $! : $?;

73 74 75 76
    return 0;
};

1;