/* * 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.InputStream; import java.io.OutputStream; import java.io.UnsupportedEncodingException; import java.security.Identity; import java.security.IdentityScope; import java.security.KeyManagementException; import java.security.KeyPairGenerator; import java.security.Principal; import java.security.PublicKey; import java.security.cert.CertificateFactory; import java.security.cert.X509Certificate; import org.apache.harmony.security.tests.java.security.IdentityScope2Test.IdentityScopeSubclass; public class Identity2Test extends junit.framework.TestCase { static PublicKey pubKey; static { try { pubKey = KeyPairGenerator.getInstance("DSA").genKeyPair().getPublic(); } catch (Exception e) { fail(e.toString()); } } public static class CertificateImpl implements java.security.Certificate { X509Certificate cert; public CertificateImpl(X509Certificate cert) { this.cert = cert; } public Principal getGuarantor() { return cert.getIssuerDN(); } public void encode(OutputStream out) { } public void decode(InputStream in) { } public String toString() { return ""; } public String toString(boolean b) { return ""; } public String getFormat() { return cert.getType(); } public Principal getPrincipal() { return cert.getSubjectDN(); } public PublicKey getPublicKey() { return cert.getPublicKey(); } } 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; 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; { try { certArray = new ByteArrayInputStream(certificate .getBytes("UTF-8")); certArray2 = new ByteArrayInputStream(certificate2 .getBytes("UTF-8")); } catch (UnsupportedEncodingException e) { throw new RuntimeException(e.getMessage()); } } public static class IdentitySubclass extends Identity { public IdentitySubclass() { super(); } public IdentitySubclass(String name) { super(name); } public IdentitySubclass(String name, IdentityScope scope) throws KeyManagementException { super(name, scope); } } /** * @tests java.security.Identity#Identity() */ public void test_Constructor() { new IdentitySubclass(); } /** * @tests java.security.Identity#Identity(java.lang.String) */ public void test_ConstructorLjava_lang_String() { new IdentitySubclass("test"); } /** * @tests java.security.Identity#Identity(java.lang.String, *java.security.IdentityScope) */ public void test_ConstructorLjava_lang_StringLjava_security_IdentityScope() throws Exception { new IdentitySubclass("test", new IdentityScopeSubclass()); } /** * @tests java.security.Identity#getScope() */ public void test_getScope() throws Exception { IdentityScope scope = new IdentityScopeSubclass(); IdentitySubclass sub = new IdentitySubclass("test", scope); IdentityScope returnedScope = sub.getScope(); assertEquals("Wrong Scope returned", scope, returnedScope); } /** * @tests java.security.Identity#getPublicKey() */ public void test_getPublicKey() throws Exception { IdentitySubclass sub = new IdentitySubclass("test", new IdentityScopeSubclass()); sub.setPublicKey(pubKey); PublicKey returnedPubKey = sub.getPublicKey(); assertEquals("Wrong PublicKey returned", pubKey, returnedPubKey); } /** * @tests java.security.Identity#getName() */ public void test_getName() throws Exception { String name = "test"; IdentitySubclass sub = new IdentitySubclass(name, new IdentityScopeSubclass()); assertEquals("Wrong Name returned", name, sub.getName()); } /** * @tests java.security.Identity#getInfo() */ public void test_getInfo() throws Exception { String info = "This is the general information."; IdentitySubclass sub = new IdentitySubclass("test", new IdentityScopeSubclass()); sub.setInfo(info); assertEquals("Wrong Info returned", info, sub.getInfo()); } /** * @tests java.security.Identity#certificates() */ public void test_certificates() throws Exception { IdentitySubclass sub = new IdentitySubclass("test", new IdentityScopeSubclass()); CertificateFactory cf = CertificateFactory.getInstance("X.509"); X509Certificate cert[] = new X509Certificate[1]; cert[0] = (X509Certificate) cf.generateCertificate(certArray); sub.setPublicKey(cert[0].getPublicKey()); CertificateImpl certImpl = new CertificateImpl(cert[0]); sub.addCertificate(certImpl); java.security.Certificate[] certs = sub.certificates(); assertEquals("Certificate not contained in the identity", certs[0], certImpl); } /** * @tests java.security.Identity#addCertificate(java.security.Certificate) */ public void test_addCertificateLjava_security_Certificate() throws Exception { IdentitySubclass sub = new IdentitySubclass("test", new IdentityScopeSubclass()); CertificateFactory cf = CertificateFactory.getInstance("X.509"); X509Certificate cert[] = new X509Certificate[1]; cert[0] = (X509Certificate) cf.generateCertificate(certArray); sub.setPublicKey(cert[0].getPublicKey()); CertificateImpl certImpl = new CertificateImpl(cert[0]); sub.addCertificate(certImpl); } /** * @tests java.security.Identity#removeCertificate(java.security.Certificate) */ public void test_removeCertificateLjava_security_Certificate() throws Exception { IdentitySubclass sub = new IdentitySubclass("test", new IdentityScopeSubclass()); CertificateFactory cf = CertificateFactory.getInstance("X.509"); X509Certificate cert[] = new X509Certificate[1]; cert[0] = (X509Certificate) cf.generateCertificate(certArray); sub.setPublicKey(cert[0].getPublicKey()); CertificateImpl certImpl = new CertificateImpl(cert[0]); sub.addCertificate(certImpl); sub.removeCertificate(certImpl); java.security.Certificate[] certs = sub.certificates(); assertEquals("Certificate not removed", 0, certs.length); } /** * @tests java.security.Identity#equals(java.lang.Object) */ public void test_equalsLjava_lang_Object() throws Exception { IdentitySubclass sub = new IdentitySubclass("test", new IdentityScopeSubclass()); CertificateFactory cf = CertificateFactory.getInstance("X.509"); X509Certificate cert[] = new X509Certificate[1]; cert[0] = (X509Certificate) cf.generateCertificate(certArray); sub.setPublicKey(cert[0].getPublicKey()); CertificateImpl certImpl = new CertificateImpl(cert[0]); sub.addCertificate(certImpl); IdentitySubclass sub2 = new IdentitySubclass("test", new IdentityScopeSubclass()); assertEquals("the two Identity objects are not equal", sub2, sub); } /** * @tests java.security.Identity#identityEquals(java.security.Identity) */ public void test_identityEqualsLjava_security_Identity() throws Exception { IdentitySubclass sub = new IdentitySubclass("test", null); CertificateFactory cf = CertificateFactory.getInstance("X.509"); X509Certificate cert[] = new X509Certificate[1]; cert[0] = (X509Certificate) cf.generateCertificate(certArray); sub.setPublicKey(cert[0].getPublicKey()); CertificateImpl certImpl = new CertificateImpl(cert[0]); sub.addCertificate(certImpl); IdentitySubclass sub2 = new IdentitySubclass("test", null); sub2.setPublicKey(cert[0].getPublicKey()); assertEquals("the two Identity objects are not identity-equal", sub2, sub); } /** * @tests java.security.Identity#toString() */ public void test_toString() throws Exception { IdentitySubclass sub = new IdentitySubclass("test", null); assertNotNull(sub.toString()); assertTrue("The String returned is not valid", sub.toString() .length() > 0); // Regression for HARMONY-1566 assertNotNull(new IdentitySubclass().toString()); } /** * @tests java.security.Identity#toString(boolean) */ public void test_toStringZ() throws Exception { IdentitySubclass sub = new IdentitySubclass("test", null); assertNotNull(sub.toString(true)); assertTrue("The String returned is not valid", sub.toString(true) .length() > 0); } /** * @tests java.security.Identity#hashCode() */ public void test_hashCode() throws Exception { IdentitySubclass sub = new IdentitySubclass("test", null); IdentitySubclass sub2 = new IdentitySubclass("test", null); assertEquals("The 2 hash codes are not equal", sub.hashCode(), sub2 .hashCode()); } }