2003-11-28 11:18:13 +01: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>
2003-11-20 19:55:07 +01:00
# Slightly 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
2004-12-16 20:26:24 +01:00
# List of failed cases (--force) backported from 4.1 by Joerg
2000-12-30 16:24:31 +01:00
# :-)
2000-07-31 21:29:14 +02:00
#++
# Access Definitions
#--
DB = test
2004-03-19 13:52:48 +01: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
2003-11-02 13:00:25 +01:00
LOCAL_SOCKET = @MYSQL_UNIX_ADDR@
2004-06-18 02:02:29 +02:00
MYSQL_TCP_PORT = @MYSQL_TCP_PORT@
2000-07-31 21:29:14 +02:00
2003-08-22 03:07:40 +02:00
# For query_cache test
2004-03-19 17:26:02 +01:00
case ` uname` in
2004-03-04 17:16:10 +01:00
SCO_SV | UnixWare | OpenUNIX )
# do nothing (Causes strange behavior)
; ;
2004-03-31 02:32:38 +02:00
QNX)
# do nothing (avoid error message)
; ;
2004-03-04 17:16:10 +01:00
* )
ulimit -n 1024
; ;
esac
2003-08-22 03:07:40 +02:00
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-02 16:52:22 +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
2005-06-10 21:29:37 +02:00
MYSQL_TEST_WINDIR = $MYSQL_TEST_DIR
export MYSQL_TEST_DIR MYSQL_TEST_WINDIR
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 = " "
2005-01-01 21:13:09 +01:00
MYSQLD_SRC_DIRS = " strings mysys include extra regex myisam \
2000-10-12 01:01:58 +02:00
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
#
2005-02-08 00:17:30 +01:00
LD_LIBRARY_PATH = " $BASEDIR /lib: $BASEDIR /libmysql/.libs: $BASEDIR /zlib/.libs: $LD_LIBRARY_PATH "
DYLD_LIBRARY_PATH = " $BASEDIR /lib: $BASEDIR /libmysql/.libs: $BASEDIR /zlib/.libs: $DYLD_LIBRARY_PATH "
2003-12-30 12:14:21 +01:00
export LD_LIBRARY_PATH DYLD_LIBRARY_PATH
2000-11-18 07:35:40 +01:00
2005-01-25 19:08:16 +01:00
#
# Allow anyone in the group to see the generated database files
#
UMASK = 0660
UMASK_DIR = 0770
export UMASK UMASK_DIR
2000-12-13 17:58:26 +01:00
MASTER_RUNNING = 0
2004-09-28 19:04:30 +02:00
MASTER1_RUNNING = 0
2001-01-04 01:56:38 +01:00
MASTER_MYPORT = 9306
2000-12-13 17:58:26 +01:00
SLAVE_RUNNING = 0
2004-09-28 19:04:30 +02:00
SLAVE_MYPORT = 9308 # leave room for 2 masters for cluster tests
2002-03-02 05:14:13 +01:00
MYSQL_MANAGER_PORT = 9305 # needs to be out of the way of slaves
2004-06-24 15:28:15 +02:00
NDBCLUSTER_PORT = 9350
2002-03-02 05:14:13 +01:00
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 =
2004-09-28 16:27:50 +02:00
FAILED_CASES =
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 = ""
2003-12-21 18:39:32 +01:00
EXTRA_MYSQLDUMP_OPT = ""
2005-03-15 19:46:43 +01:00
EXTRA_MYSQLSHOW_OPT = ""
2003-12-21 18:39:32 +01:00
EXTRA_MYSQLBINLOG_OPT = ""
2005-01-26 10:19:28 +01:00
USE_RUNNING_SERVER = 0
2005-03-07 13:42:01 +01:00
USE_NDBCLUSTER = @USE_NDBCLUSTER@
2004-04-14 17:16:31 +02:00
USE_RUNNING_NDBCLUSTER = ""
2005-01-28 00:35:26 +01:00
USE_PURIFY = ""
PURIFY_LOGS = ""
2001-01-04 01:56:38 +01:00
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
2004-11-11 17:06:47 +01:00
SLEEP_TIME_FOR_SECOND_MASTER = 400
2001-12-17 23:23:56 +01:00
SLEEP_TIME_FOR_FIRST_SLAVE = 400
2005-03-22 15:12:05 +01:00
SLEEP_TIME_FOR_SECOND_SLAVE = 300
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 = ""
2004-09-28 18:25:57 +02:00
USE_TIMER = ""
2004-09-27 17:01:26 +02:00
USE_EMBEDDED_SERVER = ""
2005-01-28 00:35:26 +01:00
TEST_MODE = ""
2001-01-04 01:56:38 +01:00
2005-01-21 12:15:14 +01:00
NDB_MGM_EXTRA_OPTS =
2005-01-19 10:00:41 +01:00
NDB_MGMD_EXTRA_OPTS =
NDBD_EXTRA_OPTS =
2001-01-04 01:56:38 +01:00
while test $# -gt 0; do
case " $1 " in
2005-01-28 00:35:26 +01:00
--embedded-server)
USE_EMBEDDED_SERVER = 1
USE_MANAGER = 0 NO_SLAVE = 1
2005-02-04 17:24:18 +01:00
USE_RUNNING_SERVER = 0
2005-01-28 00:35:26 +01:00
TEST_MODE = " $TEST_MODE embedded " ; ;
--purify)
USE_PURIFY = 1
USE_MANAGER = 0
2005-02-04 17:24:18 +01:00
USE_RUNNING_SERVER = 0
2005-01-28 00:35:26 +01:00
TEST_MODE = " $TEST_MODE purify " ; ;
2001-01-17 02:15:20 +01:00
--user= *) DBUSER = ` $ECHO " $1 " | $SED -e "s;--user=;;" ` ; ;
--force) FORCE = 1 ; ;
2004-09-28 18:25:57 +02:00
--timer) USE_TIMER = 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=;;" ` ; ;
2005-01-26 10:19:28 +01:00
--local) USE_RUNNING_SERVER = 0 ; ;
--extern) USE_RUNNING_SERVER = 1 ; ;
2004-04-14 17:16:31 +02:00
--with-ndbcluster)
2004-04-15 12:03:13 +02:00
USE_NDBCLUSTER = "--ndbcluster" ; ;
2004-09-29 01:40:20 +02:00
--ndb-connectstring= *)
2004-04-15 12:03:13 +02:00
USE_NDBCLUSTER = "--ndbcluster" ;
2004-09-29 01:40:20 +02:00
USE_RUNNING_NDBCLUSTER = ` $ECHO " $1 " | $SED -e "s;--ndb-connectstring=;;" ` ; ;
2005-01-21 12:15:14 +01:00
--ndb_mgm-extra-opts= *)
NDB_MGM_EXTRA_OPTS = ` $ECHO " $1 " | $SED -e "s;--ndb_mgm-extra-opts=;;" ` ; ;
2005-01-19 10:00:41 +01:00
--ndb_mgmd-extra-opts= *)
NDB_MGMD_EXTRA_OPTS = ` $ECHO " $1 " | $SED -e "s;--ndb_mgmd-extra-opts=;;" ` ; ;
--ndbd-extra-opts= *)
NDBD_EXTRA_OPTS = ` $ECHO " $1 " | $SED -e "s;--ndbd-extra-opts=;;" ` ; ;
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=;;" ` ; ;
2004-06-24 15:28:15 +02:00
--ndbcluster_port= *) NDBCLUSTER_PORT = ` $ECHO " $1 " | $SED -e "s;--ndbcluster_port=;;" ` ; ;
2001-08-31 19:22:18 +02:00
--with-openssl)
EXTRA_MASTER_MYSQLD_OPT = " $EXTRA_MASTER_MYSQLD_OPT \
2005-06-09 15:19:10 +02:00
--ssl-ca= $MYSQL_TEST_DIR /std_data/cacert.pem \
--ssl-cert= $MYSQL_TEST_DIR /std_data/server-cert.pem \
--ssl-key= $MYSQL_TEST_DIR /std_data/server-key.pem"
2001-08-31 19:22:18 +02:00
EXTRA_SLAVE_MYSQLD_OPT = " $EXTRA_SLAVE_MYSQLD_OPT \
2005-06-09 15:19:10 +02:00
--ssl-ca= $MYSQL_TEST_DIR /std_data/cacert.pem \
--ssl-cert= $MYSQL_TEST_DIR /std_data/server-cert.pem \
--ssl-key= $MYSQL_TEST_DIR /std_data/server-key.pem"
2005-06-24 11:56:20 +02:00
MYSQL_TEST_SSL_OPTS = " --ssl-ca= $MYSQL_TEST_DIR /std_data/cacert.pem \
2005-06-09 15:19:10 +02:00
--ssl-cert= $MYSQL_TEST_DIR /std_data/client-cert.pem \
--ssl-key= $MYSQL_TEST_DIR /std_data/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
2005-01-26 10:19:28 +01:00
USE_RUNNING_SERVER = 0
2001-11-08 00:17:40 +01:00
; ;
2001-11-11 06:24:12 +01:00
--start-and-exit)
START_AND_EXIT = 1
2001-12-10 17:16:51 +01:00
; ;
2003-11-02 13:00:25 +01:00
--socket= *) LOCAL_SOCKET = ` $ECHO " $1 " | $SED -e "s;--socket=;;" ` ; ;
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=;;" ` ; ;
2004-05-03 12:10:06 +02:00
--start-from= * ) START_FROM = ` $ECHO " $1 " | $SED -e "s;--start-from=;;" ` ; ;
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 " ; ;
2004-09-24 18:58:25 +02:00
--small-bench)
DO_SMALL_BENCH = 1
DO_BENCH = 1
NO_SLAVE = 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
; ;
2004-10-26 18:30:01 +02:00
--ps-protocol)
2005-01-28 00:35:26 +01:00
TEST_MODE = " $TEST_MODE ps-protocol " EXTRA_MYSQL_TEST_OPT = " $EXTRA_MYSQL_TEST_OPT $1 " ; ;
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
2004-03-10 12:46:11 +01:00
EXTRA_MASTER_MYSQLD_OPT = " $EXTRA_MASTER_MYSQLD_OPT --gdb "
EXTRA_SLAVE_MYSQLD_OPT = " $EXTRA_SLAVE_MYSQLD_OPT --gdb "
2001-12-13 01:31:19 +01:00
# This needs to be checked properly
# USE_MANAGER=1
2005-01-26 10:19:28 +01:00
USE_RUNNING_SERVER = 0
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
2005-01-26 10:19:28 +01:00
USE_RUNNING_SERVER = 0
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
2005-01-26 10:19:28 +01:00
USE_RUNNING_SERVER = 0
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
; ;
2003-11-04 13:59:38 +01:00
--valgrind | --valgrind-all)
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
2004-08-23 16:15:57 +02:00
$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://valgrind.kde.org ."
2003-10-30 16:12:21 +01:00
exit 1
fi
2004-08-23 16:15:57 +02:00
# >=2.1.2 requires the --tool option, some versions write to stdout, some to stderr
valgrind --help 2>& 1 | grep "\-\-tool" > /dev/null && VALGRIND = " $VALGRIND --tool=memcheck "
2005-04-06 16:22:21 +02:00
VALGRIND = " $VALGRIND --alignment=8 --leak-check=yes --num-callers=16 --suppressions= $CWD /valgrind.supp "
2003-08-19 15:00:12 +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-12-02 16:52:22 +01:00
SLEEP_TIME_FOR_DELETE = 60
2005-01-26 10:19:28 +01:00
USE_RUNNING_SERVER = 0
2003-11-04 13:59:38 +01:00
if test " $1 " = "--valgrind-all"
then
VALGRIND = " $VALGRIND -v --show-reachable=yes "
fi
2002-10-29 20:59:03 +01:00
; ;
--valgrind-options= *)
TMP = ` $ECHO " $1 " | $SED -e "s;--valgrind-options=;;" `
VALGRIND = " $VALGRIND $TMP "
; ;
2005-03-16 00:15:45 +01:00
--skip-ndbcluster | --skip-ndb)
2005-03-07 14:28:09 +01:00
USE_NDBCLUSTER = ""
2005-03-16 14:32:43 +01:00
EXTRA_MASTER_MYSQLD_OPT = " $EXTRA_MASTER_MYSQLD_OPT --skip-ndbcluster "
EXTRA_SLAVE_MYSQLD_OPT = " $EXTRA_SLAVE_MYSQLD_OPT --skip-ndbcluster "
2005-03-07 14:28:09 +01:00
; ;
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)
2005-02-09 16:23:22 +01:00
EXTRA_MASTER_MYSQLD_TRACE = " \
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"
2003-12-21 18:39:32 +01:00
EXTRA_MYSQLDUMP_OPT = " $EXTRA_MYSQLDUMP_OPT \
--debug= d:t:A,$MYSQL_TEST_DIR /var/log/mysqldump.trace"
2005-03-15 19:46:43 +01:00
EXTRA_MYSQLSHOW_OPT = " $EXTRA_MYSQLSHOW_OPT \
--debug= d:t:A,$MYSQL_TEST_DIR /var/log/mysqlshow.trace"
2003-12-21 18:39:32 +01:00
EXTRA_MYSQLBINLOG_OPT = " $EXTRA_MYSQLBINLOG_OPT \
--debug= d:t:A,$MYSQL_TEST_DIR /var/log/mysqlbinlog.trace"
2005-02-22 11:51:23 +01:00
EXTRA_MYSQL_CLIENT_TEST_OPT = " --debug=d:t:A, $MYSQL_TEST_DIR /var/log/mysql_client_test.trace "
2001-01-04 01:56:38 +01:00
; ;
2002-12-05 02:40:33 +01:00
--fast)
FAST_START = 1
; ;
2005-01-15 11:28:38 +01:00
--use-old-data)
USE_OLD_DATA = 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
2005-01-28 00:35:26 +01:00
if [ -z " $TEST_MODE " ] ; then
TEST_MODE = "default"
else
# Remove the leading space if any
TEST_MODE = ` echo $TEST_MODE | sed 's/^ *//' `
fi
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 "
2004-09-28 21:12:44 +02:00
MASTER_MYSOCK1 = $MYSQL_MYSOCK "1"
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 "
2003-11-03 13:01:59 +01:00
SMALL_SERVER = "--key_buffer_size=1M --sort_buffer=256K --max_heap_table_size=1M"
2001-01-07 23:04:30 +01:00
2005-02-18 10:57:10 +01:00
export MASTER_MYPORT SLAVE_MYPORT MYSQL_TCP_PORT MASTER_MYSOCK MASTER_MYSOCK1
2001-04-18 07:06:00 +02:00
2005-02-09 19:29:37 +01:00
NDBCLUSTER_OPTS = " --port= $NDBCLUSTER_PORT --data-dir= $MYSQL_TEST_DIR /var --ndb_mgm-extra-opts= $NDB_MGM_EXTRA_OPTS --ndb_mgmd-extra-opts= $NDB_MGMD_EXTRA_OPTS --ndbd-extra-opts= $NDBD_EXTRA_OPTS "
2005-01-24 13:06:27 +01:00
NDB_BACKUP_DIR = $MYSQL_TEST_DIR /var/ndbcluster-$NDBCLUSTER_PORT
2005-02-01 17:08:39 +01:00
NDB_TOOLS_OUTPUT = $MYSQL_TEST_DIR /var/log/ndb_tools.log
2004-11-10 17:05:28 +01:00
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`
2004-09-27 17:01:26 +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
2004-09-27 17:01:26 +02:00
if [ " x $USE_EMBEDDED_SERVER " = "x1" ] ; then
2005-01-24 16:56:17 +01:00
if [ -f " $BASEDIR /libmysqld/examples/mysqltest_embedded " ] ; then
MYSQL_TEST = " $VALGRIND $BASEDIR /libmysqld/examples/mysqltest_embedded "
2004-09-27 17:01:26 +02:00
else
2005-01-24 16:56:17 +01:00
echo "Fatal error: Cannot find embedded server 'mysqltest_embedded'" 1>& 2
2004-09-27 17:01:26 +02:00
exit 1
fi
2005-01-24 16:56:17 +01:00
MYSQL_CLIENT_TEST = " $BASEDIR /libmysqld/examples/mysql_client_test_embedded "
2001-07-13 13:58:25 +02:00
else
2005-01-28 00:35:26 +01:00
MYSQLD = " $BASEDIR /sql/mysqld "
if [ -n " $VALGRIND " ] ; then
MYSQLD = " $VALGRIND $MYSQLD "
fi
2004-09-27 17:01:26 +02:00
if [ -f " $BASEDIR /client/.libs/lt-mysqltest " ] ; then
MYSQL_TEST = " $BASEDIR /client/.libs/lt-mysqltest "
elif [ -f " $BASEDIR /client/.libs/mysqltest " ] ; then
MYSQL_TEST = " $BASEDIR /client/.libs/mysqltest "
else
MYSQL_TEST = " $BASEDIR /client/mysqltest "
fi
2005-01-24 16:56:17 +01:00
MYSQL_CLIENT_TEST = " $BASEDIR /tests/mysql_client_test "
2001-07-13 13:58:25 +02:00
fi
2003-09-08 07:53:51 +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-08 07:53:51 +02:00
else
2003-10-07 14:44:31 +02:00
MYSQL_DUMP = " $BASEDIR /client/mysqldump "
2003-09-08 07:53:51 +02:00
fi
2005-03-15 19:46:43 +01:00
if [ -f " $BASEDIR /client/.libs/mysqlshow " ] ; then
MYSQL_SHOW = " $BASEDIR /client/.libs/mysqlshow "
else
MYSQL_SHOW = " $BASEDIR /client/mysqlshow "
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-10-08 11:01:58 +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
2004-03-19 13:52:48 +01:00
CLIENT_BINDIR = " $BASEDIR /client "
MYSQLADMIN = " $CLIENT_BINDIR /mysqladmin "
2003-01-07 15:53:10 +01:00
WAIT_PID = " $BASEDIR /extra/mysql_waitpid "
2005-04-04 01:49:10 +02:00
MYSQL_MANAGER_CLIENT = " $CLIENT_BINDIR /mysqltestmanagerc "
MYSQL_MANAGER = " $BASEDIR /tools/mysqltestmanager "
MYSQL_MANAGER_PWGEN = " $CLIENT_BINDIR /mysqltestmanager-pwgen "
2004-03-19 13:52:48 +01:00
MYSQL = " $CLIENT_BINDIR /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"
2004-03-10 19:54:07 +01:00
MYSQL_FIX_SYSTEM_TABLES = " $BASEDIR /scripts/mysql_fix_privilege_tables "
2004-09-13 14:27:58 +02:00
NDB_TOOLS_DIR = " $BASEDIR /ndb/tools "
2005-01-20 13:45:42 +01:00
NDB_MGM = " $BASEDIR /ndb/src/mgmclient/ndb_mgm "
2005-01-28 00:35:26 +01:00
if [ -n " $USE_PURIFY " ] ; then
2005-05-15 06:59:34 +02:00
PSUP = " $MYSQL_TEST_DIR /suppress.purify "
2005-01-28 00:35:26 +01:00
PURIFYOPTIONS = " -windows=no -log-file=%v.purifylog -append-logfile -add-suppression-files= $PSUP "
if [ -f " ${ MYSQL_TEST } -purify " ] ; then
MYSQL_TEST = " ${ MYSQL_TEST } -purify "
PLOG = " $MYSQL_TEST .purifylog "
if [ -f $PLOG ] ; then
mv $PLOG $PLOG .$$
fi
PURIFY_LOGS = " $PLOG "
fi
if [ -f " ${ MYSQLD } -purify " ] ; then
MYSQLD = " ${ MYSQLD } -purify "
PLOG = " $MYSQLD .purifylog "
if [ -f $PLOG ] ; then
mv $PLOG $PLOG .$$
fi
PURIFY_LOGS = " $PURIFY_LOGS $PLOG "
fi
fi
2000-12-07 15:54:59 +01:00
else
2005-01-24 16:56:17 +01:00
# We have a binary installation. Note that this can be both from
# unpacking a MySQL AB binary distribution (created using
# "scripts/make_binary_distribution", and from a "make install".
# Unfortunately the structure differs a bit, for a "make install"
# currently all binaries are in "bin", for a MySQL AB packaging
# some are in "tests".
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
2004-03-19 13:52:48 +01:00
CLIENT_BINDIR = " $BASEDIR /bin "
2005-01-14 18:57:50 +01:00
if test -d " $BASEDIR /tests "
then
TESTS_BINDIR = " $BASEDIR /tests "
else
TESTS_BINDIR = " $BASEDIR /bin "
fi
2004-03-19 13:52:48 +01:00
MYSQL_TEST = " $CLIENT_BINDIR /mysqltest "
MYSQL_DUMP = " $CLIENT_BINDIR /mysqldump "
2005-03-15 19:46:43 +01:00
MYSQL_SHOW = " $CLIENT_BINDIR /mysqlshow "
2004-03-19 13:52:48 +01:00
MYSQL_BINLOG = " $CLIENT_BINDIR /mysqlbinlog "
MYSQLADMIN = " $CLIENT_BINDIR /mysqladmin "
WAIT_PID = " $CLIENT_BINDIR /mysql_waitpid "
2005-04-04 01:49:10 +02:00
MYSQL_MANAGER = " $CLIENT_BINDIR /mysqltestmanager "
MYSQL_MANAGER_CLIENT = " $CLIENT_BINDIR /mysqltestmanagerc "
MYSQL_MANAGER_PWGEN = " $CLIENT_BINDIR /mysqltestmanager-pwgen "
2004-03-19 13:52:48 +01:00
MYSQL = " $CLIENT_BINDIR /mysql "
2004-03-12 00:10:22 +01:00
INSTALL_DB = "./install_test_db --bin"
2004-03-19 13:52:48 +01:00
MYSQL_FIX_SYSTEM_TABLES = " $CLIENT_BINDIR /mysql_fix_privilege_tables "
2004-09-13 14:27:58 +02:00
NDB_TOOLS_DIR = " $CLIENT_BINDIR "
2005-01-20 13:45:42 +01:00
NDB_MGM = " $CLIENT_BINDIR /ndb_mgm "
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 "
2005-01-24 16:56:17 +01:00
fi
if [ " x $USE_EMBEDDED_SERVER " = "x1" ] ; then
if [ -f " $CLIENT_BINDIR /mysqltest_embedded " ] ; then
MYSQL_TEST = " $VALGRIND $CLIENT_BINDIR /mysqltest_embedded "
else
echo "Fatal error: Cannot find embedded server 'mysqltest_embedded'" 1>& 2
exit 1
fi
if [ -d " $BASEDIR /tests/mysql_client_test_embedded " ] ; then
MYSQL_CLIENT_TEST = " $TESTS_BINDIR /mysql_client_test_embedded "
else
MYSQL_CLIENT_TEST = " $CLIENT_BINDIR /mysql_client_test_embedded "
fi
else
MYSQL_TEST = " $CLIENT_BINDIR /mysqltest "
MYSQL_CLIENT_TEST = " $CLIENT_BINDIR /mysql_client_test "
fi
2000-12-07 15:54:59 +01:00
fi
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
2005-01-26 10:19:28 +01:00
USE_RUNNING_SERVER = 0
2001-01-03 15:54:46 +01:00
fi
2005-01-26 10:19:28 +01:00
if [ $USE_RUNNING_SERVER -eq 1 ]
2001-01-04 01:56:38 +01:00
then
2003-11-02 13:00:25 +01:00
MASTER_MYSOCK = $LOCAL_SOCKET ;
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
2004-03-19 13:52:48 +01:00
# 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 "
2001-01-03 15:54:46 +01:00
fi
2005-02-22 11:51:23 +01:00
MYSQL_CLIENT_TEST = " $MYSQL_CLIENT_TEST --no-defaults --testcase --user=root --socket= $MASTER_MYSOCK --port= $MYSQL_TCP_PORT --silent $EXTRA_MYSQL_CLIENT_TEST_OPT "
2005-04-28 02:50:48 +02:00
# Need to pass additional arguments to MYSQL_CLIENT_TEST for embedded server
# -A marks each argument for passing to the function which initializes the
# embedded library
if [ " x $USE_EMBEDDED_SERVER " = "x1" ] ; then
MYSQL_CLIENT_TEST = " $MYSQL_CLIENT_TEST -A --language= $LANGUAGE -A --datadir= $SLAVE_MYDDIR -A --character-sets-dir= $CHARSETSDIR "
fi
2005-06-21 14:19:56 +02:00
# Save path and name of mysqldump
MYSQL_DUMP_DIR = " $MYSQL_DUMP "
export MYSQL_DUMP_DIR
2004-09-03 01:25:27 +02:00
MYSQL_DUMP = " $MYSQL_DUMP --no-defaults -uroot --socket= $MASTER_MYSOCK --password= $DBPASSWD $EXTRA_MYSQLDUMP_OPT "
2005-03-15 19:46:43 +01:00
MYSQL_SHOW = " $MYSQL_SHOW -uroot --socket= $MASTER_MYSOCK --password= $DBPASSWD $EXTRA_MYSQLSHOW_OPT "
2005-02-03 16:22:16 +01:00
MYSQL_BINLOG = " $MYSQL_BINLOG --no-defaults --local-load= $MYSQL_TMP_DIR --character-sets-dir= $CHARSETSDIR $EXTRA_MYSQLBINLOG_OPT "
2004-09-03 01:25:27 +02:00
MYSQL_FIX_SYSTEM_TABLES = " $MYSQL_FIX_SYSTEM_TABLES --no-defaults --host=localhost --port= $MASTER_MYPORT --socket= $MASTER_MYSOCK --user=root --password= $DBPASSWD --basedir= $BASEDIR --bindir= $CLIENT_BINDIR --verbose "
2005-05-18 10:57:07 +02:00
MYSQL = " $MYSQL --no-defaults --host=localhost --port= $MASTER_MYPORT --socket= $MASTER_MYSOCK --user=root --password= $DBPASSWD "
2005-03-15 19:46:43 +01:00
export MYSQL MYSQL_DUMP MYSQL_SHOW MYSQL_BINLOG MYSQL_FIX_SYSTEM_TABLES
2005-01-24 16:56:17 +01:00
export CLIENT_BINDIR MYSQL_CLIENT_TEST CHARSETSDIR
2004-09-13 14:27:58 +02:00
export NDB_TOOLS_DIR
2005-01-20 13:45:42 +01:00
export NDB_MGM
2005-01-24 13:06:27 +01:00
export NDB_BACKUP_DIR
2005-02-01 17:08:39 +01:00
export NDB_TOOLS_OUTPUT
2005-01-28 00:35:26 +01:00
export PURIFYOPTIONS
2005-02-07 17:46:52 +01:00
NDB_STATUS_OK = 1
export NDB_STATUS_OK
2004-09-03 01:25:27 +02: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 "
2004-09-28 18:25:57 +02:00
if [ x$USE_TIMER = x1 ] ; then
MYSQL_TEST_ARGS = " $MYSQL_TEST_ARGS --timer-file= $MY_LOG_DIR /timer "
fi
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
2005-03-15 19:46:43 +01:00
export MYSQL MYSQL_DUMP MYSQL_SHOW MYSQL_BINLOG MYSQL_FIX_SYSTEM_TABLES CLIENT_BINDIR MASTER_MYSOCK
2004-07-15 03:19:07 +02: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"
2003-11-18 12:47:27 +01:00
echo "http://www.mysql.com/doc/en/Reporting_mysqltest_bugs.html"
2001-05-29 12:46:17 +02:00
echo "to find the reason to this problem and how to report this."
2004-07-31 22:39:10 +02:00
echo ""
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
2004-01-11 18:15:19 +01:00
$ECHO "(the last lines may be the most important ones)"
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 ] "
}
2005-01-25 17:32:09 +01:00
disable_test( ) {
USERT = " ...."
SYST = " ...."
REALT = " ...."
pname = ` $ECHO " $1 " | $CUT -c 1-24`
RES = " $pname "
skip_inc
$ECHO " $RES $RES_SPACE [ disabled ] $2 "
}
2005-01-31 10:24:33 +01:00
2005-01-28 00:35:26 +01:00
report_current_test ( ) {
tname = $1
echo " CURRENT_TEST: $tname " >> $MASTER_MYERR
if [ -n " $PURIFY_LOGS " ] ; then
for log in $PURIFY_LOGS
do
echo " CURRENT_TEST: $tname " >> $log
done
fi
}
2005-01-31 10:24:33 +01:00
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 `
2005-03-03 13:04:44 +01:00
$ECHO " Failed ${ TOT_FAIL } / ${ TOT_TEST } tests, ${ whole } . ${ deci } % were 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"
2004-04-08 12:58:06 +02:00
$ECHO "http://www.mysql.com/doc/en/MySQL_test_suite.html"
2000-07-31 21:29:14 +02:00
fi
2003-01-28 07:38:28 +01:00
2005-01-26 10:19:28 +01:00
if [ $USE_RUNNING_SERVER -eq 0 ]
2003-02-10 16:03:27 +01:00
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
2004-06-23 15:44:34 +02:00
$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' \
2003-05-15 18:35:39 +02:00
$MY_LOG_DIR /*.err \
| $SED -e 's!Warning: Table:.* on rename!!g' \
> $MY_LOG_DIR /warnings.tmp
2003-01-28 07:38:28 +01:00
found_error = 0
# Find errors
2005-06-05 16:01:20 +02:00
for i in "^Warning:" "^Error:" "^==.* at 0x" "InnoDB: Warning"
2003-01-28 07:38:28 +01:00
do
2003-02-10 16:59:16 +01:00
if $GREP " $i " $MY_LOG_DIR /warnings.tmp >> $MY_LOG_DIR /warnings
2003-01-28 07:38:28 +01:00
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"
2005-01-15 11:28:38 +01:00
if [ -z " $USE_OLD_DATA " ] ; then
$RM -rf $MASTER_MYDDIR $MASTER_MYDDIR "1"
$ECHO "Installing Master Databases"
$INSTALL_DB
if [ $? != 0 ] ; then
2000-11-18 07:35:40 +01:00
error "Could not install master test DBs"
2005-01-15 11:28:38 +01:00
exit 1
fi
2000-11-18 07:35:40 +01:00
fi
2004-09-28 19:04:30 +02:00
if [ ! -z " $USE_NDBCLUSTER " ]
then
$ECHO "Installing Master Databases 1"
$INSTALL_DB -1
if [ $? != 0 ] ; then
error "Could not install master test DBs 1"
exit 1
fi
fi
2000-12-28 08:26:37 +01:00
$ECHO "Installing Slave Databases"
2005-01-15 11:28:38 +01:00
$RM -rf $SLAVE_MYDDIR $MY_LOG_DIR /*
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
2003-07-18 11:11:01 +02:00
echo $@ | /bin/sh >> $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
2003-11-03 13:01:59 +01:00
def_exec $ident " $@ "
2001-09-28 07:05:54 +02:00
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
2004-09-28 19:04:30 +02:00
$MYSQLADMIN --no-defaults -uroot --socket= $MYSQL_TMP_DIR /$ident .sock$3 --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
2004-09-28 19:04:30 +02:00
$MYSQLADMIN --no-defaults -uroot --socket= $MYSQL_TMP_DIR /$ident .sock$3 --connect_timeout= 1 ping >> $MYSQL_MANAGER_LOG 2>& 1
2002-12-05 02:40:33 +01:00
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"
}
2004-10-04 02:10:33 +02:00
start_ndbcluster( )
{
if [ ! -z " $USE_NDBCLUSTER " ]
then
2005-02-01 17:16:05 +01:00
rm -f $NDB_TOOLS_OUTPUT
2004-10-04 02:10:33 +02:00
if [ -z " $USE_RUNNING_NDBCLUSTER " ]
then
echo "Starting ndbcluster"
if [ " $DO_BENCH " = 1 ]
then
2004-11-10 17:05:28 +01:00
NDBCLUSTER_EXTRA_OPTS = ""
2004-10-04 02:10:33 +02:00
else
2004-11-10 17:05:28 +01:00
NDBCLUSTER_EXTRA_OPTS = "--small"
2004-10-04 02:10:33 +02:00
fi
2005-02-07 17:46:52 +01:00
./ndb/ndbcluster $NDBCLUSTER_OPTS $NDBCLUSTER_EXTRA_OPTS --initial || NDB_STATUS_OK = 0
if [ x$NDB_STATUS_OK != x1 ] ; then
2005-01-20 20:27:17 +01:00
if [ x$FORCE != x1 ] ; then
exit 1
fi
2005-02-07 17:46:52 +01:00
USE_NDBCLUSTER =
return
2005-01-20 20:27:17 +01:00
fi
2005-02-07 17:46:52 +01:00
2004-10-04 15:53:36 +02:00
NDB_CONNECTSTRING = " host=localhost: $NDBCLUSTER_PORT "
2004-10-04 02:10:33 +02:00
else
2004-10-04 15:53:36 +02:00
NDB_CONNECTSTRING = " $USE_RUNNING_NDBCLUSTER "
echo " Using ndbcluster at $NDB_CONNECTSTRING "
2004-10-04 02:10:33 +02:00
fi
2004-10-04 15:53:36 +02:00
USE_NDBCLUSTER = " $USE_NDBCLUSTER --ndb-connectstring=\" $NDB_CONNECTSTRING \" "
export NDB_CONNECTSTRING
2004-10-04 02:10:33 +02:00
fi
}
stop_ndbcluster( )
{
if [ ! -z " $USE_NDBCLUSTER " ]
then
if [ -z " $USE_RUNNING_NDBCLUSTER " ]
then
# Kill any running ndbcluster stuff
2004-11-10 17:05:28 +01:00
./ndb/ndbcluster $NDBCLUSTER_OPTS --stop
2004-10-04 02:10:33 +02:00
fi
fi
}
2004-09-27 17:01:26 +02:00
# The embedded server needs the cleanup so we do some of the start work
# but stop before actually running mysqld or anything.
2001-09-28 07:05:54 +02:00
2000-11-21 07:38:08 +01:00
start_master( )
{
2004-09-28 19:04:30 +02:00
eval " this_master_running=\$MASTER $1 _RUNNING "
if [ x$this_master_running = x1 ] || [ x$LOCAL_MASTER = x1 ] ; then
2001-12-10 17:16:51 +01:00
return
fi
2004-06-20 19:11:02 +02:00
# Remove stale binary logs except for 2 tests which need them
if [ " $tname " != "rpl_crash_binlog_ib_1b" ] && [ " $tname " != "rpl_crash_binlog_ib_2b" ] && [ " $tname " != "rpl_crash_binlog_ib_3b" ]
then
2004-09-28 19:04:30 +02:00
$RM -f $MYSQL_TEST_DIR /var/log/master-bin$1 .*
2004-06-20 19:11:02 +02:00
fi
2003-03-03 14:57:02 +01:00
# Remove old master.info and relay-log.info files
2004-09-28 19:04:30 +02:00
$RM -f $MYSQL_TEST_DIR /var/master-data$1 /master.info $MYSQL_TEST_DIR /var/master-data$1 /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
2004-09-28 19:04:30 +02:00
if [ -n " $1 " ] ; then
id = ` $EXPR $1 + 101` ;
this_master_myport = ` $EXPR $MASTER_MYPORT + $1 `
2004-11-03 12:43:46 +01:00
NOT_FIRST_MASTER_EXTRA_OPTS = "--skip-innodb"
2005-02-18 10:57:10 +01:00
eval " MASTER_MYPORT $1 = $this_master_myport "
export MASTER_MYPORT$1
2004-09-28 19:04:30 +02:00
else
id = 1;
this_master_myport = $MASTER_MYPORT
2004-11-03 12:43:46 +01:00
NOT_FIRST_MASTER_EXTRA_OPTS = ""
2004-09-28 19:04:30 +02:00
fi
2005-02-09 16:23:22 +01:00
if [ -n " $EXTRA_MASTER_MYSQLD_TRACE " ]
then
2005-02-10 14:13:23 +01:00
CURR_MASTER_MYSQLD_TRACE = " $EXTRA_MASTER_MYSQLD_TRACE $1 "
2005-02-09 16:23:22 +01:00
fi
2001-12-10 17:16:51 +01:00
if [ -z " $DO_BENCH " ]
then
2004-09-28 19:04:30 +02:00
master_args = " --no-defaults --log-bin= $MYSQL_TEST_DIR /var/log/master-bin $1 \
--server-id= $id \
2002-02-09 21:58:53 +01:00
--basedir= $MY_BASEDIR \
2004-09-28 19:04:30 +02:00
--port= $this_master_myport \
2002-03-05 13:22:32 +01:00
--local-infile \
2001-12-10 17:16:51 +01:00
--exit-info= 256 \
--core \
2004-04-14 17:16:31 +02:00
$USE_NDBCLUSTER \
2004-09-28 19:04:30 +02:00
--datadir= $MASTER_MYDDIR $1 \
--pid-file= $MASTER_MYPID $1 \
--socket= $MASTER_MYSOCK $1 \
--log= $MASTER_MYLOG $1 \
2001-12-10 17:16:51 +01:00
--character-sets-dir= $CHARSETSDIR \
--default-character-set= $CHARACTER_SET \
--tmpdir= $MYSQL_TMP_DIR \
--language= $LANGUAGE \
2005-04-07 18:24:14 +02:00
--innodb_data_file_path= ibdata1:128M:autoextend \
2003-08-22 03:07:40 +02:00
--open-files-limit= 1024 \
2005-05-05 14:20:53 +02:00
--log-bin-trust-routine-creators \
2002-02-09 21:58:53 +01:00
$MASTER_40_ARGS \
2001-12-10 17:16:51 +01:00
$SMALL_SERVER \
2004-11-03 12:43:46 +01:00
$EXTRA_MASTER_OPT $EXTRA_MASTER_MYSQLD_OPT \
2005-02-10 14:13:23 +01:00
$NOT_FIRST_MASTER_EXTRA_OPTS $CURR_MASTER_MYSQLD_TRACE "
2001-12-10 17:16:51 +01:00
else
2004-09-28 19:04:30 +02:00
master_args = " --no-defaults --log-bin= $MYSQL_TEST_DIR /var/log/master-bin $1 \
--server-id= $id --rpl-recovery-rank= 1 \
2001-12-10 17:16:51 +01:00
--basedir= $MY_BASEDIR --init-rpl-role= master \
2004-09-28 19:04:30 +02:00
--port= $this_master_myport \
2002-03-05 13:22:32 +01:00
--local-infile \
2004-09-28 19:04:30 +02:00
--datadir= $MASTER_MYDDIR $1 \
--pid-file= $MASTER_MYPID $1 \
--socket= $MASTER_MYSOCK $1 \
2001-12-10 17:16:51 +01:00
--character-sets-dir= $CHARSETSDIR \
--default-character-set= $CHARACTER_SET \
--core \
2004-04-14 17:16:31 +02:00
$USE_NDBCLUSTER \
2001-12-10 17:16:51 +01:00
--tmpdir= $MYSQL_TMP_DIR \
--language= $LANGUAGE \
2005-04-07 18:24:14 +02:00
--innodb_data_file_path= ibdata1:128M:autoextend \
2005-05-05 14:20:53 +02:00
--log-bin-trust-routine-creators \
2002-02-09 21:58:53 +01:00
$MASTER_40_ARGS \
2001-12-10 17:16:51 +01:00
$SMALL_SERVER \
2004-11-03 12:43:46 +01:00
$EXTRA_MASTER_OPT $EXTRA_MASTER_MYSQLD_OPT \
$NOT_FIRST_MASTER_EXTRA_OPTS "
2001-12-10 17:16:51 +01:00
fi
2005-05-25 11:10:10 +02:00
CUR_MYERR = $MASTER_MYERR $1
CUR_MYSOCK = $MASTER_MYSOCK $1
2001-12-10 17:16:51 +01:00
2004-09-27 17:01:26 +02:00
# For embedded server we collect the server flags and return
if [ " x $USE_EMBEDDED_SERVER " = "x1" ] ; then
# Add a -A to each argument to pass it to embedded server
EMBEDDED_SERVER_OPTS = ""
for opt in $master_args
do
EMBEDDED_SERVER_OPTS = " $EMBEDDED_SERVER_OPTS -A $opt "
done
EXTRA_MYSQL_TEST_OPT = " $EMBEDDED_SERVER_OPTS "
return
fi
2001-12-10 17:16:51 +01:00
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
2004-09-28 19:04:30 +02:00
sleep_until_file_created $MASTER_MYPID $1 $wait_for_master
2001-12-13 01:31:19 +01:00
wait_for_master = $SLEEP_TIME_FOR_SECOND_MASTER
2004-09-28 19:04:30 +02:00
eval " MASTER $1 _RUNNING=1 "
2000-11-21 07:38:08 +01:00
}
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
2004-06-20 19:11:02 +02:00
# except for too tests which need them
if [ " $tname " != "rpl_crash_binlog_ib_1b" ] && [ " $tname " != "rpl_crash_binlog_ib_2b" ] && [ " $tname " != "rpl_crash_binlog_ib_3b" ]
then
$RM -f $MYSQL_TEST_DIR /var/log/$slave_ident -*bin.*
$RM -f $slave_datadir /master.info $slave_datadir /relay-log.info
fi
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 \
2004-04-16 07:49:50 +02:00
--skip-innodb --skip-ndbcluster --skip-slave-start \
2001-12-10 17:16:51 +01:00
--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 \
2005-05-05 14:20:53 +02:00
--log-bin-trust-routine-creators \
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
2003-08-19 15:00:12 +02:00
$ECHO " set args $slave_args " > $GDB_SLAVE_INIT
2001-12-10 17:16:51 +01:00
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
2004-10-04 02:10:33 +02:00
start_ndbcluster
2001-12-10 17:16:51 +01:00
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 ( )
{
2004-09-28 19:04:30 +02:00
eval " this_master_running=\$MASTER $1 _RUNNING "
if [ x$this_master_running = x1 ]
2000-11-21 07:38:08 +01:00
then
2004-09-27 17:01:26 +02:00
# For embedded server we don't stop anyting but mark that
# MASTER_RUNNING=0 to get cleanup when calling start_master().
if [ x$USE_EMBEDDED_SERVER != x1 ] ; then
2004-09-28 21:22:04 +02:00
pid = ` $CAT $MASTER_MYPID $1 `
2004-09-29 01:40:20 +02:00
manager_term $pid master $1
2004-09-28 21:22:04 +02:00
if [ $? != 0 ] && [ -f $MASTER_MYPID $1 ]
2004-09-27 17:01:26 +02:00
then # try harder!
$ECHO "master not cooperating with mysqladmin, will try manual kill"
kill $pid
2004-09-28 21:22:04 +02:00
sleep_until_file_deleted $pid $MASTER_MYPID $1
if [ -f $MASTER_MYPID $1 ] ; then
2004-09-27 17:01:26 +02:00
$ECHO "master refused to die. Sending SIGKILL"
2004-09-28 21:22:04 +02:00
kill -9 ` $CAT $MASTER_MYPID $1 `
$RM -f $MASTER_MYPID $1
2004-09-27 17:01:26 +02:00
else
$ECHO "master responded to SIGTERM "
fi
2001-12-23 02:03:09 +01:00
else
2004-09-27 17:01:26 +02:00
sleep $SLEEP_TIME_AFTER_RESTART
2001-12-23 02:03:09 +01:00
fi
2000-12-12 20:12:41 +01:00
fi
2004-09-28 19:04:30 +02:00
eval " MASTER $1 _RUNNING=0 "
2000-11-21 07:38:08 +01:00
fi
}
2000-07-31 21:29:14 +02:00
2000-11-21 07:38:08 +01:00
mysql_stop ( )
{
2004-10-05 00:05:15 +02:00
if [ " $MASTER_RUNNING " = 1 ]
then
$ECHO "Ending Tests"
$ECHO "Shutting-down MySQL daemon"
$ECHO ""
stop_master
2004-10-29 18:26:52 +02:00
stop_master 1
2004-10-05 00:05:15 +02:00
$ECHO "Master shutdown finished"
stop_slave
stop_slave 1
stop_slave 2
$ECHO "Slave shutdown finished"
2004-10-29 18:26:52 +02:00
stop_ndbcluster
2004-10-05 00:05:15 +02:00
fi
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
2004-09-27 17:01:26 +02:00
tsrcdir = $TESTDIR /$tname -src
result_file = " r/ $tname .result "
2002-08-22 15:50:58 +02:00
echo $tname > $CURRENT_TEST
2004-12-17 10:19:31 +01:00
SKIP_SLAVE = ` $EXPR \( $tname : rpl \) = 0 \& \( $tname : federated \) = 0`
2003-11-28 11:18:13 +01: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 \) `
2004-05-03 12:10:06 +02:00
fi
if $EXPR " $tname " '<' " $START_FROM " > /dev/null ; then
#skip_test $tname
return
2001-12-10 17:16:51 +01:00
fi
2004-05-03 12:10:06 +02:00
if [ " $SKIP_TEST " ] ; then
if $EXPR \( " $tname " : " $SKIP_TEST " \) > /dev/null ; then
skip_test $tname
return
2001-06-20 00:08:19 +02:00
fi
2004-05-03 12:10:06 +02:00
fi
2001-01-05 12:13:15 +01:00
2004-05-03 12:10:06 +02:00
if [ " $DO_TEST " ] ; then
if $EXPR \( " $tname " : " $DO_TEST " \) > /dev/null ; then
2004-05-03 17:17:50 +02:00
: #empty command to keep some shells happy
2004-05-03 12:10:06 +02:00
else
#skip_test $tname
return
2001-06-27 01:02:33 +02:00
fi
2004-05-03 12:10:06 +02:00
fi
2001-06-27 01:02:33 +02:00
2004-05-03 12:10:06 +02:00
if [ x${ NO_SLAVE } x$SKIP_SLAVE = x1x0 ] ; then
skip_test $tname
2001-01-05 12:13:15 +01:00
return
fi
2005-03-18 16:48:18 +01:00
# if [ -f "$TESTDIR/$tname.disabled" ]
# then
# comment=`$CAT $TESTDIR/$tname.disabled`;
# disable_test $tname "$comment"
# return
# fi
2005-03-16 09:23:38 +01:00
if [ -f " $TESTDIR /disabled.def " ] ; then
comment = ` $GREP " ^ $tname *: * " $TESTDIR /disabled.def` ;
if [ -n " $comment " ]
then
comment = ` echo $comment | sed 's/^[^:]*: *//' `
disable_test $tname " $comment "
return
fi
2005-03-15 19:48:42 +01:00
fi
2004-09-27 17:01:26 +02:00
if [ " x $USE_EMBEDDED_SERVER " != "x1" ] ; then
# 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
fi
# FIXME temporary solution, we will get a new C version of this
# script soon anyway so it is not worth it spending the time
if [ " x $USE_EMBEDDED_SERVER " = "x1" -a -z " $DO_TEST " ] ; then
for t in \
2005-03-30 03:17:46 +02:00
"init_connect" \
"init_file"
2004-09-27 17:01:26 +02:00
do
if [ " $tname " = " $t " ] ; then
skip_test $tname
return
fi
done
fi
2003-06-10 23:29:49 +02:00
2005-01-26 10:19:28 +01:00
if [ $USE_RUNNING_SERVER -eq 0 ] ;
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 = " "
; ;
2004-03-10 19:54:07 +01:00
--result-file= *)
result_file = ` $ECHO " $EXTRA_MASTER_OPT " | $SED -e "s;--result-file=;;" `
2004-09-27 17:01:26 +02:00
result_file = " r/ $result_file .result "
2005-03-31 03:32:44 +02:00
# Note that this must be set to space, not "" for test-reset to
# work
2004-03-10 19:54:07 +01:00
EXTRA_MASTER_OPT = " "
; ;
2003-05-27 15:40:14 +02:00
esac
2001-01-16 11:38:58 +01:00
stop_master
2004-09-28 19:04:30 +02:00
stop_master 1
2005-01-28 00:35:26 +01:00
report_current_test $tname
2001-01-16 11:38:58 +01:00
start_master
2004-09-29 01:40:20 +02:00
if [ -n " $USE_NDBCLUSTER " -a -z " $DO_BENCH " ] ; then
2004-09-28 19:04:30 +02:00
start_master 1
fi
2003-05-27 15:40:14 +02:00
TZ = $MY_TZ ; export TZ
2001-01-16 11:38:58 +01:00
else
2004-09-27 17:01:26 +02:00
# If we had extra master opts to the previous run
# or there is no master running (FIXME strange.....)
# or there is a master init script
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
2004-09-28 19:04:30 +02:00
stop_master 1
2005-01-28 00:35:26 +01:00
report_current_test $tname
2001-01-16 11:38:58 +01:00
start_master
2004-09-29 01:40:20 +02:00
if [ -n " $USE_NDBCLUSTER " -a -z " $DO_BENCH " ] ; then
2004-09-28 19:04:30 +02:00
start_master 1
fi
2003-01-07 15:53:10 +01:00
else
2005-01-28 00:35:26 +01:00
report_current_test $tname
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
2004-09-27 17:01:26 +02:00
# We never start a slave if embedded server is used
if [ " x $USE_EMBEDDED_SERVER " != "x1" ] ; then
do_slave_restart = 0
if [ -f $slave_opt_file ] ;
2001-01-16 11:38:58 +01:00
then
2004-09-27 17:01:26 +02:00
EXTRA_SLAVE_OPT = ` $CAT $slave_opt_file | $SED -e " s;\\ $MYSQL_TEST_DIR ; $MYSQL_TEST_DIR ; " `
2001-12-10 17:16:51 +01:00
do_slave_restart = 1
2004-09-27 17:01:26 +02:00
else
if [ ! -z " $EXTRA_SLAVE_OPT " ] || [ x$SLAVE_RUNNING != x1 ] ;
then
EXTRA_SLAVE_OPT = ""
do_slave_restart = 1
fi
2001-12-10 17:16:51 +01:00
fi
2001-01-16 11:38:58 +01:00
2004-09-27 17:01:26 +02: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 = ""
do_slave_restart = 1
fi
fi
if [ x$do_slave_restart = x1 ] ; then
stop_slave
echo " CURRENT_TEST: $tname " >> $SLAVE_MYERR
start_slave
else
echo " CURRENT_TEST: $tname " >> $SLAVE_MYERR
fi
if [ x$many_slaves = x1 ] ; then
start_slave 1
start_slave 2
fi
2001-10-10 00:43:05 +02:00
fi
2000-12-13 17:58:26 +01:00
fi
2005-01-21 08:41:38 +01:00
if [ " x $START_AND_EXIT " = "x1" ] ; then
echo "Servers started, exiting"
exit
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
2004-09-27 17:01:26 +02:00
mysql_test_args = " -R $result_file $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
2004-09-27 17:01:26 +02:00
TIMER = ""
2004-09-28 18:25:57 +02:00
if [ x$USE_TIMER = x1 -a -f " $MY_LOG_DIR /timer " ] ; then
2004-09-27 17:01:26 +02:00
TIMER = ` cat $MY_LOG_DIR /timer`
TIMER = ` $PRINTF "%13s" $TIMER `
fi
$ECHO " $RES $RES_SPACE [ pass ] $TIMER "
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 ?
2005-05-15 06:59:34 +02:00
if [ $res = 62 ] ; then
2001-07-13 13:58:25 +02:00
skip_inc
$ECHO " $RES $RES_SPACE [ skipped ] "
else
2005-05-15 06:59:34 +02:00
if [ $res -ne 1 ] ; then
2004-01-11 18:15:19 +01:00
$ECHO " mysqltest returned unexpected code $res , it has probably crashed " >> $TIMEFILE
fi
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
2004-09-27 17:01:26 +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
2005-01-05 13:09:31 +01:00
$ECHO " Aborting: $tname failed in $TEST_MODE mode. To continue, re-run with '--force'. "
2000-12-28 08:26:37 +01:00
$ECHO
2005-01-26 10:19:28 +01:00
if [ -z " $DO_GDB " ] && [ $USE_RUNNING_SERVER -eq 0 ] && \
2004-09-27 17:01:26 +02:00
[ -z " $DO_DDD " ] && [ -z " $USE_EMBEDDED_SERVER " ]
2001-01-15 21:56:44 +01:00
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
2004-09-28 16:27:50 +02:00
FAILED_CASES = " $FAILED_CASES $tname "
2005-01-26 10:19:28 +01:00
if [ -z " $DO_GDB " ] && [ $USE_RUNNING_SERVER -eq 0 ] && \
2004-09-27 17:01:26 +02:00
[ -z " $DO_DDD " ] && [ -z " $USE_EMBEDDED_SERVER " ]
2001-01-15 21:56:44 +01:00
then
mysql_restart
fi
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
2005-01-26 10:19:28 +01:00
if [ $USE_RUNNING_SERVER -eq 0 ]
2001-01-07 23:04:30 +01:00
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
2004-10-04 01:41:15 +02:00
$MYSQLADMIN --no-defaults --socket= $MASTER_MYSOCK1 -u root -O connect_timeout = 5 -O shutdown_timeout = 20 shutdown > /dev/null 2>& 1
2002-12-05 02:40:33 +01:00
$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
2005-02-18 10:57:10 +01:00
$MYSQLADMIN --no-defaults --host= $hostname --port= ` expr $MASTER_MYPORT +1` -u root -O connect_timeout = 5 -O shutdown_timeout = 20 shutdown > /dev/null 2>& 1
2002-12-05 02:40:33 +01:00
$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
2004-10-04 01:41:15 +02:00
sleep_until_file_deleted 0 $MASTER_MYPID "1"
2002-12-05 02:40:33 +01:00
sleep_until_file_deleted 0 $SLAVE_MYPID
else
2004-10-04 01:41:15 +02:00
rm $MASTER_MYPID $MASTER_MYPID "1" $SLAVE_MYPID
2002-12-05 02:40:33 +01:00
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
2004-10-04 02:25:04 +02:00
stop_ndbcluster
2004-04-14 17:16:31 +02:00
2001-12-10 17:16:51 +01:00
# Remove files that can cause problems
2004-04-15 17:30:50 +02:00
$RM -rf $MYSQL_TEST_DIR /var/ndbcluster
2001-12-10 17:16:51 +01:00
$RM -f $MYSQL_TEST_DIR /var/run/* $MYSQL_TEST_DIR /var/tmp/*
2002-12-25 13:34:32 +01:00
# Remove old berkeley db log files that can confuse the server
$RM -f $MASTER_MYDDIR /log.*
2004-09-28 19:04:30 +02:00
$RM -f $MASTER_MYDDIR "1" /log.*
2002-12-25 13:34:32 +01:00
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
2004-04-14 17:16:31 +02:00
2005-06-10 12:58:05 +02:00
if [ -n " $1 " -a ` expr " X $* " : '.*ndb' ` -eq 0 ]
then
USE_NDBCLUSTER = ""
fi
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
2000-12-28 08:26:37 +01:00
$ECHO "Starting Tests"
2000-11-21 07:38:08 +01:00
2005-01-26 10:19:28 +01:00
# Some test cases need USE_RUNNING_SERVER
export USE_RUNNING_SERVER
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
2004-04-30 10:08:44 +02:00
start_master
2004-09-24 18:58:25 +02:00
if [ " $DO_SMALL_BENCH " = 1 ]
then
EXTRA_BENCH_ARGS = "--small-test --small-tables"
fi
2004-04-30 10:08:44 +02:00
if [ ! -z " $USE_NDBCLUSTER " ]
then
2004-09-24 18:58:25 +02:00
EXTRA_BENCH_ARGS = " --create-options=TYPE=ndb $EXTRA_BENCH_ARGS "
2004-04-30 10:08:44 +02:00
fi
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
2004-09-24 18:58:25 +02:00
./run-all-tests --socket= $MASTER_MYSOCK --user= root $EXTRA_BENCH_ARGS --log
2001-04-13 20:51:27 +02:00
else
2001-12-10 17:16:51 +01:00
if [ -x " ./ $1 " ]
then
2004-04-30 10:08:44 +02:00
./$1 --socket= $MASTER_MYSOCK --user= root $EXTRA_BENCH_ARGS
2001-12-10 17:16:51 +01:00
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
2004-09-28 18:25:57 +02:00
if [ x$USE_TIMER = x1 ] ; then
2004-09-27 17:01:26 +02:00
$ECHO "TEST RESULT TIME (ms)"
2004-09-28 18:25:57 +02:00
else
$ECHO "TEST RESULT"
fi
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
2002-10-25 01:46:14 +02:00
if [ x$RECORD = x1 ] ; then
$ECHO "Will not run in record mode without a specific test case."
else
2003-08-25 15:40:14 +02:00
for tf in $TESTDIR /*.$TESTSUFFIX
do
run_testcase $tf
done
2002-10-25 01:46:14 +02:00
$RM -f $TIMEFILE # Remove for full test
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
2005-01-26 10:19:28 +01:00
if [ -z " $DO_GDB " ] && [ $USE_RUNNING_SERVER -eq 0 ] && [ -z " $DO_DDD " ]
2000-11-21 07:38:08 +01:00
then
mysql_stop
fi
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
2004-09-28 16:27:50 +02:00
if [ $TOT_FAIL -ne 0 ] ; then
2005-01-05 13:09:31 +01:00
$ECHO " mysql-test-run in $TEST_MODE mode: *** Failing the test(s): $FAILED_CASES "
2004-09-28 16:27:50 +02:00
$ECHO
exit 1
else
exit 0
fi