parent
b6ba54d403
commit
c13224fba0
|
@ -16,6 +16,7 @@ import java.util.HashMap;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
import javax.persistence.CascadeType;
|
import javax.persistence.CascadeType;
|
||||||
|
import javax.persistence.Column;
|
||||||
import javax.persistence.Entity;
|
import javax.persistence.Entity;
|
||||||
import javax.persistence.FetchType;
|
import javax.persistence.FetchType;
|
||||||
import javax.persistence.GeneratedValue;
|
import javax.persistence.GeneratedValue;
|
||||||
|
@ -51,7 +52,9 @@ public class PersistentMapTest extends BaseCoreFunctionalTestCase {
|
||||||
return new Class<?>[] {
|
return new Class<?>[] {
|
||||||
User.class,
|
User.class,
|
||||||
UserData.class,
|
UserData.class,
|
||||||
MultilingualString.class
|
MultilingualString.class,
|
||||||
|
Address.class,
|
||||||
|
Detail.class
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -235,6 +238,67 @@ public class PersistentMapTest extends BaseCoreFunctionalTestCase {
|
||||||
s.close();
|
s.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@TestForIssue( jiraKey = "HHH-11038" )
|
||||||
|
public void testMapKeyColumnNonInsertableNonUpdatableBidirOneToMany() {
|
||||||
|
Session s = openSession();
|
||||||
|
s.getTransaction().begin();
|
||||||
|
User user = new User();
|
||||||
|
Address address = new Address();
|
||||||
|
address.addressType = "email";
|
||||||
|
address.addressText = "jane@doe.com";
|
||||||
|
user.addresses.put( address.addressType, address );
|
||||||
|
address.user = user;
|
||||||
|
s.persist( user );
|
||||||
|
s.getTransaction().commit();
|
||||||
|
s.close();
|
||||||
|
|
||||||
|
s = openSession();
|
||||||
|
s.getTransaction().begin();
|
||||||
|
user = s.get( User.class, user.id );
|
||||||
|
user.addresses.clear();
|
||||||
|
s.getTransaction().commit();
|
||||||
|
s.close();
|
||||||
|
|
||||||
|
s = openSession();
|
||||||
|
s.getTransaction().begin();
|
||||||
|
user = s.get( User.class, user.id );
|
||||||
|
s.delete( user );
|
||||||
|
s.createQuery( "delete from " + User.class.getName() ).executeUpdate();
|
||||||
|
s.getTransaction().commit();
|
||||||
|
s.close();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@TestForIssue( jiraKey = "HHH-11038" )
|
||||||
|
public void testMapKeyColumnNonInsertableNonUpdatableUnidirOneToMany() {
|
||||||
|
Session s = openSession();
|
||||||
|
s.getTransaction().begin();
|
||||||
|
User user = new User();
|
||||||
|
Detail detail = new Detail();
|
||||||
|
detail.description = "desc";
|
||||||
|
detail.detailType = "trivial";
|
||||||
|
user.details.put( detail.detailType, detail );
|
||||||
|
s.persist( user );
|
||||||
|
s.getTransaction().commit();
|
||||||
|
s.close();
|
||||||
|
|
||||||
|
s = openSession();
|
||||||
|
s.getTransaction().begin();
|
||||||
|
user = s.get( User.class, user.id );
|
||||||
|
user.details.clear();
|
||||||
|
s.getTransaction().commit();
|
||||||
|
s.close();
|
||||||
|
|
||||||
|
s = openSession();
|
||||||
|
s.getTransaction().begin();
|
||||||
|
user = s.get( User.class, user.id );
|
||||||
|
s.delete( user );
|
||||||
|
s.createQuery( "delete from " + User.class.getName() ).executeUpdate();
|
||||||
|
s.getTransaction().commit();
|
||||||
|
s.close();
|
||||||
|
}
|
||||||
|
|
||||||
@Entity
|
@Entity
|
||||||
@Table(name = "MyUser")
|
@Table(name = "MyUser")
|
||||||
private static class User implements Serializable {
|
private static class User implements Serializable {
|
||||||
|
@ -244,6 +308,15 @@ public class PersistentMapTest extends BaseCoreFunctionalTestCase {
|
||||||
@OneToMany(fetch = FetchType.LAZY, mappedBy = "user", cascade = CascadeType.ALL)
|
@OneToMany(fetch = FetchType.LAZY, mappedBy = "user", cascade = CascadeType.ALL)
|
||||||
@MapKeyColumn(name = "name", nullable = true)
|
@MapKeyColumn(name = "name", nullable = true)
|
||||||
private Map<String, UserData> userDatas = new HashMap<String, UserData>();
|
private Map<String, UserData> userDatas = new HashMap<String, UserData>();
|
||||||
|
|
||||||
|
@OneToMany(fetch = FetchType.LAZY, mappedBy = "user", cascade = CascadeType.ALL)
|
||||||
|
@MapKeyColumn(name = "addressType", insertable = false, updatable = false)
|
||||||
|
private Map<String, Address> addresses = new HashMap<String, Address>();
|
||||||
|
|
||||||
|
@OneToMany(fetch = FetchType.LAZY, cascade = CascadeType.ALL)
|
||||||
|
@MapKeyColumn(name = "detailType", insertable = false, updatable = false)
|
||||||
|
@JoinColumn
|
||||||
|
private Map<String, Detail> details = new HashMap<String, Detail>();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Entity
|
@Entity
|
||||||
|
@ -257,4 +330,32 @@ public class PersistentMapTest extends BaseCoreFunctionalTestCase {
|
||||||
private User user;
|
private User user;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Entity
|
||||||
|
@Table(name = "Address")
|
||||||
|
private static class Address {
|
||||||
|
@Id @GeneratedValue
|
||||||
|
private Integer id;
|
||||||
|
|
||||||
|
@ManyToOne
|
||||||
|
@JoinColumn(name = "userId")
|
||||||
|
private User user;
|
||||||
|
|
||||||
|
@Column(nullable = false)
|
||||||
|
private String addressType;
|
||||||
|
|
||||||
|
@Column(nullable = false)
|
||||||
|
private String addressText;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Entity
|
||||||
|
@Table(name="Detail")
|
||||||
|
private static class Detail {
|
||||||
|
@Id @GeneratedValue
|
||||||
|
private Integer id;
|
||||||
|
|
||||||
|
@Column(nullable = false)
|
||||||
|
private String detailType;
|
||||||
|
|
||||||
|
private String description;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue