1 #!/bin/sh
   2 
   3 #
   4 # Copyright (c) 2012, Oracle and/or its affiliates. All rights reserved.
   5 # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
   6 #
   7 # This code is free software; you can redistribute it and/or modify it
   8 # under the terms of the GNU General Public License version 2 only, as
   9 # published by the Free Software Foundation.
  10 #
  11 # This code is distributed in the hope that it will be useful, but WITHOUT
  12 # ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
  13 # FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
  14 # version 2 for more details (a copy is included in the LICENSE file that
  15 # accompanied this code).
  16 #
  17 # You should have received a copy of the GNU General Public License version
  18 # 2 along with this work; if not, write to the Free Software Foundation,
  19 # Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
  20 #
  21 # Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
  22 # or visit www.oracle.com if you need additional information or have any
  23 # questions.
  24 #
  25 
  26 
  27 # @test
  28 # @bug 7106773
  29 # @summary 512 bits RSA key cannot work with SHA384 and SHA512
  30 # @run shell ShortRSAKey1024.sh 1024
  31 # @run shell ShortRSAKey1024.sh 768
  32 # @run shell ShortRSAKey1024.sh 512
  33 
  34 # set a few environment variables so that the shell-script can run stand-alone
  35 # in the source directory
  36 if [ "${TESTSRC}" = "" ] ; then
  37    TESTSRC="."
  38 fi
  39 
  40 if [ "${TESTCLASSES}" = "" ] ; then
  41    TESTCLASSES="."
  42 fi
  43 
  44 if [ "${TESTJAVA}" = "" ] ; then
  45    echo "TESTJAVA not set.  Test cannot execute."
  46    echo "FAILED!!!"
  47    exit 1
  48 fi
  49 
  50 OS=`uname -s`
  51 case "$OS" in
  52   SunOS | Linux | Darwin | CYGWIN* )
  53     FS="/"
  54     ;;
  55   Windows_* )
  56     FS="\\"
  57     ;;
  58 esac
  59 
  60 BITS=$1
  61 
  62 case "$OS" in
  63     Windows* | CYGWIN* )
  64 
  65         echo "Removing the keypair if it already exists (for unknown reason)..."
  66         ${TESTJAVA}${FS}bin${FS}keytool \
  67             -delete \
  68             -storetype Windows-My \
  69             -debug \
  70             -alias 7106773.$BITS
  71 
  72         echo "Creating a temporary RSA keypair in the Windows-My store..."
  73         ${TESTJAVA}${FS}bin${FS}keytool \
  74             -genkeypair \
  75             -storetype Windows-My \
  76             -keyalg RSA \
  77             -alias 7106773.$BITS \
  78             -keysize $BITS \
  79             -dname "cn=localhost,c=US" \
  80             -debug \
  81             -noprompt
  82 
  83         if [ "$?" -ne "0" ]; then
  84             echo "Unable to generate key pair in Windows-My keystore"
  85             exit 1
  86         fi
  87 
  88         echo
  89         echo "Running the test..."
  90         ${TESTJAVA}${FS}bin${FS}javac -d . \
  91             ${TESTSRC}${FS}ShortRSAKeyWithinTLS.java
  92         ${TESTJAVA}${FS}bin${FS}java ${TESTVMOPTS} ShortRSAKeyWithinTLS 7106773.$BITS $BITS \
  93             TLSv1.2 TLS_DHE_RSA_WITH_AES_128_CBC_SHA
  94 
  95         rc=$?
  96 
  97         echo
  98         echo "Removing the temporary RSA keypair from the Windows-My store..."
  99         ${TESTJAVA}${FS}bin${FS}keytool \
 100             -delete \
 101             -storetype Windows-My \
 102             -debug \
 103             -alias 7106773.$BITS
 104 
 105         echo "Done".
 106         exit $rc
 107         ;;
 108 
 109     * )
 110         echo "This test is not intended for '$OS' - passing test"
 111         exit 0
 112         ;;
 113 esac