HHH-6174 Creating schema and (primary) table
This commit is contained in:
parent
e7c26b28a6
commit
95802a0e93
|
@ -44,6 +44,7 @@ import org.jboss.jandex.AnnotationInstance;
|
||||||
import org.jboss.jandex.AnnotationTarget;
|
import org.jboss.jandex.AnnotationTarget;
|
||||||
import org.jboss.jandex.AnnotationValue;
|
import org.jboss.jandex.AnnotationValue;
|
||||||
import org.jboss.jandex.ClassInfo;
|
import org.jboss.jandex.ClassInfo;
|
||||||
|
import org.jboss.jandex.DotName;
|
||||||
import org.jboss.jandex.FieldInfo;
|
import org.jboss.jandex.FieldInfo;
|
||||||
import org.jboss.jandex.MethodInfo;
|
import org.jboss.jandex.MethodInfo;
|
||||||
|
|
||||||
|
@ -74,12 +75,12 @@ public class ConfiguredClass {
|
||||||
private final InheritanceType inheritanceType;
|
private final InheritanceType inheritanceType;
|
||||||
private final boolean hasOwnTable;
|
private final boolean hasOwnTable;
|
||||||
private final String primaryTableName;
|
private final String primaryTableName;
|
||||||
private final AnnotationInstance tableAnnotation;
|
//private final AnnotationInstance tableAnnotation;
|
||||||
|
|
||||||
private final boolean isMappedSuperClass;
|
private final boolean isMappedSuperClass;
|
||||||
private final boolean isEmbeddable;
|
private final boolean isEmbeddable;
|
||||||
|
|
||||||
private final Map<String, MappedProperty> mappedProperties;
|
private final Map<String, MappedAttribute> mappedAttributes;
|
||||||
|
|
||||||
public ConfiguredClass(ClassInfo info,
|
public ConfiguredClass(ClassInfo info,
|
||||||
ConfiguredClass parent,
|
ConfiguredClass parent,
|
||||||
|
@ -104,10 +105,6 @@ public class ConfiguredClass {
|
||||||
);
|
);
|
||||||
isEmbeddable = embeddableAnnotation != null;
|
isEmbeddable = embeddableAnnotation != null;
|
||||||
|
|
||||||
tableAnnotation = JandexHelper.getSingleAnnotation(
|
|
||||||
classInfo, JPADotNames.TABLE
|
|
||||||
);
|
|
||||||
|
|
||||||
// todo think about how exactly to handle embeddables regarding access type etc
|
// todo think about how exactly to handle embeddables regarding access type etc
|
||||||
|
|
||||||
classAccessType = determineClassAccessType();
|
classAccessType = determineClassAccessType();
|
||||||
|
@ -115,14 +112,14 @@ public class ConfiguredClass {
|
||||||
hasOwnTable = definesItsOwnTable();
|
hasOwnTable = definesItsOwnTable();
|
||||||
primaryTableName = determinePrimaryTableName();
|
primaryTableName = determinePrimaryTableName();
|
||||||
|
|
||||||
List<MappedProperty> properties = collectMappedProperties( resolvedType );
|
List<MappedAttribute> properties = collectMappedProperties( resolvedType );
|
||||||
// make sure the properties are ordered by property name
|
// make sure the properties are ordered by property name
|
||||||
Collections.sort( properties );
|
Collections.sort( properties );
|
||||||
Map<String, MappedProperty> tmpMap = new LinkedHashMap<String, MappedProperty>();
|
Map<String, MappedAttribute> tmpMap = new LinkedHashMap<String, MappedAttribute>();
|
||||||
for ( MappedProperty property : properties ) {
|
for ( MappedAttribute property : properties ) {
|
||||||
tmpMap.put( property.getName(), property );
|
tmpMap.put( property.getName(), property );
|
||||||
}
|
}
|
||||||
mappedProperties = Collections.unmodifiableMap( tmpMap );
|
mappedAttributes = Collections.unmodifiableMap( tmpMap );
|
||||||
}
|
}
|
||||||
|
|
||||||
public String getName() {
|
public String getName() {
|
||||||
|
@ -161,12 +158,12 @@ public class ConfiguredClass {
|
||||||
return primaryTableName;
|
return primaryTableName;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Iterable<MappedProperty> getMappedProperties() {
|
public Iterable<MappedAttribute> getMappedAttributes() {
|
||||||
return mappedProperties.values();
|
return mappedAttributes.values();
|
||||||
}
|
}
|
||||||
|
|
||||||
public MappedProperty getMappedProperty(String propertyName) {
|
public MappedAttribute getMappedProperty(String propertyName) {
|
||||||
return mappedProperties.get( propertyName );
|
return mappedAttributes.get( propertyName );
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -174,7 +171,7 @@ public class ConfiguredClass {
|
||||||
final StringBuilder sb = new StringBuilder();
|
final StringBuilder sb = new StringBuilder();
|
||||||
sb.append( "ConfiguredClass" );
|
sb.append( "ConfiguredClass" );
|
||||||
sb.append( "{clazz=" ).append( clazz );
|
sb.append( "{clazz=" ).append( clazz );
|
||||||
sb.append( ", mappedProperties=" ).append( mappedProperties );
|
sb.append( ", mappedAttributes=" ).append( mappedAttributes );
|
||||||
sb.append( ", classAccessType=" ).append( classAccessType );
|
sb.append( ", classAccessType=" ).append( classAccessType );
|
||||||
sb.append( ", isRoot=" ).append( isRoot );
|
sb.append( ", isRoot=" ).append( isRoot );
|
||||||
sb.append( ", inheritanceType=" ).append( inheritanceType );
|
sb.append( ", inheritanceType=" ).append( inheritanceType );
|
||||||
|
@ -197,7 +194,7 @@ public class ConfiguredClass {
|
||||||
/**
|
/**
|
||||||
* @return A list of the persistent properties of this configured class
|
* @return A list of the persistent properties of this configured class
|
||||||
*/
|
*/
|
||||||
private List<MappedProperty> collectMappedProperties(ResolvedTypeWithMembers resolvedTypes) {
|
private List<MappedAttribute> collectMappedProperties(ResolvedTypeWithMembers resolvedTypes) {
|
||||||
// create sets of transient field and method names
|
// create sets of transient field and method names
|
||||||
Set<String> transientFieldNames = new HashSet<String>();
|
Set<String> transientFieldNames = new HashSet<String>();
|
||||||
Set<String> transientMethodNames = new HashSet<String>();
|
Set<String> transientMethodNames = new HashSet<String>();
|
||||||
|
@ -216,7 +213,7 @@ public class ConfiguredClass {
|
||||||
throw new AssertionFailure( "Unable to resolve types for " + clazz.getName() );
|
throw new AssertionFailure( "Unable to resolve types for " + clazz.getName() );
|
||||||
}
|
}
|
||||||
|
|
||||||
List<MappedProperty> properties = new ArrayList<MappedProperty>();
|
List<MappedAttribute> properties = new ArrayList<MappedAttribute>();
|
||||||
Set<String> explicitlyConfiguredMemberNames = createExplicitlyConfiguredAccessProperties(
|
Set<String> explicitlyConfiguredMemberNames = createExplicitlyConfiguredAccessProperties(
|
||||||
properties, resolvedType
|
properties, resolvedType
|
||||||
);
|
);
|
||||||
|
@ -265,7 +262,7 @@ public class ConfiguredClass {
|
||||||
*
|
*
|
||||||
* @return the property names of the explicitly configured class names in a set
|
* @return the property names of the explicitly configured class names in a set
|
||||||
*/
|
*/
|
||||||
private Set<String> createExplicitlyConfiguredAccessProperties(List<MappedProperty> mappedProperties, ResolvedTypeWithMembers resolvedMembers) {
|
private Set<String> createExplicitlyConfiguredAccessProperties(List<MappedAttribute> mappedProperties, ResolvedTypeWithMembers resolvedMembers) {
|
||||||
Set<String> explicitAccessMembers = new HashSet<String>();
|
Set<String> explicitAccessMembers = new HashSet<String>();
|
||||||
|
|
||||||
List<AnnotationInstance> accessAnnotations = classInfo.annotations().get( JPADotNames.ACCESS );
|
List<AnnotationInstance> accessAnnotations = classInfo.annotations().get( JPADotNames.ACCESS );
|
||||||
|
@ -350,8 +347,8 @@ public class ConfiguredClass {
|
||||||
return explicitAccessMembers;
|
return explicitAccessMembers;
|
||||||
}
|
}
|
||||||
|
|
||||||
private MappedProperty createMappedProperty(Member member, ResolvedTypeWithMembers resolvedType) {
|
private MappedAttribute createMappedProperty(Member member, ResolvedTypeWithMembers resolvedType) {
|
||||||
String name = ReflectionHelper.getPropertyName( member );
|
final String name = ReflectionHelper.getPropertyName( member );
|
||||||
ResolvedMember[] resolvedMembers;
|
ResolvedMember[] resolvedMembers;
|
||||||
if ( member instanceof Field ) {
|
if ( member instanceof Field ) {
|
||||||
resolvedMembers = resolvedType.getMemberFields();
|
resolvedMembers = resolvedType.getMemberFields();
|
||||||
|
@ -359,8 +356,11 @@ public class ConfiguredClass {
|
||||||
else {
|
else {
|
||||||
resolvedMembers = resolvedType.getMemberMethods();
|
resolvedMembers = resolvedType.getMemberMethods();
|
||||||
}
|
}
|
||||||
Type type = findResolvedType( member.getName(), resolvedMembers );
|
final Type type = findResolvedType( member.getName(), resolvedMembers );
|
||||||
return new MappedProperty( name, (Class) type );
|
final Map<DotName, List<AnnotationInstance>> annotations = JandexHelper.getMemberAnnotations(
|
||||||
|
classInfo, member.getName()
|
||||||
|
);
|
||||||
|
return new MappedAttribute( name, (Class) type, annotations );
|
||||||
}
|
}
|
||||||
|
|
||||||
private Type findResolvedType(String name, ResolvedMember[] resolvedMembers) {
|
private Type findResolvedType(String name, ResolvedMember[] resolvedMembers) {
|
||||||
|
@ -417,6 +417,9 @@ public class ConfiguredClass {
|
||||||
String tableName = null;
|
String tableName = null;
|
||||||
if ( hasOwnTable() ) {
|
if ( hasOwnTable() ) {
|
||||||
tableName = clazz.getSimpleName();
|
tableName = clazz.getSimpleName();
|
||||||
|
AnnotationInstance tableAnnotation = JandexHelper.getSingleAnnotation(
|
||||||
|
classInfo, JPADotNames.TABLE
|
||||||
|
);
|
||||||
if ( tableAnnotation != null ) {
|
if ( tableAnnotation != null ) {
|
||||||
AnnotationValue value = tableAnnotation.value( "name" );
|
AnnotationValue value = tableAnnotation.value( "name" );
|
||||||
String tmp = value == null ? null : value.asString();
|
String tmp = value == null ? null : value.asString();
|
||||||
|
|
|
@ -190,7 +190,7 @@ public class ConfiguredClassHierarchy implements Iterable<ConfiguredClass> {
|
||||||
|
|
||||||
private AccessType throwIdNotFoundAnnotationException(List<ClassInfo> classes) {
|
private AccessType throwIdNotFoundAnnotationException(List<ClassInfo> classes) {
|
||||||
StringBuilder builder = new StringBuilder();
|
StringBuilder builder = new StringBuilder();
|
||||||
builder.append( "Unable to find Id property for class hierarchy " );
|
builder.append( "Unable to determine identifier attribute for class hierarchy " );
|
||||||
builder.append( hierarchyListString( classes ) );
|
builder.append( hierarchyListString( classes ) );
|
||||||
throw new AnnotationException( builder.toString() );
|
throw new AnnotationException( builder.toString() );
|
||||||
}
|
}
|
||||||
|
|
|
@ -29,6 +29,7 @@ import java.util.Map;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
|
||||||
import org.jboss.jandex.AnnotationInstance;
|
import org.jboss.jandex.AnnotationInstance;
|
||||||
|
import org.jboss.jandex.AnnotationValue;
|
||||||
|
|
||||||
import org.hibernate.AssertionFailure;
|
import org.hibernate.AssertionFailure;
|
||||||
import org.hibernate.MappingException;
|
import org.hibernate.MappingException;
|
||||||
|
@ -43,6 +44,7 @@ import org.hibernate.metamodel.binding.SimpleAttributeBinding;
|
||||||
import org.hibernate.metamodel.domain.Attribute;
|
import org.hibernate.metamodel.domain.Attribute;
|
||||||
import org.hibernate.metamodel.domain.Entity;
|
import org.hibernate.metamodel.domain.Entity;
|
||||||
import org.hibernate.metamodel.domain.Hierarchical;
|
import org.hibernate.metamodel.domain.Hierarchical;
|
||||||
|
import org.hibernate.metamodel.relational.Identifier;
|
||||||
import org.hibernate.metamodel.relational.Schema;
|
import org.hibernate.metamodel.relational.Schema;
|
||||||
import org.hibernate.metamodel.relational.Size;
|
import org.hibernate.metamodel.relational.Size;
|
||||||
import org.hibernate.metamodel.source.annotations.util.JandexHelper;
|
import org.hibernate.metamodel.source.annotations.util.JandexHelper;
|
||||||
|
@ -54,15 +56,17 @@ import org.hibernate.metamodel.source.internal.MetadataImpl;
|
||||||
* @author Hardy Ferentschik
|
* @author Hardy Ferentschik
|
||||||
*/
|
*/
|
||||||
public class EntityBinder {
|
public class EntityBinder {
|
||||||
private final ConfiguredClass entity;
|
private final ConfiguredClass configuredClass;
|
||||||
private final MetadataImpl meta;
|
private final MetadataImpl meta;
|
||||||
|
private final Schema.Name schemaName;
|
||||||
|
|
||||||
public EntityBinder(MetadataImpl metadata, ConfiguredClass configuredClass) {
|
public EntityBinder(MetadataImpl metadata, ConfiguredClass configuredClass) {
|
||||||
this.entity = configuredClass;
|
this.configuredClass = configuredClass;
|
||||||
this.meta = metadata;
|
this.meta = metadata;
|
||||||
EntityBinding entityBinding = new EntityBinding();
|
EntityBinding entityBinding = new EntityBinding();
|
||||||
bindJpaEntityAnnotation( entityBinding );
|
bindJpaEntityAnnotation( entityBinding );
|
||||||
bindHibernateEntityAnnotation( entityBinding ); // optional hibernate specific @org.hibernate.annotations.Entity
|
bindHibernateEntityAnnotation( entityBinding ); // optional hibernate specific @org.hibernate.annotations.Entity
|
||||||
|
schemaName = createSchemaName();
|
||||||
bindTable( entityBinding );
|
bindTable( entityBinding );
|
||||||
|
|
||||||
if ( configuredClass.isRoot() ) {
|
if ( configuredClass.isRoot() ) {
|
||||||
|
@ -71,19 +75,48 @@ public class EntityBinder {
|
||||||
meta.addEntity( entityBinding );
|
meta.addEntity( entityBinding );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private Schema.Name createSchemaName() {
|
||||||
|
String schema = "";
|
||||||
|
String catalog = "";
|
||||||
|
|
||||||
|
AnnotationInstance tableAnnotation = JandexHelper.getSingleAnnotation(
|
||||||
|
configuredClass.getClassInfo(), JPADotNames.TABLE
|
||||||
|
);
|
||||||
|
if ( tableAnnotation != null ) {
|
||||||
|
AnnotationValue schemaValue = tableAnnotation.value( "schema" );
|
||||||
|
AnnotationValue catalogValue = tableAnnotation.value( "catalog" );
|
||||||
|
|
||||||
|
schema = schemaValue != null ? schemaValue.asString() : "";
|
||||||
|
catalog = catalogValue != null ? catalogValue.asString() : "";
|
||||||
|
}
|
||||||
|
|
||||||
|
return new Schema.Name( schema, catalog );
|
||||||
|
}
|
||||||
|
|
||||||
private void bindTable(EntityBinding entityBinding) {
|
private void bindTable(EntityBinding entityBinding) {
|
||||||
|
final Schema schema = meta.getDatabase().getSchema( schemaName );
|
||||||
|
final Identifier tableName = Identifier.toIdentifier( configuredClass.getPrimaryTableName() );
|
||||||
|
org.hibernate.metamodel.relational.Table table = schema.getTable( tableName );
|
||||||
|
if ( table == null ) {
|
||||||
|
table = schema.createTable( tableName );
|
||||||
|
}
|
||||||
|
entityBinding.setBaseTable( table );
|
||||||
|
|
||||||
// this.schemaName = new Schema.Name(
|
AnnotationInstance hibernateTableAnnotation = JandexHelper.getSingleAnnotation(
|
||||||
// ( entityClazz.getSchema() == null ?
|
configuredClass.getClassInfo(), HibernateDotNames.TABLE
|
||||||
// hibernateMappingBinder.getDefaultSchemaName() :
|
);
|
||||||
// entityClazz.getSchema() ),
|
|
||||||
// ( entityClazz.getCatalog() == null ?
|
|
||||||
// hibernateMappingBinder.getDefaultCatalogName() :
|
|
||||||
// entityClazz.getCatalog() )
|
|
||||||
// );
|
|
||||||
|
|
||||||
|
if ( hibernateTableAnnotation != null && hibernateTableAnnotation.value( "comment" ) != null ) {
|
||||||
|
table.addComment( hibernateTableAnnotation.value( "comment" ).asString().trim() );
|
||||||
|
}
|
||||||
|
// todo map rest of Hibernate @Table attributes
|
||||||
|
|
||||||
final Schema schema = meta.getDatabase().getSchema( null );
|
AnnotationInstance checkAnnotation = JandexHelper.getSingleAnnotation(
|
||||||
|
configuredClass.getClassInfo(), HibernateDotNames.CHECK
|
||||||
|
);
|
||||||
|
if ( checkAnnotation != null ) {
|
||||||
|
table.addCheckConstraint( checkAnnotation.value( "constraints" ).asString() );
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void bindId(EntityBinding entityBinding) {
|
private void bindId(EntityBinding entityBinding) {
|
||||||
|
@ -107,11 +140,11 @@ public class EntityBinder {
|
||||||
|
|
||||||
private void bindJpaEntityAnnotation(EntityBinding entityBinding) {
|
private void bindJpaEntityAnnotation(EntityBinding entityBinding) {
|
||||||
AnnotationInstance jpaEntityAnnotation = JandexHelper.getSingleAnnotation(
|
AnnotationInstance jpaEntityAnnotation = JandexHelper.getSingleAnnotation(
|
||||||
entity.getClassInfo(), JPADotNames.ENTITY
|
configuredClass.getClassInfo(), JPADotNames.ENTITY
|
||||||
);
|
);
|
||||||
String name;
|
String name;
|
||||||
if ( jpaEntityAnnotation.value( "name" ) == null ) {
|
if ( jpaEntityAnnotation.value( "name" ) == null ) {
|
||||||
name = StringHelper.unqualify( entity.getName() );
|
name = StringHelper.unqualify( configuredClass.getName() );
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
name = jpaEntityAnnotation.value( "name" ).asString();
|
name = jpaEntityAnnotation.value( "name" ).asString();
|
||||||
|
@ -121,26 +154,26 @@ public class EntityBinder {
|
||||||
|
|
||||||
private void bindSingleIdAnnotation(EntityBinding entityBinding) {
|
private void bindSingleIdAnnotation(EntityBinding entityBinding) {
|
||||||
AnnotationInstance idAnnotation = JandexHelper.getSingleAnnotation(
|
AnnotationInstance idAnnotation = JandexHelper.getSingleAnnotation(
|
||||||
entity.getClassInfo(), JPADotNames.ID
|
configuredClass.getClassInfo(), JPADotNames.ID
|
||||||
);
|
);
|
||||||
|
|
||||||
String idName = JandexHelper.getPropertyName( idAnnotation.target() );
|
String idName = JandexHelper.getPropertyName( idAnnotation.target() );
|
||||||
entityBinding.getEntity().getOrCreateSingularAttribute( idName );
|
entityBinding.getEntity().getOrCreateSingularAttribute( idName );
|
||||||
SimpleAttributeBinding idBinding = entityBinding.makeSimplePrimaryKeyAttributeBinding( idName );
|
SimpleAttributeBinding idBinding = entityBinding.makeSimplePrimaryKeyAttributeBinding( idName );
|
||||||
|
|
||||||
MappedProperty idProperty = entity.getMappedProperty( idName );
|
MappedAttribute idAttribute = configuredClass.getMappedProperty( idName );
|
||||||
|
|
||||||
AnnotationSimpleAttributeDomainState domainState = new AnnotationSimpleAttributeDomainState();
|
AnnotationSimpleAttributeDomainState domainState = new AnnotationSimpleAttributeDomainState();
|
||||||
HibernateTypeDescriptor typeDescriptor = new HibernateTypeDescriptor();
|
HibernateTypeDescriptor typeDescriptor = new HibernateTypeDescriptor();
|
||||||
typeDescriptor.setTypeName( idProperty.getType().getName() );
|
typeDescriptor.setTypeName( idAttribute.getType().getName() );
|
||||||
domainState.typeDescriptor = typeDescriptor;
|
domainState.typeDescriptor = typeDescriptor;
|
||||||
domainState.attribute = entityBinding.getEntity().getOrCreateSingularAttribute( idProperty.getName() );
|
domainState.attribute = entityBinding.getEntity().getOrCreateSingularAttribute( idAttribute.getName() );
|
||||||
|
|
||||||
idBinding.initialize( domainState );
|
idBinding.initialize( domainState );
|
||||||
|
|
||||||
AnnotationColumnRelationalState columnRelationsState = new AnnotationColumnRelationalState();
|
AnnotationColumnRelationalState columnRelationsState = new AnnotationColumnRelationalState();
|
||||||
columnRelationsState.namingStrategy = meta.getNamingStrategy();
|
columnRelationsState.namingStrategy = meta.getNamingStrategy();
|
||||||
columnRelationsState.columnName = idProperty.getColumnName();
|
columnRelationsState.columnName = idAttribute.getColumnName();
|
||||||
columnRelationsState.unique = true;
|
columnRelationsState.unique = true;
|
||||||
columnRelationsState.nullable = false;
|
columnRelationsState.nullable = false;
|
||||||
|
|
||||||
|
@ -151,7 +184,7 @@ public class EntityBinder {
|
||||||
|
|
||||||
private void bindHibernateEntityAnnotation(EntityBinding entityBinding) {
|
private void bindHibernateEntityAnnotation(EntityBinding entityBinding) {
|
||||||
AnnotationInstance hibernateEntityAnnotation = JandexHelper.getSingleAnnotation(
|
AnnotationInstance hibernateEntityAnnotation = JandexHelper.getSingleAnnotation(
|
||||||
entity.getClassInfo(), HibernateDotNames.ENTITY
|
configuredClass.getClassInfo(), HibernateDotNames.ENTITY
|
||||||
);
|
);
|
||||||
// if ( hibAnn != null ) {
|
// if ( hibAnn != null ) {
|
||||||
// dynamicInsert = hibAnn.dynamicInsert();
|
// dynamicInsert = hibAnn.dynamicInsert();
|
||||||
|
@ -173,7 +206,7 @@ public class EntityBinder {
|
||||||
}
|
}
|
||||||
|
|
||||||
private Hierarchical getSuperType() {
|
private Hierarchical getSuperType() {
|
||||||
ConfiguredClass parent = entity.getParent();
|
ConfiguredClass parent = configuredClass.getParent();
|
||||||
if ( parent == null ) {
|
if ( parent == null ) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
@ -181,7 +214,7 @@ public class EntityBinder {
|
||||||
EntityBinding parentBinding = meta.getEntityBinding( parent.getName() );
|
EntityBinding parentBinding = meta.getEntityBinding( parent.getName() );
|
||||||
if ( parentBinding == null ) {
|
if ( parentBinding == null ) {
|
||||||
throw new AssertionFailure(
|
throw new AssertionFailure(
|
||||||
"Parent entity " + parent.getName() + " of entity " + entity.getName() + "not yet created!"
|
"Parent entity " + parent.getName() + " of entity " + configuredClass.getName() + "not yet created!"
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -189,14 +222,14 @@ public class EntityBinder {
|
||||||
}
|
}
|
||||||
|
|
||||||
private IdType determineIdType() {
|
private IdType determineIdType() {
|
||||||
List<AnnotationInstance> idAnnotations = entity.getClassInfo().annotations().get( JPADotNames.ENTITY );
|
List<AnnotationInstance> idAnnotations = configuredClass.getClassInfo().annotations().get( JPADotNames.ENTITY );
|
||||||
List<AnnotationInstance> embeddedIdAnnotations = entity.getClassInfo()
|
List<AnnotationInstance> embeddedIdAnnotations = configuredClass.getClassInfo()
|
||||||
.annotations()
|
.annotations()
|
||||||
.get( JPADotNames.EMBEDDED_ID );
|
.get( JPADotNames.EMBEDDED_ID );
|
||||||
|
|
||||||
if ( idAnnotations != null && embeddedIdAnnotations != null ) {
|
if ( idAnnotations != null && embeddedIdAnnotations != null ) {
|
||||||
throw new MappingException(
|
throw new MappingException(
|
||||||
"@EmbeddedId and @Id cannot be used together. Check the configuration for " + entity.getName() + "."
|
"@EmbeddedId and @Id cannot be used together. Check the configuration for " + configuredClass.getName() + "."
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -23,34 +23,52 @@
|
||||||
*/
|
*/
|
||||||
package org.hibernate.metamodel.source.annotations;
|
package org.hibernate.metamodel.source.annotations;
|
||||||
|
|
||||||
|
import java.util.Collections;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
import org.jboss.jandex.AnnotationInstance;
|
||||||
|
import org.jboss.jandex.DotName;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Represent a mapped property (explicitly or implicitly mapped).
|
* Represent a mapped attribute (explicitly or implicitly mapped).
|
||||||
*
|
*
|
||||||
* @author Hardy Ferentschik
|
* @author Hardy Ferentschik
|
||||||
*/
|
*/
|
||||||
public class MappedProperty implements Comparable<MappedProperty> {
|
public class MappedAttribute implements Comparable<MappedAttribute> {
|
||||||
private final String name;
|
private final String name;
|
||||||
private final Class<?> type;
|
private final Class<?> type;
|
||||||
|
private final Map<DotName, List<AnnotationInstance>> annotations;
|
||||||
|
|
||||||
MappedProperty(String name, Class<?> type) {
|
MappedAttribute(String name, Class<?> type, Map<DotName, List<AnnotationInstance>> annotations) {
|
||||||
this.name = name;
|
this.name = name;
|
||||||
this.type = type;
|
this.type = type;
|
||||||
|
this.annotations = annotations;
|
||||||
}
|
}
|
||||||
|
|
||||||
public String getName() {
|
final public String getName() {
|
||||||
return name;
|
return name;
|
||||||
}
|
}
|
||||||
|
|
||||||
public String getColumnName() {
|
final public String getColumnName() {
|
||||||
return name;
|
return name;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Class<?> getType() {
|
final public Class<?> getType() {
|
||||||
return type;
|
return type;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public final List<AnnotationInstance> annotations(DotName annotationDotName) {
|
||||||
|
if ( annotations.containsKey( annotationDotName ) ) {
|
||||||
|
return annotations.get( annotationDotName );
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
return Collections.emptyList();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int compareTo(MappedProperty mappedProperty) {
|
public int compareTo(MappedAttribute mappedProperty) {
|
||||||
return name.compareTo( mappedProperty.getName() );
|
return name.compareTo( mappedProperty.getName() );
|
||||||
}
|
}
|
||||||
|
|
|
@ -26,7 +26,10 @@ package org.hibernate.metamodel.source.annotations.util;
|
||||||
import java.beans.Introspector;
|
import java.beans.Introspector;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.HashMap;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
import org.jboss.jandex.AnnotationInstance;
|
import org.jboss.jandex.AnnotationInstance;
|
||||||
import org.jboss.jandex.AnnotationTarget;
|
import org.jboss.jandex.AnnotationTarget;
|
||||||
|
@ -37,7 +40,6 @@ import org.jboss.jandex.Index;
|
||||||
import org.jboss.jandex.Indexer;
|
import org.jboss.jandex.Indexer;
|
||||||
import org.jboss.jandex.MethodInfo;
|
import org.jboss.jandex.MethodInfo;
|
||||||
|
|
||||||
|
|
||||||
import org.hibernate.AssertionFailure;
|
import org.hibernate.AssertionFailure;
|
||||||
import org.hibernate.HibernateException;
|
import org.hibernate.HibernateException;
|
||||||
import org.hibernate.service.classloading.spi.ClassLoaderService;
|
import org.hibernate.service.classloading.spi.ClassLoaderService;
|
||||||
|
@ -145,6 +147,46 @@ public class JandexHelper {
|
||||||
}
|
}
|
||||||
return indexer.complete();
|
return indexer.complete();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static Map<DotName, List<AnnotationInstance>> getMemberAnnotations(ClassInfo classInfo, String name) {
|
||||||
|
if ( classInfo == null ) {
|
||||||
|
throw new IllegalArgumentException( "classInfo cannot be null" );
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( name == null ) {
|
||||||
|
throw new IllegalArgumentException( "name cannot be null" );
|
||||||
|
}
|
||||||
|
|
||||||
|
Map<DotName, List<AnnotationInstance>> annotations = new HashMap<DotName, List<AnnotationInstance>>();
|
||||||
|
for ( List<AnnotationInstance> annotationList : classInfo.annotations().values() ) {
|
||||||
|
for ( AnnotationInstance instance : annotationList ) {
|
||||||
|
String targetName = null;
|
||||||
|
if ( instance.target() instanceof FieldInfo ) {
|
||||||
|
targetName = ( (FieldInfo) instance.target() ).name();
|
||||||
|
}
|
||||||
|
else if ( instance.target() instanceof MethodInfo ) {
|
||||||
|
targetName = ( (MethodInfo) instance.target() ).name();
|
||||||
|
}
|
||||||
|
if ( targetName != null && name.equals( targetName ) ) {
|
||||||
|
addAnnotationToMap( instance, annotations );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return annotations;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void addAnnotationToMap(AnnotationInstance instance, Map<DotName, List<AnnotationInstance>> annotations) {
|
||||||
|
DotName dotName = instance.name();
|
||||||
|
List<AnnotationInstance> list;
|
||||||
|
if ( annotations.containsKey( dotName ) ) {
|
||||||
|
list = annotations.get( dotName );
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
list = new ArrayList<AnnotationInstance>();
|
||||||
|
annotations.put( dotName, list );
|
||||||
|
}
|
||||||
|
list.add( instance );
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -60,7 +60,7 @@ public class HbmColumnRelationalState implements AbstractAttributeBinding.Column
|
||||||
|
|
||||||
/* package-protected */
|
/* package-protected */
|
||||||
HbmColumnRelationalState(XMLColumnElement columnElement,
|
HbmColumnRelationalState(XMLColumnElement columnElement,
|
||||||
HbmSimpleValueRelationalStateContainer container) {
|
HbmSimpleValueRelationalStateContainer container) {
|
||||||
this.container = container;
|
this.container = container;
|
||||||
this.explicitColumnName = columnElement.getName();
|
this.explicitColumnName = columnElement.getName();
|
||||||
this.size = createSize( columnElement.getLength(), columnElement.getScale(), columnElement.getPrecision() );
|
this.size = createSize( columnElement.getLength(), columnElement.getScale(), columnElement.getPrecision() );
|
||||||
|
@ -70,8 +70,8 @@ public class HbmColumnRelationalState implements AbstractAttributeBinding.Column
|
||||||
this.defaultColumnValue = columnElement.getDefault();
|
this.defaultColumnValue = columnElement.getDefault();
|
||||||
this.sqlType = columnElement.getSqlType();
|
this.sqlType = columnElement.getSqlType();
|
||||||
this.customWrite = columnElement.getWrite();
|
this.customWrite = columnElement.getWrite();
|
||||||
if ( customWrite != null && ! customWrite.matches("[^?]*\\?[^?]*") ) {
|
if ( customWrite != null && !customWrite.matches( "[^?]*\\?[^?]*" ) ) {
|
||||||
throw new MappingException("write expression must contain exactly one value placeholder ('?') character");
|
throw new MappingException( "write expression must contain exactly one value placeholder ('?') character" );
|
||||||
}
|
}
|
||||||
this.customRead = columnElement.getRead();
|
this.customRead = columnElement.getRead();
|
||||||
this.comment = columnElement.getComment() == null ? null : columnElement.getComment().trim();
|
this.comment = columnElement.getComment() == null ? null : columnElement.getComment().trim();
|
||||||
|
@ -82,7 +82,7 @@ public class HbmColumnRelationalState implements AbstractAttributeBinding.Column
|
||||||
}
|
}
|
||||||
|
|
||||||
HbmColumnRelationalState(XMLPropertyElement property,
|
HbmColumnRelationalState(XMLPropertyElement property,
|
||||||
HbmSimpleValueRelationalStateContainer container) {
|
HbmSimpleValueRelationalStateContainer container) {
|
||||||
this.container = container;
|
this.container = container;
|
||||||
this.explicitColumnName = property.getName();
|
this.explicitColumnName = property.getName();
|
||||||
this.size = createSize( property.getLength(), property.getScale(), property.getPrecision() );
|
this.size = createSize( property.getLength(), property.getScale(), property.getPrecision() );
|
||||||
|
@ -101,11 +101,11 @@ public class HbmColumnRelationalState implements AbstractAttributeBinding.Column
|
||||||
}
|
}
|
||||||
|
|
||||||
HbmColumnRelationalState(XMLManyToOneElement manyToOne,
|
HbmColumnRelationalState(XMLManyToOneElement manyToOne,
|
||||||
HbmSimpleValueRelationalStateContainer container) {
|
HbmSimpleValueRelationalStateContainer container) {
|
||||||
this.container = container;
|
this.container = container;
|
||||||
this.explicitColumnName = manyToOne.getName();
|
this.explicitColumnName = manyToOne.getName();
|
||||||
this.size = new Size();
|
this.size = new Size();
|
||||||
this.isNullable =! MappingHelper.getBooleanValue( manyToOne.isNotNull(), false );
|
this.isNullable = !MappingHelper.getBooleanValue( manyToOne.isNotNull(), false );
|
||||||
this.isUnique = manyToOne.isUnique();
|
this.isUnique = manyToOne.isUnique();
|
||||||
this.checkCondition = null;
|
this.checkCondition = null;
|
||||||
this.defaultColumnValue = null;
|
this.defaultColumnValue = null;
|
||||||
|
@ -120,8 +120,8 @@ public class HbmColumnRelationalState implements AbstractAttributeBinding.Column
|
||||||
}
|
}
|
||||||
|
|
||||||
HbmColumnRelationalState(XMLId id,
|
HbmColumnRelationalState(XMLId id,
|
||||||
HbmSimpleValueRelationalStateContainer container) {
|
HbmSimpleValueRelationalStateContainer container) {
|
||||||
if ( id.getColumn() != null && ! id.getColumn().isEmpty() ) {
|
if ( id.getColumn() != null && !id.getColumn().isEmpty() ) {
|
||||||
throw new IllegalArgumentException( "This method should not be called with non-empty id.getColumnElement()" );
|
throw new IllegalArgumentException( "This method should not be called with non-empty id.getColumnElement()" );
|
||||||
}
|
}
|
||||||
this.container = container;
|
this.container = container;
|
||||||
|
@ -140,9 +140,11 @@ public class HbmColumnRelationalState implements AbstractAttributeBinding.Column
|
||||||
}
|
}
|
||||||
|
|
||||||
HbmColumnRelationalState(XMLDiscriminator discriminator,
|
HbmColumnRelationalState(XMLDiscriminator discriminator,
|
||||||
HbmSimpleValueRelationalStateContainer container) {
|
HbmSimpleValueRelationalStateContainer container) {
|
||||||
if ( discriminator.getColumn() != null ) {
|
if ( discriminator.getColumn() != null ) {
|
||||||
throw new IllegalArgumentException( "This method should not be called with null discriminator.getColumnElement()" );
|
throw new IllegalArgumentException(
|
||||||
|
"This method should not be called with null discriminator.getColumnElement()"
|
||||||
|
);
|
||||||
}
|
}
|
||||||
this.container = container;
|
this.container = container;
|
||||||
this.explicitColumnName = null;
|
this.explicitColumnName = null;
|
||||||
|
@ -160,11 +162,13 @@ public class HbmColumnRelationalState implements AbstractAttributeBinding.Column
|
||||||
}
|
}
|
||||||
|
|
||||||
HbmColumnRelationalState(XMLVersion version,
|
HbmColumnRelationalState(XMLVersion version,
|
||||||
HbmSimpleValueRelationalStateContainer container) {
|
HbmSimpleValueRelationalStateContainer container) {
|
||||||
this.container = container;
|
this.container = container;
|
||||||
this.explicitColumnName = version.getColumnAttribute();
|
this.explicitColumnName = version.getColumnAttribute();
|
||||||
if ( version.getColumn() != null && ! version.getColumn().isEmpty() ) {
|
if ( version.getColumn() != null && !version.getColumn().isEmpty() ) {
|
||||||
throw new IllegalArgumentException( "This method should not be called with non-empty version.getColumnElement()" );
|
throw new IllegalArgumentException(
|
||||||
|
"This method should not be called with non-empty version.getColumnElement()"
|
||||||
|
);
|
||||||
}
|
}
|
||||||
// TODO: should set default
|
// TODO: should set default
|
||||||
this.size = new Size();
|
this.size = new Size();
|
||||||
|
@ -181,7 +185,7 @@ public class HbmColumnRelationalState implements AbstractAttributeBinding.Column
|
||||||
}
|
}
|
||||||
|
|
||||||
HbmColumnRelationalState(XMLTimestamp timestamp,
|
HbmColumnRelationalState(XMLTimestamp timestamp,
|
||||||
HbmSimpleValueRelationalStateContainer container) {
|
HbmSimpleValueRelationalStateContainer container) {
|
||||||
this.container = container;
|
this.container = container;
|
||||||
this.explicitColumnName = timestamp.getColumn();
|
this.explicitColumnName = timestamp.getColumn();
|
||||||
// TODO: should set default
|
// TODO: should set default
|
||||||
|
@ -201,12 +205,15 @@ public class HbmColumnRelationalState implements AbstractAttributeBinding.Column
|
||||||
public NamingStrategy getNamingStrategy() {
|
public NamingStrategy getNamingStrategy() {
|
||||||
return container.getNamingStrategy();
|
return container.getNamingStrategy();
|
||||||
}
|
}
|
||||||
|
|
||||||
public String getExplicitColumnName() {
|
public String getExplicitColumnName() {
|
||||||
return explicitColumnName;
|
return explicitColumnName;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Size getSize() {
|
public Size getSize() {
|
||||||
return size;
|
return size;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected static Size createSize(String length, String scale, String precision) {
|
protected static Size createSize(String length, String scale, String precision) {
|
||||||
// TODO: should this set defaults if length, scale, precision is not specified?
|
// TODO: should this set defaults if length, scale, precision is not specified?
|
||||||
Size size = new Size();
|
Size size = new Size();
|
||||||
|
@ -222,6 +229,7 @@ public class HbmColumnRelationalState implements AbstractAttributeBinding.Column
|
||||||
// TODO: is there an attribute for lobMultiplier?
|
// TODO: is there an attribute for lobMultiplier?
|
||||||
return size;
|
return size;
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean isNullable() {
|
public boolean isNullable() {
|
||||||
return isNullable;
|
return isNullable;
|
||||||
}
|
}
|
||||||
|
@ -233,24 +241,31 @@ public class HbmColumnRelationalState implements AbstractAttributeBinding.Column
|
||||||
public String getCheckCondition() {
|
public String getCheckCondition() {
|
||||||
return checkCondition;
|
return checkCondition;
|
||||||
}
|
}
|
||||||
|
|
||||||
public String getDefault() {
|
public String getDefault() {
|
||||||
return defaultColumnValue;
|
return defaultColumnValue;
|
||||||
}
|
}
|
||||||
|
|
||||||
public String getSqlType() {
|
public String getSqlType() {
|
||||||
return sqlType;
|
return sqlType;
|
||||||
}
|
}
|
||||||
|
|
||||||
public String getCustomWriteFragment() {
|
public String getCustomWriteFragment() {
|
||||||
return customWrite;
|
return customWrite;
|
||||||
}
|
}
|
||||||
|
|
||||||
public String getCustomReadFragment() {
|
public String getCustomReadFragment() {
|
||||||
return customRead;
|
return customRead;
|
||||||
}
|
}
|
||||||
|
|
||||||
public String getComment() {
|
public String getComment() {
|
||||||
return comment;
|
return comment;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Set<String> getUniqueKeys() {
|
public Set<String> getUniqueKeys() {
|
||||||
return uniqueKeys;
|
return uniqueKeys;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Set<String> getIndexes() {
|
public Set<String> getIndexes() {
|
||||||
return indexes;
|
return indexes;
|
||||||
}
|
}
|
||||||
|
|
|
@ -38,7 +38,7 @@ import org.hibernate.testing.FailureExpected;
|
||||||
*/
|
*/
|
||||||
public class BasicAnnotationBindingTests extends AbstractBasicBindingTests {
|
public class BasicAnnotationBindingTests extends AbstractBasicBindingTests {
|
||||||
|
|
||||||
@FailureExpected(jiraKey = "HHH-5672", message = "Work in progress")
|
//@FailureExpected(jiraKey = "HHH-5672", message = "Work in progress")
|
||||||
@Test
|
@Test
|
||||||
public void testSimpleEntityMapping() {
|
public void testSimpleEntityMapping() {
|
||||||
super.testSimpleEntityMapping();
|
super.testSimpleEntityMapping();
|
||||||
|
|
|
@ -25,11 +25,14 @@ package org.hibernate.metamodel.binding;
|
||||||
|
|
||||||
import javax.persistence.Entity;
|
import javax.persistence.Entity;
|
||||||
import javax.persistence.Id;
|
import javax.persistence.Id;
|
||||||
|
import javax.persistence.Table;
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author Steve Ebersole
|
* @author Steve Ebersole
|
||||||
*/
|
*/
|
||||||
@Entity
|
@Entity
|
||||||
|
@Table(schema = "foo")
|
||||||
public class SimpleEntity {
|
public class SimpleEntity {
|
||||||
@Id
|
@Id
|
||||||
private Long id;
|
private Long id;
|
||||||
|
|
|
@ -59,12 +59,12 @@ import static org.junit.Assert.assertFalse;
|
||||||
public class ConfiguredClassHierarchyBuilderTest extends BaseUnitTestCase {
|
public class ConfiguredClassHierarchyBuilderTest extends BaseUnitTestCase {
|
||||||
|
|
||||||
private BasicServiceRegistryImpl serviceRegistry;
|
private BasicServiceRegistryImpl serviceRegistry;
|
||||||
private ClassLoaderService service;
|
private ClassLoaderService classLoaderService;
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void setUp() {
|
public void setUp() {
|
||||||
serviceRegistry = (BasicServiceRegistryImpl) new ServiceRegistryBuilder().buildServiceRegistry();
|
serviceRegistry = (BasicServiceRegistryImpl) new ServiceRegistryBuilder().buildServiceRegistry();
|
||||||
service = serviceRegistry.getService( ClassLoaderService.class );
|
classLoaderService = serviceRegistry.getService( ClassLoaderService.class );
|
||||||
}
|
}
|
||||||
|
|
||||||
@After
|
@After
|
||||||
|
@ -74,7 +74,7 @@ public class ConfiguredClassHierarchyBuilderTest extends BaseUnitTestCase {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testSingleEntity() {
|
public void testSingleEntity() {
|
||||||
Index index = JandexHelper.indexForClass( service, Foo.class );
|
Index index = JandexHelper.indexForClass( classLoaderService, Foo.class );
|
||||||
Set<ConfiguredClassHierarchy> hierarchies = ConfiguredClassHierarchyBuilder.createEntityHierarchies(
|
Set<ConfiguredClassHierarchy> hierarchies = ConfiguredClassHierarchyBuilder.createEntityHierarchies(
|
||||||
index, serviceRegistry
|
index, serviceRegistry
|
||||||
);
|
);
|
||||||
|
@ -88,7 +88,7 @@ public class ConfiguredClassHierarchyBuilderTest extends BaseUnitTestCase {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testSimpleInheritance() {
|
public void testSimpleInheritance() {
|
||||||
Index index = JandexHelper.indexForClass( service, B.class, A.class );
|
Index index = JandexHelper.indexForClass( classLoaderService, B.class, A.class );
|
||||||
Set<ConfiguredClassHierarchy> hierarchies = ConfiguredClassHierarchyBuilder.createEntityHierarchies(
|
Set<ConfiguredClassHierarchy> hierarchies = ConfiguredClassHierarchyBuilder.createEntityHierarchies(
|
||||||
index, serviceRegistry
|
index, serviceRegistry
|
||||||
);
|
);
|
||||||
|
@ -104,7 +104,7 @@ public class ConfiguredClassHierarchyBuilderTest extends BaseUnitTestCase {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testMultipleHierarchies() {
|
public void testMultipleHierarchies() {
|
||||||
Index index = JandexHelper.indexForClass( service, B.class, A.class, Foo.class );
|
Index index = JandexHelper.indexForClass( classLoaderService, B.class, A.class, Foo.class );
|
||||||
Set<ConfiguredClassHierarchy> hierarchies = ConfiguredClassHierarchyBuilder.createEntityHierarchies(
|
Set<ConfiguredClassHierarchy> hierarchies = ConfiguredClassHierarchyBuilder.createEntityHierarchies(
|
||||||
index, serviceRegistry
|
index, serviceRegistry
|
||||||
);
|
);
|
||||||
|
@ -130,7 +130,7 @@ public class ConfiguredClassHierarchyBuilderTest extends BaseUnitTestCase {
|
||||||
}
|
}
|
||||||
|
|
||||||
Index index = JandexHelper.indexForClass(
|
Index index = JandexHelper.indexForClass(
|
||||||
service, MappedSubClass.class, MappedSuperClass.class, UnmappedSubClass.class
|
classLoaderService, MappedSubClass.class, MappedSuperClass.class, UnmappedSubClass.class
|
||||||
);
|
);
|
||||||
Set<ConfiguredClassHierarchy> hierarchies = ConfiguredClassHierarchyBuilder.createEntityHierarchies(
|
Set<ConfiguredClassHierarchy> hierarchies = ConfiguredClassHierarchyBuilder.createEntityHierarchies(
|
||||||
index, serviceRegistry
|
index, serviceRegistry
|
||||||
|
@ -154,7 +154,7 @@ public class ConfiguredClassHierarchyBuilderTest extends BaseUnitTestCase {
|
||||||
class EntityAndMappedSuperClass {
|
class EntityAndMappedSuperClass {
|
||||||
}
|
}
|
||||||
|
|
||||||
Index index = JandexHelper.indexForClass( service, EntityAndMappedSuperClass.class );
|
Index index = JandexHelper.indexForClass( classLoaderService, EntityAndMappedSuperClass.class );
|
||||||
ConfiguredClassHierarchyBuilder.createEntityHierarchies( index, serviceRegistry );
|
ConfiguredClassHierarchyBuilder.createEntityHierarchies( index, serviceRegistry );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -165,7 +165,7 @@ public class ConfiguredClassHierarchyBuilderTest extends BaseUnitTestCase {
|
||||||
class EntityAndEmbeddable {
|
class EntityAndEmbeddable {
|
||||||
}
|
}
|
||||||
|
|
||||||
Index index = JandexHelper.indexForClass( service, EntityAndEmbeddable.class );
|
Index index = JandexHelper.indexForClass( classLoaderService, EntityAndEmbeddable.class );
|
||||||
ConfiguredClassHierarchyBuilder.createEntityHierarchies( index, serviceRegistry );
|
ConfiguredClassHierarchyBuilder.createEntityHierarchies( index, serviceRegistry );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -181,7 +181,7 @@ public class ConfiguredClassHierarchyBuilderTest extends BaseUnitTestCase {
|
||||||
class B extends A {
|
class B extends A {
|
||||||
}
|
}
|
||||||
|
|
||||||
Index index = JandexHelper.indexForClass( service, B.class, A.class );
|
Index index = JandexHelper.indexForClass( classLoaderService, B.class, A.class );
|
||||||
ConfiguredClassHierarchyBuilder.createEntityHierarchies( index, serviceRegistry );
|
ConfiguredClassHierarchyBuilder.createEntityHierarchies( index, serviceRegistry );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -197,7 +197,7 @@ public class ConfiguredClassHierarchyBuilderTest extends BaseUnitTestCase {
|
||||||
class B extends A {
|
class B extends A {
|
||||||
}
|
}
|
||||||
|
|
||||||
Index index = JandexHelper.indexForClass( service, B.class, A.class );
|
Index index = JandexHelper.indexForClass( classLoaderService, B.class, A.class );
|
||||||
Set<ConfiguredClassHierarchy> hierarchies = ConfiguredClassHierarchyBuilder.createEntityHierarchies(
|
Set<ConfiguredClassHierarchy> hierarchies = ConfiguredClassHierarchyBuilder.createEntityHierarchies(
|
||||||
index, serviceRegistry
|
index, serviceRegistry
|
||||||
);
|
);
|
||||||
|
@ -226,7 +226,7 @@ public class ConfiguredClassHierarchyBuilderTest extends BaseUnitTestCase {
|
||||||
class B extends A {
|
class B extends A {
|
||||||
}
|
}
|
||||||
|
|
||||||
Index index = JandexHelper.indexForClass( service, B.class, A.class );
|
Index index = JandexHelper.indexForClass( classLoaderService, B.class, A.class );
|
||||||
Set<ConfiguredClassHierarchy> hierarchies = ConfiguredClassHierarchyBuilder.createEntityHierarchies(
|
Set<ConfiguredClassHierarchy> hierarchies = ConfiguredClassHierarchyBuilder.createEntityHierarchies(
|
||||||
index, serviceRegistry
|
index, serviceRegistry
|
||||||
);
|
);
|
||||||
|
@ -247,7 +247,7 @@ public class ConfiguredClassHierarchyBuilderTest extends BaseUnitTestCase {
|
||||||
class B extends A {
|
class B extends A {
|
||||||
}
|
}
|
||||||
|
|
||||||
Index index = JandexHelper.indexForClass( service, B.class, A.class );
|
Index index = JandexHelper.indexForClass( classLoaderService, B.class, A.class );
|
||||||
Set<ConfiguredClassHierarchy> hierarchies = ConfiguredClassHierarchyBuilder.createEntityHierarchies(
|
Set<ConfiguredClassHierarchy> hierarchies = ConfiguredClassHierarchyBuilder.createEntityHierarchies(
|
||||||
index, serviceRegistry
|
index, serviceRegistry
|
||||||
);
|
);
|
||||||
|
@ -275,7 +275,7 @@ public class ConfiguredClassHierarchyBuilderTest extends BaseUnitTestCase {
|
||||||
class B extends A {
|
class B extends A {
|
||||||
}
|
}
|
||||||
|
|
||||||
Index index = JandexHelper.indexForClass( service, B.class, MappedSuperClass.class, A.class );
|
Index index = JandexHelper.indexForClass( classLoaderService, B.class, MappedSuperClass.class, A.class );
|
||||||
Set<ConfiguredClassHierarchy> hierarchies = ConfiguredClassHierarchyBuilder.createEntityHierarchies(
|
Set<ConfiguredClassHierarchy> hierarchies = ConfiguredClassHierarchyBuilder.createEntityHierarchies(
|
||||||
index, serviceRegistry
|
index, serviceRegistry
|
||||||
);
|
);
|
||||||
|
@ -298,7 +298,7 @@ public class ConfiguredClassHierarchyBuilderTest extends BaseUnitTestCase {
|
||||||
class B extends A {
|
class B extends A {
|
||||||
}
|
}
|
||||||
|
|
||||||
Index index = JandexHelper.indexForClass( service, B.class, A.class );
|
Index index = JandexHelper.indexForClass( classLoaderService, B.class, A.class );
|
||||||
ConfiguredClassHierarchyBuilder.createEntityHierarchies( index, serviceRegistry );
|
ConfiguredClassHierarchyBuilder.createEntityHierarchies( index, serviceRegistry );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -40,7 +40,7 @@ import org.junit.Test;
|
||||||
|
|
||||||
import org.hibernate.metamodel.source.annotations.ConfiguredClass;
|
import org.hibernate.metamodel.source.annotations.ConfiguredClass;
|
||||||
import org.hibernate.metamodel.source.annotations.ConfiguredClassHierarchy;
|
import org.hibernate.metamodel.source.annotations.ConfiguredClassHierarchy;
|
||||||
import org.hibernate.metamodel.source.annotations.MappedProperty;
|
import org.hibernate.metamodel.source.annotations.MappedAttribute;
|
||||||
import org.hibernate.service.ServiceRegistryBuilder;
|
import org.hibernate.service.ServiceRegistryBuilder;
|
||||||
import org.hibernate.service.classloading.spi.ClassLoaderService;
|
import org.hibernate.service.classloading.spi.ClassLoaderService;
|
||||||
import org.hibernate.service.internal.BasicServiceRegistryImpl;
|
import org.hibernate.service.internal.BasicServiceRegistryImpl;
|
||||||
|
@ -80,7 +80,7 @@ public class GenericTypeDiscoveryTest extends BaseUnitTestCase {
|
||||||
ConfiguredClass configuredClass = iter.next();
|
ConfiguredClass configuredClass = iter.next();
|
||||||
ClassInfo info = configuredClass.getClassInfo();
|
ClassInfo info = configuredClass.getClassInfo();
|
||||||
assertEquals( "wrong class", DotName.createSimple( Stuff.class.getName() ), info.name() );
|
assertEquals( "wrong class", DotName.createSimple( Stuff.class.getName() ), info.name() );
|
||||||
MappedProperty property = configuredClass.getMappedProperty( "value" );
|
MappedAttribute property = configuredClass.getMappedProperty( "value" );
|
||||||
assertEquals( Price.class, property.getType() );
|
assertEquals( Price.class, property.getType() );
|
||||||
|
|
||||||
assertTrue( iter.hasNext() );
|
assertTrue( iter.hasNext() );
|
||||||
|
@ -88,7 +88,7 @@ public class GenericTypeDiscoveryTest extends BaseUnitTestCase {
|
||||||
info = configuredClass.getClassInfo();
|
info = configuredClass.getClassInfo();
|
||||||
assertEquals( "wrong class", DotName.createSimple( PricedStuff.class.getName() ), info.name() );
|
assertEquals( "wrong class", DotName.createSimple( PricedStuff.class.getName() ), info.name() );
|
||||||
assertFalse(
|
assertFalse(
|
||||||
"PricedStuff should not mapped properties", configuredClass.getMappedProperties().iterator().hasNext()
|
"PricedStuff should not mapped properties", configuredClass.getMappedAttributes().iterator().hasNext()
|
||||||
);
|
);
|
||||||
|
|
||||||
assertTrue( iter.hasNext() );
|
assertTrue( iter.hasNext() );
|
||||||
|
@ -105,7 +105,7 @@ public class GenericTypeDiscoveryTest extends BaseUnitTestCase {
|
||||||
configuredClass = iter.next();
|
configuredClass = iter.next();
|
||||||
info = configuredClass.getClassInfo();
|
info = configuredClass.getClassInfo();
|
||||||
assertEquals( "wrong class", DotName.createSimple( Paper.class.getName() ), info.name() );
|
assertEquals( "wrong class", DotName.createSimple( Paper.class.getName() ), info.name() );
|
||||||
assertFalse( "Paper should not mapped properties", configuredClass.getMappedProperties().iterator().hasNext() );
|
assertFalse( "Paper should not mapped properties", configuredClass.getMappedAttributes().iterator().hasNext() );
|
||||||
|
|
||||||
assertFalse( iter.hasNext() );
|
assertFalse( iter.hasNext() );
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,70 @@
|
||||||
|
package org.hibernate.metamodel.source.annotations.util;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
import javax.persistence.Basic;
|
||||||
|
import javax.persistence.Column;
|
||||||
|
|
||||||
|
import org.jboss.jandex.AnnotationInstance;
|
||||||
|
import org.jboss.jandex.ClassInfo;
|
||||||
|
import org.jboss.jandex.DotName;
|
||||||
|
import org.jboss.jandex.Index;
|
||||||
|
import org.junit.After;
|
||||||
|
import org.junit.Before;
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
|
import org.hibernate.service.ServiceRegistryBuilder;
|
||||||
|
import org.hibernate.service.classloading.spi.ClassLoaderService;
|
||||||
|
import org.hibernate.service.internal.BasicServiceRegistryImpl;
|
||||||
|
import org.hibernate.testing.junit4.BaseUnitTestCase;
|
||||||
|
|
||||||
|
import static junit.framework.Assert.assertTrue;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @author Hardy Ferentschik
|
||||||
|
*/
|
||||||
|
public class JandexHelperTest extends BaseUnitTestCase {
|
||||||
|
private BasicServiceRegistryImpl serviceRegistry;
|
||||||
|
private ClassLoaderService classLoaderService;
|
||||||
|
|
||||||
|
@Before
|
||||||
|
public void setUp() {
|
||||||
|
serviceRegistry = (BasicServiceRegistryImpl) new ServiceRegistryBuilder().buildServiceRegistry();
|
||||||
|
classLoaderService = serviceRegistry.getService( ClassLoaderService.class );
|
||||||
|
}
|
||||||
|
|
||||||
|
@After
|
||||||
|
public void tearDown() {
|
||||||
|
serviceRegistry.destroy();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testGetMemberAnnotations() {
|
||||||
|
class Foo {
|
||||||
|
@Column
|
||||||
|
@Basic
|
||||||
|
private String bar;
|
||||||
|
|
||||||
|
private String fubar;
|
||||||
|
}
|
||||||
|
Index index = JandexHelper.indexForClass( classLoaderService, Foo.class );
|
||||||
|
|
||||||
|
ClassInfo classInfo = index.getClassByName( DotName.createSimple( Foo.class.getName() ) );
|
||||||
|
Map<DotName, List<AnnotationInstance>> memberAnnotations = JandexHelper.getMemberAnnotations(
|
||||||
|
classInfo, "bar"
|
||||||
|
);
|
||||||
|
assertTrue(
|
||||||
|
"property bar should defines @Column annotation",
|
||||||
|
memberAnnotations.containsKey( DotName.createSimple( Column.class.getName() ) )
|
||||||
|
);
|
||||||
|
assertTrue(
|
||||||
|
"property bar should defines @Basic annotation",
|
||||||
|
memberAnnotations.containsKey( DotName.createSimple( Basic.class.getName() ) )
|
||||||
|
);
|
||||||
|
|
||||||
|
memberAnnotations = JandexHelper.getMemberAnnotations( classInfo, "fubar" );
|
||||||
|
assertTrue( "there should be no annotations in fubar", memberAnnotations.isEmpty() );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue