mirror of
https://github.com/MariaDB/server.git
synced 2025-01-22 23:04:20 +01:00
361 lines
7.5 KiB
Perl
361 lines
7.5 KiB
Perl
# -*- cperl -*-
|
|
# Copyright (c) 2004, 2011, Oracle and/or its affiliates.
|
|
# Copyright (c) 2009-2011, Monty Program Ab
|
|
#
|
|
# This program is free software; you can redistribute it and/or
|
|
# modify it under the terms of the GNU Library General Public
|
|
# License as published by the Free Software Foundation; version 2
|
|
# of the License.
|
|
#
|
|
# This program is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
# Library General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU General Public License
|
|
# along with this program; if not, write to the Free Software
|
|
# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
|
|
# This is a library file used by the Perl version of mysql-test-run,
|
|
# and is part of the translation of the Bourne shell script with the
|
|
# same name.
|
|
|
|
use strict;
|
|
|
|
use My::Platform;
|
|
|
|
sub mtr_init_args ($);
|
|
sub mtr_add_arg ($$@);
|
|
sub mtr_args2str($@);
|
|
sub mtr_path_exists(@);
|
|
sub mtr_script_exists(@);
|
|
sub mtr_file_exists(@);
|
|
sub mtr_exe_exists(@);
|
|
sub mtr_exe_maybe_exists(@);
|
|
sub mtr_compress_file($);
|
|
sub mtr_milli_sleep($);
|
|
sub start_timer($);
|
|
sub has_expired($);
|
|
sub init_timers();
|
|
sub mark_time_used($);
|
|
sub mark_time_idle();
|
|
sub add_total_times($);
|
|
sub print_times_used($$);
|
|
sub print_total_times($);
|
|
|
|
our $opt_report_times;
|
|
|
|
##############################################################################
|
|
#
|
|
# Args
|
|
#
|
|
##############################################################################
|
|
|
|
sub mtr_init_args ($) {
|
|
my $args = shift;
|
|
$$args = []; # Empty list
|
|
}
|
|
|
|
sub mtr_add_arg ($$@) {
|
|
my $args= shift;
|
|
my $format= shift;
|
|
my @fargs = @_;
|
|
|
|
# Quote args if args contain space
|
|
$format= "\"$format\""
|
|
if (IS_WINDOWS and grep(/\s/, @fargs));
|
|
|
|
push(@$args, sprintf($format, @fargs));
|
|
}
|
|
|
|
sub mtr_args2str($@) {
|
|
my $exe= shift or die;
|
|
return join(" ", native_path($exe), @_);
|
|
}
|
|
|
|
##############################################################################
|
|
|
|
#
|
|
# NOTE! More specific paths should be given before less specific.
|
|
# For example /client/debug should be listed before /client
|
|
#
|
|
sub mtr_path_exists (@) {
|
|
foreach my $path ( @_ )
|
|
{
|
|
return $path if -e $path;
|
|
}
|
|
if ( @_ == 1 )
|
|
{
|
|
mtr_error("Could not find $_[0]");
|
|
}
|
|
else
|
|
{
|
|
mtr_error("Could not find any of " . join(" ", @_));
|
|
}
|
|
}
|
|
|
|
|
|
#
|
|
# NOTE! More specific paths should be given before less specific.
|
|
# For example /client/debug should be listed before /client
|
|
#
|
|
sub mtr_script_exists (@) {
|
|
foreach my $path ( @_ )
|
|
{
|
|
if(IS_WINDOWS)
|
|
{
|
|
return $path if -f $path;
|
|
}
|
|
else
|
|
{
|
|
return $path if -x $path;
|
|
}
|
|
}
|
|
if ( @_ == 1 )
|
|
{
|
|
mtr_error("Could not find $_[0]");
|
|
}
|
|
else
|
|
{
|
|
mtr_error("Could not find any of " . join(" ", @_));
|
|
}
|
|
}
|
|
|
|
|
|
#
|
|
# NOTE! More specific paths should be given before less specific.
|
|
# For example /client/debug should be listed before /client
|
|
#
|
|
sub mtr_file_exists (@) {
|
|
foreach my $path ( @_ )
|
|
{
|
|
return $path if -e $path;
|
|
}
|
|
return "";
|
|
}
|
|
|
|
|
|
#
|
|
# NOTE! More specific paths should be given before less specific.
|
|
# For example /client/debug should be listed before /client
|
|
#
|
|
sub mtr_exe_maybe_exists (@) {
|
|
my @path= @_;
|
|
|
|
map {$_.= ".exe"} @path if IS_WINDOWS;
|
|
foreach my $path ( @path )
|
|
{
|
|
if(IS_WINDOWS)
|
|
{
|
|
return $path if -f $path;
|
|
}
|
|
else
|
|
{
|
|
return $path if -x $path;
|
|
}
|
|
}
|
|
return "";
|
|
}
|
|
|
|
|
|
#
|
|
# NOTE! More specific paths should be given before less specific.
|
|
#
|
|
sub mtr_pl_maybe_exists (@) {
|
|
my @path= @_;
|
|
|
|
map {$_.= ".pl"} @path if IS_WINDOWS;
|
|
foreach my $path ( @path )
|
|
{
|
|
if(IS_WINDOWS)
|
|
{
|
|
return $path if -f $path;
|
|
}
|
|
else
|
|
{
|
|
return $path if -x $path;
|
|
}
|
|
}
|
|
return "";
|
|
}
|
|
|
|
|
|
#
|
|
# NOTE! More specific paths should be given before less specific.
|
|
# For example /client/debug should be listed before /client
|
|
#
|
|
sub mtr_exe_exists (@) {
|
|
my @path= @_;
|
|
if (my $path= mtr_exe_maybe_exists(@path))
|
|
{
|
|
return $path;
|
|
}
|
|
# Could not find exe, show error
|
|
if ( @path == 1 )
|
|
{
|
|
mtr_error("Could not find $path[0]");
|
|
}
|
|
else
|
|
{
|
|
mtr_error("Could not find any of " . join(" ", @path));
|
|
}
|
|
}
|
|
|
|
#
|
|
# Try to compress file using tools that might be available.
|
|
# If zip/gzip is not available, just silently ignore.
|
|
#
|
|
|
|
sub mtr_compress_file ($) {
|
|
my ($filename)= @_;
|
|
|
|
mtr_error ("File to compress not found: $filename") unless -f $filename;
|
|
|
|
my $did_compress= 0;
|
|
|
|
if (IS_WINDOWS)
|
|
{
|
|
# Capture stderr
|
|
my $ziperr= `zip $filename.zip $filename 2>&1`;
|
|
if ($?) {
|
|
print "$ziperr\n" if $ziperr !~ /recognized as an internal or external/;
|
|
} else {
|
|
unlink($filename);
|
|
$did_compress=1;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
my $gzres= system("gzip $filename");
|
|
$did_compress= ! $gzres;
|
|
if ($gzres && $gzres != -1) {
|
|
mtr_error ("Error: have gzip but it fails to compress core file");
|
|
}
|
|
}
|
|
mtr_print("Compressed file $filename") if $did_compress;
|
|
}
|
|
|
|
|
|
sub mtr_milli_sleep ($) {
|
|
die "usage: mtr_milli_sleep(milliseconds)" unless @_ == 1;
|
|
my ($millis)= @_;
|
|
|
|
select(undef, undef, undef, ($millis/1000));
|
|
}
|
|
|
|
sub mtr_wait_lock_file {
|
|
die "usage: mtr_wait_lock_file(path_to_file, keep_alive)" unless @_ == 2;
|
|
my ($file, $keep_alive)= @_;
|
|
my $waited= 0;
|
|
my $msg_counter= $keep_alive;
|
|
|
|
while ( -e $file)
|
|
{
|
|
if ($keep_alive && !$msg_counter)
|
|
{
|
|
print "\n-STOPPED- [pass] ".$keep_alive."\n";
|
|
$msg_counter= $keep_alive;
|
|
}
|
|
mtr_milli_sleep(1000);
|
|
$waited= 1;
|
|
$msg_counter--;
|
|
}
|
|
return ($waited);
|
|
}
|
|
|
|
sub uniq(@) {
|
|
my %seen = map { $_ => $_ } @_;
|
|
values %seen;
|
|
}
|
|
|
|
# Simple functions to start and check timers (have to be actively polled)
|
|
# Timer can be "killed" by setting it to 0
|
|
|
|
sub start_timer ($) { return time + $_[0]; }
|
|
|
|
sub has_expired ($) { return $_[0] && time gt $_[0]; }
|
|
|
|
# Below code is for time usage reporting
|
|
|
|
use Time::HiRes qw(gettimeofday);
|
|
|
|
my %time_used= (
|
|
'collect' => 0,
|
|
'restart' => 0,
|
|
'check' => 0,
|
|
'ch-warn' => 0,
|
|
'test' => 0,
|
|
'init' => 0,
|
|
'admin' => 0,
|
|
);
|
|
|
|
my %time_text= (
|
|
'collect' => "Collecting test cases",
|
|
'restart' => "Server stop/start",
|
|
'check' => "Check-testcase",
|
|
'ch-warn' => "Check for warnings",
|
|
'test' => "Test execution",
|
|
'init' => "Initialization/cleanup",
|
|
'admin' => "Test administration",
|
|
);
|
|
|
|
# Counts number of reports from workers
|
|
|
|
my $time_totals= 0;
|
|
|
|
my $last_timer_set;
|
|
|
|
sub init_timers() {
|
|
$last_timer_set= gettimeofday();
|
|
}
|
|
|
|
sub mark_time_used($) {
|
|
my ($name)= @_;
|
|
return unless $opt_report_times;
|
|
die "Unknown timer $name" unless exists $time_used{$name};
|
|
|
|
my $curr_time= gettimeofday();
|
|
$time_used{$name}+= int (($curr_time - $last_timer_set) * 1000 + .5);
|
|
$last_timer_set= $curr_time;
|
|
}
|
|
|
|
sub mark_time_idle() {
|
|
$last_timer_set= gettimeofday() if $opt_report_times;
|
|
}
|
|
|
|
sub add_total_times($) {
|
|
my ($dummy, $num, @line)= split (" ", $_[0]);
|
|
|
|
$time_totals++;
|
|
foreach my $elem (@line) {
|
|
my ($name, $spent)= split (":", $elem);
|
|
$time_used{$name}+= $spent;
|
|
}
|
|
}
|
|
|
|
sub print_times_used($$) {
|
|
my ($server, $num)= @_;
|
|
return unless $opt_report_times;
|
|
|
|
my $output= "SPENT $num";
|
|
foreach my $name (keys %time_used) {
|
|
my $spent= $time_used{$name};
|
|
$output.= " $name:$spent";
|
|
}
|
|
print $server $output . "\n";
|
|
}
|
|
|
|
sub print_total_times($) {
|
|
# Don't print if we haven't received all worker data
|
|
return if $time_totals != $_[0];
|
|
|
|
foreach my $name (keys %time_used)
|
|
{
|
|
my $spent= $time_used{$name}/1000;
|
|
my $text= $time_text{$name};
|
|
print ("Spent $spent seconds on $text\n");
|
|
}
|
|
}
|
|
|
|
|
|
1;
|