/*
* Copyright (c) 1999, 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
* @author Gary Ellison
* @bug 4183136
* @summary java.security.Identity violates equals/hashCode contract
*/
import java.security.*;
import java.io.*;
public class EqualsHashCodeContract
{
public static void main(String args[]) throws Exception {
Identity i1=new MyIdentity("identity",
new MyIdentityScope("IdentityScope"));
Identity i2=new MyIdentity("identity",
new MyIdentityScope("IdentityScope"));
Identity i3=new MyIdentity("identity",
new MyIdentityScope(""));
PublicKey pk1=new MyPublicKey();
PublicKey pk2=new MyPublicKey();
if ( !(i1.equals(i2)) == (i1.hashCode()==i2.hashCode()) ) {
System.err.println("FAILED");
Exception up = new
Exception("Contract violated -- same name and same scope");
throw up;
}
System.out.println("Test same name, same scope........... PASSED");
i1.setPublicKey(pk1);
i3.setPublicKey(pk1);
if ( !((i1.equals(i3)) && (i1.hashCode()==i3.hashCode()))) {
System.err.println("FAILED");
Exception up = new Exception("Contract violated -- PublicKeys do not differ");
throw up;
}
System.out.println("Test same name, same PublicKeys ..... PASSED");
System.out.println("TEST PASSED");
}
}
class MyIdentity extends Identity {
public MyIdentity(String name, IdentityScope is) throws KeyManagementException {
super(name, is);
}
}
class MyPublicKey implements PublicKey, Certificate {
private byte e[] = null;
public String getAlgorithm() {
return null;
}
public String getFormat() {
return new String("PKCS15");
}
public byte[] getEncoded() {
if (e == null) {
ByteArrayOutputStream bs = new ByteArrayOutputStream();
DataOutputStream ds = new DataOutputStream(bs);
try {
ds.writeLong(System.currentTimeMillis());
} catch (IOException ioe) {
ioe.printStackTrace();
}
e = bs.toByteArray();
}
return e;
}
public void decode(InputStream stream) {
}
public void encode(OutputStream stream) {
}
public Principal getGuarantor() {
return null;
}
public Principal getPrincipal() {
return null;
}
public PublicKey getPublicKey() {
return this;
}
public String toString(boolean detailed) {
return null;
}
}
class MyIdentityScope extends IdentityScope {
public MyIdentityScope(String name) {
super(name);
}
public int size() {
return 0;
}
public Identity getIdentity(String name) {
return null;
}
public Identity getIdentity(PublicKey key) {
return null;
}
public void addIdentity(Identity identity) {
}
public void removeIdentity(Identity identity) {
}
public java.util.Enumeration identities() {
return null;
}
}