2004-12-30 16:34:01 +01:00
|
|
|
# -*- cperl -*-
|
2006-12-31 01:02:27 +01:00
|
|
|
# Copyright (C) 2004-2006 MySQL AB
|
|
|
|
#
|
|
|
|
# This program is free software; you can redistribute it and/or modify
|
|
|
|
# it under the terms of the GNU 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 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
|
2004-12-30 16:34:01 +01:00
|
|
|
|
|
|
|
# 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;
|
|
|
|
|
|
|
|
sub mtr_report_test_name($);
|
|
|
|
sub mtr_report_test_passed($);
|
|
|
|
sub mtr_report_test_failed($);
|
|
|
|
sub mtr_report_test_skipped($);
|
2006-10-04 12:47:32 +02:00
|
|
|
sub mtr_report_test_not_skipped_though_disabled($);
|
2004-12-30 16:34:01 +01:00
|
|
|
|
|
|
|
sub mtr_show_failed_diff ($);
|
|
|
|
sub mtr_report_stats ($);
|
|
|
|
sub mtr_print_line ();
|
2005-01-03 16:54:08 +01:00
|
|
|
sub mtr_print_thick_line ();
|
2004-12-30 16:34:01 +01:00
|
|
|
sub mtr_print_header ();
|
|
|
|
sub mtr_report (@);
|
|
|
|
sub mtr_warning (@);
|
|
|
|
sub mtr_error (@);
|
2005-09-14 13:55:53 +02:00
|
|
|
sub mtr_child_error (@);
|
2004-12-30 16:34:01 +01:00
|
|
|
sub mtr_debug (@);
|
2006-10-04 12:47:32 +02:00
|
|
|
sub mtr_verbose (@);
|
2004-12-30 16:34:01 +01:00
|
|
|
|
|
|
|
|
|
|
|
##############################################################################
|
|
|
|
#
|
|
|
|
#
|
|
|
|
#
|
|
|
|
##############################################################################
|
|
|
|
|
|
|
|
# We can't use diff -u or diff -a as these are not portable
|
|
|
|
|
|
|
|
sub mtr_show_failed_diff ($) {
|
2006-11-21 15:16:12 +01:00
|
|
|
my $result_file_name= shift;
|
|
|
|
|
|
|
|
# The reject and log files have been dumped to
|
|
|
|
# to filenames based on the result_file's name
|
|
|
|
my $tname= basename($result_file_name);
|
|
|
|
$tname=~ s/\..*$//;
|
2004-12-30 16:34:01 +01:00
|
|
|
|
|
|
|
my $reject_file= "r/$tname.reject";
|
|
|
|
my $result_file= "r/$tname.result";
|
2006-11-21 21:32:58 +01:00
|
|
|
my $log_file= "$::opt_vardir/log/$tname.log";
|
2004-12-30 16:34:01 +01:00
|
|
|
my $eval_file= "r/$tname.eval";
|
|
|
|
|
2005-06-21 02:21:52 +02:00
|
|
|
if ( $::opt_suite ne "main" )
|
|
|
|
{
|
|
|
|
$reject_file= "$::glob_mysql_test_dir/suite/$::opt_suite/$reject_file";
|
|
|
|
$result_file= "$::glob_mysql_test_dir/suite/$::opt_suite/$result_file";
|
|
|
|
$eval_file= "$::glob_mysql_test_dir/suite/$::opt_suite/$eval_file";
|
2006-10-04 12:47:32 +02:00
|
|
|
$log_file= "$::glob_mysql_test_dir/suite/$::opt_suite/$log_file";
|
2005-06-21 02:21:52 +02:00
|
|
|
}
|
|
|
|
|
2004-12-30 16:34:01 +01:00
|
|
|
if ( -f $eval_file )
|
2006-10-04 12:47:32 +02:00
|
|
|
{
|
2004-12-30 16:34:01 +01:00
|
|
|
$result_file= $eval_file;
|
|
|
|
}
|
|
|
|
|
2005-02-07 20:32:56 +01:00
|
|
|
my $diffopts= $::opt_udiff ? "-u" : "-c";
|
|
|
|
|
2004-12-30 16:34:01 +01:00
|
|
|
if ( -f $reject_file )
|
|
|
|
{
|
|
|
|
print "Below are the diffs between actual and expected results:\n";
|
|
|
|
print "-------------------------------------------------------\n";
|
|
|
|
# FIXME check result code?!
|
2005-02-07 20:32:56 +01:00
|
|
|
mtr_run("diff",[$diffopts,$result_file,$reject_file], "", "", "", "");
|
2004-12-30 16:34:01 +01:00
|
|
|
print "-------------------------------------------------------\n";
|
|
|
|
print "Please follow the instructions outlined at\n";
|
|
|
|
print "http://www.mysql.com/doc/en/Reporting_mysqltest_bugs.html\n";
|
|
|
|
print "to find the reason to this problem and how to report this.\n\n";
|
|
|
|
}
|
2006-10-04 12:47:32 +02:00
|
|
|
|
|
|
|
if ( -f $log_file )
|
|
|
|
{
|
|
|
|
print "Result from queries before failure can be found in $log_file\n";
|
|
|
|
# FIXME Maybe a tail -f -n 10 $log_file here
|
|
|
|
}
|
2004-12-30 16:34:01 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
sub mtr_report_test_name ($) {
|
|
|
|
my $tinfo= shift;
|
|
|
|
|
2005-09-14 13:12:30 +02:00
|
|
|
printf "%-30s ", $tinfo->{'name'};
|
2004-12-30 16:34:01 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
sub mtr_report_test_skipped ($) {
|
|
|
|
my $tinfo= shift;
|
|
|
|
|
|
|
|
$tinfo->{'result'}= 'MTR_RES_SKIPPED';
|
mysql-test-run.pl:
Let --start-and-exit actually start a server
Added that test case names can be specified on the comman line
Added embedded server support
Added environment variables UMASK, UMASK_DIR
Added missing MASTER_MYSOCK1, MASTER_MYPORT1, USE_RUNNING_SERVER
Added missing CHARSETSDIR, MYSQL_FIX_SYSTEM_TABLES, MYSQL_CLIENT_TEST
Pass on return value from sleep_until_file_created(), to fail test
Fail test if early termination of mysqld servers
Create intial databases for the second master, and two additional slaves
mtr_process.pl:
Find out if port is still in use, using simple TCP connect
Use non blocking waitpid() to catch terminations early
Make a special case spawning the 'mysqltest' application
Redo the fork() if it returns EAGAIN
Make sure to record if master or slave terminated
Improved debugging output
Improved code that remove PID files to avoid race
Abort if we can't stop all mysqld servers using our ports
Many improvements in killing mysqld servers
Let sleep_until_file_created() catch if server died early
mtr_report.pl:
Added option to disable test cases using <testcase>.disabled file
If --timer, only try to open file with time data if it exists
mtr_io.pl:
Remove starting/ending space reading server options from file
mysql-test/lib/mtr_io.pl:
Remove starting/ending space reading server options from file
mysql-test/lib/mtr_report.pl:
Added option to disable test cases using <testcase>.disabled file
If --timer, only try to open file with time data if it exists
mysql-test/lib/mtr_process.pl:
Find out if port is still in use, using simple TCP connect
Use non blocking waitpid() to catch terminations early
Make a special case spawning the 'mysqltest' application
Redo the fork() if it returns EAGAIN
Make sure to record if master or slave terminated
Improved debugging output
Improved code that remove PID files to avoid race
Abort if we can't stop all mysqld servers using our ports
Many improvements in killing mysqld servers
Let sleep_until_file_created() catch if server died early
mysql-test/mysql-test-run.pl:
Let --start-and-exit actually start a server
Added that test case names can be specified on the comman line
Added embedded server support
Added environment variables UMASK, UMASK_DIR
Added missing MASTER_MYSOCK1, MASTER_MYPORT1, USE_RUNNING_SERVER
Added missing CHARSETSDIR, MYSQL_FIX_SYSTEM_TABLES, MYSQL_CLIENT_TEST
Pass on return value from sleep_until_file_created(), to fail test
Fail test if early termination of mysqld servers
Create intial databases for the second master, and two additional slaves
2005-02-03 21:13:27 +01:00
|
|
|
if ( $tinfo->{'disable'} )
|
|
|
|
{
|
|
|
|
print "[ disabled ] $tinfo->{'comment'}\n";
|
|
|
|
}
|
2006-11-24 18:26:53 +01:00
|
|
|
elsif ( $tinfo->{'comment'} )
|
mysql-test-run.pl:
Let --start-and-exit actually start a server
Added that test case names can be specified on the comman line
Added embedded server support
Added environment variables UMASK, UMASK_DIR
Added missing MASTER_MYSOCK1, MASTER_MYPORT1, USE_RUNNING_SERVER
Added missing CHARSETSDIR, MYSQL_FIX_SYSTEM_TABLES, MYSQL_CLIENT_TEST
Pass on return value from sleep_until_file_created(), to fail test
Fail test if early termination of mysqld servers
Create intial databases for the second master, and two additional slaves
mtr_process.pl:
Find out if port is still in use, using simple TCP connect
Use non blocking waitpid() to catch terminations early
Make a special case spawning the 'mysqltest' application
Redo the fork() if it returns EAGAIN
Make sure to record if master or slave terminated
Improved debugging output
Improved code that remove PID files to avoid race
Abort if we can't stop all mysqld servers using our ports
Many improvements in killing mysqld servers
Let sleep_until_file_created() catch if server died early
mtr_report.pl:
Added option to disable test cases using <testcase>.disabled file
If --timer, only try to open file with time data if it exists
mtr_io.pl:
Remove starting/ending space reading server options from file
mysql-test/lib/mtr_io.pl:
Remove starting/ending space reading server options from file
mysql-test/lib/mtr_report.pl:
Added option to disable test cases using <testcase>.disabled file
If --timer, only try to open file with time data if it exists
mysql-test/lib/mtr_process.pl:
Find out if port is still in use, using simple TCP connect
Use non blocking waitpid() to catch terminations early
Make a special case spawning the 'mysqltest' application
Redo the fork() if it returns EAGAIN
Make sure to record if master or slave terminated
Improved debugging output
Improved code that remove PID files to avoid race
Abort if we can't stop all mysqld servers using our ports
Many improvements in killing mysqld servers
Let sleep_until_file_created() catch if server died early
mysql-test/mysql-test-run.pl:
Let --start-and-exit actually start a server
Added that test case names can be specified on the comman line
Added embedded server support
Added environment variables UMASK, UMASK_DIR
Added missing MASTER_MYSOCK1, MASTER_MYPORT1, USE_RUNNING_SERVER
Added missing CHARSETSDIR, MYSQL_FIX_SYSTEM_TABLES, MYSQL_CLIENT_TEST
Pass on return value from sleep_until_file_created(), to fail test
Fail test if early termination of mysqld servers
Create intial databases for the second master, and two additional slaves
2005-02-03 21:13:27 +01:00
|
|
|
{
|
2006-10-04 12:47:32 +02:00
|
|
|
print "[ skipped ] $tinfo->{'comment'}\n";
|
|
|
|
}
|
2006-11-24 18:26:53 +01:00
|
|
|
else
|
|
|
|
{
|
|
|
|
print "[ skipped ]\n";
|
|
|
|
}
|
2006-10-04 12:47:32 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
sub mtr_report_tests_not_skipped_though_disabled ($) {
|
|
|
|
my $tests= shift;
|
|
|
|
|
|
|
|
if ( $::opt_enable_disabled )
|
|
|
|
{
|
|
|
|
my @disabled_tests= grep {$_->{'dont_skip_though_disabled'}} @$tests;
|
|
|
|
if ( @disabled_tests )
|
|
|
|
{
|
|
|
|
print "\nTest(s) which will be run though they are marked as disabled:\n";
|
|
|
|
foreach my $tinfo ( sort {$a->{'name'} cmp $b->{'name'}} @disabled_tests )
|
|
|
|
{
|
|
|
|
printf " %-20s : %s\n", $tinfo->{'name'}, $tinfo->{'comment'};
|
|
|
|
}
|
|
|
|
}
|
mysql-test-run.pl:
Let --start-and-exit actually start a server
Added that test case names can be specified on the comman line
Added embedded server support
Added environment variables UMASK, UMASK_DIR
Added missing MASTER_MYSOCK1, MASTER_MYPORT1, USE_RUNNING_SERVER
Added missing CHARSETSDIR, MYSQL_FIX_SYSTEM_TABLES, MYSQL_CLIENT_TEST
Pass on return value from sleep_until_file_created(), to fail test
Fail test if early termination of mysqld servers
Create intial databases for the second master, and two additional slaves
mtr_process.pl:
Find out if port is still in use, using simple TCP connect
Use non blocking waitpid() to catch terminations early
Make a special case spawning the 'mysqltest' application
Redo the fork() if it returns EAGAIN
Make sure to record if master or slave terminated
Improved debugging output
Improved code that remove PID files to avoid race
Abort if we can't stop all mysqld servers using our ports
Many improvements in killing mysqld servers
Let sleep_until_file_created() catch if server died early
mtr_report.pl:
Added option to disable test cases using <testcase>.disabled file
If --timer, only try to open file with time data if it exists
mtr_io.pl:
Remove starting/ending space reading server options from file
mysql-test/lib/mtr_io.pl:
Remove starting/ending space reading server options from file
mysql-test/lib/mtr_report.pl:
Added option to disable test cases using <testcase>.disabled file
If --timer, only try to open file with time data if it exists
mysql-test/lib/mtr_process.pl:
Find out if port is still in use, using simple TCP connect
Use non blocking waitpid() to catch terminations early
Make a special case spawning the 'mysqltest' application
Redo the fork() if it returns EAGAIN
Make sure to record if master or slave terminated
Improved debugging output
Improved code that remove PID files to avoid race
Abort if we can't stop all mysqld servers using our ports
Many improvements in killing mysqld servers
Let sleep_until_file_created() catch if server died early
mysql-test/mysql-test-run.pl:
Let --start-and-exit actually start a server
Added that test case names can be specified on the comman line
Added embedded server support
Added environment variables UMASK, UMASK_DIR
Added missing MASTER_MYSOCK1, MASTER_MYPORT1, USE_RUNNING_SERVER
Added missing CHARSETSDIR, MYSQL_FIX_SYSTEM_TABLES, MYSQL_CLIENT_TEST
Pass on return value from sleep_until_file_created(), to fail test
Fail test if early termination of mysqld servers
Create intial databases for the second master, and two additional slaves
2005-02-03 21:13:27 +01:00
|
|
|
}
|
2004-12-30 16:34:01 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
sub mtr_report_test_passed ($) {
|
|
|
|
my $tinfo= shift;
|
|
|
|
|
|
|
|
my $timer= "";
|
2005-05-15 17:22:54 +02:00
|
|
|
if ( $::opt_timer and -f "$::opt_vardir/log/timer" )
|
2005-03-21 16:01:39 +01:00
|
|
|
{
|
2005-05-15 17:22:54 +02:00
|
|
|
$timer= mtr_fromfile("$::opt_vardir/log/timer");
|
2006-10-04 12:47:32 +02:00
|
|
|
$::glob_tot_real_time += ($timer/1000);
|
2005-03-21 16:01:39 +01:00
|
|
|
$timer= sprintf "%12s", $timer;
|
|
|
|
}
|
2004-12-30 16:34:01 +01:00
|
|
|
$tinfo->{'result'}= 'MTR_RES_PASSED';
|
|
|
|
print "[ pass ] $timer\n";
|
|
|
|
}
|
|
|
|
|
|
|
|
sub mtr_report_test_failed ($) {
|
|
|
|
my $tinfo= shift;
|
|
|
|
|
|
|
|
$tinfo->{'result'}= 'MTR_RES_FAILED';
|
2006-10-17 10:31:06 +02:00
|
|
|
if ( defined $tinfo->{'timeout'} )
|
2005-08-18 00:16:44 +02:00
|
|
|
{
|
|
|
|
print "[ fail ] timeout\n";
|
2006-10-14 17:14:03 +02:00
|
|
|
return;
|
2005-08-18 00:16:44 +02:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
print "[ fail ]\n";
|
|
|
|
}
|
2004-12-30 16:34:01 +01:00
|
|
|
|
2006-10-06 17:15:26 +02:00
|
|
|
if ( $tinfo->{'comment'} )
|
|
|
|
{
|
|
|
|
print "\nERROR: $tinfo->{'comment'}\n";
|
|
|
|
}
|
|
|
|
elsif ( -f $::path_timefile )
|
mysql-test-run.pl:
Let --start-and-exit actually start a server
Added that test case names can be specified on the comman line
Added embedded server support
Added environment variables UMASK, UMASK_DIR
Added missing MASTER_MYSOCK1, MASTER_MYPORT1, USE_RUNNING_SERVER
Added missing CHARSETSDIR, MYSQL_FIX_SYSTEM_TABLES, MYSQL_CLIENT_TEST
Pass on return value from sleep_until_file_created(), to fail test
Fail test if early termination of mysqld servers
Create intial databases for the second master, and two additional slaves
mtr_process.pl:
Find out if port is still in use, using simple TCP connect
Use non blocking waitpid() to catch terminations early
Make a special case spawning the 'mysqltest' application
Redo the fork() if it returns EAGAIN
Make sure to record if master or slave terminated
Improved debugging output
Improved code that remove PID files to avoid race
Abort if we can't stop all mysqld servers using our ports
Many improvements in killing mysqld servers
Let sleep_until_file_created() catch if server died early
mtr_report.pl:
Added option to disable test cases using <testcase>.disabled file
If --timer, only try to open file with time data if it exists
mtr_io.pl:
Remove starting/ending space reading server options from file
mysql-test/lib/mtr_io.pl:
Remove starting/ending space reading server options from file
mysql-test/lib/mtr_report.pl:
Added option to disable test cases using <testcase>.disabled file
If --timer, only try to open file with time data if it exists
mysql-test/lib/mtr_process.pl:
Find out if port is still in use, using simple TCP connect
Use non blocking waitpid() to catch terminations early
Make a special case spawning the 'mysqltest' application
Redo the fork() if it returns EAGAIN
Make sure to record if master or slave terminated
Improved debugging output
Improved code that remove PID files to avoid race
Abort if we can't stop all mysqld servers using our ports
Many improvements in killing mysqld servers
Let sleep_until_file_created() catch if server died early
mysql-test/mysql-test-run.pl:
Let --start-and-exit actually start a server
Added that test case names can be specified on the comman line
Added embedded server support
Added environment variables UMASK, UMASK_DIR
Added missing MASTER_MYSOCK1, MASTER_MYPORT1, USE_RUNNING_SERVER
Added missing CHARSETSDIR, MYSQL_FIX_SYSTEM_TABLES, MYSQL_CLIENT_TEST
Pass on return value from sleep_until_file_created(), to fail test
Fail test if early termination of mysqld servers
Create intial databases for the second master, and two additional slaves
2005-02-03 21:13:27 +01:00
|
|
|
{
|
2005-09-14 13:12:30 +02:00
|
|
|
print "\nErrors are (from $::path_timefile) :\n";
|
mysql-test-run.pl:
Let --start-and-exit actually start a server
Added that test case names can be specified on the comman line
Added embedded server support
Added environment variables UMASK, UMASK_DIR
Added missing MASTER_MYSOCK1, MASTER_MYPORT1, USE_RUNNING_SERVER
Added missing CHARSETSDIR, MYSQL_FIX_SYSTEM_TABLES, MYSQL_CLIENT_TEST
Pass on return value from sleep_until_file_created(), to fail test
Fail test if early termination of mysqld servers
Create intial databases for the second master, and two additional slaves
mtr_process.pl:
Find out if port is still in use, using simple TCP connect
Use non blocking waitpid() to catch terminations early
Make a special case spawning the 'mysqltest' application
Redo the fork() if it returns EAGAIN
Make sure to record if master or slave terminated
Improved debugging output
Improved code that remove PID files to avoid race
Abort if we can't stop all mysqld servers using our ports
Many improvements in killing mysqld servers
Let sleep_until_file_created() catch if server died early
mtr_report.pl:
Added option to disable test cases using <testcase>.disabled file
If --timer, only try to open file with time data if it exists
mtr_io.pl:
Remove starting/ending space reading server options from file
mysql-test/lib/mtr_io.pl:
Remove starting/ending space reading server options from file
mysql-test/lib/mtr_report.pl:
Added option to disable test cases using <testcase>.disabled file
If --timer, only try to open file with time data if it exists
mysql-test/lib/mtr_process.pl:
Find out if port is still in use, using simple TCP connect
Use non blocking waitpid() to catch terminations early
Make a special case spawning the 'mysqltest' application
Redo the fork() if it returns EAGAIN
Make sure to record if master or slave terminated
Improved debugging output
Improved code that remove PID files to avoid race
Abort if we can't stop all mysqld servers using our ports
Many improvements in killing mysqld servers
Let sleep_until_file_created() catch if server died early
mysql-test/mysql-test-run.pl:
Let --start-and-exit actually start a server
Added that test case names can be specified on the comman line
Added embedded server support
Added environment variables UMASK, UMASK_DIR
Added missing MASTER_MYSOCK1, MASTER_MYPORT1, USE_RUNNING_SERVER
Added missing CHARSETSDIR, MYSQL_FIX_SYSTEM_TABLES, MYSQL_CLIENT_TEST
Pass on return value from sleep_until_file_created(), to fail test
Fail test if early termination of mysqld servers
Create intial databases for the second master, and two additional slaves
2005-02-03 21:13:27 +01:00
|
|
|
print mtr_fromfile($::path_timefile); # FIXME print_file() instead
|
|
|
|
print "\n(the last lines may be the most important ones)\n";
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2005-09-14 13:12:30 +02:00
|
|
|
print "\nUnexpected termination, probably when starting mysqld\n";
|
mysql-test-run.pl:
Let --start-and-exit actually start a server
Added that test case names can be specified on the comman line
Added embedded server support
Added environment variables UMASK, UMASK_DIR
Added missing MASTER_MYSOCK1, MASTER_MYPORT1, USE_RUNNING_SERVER
Added missing CHARSETSDIR, MYSQL_FIX_SYSTEM_TABLES, MYSQL_CLIENT_TEST
Pass on return value from sleep_until_file_created(), to fail test
Fail test if early termination of mysqld servers
Create intial databases for the second master, and two additional slaves
mtr_process.pl:
Find out if port is still in use, using simple TCP connect
Use non blocking waitpid() to catch terminations early
Make a special case spawning the 'mysqltest' application
Redo the fork() if it returns EAGAIN
Make sure to record if master or slave terminated
Improved debugging output
Improved code that remove PID files to avoid race
Abort if we can't stop all mysqld servers using our ports
Many improvements in killing mysqld servers
Let sleep_until_file_created() catch if server died early
mtr_report.pl:
Added option to disable test cases using <testcase>.disabled file
If --timer, only try to open file with time data if it exists
mtr_io.pl:
Remove starting/ending space reading server options from file
mysql-test/lib/mtr_io.pl:
Remove starting/ending space reading server options from file
mysql-test/lib/mtr_report.pl:
Added option to disable test cases using <testcase>.disabled file
If --timer, only try to open file with time data if it exists
mysql-test/lib/mtr_process.pl:
Find out if port is still in use, using simple TCP connect
Use non blocking waitpid() to catch terminations early
Make a special case spawning the 'mysqltest' application
Redo the fork() if it returns EAGAIN
Make sure to record if master or slave terminated
Improved debugging output
Improved code that remove PID files to avoid race
Abort if we can't stop all mysqld servers using our ports
Many improvements in killing mysqld servers
Let sleep_until_file_created() catch if server died early
mysql-test/mysql-test-run.pl:
Let --start-and-exit actually start a server
Added that test case names can be specified on the comman line
Added embedded server support
Added environment variables UMASK, UMASK_DIR
Added missing MASTER_MYSOCK1, MASTER_MYPORT1, USE_RUNNING_SERVER
Added missing CHARSETSDIR, MYSQL_FIX_SYSTEM_TABLES, MYSQL_CLIENT_TEST
Pass on return value from sleep_until_file_created(), to fail test
Fail test if early termination of mysqld servers
Create intial databases for the second master, and two additional slaves
2005-02-03 21:13:27 +01:00
|
|
|
}
|
2004-12-30 16:34:01 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
sub mtr_report_stats ($) {
|
|
|
|
my $tests= shift;
|
|
|
|
|
|
|
|
# ----------------------------------------------------------------------
|
|
|
|
# Find out how we where doing
|
|
|
|
# ----------------------------------------------------------------------
|
|
|
|
|
|
|
|
my $tot_skiped= 0;
|
|
|
|
my $tot_passed= 0;
|
|
|
|
my $tot_failed= 0;
|
|
|
|
my $tot_tests= 0;
|
2006-10-04 12:47:32 +02:00
|
|
|
my $tot_restarts= 0;
|
2006-10-08 17:48:01 +02:00
|
|
|
my $found_problems= 0; # Some warnings in the logfiles are errors...
|
2004-12-30 16:34:01 +01:00
|
|
|
|
|
|
|
foreach my $tinfo (@$tests)
|
|
|
|
{
|
|
|
|
if ( $tinfo->{'result'} eq 'MTR_RES_SKIPPED' )
|
|
|
|
{
|
|
|
|
$tot_skiped++;
|
|
|
|
}
|
|
|
|
elsif ( $tinfo->{'result'} eq 'MTR_RES_PASSED' )
|
|
|
|
{
|
|
|
|
$tot_tests++;
|
|
|
|
$tot_passed++;
|
|
|
|
}
|
|
|
|
elsif ( $tinfo->{'result'} eq 'MTR_RES_FAILED' )
|
|
|
|
{
|
|
|
|
$tot_tests++;
|
|
|
|
$tot_failed++;
|
|
|
|
}
|
2006-10-04 12:47:32 +02:00
|
|
|
if ( $tinfo->{'restarted'} )
|
|
|
|
{
|
|
|
|
$tot_restarts++;
|
|
|
|
}
|
2004-12-30 16:34:01 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
# ----------------------------------------------------------------------
|
|
|
|
# Print out a summary report to screen
|
|
|
|
# ----------------------------------------------------------------------
|
|
|
|
|
|
|
|
if ( ! $tot_failed )
|
|
|
|
{
|
|
|
|
print "All $tot_tests tests were successful.\n";
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
my $ratio= $tot_passed * 100 / $tot_tests;
|
2006-10-18 17:58:26 +02:00
|
|
|
print "Failed $tot_failed/$tot_tests tests, ";
|
|
|
|
printf("%.2f", $ratio);
|
|
|
|
print "\% were successful.\n\n";
|
2004-12-30 16:34:01 +01:00
|
|
|
print
|
|
|
|
"The log files in var/log may give you some hint\n",
|
2005-08-31 16:28:47 +02:00
|
|
|
"of what went wrong.\n",
|
2004-12-30 16:34:01 +01:00
|
|
|
"If you want to report this error, please read first ",
|
|
|
|
"the documentation at\n",
|
|
|
|
"http://www.mysql.com/doc/en/MySQL_test_suite.html\n";
|
|
|
|
}
|
2007-02-23 12:13:55 +01:00
|
|
|
if (!$::opt_extern)
|
|
|
|
{
|
2007-04-28 10:13:27 +02:00
|
|
|
print "The servers were restarted $tot_restarts times\n";
|
2007-02-23 12:13:55 +01:00
|
|
|
}
|
2006-10-04 12:47:32 +02:00
|
|
|
|
|
|
|
if ( $::opt_timer )
|
|
|
|
{
|
|
|
|
print
|
|
|
|
"Spent $::glob_tot_real_time seconds actually executing testcases\n"
|
|
|
|
}
|
2004-12-30 16:34:01 +01:00
|
|
|
|
|
|
|
# ----------------------------------------------------------------------
|
2006-10-04 12:47:32 +02:00
|
|
|
# If a debug run, there might be interesting information inside
|
|
|
|
# the "var/log/*.err" files. We save this info in "var/log/warnings"
|
2004-12-30 16:34:01 +01:00
|
|
|
# ----------------------------------------------------------------------
|
|
|
|
|
|
|
|
if ( ! $::glob_use_running_server )
|
|
|
|
{
|
2006-10-04 12:47:32 +02:00
|
|
|
# Save and report if there was any fatal warnings/errors in err logs
|
2004-12-30 16:34:01 +01:00
|
|
|
|
2006-10-04 12:47:32 +02:00
|
|
|
my $warnlog= "$::opt_vardir/log/warnings";
|
|
|
|
|
|
|
|
unless ( open(WARN, ">$warnlog") )
|
|
|
|
{
|
|
|
|
mtr_warning("can't write to the file \"$warnlog\": $!");
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
# We report different types of problems in order
|
2007-05-31 16:45:22 +02:00
|
|
|
foreach my $pattern ( "^Warning:",
|
|
|
|
"\\[Warning\\]",
|
|
|
|
"\\[ERROR\\]",
|
|
|
|
"^Error:", "^==.* at 0x",
|
|
|
|
"InnoDB: Warning",
|
|
|
|
"^safe_mutex:",
|
|
|
|
"missing DBUG_RETURN",
|
2006-10-04 12:47:32 +02:00
|
|
|
"mysqld: Warning",
|
2006-11-21 21:32:58 +01:00
|
|
|
"allocated at line",
|
2006-10-04 12:47:32 +02:00
|
|
|
"Attempting backtrace", "Assertion .* failed" )
|
|
|
|
{
|
|
|
|
foreach my $errlog ( sort glob("$::opt_vardir/log/*.err") )
|
|
|
|
{
|
|
|
|
unless ( open(ERR, $errlog) )
|
|
|
|
{
|
|
|
|
mtr_warning("can't read $errlog");
|
|
|
|
next;
|
|
|
|
}
|
2007-05-24 13:11:45 +02:00
|
|
|
my $leak_reports_expected= undef;
|
2006-10-04 12:47:32 +02:00
|
|
|
while ( <ERR> )
|
|
|
|
{
|
2007-05-24 13:11:45 +02:00
|
|
|
# There is a test case that purposely provokes a
|
|
|
|
# SAFEMALLOC leak report, even though there is no actual
|
|
|
|
# leak. We need to detect this, and ignore the warning in
|
|
|
|
# that case.
|
|
|
|
if (/Begin safemalloc memory dump:/) {
|
|
|
|
$leak_reports_expected= 1;
|
|
|
|
} elsif (/End safemalloc memory dump./) {
|
|
|
|
$leak_reports_expected= undef;
|
|
|
|
}
|
|
|
|
|
2006-10-04 12:47:32 +02:00
|
|
|
# Skip some non fatal warnings from the log files
|
2007-05-31 16:45:22 +02:00
|
|
|
if (
|
|
|
|
/\"SELECT UNIX_TIMESTAMP\(\)\" failed on master/ or
|
|
|
|
/Aborted connection/ or
|
|
|
|
/Client requested master to start replication from impossible position/ or
|
|
|
|
/Could not find first log file name in binary log/ or
|
|
|
|
/Enabling keys got errno/ or
|
|
|
|
/Error reading master configuration/ or
|
|
|
|
/Error reading packet/ or
|
|
|
|
/Event Scheduler/ or
|
|
|
|
/Failed to open log/ or
|
|
|
|
/Failed to open the existing master info file/ or
|
|
|
|
/Forcing shutdown of [0-9]* plugins/ or
|
|
|
|
/Got error [0-9]* when reading table/ or
|
|
|
|
/Incorrect definition of table/ or
|
|
|
|
/Incorrect information in file/ or
|
|
|
|
/InnoDB: Warning: we did not need to do crash recovery/ or
|
|
|
|
/Invalid \(old\?\) table or database name/ or
|
|
|
|
/Lock wait timeout exceeded/ or
|
|
|
|
/Log entry on master is longer than max_allowed_packet/ or
|
|
|
|
/unknown option '--loose-/ or
|
|
|
|
/unknown variable 'loose-/ or
|
|
|
|
/You have forced lower_case_table_names to 0 through a command-line option/ or
|
|
|
|
/Setting lower_case_table_names=2/ or
|
|
|
|
/NDB Binlog:/ or
|
|
|
|
/NDB: failed to setup table/ or
|
|
|
|
/NDB: only row based binary logging/ or
|
|
|
|
/Neither --relay-log nor --relay-log-index were used/ or
|
|
|
|
/Query partially completed/ or
|
|
|
|
/Slave I.O thread aborted while waiting for relay log/ or
|
|
|
|
/Slave SQL thread is stopped because UNTIL condition/ or
|
|
|
|
/Slave SQL thread retried transaction/ or
|
|
|
|
/Slave \(additional info\)/ or
|
|
|
|
/Slave: .*Duplicate column name/ or
|
|
|
|
/Slave: .*master may suffer from/ or
|
|
|
|
/Slave: According to the master's version/ or
|
|
|
|
/Slave: Column [0-9]* type mismatch/ or
|
|
|
|
/Slave: Error .* doesn't exist/ or
|
|
|
|
/Slave: Error .*Deadlock found/ or
|
|
|
|
/Slave: Error .*Unknown table/ or
|
|
|
|
/Slave: Error in Write_rows event: / or
|
|
|
|
/Slave: Field .* of table .* has no default value/ or
|
|
|
|
/Slave: Query caused different errors on master and slave/ or
|
|
|
|
/Slave: Table .* doesn't exist/ or
|
|
|
|
/Slave: Table width mismatch/ or
|
|
|
|
/Slave: The incident LOST_EVENTS occured on the master/ or
|
|
|
|
/Slave: Unknown error.* 1105/ or
|
|
|
|
/Slave: Can't drop database.* database doesn't exist/ or
|
|
|
|
/Sort aborted/ or
|
|
|
|
/Time-out in NDB/ or
|
|
|
|
/Warning:\s+One can only use the --user.*root/ or
|
|
|
|
/Warning:\s+Setting lower_case_table_names=2/ or
|
|
|
|
/Warning:\s+Table:.* on (delete|rename)/ or
|
|
|
|
/You have an error in your SQL syntax/ or
|
|
|
|
/deprecated/ or
|
|
|
|
/description of time zone/ or
|
|
|
|
/equal MySQL server ids/ or
|
|
|
|
/error .*connecting to master/ or
|
|
|
|
/error reading log entry/ or
|
|
|
|
/lower_case_table_names is set/ or
|
|
|
|
/skip-name-resolve mode/ or
|
|
|
|
/slave SQL thread aborted/ or
|
2007-06-06 03:49:24 +02:00
|
|
|
/Slave: .*Duplicate entry/ or
|
|
|
|
# Special case, made as specific as possible, for:
|
|
|
|
# Bug #28436: Incorrect position in SHOW BINLOG EVENTS causes
|
|
|
|
# server coredump
|
|
|
|
/\QError in Log_event::read_log_event(): 'Sanity check failed', data_len: 258, event_type: 49\E/
|
2007-05-31 16:45:22 +02:00
|
|
|
)
|
2006-10-04 12:47:32 +02:00
|
|
|
{
|
|
|
|
next; # Skip these lines
|
|
|
|
}
|
|
|
|
if ( /$pattern/ )
|
|
|
|
{
|
2007-05-24 13:11:45 +02:00
|
|
|
if ($leak_reports_expected) {
|
|
|
|
next;
|
|
|
|
}
|
2006-10-04 12:47:32 +02:00
|
|
|
$found_problems= 1;
|
|
|
|
print WARN $_;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2007-04-02 22:58:25 +02:00
|
|
|
|
2007-04-04 10:59:00 +02:00
|
|
|
if ( $::opt_check_testcases )
|
2007-04-02 22:58:25 +02:00
|
|
|
{
|
2007-04-04 10:59:00 +02:00
|
|
|
# Look for warnings produced by mysqltest in testname.warnings
|
|
|
|
foreach my $test_warning_file
|
|
|
|
( glob("$::glob_mysql_test_dir/r/*.warnings") )
|
|
|
|
{
|
|
|
|
$found_problems= 1;
|
|
|
|
print WARN "Check myqltest warnings in $test_warning_file\n";
|
|
|
|
}
|
2007-04-02 22:58:25 +02:00
|
|
|
}
|
|
|
|
|
2006-10-04 12:47:32 +02:00
|
|
|
if ( $found_problems )
|
|
|
|
{
|
|
|
|
mtr_warning("Got errors/warnings while running tests, please examine",
|
|
|
|
"\"$warnlog\" for details.");
|
|
|
|
}
|
|
|
|
}
|
2004-12-30 16:34:01 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
print "\n";
|
|
|
|
|
2006-10-08 17:48:01 +02:00
|
|
|
# Print a list of testcases that failed
|
2004-12-30 16:34:01 +01:00
|
|
|
if ( $tot_failed != 0 )
|
|
|
|
{
|
2005-08-31 16:28:47 +02:00
|
|
|
my $test_mode= join(" ", @::glob_test_mode) || "default";
|
|
|
|
print "mysql-test-run in $test_mode mode: *** Failing the test(s):";
|
2004-12-30 16:34:01 +01:00
|
|
|
|
|
|
|
foreach my $tinfo (@$tests)
|
|
|
|
{
|
|
|
|
if ( $tinfo->{'result'} eq 'MTR_RES_FAILED' )
|
|
|
|
{
|
|
|
|
print " $tinfo->{'name'}";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
print "\n";
|
2006-10-08 17:48:01 +02:00
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
# Print a list of check_testcases that failed(if any)
|
|
|
|
if ( $::opt_check_testcases )
|
|
|
|
{
|
|
|
|
my @check_testcases= ();
|
|
|
|
|
|
|
|
foreach my $tinfo (@$tests)
|
|
|
|
{
|
|
|
|
if ( defined $tinfo->{'check_testcase_failed'} )
|
|
|
|
{
|
|
|
|
push(@check_testcases, $tinfo->{'name'});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( @check_testcases )
|
|
|
|
{
|
|
|
|
print "Check of testcase failed for: ";
|
|
|
|
print join(" ", @check_testcases);
|
|
|
|
print "\n\n";
|
|
|
|
}
|
2006-10-04 12:47:32 +02:00
|
|
|
}
|
2006-10-08 17:48:01 +02:00
|
|
|
|
2006-10-04 12:47:32 +02:00
|
|
|
if ( $tot_failed != 0 || $found_problems)
|
|
|
|
{
|
2007-04-28 10:13:27 +02:00
|
|
|
mtr_error("there were failing test cases");
|
2004-12-30 16:34:01 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
##############################################################################
|
|
|
|
#
|
|
|
|
# Text formatting
|
|
|
|
#
|
|
|
|
##############################################################################
|
|
|
|
|
|
|
|
sub mtr_print_line () {
|
|
|
|
print '-' x 55, "\n";
|
|
|
|
}
|
|
|
|
|
2005-01-03 16:54:08 +01:00
|
|
|
sub mtr_print_thick_line () {
|
|
|
|
print '=' x 55, "\n";
|
|
|
|
}
|
|
|
|
|
2004-12-30 16:34:01 +01:00
|
|
|
sub mtr_print_header () {
|
|
|
|
print "\n";
|
|
|
|
if ( $::opt_timer )
|
|
|
|
{
|
2005-09-30 00:52:18 +02:00
|
|
|
print "TEST RESULT TIME (ms)\n";
|
2004-12-30 16:34:01 +01:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2005-09-30 00:52:18 +02:00
|
|
|
print "TEST RESULT\n";
|
2004-12-30 16:34:01 +01:00
|
|
|
}
|
|
|
|
mtr_print_line();
|
|
|
|
print "\n";
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
##############################################################################
|
|
|
|
#
|
|
|
|
# Misc
|
|
|
|
#
|
|
|
|
##############################################################################
|
|
|
|
|
|
|
|
sub mtr_report (@) {
|
|
|
|
print join(" ", @_),"\n";
|
|
|
|
}
|
|
|
|
|
|
|
|
sub mtr_warning (@) {
|
|
|
|
print STDERR "mysql-test-run: WARNING: ",join(" ", @_),"\n";
|
|
|
|
}
|
|
|
|
|
|
|
|
sub mtr_error (@) {
|
2005-06-05 20:10:47 +02:00
|
|
|
print STDERR "mysql-test-run: *** ERROR: ",join(" ", @_),"\n";
|
|
|
|
mtr_exit(1);
|
2004-12-30 16:34:01 +01:00
|
|
|
}
|
|
|
|
|
2005-09-14 13:55:53 +02:00
|
|
|
sub mtr_child_error (@) {
|
|
|
|
print STDERR "mysql-test-run: *** ERROR(child): ",join(" ", @_),"\n";
|
|
|
|
exit(1);
|
|
|
|
}
|
|
|
|
|
2004-12-30 16:34:01 +01:00
|
|
|
sub mtr_debug (@) {
|
|
|
|
if ( $::opt_script_debug )
|
|
|
|
{
|
2005-01-03 16:54:08 +01:00
|
|
|
print STDERR "####: ",join(" ", @_),"\n";
|
2004-12-30 16:34:01 +01:00
|
|
|
}
|
|
|
|
}
|
2006-10-04 12:47:32 +02:00
|
|
|
sub mtr_verbose (@) {
|
|
|
|
if ( $::opt_verbose )
|
|
|
|
{
|
|
|
|
print STDERR "> ",join(" ", @_),"\n";
|
|
|
|
}
|
|
|
|
}
|
2004-12-30 16:34:01 +01:00
|
|
|
|
|
|
|
1;
|