jdk-24/test/jdk/sun/jvmstat/testlibrary/utils.sh
2017-09-12 19:03:39 +02:00

224 lines
6.2 KiB
Bash

#
# Copyright (c) 2004, 2010, Oracle and/or its affiliates. All rights reserved.
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
#
# This code is free software; you can redistribute it and/or modify it
# under the terms of the GNU General Public License version 2 only, as
# published by the Free Software Foundation.
#
# This code is distributed in the hope that it will be useful, but WITHOUT
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
# version 2 for more details (a copy is included in the LICENSE file that
# accompanied this code).
#
# You should have received a copy of the GNU General Public License version
# 2 along with this work; if not, write to the Free Software Foundation,
# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
#
# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
# or visit www.oracle.com if you need additional information or have any
# questions.
#
#
setup() {
# Verify directory context variables are set
if [ "${TESTJAVA}" = "" ] ; then
echo "TESTJAVA not set. Test cannot execute. Failed."
exit 1
fi
if [ "${TESTCLASSES}" = "" ] ; then
TESTCLASSES="."
fi
if [ "${TESTSRC}" = "" ] ; then
TESTSRC="."
fi
OS=`uname -s`
case ${OS} in
Windows_* | CYGWIN*)
PS=";"
FS="\\"
;;
*)
PS=":"
FS="/"
;;
esac
}
verify_os() {
OS=`uname -s`
case ${OS} in
Windows_95 | Windows_98 | Windows_ME | CYGWIN* )
echo "Test bypassed: jvmstat feature not supported on ${OS}"
exit 0
;;
Windows_*)
# verify that the tmp directory supports persistent ACLs, which
# are required for jvmstat to enable its shared memory feature.
# NOTE: FAT type files systems do not support ACLs, but NTFS files
# systems do.
#
echo "temp directory is in: `windir -t`"
TMPDRIVE=`windir -t | cut -d: -f1`
if [ "${TMPDRIVE}" = "" ] ; then
echo "Could not get temp directory drive letter"
exit 1
fi
echo "temp file system characteristics:"
sysinf drives -a | grep "^${TMPDRIVE}"
sysinf drives -a | grep "^${TMPDRIVE}" | grep PERSISTENT_ACLS > /dev/null
case $? in
0)
;;
1)
echo "Test bypassed: jvmstat feature disabled because the temp"
echo "directory doesn't support persistent ACLs"
exit 0
;;
2)
echo "Could not get temp directory file system features"
exit 1
;;
*)
echo "Unexpected return code from grep - $?"
exit 1
;;
esac
;;
esac
}
# function to kill the process with the given process id
kill_proc() {
kill_pid=$1
if [ "${kill_pid}" = "" ]
then
echo "kill_proc(): null pid: ignored"
return
fi
if [ ${kill_pid} -le 0 ]
then
echo "kill_proc(): invalid pid: ${kill_pid}: ignored"
return
fi
OS=`uname -s`
case $OS in
Windows_*)
case ${SHELL_VERSION} in
[1234567].* | 8.[12345].*)
# when starting processes in the background, mks creates an
# intervening between the parent process and the background
# process. The pid acquired for background process as acquired
# by the $! shell variable is actually the pid of the invervening
# shell and not that of the background process. Sending a specific
# signal to the intervening shell will only effects the intervening
# shell and not the background process, thus leaving the background
# process running. The following code assumes that the pid passed
# into this function as ${kill_pid}, was acquired by $!. Therefore,
# in order to kill the background process, we must first find the
# children of ${kill_pid} (should be only one child) and kill them.
ps -o pid,ppid | grep "${kill_pid}$"
children=`mks_children ${kill_pid}`
echo "killing children of ${kill_pid}: ${children}"
for child in ${children} ; do
kill_proc_common ${child}
done
;;
*)
# in mks 8.6 and later, the pid returned in $! is now the pid
# of the background process and not that of the intervening shell.
kill_proc_common ${kill_pid}
;;
esac
;;
*)
kill_proc_common ${kill_pid}
;;
esac
}
mks_children() {
ppid=$1
ps -o pid,ppid | grep "${ppid}$" | awk '
BEGIN { pids="" }
{ pids = pids $1 " " }
END { print pids }'
}
kill_proc_common() {
kpid=$1
# verify that the process exists and we can signal it
kill -0 ${kpid} 2>/dev/null
if [ $? -ne 0 ]
then
echo "Could not signal >${kpid}<"
echo "user id = `id`"
echo "process information :"
ps -l -p ${kpid}
return
fi
kill -TERM ${kpid} # hit it easy first
if [ $? -eq 0 ]
then
sleep 2
kill -0 ${kpid} 2>/dev/null
# check if it's still hanging around
if [ $? -eq 0 ]
then
# it's still lingering, now it it hard
kill -KILL ${kpid} 2>/dev/null
if [ $? -ne 0 ]
then
echo "Could not kill ${kpid}!"
fi
fi
else
echo "Error sending term signal to ${kpid}!"
fi
}
# check to see if a port is free
checkPort() # port
{
inuse=`netstat -a | egrep "\.$1"`
if [ "${inuse}" = "" ] ; then
echo "free"
else
echo "inuse"
fi
}
# Get a free port, where port+1 is also free, return 0 when giving up
freePort()
{
start=3000
while [ ${start} -lt 3030 ] ; do
port1=`expr ${start} '+' $$ '%' 1000`
port2=`expr ${port1} '+' 1`
if [ "`checkPort ${port1}`" = "inuse" \
-o "`checkPort ${port2}`" = "inuse" ] ; then
start=`expr ${start} '+' 1`
else
break
fi
done
if [ "`checkPort ${port1}`" = "inuse" \
-o "`checkPort ${port2}`" = "inuse" ] ; then
port1="0"
fi
echo "${port1}"
}