HHH-12151 HHH-10575 : Add test for HHH-10575; add @TestForIssue to tests
This commit is contained in:
parent
8b980c4e7b
commit
794c784c0d
|
@ -0,0 +1,188 @@
|
||||||
|
/*
|
||||||
|
* Hibernate, Relational Persistence for Idiomatic Java
|
||||||
|
*
|
||||||
|
* License: GNU Lesser General Public License (LGPL), version 2.1 or later
|
||||||
|
* See the lgpl.txt file in the root directory or http://www.gnu.org/licenses/lgpl-2.1.html
|
||||||
|
*/
|
||||||
|
package org.hibernate.test.jpa.compliance.tck2_2.mapkeycolumn;
|
||||||
|
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
import javax.persistence.CascadeType;
|
||||||
|
import javax.persistence.Column;
|
||||||
|
import javax.persistence.Entity;
|
||||||
|
import javax.persistence.Id;
|
||||||
|
import javax.persistence.ManyToOne;
|
||||||
|
import javax.persistence.MapKeyColumn;
|
||||||
|
import javax.persistence.OneToMany;
|
||||||
|
import javax.persistence.Table;
|
||||||
|
|
||||||
|
import org.hibernate.boot.MetadataSources;
|
||||||
|
|
||||||
|
import org.hibernate.testing.TestForIssue;
|
||||||
|
import org.hibernate.testing.junit4.BaseNonConfigCoreFunctionalTestCase;
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
|
import static junit.framework.Assert.assertEquals;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @author Steve Ebersole
|
||||||
|
* @author Gail Badner
|
||||||
|
*/
|
||||||
|
public class MapKeyColumnBiDiOneToManyFKTest extends BaseNonConfigCoreFunctionalTestCase {
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@TestForIssue( jiraKey = "HHH-12150" )
|
||||||
|
public void testReferenceToAlreadyMappedColumn() {
|
||||||
|
inTransaction(
|
||||||
|
session -> {
|
||||||
|
AddressCapable2 holder = new AddressCapable2( 1, "osd");
|
||||||
|
Address2 address = new Address2( 1, "123 Main St" );
|
||||||
|
|
||||||
|
session.persist( holder );
|
||||||
|
session.persist( address );
|
||||||
|
}
|
||||||
|
);
|
||||||
|
inTransaction(
|
||||||
|
session -> {
|
||||||
|
AddressCapable2 holder = session.get( AddressCapable2.class, 1 );
|
||||||
|
Address2 address = session.get( Address2.class, 1 );
|
||||||
|
|
||||||
|
address.holder = holder;
|
||||||
|
holder.addresses.put( "work", address );
|
||||||
|
|
||||||
|
session.persist( holder );
|
||||||
|
}
|
||||||
|
);
|
||||||
|
inTransaction(
|
||||||
|
session -> {
|
||||||
|
AddressCapable2 holder = session.get( AddressCapable2.class, 1 );
|
||||||
|
assertEquals( 1, holder.addresses.size() );
|
||||||
|
final Map.Entry<String,Address2> entry = holder.addresses.entrySet().iterator().next();
|
||||||
|
assertEquals( "work", entry.getKey() );
|
||||||
|
assertEquals( "work", entry.getValue().type );
|
||||||
|
session.remove( holder );
|
||||||
|
}
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@TestForIssue( jiraKey = "HHH-12150" )
|
||||||
|
public void testReferenceToNonMappedColumn() {
|
||||||
|
inTransaction(
|
||||||
|
session -> {
|
||||||
|
AddressCapable holder = new AddressCapable( 1, "osd");
|
||||||
|
Address address = new Address( 1, "123 Main St" );
|
||||||
|
|
||||||
|
session.persist( holder );
|
||||||
|
session.persist( address );
|
||||||
|
}
|
||||||
|
);
|
||||||
|
inTransaction(
|
||||||
|
session -> {
|
||||||
|
AddressCapable holder = session.get( AddressCapable.class, 1 );
|
||||||
|
Address address = session.get( Address.class, 1 );
|
||||||
|
|
||||||
|
address.holder = holder;
|
||||||
|
holder.addresses.put( "work", address );
|
||||||
|
|
||||||
|
session.persist( holder );
|
||||||
|
}
|
||||||
|
);
|
||||||
|
inTransaction(
|
||||||
|
session -> {
|
||||||
|
AddressCapable holder = session.get( AddressCapable.class, 1 );
|
||||||
|
assertEquals( 1, holder.addresses.size() );
|
||||||
|
final Map.Entry<String,Address> entry = holder.addresses.entrySet().iterator().next();
|
||||||
|
assertEquals( "work", entry.getKey() );
|
||||||
|
session.remove( holder );
|
||||||
|
}
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void applyMetadataSources(MetadataSources sources) {
|
||||||
|
super.applyMetadataSources( sources );
|
||||||
|
|
||||||
|
sources.addAnnotatedClass( AddressCapable.class );
|
||||||
|
sources.addAnnotatedClass( AddressCapable2.class );
|
||||||
|
sources.addAnnotatedClass( Address.class );
|
||||||
|
sources.addAnnotatedClass( Address2.class );
|
||||||
|
}
|
||||||
|
|
||||||
|
@Entity( name = "AddressCapable" )
|
||||||
|
@Table( name = "address_capables" )
|
||||||
|
public static class AddressCapable {
|
||||||
|
@Id
|
||||||
|
public Integer id;
|
||||||
|
public String name;
|
||||||
|
@MapKeyColumn( name = "a_type" )
|
||||||
|
@OneToMany( mappedBy = "holder", cascade = {CascadeType.PERSIST, CascadeType.REMOVE} )
|
||||||
|
public Map<String,Address> addresses = new HashMap<>();
|
||||||
|
|
||||||
|
public AddressCapable() {
|
||||||
|
}
|
||||||
|
|
||||||
|
public AddressCapable(Integer id, String name) {
|
||||||
|
this.id = id;
|
||||||
|
this.name = name;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Entity( name = "Address" )
|
||||||
|
@Table( name = "addresses" )
|
||||||
|
public static class Address {
|
||||||
|
@Id
|
||||||
|
public Integer id;
|
||||||
|
public String street;
|
||||||
|
@ManyToOne
|
||||||
|
public AddressCapable holder;
|
||||||
|
|
||||||
|
public Address() {
|
||||||
|
}
|
||||||
|
|
||||||
|
public Address(Integer id, String street) {
|
||||||
|
this.id = id;
|
||||||
|
this.street = street;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Entity( name = "AddressCapable2" )
|
||||||
|
@Table( name = "address_capables2" )
|
||||||
|
public static class AddressCapable2 {
|
||||||
|
@Id
|
||||||
|
public Integer id;
|
||||||
|
public String name;
|
||||||
|
@MapKeyColumn( name = "a_type" )
|
||||||
|
@OneToMany( mappedBy = "holder", cascade = {CascadeType.PERSIST, CascadeType.REMOVE} )
|
||||||
|
public Map<String,Address2> addresses = new HashMap<>();
|
||||||
|
|
||||||
|
public AddressCapable2() {
|
||||||
|
}
|
||||||
|
|
||||||
|
public AddressCapable2(Integer id, String name) {
|
||||||
|
this.id = id;
|
||||||
|
this.name = name;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Entity( name = "Address2" )
|
||||||
|
@Table( name = "addresses2" )
|
||||||
|
public static class Address2 {
|
||||||
|
@Id
|
||||||
|
public Integer id;
|
||||||
|
public String street;
|
||||||
|
@Column( name = "a_type" )
|
||||||
|
public String type;
|
||||||
|
@ManyToOne
|
||||||
|
public AddressCapable2 holder;
|
||||||
|
|
||||||
|
public Address2() {
|
||||||
|
}
|
||||||
|
|
||||||
|
public Address2(Integer id, String street) {
|
||||||
|
this.id = id;
|
||||||
|
this.street = street;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -14,13 +14,12 @@ import javax.persistence.ElementCollection;
|
||||||
import javax.persistence.Embeddable;
|
import javax.persistence.Embeddable;
|
||||||
import javax.persistence.Entity;
|
import javax.persistence.Entity;
|
||||||
import javax.persistence.Id;
|
import javax.persistence.Id;
|
||||||
import javax.persistence.JoinColumn;
|
|
||||||
import javax.persistence.MapKeyColumn;
|
import javax.persistence.MapKeyColumn;
|
||||||
import javax.persistence.OneToMany;
|
|
||||||
import javax.persistence.Table;
|
import javax.persistence.Table;
|
||||||
|
|
||||||
import org.hibernate.boot.MetadataSources;
|
import org.hibernate.boot.MetadataSources;
|
||||||
|
|
||||||
|
import org.hibernate.testing.TestForIssue;
|
||||||
import org.hibernate.testing.junit4.BaseNonConfigCoreFunctionalTestCase;
|
import org.hibernate.testing.junit4.BaseNonConfigCoreFunctionalTestCase;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
|
@ -32,6 +31,7 @@ import static junit.framework.Assert.assertEquals;
|
||||||
public class MapKeyColumnElementCollectionTest extends BaseNonConfigCoreFunctionalTestCase {
|
public class MapKeyColumnElementCollectionTest extends BaseNonConfigCoreFunctionalTestCase {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@TestForIssue( jiraKey = "HHH-12150" )
|
||||||
public void testReferenceToAlreadyMappedColumn() {
|
public void testReferenceToAlreadyMappedColumn() {
|
||||||
inTransaction(
|
inTransaction(
|
||||||
session -> {
|
session -> {
|
||||||
|
@ -64,6 +64,7 @@ public class MapKeyColumnElementCollectionTest extends BaseNonConfigCoreFunction
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@TestForIssue( jiraKey = "HHH-12150" )
|
||||||
public void testReferenceToNonMappedColumn() {
|
public void testReferenceToNonMappedColumn() {
|
||||||
inTransaction(
|
inTransaction(
|
||||||
session -> {
|
session -> {
|
||||||
|
|
|
@ -12,14 +12,13 @@ import javax.persistence.CascadeType;
|
||||||
import javax.persistence.Column;
|
import javax.persistence.Column;
|
||||||
import javax.persistence.Entity;
|
import javax.persistence.Entity;
|
||||||
import javax.persistence.Id;
|
import javax.persistence.Id;
|
||||||
import javax.persistence.JoinColumn;
|
|
||||||
import javax.persistence.ManyToMany;
|
import javax.persistence.ManyToMany;
|
||||||
import javax.persistence.MapKeyColumn;
|
import javax.persistence.MapKeyColumn;
|
||||||
import javax.persistence.OneToMany;
|
|
||||||
import javax.persistence.Table;
|
import javax.persistence.Table;
|
||||||
|
|
||||||
import org.hibernate.boot.MetadataSources;
|
import org.hibernate.boot.MetadataSources;
|
||||||
|
|
||||||
|
import org.hibernate.testing.TestForIssue;
|
||||||
import org.hibernate.testing.junit4.BaseNonConfigCoreFunctionalTestCase;
|
import org.hibernate.testing.junit4.BaseNonConfigCoreFunctionalTestCase;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
|
@ -31,6 +30,7 @@ import static junit.framework.Assert.assertEquals;
|
||||||
public class MapKeyColumnManyToManyTest extends BaseNonConfigCoreFunctionalTestCase {
|
public class MapKeyColumnManyToManyTest extends BaseNonConfigCoreFunctionalTestCase {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@TestForIssue( jiraKey = "HHH-12150" )
|
||||||
public void testReferenceToAlreadyMappedColumn() {
|
public void testReferenceToAlreadyMappedColumn() {
|
||||||
inTransaction(
|
inTransaction(
|
||||||
session -> {
|
session -> {
|
||||||
|
@ -64,6 +64,7 @@ public class MapKeyColumnManyToManyTest extends BaseNonConfigCoreFunctionalTestC
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@TestForIssue( jiraKey = "HHH-12150" )
|
||||||
public void testReferenceToNonMappedColumn() {
|
public void testReferenceToNonMappedColumn() {
|
||||||
inTransaction(
|
inTransaction(
|
||||||
session -> {
|
session -> {
|
||||||
|
|
|
@ -19,7 +19,7 @@ import javax.persistence.Table;
|
||||||
|
|
||||||
import org.hibernate.boot.MetadataSources;
|
import org.hibernate.boot.MetadataSources;
|
||||||
|
|
||||||
import org.hibernate.testing.FailureExpected;
|
import org.hibernate.testing.TestForIssue;
|
||||||
import org.hibernate.testing.junit4.BaseNonConfigCoreFunctionalTestCase;
|
import org.hibernate.testing.junit4.BaseNonConfigCoreFunctionalTestCase;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
|
@ -31,6 +31,7 @@ import static junit.framework.Assert.assertEquals;
|
||||||
public class MapKeyColumnOneToManyFKTest extends BaseNonConfigCoreFunctionalTestCase {
|
public class MapKeyColumnOneToManyFKTest extends BaseNonConfigCoreFunctionalTestCase {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@TestForIssue( jiraKey = "HHH-12150" )
|
||||||
public void testReferenceToAlreadyMappedColumn() {
|
public void testReferenceToAlreadyMappedColumn() {
|
||||||
inTransaction(
|
inTransaction(
|
||||||
session -> {
|
session -> {
|
||||||
|
@ -64,6 +65,7 @@ public class MapKeyColumnOneToManyFKTest extends BaseNonConfigCoreFunctionalTest
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@TestForIssue( jiraKey = "HHH-12150" )
|
||||||
public void testReferenceToNonMappedColumn() {
|
public void testReferenceToNonMappedColumn() {
|
||||||
inTransaction(
|
inTransaction(
|
||||||
session -> {
|
session -> {
|
||||||
|
|
|
@ -12,13 +12,13 @@ import javax.persistence.CascadeType;
|
||||||
import javax.persistence.Column;
|
import javax.persistence.Column;
|
||||||
import javax.persistence.Entity;
|
import javax.persistence.Entity;
|
||||||
import javax.persistence.Id;
|
import javax.persistence.Id;
|
||||||
import javax.persistence.JoinColumn;
|
|
||||||
import javax.persistence.MapKeyColumn;
|
import javax.persistence.MapKeyColumn;
|
||||||
import javax.persistence.OneToMany;
|
import javax.persistence.OneToMany;
|
||||||
import javax.persistence.Table;
|
import javax.persistence.Table;
|
||||||
|
|
||||||
import org.hibernate.boot.MetadataSources;
|
import org.hibernate.boot.MetadataSources;
|
||||||
|
|
||||||
|
import org.hibernate.testing.TestForIssue;
|
||||||
import org.hibernate.testing.junit4.BaseNonConfigCoreFunctionalTestCase;
|
import org.hibernate.testing.junit4.BaseNonConfigCoreFunctionalTestCase;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
|
@ -30,6 +30,7 @@ import static junit.framework.Assert.assertEquals;
|
||||||
public class MapKeyColumnOneToManyJoinTableTest extends BaseNonConfigCoreFunctionalTestCase {
|
public class MapKeyColumnOneToManyJoinTableTest extends BaseNonConfigCoreFunctionalTestCase {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@TestForIssue( jiraKey = "HHH-12150" )
|
||||||
public void testReferenceToAlreadyMappedColumn() {
|
public void testReferenceToAlreadyMappedColumn() {
|
||||||
inTransaction(
|
inTransaction(
|
||||||
session -> {
|
session -> {
|
||||||
|
@ -63,6 +64,7 @@ public class MapKeyColumnOneToManyJoinTableTest extends BaseNonConfigCoreFunctio
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@TestForIssue( jiraKey = "HHH-12150" )
|
||||||
public void testReferenceToNonMappedColumn() {
|
public void testReferenceToNonMappedColumn() {
|
||||||
inTransaction(
|
inTransaction(
|
||||||
session -> {
|
session -> {
|
||||||
|
|
Loading…
Reference in New Issue