2004-12-30 16:34:01 +01:00
|
|
|
# -*- cperl -*-
|
|
|
|
|
|
|
|
# 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($);
|
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
|
|
|
sub mtr_report_test_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 (@);
|
|
|
|
sub mtr_debug (@);
|
|
|
|
|
|
|
|
|
|
|
|
##############################################################################
|
|
|
|
#
|
|
|
|
#
|
|
|
|
#
|
|
|
|
##############################################################################
|
|
|
|
|
|
|
|
# We can't use diff -u or diff -a as these are not portable
|
|
|
|
|
|
|
|
sub mtr_show_failed_diff ($) {
|
|
|
|
my $tname= shift;
|
|
|
|
|
|
|
|
my $reject_file= "r/$tname.reject";
|
|
|
|
my $result_file= "r/$tname.result";
|
|
|
|
my $eval_file= "r/$tname.eval";
|
|
|
|
|
|
|
|
if ( -f $eval_file )
|
|
|
|
{
|
|
|
|
$result_file= $eval_file;
|
|
|
|
}
|
|
|
|
elsif ( $::opt_result_ext and
|
|
|
|
( $::opt_record or -f "$result_file$::opt_result_ext" ))
|
|
|
|
{
|
|
|
|
# If we have an special externsion for result files we use it if we are
|
|
|
|
# recording or a result file with that extension exists.
|
|
|
|
$result_file= "$result_file$::opt_result_ext";
|
|
|
|
}
|
|
|
|
|
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";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
sub mtr_report_test_name ($) {
|
|
|
|
my $tinfo= shift;
|
|
|
|
|
|
|
|
printf "%-31s ", $tinfo->{'name'};
|
|
|
|
}
|
|
|
|
|
|
|
|
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";
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
print "[ skipped ]\n";
|
|
|
|
}
|
2004-12-30 16:34:01 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
sub mtr_report_test_passed ($) {
|
|
|
|
my $tinfo= shift;
|
|
|
|
|
|
|
|
my $timer= "";
|
|
|
|
# FIXME
|
|
|
|
# if ( $::opt_timer and -f "$::glob_mysql_test_dir/var/log/timer" )
|
|
|
|
# {
|
|
|
|
# $timer= `cat var/log/timer`;
|
|
|
|
# $timer= sprintf "%13s", $timer;
|
|
|
|
# }
|
|
|
|
$tinfo->{'result'}= 'MTR_RES_PASSED';
|
|
|
|
print "[ pass ] $timer\n";
|
|
|
|
}
|
|
|
|
|
|
|
|
sub mtr_report_test_failed ($) {
|
|
|
|
my $tinfo= shift;
|
|
|
|
|
|
|
|
$tinfo->{'result'}= 'MTR_RES_FAILED';
|
|
|
|
print "[ fail ]\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
|
|
|
# FIXME Instead of this test, and meaningless error message in 'else'
|
|
|
|
# we should write out into $::path_timefile when the error occurs.
|
|
|
|
if ( -f $::path_timefile )
|
|
|
|
{
|
|
|
|
print "Errors are (from $::path_timefile) :\n";
|
|
|
|
print mtr_fromfile($::path_timefile); # FIXME print_file() instead
|
|
|
|
print "\n(the last lines may be the most important ones)\n";
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
print "Unexpected termination, probably when starting mysqld\n";
|
|
|
|
}
|
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;
|
|
|
|
|
|
|
|
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++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
# ----------------------------------------------------------------------
|
|
|
|
# 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;
|
|
|
|
printf "Failed $tot_failed/$tot_tests tests, " .
|
|
|
|
"%.2f\% successful.\n\n", $ratio;
|
|
|
|
print
|
|
|
|
"The log files in var/log may give you some hint\n",
|
|
|
|
"of what when wrong.\n",
|
|
|
|
"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";
|
|
|
|
}
|
|
|
|
|
|
|
|
# ----------------------------------------------------------------------
|
|
|
|
# ----------------------------------------------------------------------
|
|
|
|
|
|
|
|
if ( ! $::glob_use_running_server )
|
|
|
|
{
|
|
|
|
|
|
|
|
# Report if there was any fatal warnings/errors in the log files
|
|
|
|
#
|
|
|
|
unlink("$::glob_mysql_test_dir/var/log/warnings");
|
|
|
|
unlink("$::glob_mysql_test_dir/var/log/warnings.tmp");
|
|
|
|
# Remove some non fatal warnings from the log files
|
|
|
|
|
|
|
|
# FIXME what is going on ????? ;-)
|
|
|
|
# sed -e 's!Warning: Table:.* on delete!!g' -e 's!Warning: Setting lower_case_table_names=2!!g' -e 's!Warning: One can only use the --user.*root!!g' \
|
|
|
|
# var/log/*.err \
|
|
|
|
# | sed -e 's!Warning: Table:.* on rename!!g' \
|
|
|
|
# > var/log/warnings.tmp;
|
|
|
|
#
|
|
|
|
# found_error=0;
|
|
|
|
# # Find errors
|
|
|
|
# for i in "^Warning:" "^Error:" "^==.* at 0x"
|
|
|
|
# do
|
|
|
|
# if ( $GREP "$i" var/log/warnings.tmp >> var/log/warnings )
|
|
|
|
# {
|
|
|
|
# found_error=1
|
|
|
|
# }
|
|
|
|
# done
|
|
|
|
# unlink("$::glob_mysql_test_dir/var/log/warnings.tmp");
|
|
|
|
# if ( $found_error= "1" )
|
|
|
|
# {
|
|
|
|
# print "WARNING: Got errors/warnings while running tests. Please examine\n"
|
|
|
|
# print "$::glob_mysql_test_dir/var/log/warnings for details.\n"
|
|
|
|
# }
|
|
|
|
# }
|
|
|
|
}
|
|
|
|
|
|
|
|
print "\n";
|
|
|
|
|
|
|
|
if ( $tot_failed != 0 )
|
|
|
|
{
|
|
|
|
print "mysql-test-run: *** Failing the test(s):";
|
|
|
|
|
|
|
|
foreach my $tinfo (@$tests)
|
|
|
|
{
|
|
|
|
if ( $tinfo->{'result'} eq 'MTR_RES_FAILED' )
|
|
|
|
{
|
|
|
|
print " $tinfo->{'name'}";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
print "\n";
|
|
|
|
mtr_error("there where failing test cases");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
##############################################################################
|
|
|
|
#
|
|
|
|
# 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 )
|
|
|
|
{
|
|
|
|
print "TEST RESULT TIME (ms)\n";
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
print "TEST RESULT\n";
|
|
|
|
}
|
|
|
|
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 (@) {
|
|
|
|
die "mysql-test-run: *** ERROR: ",join(" ", @_),"\n";
|
|
|
|
}
|
|
|
|
|
|
|
|
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
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
1;
|