1 #!/bin/sh
   2 
   3 #
   4 # Copyright (c) 2012, 2016, 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 ${TESTTOOLVMOPTS} \
  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 ${TESTTOOLVMOPTS} \
  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 -XaddExports:java.base/sun.security.util=ALL-UNNAMED \
  92             ${TESTTOOLVMOPTS} ${TESTJAVACOPTS} -d . \
  93             ${TESTSRC}${FS}ShortRSAKeyWithinTLS.java
  94         ${TESTJAVA}${FS}bin${FS}java -XaddExports:java.base/sun.security.util=ALL-UNNAMED \
  95             ${TESTVMOPTS} ShortRSAKeyWithinTLS 7106773.$BITS $BITS \
  96             TLSv1.2 TLS_DHE_RSA_WITH_AES_128_CBC_SHA
  97 
  98         rc=$?
  99 
 100         echo
 101         echo "Removing the temporary RSA keypair from the Windows-My store..."
 102         ${TESTJAVA}${FS}bin${FS}keytool ${TESTTOOLVMOPTS} \
 103             -delete \
 104             -storetype Windows-My \
 105             -debug \
 106             -alias 7106773.$BITS
 107 
 108         echo "Done".
 109         exit $rc
 110         ;;
 111 
 112     * )
 113         echo "This test is not intended for '$OS' - passing test"
 114         exit 0
 115         ;;
 116 esac