/* * 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. */ /** * @author Vladimir N. Molotkov * @version $Revision$ */ package tests.security.cert; import dalvik.annotation.KnownFailure; import dalvik.annotation.TestLevel; import dalvik.annotation.TestTargetClass; import dalvik.annotation.TestTargetNew; import dalvik.annotation.TestTargets; import junit.framework.TestCase; import org.apache.harmony.security.tests.support.cert.MyCertPath; import org.apache.harmony.security.tests.support.cert.MyFailingCertPath; import org.apache.harmony.security.tests.support.cert.TestUtils; import org.apache.harmony.testframework.serialization.SerializationTest; import org.apache.harmony.testframework.serialization.SerializationTest.SerializableAssert; import java.io.ObjectStreamException; import java.io.Serializable; import java.security.cert.CertPath; import java.security.cert.CertificateEncodingException; import java.util.Arrays; /** * Tests for <code>CertPath</code> fields and methods * */ @TestTargetClass(CertPath.class) public class CertPathTest extends TestCase { /** * Meaningless cert path encoding just for testing purposes */ private static final byte[] testEncoding = new byte[] { (byte)1, (byte)2, (byte)3, (byte)4, (byte)5 }; private static final byte[] testEncoding1 = new byte[] { (byte)1, (byte)2, (byte)3, (byte)4, (byte)5, (byte)6 }; // // Tests // /** * Test for <code>CertPath(String type)</code> method<br> * Assertion: returns hash of the <code>Certificate</code> instance */ @TestTargetNew( level = TestLevel.COMPLETE, notes = "", method = "CertPath", args = {java.lang.String.class} ) public final void testCertPath() { try { CertPath cp1 = new MyCertPath(testEncoding); assertEquals("MyEncoding", cp1.getType()); assertTrue(Arrays.equals(testEncoding, cp1.getEncoded())); } catch (CertificateEncodingException e) { fail("Unexpected CertificateEncodingException " + e.getMessage()); } try { CertPath cp1 = new MyCertPath(null); } catch (Exception e) { fail("Unexpected exception " + e.getMessage()); } } /** * Test for <code>hashCode()</code> method<br> * Assertion: returns hash of the <code>Certificate</code> instance */ @TestTargetNew( level = TestLevel.PARTIAL_COMPLETE, notes = "", method = "hashCode", args = {} ) public final void testHashCode() { CertPath cp1 = new MyCertPath(testEncoding); CertPath cp2 = new MyCertPath(testEncoding); CertPath cp3 = new MyCertPath(testEncoding1); assertTrue(cp1.hashCode() == cp2.hashCode()); assertTrue(cp1.hashCode() != cp3.hashCode()); } /** * Test for <code>hashCode()</code> method<br> * Assertion: hash code of equal objects should be the same */ @TestTargetNew( level = TestLevel.PARTIAL_COMPLETE, notes = "", method = "hashCode", args = {} ) public final void testHashCodeEqualsObject() { CertPath cp1 = new MyCertPath(testEncoding); CertPath cp2 = new MyCertPath(testEncoding); assertTrue((cp1.hashCode() == cp2.hashCode()) && cp1.equals(cp2)); } /** * Test for <code>getType()</code> method<br> * Assertion: returns cert path type */ @TestTargetNew( level = TestLevel.COMPLETE, notes = "", method = "getType", args = {} ) public final void testGetType() { assertEquals("MyEncoding", new MyCertPath(testEncoding).getType()); } /** * Test #1 for <code>equals(Object)</code> method<br> * Assertion: object equals to itself */ @TestTargetNew( level = TestLevel.PARTIAL_COMPLETE, notes = "Verifies that object equals to itself.", method = "equals", args = {java.lang.Object.class} ) public final void testEqualsObject01() { CertPath cp1 = new MyCertPath(testEncoding); assertTrue(cp1.equals(cp1)); } /** * Test for <code>equals(Object)</code> method<br> * Assertion: object equals to other <code>CertPath</code> * instance with the same state */ @TestTargetNew( level = TestLevel.PARTIAL_COMPLETE, notes = "Verifies that CertPath object equals to other CertPath with the same state.", method = "equals", args = {java.lang.Object.class} ) public final void testEqualsObject02() { CertPath cp1 = new MyCertPath(testEncoding); CertPath cp2 = new MyCertPath(testEncoding); assertTrue(cp1.equals(cp2) && cp2.equals(cp1)); } /** * Test for <code>equals(Object)</code> method<br> * Assertion: object not equals to <code>null</code> */ @TestTargetNew( level = TestLevel.PARTIAL_COMPLETE, notes = "Verifies null as a parameter.", method = "equals", args = {java.lang.Object.class} ) public final void testEqualsObject03() { CertPath cp1 = new MyCertPath(testEncoding); assertFalse(cp1.equals(null)); } /** * Test for <code>equals(Object)</code> method<br> * Assertion: object not equals to other which is not * instance of <code>CertPath</code> */ @TestTargetNew( level = TestLevel.PARTIAL_COMPLETE, notes = "Verifies non equal objects.", method = "equals", args = {java.lang.Object.class} ) public final void testEqualsObject04() { CertPath cp1 = new MyCertPath(testEncoding); assertFalse(cp1.equals("MyEncoding")); } /** * Test for <code>toString()</code> method<br> * Assertion: returns string representation of * <code>CertPath</code> object */ @TestTargetNew( level = TestLevel.COMPLETE, notes = "", method = "toString", args = {} ) public final void testToString() { CertPath cp1 = new MyCertPath(testEncoding); assertNotNull(cp1.toString()); } // // the following tests just call methods // that are abstract in <code>CertPath</code> // (So they just like signature tests) // /** * This test just calls <code>getCertificates()</code> method<br> */ @TestTargetNew( level = TestLevel.COMPLETE, notes = "Abstract method.", method = "getCertificates", args = {} ) public final void testGetCertificates() { CertPath cp1 = new MyCertPath(testEncoding); cp1.getCertificates(); } /** * This test just calls <code>getEncoded()</code> method<br> * * @throws CertificateEncodingException */ @TestTargetNew( level = TestLevel.COMPLETE, notes = "Abstract method.", method = "getEncoded", args = {} ) public final void testGetEncoded() throws CertificateEncodingException { CertPath cp1 = new MyCertPath(testEncoding); cp1.getEncoded(); } /** * This test just calls <code>getEncoded(String)</code> method<br> * * @throws CertificateEncodingException */ @TestTargetNew( level = TestLevel.COMPLETE, notes = "Abstract method.", method = "getEncoded", args = {java.lang.String.class} ) public final void testGetEncodedString() throws CertificateEncodingException { CertPath cp1 = new MyCertPath(testEncoding); cp1.getEncoded("MyEncoding"); } /** * This test just calls <code>getEncodings()</code> method<br> */ @TestTargetNew( level = TestLevel.COMPLETE, notes = "Abstract method.", method = "getEncodings", args = {} ) public final void testGetEncodings() { CertPath cp1 = new MyCertPath(testEncoding); cp1.getEncodings(); } /** * This test just calls <code>writeReplace()</code> method<br> */ @TestTargetNew( level = TestLevel.PARTIAL_COMPLETE, notes = "Doesn't verify ObjectStreamException.", method = "writeReplace", args = {} ) public final void testWriteReplace() { try { MyCertPath cp1 = new MyCertPath(testEncoding); Object obj = cp1.writeReplace(); assertTrue(obj.toString().contains( "java.security.cert.CertPath$CertPathRep")); } catch (ObjectStreamException e) { fail("Unexpected ObjectStreamException " + e.getMessage()); } } @TestTargetNew( level = TestLevel.PARTIAL_COMPLETE, notes = "verifies ObjectStreamException.", method = "writeReplace", args = {} ) public final void testWriteReplace_ObjectStreamException() { try { MyFailingCertPath cp = new MyFailingCertPath(testEncoding); Object obj = cp.writeReplace(); fail("expected ObjectStreamException"); } catch (ObjectStreamException e) { // ok } } /** * @tests serialization/deserialization compatibility. */ @TestTargets({ @TestTargetNew( level = TestLevel.COMPLETE, notes = "Verifies serialization/deserialization compatibility. And tests default constructor", method = "!SerializationSelf", args = {} ), @TestTargetNew( level = TestLevel.PARTIAL_COMPLETE, notes = "", method = "writeReplace", args = {} ), @TestTargetNew( level = TestLevel.PARTIAL_COMPLETE, notes = "", method = "CertPath.CertPathRep.readResolve", args = {} ) }) // Test passed on RI @KnownFailure(value="expired certificate bug 2322662") public void testSerializationSelf() throws Exception { TestUtils.initCertPathSSCertChain(); CertPath certPath = TestUtils.buildCertPathSSCertChain(); SerializationTest.verifySelf(certPath); } /** * @tests serialization/deserialization compatibility with RI. */ @TestTargets({ @TestTargetNew( level = TestLevel.COMPLETE, notes = "Verifies serialization/deserialization compatibility.", method = "!SerializationGolden", args = {} ), @TestTargetNew( level = TestLevel.PARTIAL_COMPLETE, notes = "", method = "writeReplace", args = {} ), @TestTargetNew( level = TestLevel.PARTIAL_COMPLETE, notes = "", method = "CertPath.CertPathRep.readResolve", args = {} ) }) // Test passed on RI @KnownFailure(value="expired certificate bug 2322662") public void testSerializationCompatibility() throws Exception { TestUtils.initCertPathSSCertChain(); CertPath certPath = TestUtils.buildCertPathSSCertChain(); SerializationTest.verifyGolden(this, certPath); } }