1 #!/bin/sh
   2 
   3 #
   4 # Copyright (c) 2012, 2015, 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 # @requires os.family == "windows"
  31 # @run shell ShortRSAKey1024.sh 1024
  32 # @run shell ShortRSAKey1024.sh 768
  33 # @run shell ShortRSAKey1024.sh 512
  34 
  35 # set a few environment variables so that the shell-script can run stand-alone
  36 # in the source directory
  37 if [ "${TESTSRC}" = "" ] ; then
  38    TESTSRC="."
  39 fi
  40 
  41 if [ "${TESTCLASSES}" = "" ] ; then
  42    TESTCLASSES="."
  43 fi
  44 
  45 if [ "${TESTJAVA}" = "" ] ; then
  46    echo "TESTJAVA not set.  Test cannot execute."
  47    echo "FAILED!!!"
  48    exit 1
  49 fi
  50 
  51 OS=`uname -s`
  52 case "$OS" in
  53   SunOS | Linux | Darwin | CYGWIN* )
  54     FS="/"
  55     ;;
  56   Windows_* )
  57     FS="\\"
  58     ;;
  59 esac
  60 
  61 BITS=$1
  62 
  63 case "$OS" in
  64     Windows* | CYGWIN* )
  65 
  66         echo "Removing the keypair if it already exists (for unknown reason)..."
  67         ${TESTJAVA}${FS}bin${FS}keytool \
  68             -delete \
  69             -storetype Windows-My \
  70             -debug \
  71             -alias 7106773.$BITS
  72 
  73         echo "Creating a temporary RSA keypair in the Windows-My store..."
  74         ${TESTJAVA}${FS}bin${FS}keytool \
  75             -genkeypair \
  76             -storetype Windows-My \
  77             -keyalg RSA \
  78             -alias 7106773.$BITS \
  79             -keysize $BITS \
  80             -dname "cn=localhost,c=US" \
  81             -debug \
  82             -noprompt
  83 
  84         if [ "$?" -ne "0" ]; then
  85             echo "Unable to generate key pair in Windows-My keystore"
  86             exit 1
  87         fi
  88 
  89         echo
  90         echo "Running the test..."
  91         ${TESTJAVA}${FS}bin${FS}javac -d . \
  92             ${TESTSRC}${FS}ShortRSAKeyWithinTLS.java
  93         ${TESTJAVA}${FS}bin${FS}java ${TESTVMOPTS} ShortRSAKeyWithinTLS 7106773.$BITS $BITS \
  94             TLSv1.2 TLS_DHE_RSA_WITH_AES_128_CBC_SHA
  95 
  96         rc=$?
  97 
  98         echo
  99         echo "Removing the temporary RSA keypair from the Windows-My store..."
 100         ${TESTJAVA}${FS}bin${FS}keytool \
 101             -delete \
 102             -storetype Windows-My \
 103             -debug \
 104             -alias 7106773.$BITS
 105 
 106         echo "Done".
 107         exit $rc
 108         ;;
 109 
 110     * )
 111         echo "This test is not intended for '$OS' - passing test"
 112         exit 0
 113         ;;
 114 esac