HHH-6662, HHH-7445 - Fix and test

This commit is contained in:
Strong Liu 2012-08-03 18:21:32 +08:00
parent 00a83af879
commit 30ea6c9025
10 changed files with 264 additions and 5 deletions

View File

@ -285,7 +285,7 @@ public abstract class AbstractPropertyHolder implements PropertyHolder {
Map<String, JoinTable> currentJoinTableOverride = buildJoinTableOverride( current, getPath() ); Map<String, JoinTable> currentJoinTableOverride = buildJoinTableOverride( current, getPath() );
currentOverride.putAll( columnOverride ); //subclasses have precedence over superclasses currentOverride.putAll( columnOverride ); //subclasses have precedence over superclasses
currentJoinOverride.putAll( joinColumnOverride ); //subclasses have precedence over superclasses currentJoinOverride.putAll( joinColumnOverride ); //subclasses have precedence over superclasses
currentJoinOverride.putAll( joinColumnOverride ); //subclasses have precedence over superclasses currentJoinTableOverride.putAll( joinTableOverride ); //subclasses have precedence over superclasses
columnOverride = currentOverride; columnOverride = currentOverride;
joinColumnOverride = currentJoinOverride; joinColumnOverride = currentJoinOverride;
joinTableOverride = currentJoinTableOverride; joinTableOverride = currentJoinTableOverride;

View File

@ -36,9 +36,11 @@ public class HibernateSequenceTest extends BaseCoreFunctionalTestCase {
protected void configure(Configuration cfg) { protected void configure(Configuration cfg) {
super.configure( cfg ); super.configure( cfg );
cfg.addResource( "org/hibernate/test/annotations/id/sequences/orm.xml" ); cfg.addResource( "org/hibernate/test/annotations/id/sequences/orm.xml" );
cfg.setProperty( }
Environment.URL, cfg.getProperty( Environment.URL ) + ";INIT=CREATE SCHEMA IF NOT EXISTS " + SCHEMA_NAME
); @Override
protected String createSecondSchema() {
return SCHEMA_NAME;
} }
@Test @Test

View File

@ -0,0 +1,58 @@
package org.hibernate.test.annotations.override;
import java.util.Iterator;
import org.junit.Assert;
import org.junit.Test;
import org.hibernate.dialect.H2Dialect;
import org.hibernate.mapping.Table;
import org.hibernate.test.util.SchemaUtil;
import org.hibernate.testing.RequiresDialect;
import org.hibernate.testing.TestForIssue;
import org.hibernate.testing.junit4.BaseCoreFunctionalTestCase;
/**
* @author Lukasz Antoniak (lukasz dot antoniak at gmail dot com)
*/
@RequiresDialect({ H2Dialect.class })
@TestForIssue(jiraKey = "HHH-6662")
public class AssociationOverrideSchemaTest extends BaseCoreFunctionalTestCase {
public static final String SCHEMA_NAME = "OTHER_SCHEMA";
public static final String TABLE_NAME = "BLOG_TAGS";
public static final String ID_COLUMN_NAME = "BLOG_ID";
public static final String VALUE_COLUMN_NAME = "BLOG_TAG";
@Override
protected Class<?>[] getAnnotatedClasses() {
return new Class[] { Entry.class, BlogEntry.class };
}
@Override
protected String createSecondSchema() {
return SCHEMA_NAME;
}
@Test
public void testJoinTableSchemaName() {
Iterator<Table> tableIterator = configuration().getTableMappings();
while ( tableIterator.hasNext() ) {
Table table = tableIterator.next();
if ( TABLE_NAME.equals( table.getName() ) ) {
Assert.assertEquals( SCHEMA_NAME, table.getSchema() );
return;
}
}
Assert.fail();
}
@Test
public void testJoinTableJoinColumnName() {
Assert.assertTrue( SchemaUtil.isColumnPresent( TABLE_NAME, ID_COLUMN_NAME, configuration() ) );
}
@Test
public void testJoinTableColumnName() {
Assert.assertTrue( SchemaUtil.isColumnPresent( TABLE_NAME, VALUE_COLUMN_NAME, configuration() ) );
}
}

View File

@ -0,0 +1,56 @@
package org.hibernate.test.annotations.override;
import javax.persistence.AssociationOverride;
import javax.persistence.AttributeOverride;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.JoinColumn;
import javax.persistence.JoinTable;
import javax.persistence.Table;
/**
* @author Lukasz Antoniak (lukasz dot antoniak at gmail dot com)
*/
@Entity
@Table(schema = AssociationOverrideSchemaTest.SCHEMA_NAME)
@AssociationOverride(name = "tags",
joinTable = @JoinTable(name = AssociationOverrideSchemaTest.TABLE_NAME,
joinColumns = @JoinColumn(name = AssociationOverrideSchemaTest.ID_COLUMN_NAME),
schema = AssociationOverrideSchemaTest.SCHEMA_NAME))
@AttributeOverride(name = "tags", column = @Column(name = AssociationOverrideSchemaTest.VALUE_COLUMN_NAME))
public class BlogEntry extends Entry {
private String text;
@Override
public boolean equals(Object o) {
if ( this == o ) return true;
if ( !( o instanceof BlogEntry ) ) return false;
if ( !super.equals( o ) ) return false;
BlogEntry blogEntry = (BlogEntry) o;
if ( text != null ? !text.equals( blogEntry.text ) : blogEntry.text != null ) return false;
return true;
}
@Override
public int hashCode() {
int result = super.hashCode();
result = 31 * result + ( text != null ? text.hashCode() : 0 );
return result;
}
@Override
public String toString() {
return "BlogEntry(" + super.toString() + ", text = " + text + ")";
}
public String getText() {
return text;
}
public void setText(String text) {
this.text = text;
}
}

View File

@ -0,0 +1,73 @@
package org.hibernate.test.annotations.override;
import java.io.Serializable;
import java.util.HashSet;
import java.util.Set;
import javax.persistence.Column;
import javax.persistence.ElementCollection;
import javax.persistence.FetchType;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.JoinTable;
import javax.persistence.MappedSuperclass;
import org.hibernate.annotations.Fetch;
import org.hibernate.annotations.FetchMode;
/**
* @author Lukasz Antoniak (lukasz dot antoniak at gmail dot com)
*/
@MappedSuperclass
public abstract class Entry implements Serializable {
@Id
@GeneratedValue
private Long id;
@ElementCollection(fetch = FetchType.EAGER)
@JoinTable(name = "TAGS", joinColumns = @JoinColumn(name = "ID"))
@Column(name = "KEYWORD")
@Fetch(FetchMode.JOIN)
private Set<String> tags = new HashSet<String>();
@Override
public boolean equals(Object o) {
if ( this == o ) return true;
if ( !( o instanceof Entry ) ) return false;
Entry entry = (Entry) o;
if ( id != null ? !id.equals( entry.id ) : entry.id != null ) return false;
if ( tags != null ? !tags.equals( entry.tags ) : entry.tags != null ) return false;
return true;
}
@Override
public int hashCode() {
int result = id != null ? id.hashCode() : 0;
result = 31 * result + ( tags != null ? tags.hashCode() : 0 );
return result;
}
@Override
public String toString() {
return "Entry(id = " + id + ", tags = " + tags + ")";
}
public Long getId() {
return id;
}
public void setId(Long id) {
this.id = id;
}
public Set<String> getTags() {
return tags;
}
public void setTags(Set<String> tags) {
this.tags = tags;
}
}

View File

@ -23,6 +23,8 @@
*/ */
package org.hibernate.test.sql.hand.custom.oracle; package org.hibernate.test.sql.hand.custom.oracle;
import org.hibernate.cfg.Configuration;
import org.hibernate.cfg.Environment;
import org.hibernate.dialect.Oracle9iDialect; import org.hibernate.dialect.Oracle9iDialect;
import org.hibernate.test.sql.hand.custom.CustomStoredProcTestSupport; import org.hibernate.test.sql.hand.custom.CustomStoredProcTestSupport;
import org.hibernate.testing.RequiresDialect; import org.hibernate.testing.RequiresDialect;

View File

@ -36,6 +36,7 @@ import org.jboss.logging.Logger;
import org.hibernate.cfg.Configuration; import org.hibernate.cfg.Configuration;
import org.hibernate.cfg.Environment; import org.hibernate.cfg.Environment;
import org.hibernate.dialect.Dialect; import org.hibernate.dialect.Dialect;
import org.hibernate.dialect.H2Dialect;
import org.hibernate.ejb.AvailableSettings; import org.hibernate.ejb.AvailableSettings;
import org.hibernate.ejb.Ejb3Configuration; import org.hibernate.ejb.Ejb3Configuration;
import org.hibernate.ejb.EntityManagerFactoryImpl; import org.hibernate.ejb.EntityManagerFactoryImpl;
@ -54,6 +55,7 @@ import org.junit.After;
import org.hibernate.testing.AfterClassOnce; import org.hibernate.testing.AfterClassOnce;
import org.hibernate.testing.BeforeClassOnce; import org.hibernate.testing.BeforeClassOnce;
import org.hibernate.testing.jta.TestingJtaPlatformImpl; import org.hibernate.testing.jta.TestingJtaPlatformImpl;
import org.hibernate.testing.junit4.Helper;
/** /**
* @author Strong Liu (stliu@hibernate.org) * @author Strong Liu (stliu@hibernate.org)
@ -93,6 +95,7 @@ public abstract class BaseEnversJPAFunctionalTestCase extends AbstractEnversTest
log.trace( "Building session factory" ); log.trace( "Building session factory" );
ejb3Configuration = buildConfiguration(); ejb3Configuration = buildConfiguration();
ejb3Configuration.configure( getConfig() ); ejb3Configuration.configure( getConfig() );
preConfigure( ejb3Configuration );
configure(ejb3Configuration); configure(ejb3Configuration);
afterConfigurationBuilt( ejb3Configuration ); afterConfigurationBuilt( ejb3Configuration );
@ -106,6 +109,19 @@ public abstract class BaseEnversJPAFunctionalTestCase extends AbstractEnversTest
afterEntityManagerFactoryBuilt(); afterEntityManagerFactoryBuilt();
} }
private void preConfigure(Ejb3Configuration ejb3Configuration) {
if ( createSchema() ) {
final String secondSchemaName = createSecondSchema();
if ( StringHelper.isNotEmpty( secondSchemaName ) ) {
if ( !( getDialect() instanceof H2Dialect ) ) {
throw new UnsupportedOperationException( "Only H2 dialect supports creation of second schema." );
}
Helper.createH2Schema( secondSchemaName, ejb3Configuration.getHibernateConfiguration() );
}
}
}
public void configure(Ejb3Configuration cfg) { public void configure(Ejb3Configuration cfg) {
} }
@ -219,6 +235,15 @@ public abstract class BaseEnversJPAFunctionalTestCase extends AbstractEnversTest
protected boolean createSchema() { protected boolean createSchema() {
return true; return true;
} }
/**
* Feature supported only by H2 dialect.
* @return Provide not empty name to create second schema.
*/
protected String createSecondSchema() {
return null;
}
protected boolean isAudit() { protected boolean isAudit() {
return true; return true;
} }

View File

@ -30,10 +30,14 @@ public class DifferentDBSchemaTest extends BaseEnversJPAFunctionalTestCase {
super.addConfigOptions(options); super.addConfigOptions(options);
// Creates new schema after establishing connection // Creates new schema after establishing connection
options.putAll(Environment.getProperties()); options.putAll(Environment.getProperties());
options.put(Environment.URL, options.get(Environment.URL) + ";INIT=CREATE SCHEMA IF NOT EXISTS " + SCHEMA_NAME);
options.put("org.hibernate.envers.default_schema", SCHEMA_NAME); options.put("org.hibernate.envers.default_schema", SCHEMA_NAME);
} }
@Override
protected String createSecondSchema() {
return SCHEMA_NAME;
}
@Override @Override
public void configure(Ejb3Configuration cfg) { public void configure(Ejb3Configuration cfg) {
cfg.addAnnotatedClass(StrTestEntity.class); cfg.addAnnotatedClass(StrTestEntity.class);

View File

@ -45,8 +45,10 @@ import org.hibernate.cfg.Configuration;
import org.hibernate.cfg.Environment; import org.hibernate.cfg.Environment;
import org.hibernate.cfg.Mappings; import org.hibernate.cfg.Mappings;
import org.hibernate.dialect.Dialect; import org.hibernate.dialect.Dialect;
import org.hibernate.dialect.H2Dialect;
import org.hibernate.engine.spi.SessionFactoryImplementor; import org.hibernate.engine.spi.SessionFactoryImplementor;
import org.hibernate.engine.spi.SessionImplementor; import org.hibernate.engine.spi.SessionImplementor;
import org.hibernate.internal.util.StringHelper;
import org.hibernate.internal.util.config.ConfigurationHelper; import org.hibernate.internal.util.config.ConfigurationHelper;
import org.hibernate.jdbc.AbstractReturningWork; import org.hibernate.jdbc.AbstractReturningWork;
import org.hibernate.jdbc.Work; import org.hibernate.jdbc.Work;
@ -178,6 +180,13 @@ public abstract class BaseCoreFunctionalTestCase extends BaseUnitTestCase {
configuration.setProperty( AvailableSettings.USE_NEW_ID_GENERATOR_MAPPINGS, "true" ); configuration.setProperty( AvailableSettings.USE_NEW_ID_GENERATOR_MAPPINGS, "true" );
if ( createSchema() ) { if ( createSchema() ) {
configuration.setProperty( Environment.HBM2DDL_AUTO, "create-drop" ); configuration.setProperty( Environment.HBM2DDL_AUTO, "create-drop" );
final String secondSchemaName = createSecondSchema();
if ( StringHelper.isNotEmpty( secondSchemaName ) ) {
if ( !( getDialect() instanceof H2Dialect ) ) {
throw new UnsupportedOperationException( "Only H2 dialect supports creation of second schema." );
}
Helper.createH2Schema( secondSchemaName, configuration );
}
} }
configuration.setProperty( Environment.DIALECT, getDialect().getClass().getName() ); configuration.setProperty( Environment.DIALECT, getDialect().getClass().getName() );
return configuration; return configuration;
@ -350,6 +359,14 @@ public abstract class BaseCoreFunctionalTestCase extends BaseUnitTestCase {
return true; return true;
} }
/**
* Feature supported only by H2 dialect.
* @return Provide not empty name to create second schema.
*/
protected String createSecondSchema() {
return null;
}
protected boolean rebuildSessionFactoryOnError() { protected boolean rebuildSessionFactoryOnError() {
return true; return true;
} }

View File

@ -25,10 +25,13 @@ package org.hibernate.testing.junit4;
import java.lang.annotation.Annotation; import java.lang.annotation.Annotation;
import java.lang.reflect.Method; import java.lang.reflect.Method;
import java.util.Map;
import org.junit.runners.model.FrameworkMethod; import org.junit.runners.model.FrameworkMethod;
import org.junit.runners.model.TestClass; import org.junit.runners.model.TestClass;
import org.hibernate.cfg.Configuration;
import org.hibernate.cfg.Environment;
import org.hibernate.testing.FailureExpected; import org.hibernate.testing.FailureExpected;
/** /**
@ -98,4 +101,23 @@ public class Helper {
.toString(); .toString();
} }
/**
* @see #createH2Schema(String, Map)
*/
public static void createH2Schema(String schemaName, Configuration cfg) {
createH2Schema( schemaName, cfg.getProperties() );
}
/**
* Create additional H2 schema.
*
* @param schemaName New schema name.
* @param settings Current settings.
*/
public static void createH2Schema(String schemaName, Map settings) {
settings.put(
Environment.URL,
settings.get( Environment.URL ) + ";INIT=CREATE SCHEMA IF NOT EXISTS " + schemaName
);
}
} }