| #!/bin/ksh -p |
| |
| # |
| # Copyright (c) 2001, 2008, 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. |
| # |
| |
| # |
| # @test Solaris32AndSolaris64Test.sh |
| # @bug 4478312 4780570 4913748 6730273 |
| # @summary Test debugging with mixed 32/64bit VMs. |
| # @author Tim Bell |
| # Based on test/java/awt/TEMPLATE/AutomaticShellTest.sh |
| # |
| # @run build TestScaffold VMConnection TargetListener TargetAdapter |
| # @run compile -g FetchLocals.java |
| # @run compile -g DataModelTest.java |
| # @run shell/timeout=240 Solaris32AndSolaris64Test.sh DataModelTest |
| # @run shell/timeout=240 Solaris32AndSolaris64Test.sh FetchLocals |
| |
| # Beginning of subroutines: |
| status=1 |
| |
| #Call this from anywhere to fail the test with an error message |
| # usage: fail "reason why the test failed" |
| fail() |
| { echo "The test failed :-(" |
| echo "$*" 1>&2 |
| echo "exit status was $status" |
| exit $status |
| } #end of fail() |
| |
| #Call this from anywhere to pass the test with a message |
| # usage: pass "reason why the test passed if applicable" |
| pass() |
| { echo "The test passed!!!" |
| echo "$*" 1>&2 |
| exit 0 |
| } #end of pass() |
| |
| # end of subroutines |
| |
| if [ $# = 0 ] ; then |
| echo "Error: no testname specified on cmd line" |
| exit 1 |
| fi |
| testName=$1 |
| shift |
| |
| #Set appropriate jdk |
| |
| if [ -z "${TESTJAVA}" ] ; then |
| # TESTJAVA is not set, so the test is running stand-alone. |
| # TESTJAVA holds the path to the root directory of the build of the JDK |
| # to be tested. That is, any java files run explicitly in this shell |
| # should use TESTJAVA in the path to the java interpreter. |
| # So, we'll set this to the JDK spec'd on the command line. If none |
| # is given on the command line, tell the user that and use a default. |
| # THIS IS THE JDK BEING TESTED. |
| if [ -n "$1" ] ; then |
| TESTJAVA=$1 |
| else |
| echo "no JDK specified on command line so using JAVA_HOME=$JAVA_HOME" |
| TESTJAVA=$JAVA_HOME |
| fi |
| TESTSRC=. |
| TESTCLASSES=. |
| STANDALONE=1; |
| fi |
| echo "JDK under test is: $TESTJAVA" |
| |
| |
| # The beginning of the script proper |
| |
| # Checking for proper OS and processor type. |
| # |
| # This test is only interested in SunOS SPARC sparcv9 and SunOS AMD64 |
| # (supporting both 32 and 64 bit Solaris binaries). |
| # |
| # All other platforms will instantly complete with passing |
| # status. |
| # |
| OS=`uname -s` |
| case "$OS" in |
| SunOS ) |
| PATHSEP=":" |
| PTYPE=`uname -p` |
| if [ -x /usr/bin/isainfo ]; then |
| # Instruction set being used by the OS |
| ISET=`isainfo -k` |
| else |
| #SunOS 5.6 didn't have "isainfo" |
| pass "This test always passes on $OS/$PTYPE (32-bit ${ISET})" |
| fi |
| ;; |
| |
| Linux ) |
| pass "This test always passes on $OS" |
| ;; |
| |
| Windows* | CYGWIN*) |
| pass "This test always passes on $OS" |
| ;; |
| |
| # catch all other OSs |
| * ) |
| echo "Unrecognized system! $OS" |
| fail "Unrecognized system! $OS" |
| ;; |
| esac |
| |
| # Is the OS running in sparcv9 or amd64 mode? |
| case "${ISET}" in |
| sparc ) |
| pass "This test always passes on $OS/$PTYPE (32-bit ${ISET})" |
| ;; |
| i386 ) |
| pass "This test always passes on $OS/$PTYPE (32-bit ${ISET})" |
| ;; |
| amd64 ) |
| echo "OS is running in ${ISET} mode" |
| ;; |
| sparcv9 ) |
| echo "OS is running in ${ISET} mode" |
| ;; |
| # catch all others |
| * ) |
| echo "Unrecognized instruction set! $OS/$PTYPE/${ISET}" |
| fail "Unrecognized instruction set! $OS/$PTYPE/${ISET}" |
| ;; |
| esac |
| |
| # SunOS 32 and 64 bit binaries must be available |
| # to test in the remainder of the script below. |
| $TESTJAVA/bin/java -d64 -version > /dev/null 2<&1 |
| if [ $? = 1 ]; then |
| # The 64 bit version is not installed. Make the test pass. |
| pass "This test always passes on $OS/$PTYPE if 64 bit jdk is not installed" |
| fi |
| |
| # Want this test to run standalone as well as in the harness, so do the |
| # following to copy the test's directory into the harness's scratch directory |
| # and set all appropriate variables: |
| |
| #Deal with .class files: |
| if [ -n "${STANDALONE}" ] ; then |
| #if running standalone, compile the support files |
| ${TESTJAVA}/bin/javac -d ${TESTCLASSES} \ |
| -classpath "$TESTJAVA/lib/tools.jar${PATHSEP}${TESTSRC}" \ |
| TestScaffold.java VMConnection.java TargetListener.java TargetAdapter.java |
| ${TESTJAVA}/bin/javac -d ${TESTCLASSES} \ |
| -classpath "$TESTJAVA/lib/tools.jar${PATHSEP}${TESTSRC}" -g \ |
| FetchLocals.java DataModelTest.java |
| fi |
| |
| # Get DEBUGGEE flags |
| DEBUGGEEFLAGS= |
| filename=$TESTCLASSES/@debuggeeVMOptions |
| if [ ! -r ${filename} ] ; then |
| filename=$TESTCLASSES/../@debuggeeVMOptions |
| fi |
| # Remove -d32, -d64 if present, and remove -XX:[+-]UseCompressedOops |
| # if present since it is illegal in 32 bit mode. |
| if [ -r ${filename} ] ; then |
| DEBUGGEEFLAGS=`cat ${filename} | sed \ |
| -e 's/-d32//g' \ |
| -e 's/-d64//g' \ |
| -e 's/-XX:.UseCompressedOops//g' \ |
| ` |
| fi |
| |
| # |
| CLASSPATH="$TESTJAVA/lib/tools.jar${PATHSEP}${TESTCLASSES}" |
| export CLASSPATH |
| CP="-classpath \"${CLASSPATH}\"" |
| |
| for DEBUGGERMODEL in \ |
| 32 \ |
| 64 \ |
| ; do |
| |
| for TARGETMODEL in \ |
| 32 \ |
| 64 \ |
| ; do |
| DEBUGGERFLAGS="-d${DEBUGGERMODEL} -showversion -DEXPECTED=${TARGETMODEL}" |
| CONNECTSTRING="-connect 'com.sun.jdi.CommandLineLaunch:options=-d${TARGETMODEL} $DEBUGGEEFLAGS -showversion'" |
| |
| for TARGETCLASS in $testName ; do |
| echo "--------------------------------------------" |
| echo "debugger=${DEBUGGERMODEL} debugee=${TARGETMODEL} class=${TARGETCLASS}" |
| echo "--------------------------------------------" |
| echo ${TESTJAVA}/bin/java -DHANGINGJAVA_DEB ${DEBUGGERFLAGS} ${CP} ${TARGETCLASS} ${CONNECTSTRING} |
| eval ${TESTJAVA}/bin/java -DHANGINGJAVA_DEB ${DEBUGGERFLAGS} ${CP} ${TARGETCLASS} ${CONNECTSTRING} |
| status=$? |
| if [ $status -ne "0" ]; |
| then fail "$DEBUGGERMODEL to $TARGETMODEL test failed for class=$TARGETCLASS!" |
| fi |
| done |
| done |
| done |
| # |
| # pass or fail the test based on status of the command |
| if [ $status -eq "0" ]; |
| then pass "" |
| |
| else fail "unspecified test failure" |
| fi |