HHH-12654 - Throw MappingException if both @Inheritance and @AttributeOverride are used
This commit is contained in:
parent
f2238ec089
commit
ebca36a768
|
@ -19,6 +19,8 @@ import java.util.Locale;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
import javax.persistence.AttributeOverride;
|
||||||
|
import javax.persistence.AttributeOverrides;
|
||||||
import javax.persistence.Basic;
|
import javax.persistence.Basic;
|
||||||
import javax.persistence.CollectionTable;
|
import javax.persistence.CollectionTable;
|
||||||
import javax.persistence.Column;
|
import javax.persistence.Column;
|
||||||
|
@ -556,6 +558,15 @@ public final class AnnotationBinder {
|
||||||
inheritanceState
|
inheritanceState
|
||||||
);
|
);
|
||||||
|
|
||||||
|
if(superEntity != null && (
|
||||||
|
clazzToProcess.getAnnotation( AttributeOverride.class ) != null ||
|
||||||
|
clazzToProcess.getAnnotation( AttributeOverrides.class ) != null ) ) {
|
||||||
|
throw new AnnotationException(
|
||||||
|
"An entity annotated with @Inheritance cannot use @AttributeOverride or @AttributeOverrides: " +
|
||||||
|
clazzToProcess.getName()
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
PersistentClass persistentClass = makePersistentClass( inheritanceState, superEntity, context );
|
PersistentClass persistentClass = makePersistentClass( inheritanceState, superEntity, context );
|
||||||
Entity entityAnn = clazzToProcess.getAnnotation( Entity.class );
|
Entity entityAnn = clazzToProcess.getAnnotation( Entity.class );
|
||||||
org.hibernate.annotations.Entity hibEntityAnn = clazzToProcess.getAnnotation(
|
org.hibernate.annotations.Entity hibEntityAnn = clazzToProcess.getAnnotation(
|
||||||
|
|
|
@ -16,6 +16,7 @@ import javax.persistence.MappedSuperclass;
|
||||||
import javax.persistence.Table;
|
import javax.persistence.Table;
|
||||||
import javax.persistence.UniqueConstraint;
|
import javax.persistence.UniqueConstraint;
|
||||||
|
|
||||||
|
import org.hibernate.AnnotationException;
|
||||||
import org.hibernate.jpa.test.BaseEntityManagerFunctionalTestCase;
|
import org.hibernate.jpa.test.BaseEntityManagerFunctionalTestCase;
|
||||||
|
|
||||||
import org.hibernate.testing.FailureExpected;
|
import org.hibernate.testing.FailureExpected;
|
||||||
|
@ -24,11 +25,15 @@ import org.junit.Test;
|
||||||
|
|
||||||
import static org.hibernate.testing.transaction.TransactionUtil.doInJPA;
|
import static org.hibernate.testing.transaction.TransactionUtil.doInJPA;
|
||||||
import static org.junit.Assert.assertEquals;
|
import static org.junit.Assert.assertEquals;
|
||||||
|
import static org.junit.Assert.assertTrue;
|
||||||
|
import static org.junit.Assert.fail;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author Vlad Mihalcea
|
* @author Vlad Mihalcea
|
||||||
*/
|
*/
|
||||||
|
@TestForIssue( jiraKey = "HHH-12609, HHH-12654" )
|
||||||
public class EntityInheritanceAttributeOverrideTest extends BaseEntityManagerFunctionalTestCase {
|
public class EntityInheritanceAttributeOverrideTest extends BaseEntityManagerFunctionalTestCase {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Class[] getAnnotatedClasses() {
|
public Class[] getAnnotatedClasses() {
|
||||||
return new Class[]{
|
return new Class[]{
|
||||||
|
@ -38,39 +43,19 @@ public class EntityInheritanceAttributeOverrideTest extends BaseEntityManagerFun
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void buildEntityManagerFactory() {
|
||||||
|
try {
|
||||||
|
super.buildEntityManagerFactory();
|
||||||
|
fail("Should throw AnnotationException");
|
||||||
|
}
|
||||||
|
catch (AnnotationException e) {
|
||||||
|
assertTrue( e.getMessage().startsWith( "An entity annotated with @Inheritance cannot use @AttributeOverride or @AttributeOverrides" ) );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@TestForIssue( jiraKey = "HHH-12609" )
|
|
||||||
@FailureExpected(
|
|
||||||
jiraKey = "HHH-12609",
|
|
||||||
message = "Base class attributes cannot be overridden unless the base class is @MappedSuperclass"
|
|
||||||
)
|
|
||||||
public void test() {
|
public void test() {
|
||||||
doInJPA( this::entityManagerFactory, entityManager -> {
|
|
||||||
TaxonEntity taxon1 = new TaxonEntity();
|
|
||||||
taxon1.setId( 1L );
|
|
||||||
taxon1.setCode( "Taxon" );
|
|
||||||
taxon1.setCatalogVersion( "C1" );
|
|
||||||
|
|
||||||
entityManager.persist( taxon1 );
|
|
||||||
|
|
||||||
TaxonEntity taxon2 = new TaxonEntity();
|
|
||||||
taxon2.setId( 2L );
|
|
||||||
taxon2.setCode( "Taxon" );
|
|
||||||
taxon2.setCatalogVersion( "C2" );
|
|
||||||
|
|
||||||
entityManager.persist( taxon2 );
|
|
||||||
} );
|
|
||||||
doInJPA( this::entityManagerFactory, entityManager -> {
|
|
||||||
assertEquals(
|
|
||||||
2,
|
|
||||||
((Number) entityManager.createQuery(
|
|
||||||
"select count(t) " +
|
|
||||||
"from Taxon t " +
|
|
||||||
"where t.code = :code" )
|
|
||||||
.setParameter( "code", "Taxon" )
|
|
||||||
.getSingleResult()).intValue()
|
|
||||||
);
|
|
||||||
} );
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Entity(name = "AbstractEntity")
|
@Entity(name = "AbstractEntity")
|
||||||
|
|
Loading…
Reference in New Issue