HHH-10208 - Index not considered while loading from XML mapping file
(cherry picked from commit 8bcf66631d
)
This commit is contained in:
parent
fa7fcf5b95
commit
1de3002fe5
|
@ -45,6 +45,8 @@ import org.hibernate.boot.model.source.spi.SingularAttributeSourceEmbedded;
|
|||
import org.hibernate.boot.model.source.spi.ToolingHintContext;
|
||||
import org.hibernate.internal.util.StringHelper;
|
||||
|
||||
import static org.hibernate.internal.util.StringHelper.isNotEmpty;
|
||||
|
||||
/**
|
||||
* @author Steve Ebersole
|
||||
*/
|
||||
|
@ -447,6 +449,7 @@ public class AttributesHelper {
|
|||
);
|
||||
|
||||
processConstraints(
|
||||
mappingDocument,
|
||||
callback,
|
||||
logicalTableName,
|
||||
basicAttributeJaxbMapping.getColumnAttribute(),
|
||||
|
@ -457,6 +460,7 @@ public class AttributesHelper {
|
|||
}
|
||||
|
||||
private static void processConstraints(
|
||||
MappingDocument mappingDocument,
|
||||
Callback callback,
|
||||
String logicalTableName,
|
||||
String columnAttribute,
|
||||
|
@ -470,13 +474,20 @@ public class AttributesHelper {
|
|||
final Set<String> groupedUniqueKeyNameSet = splitNames( groupedUniqueKeyNames );
|
||||
final boolean hasGroupedUniqueKeys = !groupedUniqueKeyNameSet.isEmpty();
|
||||
|
||||
if ( hasGroupedIndexes && StringHelper.isNotEmpty( columnAttribute ) ) {
|
||||
if ( hasGroupedIndexes ) {
|
||||
if ( isNotEmpty( columnAttribute ) ) {
|
||||
for ( String name : groupedIndexNameSet ) {
|
||||
callback.registerIndexColumn( name, logicalTableName, columnAttribute );
|
||||
}
|
||||
}
|
||||
}
|
||||
if ( hasGroupedIndexes && isNotEmpty( columnAttribute ) ) {
|
||||
for ( String name : groupedIndexNameSet ) {
|
||||
callback.registerIndexColumn( name, logicalTableName, columnAttribute );
|
||||
}
|
||||
}
|
||||
|
||||
if ( hasGroupedUniqueKeys && StringHelper.isNotEmpty( columnAttribute ) ) {
|
||||
if ( hasGroupedUniqueKeys && isNotEmpty( columnAttribute ) ) {
|
||||
for ( String name : groupedUniqueKeyNameSet ) {
|
||||
callback.registerUniqueKeyColumn( name, logicalTableName, columnAttribute );
|
||||
}
|
||||
|
@ -488,7 +499,7 @@ public class AttributesHelper {
|
|||
}
|
||||
|
||||
final JaxbHbmColumnType column = (JaxbHbmColumnType) oColumn;
|
||||
if ( StringHelper.isNotEmpty( column.getIndex() ) ) {
|
||||
if ( isNotEmpty( column.getIndex() ) ) {
|
||||
callback.registerIndexColumn( column.getIndex(), logicalTableName, column.getName() );
|
||||
}
|
||||
if ( hasGroupedIndexes ) {
|
||||
|
@ -497,7 +508,7 @@ public class AttributesHelper {
|
|||
}
|
||||
}
|
||||
|
||||
if ( StringHelper.isNotEmpty( column.getUniqueKey() ) ) {
|
||||
if ( isNotEmpty( column.getUniqueKey() ) ) {
|
||||
callback.registerUniqueKeyColumn( column.getUniqueKey(), logicalTableName, column.getName() );
|
||||
}
|
||||
if ( hasGroupedUniqueKeys ) {
|
||||
|
@ -589,6 +600,7 @@ public class AttributesHelper {
|
|||
);
|
||||
|
||||
processConstraints(
|
||||
mappingDocument,
|
||||
callback,
|
||||
logicalTableName,
|
||||
manyToOneAttributeJaxbMapping.getColumnAttribute(),
|
||||
|
@ -632,6 +644,7 @@ public class AttributesHelper {
|
|||
);
|
||||
|
||||
processConstraints(
|
||||
mappingDocument,
|
||||
callback,
|
||||
logicalTableName,
|
||||
null,
|
||||
|
|
|
@ -0,0 +1,87 @@
|
|||
/*
|
||||
* 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.hbm;
|
||||
|
||||
import java.util.Collections;
|
||||
|
||||
import org.hibernate.boot.Metadata;
|
||||
import org.hibernate.boot.MetadataSources;
|
||||
import org.hibernate.boot.registry.StandardServiceRegistry;
|
||||
import org.hibernate.boot.registry.StandardServiceRegistryBuilder;
|
||||
import org.hibernate.tool.schema.spi.SchemaCreator;
|
||||
import org.hibernate.tool.schema.spi.SchemaManagementTool;
|
||||
|
||||
import org.hibernate.testing.FailureExpected;
|
||||
import org.hibernate.testing.TestForIssue;
|
||||
import org.hibernate.testing.junit4.BaseUnitTestCase;
|
||||
import org.hibernate.test.hbm.JournalingSchemaToolingTarget;
|
||||
import org.junit.After;
|
||||
import org.junit.Before;
|
||||
import org.junit.Test;
|
||||
|
||||
import static org.junit.Assert.assertTrue;
|
||||
|
||||
/**
|
||||
* @author Steve Ebersole
|
||||
*/
|
||||
@TestForIssue( jiraKey = "HHH-10208" )
|
||||
public class IndexTest extends BaseUnitTestCase {
|
||||
private StandardServiceRegistry ssr;
|
||||
|
||||
@Before
|
||||
public void before() {
|
||||
ssr = new StandardServiceRegistryBuilder().build();
|
||||
}
|
||||
|
||||
@After
|
||||
public void after() {
|
||||
if ( ssr != null ) {
|
||||
StandardServiceRegistryBuilder.destroy( ssr );
|
||||
}
|
||||
}
|
||||
|
||||
@Test
|
||||
@FailureExpected( jiraKey = "HHH-10208" )
|
||||
public void testOneToMany() throws Exception {
|
||||
verifyIndexCreated(
|
||||
"org/hibernate/test/hbm/index/person_manytoone.hbm.xml",
|
||||
"person_persongroup_index"
|
||||
);
|
||||
}
|
||||
|
||||
private void verifyIndexCreated(String mappingResource, String expectedIndexName) {
|
||||
final Metadata metadata = new MetadataSources( ssr )
|
||||
.addResource( mappingResource )
|
||||
.buildMetadata();
|
||||
|
||||
final SchemaCreator schemaCreator = ssr.getService( SchemaManagementTool.class ).getSchemaCreator( Collections.emptyMap() );
|
||||
final JournalingSchemaToolingTarget target = new JournalingSchemaToolingTarget();
|
||||
schemaCreator.doCreation( metadata, false, target );
|
||||
|
||||
assertTrue(
|
||||
"Expected index [" + expectedIndexName + "] not seen in schema creation output",
|
||||
target.containedText( expectedIndexName )
|
||||
);
|
||||
}
|
||||
|
||||
@Test
|
||||
@FailureExpected( jiraKey = "HHH-10208" )
|
||||
public void testProperty() throws Exception {
|
||||
verifyIndexCreated(
|
||||
"org/hibernate/test/hbm/index/person_property.hbm.xml",
|
||||
"person_name_index"
|
||||
);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testPropertyColumn() throws Exception {
|
||||
verifyIndexCreated(
|
||||
"org/hibernate/test/hbm/index/person_propertycolumn.hbm.xml",
|
||||
"person_name_index"
|
||||
);
|
||||
}
|
||||
}
|
|
@ -0,0 +1,53 @@
|
|||
/*
|
||||
* 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.hbm;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
|
||||
import org.hibernate.tool.schema.spi.Target;
|
||||
|
||||
/**
|
||||
* @author Steve Ebersole
|
||||
*/
|
||||
public class JournalingSchemaToolingTarget implements Target {
|
||||
private List<String> actions = new ArrayList<String>();
|
||||
|
||||
@Override
|
||||
public boolean acceptsImportScriptActions() {
|
||||
return false;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void prepare() {
|
||||
|
||||
}
|
||||
|
||||
@Override
|
||||
public void accept(String action) {
|
||||
actions.add( action );
|
||||
}
|
||||
|
||||
@Override
|
||||
public void release() {
|
||||
|
||||
}
|
||||
|
||||
public List<String> getActions() {
|
||||
return actions;
|
||||
}
|
||||
|
||||
public boolean containedText(String text) {
|
||||
for ( String action : actions ) {
|
||||
if ( action.contains( text ) ) {
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
}
|
|
@ -0,0 +1,37 @@
|
|||
/*
|
||||
* 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.hbm;
|
||||
|
||||
public class Person {
|
||||
private long id;
|
||||
private String name;
|
||||
private PersonGroup personGroup;
|
||||
|
||||
public long getId() {
|
||||
return id;
|
||||
}
|
||||
|
||||
public void setId(long id) {
|
||||
this.id = id;
|
||||
}
|
||||
|
||||
public String getName() {
|
||||
return name;
|
||||
}
|
||||
|
||||
public void setName(String name) {
|
||||
this.name = name;
|
||||
}
|
||||
|
||||
public PersonGroup getPersonGroup() {
|
||||
return personGroup;
|
||||
}
|
||||
|
||||
public void setPersonGroup(PersonGroup personGroup) {
|
||||
this.personGroup = personGroup;
|
||||
}
|
||||
}
|
|
@ -0,0 +1,13 @@
|
|||
/*
|
||||
* 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.hbm;
|
||||
|
||||
/**
|
||||
* @author Steve Ebersole
|
||||
*/
|
||||
public class PersonGroup {
|
||||
}
|
|
@ -0,0 +1,11 @@
|
|||
/*
|
||||
* 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>.
|
||||
*/
|
||||
|
||||
/**
|
||||
* Tests specific to {@code hbm.xml} handling/binding
|
||||
*/
|
||||
package org.hibernate.test.hbm;
|
|
@ -0,0 +1,28 @@
|
|||
<?xml version="1.0"?>
|
||||
<!--
|
||||
~ 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>.
|
||||
-->
|
||||
<!DOCTYPE hibernate-mapping PUBLIC
|
||||
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
|
||||
"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
|
||||
|
||||
<hibernate-mapping package="org.hibernate.test.hbm">
|
||||
|
||||
<class name="PersonGroup">
|
||||
<id name="id" type="long">
|
||||
<generator class="native" />
|
||||
</id>
|
||||
<property name="name" type="string" not-null="true" />
|
||||
</class>
|
||||
|
||||
<class name="Person">
|
||||
<id name="id" type="long">
|
||||
<generator class="native" />
|
||||
</id>
|
||||
<many-to-one name="personGroup" foreign-key="person_persongroup_fk" index="person_persongroup_index" class="PersonGroup"/>
|
||||
</class>
|
||||
|
||||
</hibernate-mapping>
|
|
@ -0,0 +1,21 @@
|
|||
<?xml version="1.0"?>
|
||||
<!--
|
||||
~ 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>.
|
||||
-->
|
||||
<!DOCTYPE hibernate-mapping PUBLIC
|
||||
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
|
||||
"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
|
||||
|
||||
<hibernate-mapping package="org.hibernate.test.hbm">
|
||||
|
||||
<class name="Person">
|
||||
<id name="id" type="long">
|
||||
<generator class="native" />
|
||||
</id>
|
||||
<property name="name" index="person_name_index" type="string"/>
|
||||
</class>
|
||||
|
||||
</hibernate-mapping>
|
|
@ -0,0 +1,23 @@
|
|||
<?xml version="1.0"?>
|
||||
<!--
|
||||
~ 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>.
|
||||
-->
|
||||
<!DOCTYPE hibernate-mapping PUBLIC
|
||||
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
|
||||
"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
|
||||
|
||||
<hibernate-mapping package="org.hibernate.test.hbm">
|
||||
|
||||
<class name="Person">
|
||||
<id name="id" type="long">
|
||||
<generator class="native" />
|
||||
</id>
|
||||
<property name="name" type="string">
|
||||
<column name="name" index="person_name_index"/>
|
||||
</property>
|
||||
</class>
|
||||
|
||||
</hibernate-mapping>
|
Loading…
Reference in New Issue