blob: fae3422334c87b11121c791968f0e330d42e5df4 [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.apache.harmony.security.tests.java.security;
import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.math.BigInteger;
import java.security.InvalidKeyException;
import java.security.KeyFactory;
import java.security.KeyPair;
import java.security.KeyPairGenerator;
import java.security.KeyStore;
import java.security.KeyStoreException;
import java.security.NoSuchAlgorithmException;
import java.security.NoSuchProviderException;
import java.security.PrivateKey;
import java.security.Provider;
import java.security.PublicKey;
import java.security.SecureRandom;
import java.security.Security;
import java.security.SignatureException;
import java.security.UnrecoverableEntryException;
import java.security.UnrecoverableKeyException;
import java.security.cert.Certificate;
import java.security.cert.CertificateEncodingException;
import java.security.cert.CertificateException;
import java.security.cert.CertificateFactory;
import java.security.cert.X509Certificate;
import java.security.interfaces.DSAPrivateKey;
import java.security.spec.DSAPrivateKeySpec;
import java.security.spec.InvalidKeySpecException;
import java.util.Arrays;
import java.util.Calendar;
import java.util.Enumeration;
import java.util.HashSet;
import java.util.Set;
import tests.support.Support_TestProvider;
public class KeyStore2Test extends junit.framework.TestCase {
static PrivateKey privateKey;
static {
try {
KeyPairGenerator keyPairGenerator = KeyPairGenerator.getInstance("DSA");
SecureRandom secureRandom = new SecureRandom();
keyPairGenerator.initialize(1024, secureRandom);
KeyPair keyPair = keyPairGenerator.genKeyPair();
privateKey = keyPair.getPrivate();
} catch (Exception e) {
fail("initialization failed: " + e);
}
}
final char[] pssWord = { 'a', 'b', 'c' };
final byte[] testEncoding = new byte[] { (byte) 1, (byte) 2, (byte) 3,
(byte) 4, (byte) 5 };
private Provider support_TestProvider;
// creating a certificate
String certificate = "-----BEGIN CERTIFICATE-----\n"
+ "MIICZTCCAdICBQL3AAC2MA0GCSqGSIb3DQEBAgUAMF8xCzAJBgNVBAYTAlVTMSAw\n"
+ "HgYDVQQKExdSU0EgRGF0YSBTZWN1cml0eSwgSW5jLjEuMCwGA1UECxMlU2VjdXJl\n"
+ "IFNlcnZlciBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTAeFw05NzAyMjAwMDAwMDBa\n"
+ "Fw05ODAyMjAyMzU5NTlaMIGWMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZv\n"
+ "cm5pYTESMBAGA1UEBxMJUGFsbyBBbHRvMR8wHQYDVQQKExZTdW4gTWljcm9zeXN0\n"
+ "ZW1zLCBJbmMuMSEwHwYDVQQLExhUZXN0IGFuZCBFdmFsdWF0aW9uIE9ubHkxGjAY\n"
+ "BgNVBAMTEWFyZ29uLmVuZy5zdW4uY29tMIGfMA0GCSqGSIb3DQEBAQUAA4GNADCB\n"
+ "iQKBgQCofmdY+PiUWN01FOzEewf+GaG+lFf132UpzATmYJkA4AEA/juW7jSi+LJk\n"
+ "wJKi5GO4RyZoyimAL/5yIWDV6l1KlvxyKslr0REhMBaD/3Z3EsLTTEf5gVrQS6sT\n"
+ "WMoSZAyzB39kFfsB6oUXNtV8+UKKxSxKbxvhQn267PeCz5VX2QIDAQABMA0GCSqG\n"
+ "SIb3DQEBAgUAA34AXl3at6luiV/7I9MN5CXYoPJYI8Bcdc1hBagJvTMcmlqL2uOZ\n"
+ "H9T5hNMEL9Tk6aI7yZPXcw/xI2K6pOR/FrMp0UwJmdxX7ljV6ZtUZf7pY492UqwC\n"
+ "1777XQ9UEZyrKJvF5ntleeO0ayBqLGVKCWzWZX9YsXCpv47FNLZbupE=\n"
+ "-----END CERTIFICATE-----\n";
ByteArrayInputStream certArray = new ByteArrayInputStream(certificate.getBytes());
String certificate2 = "-----BEGIN CERTIFICATE-----\n"
+ "MIICZzCCAdCgAwIBAgIBGzANBgkqhkiG9w0BAQUFADBhMQswCQYDVQQGEwJVUzEY\n"
+ "MBYGA1UEChMPVS5TLiBHb3Zlcm5tZW50MQwwCgYDVQQLEwNEb0QxDDAKBgNVBAsT\n"
+ "A1BLSTEcMBoGA1UEAxMTRG9EIFBLSSBNZWQgUm9vdCBDQTAeFw05ODA4MDMyMjAy\n"
+ "MjlaFw0wODA4MDQyMjAyMjlaMGExCzAJBgNVBAYTAlVTMRgwFgYDVQQKEw9VLlMu\n"
+ "IEdvdmVybm1lbnQxDDAKBgNVBAsTA0RvRDEMMAoGA1UECxMDUEtJMRwwGgYDVQQD\n"
+ "ExNEb0QgUEtJIE1lZCBSb290IENBMIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKB\n"
+ "gQDbrM/J9FrJSX+zxFUbsI9Vw5QbguVBIa95rwW/0M8+sM0r5gd+DY6iubm6wnXk\n"
+ "CSvbfQlFEDSKr4WYeeGp+d9WlDnQdtDFLdA45tCi5SHjnW+hGAmZnld0rz6wQekF\n"
+ "5xQaa5A6wjhMlLOjbh27zyscrorMJ1O5FBOWnEHcRv6xqQIDAQABoy8wLTAdBgNV\n"
+ "HQ4EFgQUVrmYR6m9701cHQ3r5kXyG7zsCN0wDAYDVR0TBAUwAwEB/zANBgkqhkiG\n"
+ "9w0BAQUFAAOBgQDVX1Y0YqC7vekeZjVxtyuC8Mnxbrz6D109AX07LEIRzNYzwZ0w\n"
+ "MTImSp9sEzWW+3FueBIU7AxGys2O7X0qmN3zgszPfSiocBuQuXIYQctJhKjF5KVc\n"
+ "VGQRYYlt+myhl2vy6yPzEVCjiKwMEb1Spu0irCf+lFW2hsdjvmSQMtZvOw==\n"
+ "-----END CERTIFICATE-----\n";
ByteArrayInputStream certArray2 = new ByteArrayInputStream(certificate2.getBytes());
String certificate3 = "-----BEGIN CERTIFICATE-----\n"
+ "MIIDXDCCAsWgAwIBAgIBSjANBgkqhkiG9w0BAQUFADBWMQswCQYDVQQGEwJVUzEY\n"
+ "MBYGA1UEChMPVS5TLiBHb3Zlcm5tZW50MQwwCgYDVQQLEwNEb0QxDDAKBgNVBAsT\n"
+ "A1BLSTERMA8GA1UEAxMITWVkIENBLTEwHhcNOTgwODAyMTgwMjQwWhcNMDEwODAy\n"
+ "MTgwMjQwWjB0MQswCQYDVQQGEwJVUzEYMBYGA1UEChMPVS5TLiBHb3Zlcm5tZW50\n"
+ "MQwwCgYDVQQLEwNEb0QxDDAKBgNVBAsTA1BLSTENMAsGA1UECxMEVVNBRjEgMB4G\n"
+ "A1UEAxMXR3VtYnkuSm9zZXBoLjAwMDAwMDUwNDQwgZ8wDQYJKoZIhvcNAQEBBQAD\n"
+ "gY0AMIGJAoGBALT/R7bPqs1c1YqXAg5HNpZLgW2HuAc7RCaP06cE4R44GBLw/fQc\n"
+ "VRNLn5pgbTXsDnjiZVd8qEgYqjKFQka4/tNhaF7No2tBZB+oYL/eP0IWtP+h/W6D\n"
+ "KR5+UvIIdgmx7k3t9jp2Q51JpHhhKEb9WN54trCO9Yu7PYU+LI85jEIBAgMBAAGj\n"
+ "ggEaMIIBFjAWBgNVHSAEDzANMAsGCWCGSAFlAgELAzAfBgNVHSMEGDAWgBQzOhTo\n"
+ "CWdhiGUkIOx5cELXppMe9jAdBgNVHQ4EFgQUkLBJl+ayKgzOp/wwBX9M1lSkCg4w\n"
+ "DgYDVR0PAQH/BAQDAgbAMAwGA1UdEwEB/wQCMAAwgZ0GA1UdHwSBlTCBkjCBj6CB\n"
+ "jKCBiYaBhmxkYXA6Ly9kcy0xLmNoYW1iLmRpc2EubWlsL2NuJTNkTWVkJTIwQ0El\n"
+ "MmQxJTJjb3UlM2RQS0klMmNvdSUzZERvRCUyY28lM2RVLlMuJTIwR292ZXJubWVu\n"
+ "dCUyY2MlM2RVUz9jZXJ0aWZpY2F0ZVJldm9jYXRpb25MaXN0JTNiYmluYXJ5MA0G\n"
+ "CSqGSIb3DQEBBQUAA4GBAFjapuDHMvIdUeYRyEYdShBR1JZC20tJ3MQnyBQveddz\n"
+ "LGFDGpIkRAQU7T/5/ne8lMexyxViC21xOlK9LdbJCbVyywvb9uEm/1je9wieQQtr\n"
+ "kjykuB+WB6qTCIslAO/eUmgzfzIENvnH8O+fH7QTr2PdkFkiPIqBJYHvw7F3XDqy\n"
+ "-----END CERTIFICATE-----\n";
ByteArrayInputStream certArray3 = new ByteArrayInputStream(certificate3.getBytes());
private byte[] creatCertificate() throws Exception {
ByteArrayOutputStream out = null;
CertificateFactory cf = CertificateFactory.getInstance("X.509");
X509Certificate cert[] = new X509Certificate[2];
cert[0] = (X509Certificate) cf.generateCertificate(certArray);
cert[1] = (X509Certificate) cf.generateCertificate(certArray2);
KeyStore keyTest = KeyStore.getInstance(KeyStore.getDefaultType());
keyTest.load(null, null);
// alias 1
keyTest.setCertificateEntry("alias1", cert[0]);
// alias 2
keyTest.setKeyEntry("alias2", privateKey, pssWord, cert);
// alias 3
keyTest.setCertificateEntry("alias3", cert[1]);
out = new ByteArrayOutputStream();
keyTest.store(out, pssWord);
out.close();
return out.toByteArray();
}
/**
* java.security.KeyStore#aliases()
*/
public void test_aliases() throws Exception {
// Test for method java.util.Enumeration
// java.security.KeyStore.aliases()
// NOT COMPATIBLE WITH PCS#12
CertificateFactory cf = CertificateFactory.getInstance("X.509");
X509Certificate cert[] = new X509Certificate[2];
cert[0] = (X509Certificate) cf.generateCertificate(certArray);
cert[1] = (X509Certificate) cf.generateCertificate(certArray2);
KeyStore keyTest = KeyStore.getInstance(KeyStore.getDefaultType());
try {
keyTest.aliases();
fail("expected KeyStoreException");
} catch (KeyStoreException e) {
// ok
}
keyTest.load(null, null);
// KeyStore keyTest =
// KeyStore.getInstance(KeyStore.getDefaultType());
// alias 1
keyTest.setCertificateEntry("alias1", cert[0]);
// alias 2
keyTest.setCertificateEntry("alias2", cert[0]);
// alias 3
keyTest.setCertificateEntry("alias3", cert[0]);
// obtaining the aliase
Enumeration<String> aliase = keyTest.aliases();
Set<String> alia = new HashSet<String>();
int i = 0;
while (aliase.hasMoreElements()) {
alia.add(aliase.nextElement());
i++;
}
assertEquals("the wrong aliases were returned", i, 3);
assertTrue("the wrong aliases were returned", alia.contains("alias1"));
assertTrue("the wrong aliases were returned", alia.contains("alias2"));
assertTrue("the wrong aliases were returned", alia.contains("alias3"));
}
/**
* java.security.KeyStore#containsAlias(java.lang.String)
*/
public void test_containsAliasLjava_lang_String() throws Exception {
// Test for method boolean
// java.security.KeyStore.containsAlias(java.lang.String)
CertificateFactory cf = CertificateFactory.getInstance("X.509");
X509Certificate cert[] = new X509Certificate[2];
cert[0] = (X509Certificate) cf.generateCertificate(certArray);
cert[1] = (X509Certificate) cf.generateCertificate(certArray2);
KeyStore keyTest = KeyStore.getInstance(KeyStore.getDefaultType());
try {
keyTest.containsAlias("alias1");
fail("expected KeyStoreException");
} catch (KeyStoreException e) {
// ok
}
keyTest.load(null, null);
// alias 1
keyTest.setCertificateEntry("alias1", cert[0]);
// alias 2
keyTest.setCertificateEntry("alias2", cert[0]);
assertTrue("alias1 does not exist", keyTest.containsAlias("alias1"));
assertTrue("alias2 does not exist", keyTest.containsAlias("alias2"));
assertFalse("alias3 exists", keyTest.containsAlias("alias3"));
try {
keyTest.containsAlias(null);
fail("expected NullPointerException");
} catch (NullPointerException e) {
// ok
}
}
/**
* java.security.KeyStore#getCertificate(java.lang.String)
*/
public void test_getCertificateLjava_lang_String() throws Exception {
// Test for method java.security.cert.Certificate
// java.security.KeyStore.getCertificate(java.lang.String)
CertificateFactory cf = CertificateFactory.getInstance("X.509");
X509Certificate cert[] = new X509Certificate[2];
cert[0] = (X509Certificate) cf.generateCertificate(certArray);
cert[1] = (X509Certificate) cf.generateCertificate(certArray2);
KeyStore keyTest = KeyStore.getInstance(KeyStore.getDefaultType());
try {
keyTest.getCertificate("anAlias");
fail("expected KeyStoreException");
} catch (KeyStoreException e) {
// ok
}
keyTest.load(null, null);
// alias 1
PublicKey pub = cert[0].getPublicKey();
keyTest.setCertificateEntry("alias1", cert[0]);
Certificate certRes = keyTest.getCertificate("alias1");
assertEquals("the public key of the certificate from getCertificate() "
+ "did not equal the original certificate",
pub, certRes.getPublicKey());
// alias 2
keyTest.setCertificateEntry("alias2", cert[0]);
// testing for a certificate chain
Certificate cert2 = keyTest.getCertificate("alias2");
assertEquals("the certificate for alias2 is supposed to exist",
cert2, cert[0]);
}
/**
* java.security.KeyStore#getCertificateAlias(java.security.cert.Certificate)
*/
public void test_getCertificateAliasLjava_security_cert_Certificate()
throws Exception {
// Test for method java.lang.String
// java.security.KeyStore.getCertificateAlias(java.security.cert.Certificate)
CertificateFactory cf = CertificateFactory.getInstance("X.509");
X509Certificate cert[] = new X509Certificate[2];
cert[0] = (X509Certificate) cf.generateCertificate(certArray);
cert[1] = (X509Certificate) cf.generateCertificate(certArray2);
KeyStore keyTest = KeyStore.getInstance(KeyStore.getDefaultType());
keyTest.load(null, null);
// certificate entry
keyTest.setCertificateEntry("alias1", cert[1]);
String alias = keyTest.getCertificateAlias(cert[1]);
assertEquals("certificate entry - the alias returned for this certificate was wrong",
"alias1", alias);
// key entry
keyTest.setKeyEntry("alias2", privateKey, pssWord, cert);
alias = keyTest.getCertificateAlias(cert[0]);
assertEquals("key entry - the alias returned for this certificate was wrong",
"alias2", alias);
// testing case with a nonexistent certificate
X509Certificate cert2 = (X509Certificate) cf.generateCertificate(certArray3);
String aliasNull = keyTest.getCertificateAlias(cert2);
assertNull("the alias returned for the nonexist certificate was NOT null", aliasNull);
}
/**
* java.security.KeyStore#getCertificateChain(java.lang.String)
*/
public void test_getCertificateChainLjava_lang_String() throws Exception {
// Test for method java.security.cert.Certificate[]
// java.security.KeyStore.getCertificateChain(java.lang.String)
// creatCertificate();
CertificateFactory cf = CertificateFactory.getInstance("X.509");
X509Certificate cert[] = new X509Certificate[2];
cert[0] = (X509Certificate) cf.generateCertificate(certArray);
cert[1] = (X509Certificate) cf.generateCertificate(certArray2);
KeyStore keyTest = KeyStore.getInstance(KeyStore.getDefaultType());
try {
keyTest.getCertificateChain("anAlias");
fail("expected KeyStoreException");
} catch (KeyStoreException e) {
// ok
}
keyTest.load(null, null);
// alias 1
keyTest.setCertificateEntry("alias1", cert[0]);
// alias 2
keyTest.setKeyEntry("alias2", privateKey, pssWord, cert);
Certificate[] certRes = keyTest.getCertificateChain("alias2");
assertEquals("there are more than two certificate returned from getCertificateChain",
2, certRes.length);
assertEquals("the first certificate returned from getCertificateChain is not correct",
cert[0].getPublicKey(), certRes[0].getPublicKey());
assertEquals("the second certificate returned from getCertificateChain is not correct",
cert[1].getPublicKey(), certRes[1].getPublicKey());
Certificate[] certResNull = keyTest.getCertificateChain("alias1");
assertNull("the certificate chain returned from getCertificateChain is NOT null",
certResNull);
try {
keyTest.getCertificateChain(null);
fail("expected NullPointerException");
} catch (NullPointerException e) {
// ok
}
}
/**
* java.security.KeyStore#getInstance(java.lang.String)
*/
public void test_getInstanceLjava_lang_String() throws Exception {
// Test for method java.security.KeyStore
// java.security.KeyStore.getInstance(java.lang.String)
KeyStore keyTest = KeyStore.getInstance(KeyStore.getDefaultType());
assertEquals("the method getInstance did not obtain the correct type",
KeyStore.getDefaultType(), keyTest.getType());
}
/**
* java.security.KeyStore#getKey(java.lang.String, char[])
*/
public void test_getKeyLjava_lang_String$C() throws Exception {
// Test for method java.security.Key
// java.security.KeyStore.getKey(java.lang.String, char[])
// creatCertificate();
CertificateFactory cf = CertificateFactory.getInstance("X.509");
X509Certificate cert[] = new X509Certificate[2];
cert[0] = (X509Certificate) cf.generateCertificate(certArray);
cert[1] = (X509Certificate) cf.generateCertificate(certArray2);
KeyStore keyTest = KeyStore.getInstance(KeyStore.getDefaultType());
keyTest.load(null, null);
keyTest.setKeyEntry("alias2", privateKey, pssWord, cert);
PrivateKey returnedKey = (PrivateKey) keyTest.getKey("alias2", pssWord);
byte[] retB = returnedKey.getEncoded();
byte[] priB = privateKey.getEncoded();
assertTrue(Arrays.equals(retB, priB));
assertEquals(privateKey.getAlgorithm(), returnedKey.getAlgorithm());
assertEquals(privateKey.getFormat(), returnedKey.getFormat());
try {
keyTest.getKey("alias2", "wrong".toCharArray());
fail("Should have thrown UnrecoverableKeyException");
} catch (UnrecoverableKeyException e) {
// expected
}
keyTest.setCertificateEntry("alias1", cert[1]);
assertNull("the private key returned from getKey for a certificate entry is not null",
keyTest.getKey("alias1", pssWord));
}
/**
* java.security.KeyStore#isCertificateEntry(java.lang.String)
*/
public void test_isCertificateEntryLjava_lang_String() throws Exception {
// Test for method boolean
// java.security.KeyStore.isCertificateEntry(java.lang.String)
CertificateFactory cf = CertificateFactory.getInstance("X.509");
X509Certificate cert[] = new X509Certificate[2];
cert[0] = (X509Certificate) cf.generateCertificate(certArray);
cert[1] = (X509Certificate) cf.generateCertificate(certArray2);
KeyStore keyTest = KeyStore.getInstance(KeyStore.getDefaultType());
try {
keyTest.isCertificateEntry("alias");
fail("expected KeyStoreException");
} catch (KeyStoreException e) {
// ok
}
keyTest.load(null, null);
// alias 1
keyTest.setCertificateEntry("alias1", cert[0]);
// alias 2
keyTest.setKeyEntry("alias2", privateKey, pssWord, cert);
assertTrue("isCertificateEntry method returns false for a certificate",
keyTest.isCertificateEntry("alias1"));
assertFalse("isCertificateEntry method returns true for noncertificate",
keyTest.isCertificateEntry("alias2"));
}
/**
* java.security.KeyStore#isKeyEntry(java.lang.String)
*/
public void test_isKeyEntryLjava_lang_String() throws Exception {
// Test for method boolean
// java.security.KeyStore.isKeyEntry(java.lang.String)
CertificateFactory cf = CertificateFactory.getInstance("X.509");
X509Certificate cert[] = new X509Certificate[2];
cert[0] = (X509Certificate) cf.generateCertificate(certArray);
cert[1] = (X509Certificate) cf.generateCertificate(certArray2);
KeyStore keyTest = KeyStore.getInstance(KeyStore.getDefaultType());
try {
keyTest.isKeyEntry("alias");
fail("expected KeyStoreException");
} catch (KeyStoreException e) {
// ok
}
keyTest.load(null, null);
// alias 1
keyTest.setCertificateEntry("alias1", cert[0]);
// alias 2
keyTest.setKeyEntry("alias2", privateKey, pssWord, cert);
assertTrue("isKeyEntry method returns false for a certificate",
keyTest.isKeyEntry("alias2"));
assertFalse("isKeyEntry method returns true for noncertificate",
keyTest.isKeyEntry("alias1"));
}
/**
* java.security.KeyStore#load(java.io.InputStream, char[])
*/
public void test_loadLjava_io_InputStream$C() throws Exception {
// Test for method void java.security.KeyStore.load(java.io.InputStream,
// char[])
byte[] keyStore = creatCertificate();
KeyStore keyTest = KeyStore.getInstance(KeyStore.getDefaultType());
InputStream in = new ByteArrayInputStream(keyStore);
keyTest.load(in, pssWord);
in.close();
assertTrue("alias1 is not a certificate", keyTest.isCertificateEntry("alias1"));
assertTrue("alias2 is not a keyEntry", keyTest.isKeyEntry("alias2"));
assertTrue("alias3 is not a certificate", keyTest.isCertificateEntry("alias3"));
// test with null password
keyTest = KeyStore.getInstance(KeyStore.getDefaultType());
in = new ByteArrayInputStream(keyStore);
keyTest.load(in, null);
in.close();
assertTrue("alias1 is not a certificate", keyTest.isCertificateEntry("alias1"));
assertTrue("alias2 is not a keyEntry", keyTest.isKeyEntry("alias2"));
assertTrue("alias3 is not a certificate", keyTest.isCertificateEntry("alias3"));
}
/**
* java.security.KeyStore#load(KeyStore.LoadStoreParameter param)
*/
public void test_loadLjava_security_KeyStoreLoadStoreParameter() {
try {
KeyStore keyTest = KeyStore.getInstance(KeyStore.getDefaultType());
keyTest.load(null);
} catch (Exception e ) {
fail("Unexpected Exception " + e);
}
}
/**
* java.security.KeyStore#setCertificateEntry(java.lang.String,
* java.security.cert.Certificate)
*/
public void test_setCertificateEntryLjava_lang_StringLjava_security_cert_Certificate()
throws Exception {
// Test for method void
// java.security.KeyStore.setCertificateEntry(java.lang.String,
// java.security.cert.Certificate)
CertificateFactory cf = CertificateFactory.getInstance("X.509");
X509Certificate cert = (X509Certificate) cf.generateCertificate(certArray);
KeyStore keyTest = KeyStore.getInstance(KeyStore.getDefaultType());
try {
keyTest.setCertificateEntry("alias", cert);
fail("expected KeyStoreException");
} catch (KeyStoreException e) {
// ok
}
keyTest.load(null, null);
PublicKey pub = cert.getPublicKey();
keyTest.setCertificateEntry("alias1", cert);
assertTrue("the entry specified by the alias alias1 is not a certificate",
keyTest.isCertificateEntry("alias1"));
Certificate resultCert = keyTest.getCertificate("alias1");
assertEquals("the public key of the certificate from getCertificate() "
+ "did not equal the original certificate",
pub, resultCert.getPublicKey());
}
/**
* java.security.KeyStore#setKeyEntry(java.lang.String,
* java.security.Key, char[], java.security.cert.Certificate[])
*/
public void test_setKeyEntryLjava_lang_StringLjava_security_Key$C$Ljava_security_cert_Certificate()
throws Exception {
// Test for method void
// java.security.KeyStore.setKeyEntry(java.lang.String,
// java.security.Key, char[], java.security.cert.Certificate[])
CertificateFactory cf = CertificateFactory.getInstance("X.509");
X509Certificate cert[] = new X509Certificate[2];
cert[0] = (X509Certificate) cf.generateCertificate(certArray);
cert[1] = (X509Certificate) cf.generateCertificate(certArray2);
KeyStore keyTest = KeyStore.getInstance(KeyStore.getDefaultType());
try {
keyTest.setKeyEntry("alias3", privateKey, pssWord, cert);
fail("expected KeyStoreException");
} catch (KeyStoreException e) {
// ok
}
keyTest.load(null, null);
keyTest.setKeyEntry("alias3", privateKey, pssWord, cert);
assertTrue("the entry specified by the alias alias3 is not a keyEntry",
keyTest.isKeyEntry("alias3"));
try {
keyTest.setKeyEntry("alias4", privateKey, pssWord, new Certificate[] {});
fail("expected IllegalArgumentException");
} catch (IllegalArgumentException e) {
// ok
}
}
/**
* java.security.KeyStore#size()
*/
public void test_size() throws Exception {
// Test for method int java.security.KeyStore.size()
CertificateFactory cf = CertificateFactory.getInstance("X.509");
X509Certificate cert[] = new X509Certificate[2];
cert[0] = (X509Certificate) cf.generateCertificate(certArray);
cert[1] = (X509Certificate) cf.generateCertificate(certArray2);
KeyStore keyTest = KeyStore.getInstance(KeyStore.getDefaultType());
try {
keyTest.size();
fail("expected KeyStoreException");
} catch (KeyStoreException e) {
// ok
}
keyTest.load(null, null);
// alias 1
keyTest.setCertificateEntry("alias1", cert[0]);
// alias 2
keyTest.setKeyEntry("alias2", privateKey, pssWord, cert);
// alias 3
keyTest.setCertificateEntry("alias3", cert[1]);
assertEquals("the size of the keyStore is not 3", 3, keyTest.size());
}
public void test_deleteEmptyEntry() {
try {
KeyStore keyTest = KeyStore.getInstance(KeyStore.getDefaultType());
keyTest.load(null, null);
keyTest.deleteEntry("");
} catch (Exception e) {
fail("Unexpected Exception " + e);
}
try {
KeyStore keyTest = KeyStore.getInstance(KeyStore.getDefaultType());
keyTest.load(null, null);
keyTest.deleteEntry("entry");
} catch (Exception e) {
fail("Unexpected Exception " + e);
}
}
/**
* java.security.KeyStore#deleteEntry(String)
*/
public void test_deleteEntry() {
try {
KeyStore keyTest = KeyStore.getInstance(KeyStore.getDefaultType());
keyTest.load(null, null);
keyTest.deleteEntry(null);
fail("NullPointerException expected");
} catch (NullPointerException e) {
// expected
} catch (Exception e) {
fail("Unexpected Exception " + e);
}
try {
KeyStore keyTest = KeyStore.getInstance(KeyStore.getDefaultType());
keyTest.load(null, "password".toCharArray());
KeyStore.PasswordProtection pp = new KeyStore.PasswordProtection(
pssWord);
Certificate[] chain = { new MyCertificate("DSA", testEncoding),
new MyCertificate("DSA", testEncoding) };
KeyStore.PrivateKeyEntry pkEntry = new KeyStore.PrivateKeyEntry(
privateKey, chain);
keyTest.setEntry("symKey", pkEntry, pp);
keyTest.deleteEntry("symKey");
} catch (KeyStoreException e) {
fail("Unexpected KeyStoreException " + e.getMessage());
} catch (IOException e) {
fail("Unexpected IOException " + e.getMessage());
} catch (NoSuchAlgorithmException e) {
fail("Unexpected NoSuchAlgorithmException " + e.getMessage());
} catch (CertificateException e) {
fail("Unexpected CertificateException " + e.getMessage());
} catch (Exception e) {
fail("Unexpected Exception " + e);
}
}
/**
* java.security.KeyStore#getCreationDate(String)
*/
public void test_getCreationDate() throws Exception {
String type = "DSA";
KeyStore keyTest = KeyStore.getInstance(KeyStore.getDefaultType());
try {
keyTest.getCreationDate("anAlias");
fail("expected KeyStoreException");
} catch (KeyStoreException e) {
// ok
}
keyTest.load(null, pssWord);
assertNull(keyTest.getCreationDate(""));
try {
keyTest.getCreationDate(null);
fail("NullPointerException expected");
} catch (NullPointerException e) {
// expected
}
Certificate[] chain = { new MyCertificate(type, testEncoding),
new MyCertificate(type, testEncoding) };
PrivateKey privateKey1 = KeyFactory.getInstance(type).generatePrivate(
new DSAPrivateKeySpec(new BigInteger("0"), new BigInteger("0"),
new BigInteger("0"), new BigInteger("0")));
KeyStore.PasswordProtection pp = new KeyStore.PasswordProtection(
pssWord);
KeyStore.PrivateKeyEntry pke = new KeyStore.PrivateKeyEntry(privateKey,
chain);
KeyStore.PrivateKeyEntry pke1 = new KeyStore.PrivateKeyEntry(
privateKey1, chain);
keyTest.setEntry("alias1", pke, pp);
keyTest.setEntry("alias2", pke1, pp);
Calendar.getInstance().get(Calendar.DAY_OF_MONTH);
int dayExpected = Calendar.getInstance().get(Calendar.DAY_OF_MONTH);
int monthExpected = Calendar.getInstance().get(Calendar.MONTH);
int yearExpected = Calendar.getInstance().get(Calendar.YEAR);
int hourExpected = Calendar.getInstance().get(Calendar.HOUR);
int minuteExpected = Calendar.getInstance().get(Calendar.MINUTE);
Calendar.getInstance().setTimeInMillis(
keyTest.getCreationDate("alias1").getTime());
int dayActual1 = Calendar.getInstance().get(Calendar.DAY_OF_MONTH);
int monthActual1 = Calendar.getInstance().get(Calendar.MONTH);
int yearActual1 = Calendar.getInstance().get(Calendar.YEAR);
int hourActual1 = Calendar.getInstance().get(Calendar.HOUR);
int minuteActual1 = Calendar.getInstance().get(Calendar.MINUTE);
assertEquals(dayExpected, dayActual1);
assertEquals(monthExpected, monthActual1);
assertEquals(yearExpected, yearActual1);
assertEquals(hourExpected, hourActual1);
assertEquals(minuteExpected, minuteActual1);
Calendar.getInstance().setTimeInMillis(
keyTest.getCreationDate("alias2").getTime());
int dayActual2 = Calendar.getInstance().get(Calendar.DAY_OF_MONTH);
int monthActual2 = Calendar.getInstance().get(Calendar.MONTH);
int yearActual2 = Calendar.getInstance().get(Calendar.YEAR);
int hourActual2 = Calendar.getInstance().get(Calendar.HOUR);
int minuteActual2 = Calendar.getInstance().get(Calendar.MINUTE);
assertEquals(dayExpected, dayActual2);
assertEquals(monthExpected, monthActual2);
assertEquals(yearExpected, yearActual2);
assertEquals(hourExpected, hourActual2);
assertEquals(minuteExpected, minuteActual2);
try {
keyTest.getCreationDate(null);
fail("expected NullPointerException");
} catch (NullPointerException e) {
// ok
}
}
/**
* java.security.KeyStore#getEntry(String,
* KeyStore.ProtectionParameter)
*/
public void test_getEntry() {
String type = "DSA";
KeyStore keyTest = null;
KeyStore.PasswordProtection pp = null;
try {
keyTest = KeyStore.getInstance(KeyStore.getDefaultType());
} catch (KeyStoreException e) {
fail("unexpected exception: " + e);
}
try {
keyTest.getEntry("anAlias", new KeyStore.PasswordProtection(new char[] {}));
fail("expected KeyStoreException");
} catch (KeyStoreException e) {
// ok
} catch (NoSuchAlgorithmException e) {
fail("unexpected exception: " + e);
} catch (UnrecoverableEntryException e) {
fail("unexpected exception: " + e);
}
try {
keyTest.load(null, pssWord);
} catch (NoSuchAlgorithmException e) {
fail("unexpected exception: " + e);
} catch (CertificateException e) {
fail("unexpected exception: " + e);
} catch (IOException e) {
fail("unexpected exception: " + e);
}
try {
keyTest.getEntry(null, new KeyStore.PasswordProtection(new char[] {}));
fail("expected NullPointerException");
} catch (NullPointerException e) {
// ok
} catch (NoSuchAlgorithmException e) {
fail("unexpected exception: " + e);
} catch (UnrecoverableEntryException e) {
fail("unexpected exception: " + e);
} catch (KeyStoreException e) {
fail("unexpected exception: " + e);
}
try {
keyTest.getEntry("anAlias", null);
} catch (NullPointerException e) {
fail("unexpected exception: " + e);
} catch (NoSuchAlgorithmException e) {
fail("unexpected exception: " + e);
} catch (UnrecoverableEntryException e) {
fail("unexpected exception: " + e);
} catch (KeyStoreException e) {
fail("unexpected exception: " + e);
}
try {
keyTest.getEntry(null, null);
fail("expected NullPointerException");
} catch (NullPointerException e) {
// ok
} catch (NoSuchAlgorithmException e) {
fail("unexpected exception: " + e);
} catch (UnrecoverableEntryException e) {
fail("unexpected exception: " + e);
} catch (KeyStoreException e) {
fail("unexpected exception: " + e);
}
try {
assertNull(keyTest.getEntry("alias", pp));
} catch (NoSuchAlgorithmException e) {
fail("unexpected exception: " + e);
} catch (UnrecoverableEntryException e) {
fail("unexpected exception: " + e);
} catch (KeyStoreException e) {
fail("unexpected exception: " + e);
}
Certificate[] chain = { new MyCertificate(type, testEncoding),
new MyCertificate(type, testEncoding) };
DSAPrivateKey privateKey1 = null;
try {
privateKey1 = (DSAPrivateKey) KeyFactory.getInstance(type)
.generatePrivate(
new DSAPrivateKeySpec(new BigInteger("1"),
new BigInteger("2"), new BigInteger("3"),
new BigInteger("4")));
} catch (InvalidKeySpecException e) {
fail("unexpected exception: " + e);
} catch (NoSuchAlgorithmException e) {
fail("unexpected exception: " + e);
}
pp = new KeyStore.PasswordProtection(pssWord);
try {
assertNull(keyTest.getEntry("alias", pp));
} catch (NoSuchAlgorithmException e) {
fail("unexpected exception: " + e);
} catch (UnrecoverableEntryException e) {
fail("unexpected exception: " + e);
} catch (KeyStoreException e) {
fail("unexpected exception: " + e);
}
KeyStore.PrivateKeyEntry pke1 = new KeyStore.PrivateKeyEntry(
privateKey, chain);
KeyStore.PrivateKeyEntry pke2 = new KeyStore.PrivateKeyEntry(
privateKey1, chain);
try {
keyTest.setEntry("alias1", pke1, pp);
} catch (KeyStoreException e) {
fail("unexpected exception: " + e);
}
try {
keyTest.setEntry("alias2", pke2, pp);
} catch (KeyStoreException e) {
fail("unexpected exception: " + e);
}
try {
assertNull(keyTest.getEntry("alias", pp));
} catch (NoSuchAlgorithmException e) {
fail("unexpected exception: " + e);
} catch (UnrecoverableEntryException e) {
fail("unexpected exception: " + e);
} catch (KeyStoreException e) {
fail("unexpected exception: " + e);
}
KeyStore.PrivateKeyEntry pkeActual1 = null;
try {
pkeActual1 = (KeyStore.PrivateKeyEntry) keyTest.getEntry("alias1", pp);
} catch (NoSuchAlgorithmException e) {
fail("unexpected exception: " + e);
} catch (UnrecoverableEntryException e) {
fail("unexpected exception: " + e);
} catch (KeyStoreException e) {
fail("unexpected exception: " + e);
}
KeyStore.PrivateKeyEntry pkeActual2 = null;
try {
pkeActual2 = (KeyStore.PrivateKeyEntry) keyTest.getEntry("alias2", pp);
} catch (NoSuchAlgorithmException e) {
fail("unexpected exception: " + e);
} catch (UnrecoverableEntryException e) {
fail("unexpected exception: " + e);
} catch (KeyStoreException e) {
fail("unexpected exception: " + e);
}
assertTrue(Arrays.equals(chain, pkeActual1.getCertificateChain()));
assertEquals(privateKey, pkeActual1.getPrivateKey());
assertEquals(new MyCertificate(type, testEncoding), pkeActual1.getCertificate());
try {
assertTrue(keyTest.entryInstanceOf("alias1", KeyStore.PrivateKeyEntry.class));
} catch (KeyStoreException e) {
fail("unexpected exception: " + e);
}
assertTrue(Arrays.equals(chain, pkeActual2.getCertificateChain()));
DSAPrivateKey entryPrivateKey = (DSAPrivateKey) pkeActual2.getPrivateKey();
assertEquals(privateKey1.getX(), entryPrivateKey.getX());
assertEquals(privateKey1.getParams().getG(), entryPrivateKey.getParams().getG());
assertEquals(privateKey1.getParams().getP(), entryPrivateKey.getParams().getP());
assertEquals(privateKey1.getParams().getQ(), entryPrivateKey.getParams().getQ());
assertEquals(new MyCertificate(type, testEncoding), pkeActual2.getCertificate());
try {
assertTrue(keyTest.entryInstanceOf("alias2", KeyStore.PrivateKeyEntry.class));
} catch (KeyStoreException e) {
fail("unexpected exception: " + e);
}
}
/**
* java.security.KeyStore#setEntry(String, KeyStore.Entry,
* KeyStore.ProtectionParameter)
*/
public void test_setEntry() {
String type = "DSA";
KeyStore keyTest = null;
KeyStore.PasswordProtection pp = null;
try {
keyTest = KeyStore.getInstance(KeyStore.getDefaultType());
keyTest.load(null, pssWord);
Certificate[] chain = { new MyCertificate(type, testEncoding),
new MyCertificate(type, testEncoding) };
DSAPrivateKey privateKey1 = (DSAPrivateKey) KeyFactory.getInstance(type)
.generatePrivate(
new DSAPrivateKeySpec(new BigInteger("1"),
new BigInteger("2"), new BigInteger("3"),
new BigInteger("4")));
pp = new KeyStore.PasswordProtection(pssWord);
KeyStore.PrivateKeyEntry pke = new KeyStore.PrivateKeyEntry(privateKey, chain);
KeyStore.PrivateKeyEntry pke1 = new KeyStore.PrivateKeyEntry(privateKey1, chain);
try {
keyTest.setEntry("alias", pke, null);
fail("Exception expected");
} catch (Exception e) {
// expected
}
keyTest.setEntry("alias", pke, pp);
KeyStore.PrivateKeyEntry pkeActual = (KeyStore.PrivateKeyEntry)
keyTest.getEntry("alias",pp);
assertTrue(Arrays.equals(chain, pkeActual.getCertificateChain()));
assertEquals(privateKey, pkeActual.getPrivateKey());
assertEquals(new MyCertificate(type, testEncoding), pkeActual.getCertificate());
assertTrue(keyTest.entryInstanceOf("alias", KeyStore.PrivateKeyEntry.class));
keyTest.setEntry("alias", pke1, pp);
pkeActual = (KeyStore.PrivateKeyEntry) keyTest.getEntry("alias", pp);
assertTrue(Arrays.equals(chain, pkeActual.getCertificateChain()));
DSAPrivateKey actualPrivateKey = (DSAPrivateKey) pkeActual.getPrivateKey();
assertEquals(privateKey1.getX(), actualPrivateKey.getX());
assertEquals(privateKey1.getParams().getG(), actualPrivateKey.getParams().getG());
assertEquals(privateKey1.getParams().getP(), actualPrivateKey.getParams().getP());
assertEquals(privateKey1.getParams().getQ(), actualPrivateKey.getParams().getQ());
assertEquals(new MyCertificate(type, testEncoding), pkeActual.getCertificate());
assertTrue(keyTest.entryInstanceOf("alias", KeyStore.PrivateKeyEntry.class));
keyTest.setEntry("alias2", pke1, pp);
pkeActual = (KeyStore.PrivateKeyEntry) keyTest.getEntry("alias2", pp);
assertTrue(Arrays.equals(chain, pkeActual.getCertificateChain()));
actualPrivateKey = (DSAPrivateKey) pkeActual.getPrivateKey();
assertEquals(privateKey1.getX(), actualPrivateKey.getX());
assertEquals(privateKey1.getParams().getG(), actualPrivateKey.getParams().getG());
assertEquals(privateKey1.getParams().getP(), actualPrivateKey.getParams().getP());
assertEquals(privateKey1.getParams().getQ(), actualPrivateKey.getParams().getQ());
assertEquals(new MyCertificate(type, testEncoding), pkeActual.getCertificate());
assertTrue(keyTest.entryInstanceOf("alias2", KeyStore.PrivateKeyEntry.class));
} catch (Exception e) {
fail("Unexpected Exception " + e);
}
try {
keyTest.setEntry(null, null, null);
fail("NullPointerException expected");
} catch (NullPointerException e) {
// expected
} catch (Exception e) {
fail("Unexpected exception");
}
}
/*
* java.security.KeyStore.entryInstanceOf(String, Class<? extends
* Entry>)
*/
public void test_entryInstanceOf() throws Exception {
KeyStore keyStore = KeyStore.getInstance(KeyStore.getDefaultType());
try {
keyStore.entryInstanceOf("anAlias", KeyStore.SecretKeyEntry.class);
fail("expected KeyStoreException");
} catch (KeyStoreException e) {
// ok
}
keyStore.load(null, "pwd".toCharArray());
// put the key into keystore
String alias = "alias";
Certificate[] chain = { new MyCertificate("DSA", testEncoding),
new MyCertificate("DSA", testEncoding) };
keyStore.setKeyEntry(alias, privateKey, "pwd".toCharArray(), chain);
assertTrue(keyStore.entryInstanceOf(alias, KeyStore.PrivateKeyEntry.class));
assertFalse(keyStore.entryInstanceOf(alias, KeyStore.SecretKeyEntry.class));
assertFalse(keyStore.entryInstanceOf(alias, KeyStore.TrustedCertificateEntry.class));
try {
keyStore.entryInstanceOf(null, KeyStore.SecretKeyEntry.class);
fail("expected NullPointerException");
} catch (NullPointerException e) {
// ok
}
try {
keyStore.entryInstanceOf("anAlias", null);
fail("expected NullPointerException");
} catch (NullPointerException e) {
// ok
}
}
/**
* java.security.KeyStore#store(KeyStore.LoadStoreParameter)
*/
public void test_store_java_securityKeyStore_LoadStoreParameter()
throws Exception {
KeyStore keyStore = KeyStore.getInstance(KeyStore.getDefaultType());
keyStore.load(null, "pwd".toCharArray());
try {
keyStore.store(null);
fail("UnsupportedOperationException expected");
} catch (UnsupportedOperationException e) {
// expected
}
}
/**
* java.security.KeyStore#store(OutputStream, char[])
*/
public void test_store_java_io_OutputStream_char() throws Exception {
KeyStore keyStore = KeyStore.getInstance(KeyStore.getDefaultType());
try {
keyStore.store(new ByteArrayOutputStream(), "pwd".toCharArray());
fail("expected KeyStoreException");
} catch (KeyStoreException e) {
// ok
}
keyStore.load(null, "pwd".toCharArray());
try {
keyStore.store(null, "pwd".toCharArray());
fail("NullPointerException or IOException expected");
} catch (NullPointerException e) {
// expected
} catch (IOException e) {
// also ok
} catch (Exception e) {
fail("Unexpected Exception " + e);
}
}
/**
* Sets up the fixture, for example, open a network connection. This method
* is called before a test is executed.
*/
protected void setUp() throws Exception {
super.setUp();
support_TestProvider = new Support_TestProvider();
Security.addProvider(support_TestProvider);
}
protected void tearDown() throws Exception {
super.tearDown();
Security.removeProvider(support_TestProvider.getName());
}
class MyCertificate extends Certificate {
// MyCertificate encoding
private final byte[] encoding;
public MyCertificate(String type, byte[] encoding) {
super(type);
// don't copy to allow null parameter in test
this.encoding = encoding;
}
public byte[] getEncoded() throws CertificateEncodingException {
// do copy to force NPE in test
return encoding.clone();
}
public void verify(PublicKey key) throws CertificateException,
NoSuchAlgorithmException, InvalidKeyException,
NoSuchProviderException, SignatureException {
}
public void verify(PublicKey key, String sigProvider)
throws CertificateException, NoSuchAlgorithmException,
InvalidKeyException, NoSuchProviderException,
SignatureException {
}
public String toString() {
return "[My test Certificate, type: " + getType() + "]";
}
public PublicKey getPublicKey() {
return new PublicKey() {
public String getAlgorithm() {
return "DSA";
}
public byte[] getEncoded() {
return new byte[] { (byte) 1, (byte) 2, (byte) 3 };
}
public String getFormat() {
return "TEST_FORMAT";
}
};
}
}
}