jdk-24/jdk/test/sun/security/tools/keytool/StorePasswordsByShell.sh
2013-10-04 16:05:55 +01:00

141 lines
3.5 KiB
Bash

#
# Copyright (c) 2013, 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
# @bug 8008296
# @summary confirm that keytool correctly imports user passwords
#
# @run shell StorePasswordsByShell.sh
# set a few environment variables so that the shell-script can run stand-alone
# in the source directory
if [ "${TESTSRC}" = "" ] ; then
TESTSRC="."
fi
if [ "${TESTCLASSES}" = "" ] ; then
TESTCLASSES="."
fi
if [ "${TESTJAVA}" = "" ] ; then
echo "TESTJAVA not set. Test cannot execute."
echo "FAILED!!!"
exit 1
fi
# set platform-dependent variables
OS=`uname -s`
case "$OS" in
SunOS )
PATHSEP=":"
FILESEP="/"
;;
Linux )
PATHSEP=":"
FILESEP="/"
;;
Darwin )
PATHSEP=":"
FILESEP="/"
;;
CYGWIN* )
PATHSEP=";"
FILESEP="/"
;;
Windows* )
PATHSEP=";"
FILESEP="\\"
;;
* )
echo "Unrecognized system!"
exit 1;
;;
esac
PBE_ALGORITHMS="\
default-PBE-algorithm \
PBEWithMD5AndDES \
PBEWithSHA1AndDESede \
PBEWithSHA1AndRC2_40 \
PBEWithSHA1AndRC2_128
PBEWithSHA1AndRC4_40 \
PBEWithSHA1AndRC4_128 \
PBEWithHmacSHA1AndAES_128 \
PBEWithHmacSHA224AndAES_128 \
PBEWithHmacSHA256AndAES_128 \
PBEWithHmacSHA384AndAES_128 \
PBEWithHmacSHA512AndAES_128 \
PBEWithHmacSHA1AndAES_256 \
PBEWithHmacSHA224AndAES_256 \
PBEWithHmacSHA256AndAES_256 \
PBEWithHmacSHA384AndAES_256 \
PBEWithHmacSHA512AndAES_256"
USER_PWD="hello1\n"
ALIAS_PREFIX="this entry is protected by "
COUNTER=0
# cleanup
rm mykeystore.p12 > /dev/null 2>&1
echo
for i in $PBE_ALGORITHMS; do
if [ $i = "default-PBE-algorithm" ]; then
KEYALG=""
else
KEYALG="-keyalg ${i}"
fi
if [ $COUNTER -lt 5 ]; then
IMPORTPASSWORD="-importpassword"
else
IMPORTPASSWORD="-importpass"
fi
echo "Storing user password (protected by ${i})"
echo "${USER_PWD}" | \
${TESTJAVA}${FILESEP}bin${FILESEP}keytool ${IMPORTPASSWORD} \
-storetype pkcs12 -keystore mykeystore.p12 -storepass changeit \
-alias "${ALIAS_PREFIX}${i}" ${KEYALG} > /dev/null 2>&1
if [ $? -ne 0 ]; then
echo Error
else
echo OK
COUNTER=`expr ${COUNTER} + 1`
fi
done
echo
COUNTER2=`${TESTJAVA}${FILESEP}bin${FILESEP}keytool -list -storetype pkcs12 \
-keystore mykeystore.p12 -storepass changeit | grep -c "${ALIAS_PREFIX}"`
RESULT="stored ${COUNTER} user passwords, detected ${COUNTER2} user passwords"
if [ $COUNTER -ne $COUNTER2 -o $COUNTER -lt 11 ]; then
echo "ERROR: $RESULT"
exit 1
else
echo "OK: $RESULT"
exit 0
fi