HHH-6361 - Fixed ManyToManyAssociationClassCompositeIdTest broken by

CollectionType changes
This commit is contained in:
Erik-Berndt Scheper 2012-10-29 17:53:45 -04:00 committed by brmeyer
parent c57a31ad0c
commit 7036538d9c
2 changed files with 87 additions and 53 deletions

View File

@ -24,7 +24,9 @@
package org.hibernate.test.manytomanyassociationclass.compositeid;
import org.hibernate.test.manytomanyassociationclass.AbstractManyToManyAssociationClassTest;
import org.hibernate.test.manytomanyassociationclass.Group;
import org.hibernate.test.manytomanyassociationclass.Membership;
import org.hibernate.test.manytomanyassociationclass.User;
/**
* Tests on many-to-many association using an association class with a composite ID containing
@ -42,4 +44,15 @@ public class ManyToManyAssociationClassCompositeIdTest extends AbstractManyToMan
public Membership createMembership( String name ) {
return new MembershipWithCompositeId( name );
}
@Override
public void deleteMembership(User u, Group g, Membership ug) {
if ( u == null || g == null ) {
throw new IllegalArgumentException();
}
u.getMemberships().remove( ug );
g.getMemberships().remove( ug );
ug.setId(null);
}
}

View File

@ -64,19 +64,34 @@ public class MembershipWithCompositeId extends Membership {
this.groupId = groupId;
}
public boolean equals(Object o) {
if ( o != null && o instanceof Id ) {
Id that = ( Id ) o;
return this.userId.equals( that.userId ) &&
this.groupId.equals( that.groupId );
}
else {
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
}
if (getClass() != obj.getClass())
return false;
Id other = (Id) obj;
if (userId == null) {
if (other.userId != null)
return false;
} else if (!userId.equals(other.userId))
return false;
if (groupId == null) {
if (other.groupId != null)
return false;
} else if (!groupId.equals(other.groupId))
return false;
return true;
}
public int hashCode() {
return userId.hashCode() + groupId.hashCode();
final int prime = 31;
int result = 1;
result = prime * result + ((userId == null) ? 0 : userId.hashCode());
result = prime * result
+ ((groupId == null) ? 0 : groupId.hashCode());
return result;
}
}
@ -89,11 +104,17 @@ public class MembershipWithCompositeId extends Membership {
}
public void setGroup(Group group) {
if (getId() == null) {
setId(new Id());
}
( (Id) getId() ).setGroupId( ( group == null ? null : group.getId() ) );
super.setGroup( group );
}
public void setUser(User user) {
if (getId() == null) {
setId(new Id());
}
( (Id) getId() ).setUserId( user == null ? null : user.getId() );
super.setUser( user );
}