2006-06-19 14:13:34 +04:00
|
|
|
#!/bin/sh
|
|
|
|
|
|
|
|
###########################################################################
|
|
|
|
|
2006-11-23 22:55:36 +03:00
|
|
|
# NOTE: this script returns 0 (success) even in case of failure (except for
|
|
|
|
# usage-error). This is because this script is executed under
|
|
|
|
# mysql-test-run[.pl] and it's better to examine particular problem in log
|
|
|
|
# file, than just having said that the test case has failed.
|
2006-06-19 14:13:34 +04:00
|
|
|
|
2006-11-23 22:55:36 +03:00
|
|
|
###########################################################################
|
2006-06-19 14:13:34 +04:00
|
|
|
|
2006-11-23 22:55:36 +03:00
|
|
|
basename=`basename "$0"`
|
|
|
|
dirname=`dirname "$0"`
|
2006-06-19 14:13:34 +04:00
|
|
|
|
2006-11-23 22:55:36 +03:00
|
|
|
###########################################################################
|
|
|
|
|
|
|
|
. "$dirname/utils.sh"
|
2006-06-19 14:13:34 +04:00
|
|
|
|
|
|
|
###########################################################################
|
|
|
|
|
|
|
|
check_started()
|
|
|
|
{
|
2006-11-23 22:55:36 +03:00
|
|
|
if [ ! -r "$pid_path" ]; then
|
|
|
|
log_debug "No PID-file ($pid_path) found -- not started."
|
|
|
|
return 1
|
|
|
|
fi
|
2006-06-19 14:13:34 +04:00
|
|
|
|
|
|
|
new_pid=`cat "$pid_path" 2>/dev/null`
|
2006-11-23 22:55:36 +03:00
|
|
|
err_code=$?
|
|
|
|
|
|
|
|
log_debug "err_code: $err_code; new_pid: $new_pid."
|
2006-06-19 14:13:34 +04:00
|
|
|
|
2006-11-23 22:55:36 +03:00
|
|
|
if [ $? -ne 0 -o -z "$new_pid" ]; then
|
|
|
|
log_debug "The process was not started."
|
|
|
|
return 1
|
|
|
|
fi
|
2006-06-19 14:13:34 +04:00
|
|
|
|
2006-11-23 22:55:36 +03:00
|
|
|
log_debug "The process was started."
|
2006-06-19 14:13:34 +04:00
|
|
|
return 0
|
|
|
|
}
|
|
|
|
|
|
|
|
###########################################################################
|
|
|
|
|
|
|
|
check_stopped()
|
|
|
|
{
|
2006-11-23 22:55:36 +03:00
|
|
|
if [ -r "$pid_path" ]; then
|
|
|
|
log_debug "PID-file '$pid_path' exists -- not stopped."
|
|
|
|
return 1
|
|
|
|
fi
|
2006-06-19 14:13:34 +04:00
|
|
|
|
2006-11-23 22:55:36 +03:00
|
|
|
log_debug "No PID-file ($pid_path) found -- stopped."
|
2006-06-19 14:13:34 +04:00
|
|
|
return 0
|
|
|
|
}
|
|
|
|
|
|
|
|
###########################################################################
|
|
|
|
|
2006-11-23 22:55:36 +03:00
|
|
|
if [ $# -ne 4 ]; then
|
|
|
|
echo "Usage: $basename <pid file path> <total attempts> started|stopped <test id>"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
pid_path="$1"
|
|
|
|
total_attempts="$2"
|
|
|
|
event="$3"
|
|
|
|
test_id="$4"
|
IM test suite fix.
Log messages from shell-scripts were put to var/log/<test id>.log
file. Now, this file is used by mysql-test-run.pl. So, move log
messages to var/log/<test id>.script.log.
mysql-test/t/kill_n_check.sh:
Log messages from shell-scripts were put to var/log/<test id>.log
file. Now, this file is used by mysql-test-run.pl. So, move log
messages to var/log/<test id>.script.log.
mysql-test/t/log.sh:
Log messages from shell-scripts were put to var/log/<test id>.log
file. Now, this file is used by mysql-test-run.pl. So, move log
messages to var/log/<test id>.script.log.
mysql-test/t/wait_for_process.sh:
Log messages from shell-scripts were put to var/log/<test id>.log
file. Now, this file is used by mysql-test-run.pl. So, move log
messages to var/log/<test id>.script.log.
mysql-test/t/wait_for_socket.sh:
Log messages from shell-scripts were put to var/log/<test id>.log
file. Now, this file is used by mysql-test-run.pl. So, move log
messages to var/log/<test id>.script.log.
2007-02-24 13:12:20 +03:00
|
|
|
log_file="$MYSQLTEST_VARDIR/log/$test_id.script.log"
|
2006-11-23 22:55:36 +03:00
|
|
|
|
|
|
|
log_debug "-- $basename: starting --"
|
|
|
|
log_debug "pid_path: '$pid_path'"
|
|
|
|
log_debug "total_attempts: '$total_attempts'"
|
|
|
|
log_debug "event: '$event'"
|
|
|
|
log_debug "test_id: '$test_id'"
|
|
|
|
log_debug "log_file: '$log_file'"
|
|
|
|
|
|
|
|
###########################################################################
|
|
|
|
|
|
|
|
case "$event" in
|
|
|
|
started)
|
|
|
|
check_fn='check_started';
|
|
|
|
;;
|
|
|
|
|
|
|
|
stopped)
|
|
|
|
check_fn='check_stopped';
|
|
|
|
;;
|
|
|
|
|
|
|
|
*)
|
|
|
|
log_error "Invalid third argument ('started' or 'stopped' expected)."
|
|
|
|
quit 0
|
|
|
|
esac
|
|
|
|
|
|
|
|
###########################################################################
|
|
|
|
|
2006-06-19 14:13:34 +04:00
|
|
|
cur_attempt=1
|
|
|
|
|
|
|
|
while true; do
|
|
|
|
|
2006-11-23 22:55:36 +03:00
|
|
|
log_debug "cur_attempt: $cur_attempt."
|
|
|
|
|
2006-06-19 14:13:34 +04:00
|
|
|
if ( eval $check_fn ); then
|
2006-11-23 22:55:36 +03:00
|
|
|
log_info "Success: the process has been $event."
|
|
|
|
quit 0
|
2006-06-19 14:13:34 +04:00
|
|
|
fi
|
|
|
|
|
|
|
|
[ $cur_attempt -ge $total_attempts ] && break
|
|
|
|
|
2006-11-23 22:55:36 +03:00
|
|
|
log_debug "Sleeping for 1 second..."
|
2006-06-19 14:13:34 +04:00
|
|
|
sleep 1
|
|
|
|
|
|
|
|
cur_attempt=`expr $cur_attempt + 1`
|
|
|
|
|
|
|
|
done
|
|
|
|
|
2006-11-23 22:55:36 +03:00
|
|
|
log_error "The process has not been $event in $total_attempts secs."
|
|
|
|
quit 0
|