用于EagleEye3.0 规则集漏报和误报测试的示例项目,项目收集于github和gitee
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

265 lines
6.9 KiB

5 months ago
# -*- cperl -*-
# Copyright (c) 2004, 2018, Oracle and/or its affiliates. All rights reserved.
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License, version 2.0,
# as published by the Free Software Foundation.
#
# This program is also distributed with certain software (including
# but not limited to OpenSSL) that is licensed under separate terms,
# as designated in a particular file or component or in included license
# documentation. The authors of MySQL hereby grant you an additional
# permission to link the program and your derivative works with the
# separately licensed software that they have included with MySQL.
#
# 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 General Public License, version 2.0, 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;
our $opt_report_times;
# Initialize an empty array or list
sub mtr_init_args ($) {
my $args = shift;
$$args = [];
}
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));
}
# 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;
my %time_text = ('admin' => "Test administration",
'ch-warn' => "Check for warnings",
'check' => "Check-testcase",
'collect' => "Collecting test cases",
'init' => "Initialization/cleanup",
'restart' => "Server stop/start",
'test' => "Test execution",);
# Counts number of reports from workers
my $last_timer_set;
my $time_totals = 0;
sub init_timers() {
$last_timer_set = gettimeofday();
# Initialize the 'time_used' hash for each worker
%time_used = ('admin' => 0,
'ch-warn' => 0,
'check' => 0,
'collect' => 0,
'init' => 0,
'restart' => 0,
'test' => 0,);
}
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;