2000-07-31 21:29:14 +02:00
#! /bin/sh
2000-12-07 15:54:59 +01:00
# mysql-test-run - originally written by Matt Wagner <matt@mysql.com>
# modified by Sasha Pachev <sasha@mysql.com>
2000-12-15 15:12:31 +01:00
# Sligtly updated by Monty
2000-12-28 08:26:37 +01:00
# Cleaned up again by Matt
2000-12-30 16:24:31 +01:00
# Fixed by Sergei
# :-)
2000-07-31 21:29:14 +02:00
#++
# Access Definitions
#--
DB = test
2000-10-11 15:50:13 +02:00
DBPASSWD =
2000-12-28 02:56:38 +01:00
VERBOSE = ""
2001-10-11 23:41:31 +02:00
USE_MANAGER = 0
2003-05-27 15:40:14 +02:00
MY_TZ = GMT-3
TZ = $MY_TZ ; export TZ # for UNIX_TIMESTAMP tests to work
2000-07-31 21:29:14 +02:00
2003-08-22 03:07:40 +02:00
# For query_cache test
ulimit -n 1024
2001-01-02 13:29:47 +01:00
#++
# Program Definitions
#--
2003-05-21 20:58:12 +02:00
LC_COLLATE = C
export LC_COLLATE
2002-12-05 02:40:33 +01:00
PATH = /bin:/usr/bin:/usr/local/bin:/usr/bsd:/usr/X11R6/bin:/usr/openwin/bin:/usr/bin/X11:$PATH
2002-02-09 21:58:53 +01:00
MASTER_40_ARGS = "--rpl-recovery-rank=1 --init-rpl-role=master"
2000-12-07 15:54:59 +01:00
2001-04-12 14:46:50 +02:00
# Standard functions
which ( )
{
2001-04-14 15:35:42 +02:00
IFS = " ${ IFS = } " ; save_ifs = " $IFS " ; IFS = ':'
2001-04-12 14:46:50 +02:00
for file
do
2001-04-14 15:35:42 +02:00
for dir in $PATH
2001-04-12 14:46:50 +02:00
do
2001-12-18 04:34:00 +01:00
if test -f $dir /$file
2001-04-12 14:46:50 +02:00
then
echo " $dir / $file "
continue 2
fi
done
2002-09-05 15:17:08 +02:00
echo " Fatal error: Cannot find program $file in $PATH " 1>& 2
2001-04-12 14:46:50 +02:00
exit 1
done
2001-04-14 15:35:42 +02:00
IFS = " $save_ifs "
2002-09-05 15:17:08 +02:00
exit 0
2001-04-12 14:46:50 +02:00
}
2001-12-10 17:16:51 +01:00
sleep_until_file_deleted ( )
{
2002-12-05 02:40:33 +01:00
pid = $1 ;
file = $2
2001-12-13 01:31:19 +01:00
loop = $SLEEP_TIME_FOR_DELETE
2001-12-10 17:16:51 +01:00
while ( test $loop -gt 0)
do
2001-12-18 04:34:00 +01:00
if [ ! -r $file ]
2001-12-10 17:16:51 +01:00
then
2002-12-05 02:40:33 +01:00
if test $pid != "0"
then
wait_for_pid $pid
fi
2001-12-10 17:16:51 +01:00
return
fi
2002-10-29 20:59:03 +01:00
sleep 1
2001-12-10 17:16:51 +01:00
loop = ` expr $loop - 1`
done
}
2002-02-09 21:58:53 +01:00
sleep_until_file_created ( )
2001-12-10 17:16:51 +01:00
{
file = $1
2001-12-13 01:31:19 +01:00
loop = $2
org_time = $2
2001-12-10 17:16:51 +01:00
while ( test $loop -gt 0)
do
2001-12-18 04:34:00 +01:00
if [ -r $file ]
2001-12-10 17:16:51 +01:00
then
2002-09-05 15:17:08 +02:00
return 0
2001-12-10 17:16:51 +01:00
fi
2001-12-17 14:00:14 +01:00
sleep 1
2001-12-10 17:16:51 +01:00
loop = ` expr $loop - 1`
done
2001-12-13 01:31:19 +01:00
echo " ERROR: $file was not created in $org_time seconds; Aborting "
2001-12-10 17:16:51 +01:00
exit 1;
}
2002-12-05 02:40:33 +01:00
# For the future
wait_for_pid( )
{
pid = $1
2003-01-07 15:53:10 +01:00
#$WAIT_PID pid $SLEEP_TIME_FOR_DELETE
2002-12-05 02:40:33 +01:00
}
2001-01-02 13:29:47 +01:00
# No paths below as we can't be sure where the program is!
2002-03-05 14:46:30 +01:00
SED = sed
2002-09-05 15:17:08 +02:00
BASENAME = ` which basename`
if test $? != 0; then exit 1; fi
2002-03-05 14:46:30 +01:00
DIFF = ` which diff | $SED q`
2002-09-05 15:17:08 +02:00
if test $? != 0; then exit 1; fi
2001-01-02 13:29:47 +01:00
CAT = cat
CUT = cut
2001-11-28 01:55:52 +01:00
HEAD = head
2001-01-02 13:29:47 +01:00
TAIL = tail
ECHO = echo # use internal echo if possible
EXPR = expr # use internal if possible
FIND = find
2003-01-28 07:38:28 +01:00
GREP = grep
2002-09-05 15:17:08 +02:00
if test $? != 0; then exit 1; fi
2001-01-02 13:29:47 +01:00
PRINTF = printf
RM = rm
2002-09-05 15:17:08 +02:00
if test $? != 0; then exit 1; fi
2001-01-02 13:29:47 +01:00
TR = tr
2002-09-05 15:17:08 +02:00
XARGS = ` which xargs`
if test $? != 0; then exit 1; fi
2003-05-14 21:12:55 +02:00
SORT = sort
2001-01-02 13:29:47 +01:00
# Are we using a source or a binary distribution?
testdir = @testdir@
if [ -d bin/mysqld ] && [ -d mysql-test ] ; then
2000-12-07 15:54:59 +01:00
cd mysql-test
else
2001-01-02 13:29:47 +01:00
if [ -d $testdir /mysql-test ] ; then
cd $testdir
2000-12-07 15:54:59 +01:00
fi
2001-01-02 13:29:47 +01:00
fi
if [ ! -f ./mysql-test-run ] ; then
$ECHO "Can't find the location for the mysql-test-run script"
$ECHO "Go to to the mysql-test directory and execute the script as follows:"
$ECHO "./mysql-test-run."
2000-12-15 15:12:31 +01:00
exit 1
2000-12-07 15:54:59 +01:00
fi
2000-10-12 01:38:30 +02:00
2000-07-31 21:29:14 +02:00
#++
# Misc. Definitions
#--
2000-12-07 15:54:59 +01:00
2001-01-02 13:29:47 +01:00
if [ -d ../sql ] ; then
SOURCE_DIST = 1
else
BINARY_DIST = 1
fi
2001-01-04 01:56:38 +01:00
2001-12-10 17:16:51 +01:00
#BASEDIR is always one above mysql-test directory
2000-07-31 21:29:14 +02:00
CWD = ` pwd `
cd ..
BASEDIR = ` pwd `
cd $CWD
2000-12-07 15:54:59 +01:00
MYSQL_TEST_DIR = $BASEDIR /mysql-test
2001-01-24 20:47:09 +01:00
export MYSQL_TEST_DIR
2000-12-12 16:24:50 +01:00
STD_DATA = $MYSQL_TEST_DIR /std_data
2001-01-22 14:33:34 +01:00
hostname = ` hostname` # Installed in the mysql privilege table
2001-09-28 07:05:54 +02:00
2001-12-10 17:16:51 +01:00
MANAGER_QUIET_OPT = "-q"
2001-06-05 02:38:10 +02:00
TESTDIR = " $MYSQL_TEST_DIR /t "
2000-10-10 10:42:07 +02:00
TESTSUFFIX = test
2001-06-05 02:38:10 +02:00
TOT_SKIP = 0
2000-07-31 21:29:14 +02:00
TOT_PASS = 0
TOT_FAIL = 0
TOT_TEST = 0
2000-10-11 15:50:13 +02:00
USERT = 0
SYST = 0
REALT = 0
2002-12-05 02:40:33 +01:00
FAST_START = ""
2000-12-28 18:25:41 +01:00
MYSQL_TMP_DIR = $MYSQL_TEST_DIR /var/tmp
2001-08-07 00:47:48 +02:00
SLAVE_LOAD_TMPDIR = ../../var/tmp #needs to be same length to test logging
2000-12-15 15:12:31 +01:00
RES_SPACE = " "
2000-10-12 01:01:58 +02:00
MYSQLD_SRC_DIRS = " strings mysys include extra regex isam merge myisam \
myisammrg heap sql"
2002-01-22 23:05:11 +01:00
MY_LOG_DIR = " $MYSQL_TEST_DIR /var/log "
2001-10-03 15:27:20 +02:00
#
# Set LD_LIBRARY_PATH if we are using shared libraries
#
2001-11-28 01:55:52 +01:00
LD_LIBRARY_PATH = " $BASEDIR /lib: $BASEDIR /libmysql/.libs: $LD_LIBRARY_PATH "
2001-10-03 15:27:20 +02:00
export LD_LIBRARY_PATH
2000-11-18 07:35:40 +01:00
2000-12-13 17:58:26 +01:00
MASTER_RUNNING = 0
2001-01-04 01:56:38 +01:00
MASTER_MYPORT = 9306
2000-12-13 17:58:26 +01:00
SLAVE_RUNNING = 0
2001-01-04 01:56:38 +01:00
SLAVE_MYPORT = 9307
2002-03-02 05:14:13 +01:00
MYSQL_MANAGER_PORT = 9305 # needs to be out of the way of slaves
MYSQL_MANAGER_PW_FILE = $MYSQL_TEST_DIR /var/tmp/manager.pwd
MYSQL_MANAGER_LOG = $MYSQL_TEST_DIR /var/log/manager.log
MYSQL_MANAGER_USER = root
2001-01-05 12:13:15 +01:00
NO_SLAVE = 0
2002-02-15 22:02:48 +01:00
USER_TEST =
2001-01-04 01:56:38 +01:00
2001-01-16 11:38:58 +01:00
EXTRA_MASTER_OPT = ""
2001-01-04 01:56:38 +01:00
EXTRA_MYSQL_TEST_OPT = ""
USE_RUNNING_SERVER = 1
DO_GCOV = ""
DO_GDB = ""
2001-12-17 02:02:58 +01:00
MANUAL_GDB = ""
2001-01-04 01:56:38 +01:00
DO_DDD = ""
2001-06-09 03:24:41 +02:00
DO_CLIENT_GDB = ""
2001-12-17 23:23:56 +01:00
SLEEP_TIME_AFTER_RESTART = 1
2001-12-13 01:31:19 +01:00
SLEEP_TIME_FOR_DELETE = 10
2001-12-17 23:23:56 +01:00
SLEEP_TIME_FOR_FIRST_MASTER = 400 # Enough time to create innodb tables
2001-12-13 01:31:19 +01:00
SLEEP_TIME_FOR_SECOND_MASTER = 30
2001-12-17 23:23:56 +01:00
SLEEP_TIME_FOR_FIRST_SLAVE = 400
2001-12-13 01:31:19 +01:00
SLEEP_TIME_FOR_SECOND_SLAVE = 30
2001-09-14 01:54:33 +02:00
CHARACTER_SET = latin1
2001-01-17 02:15:20 +01:00
DBUSER = ""
2002-01-22 23:05:11 +01:00
START_WAIT_TIMEOUT = 10
STOP_WAIT_TIMEOUT = 10
2003-03-11 10:41:53 +01:00
MYSQL_TEST_SSL_OPTS = ""
2001-01-04 01:56:38 +01:00
while test $# -gt 0; do
case " $1 " in
2001-01-17 02:15:20 +01:00
--user= *) DBUSER = ` $ECHO " $1 " | $SED -e "s;--user=;;" ` ; ;
--force) FORCE = 1 ; ;
2001-09-28 07:05:54 +02:00
--verbose-manager) MANAGER_QUIET_OPT = "" ; ;
2002-02-09 21:58:53 +01:00
--old-master) MASTER_40_ARGS = "" ; ;
--master-binary= *)
MASTER_MYSQLD = ` $ECHO " $1 " | $SED -e "s;--master-binary=;;" ` ; ;
--slave-binary= *)
SLAVE_MYSQLD = ` $ECHO " $1 " | $SED -e "s;--slave-binary=;;" ` ; ;
2001-01-04 01:56:38 +01:00
--local) USE_RUNNING_SERVER = "" ; ;
2002-12-06 21:49:16 +01:00
--extern) USE_RUNNING_SERVER = "1" ; ;
2001-01-04 01:56:38 +01:00
--tmpdir= *) MYSQL_TMP_DIR = ` $ECHO " $1 " | $SED -e "s;--tmpdir=;;" ` ; ;
2001-11-18 01:23:46 +01:00
--local-master)
MASTER_MYPORT = 3306;
EXTRA_MYSQL_TEST_OPT = " $EXTRA_MYSQL_TEST_OPT --host=127.0.0.1 \
--port= $MYSQL_MYPORT "
LOCAL_MASTER = 1 ; ;
2001-01-04 01:56:38 +01:00
--master_port= *) MASTER_MYPORT = ` $ECHO " $1 " | $SED -e "s;--master_port=;;" ` ; ;
--slave_port= *) SLAVE_MYPORT = ` $ECHO " $1 " | $SED -e "s;--slave_port=;;" ` ; ;
2001-10-08 06:24:04 +02:00
--manager-port= *) MYSQL_MANAGER_PORT = ` $ECHO " $1 " | $SED -e "s;--manager_port=;;" ` ; ;
2001-08-31 19:22:18 +02:00
--with-openssl)
EXTRA_MASTER_MYSQLD_OPT = " $EXTRA_MASTER_MYSQLD_OPT \
2001-08-31 23:38:50 +02:00
--ssl-ca= $BASEDIR /SSL/cacert.pem \
--ssl-cert= $BASEDIR /SSL/server-cert.pem \
--ssl-key= $BASEDIR /SSL/server-key.pem"
2001-08-31 19:22:18 +02:00
EXTRA_SLAVE_MYSQLD_OPT = " $EXTRA_SLAVE_MYSQLD_OPT \
2001-08-31 23:38:50 +02:00
--ssl-ca= $BASEDIR /SSL/cacert.pem \
--ssl-cert= $BASEDIR /SSL/server-cert.pem \
2003-03-11 10:41:53 +01:00
--ssl-key= $BASEDIR /SSL/server-key.pem"
MYSQL_TEST_SSL_OPTS = " --ssl-ca= $BASEDIR /SSL/cacert.pem \
--ssl-cert= $BASEDIR /SSL/client-cert.pem \
--ssl-key= $BASEDIR /SSL/client-key.pem" ;;
2001-10-11 23:41:31 +02:00
--no-manager | --skip-manager) USE_MANAGER = 0 ; ;
2001-11-08 00:17:40 +01:00
--manager)
USE_MANAGER = 1
USE_RUNNING_SERVER =
; ;
2001-11-11 06:24:12 +01:00
--start-and-exit)
START_AND_EXIT = 1
2001-12-10 17:16:51 +01:00
; ;
2001-01-05 12:13:15 +01:00
--skip-rpl) NO_SLAVE = 1 ; ;
2001-06-20 00:08:19 +02:00
--skip-test= *) SKIP_TEST = ` $ECHO " $1 " | $SED -e "s;--skip-test=;;" ` ; ;
2001-06-27 01:02:33 +02:00
--do-test= *) DO_TEST = ` $ECHO " $1 " | $SED -e "s;--do-test=;;" ` ; ;
2002-08-08 02:12:02 +02:00
--warnings | --log-warnings)
EXTRA_MASTER_MYSQLD_OPT = " $EXTRA_MASTER_MYSQLD_OPT --log-warnings "
EXTRA_SLAVE_MYSQLD_OPT = " $EXTRA_SLAVE_MYSQLD_OPT --log-warnings "
; ;
2001-09-28 07:05:54 +02:00
--wait-timeout= *)
START_WAIT_TIMEOUT = ` $ECHO " $1 " | $SED -e "s;--wait-timeout=;;" `
STOP_WAIT_TIMEOUT = $START_WAIT_TIMEOUT ; ;
2001-01-04 01:56:38 +01:00
--record)
RECORD = 1;
EXTRA_MYSQL_TEST_OPT = " $EXTRA_MYSQL_TEST_OPT $1 " ; ;
2001-04-13 20:51:27 +02:00
--bench)
DO_BENCH = 1
NO_SLAVE = 1
2001-12-10 17:16:51 +01:00
; ;
2001-06-24 21:11:00 +02:00
--big*) # Actually --big-test
EXTRA_MYSQL_TEST_OPT = " $EXTRA_MYSQL_TEST_OPT $1 " ; ;
2001-10-04 01:44:18 +02:00
--compress)
EXTRA_MYSQL_TEST_OPT = " $EXTRA_MYSQL_TEST_OPT $1 " ; ;
2001-01-04 01:56:38 +01:00
--sleep= *)
EXTRA_MYSQL_TEST_OPT = " $EXTRA_MYSQL_TEST_OPT $1 "
2001-12-19 14:45:04 +01:00
SLEEP_TIME_AFTER_RESTART = ` $ECHO " $1 " | $SED -e "s;--sleep=;;" `
2001-01-04 01:56:38 +01:00
; ;
2002-02-15 22:02:48 +01:00
--user-test= *)
USER_TEST = ` $ECHO " $1 " | $SED -e "s;--user-test=;;" `
; ;
2001-06-06 23:10:59 +02:00
--mysqld= *)
2001-07-27 20:39:48 +02:00
TMP = ` $ECHO " $1 " | $SED -e "s;--mysqld=;;" `
2001-09-03 04:16:15 +02:00
EXTRA_MASTER_MYSQLD_OPT = " $EXTRA_MASTER_MYSQLD_OPT $TMP "
2001-06-12 17:00:36 +02:00
EXTRA_SLAVE_MYSQLD_OPT = " $EXTRA_SLAVE_MYSQLD_OPT $TMP "
2001-06-06 23:10:59 +02:00
; ;
2001-01-04 01:56:38 +01:00
--gcov )
if [ x$BINARY_DIST = x1 ] ; then
$ECHO "Cannot do coverage test without the source - please use source dist"
exit 1
fi
DO_GCOV = 1
2002-09-23 21:30:08 +02:00
GCOV = ` which gcov`
2001-01-04 01:56:38 +01:00
; ;
2001-04-10 02:25:06 +02:00
--gprof )
DO_GPROF = 1
2001-12-10 17:16:51 +01:00
; ;
2001-01-04 01:56:38 +01:00
--gdb )
2001-09-28 07:05:54 +02:00
START_WAIT_TIMEOUT = 300
STOP_WAIT_TIMEOUT = 300
2001-01-04 01:56:38 +01:00
if [ x$BINARY_DIST = x1 ] ; then
2001-06-09 03:24:41 +02:00
$ECHO "Note: you will get more meaningful output on a source distribution compiled with debugging option when running tests with --gdb option"
2001-01-04 01:56:38 +01:00
fi
DO_GDB = 1
2001-12-13 01:31:19 +01:00
# This needs to be checked properly
# USE_MANAGER=1
2001-06-06 23:10:59 +02:00
USE_RUNNING_SERVER = ""
2001-01-04 01:56:38 +01:00
; ;
2001-06-09 03:24:41 +02:00
--client-gdb )
if [ x$BINARY_DIST = x1 ] ; then
$ECHO "Note: you will get more meaningful output on a source distribution compiled with debugging option when running tests with --client-gdb option"
fi
DO_CLIENT_GDB = 1
2003-06-10 20:42:29 +02:00
EXTRA_MASTER_MYSQLD_OPT = " $EXTRA_MASTER_MYSQLD_OPT --gdb "
EXTRA_SLAVE_MYSQLD_OPT = " $EXTRA_SLAVE_MYSQLD_OPT --gdb "
2001-06-09 03:24:41 +02:00
; ;
2001-12-17 02:02:58 +01:00
--manual-gdb )
DO_GDB = 1
MANUAL_GDB = 1
USE_RUNNING_SERVER = ""
2003-06-10 20:42:29 +02:00
EXTRA_MASTER_MYSQLD_OPT = " $EXTRA_MASTER_MYSQLD_OPT --gdb "
EXTRA_SLAVE_MYSQLD_OPT = " $EXTRA_SLAVE_MYSQLD_OPT --gdb "
2001-12-17 02:02:58 +01:00
; ;
2001-01-04 01:56:38 +01:00
--ddd )
if [ x$BINARY_DIST = x1 ] ; then
2001-06-09 03:24:41 +02:00
$ECHO "Note: you will get more meaningful output on a source distribution compiled with debugging option when running tests with --ddd option"
2001-01-04 01:56:38 +01:00
fi
DO_DDD = 1
2001-06-06 23:10:59 +02:00
USE_RUNNING_SERVER = ""
2003-06-10 20:42:29 +02:00
EXTRA_MASTER_MYSQLD_OPT = " $EXTRA_MASTER_MYSQLD_OPT --gdb "
EXTRA_SLAVE_MYSQLD_OPT = " $EXTRA_SLAVE_MYSQLD_OPT --gdb "
2001-01-04 01:56:38 +01:00
; ;
2002-10-29 20:59:03 +01:00
--valgrind)
2003-10-30 16:12:21 +01:00
VALGRIND = ` which valgrind` # this will print an error if not found
# Give good warning to the user and stop
if [ -z " $VALGRIND " ] ; then
$ECHO "You need to have the 'valgrind' program in your PATH to run mysql-test-run with option --valgrind. Valgrind's home page is http://developer.kde.org/~sewardj ."
exit 1
fi
VALGRIND = " $VALGRIND --alignment=8 --leak-check=yes --num-callers=16 "
2003-10-02 23:40:27 +02:00
EXTRA_MASTER_MYSQLD_OPT = " $EXTRA_MASTER_MYSQLD_OPT --skip-safemalloc --skip-bdb "
EXTRA_SLAVE_MYSQLD_OPT = " $EXTRA_SLAVE_MYSQLD_OPT --skip-safemalloc --skip-bdb "
2003-01-09 10:11:06 +01:00
SLEEP_TIME_AFTER_RESTART = 10
2002-10-29 20:59:03 +01:00
SLEEP_TIME_FOR_DELETE = 120
2003-02-17 01:14:37 +01:00
USE_RUNNING_SERVER = ""
2002-10-29 20:59:03 +01:00
; ;
--valgrind-options= *)
TMP = ` $ECHO " $1 " | $SED -e "s;--valgrind-options=;;" `
VALGRIND = " $VALGRIND $TMP "
; ;
2001-03-24 03:59:30 +01:00
--skip-*)
EXTRA_MASTER_MYSQLD_OPT = " $EXTRA_MASTER_MYSQLD_OPT $1 "
EXTRA_SLAVE_MYSQLD_OPT = " $EXTRA_SLAVE_MYSQLD_OPT $1 "
; ;
2001-10-12 17:37:25 +02:00
--strace-client )
STRACE_CLIENT = 1
2001-12-10 17:16:51 +01:00
; ;
2001-01-04 01:56:38 +01:00
--debug)
2001-03-24 03:59:30 +01:00
EXTRA_MASTER_MYSQLD_OPT = " $EXTRA_MASTER_MYSQLD_OPT \
2003-01-07 15:53:10 +01:00
--debug= d:t:i:A,$MYSQL_TEST_DIR /var/log/master.trace"
2001-03-24 03:59:30 +01:00
EXTRA_SLAVE_MYSQLD_OPT = " $EXTRA_SLAVE_MYSQLD_OPT \
2003-01-07 15:53:10 +01:00
--debug= d:t:i:A,$MYSQL_TEST_DIR /var/log/slave.trace"
2003-03-04 11:22:35 +01:00
EXTRA_MYSQL_TEST_OPT = " $EXTRA_MYSQL_TEST_OPT \
--debug= d:t:A,$MYSQL_TEST_DIR /var/log/mysqltest.trace"
2001-01-04 01:56:38 +01:00
; ;
2002-12-05 02:40:33 +01:00
--fast)
FAST_START = 1
; ;
2001-01-04 01:56:38 +01:00
-- ) shift; break ; ;
--* ) $ECHO " Unrecognized option: $1 " ; exit 1 ; ;
* ) break ; ;
esac
shift
done
2000-12-13 17:58:26 +01:00
2000-07-31 21:29:14 +02:00
#++
# mysqld Environment Parameters
#--
2001-01-04 01:56:38 +01:00
2000-12-28 18:25:41 +01:00
MYRUN_DIR = $MYSQL_TEST_DIR /var/run
2001-11-08 00:17:40 +01:00
MANAGER_PID_FILE = " $MYRUN_DIR /manager.pid "
2001-04-21 16:12:59 +02:00
MASTER_MYDDIR = " $MYSQL_TEST_DIR /var/master-data "
2001-10-04 20:52:41 +02:00
MASTER_MYSOCK = " $MYSQL_TMP_DIR /master.sock "
2001-12-18 04:34:00 +01:00
MASTER_MYPID = " $MYRUN_DIR /master.pid "
MASTER_MYLOG = " $MYSQL_TEST_DIR /var/log/master.log "
MASTER_MYERR = " $MYSQL_TEST_DIR /var/log/master.err "
2000-12-07 15:54:59 +01:00
SLAVE_MYDDIR = " $MYSQL_TEST_DIR /var/slave-data "
2001-10-04 20:52:41 +02:00
SLAVE_MYSOCK = " $MYSQL_TMP_DIR /slave.sock "
2001-12-18 04:34:00 +01:00
SLAVE_MYPID = " $MYRUN_DIR /slave.pid "
SLAVE_MYLOG = " $MYSQL_TEST_DIR /var/log/slave.log "
SLAVE_MYERR = " $MYSQL_TEST_DIR /var/log/slave.err "
2000-12-07 15:54:59 +01:00
2002-08-22 15:50:58 +02:00
CURRENT_TEST = " $MYSQL_TEST_DIR /var/log/current_test "
2001-01-07 23:04:30 +01:00
SMALL_SERVER = "-O key_buffer_size=1M -O sort_buffer=256K -O max_heap_table_size=1M"
2001-04-18 07:06:00 +02:00
export MASTER_MYPORT
export SLAVE_MYPORT
2000-12-07 15:54:59 +01:00
if [ x$SOURCE_DIST = x1 ] ; then
MY_BASEDIR = $MYSQL_TEST_DIR
else
MY_BASEDIR = $BASEDIR
2001-12-10 17:16:51 +01:00
fi
2000-07-31 21:29:14 +02:00
2000-12-28 18:25:41 +01:00
# Create the directories
# This should be fixed to be not be dependent on the contence of MYSQL_TMP_DIR
# or MYRUN_DIR
# (mkdir -p is not portable)
[ -d $MYSQL_TEST_DIR /var ] || mkdir $MYSQL_TEST_DIR /var
[ -d $MYSQL_TEST_DIR /var/tmp ] || mkdir $MYSQL_TEST_DIR /var/tmp
[ -d $MYSQL_TEST_DIR /var/run ] || mkdir $MYSQL_TEST_DIR /var/run
2002-10-29 21:56:30 +01:00
[ -d $MYSQL_TEST_DIR /var/log ] || mkdir $MYSQL_TEST_DIR /var/log
2000-12-28 18:25:41 +01:00
2001-12-23 01:43:46 +01:00
if test ${ COLUMNS :- 0 } -lt 80 ; then COLUMNS = 80 ; fi
2000-12-20 13:39:27 +01:00
E = ` $EXPR $COLUMNS - 8`
2003-05-13 10:39:07 +02:00
DASH72 = ` $ECHO '------------------------------------------' | $CUT -c 1-$E `
2000-12-20 13:39:27 +01:00
2000-12-07 15:54:59 +01:00
# on source dist, we pick up freshly build executables
# on binary, use what is installed
if [ x$SOURCE_DIST = x1 ] ; then
2002-10-29 20:59:03 +01:00
MYSQLD = " $VALGRIND $BASEDIR /sql/mysqld "
2001-09-21 02:38:35 +02:00
if [ -f " $BASEDIR /client/.libs/lt-mysqltest " ] ; then
2001-07-13 13:58:25 +02:00
MYSQL_TEST = " $BASEDIR /client/.libs/lt-mysqltest "
2001-11-28 01:55:52 +01:00
elif [ -f " $BASEDIR /client/.libs/mysqltest " ] ; then
MYSQL_TEST = " $BASEDIR /client/.libs/mysqltest "
2001-07-13 13:58:25 +02:00
else
MYSQL_TEST = " $BASEDIR /client/mysqltest "
fi
2003-09-24 13:13:47 +02:00
if [ -f " $BASEDIR /client/.libs/mysqldump " ] ; then
2003-10-07 14:44:31 +02:00
MYSQL_DUMP = " $BASEDIR /client/.libs/mysqldump "
2003-09-24 13:13:47 +02:00
else
2003-10-07 14:44:31 +02:00
MYSQL_DUMP = " $BASEDIR /client/mysqldump "
2003-09-24 13:13:47 +02:00
fi
2003-09-24 13:46:19 +02:00
if [ -f " $BASEDIR /client/.libs/mysqlbinlog " ] ; then
2003-10-07 14:44:31 +02:00
MYSQL_BINLOG = " $BASEDIR /client/.libs/mysqlbinlog "
2003-09-24 13:46:19 +02:00
else
2003-10-07 14:44:31 +02:00
MYSQL_BINLOG = " $BASEDIR /client/mysqlbinlog "
2003-09-24 13:46:19 +02:00
fi
2001-10-12 17:37:25 +02:00
if [ -n " $STRACE_CLIENT " ] ; then
MYSQL_TEST = " strace -o $MYSQL_TEST_DIR /var/log/mysqltest.strace $MYSQL_TEST "
fi
2001-12-10 17:16:51 +01:00
2000-12-07 15:54:59 +01:00
MYSQLADMIN = " $BASEDIR /client/mysqladmin "
2003-01-07 15:53:10 +01:00
WAIT_PID = " $BASEDIR /extra/mysql_waitpid "
2001-09-23 05:47:57 +02:00
MYSQL_MANAGER_CLIENT = " $BASEDIR /client/mysqlmanagerc "
MYSQL_MANAGER = " $BASEDIR /tools/mysqlmanager "
MYSQL_MANAGER_PWGEN = " $BASEDIR /client/mysqlmanager-pwgen "
2001-01-17 13:47:33 +01:00
MYSQL = " $BASEDIR /client/mysql "
2001-06-25 10:35:22 +02:00
LANGUAGE = " $BASEDIR /sql/share/english/ "
2001-09-07 00:05:04 +02:00
CHARSETSDIR = " $BASEDIR /sql/share/charsets "
2000-12-07 15:54:59 +01:00
INSTALL_DB = "./install_test_db"
else
2002-08-21 21:04:22 +02:00
if test -x " $BASEDIR /libexec/mysqld "
then
2002-10-29 20:59:03 +01:00
MYSQLD = " $VALGRIND $BASEDIR /libexec/mysqld "
2002-08-21 21:04:22 +02:00
else
2002-10-29 20:59:03 +01:00
MYSQLD = " $VALGRIND $BASEDIR /bin/mysqld "
2002-08-21 21:04:22 +02:00
fi
2000-12-07 15:54:59 +01:00
MYSQL_TEST = " $BASEDIR /bin/mysqltest "
2003-10-07 14:44:31 +02:00
MYSQL_DUMP = " $BASEDIR /bin/mysqldump "
MYSQL_BINLOG = " $BASEDIR /bin/mysqlbinlog "
2000-12-07 15:54:59 +01:00
MYSQLADMIN = " $BASEDIR /bin/mysqladmin "
2003-01-07 15:53:10 +01:00
WAIT_PID = " $BASEDIR /bin/mysql_waitpid "
2001-09-23 05:47:57 +02:00
MYSQL_MANAGER = " $BASEDIR /bin/mysqlmanager "
MYSQL_MANAGER_CLIENT = " $BASEDIR /bin/mysqlmanagerc "
MYSQL_MANAGER_PWGEN = " $BASEDIR /bin/mysqlmanager-pwgen "
2001-01-17 13:47:33 +01:00
MYSQL = " $BASEDIR /bin/mysql "
2000-12-28 18:25:41 +01:00
INSTALL_DB = "./install_test_db -bin"
2001-12-10 17:16:51 +01:00
if test -d " $BASEDIR /share/mysql/english "
2001-06-25 10:35:22 +02:00
then
LANGUAGE = " $BASEDIR /share/mysql/english/ "
2001-09-07 00:05:04 +02:00
CHARSETSDIR = " $BASEDIR /share/mysql/charsets "
2001-06-25 10:35:22 +02:00
else
LANGUAGE = " $BASEDIR /share/english/ "
2001-09-07 00:05:04 +02:00
CHARSETSDIR = " $BASEDIR /share/charsets "
2001-06-25 10:35:22 +02:00
fi
2000-12-07 15:54:59 +01:00
fi
2003-10-07 14:44:31 +02:00
MYSQL_DUMP = " $MYSQL_DUMP --no-defaults -uroot --socket= $MASTER_MYSOCK "
MYSQL_BINLOG = " $MYSQL_BINLOG --no-defaults --local-load= $MYSQL_TMP_DIR "
2003-09-24 13:13:47 +02:00
export MYSQL_DUMP
2003-09-24 13:46:19 +02:00
export MYSQL_BINLOG
2003-09-24 13:13:47 +02:00
2002-02-09 21:58:53 +01:00
if [ -z " $MASTER_MYSQLD " ]
then
MASTER_MYSQLD = $MYSQLD
fi
if [ -z " $SLAVE_MYSQLD " ]
then
SLAVE_MYSQLD = $MYSQLD
fi
2001-01-03 15:54:46 +01:00
# If we should run all tests cases, we will use a local server for that
if [ -z " $1 " ]
then
USE_RUNNING_SERVER = ""
fi
2001-01-04 01:56:38 +01:00
if [ -n " $USE_RUNNING_SERVER " ]
then
MASTER_MYSOCK = "/tmp/mysql.sock"
2001-01-17 02:15:20 +01:00
DBUSER = ${ DBUSER :- test }
2001-01-16 05:02:05 +01:00
else
2001-01-17 02:15:20 +01:00
DBUSER = ${ DBUSER :- root } # We want to do FLUSH xxx commands
2001-01-04 01:56:38 +01:00
fi
2001-01-03 15:54:46 +01:00
if [ -w / ]
then
# We are running as root; We need to add the --root argument
EXTRA_MASTER_MYSQLD_OPT = " $EXTRA_MASTER_MYSQLD_OPT --user=root "
EXTRA_SLAVE_MYSQLD_OPT = " $EXTRA_SLAVE_MYSQLD_OPT --user=root "
fi
2001-01-04 01:56:38 +01:00
2001-10-02 00:13:55 +02:00
MYSQL_TEST_ARGS = " --no-defaults --socket= $MASTER_MYSOCK --database= $DB \
2002-10-29 21:56:30 +01:00
--user= $DBUSER --password= $DBPASSWD --silent -v --skip-safemalloc \
2003-03-11 10:41:53 +01:00
--tmpdir= $MYSQL_TMP_DIR --port= $MASTER_MYPORT $MYSQL_TEST_SSL_OPTS "
2001-06-09 03:24:41 +02:00
MYSQL_TEST_BIN = $MYSQL_TEST
MYSQL_TEST = " $MYSQL_TEST $MYSQL_TEST_ARGS "
GDB_CLIENT_INIT = $MYSQL_TMP_DIR /gdbinit.client
2001-01-04 01:56:38 +01:00
GDB_MASTER_INIT = $MYSQL_TMP_DIR /gdbinit.master
GDB_SLAVE_INIT = $MYSQL_TMP_DIR /gdbinit.slave
GCOV_MSG = $MYSQL_TMP_DIR /mysqld-gcov.out
2001-04-10 02:25:06 +02:00
GCOV_ERR = $MYSQL_TMP_DIR /mysqld-gcov.err
GPROF_DIR = $MYSQL_TMP_DIR /gprof
GPROF_MASTER = $GPROF_DIR /master.gprof
GPROF_SLAVE = $GPROF_DIR /slave.gprof
2001-11-05 00:04:08 +01:00
TIMEFILE = " $MYSQL_TEST_DIR /var/log/mysqltest-time "
2002-09-05 15:17:08 +02:00
if [ -n " $DO_CLIENT_GDB " -o -n " $DO_GDB " ] ; then
XTERM = ` which xterm`
fi
2001-01-04 01:56:38 +01:00
2000-07-31 21:29:14 +02:00
#++
# Function Definitions
#--
2000-11-21 07:38:08 +01:00
prompt_user ( )
{
2000-12-28 08:26:37 +01:00
$ECHO $1
2000-12-07 15:54:59 +01:00
read unused
2000-11-21 07:38:08 +01:00
}
2001-09-30 21:04:56 +02:00
# We can't use diff -u or diff -a as these are not portable
2001-04-21 16:12:59 +02:00
2001-04-12 21:46:19 +02:00
show_failed_diff ( )
{
reject_file = r/$1 .reject
result_file = r/$1 .result
2001-06-30 21:08:35 +02:00
eval_file = r/$1 .eval
2001-12-10 17:16:51 +01:00
2001-06-30 21:08:35 +02:00
if [ -f $eval_file ]
then
result_file = $eval_file
fi
2001-12-10 17:16:51 +01:00
2001-04-12 21:46:19 +02:00
if [ -x " $DIFF " ] && [ -f $reject_file ]
then
echo "Below are the diffs between actual and expected results:"
echo "-------------------------------------------------------"
2001-09-30 21:04:56 +02:00
$DIFF -c $result_file $reject_file
2001-04-12 21:46:19 +02:00
echo "-------------------------------------------------------"
2001-05-29 12:46:17 +02:00
echo "Please follow the instructions outlined at"
echo "http://www.mysql.com/doc/R/e/Reporting_mysqltest_bugs.html"
echo "to find the reason to this problem and how to report this."
2001-12-10 17:16:51 +01:00
fi
2001-04-12 21:46:19 +02:00
}
2000-07-31 21:29:14 +02:00
2001-06-09 03:24:41 +02:00
do_gdb_test ( )
{
mysql_test_args = " $MYSQL_TEST_ARGS $1 "
$ECHO " set args $mysql_test_args < $2 " > $GDB_CLIENT_INIT
echo "Set breakpoints ( if needed) and type 'run' in gdb window"
#this xterm should not be backgrounded
2001-11-28 01:55:52 +01:00
$XTERM -title "Client" -e gdb -x $GDB_CLIENT_INIT $MYSQL_TEST_BIN
2001-06-09 03:24:41 +02:00
}
2000-07-31 21:29:14 +02:00
error ( ) {
2000-12-14 18:05:04 +01:00
$ECHO " Error: $1 "
2000-07-31 21:29:14 +02:00
exit 1
}
2000-12-28 08:26:37 +01:00
error_is ( ) {
2003-06-17 16:35:20 +02:00
$ECHO " Errors are (from $TIMEFILE ) : "
$CAT < $TIMEFILE
$ECHO "(the last line(s) may be the ones that caused the die() in mysqltest)"
2000-12-28 08:26:37 +01:00
}
2000-12-15 15:12:31 +01:00
prefix_to_8( ) {
2000-12-28 08:26:37 +01:00
$ECHO " $1 " | $SED -e 's:.*\(........\)$:\1:'
2000-12-15 15:12:31 +01:00
}
2000-07-31 21:29:14 +02:00
pass_inc ( ) {
2000-10-10 10:42:07 +02:00
TOT_PASS = ` $EXPR $TOT_PASS + 1`
2000-07-31 21:29:14 +02:00
}
fail_inc ( ) {
2000-10-10 10:42:07 +02:00
TOT_FAIL = ` $EXPR $TOT_FAIL + 1`
2000-07-31 21:29:14 +02:00
}
2000-12-27 02:31:06 +01:00
skip_inc ( ) {
TOT_SKIP = ` $EXPR $TOT_SKIP + 1`
}
2000-07-31 21:29:14 +02:00
total_inc ( ) {
2000-10-10 10:42:07 +02:00
TOT_TEST = ` $EXPR $TOT_TEST + 1`
2000-07-31 21:29:14 +02:00
}
2002-08-21 21:04:22 +02:00
skip_test( ) {
USERT = " ...."
SYST = " ...."
REALT = " ...."
pname = ` $ECHO " $1 " | $CUT -c 1-24`
2003-05-13 10:39:07 +02:00
RES = " $pname "
2002-08-21 21:04:22 +02:00
skip_inc
$ECHO " $RES $RES_SPACE [ skipped ] "
}
2000-07-31 21:29:14 +02:00
report_stats ( ) {
2000-10-10 00:41:21 +02:00
if [ $TOT_FAIL = 0 ] ; then
2000-12-28 18:25:41 +01:00
$ECHO " All $TOT_TEST tests were successful. "
2000-07-31 21:29:14 +02:00
else
2001-12-10 17:16:51 +01:00
xten = ` $EXPR $TOT_PASS \* 10000`
raw = ` $EXPR $xten / $TOT_TEST `
raw = ` $PRINTF %.4d $raw `
whole = ` $PRINTF %.2s $raw `
xwhole = ` $EXPR $whole \* 100`
deci = ` $EXPR $raw - $xwhole `
2000-12-28 08:26:37 +01:00
$ECHO " Failed ${ TOT_FAIL } / ${ TOT_TEST } tests, ${ whole } . ${ deci } % successful. "
2001-03-08 21:27:43 +01:00
$ECHO ""
2002-01-22 23:05:11 +01:00
$ECHO " The log files in $MY_LOG_DIR may give you some hint "
2001-03-08 21:27:43 +01:00
$ECHO "of what when wrong."
$ECHO "If you want to report this error, please read first the documentation at"
$ECHO "http://www.mysql.com/doc/M/y/MySQL_test_suite.html"
2000-07-31 21:29:14 +02:00
fi
2003-01-28 07:38:28 +01:00
2003-02-10 16:03:27 +01:00
if test -z " $USE_RUNNING_SERVER "
then
2003-01-28 07:38:28 +01:00
# Report if there was any fatal warnings/errors in the log files
#
$RM -f $MY_LOG_DIR /warnings $MY_LOG_DIR /warnings.tmp
# Remove some non fatal warnings from the log files
$SED -e 's!Warning: Table:.* on delete!!g' \
$MY_LOG_DIR /*.err > $MY_LOG_DIR /warnings.tmp
found_error = 0
# Find errors
for i in "^Warning:" "^Error:" "^==.* at 0x"
do
if ` $GREP " $i " $MY_LOG_DIR /warnings.tmp >> $MY_LOG_DIR /warnings`
then
found_error = 1
fi
done
$RM -f $MY_LOG_DIR /warnings.tmp
if [ $found_error = "1" ]
then
echo "WARNING: Got errors/warnings while running tests. Please examine"
echo " $MY_LOG_DIR /warnings for details. "
fi
2003-02-10 16:03:27 +01:00
fi
2000-07-31 21:29:14 +02:00
}
2000-10-11 15:50:13 +02:00
2000-07-31 21:29:14 +02:00
mysql_install_db ( ) {
2000-12-28 08:26:37 +01:00
$ECHO "Removing Stale Files"
2002-01-22 23:05:11 +01:00
$RM -rf $MASTER_MYDDIR $SLAVE_MYDDIR $MY_LOG_DIR /*
2000-12-28 08:26:37 +01:00
$ECHO "Installing Master Databases"
2000-11-18 07:35:40 +01:00
$INSTALL_DB
if [ $? != 0 ] ; then
error "Could not install master test DBs"
exit 1
fi
2000-12-28 08:26:37 +01:00
$ECHO "Installing Slave Databases"
2000-11-18 07:35:40 +01:00
$INSTALL_DB -slave
2000-10-10 00:41:21 +02:00
if [ $? != 0 ] ; then
2000-11-18 07:35:40 +01:00
error "Could not install slave test DBs"
2000-10-10 00:41:21 +02:00
exit 1
2000-07-31 21:29:14 +02:00
fi
2001-12-10 17:16:51 +01:00
2001-10-10 00:43:05 +02:00
for slave_num in 1 2 ;
do
2002-08-21 21:04:22 +02:00
$RM -rf var/slave$slave_num -data
2001-12-23 01:43:46 +01:00
mkdir -p var/slave$slave_num -data/mysql
mkdir -p var/slave$slave_num -data/test
cp var/slave-data/mysql/* var/slave$slave_num -data/mysql
2001-10-10 00:43:05 +02:00
done
2000-07-31 21:29:14 +02:00
return 0
}
2001-04-10 02:25:06 +02:00
gprof_prepare ( )
{
2001-12-10 17:16:51 +01:00
$RM -rf $GPROF_DIR
mkdir -p $GPROF_DIR
2001-04-10 02:25:06 +02:00
}
gprof_collect ( )
{
if [ -f $MASTER_MYDDIR /gmon.out ] ; then
2002-02-09 21:58:53 +01:00
gprof $MASTER_MYSQLD $MASTER_MYDDIR /gmon.out > $GPROF_MASTER
2001-04-10 02:25:06 +02:00
echo " Master execution profile has been saved in $GPROF_MASTER "
fi
if [ -f $SLAVE_MYDDIR /gmon.out ] ; then
2002-02-09 21:58:53 +01:00
gprof $SLAVE_MYSQLD $SLAVE_MYDDIR /gmon.out > $GPROF_SLAVE
2001-04-10 02:25:06 +02:00
echo " Slave execution profile has been saved in $GPROF_SLAVE "
fi
}
2000-11-18 07:35:40 +01:00
gcov_prepare ( ) {
2000-10-13 14:14:39 +02:00
$FIND $BASEDIR -name \* .gcov \
-or -name \* .da | $XARGS $RM
2000-10-12 01:01:58 +02:00
}
gcov_collect ( ) {
2000-10-13 14:14:39 +02:00
$ECHO "Collecting source coverage info..."
2000-12-09 01:32:30 +01:00
[ -f $GCOV_MSG ] && $RM $GCOV_MSG
[ -f $GCOV_ERR ] && $RM $GCOV_ERR
2000-10-13 14:14:39 +02:00
for d in $MYSQLD_SRC_DIRS ; do
cd $BASEDIR /$d
for f in *.h *.cc *.c; do
2000-12-09 01:32:30 +01:00
$GCOV $f 2>>$GCOV_ERR >>$GCOV_MSG
2000-10-13 14:14:39 +02:00
done
2000-12-07 15:54:59 +01:00
cd $MYSQL_TEST_DIR
2000-10-12 01:01:58 +02:00
done
2000-12-28 18:25:41 +01:00
$ECHO " gcov info in $GCOV_MSG , errors in $GCOV_ERR "
2000-10-12 01:01:58 +02:00
}
2001-09-23 05:47:57 +02:00
abort_if_failed( )
{
if [ ! $? = 0 ] ; then
echo $1
exit 1
2001-12-10 17:16:51 +01:00
fi
2001-09-23 05:47:57 +02:00
}
start_manager( )
{
2001-10-11 23:41:31 +02:00
if [ $USE_MANAGER = 0 ] ; then
2001-12-23 01:43:46 +01:00
echo "Manager disabled, skipping manager start."
$RM -f $MYSQL_MANAGER_LOG
2001-10-11 21:54:06 +02:00
return
fi
2001-10-11 23:41:31 +02:00
$ECHO "Starting MySQL Manager"
2001-11-08 00:17:40 +01:00
if [ -f " $MANAGER_PID_FILE " ] ; then
kill ` cat $MANAGER_PID_FILE `
sleep 1
if [ -f " $MANAGER_PID_FILE " ] ; then
kill -9 ` cat $MANAGER_PID_FILE `
sleep 1
fi
fi
2001-12-10 17:16:51 +01:00
$RM -f $MANAGER_PID_FILE
2001-09-28 07:05:54 +02:00
MYSQL_MANAGER_PW = ` $MYSQL_MANAGER_PWGEN -u $MYSQL_MANAGER_USER \
-o $MYSQL_MANAGER_PW_FILE `
2001-09-23 05:47:57 +02:00
$MYSQL_MANAGER --log= $MYSQL_MANAGER_LOG --port= $MYSQL_MANAGER_PORT \
2001-11-08 00:17:40 +01:00
--password-file= $MYSQL_MANAGER_PW_FILE --pid-file= $MANAGER_PID_FILE
2001-09-23 05:47:57 +02:00
abort_if_failed "Could not start MySQL manager"
2001-10-10 23:36:35 +02:00
mysqltest_manager_args = " --manager-host=localhost \
--manager-user= $MYSQL_MANAGER_USER \
2001-10-02 00:13:55 +02:00
--manager-password= $MYSQL_MANAGER_PW \
--manager-port= $MYSQL_MANAGER_PORT \
--manager-wait-timeout= $START_WAIT_TIMEOUT "
MYSQL_TEST = " $MYSQL_TEST $mysqltest_manager_args "
MYSQL_TEST_ARGS = " $MYSQL_TEST_ARGS $mysqltest_manager_args "
2001-11-08 00:17:40 +01:00
while [ ! -f $MANAGER_PID_FILE ] ; do
sleep 1
done
echo "Manager started"
2001-09-23 05:47:57 +02:00
}
2001-09-28 07:05:54 +02:00
stop_manager( )
{
2001-10-11 23:41:31 +02:00
if [ $USE_MANAGER = 0 ] ; then
2001-10-11 21:54:06 +02:00
return
fi
2001-09-28 07:05:54 +02:00
$MYSQL_MANAGER_CLIENT $MANAGER_QUIET_OPT -u$MYSQL_MANAGER_USER \
-p$MYSQL_MANAGER_PW -P $MYSQL_MANAGER_PORT <<EOF
shutdown
EOF
2001-11-08 00:17:40 +01:00
echo "Manager terminated"
2001-09-28 07:05:54 +02:00
}
manager_launch( )
2001-09-23 05:47:57 +02:00
{
2001-09-28 07:05:54 +02:00
ident = $1
shift
2001-10-11 23:41:31 +02:00
if [ $USE_MANAGER = 0 ] ; then
2002-10-29 20:59:03 +01:00
$@ >> $CUR_MYERR 2>& 1 &
2002-06-05 22:04:38 +02:00
sleep 2 #hack
return
2001-10-11 21:54:06 +02:00
fi
2001-09-28 07:05:54 +02:00
$MYSQL_MANAGER_CLIENT $MANAGER_QUIET_OPT --user= $MYSQL_MANAGER_USER \
2001-09-23 05:47:57 +02:00
--password= $MYSQL_MANAGER_PW --port= $MYSQL_MANAGER_PORT <<EOF
2001-09-28 07:05:54 +02:00
def_exec $ident $@
set_exec_stdout $ident $CUR_MYERR
set_exec_stderr $ident $CUR_MYERR
set_exec_con $ident root localhost $CUR_MYSOCK
start_exec $ident $START_WAIT_TIMEOUT
2001-09-23 05:47:57 +02:00
EOF
2002-06-05 22:04:38 +02:00
abort_if_failed "Could not execute manager command"
2001-09-23 05:47:57 +02:00
}
2001-01-17 13:47:33 +01:00
2001-09-28 07:05:54 +02:00
manager_term( )
{
2002-12-05 02:40:33 +01:00
pid = $1
ident = $2
2001-10-11 23:41:31 +02:00
if [ $USE_MANAGER = 0 ] ; then
2003-01-07 15:53:10 +01:00
# Shutdown time must be high as slave may be in reconnect
$MYSQLADMIN --no-defaults -uroot --socket= $MYSQL_TMP_DIR /$ident .sock --connect_timeout= 5 --shutdown_timeout= 70 shutdown >> $MYSQL_MANAGER_LOG 2>& 1
2002-12-05 02:40:33 +01:00
res = $?
# Some systems require an extra connect
$MYSQLADMIN --no-defaults -uroot --socket= $MYSQL_TMP_DIR /$ident .sock --connect_timeout= 1 ping >> $MYSQL_MANAGER_LOG 2>& 1
if test $res = 0
then
wait_for_pid $pid
fi
return $res
2001-10-11 21:54:06 +02:00
fi
2001-09-28 07:05:54 +02:00
$MYSQL_MANAGER_CLIENT $MANAGER_QUIET_OPT --user= $MYSQL_MANAGER_USER \
--password= $MYSQL_MANAGER_PW --port= $MYSQL_MANAGER_PORT <<EOF
2001-10-02 00:13:55 +02:00
stop_exec $ident $STOP_WAIT_TIMEOUT
2001-09-28 07:05:54 +02:00
EOF
abort_if_failed "Could not execute manager command"
}
2000-11-21 07:38:08 +01:00
start_master( )
{
2001-12-10 17:16:51 +01:00
if [ x$MASTER_RUNNING = x1 ] || [ x$LOCAL_MASTER = x1 ] ; then
return
fi
# Remove old berkeley db log files that can confuse the server
$RM -f $MASTER_MYDDIR /log.*
# Remove stale binary logs
$RM -f $MYSQL_TEST_DIR /var/log/master-bin.*
2003-03-03 14:57:02 +01:00
# Remove old master.info and relay-log.info files
$RM -f $MYSQL_TEST_DIR /var/master-data/master.info $MYSQL_TEST_DIR /var/master-data/relay-log.info
2001-12-10 17:16:51 +01:00
#run master initialization shell script if one exists
if [ -f " $master_init_script " ] ;
then
/bin/sh $master_init_script
fi
cd $BASEDIR # for gcov
if [ -z " $DO_BENCH " ]
then
master_args = " --no-defaults --log-bin= $MYSQL_TEST_DIR /var/log/master-bin \
2002-02-09 21:58:53 +01:00
--server-id= 1 \
--basedir= $MY_BASEDIR \
2001-12-10 17:16:51 +01:00
--port= $MASTER_MYPORT \
2002-03-05 13:22:32 +01:00
--local-infile \
2001-12-10 17:16:51 +01:00
--exit-info= 256 \
--core \
--datadir= $MASTER_MYDDIR \
--pid-file= $MASTER_MYPID \
--socket= $MASTER_MYSOCK \
--log= $MASTER_MYLOG \
--character-sets-dir= $CHARSETSDIR \
--default-character-set= $CHARACTER_SET \
--tmpdir= $MYSQL_TMP_DIR \
--language= $LANGUAGE \
--innodb_data_file_path= ibdata1:50M \
2003-08-22 03:07:40 +02:00
--open-files-limit= 1024 \
2002-02-09 21:58:53 +01:00
$MASTER_40_ARGS \
2001-12-10 17:16:51 +01:00
$SMALL_SERVER \
$EXTRA_MASTER_OPT $EXTRA_MASTER_MYSQLD_OPT "
else
master_args = " --no-defaults --log-bin= $MYSQL_TEST_DIR /var/log/master-bin \
--server-id= 1 --rpl-recovery-rank= 1 \
--basedir= $MY_BASEDIR --init-rpl-role= master \
--port= $MASTER_MYPORT \
2002-03-05 13:22:32 +01:00
--local-infile \
2001-12-10 17:16:51 +01:00
--datadir= $MASTER_MYDDIR \
--pid-file= $MASTER_MYPID \
--socket= $MASTER_MYSOCK \
--character-sets-dir= $CHARSETSDIR \
--default-character-set= $CHARACTER_SET \
--core \
--tmpdir= $MYSQL_TMP_DIR \
--language= $LANGUAGE \
--innodb_data_file_path= ibdata1:50M \
2002-02-09 21:58:53 +01:00
$MASTER_40_ARGS \
2001-12-10 17:16:51 +01:00
$SMALL_SERVER \
$EXTRA_MASTER_OPT $EXTRA_MASTER_MYSQLD_OPT "
fi
CUR_MYERR = $MASTER_MYERR
CUR_MYSOCK = $MASTER_MYSOCK
if [ x$DO_DDD = x1 ]
then
$ECHO " set args $master_args " > $GDB_MASTER_INIT
manager_launch master ddd -display $DISPLAY --debugger \
2002-02-09 21:58:53 +01:00
" gdb -x $GDB_MASTER_INIT " $MASTER_MYSQLD
2001-12-10 17:16:51 +01:00
elif [ x$DO_GDB = x1 ]
then
2001-12-17 02:02:58 +01:00
if [ x$MANUAL_GDB = x1 ]
then
$ECHO " set args $master_args " > $GDB_MASTER_INIT
$ECHO "To start gdb for the master , type in another window:"
2002-02-09 21:58:53 +01:00
$ECHO " cd $CWD ; gdb -x $GDB_MASTER_INIT $MASTER_MYSQLD "
2001-12-17 02:02:58 +01:00
wait_for_master = 1500
else
( $ECHO set args $master_args ;
if [ $USE_MANAGER = 0 ] ; then
2001-12-10 17:16:51 +01:00
cat <<EOF
2001-10-18 15:45:33 +02:00
b mysql_parse
commands 1
2001-11-20 17:59:57 +01:00
disa 1
2001-10-18 15:45:33 +02:00
end
2001-11-09 06:27:55 +01:00
r
EOF
2001-12-17 02:02:58 +01:00
fi ) > $GDB_MASTER_INIT
manager_launch master $XTERM -display $DISPLAY \
2002-02-09 21:58:53 +01:00
-title "Master" -e gdb -x $GDB_MASTER_INIT $MASTER_MYSQLD
2001-12-17 02:02:58 +01:00
fi
2001-12-10 17:16:51 +01:00
else
2002-02-09 21:58:53 +01:00
manager_launch master $MASTER_MYSQLD $master_args
2001-12-10 17:16:51 +01:00
fi
2002-02-09 21:58:53 +01:00
sleep_until_file_created $MASTER_MYPID $wait_for_master
2001-12-13 01:31:19 +01:00
wait_for_master = $SLEEP_TIME_FOR_SECOND_MASTER
2000-11-21 07:38:08 +01:00
MASTER_RUNNING = 1
}
start_slave( )
{
2001-12-10 17:16:51 +01:00
[ x$SKIP_SLAVE = x1 ] && return
eval " this_slave_running=\$SLAVE $1 _RUNNING "
[ x$this_slave_running = 1 ] && return
2003-01-07 15:53:10 +01:00
# When testing fail-safe replication, we will have more than one slave
# in this case, we start secondary slaves with an argument
2001-12-10 17:16:51 +01:00
slave_ident = " slave $1 "
if [ -n " $1 " ] ;
then
slave_server_id = ` $EXPR 2 + $1 `
slave_rpl_rank = $slave_server_id
slave_port = ` expr $SLAVE_MYPORT + $1 `
slave_log = " $SLAVE_MYLOG . $1 "
slave_err = " $SLAVE_MYERR . $1 "
2003-03-03 14:57:02 +01:00
slave_datadir = " $SLAVE_MYDDIR /../ $slave_ident -data/ "
2001-12-10 17:16:51 +01:00
slave_pid = " $MYRUN_DIR /mysqld- $slave_ident .pid "
slave_sock = " $SLAVE_MYSOCK - $1 "
else
slave_server_id = 2
slave_rpl_rank = 2
slave_port = $SLAVE_MYPORT
slave_log = $SLAVE_MYLOG
slave_err = $SLAVE_MYERR
slave_datadir = $SLAVE_MYDDIR
slave_pid = $SLAVE_MYPID
slave_sock = " $SLAVE_MYSOCK "
fi
2002-09-11 05:40:08 +02:00
# Remove stale binary logs and old master.info files
$RM -f $MYSQL_TEST_DIR /var/log/$slave_ident -*bin.*
2003-03-03 14:57:02 +01:00
$RM -f $slave_datadir /master.info $slave_datadir /relay-log.info
2001-12-10 17:16:51 +01:00
#run slave initialization shell script if one exists
if [ -f " $slave_init_script " ] ;
then
/bin/sh $slave_init_script
fi
if [ -z " $SLAVE_MASTER_INFO " ] ; then
master_info = " --master-user=root \
--master-connect-retry= 1 \
--master-host= 127.0.0.1 \
2002-08-08 02:12:02 +02:00
--master-password= "" \
2001-12-10 17:16:51 +01:00
--master-port= $MASTER_MYPORT \
--server-id= $slave_server_id --rpl-recovery-rank= $slave_rpl_rank "
else
master_info = $SLAVE_MASTER_INFO
fi
$RM -f $slave_datadir /log.*
slave_args = " --no-defaults $master_info \
--exit-info= 256 \
--log-bin= $MYSQL_TEST_DIR /var/log/$slave_ident -bin \
2002-01-27 06:26:24 +01:00
--relay-log= $MYSQL_TEST_DIR /var/log/$slave_ident -relay-bin \
2001-12-10 17:16:51 +01:00
--log-slave-updates \
--log= $slave_log \
--basedir= $MY_BASEDIR \
--datadir= $slave_datadir \
--pid-file= $slave_pid \
--port= $slave_port \
--socket= $slave_sock \
--character-sets-dir= $CHARSETSDIR \
--default-character-set= $CHARACTER_SET \
--core --init-rpl-role= slave \
--tmpdir= $MYSQL_TMP_DIR \
--language= $LANGUAGE \
--skip-innodb --skip-slave-start \
--slave-load-tmpdir= $SLAVE_LOAD_TMPDIR \
--report-host= 127.0.0.1 --report-user= root \
--report-port= $slave_port \
2002-08-18 15:04:26 +02:00
--master-retry-count= 10 \
2002-04-26 07:56:28 +02:00
-O slave_net_timeout = 10 \
2001-12-10 17:16:51 +01:00
$SMALL_SERVER \
$EXTRA_SLAVE_OPT $EXTRA_SLAVE_MYSQLD_OPT "
CUR_MYERR = $slave_err
CUR_MYSOCK = $slave_sock
if [ x$DO_DDD = x1 ]
then
$ECHO " set args $master_args " > $GDB_SLAVE_INIT
manager_launch $slave_ident ddd -display $DISPLAY --debugger \
" gdb -x $GDB_SLAVE_INIT " $SLAVE_MYSQLD
elif [ x$DO_GDB = x1 ]
then
2001-12-17 02:02:58 +01:00
if [ x$MANUAL_GDB = x1 ]
then
2002-06-05 22:04:38 +02:00
$ECHO " set args $slave_args " > $GDB_SLAVE_INIT
2001-12-17 02:02:58 +01:00
echo "To start gdb for the slave, type in another window:"
2002-02-09 21:58:53 +01:00
echo " cd $CWD ; gdb -x $GDB_SLAVE_INIT $SLAVE_MYSQLD "
2001-12-17 02:02:58 +01:00
wait_for_slave = 1500
else
2002-06-05 22:04:38 +02:00
( $ECHO set args $slave_args ;
if [ $USE_MANAGER = 0 ] ; then
cat <<EOF
b mysql_parse
commands 1
disa 1
end
r
EOF
fi ) > $GDB_SLAVE_INIT
2001-12-17 02:02:58 +01:00
manager_launch $slave_ident $XTERM -display $DISPLAY -title "Slave" -e \
gdb -x $GDB_SLAVE_INIT $SLAVE_MYSQLD
fi
2001-12-10 17:16:51 +01:00
else
manager_launch $slave_ident $SLAVE_MYSQLD $slave_args
fi
eval " SLAVE $1 _RUNNING=1 "
2002-02-09 21:58:53 +01:00
sleep_until_file_created $slave_pid $wait_for_slave
2001-12-13 01:31:19 +01:00
wait_for_slave = $SLEEP_TIME_FOR_SECOND_SLAVE
2000-11-21 07:38:08 +01:00
}
2001-12-10 17:16:51 +01:00
mysql_start ( )
{
2003-10-06 23:23:29 +02:00
# We should not start the daemon here as we don't know the arguments
2003-10-05 00:41:17 +02:00
# for the test. Better to let the test start the daemon
2003-01-07 15:53:10 +01:00
# $ECHO "Starting MySQL daemon"
# start_master
# start_slave
2001-12-10 17:16:51 +01:00
cd $MYSQL_TEST_DIR
return 1
2000-07-31 21:29:14 +02:00
}
2000-11-21 07:38:08 +01:00
stop_slave ( )
{
2001-10-10 00:43:05 +02:00
eval " this_slave_running=\$SLAVE $1 _RUNNING "
slave_ident = " slave $1 "
if [ -n " $1 " ] ;
2000-11-21 07:38:08 +01:00
then
2001-10-10 00:43:05 +02:00
slave_pid = " $MYRUN_DIR /mysqld- $slave_ident .pid "
else
slave_pid = $SLAVE_MYPID
2001-12-10 17:16:51 +01:00
fi
2001-10-10 00:43:05 +02:00
if [ x$this_slave_running = x1 ]
then
2002-12-05 02:40:33 +01:00
pid = ` $CAT $slave_pid `
manager_term $pid $slave_ident
2001-10-10 00:43:05 +02:00
if [ $? != 0 ] && [ -f $slave_pid ]
2001-01-03 15:54:46 +01:00
then # try harder!
2001-12-23 02:03:09 +01:00
$ECHO "slave not cooperating with mysqladmin, will try manual kill"
2002-12-05 02:40:33 +01:00
kill $pid
sleep_until_file_deleted $pid $slave_pid
2001-12-23 02:03:09 +01:00
if [ -f $slave_pid ] ; then
$ECHO "slave refused to die. Sending SIGKILL"
kill -9 ` $CAT $slave_pid `
$RM -f $slave_pid
else
$ECHO "slave responded to SIGTERM "
fi
else
sleep $SLEEP_TIME_AFTER_RESTART
2000-12-12 20:12:41 +01:00
fi
2001-10-10 00:43:05 +02:00
eval " SLAVE $1 _RUNNING=0 "
2001-12-10 17:16:51 +01:00
fi
2000-11-21 07:38:08 +01:00
}
2000-07-31 21:29:14 +02:00
2003-06-10 23:29:49 +02:00
stop_slave_threads ( )
{
eval " this_slave_running=\$SLAVE $1 _RUNNING "
slave_ident = " slave $1 "
if [ x$this_slave_running = x1 ]
then
$MYSQLADMIN --no-defaults -uroot --socket= $MYSQL_TMP_DIR /$slave_ident .sock stop-slave > /dev/null 2>& 1
fi
}
2000-11-21 07:38:08 +01:00
stop_master ( )
{
if [ x$MASTER_RUNNING = x1 ]
then
2002-12-05 02:40:33 +01:00
pid = ` $CAT $MASTER_MYPID `
manager_term $pid master
2001-01-03 15:54:46 +01:00
if [ $? != 0 ] && [ -f $MASTER_MYPID ]
then # try harder!
2001-12-23 02:03:09 +01:00
$ECHO "master not cooperating with mysqladmin, will try manual kill"
2002-12-05 02:40:33 +01:00
kill $pid
sleep_until_file_deleted $pid $MASTER_MYPID
2001-12-23 02:03:09 +01:00
if [ -f $MASTER_MYPID ] ; then
$ECHO "master refused to die. Sending SIGKILL"
kill -9 ` $CAT $MASTER_MYPID `
$RM -f $MASTER_MYPID
else
$ECHO "master responded to SIGTERM "
fi
else
sleep $SLEEP_TIME_AFTER_RESTART
2000-12-12 20:12:41 +01:00
fi
2000-11-21 07:38:08 +01:00
MASTER_RUNNING = 0
fi
}
2000-07-31 21:29:14 +02:00
2000-11-21 07:38:08 +01:00
mysql_stop ( )
{
2000-12-28 08:26:37 +01:00
$ECHO "Ending Tests"
$ECHO "Shutting-down MySQL daemon"
2001-01-02 13:29:47 +01:00
$ECHO ""
2000-11-21 07:38:08 +01:00
stop_master
2001-01-17 13:47:33 +01:00
$ECHO "Master shutdown finished"
2000-11-21 07:38:08 +01:00
stop_slave
2001-10-10 00:43:05 +02:00
stop_slave 1
stop_slave 2
2001-01-17 13:47:33 +01:00
$ECHO "Slave shutdown finished"
2001-12-10 17:16:51 +01:00
2000-11-21 07:38:08 +01:00
return 1
2000-07-31 21:29:14 +02:00
}
2001-12-10 17:16:51 +01:00
mysql_restart ( )
{
mysql_stop
mysql_start
return 1
2000-07-31 21:29:14 +02:00
}
mysql_loadstd ( ) {
2001-12-10 17:16:51 +01:00
# cp $STD_DATA/*.frm $STD_DATA/*.MRG $MASTER_MYDDIR/test
2000-07-31 21:29:14 +02:00
return 1
}
2000-11-21 07:38:08 +01:00
run_testcase ( )
{
tf = $1
2000-12-15 15:12:31 +01:00
tname = ` $BASENAME $tf .test`
2000-11-21 07:38:08 +01:00
master_opt_file = $TESTDIR /$tname -master.opt
slave_opt_file = $TESTDIR /$tname -slave.opt
2001-01-24 20:47:09 +01:00
master_init_script = $TESTDIR /$tname -master.sh
slave_init_script = $TESTDIR /$tname -slave.sh
2003-02-25 23:04:13 +01:00
slave_master_info_file = $TESTDIR /$tname .slave-mi
2002-08-22 15:50:58 +02:00
echo $tname > $CURRENT_TEST
2000-12-07 00:18:46 +01:00
SKIP_SLAVE = ` $EXPR \( $tname : rpl \) = 0`
2001-10-11 23:41:31 +02:00
if [ $USE_MANAGER = 1 ] ; then
2003-10-29 14:23:35 +01:00
many_slaves = ` $EXPR \( \( $tname : rpl_failsafe \) != 0 \) \| \( \( $tname : rpl_chain_temp_table \) != 0 \) `
2001-12-10 17:16:51 +01:00
fi
if [ -n " $SKIP_TEST " ] ; then
2001-06-22 16:35:18 +02:00
SKIP_THIS_TEST = ` $EXPR \( $tname : " $SKIP_TEST " \) != 0`
2001-06-20 00:08:19 +02:00
if [ x$SKIP_THIS_TEST = x1 ] ;
then
2002-08-21 21:04:22 +02:00
skip_test $tname ;
return ;
2001-06-20 00:08:19 +02:00
fi
fi
2001-01-05 12:13:15 +01:00
2001-12-10 17:16:51 +01:00
if [ -n " $DO_TEST " ] ; then
2001-06-27 01:02:33 +02:00
DO_THIS_TEST = ` $EXPR \( $tname : " $DO_TEST " \) != 0`
if [ x$DO_THIS_TEST = x0 ] ;
then
2002-08-21 21:04:22 +02:00
skip_test $tname ;
return ;
2001-06-27 01:02:33 +02:00
fi
fi
2001-01-05 12:13:15 +01:00
if [ x${ NO_SLAVE } x$SKIP_SLAVE = x1x0 ] ;
then
2002-08-21 21:04:22 +02:00
skip_test $tname ;
2001-01-05 12:13:15 +01:00
return
fi
2003-06-10 23:29:49 +02:00
# Stop all slave threads, so that we don't have useless reconnection attempts
# and error messages in case the slave and master servers restart.
stop_slave_threads
stop_slave_threads 1
stop_slave_threads 2
2001-01-16 11:38:58 +01:00
if [ -z " $USE_RUNNING_SERVER " ] ;
2000-11-21 07:38:08 +01:00
then
2001-01-16 11:38:58 +01:00
if [ -f $master_opt_file ] ;
then
2001-12-13 14:53:18 +01:00
EXTRA_MASTER_OPT = ` $CAT $master_opt_file | $SED -e " s;\\ $MYSQL_TEST_DIR ; $MYSQL_TEST_DIR ; " `
2003-05-27 15:40:14 +02:00
case " $EXTRA_MASTER_OPT " in
--timezone= *)
TZ = ` $ECHO " $EXTRA_MASTER_OPT " | $SED -e "s;--timezone=;;" `
export TZ
# Note that this must be set to space, not "" for test-reset to work
EXTRA_MASTER_OPT = " "
; ;
esac
2001-01-16 11:38:58 +01:00
stop_master
2003-01-07 15:53:10 +01:00
echo " CURRENT_TEST: $tname " >> $MASTER_MYERR
2001-01-16 11:38:58 +01:00
start_master
2003-05-27 15:40:14 +02:00
TZ = $MY_TZ ; export TZ
2001-01-16 11:38:58 +01:00
else
2003-03-10 10:22:37 +01:00
if [ ! -z " $EXTRA_MASTER_OPT " ] || [ x$MASTER_RUNNING != x1 ] || [ -f $master_init_script ]
2001-01-16 11:38:58 +01:00
then
EXTRA_MASTER_OPT = ""
stop_master
2003-01-07 15:53:10 +01:00
echo " CURRENT_TEST: $tname " >> $MASTER_MYERR
2001-01-16 11:38:58 +01:00
start_master
2003-01-07 15:53:10 +01:00
else
echo " CURRENT_TEST: $tname " >> $MASTER_MYERR
2001-12-10 17:16:51 +01:00
fi
2001-01-16 11:38:58 +01:00
fi
2001-12-10 17:16:51 +01:00
2002-09-11 05:40:08 +02:00
do_slave_restart = 0
2001-01-16 11:38:58 +01:00
if [ -f $slave_opt_file ] ;
then
2001-12-13 14:53:18 +01:00
EXTRA_SLAVE_OPT = ` $CAT $slave_opt_file | $SED -e " s;\\ $MYSQL_TEST_DIR ; $MYSQL_TEST_DIR ; " `
2001-01-16 11:38:58 +01:00
do_slave_restart = 1
else
if [ ! -z " $EXTRA_SLAVE_OPT " ] || [ x$SLAVE_RUNNING != x1 ] ;
then
EXTRA_SLAVE_OPT = ""
2001-12-10 17:16:51 +01:00
do_slave_restart = 1
fi
2001-01-16 11:38:58 +01:00
fi
2000-12-13 17:58:26 +01:00
2001-01-16 11:38:58 +01:00
if [ -f $slave_master_info_file ] ; then
SLAVE_MASTER_INFO = ` $CAT $slave_master_info_file `
do_slave_restart = 1
else
if [ ! -z " $SLAVE_MASTER_INFO " ] || [ x$SLAVE_RUNNING != x1 ] ;
then
SLAVE_MASTER_INFO = ""
2001-12-10 17:16:51 +01:00
do_slave_restart = 1
fi
2001-01-16 11:38:58 +01:00
fi
if [ x$do_slave_restart = x1 ] ; then
stop_slave
2003-01-07 15:53:10 +01:00
echo " CURRENT_TEST: $tname " >> $SLAVE_MYERR
2001-01-16 11:38:58 +01:00
start_slave
2003-01-07 15:53:10 +01:00
else
echo " CURRENT_TEST: $tname " >> $SLAVE_MYERR
2001-01-16 11:38:58 +01:00
fi
2001-10-10 00:43:05 +02:00
if [ x$many_slaves = x1 ] ; then
start_slave 1
start_slave 2
fi
2000-12-13 17:58:26 +01:00
fi
2000-12-07 15:54:59 +01:00
cd $MYSQL_TEST_DIR
2001-12-10 17:16:51 +01:00
2000-10-10 01:53:10 +02:00
if [ -f $tf ] ; then
2000-12-28 18:25:41 +01:00
$RM -f r/$tname .*reject
2001-06-09 03:24:41 +02:00
mysql_test_args = " -R r/ $tname .result $EXTRA_MYSQL_TEST_OPT "
2001-10-08 03:58:07 +02:00
if [ -z " $DO_CLIENT_GDB " ] ; then
2003-05-13 10:39:07 +02:00
` $MYSQL_TEST $mysql_test_args < $tf 2> $TIMEFILE ` ;
2001-06-09 03:24:41 +02:00
else
2001-10-08 03:58:07 +02:00
do_gdb_test " $mysql_test_args " " $tf "
2001-06-09 03:24:41 +02:00
fi
2001-12-10 17:16:51 +01:00
2000-07-31 21:29:14 +02:00
res = $?
2001-06-25 10:35:22 +02:00
pname = ` $ECHO " $tname " | $CUT -c 1-24`
2003-05-13 10:39:07 +02:00
RES = " $pname "
2001-12-10 17:16:51 +01:00
2001-10-11 21:54:06 +02:00
if [ x$many_slaves = x1 ] ; then
stop_slave 1
stop_slave 2
fi
2001-12-10 17:16:51 +01:00
2000-12-28 18:25:41 +01:00
if [ $res = 0 ] ; then
2000-12-27 02:31:06 +01:00
total_inc
pass_inc
2001-01-04 01:56:38 +01:00
$ECHO " $RES $RES_SPACE [ pass ] "
2000-12-27 02:31:06 +01:00
else
2001-07-12 18:06:42 +02:00
# why the following ``if'' ? That is why res==1 is special ?
2001-07-13 13:58:25 +02:00
if [ $res = 2 ] ; then
skip_inc
$ECHO " $RES $RES_SPACE [ skipped ] "
else
2000-12-27 02:31:06 +01:00
total_inc
2000-12-14 18:05:04 +01:00
fail_inc
2001-01-04 01:56:38 +01:00
$ECHO " $RES $RES_SPACE [ fail ] "
2000-12-28 08:26:37 +01:00
$ECHO
error_is
2001-04-12 21:46:19 +02:00
show_failed_diff $tname
2000-10-10 10:42:07 +02:00
$ECHO
2000-12-07 15:54:59 +01:00
if [ x$FORCE != x1 ] ; then
2000-12-28 08:26:37 +01:00
$ECHO "Aborting. To continue, re-run with '--force'."
$ECHO
2001-01-15 21:56:44 +01:00
if [ -z " $DO_GDB " ] && [ -z " $USE_RUNNING_SERVER " ] && [ -z " $DO_DDD " ]
then
mysql_stop
2001-09-28 07:05:54 +02:00
stop_manager
2001-01-15 21:56:44 +01:00
fi
2000-12-07 15:54:59 +01:00
exit 1
fi
2001-12-10 17:16:51 +01:00
2001-01-15 21:56:44 +01:00
if [ -z " $DO_GDB " ] && [ -z " $USE_RUNNING_SERVER " ] && [ -z " $DO_DDD " ]
then
mysql_restart
fi
2000-12-28 08:26:37 +01:00
$ECHO "Resuming Tests"
2001-01-02 13:29:47 +01:00
$ECHO ""
2000-12-27 02:31:06 +01:00
fi
2000-07-31 21:29:14 +02:00
fi
2001-01-03 15:54:46 +01:00
fi
2000-11-21 07:38:08 +01:00
}
2000-12-28 18:25:41 +01:00
######################################################################
# Main script starts here
######################################################################
2000-11-21 07:38:08 +01:00
[ " $DO_GCOV " -a ! -x " $GCOV " ] && error "No gcov found"
2001-12-10 17:16:51 +01:00
[ " $DO_GCOV " ] && gcov_prepare
[ " $DO_GPROF " ] && gprof_prepare
2000-11-21 07:38:08 +01:00
2001-01-07 23:04:30 +01:00
if [ -z " $USE_RUNNING_SERVER " ]
then
2002-12-05 02:40:33 +01:00
if [ -z " $FAST_START " ]
then
# Ensure that no old mysqld test servers are running
$MYSQLADMIN --no-defaults --socket= $MASTER_MYSOCK -u root -O connect_timeout = 5 -O shutdown_timeout = 20 shutdown > /dev/null 2>& 1
$MYSQLADMIN --no-defaults --socket= $SLAVE_MYSOCK -u root -O connect_timeout = 5 -O shutdown_timeout = 20 shutdown > /dev/null 2>& 1
$MYSQLADMIN --no-defaults --host= $hostname --port= $MASTER_MYPORT -u root -O connect_timeout = 5 -O shutdown_timeout = 20 shutdown > /dev/null 2>& 1
$MYSQLADMIN --no-defaults --host= $hostname --port= $SLAVE_MYPORT -u root -O connect_timeout = 5 -O shutdown_timeout = 20 shutdown > /dev/null 2>& 1
$MYSQLADMIN --no-defaults --host= $hostname --port= ` expr $SLAVE_MYPORT + 1` -u root -O connect_timeout = 5 -O shutdown_timeout = 20 shutdown > /dev/null 2>& 1
sleep_until_file_deleted 0 $MASTER_MYPID
sleep_until_file_deleted 0 $SLAVE_MYPID
else
rm $MASTER_MYPID $SLAVE_MYPID
fi
2001-12-10 17:16:51 +01:00
# Kill any running managers
if [ -f " $MANAGER_PID_FILE " ]
then
kill ` cat $MANAGER_PID_FILE `
sleep 1
if [ -f " $MANAGER_PID_FILE " ]
then
kill -9 ` cat $MANAGER_PID_FILE `
sleep 1
fi
fi
# Remove files that can cause problems
$RM -f $MYSQL_TEST_DIR /var/run/* $MYSQL_TEST_DIR /var/tmp/*
2001-12-13 01:31:19 +01:00
wait_for_master = $SLEEP_TIME_FOR_FIRST_MASTER
wait_for_slave = $SLEEP_TIME_FOR_FIRST_SLAVE
2001-01-07 23:04:30 +01:00
$ECHO "Installing Test Databases"
mysql_install_db
2001-09-28 07:05:54 +02:00
start_manager
2001-12-10 17:16:51 +01:00
2003-10-05 00:41:17 +02:00
# Do not automagically start daemons if we are in gdb or running only one test
2001-12-10 17:16:51 +01:00
# case
2001-01-07 23:04:30 +01:00
if [ -z " $DO_GDB " ] && [ -z " $DO_DDD " ]
then
mysql_start
fi
$ECHO "Loading Standard Test Databases"
mysql_loadstd
2000-11-21 07:38:08 +01:00
fi
2001-11-11 06:24:12 +01:00
if [ " x $START_AND_EXIT " = "x1" ] ; then
echo "Servers started, exiting"
exit
fi
2000-11-21 07:38:08 +01:00
2000-12-28 08:26:37 +01:00
$ECHO "Starting Tests"
2000-11-21 07:38:08 +01:00
2003-08-22 03:07:40 +02:00
#
# This can probably be deleted
#
2001-04-13 20:51:27 +02:00
if [ " $DO_BENCH " = 1 ]
then
2001-12-10 17:16:51 +01:00
BENCHDIR = $BASEDIR /sql-bench/
savedir = ` pwd `
cd $BENCHDIR
if [ -z " $1 " ]
2001-04-13 20:51:27 +02:00
then
2001-12-10 17:16:51 +01:00
./run-all-tests --socket= $MASTER_MYSOCK --user= root
2001-04-13 20:51:27 +02:00
else
2001-12-10 17:16:51 +01:00
if [ -x " ./ $1 " ]
then
./$1 --socket= $MASTER_MYSOCK --user= root
else
echo " benchmark $1 not found "
fi
2001-04-13 20:51:27 +02:00
fi
2001-12-10 17:16:51 +01:00
cd $savedir
mysql_stop
stop_manager
exit
2001-04-13 20:51:27 +02:00
fi
2000-11-21 07:38:08 +01:00
$ECHO
2003-05-13 10:39:07 +02:00
$ECHO " TEST RESULT"
2000-11-21 07:38:08 +01:00
$ECHO $DASH72
2000-12-14 18:05:04 +01:00
if [ -z " $1 " ] ;
2000-11-21 07:38:08 +01:00
then
2000-12-12 23:01:35 +01:00
if [ x$RECORD = x1 ] ; then
2000-12-28 08:26:37 +01:00
$ECHO "Will not run in record mode without a specific test case."
2000-12-12 23:01:35 +01:00
else
2003-05-14 21:12:55 +02:00
for tf in ` ls -1 $TESTDIR /*.$TESTSUFFIX | $SORT `
2000-12-12 23:01:35 +01:00
do
run_testcase $tf
done
2001-01-07 23:04:30 +01:00
$RM -f $TIMEFILE # Remove for full test
2000-12-12 23:01:35 +01:00
fi
2001-12-10 17:16:51 +01:00
else
2001-11-20 14:18:57 +01:00
while [ ! -z " $1 " ] ; do
tname = ` $BASENAME $1 .test`
tf = $TESTDIR /$tname .$TESTSUFFIX
if [ -f $tf ] ; then
run_testcase $tf
else
$ECHO " Test case $tf does not exist. "
fi
shift
done
2000-11-21 07:38:08 +01:00
fi
2000-07-31 21:29:14 +02:00
2000-10-10 10:42:07 +02:00
$ECHO $DASH72
$ECHO
2000-12-28 08:26:37 +01:00
2001-01-03 15:54:46 +01:00
if [ -z " $DO_GDB " ] && [ -z " $USE_RUNNING_SERVER " ] && [ -z " $DO_DDD " ]
2000-11-21 07:38:08 +01:00
then
mysql_stop
fi
2000-07-31 21:29:14 +02:00
2001-09-28 07:05:54 +02:00
stop_manager
2000-07-31 21:29:14 +02:00
report_stats
2000-10-10 10:42:07 +02:00
$ECHO
2000-07-31 21:29:14 +02:00
2000-10-12 15:51:19 +02:00
[ " $DO_GCOV " ] && gcov_collect # collect coverage information
2001-04-10 02:25:06 +02:00
[ " $DO_GPROF " ] && gprof_collect # collect coverage information
2000-10-12 01:01:58 +02:00
2000-07-31 21:29:14 +02:00
exit 0