HHH-11910 : SchemaUpdateTest fails on databases using case-insensitive identifiers

This commit is contained in:
Gail Badner 2017-08-04 16:37:34 -07:00
parent a8fcdffc50
commit cc342dc072
1 changed files with 29 additions and 4 deletions

View File

@ -33,20 +33,22 @@ import javax.persistence.PrimaryKeyJoinColumn;
import javax.persistence.Table; import javax.persistence.Table;
import org.hibernate.boot.MetadataSources; import org.hibernate.boot.MetadataSources;
import org.hibernate.boot.model.naming.Identifier;
import org.hibernate.boot.registry.StandardServiceRegistry; import org.hibernate.boot.registry.StandardServiceRegistry;
import org.hibernate.boot.registry.StandardServiceRegistryBuilder; import org.hibernate.boot.registry.StandardServiceRegistryBuilder;
import org.hibernate.boot.spi.MetadataImplementor; import org.hibernate.boot.spi.MetadataImplementor;
import org.hibernate.cfg.AvailableSettings; import org.hibernate.cfg.AvailableSettings;
import org.hibernate.dialect.Dialect; import org.hibernate.dialect.Dialect;
import org.hibernate.dialect.SQLServerDialect; import org.hibernate.dialect.SQLServerDialect;
import org.hibernate.engine.jdbc.env.spi.IdentifierHelper;
import org.hibernate.engine.jdbc.env.spi.JdbcEnvironment;
import org.hibernate.tool.hbm2ddl.SchemaExport; import org.hibernate.tool.hbm2ddl.SchemaExport;
import org.hibernate.tool.hbm2ddl.SchemaUpdate; import org.hibernate.tool.hbm2ddl.SchemaUpdate;
import org.hibernate.tool.hbm2ddl.SchemaValidator; import org.hibernate.tool.hbm2ddl.SchemaValidator;
import org.hibernate.tool.schema.JdbcMetadaAccessStrategy; import org.hibernate.tool.schema.JdbcMetadaAccessStrategy;
import org.hibernate.tool.schema.TargetType; import org.hibernate.tool.schema.TargetType;
import org.hibernate.testing.SkipForDialect; import org.hibernate.testing.SkipLog;
import org.hibernate.testing.junit4.BaseUnitTestCase;
import org.junit.After; import org.junit.After;
import org.junit.Before; import org.junit.Before;
import org.junit.Test; import org.junit.Test;
@ -62,6 +64,8 @@ import static org.junit.Assert.assertThat;
@RunWith(Parameterized.class) @RunWith(Parameterized.class)
public class SchemaUpdateTest { public class SchemaUpdateTest {
private boolean skipTest;
@Parameterized.Parameters @Parameterized.Parameters
public static Collection<String> parameters() { public static Collection<String> parameters() {
return Arrays.asList( return Arrays.asList(
@ -79,6 +83,9 @@ public class SchemaUpdateTest {
@Before @Before
public void setUp() throws IOException { public void setUp() throws IOException {
if(SQLServerDialect.class.isAssignableFrom( Dialect.getDialect().getClass() )) { if(SQLServerDialect.class.isAssignableFrom( Dialect.getDialect().getClass() )) {
// SQLServerDialect stores case-insensitive quoted identifiers in mixed case,
// so the checks at the end of this method won't work.
skipTest = true;
return; return;
} }
output = File.createTempFile( "update_script", ".sql" ); output = File.createTempFile( "update_script", ".sql" );
@ -87,6 +94,7 @@ public class SchemaUpdateTest {
.applySetting( AvailableSettings.KEYWORD_AUTO_QUOTING_ENABLED, "true" ) .applySetting( AvailableSettings.KEYWORD_AUTO_QUOTING_ENABLED, "true" )
.applySetting( AvailableSettings.HBM2DDL_JDBC_METADATA_EXTRACTOR_STRATEGY, jdbcMetadataExtractorStrategy ) .applySetting( AvailableSettings.HBM2DDL_JDBC_METADATA_EXTRACTOR_STRATEGY, jdbcMetadataExtractorStrategy )
.build(); .build();
final MetadataSources metadataSources = new MetadataSources( ssr ); final MetadataSources metadataSources = new MetadataSources( ssr );
metadataSources.addAnnotatedClass( LowercaseTableNameEntity.class ); metadataSources.addAnnotatedClass( LowercaseTableNameEntity.class );
metadataSources.addAnnotatedClass( TestEntity.class ); metadataSources.addAnnotatedClass( TestEntity.class );
@ -99,11 +107,26 @@ public class SchemaUpdateTest {
metadata = (MetadataImplementor) metadataSources.buildMetadata(); metadata = (MetadataImplementor) metadataSources.buildMetadata();
metadata.validate(); metadata.validate();
// Databases that use case-insensitive quoted identifiers need to be skipped.
// The following checks will work for checking those dialects that store case-insensitive
// quoted identifiers as upper-case or lower-case. It does not work for dialects that
// store case-insensitive identifiers in mixed case (like SQL Server).
final IdentifierHelper identifierHelper = ssr.getService( JdbcEnvironment.class ).getIdentifierHelper();
final String lowerCaseName = identifierHelper.toMetaDataObjectName( Identifier.toIdentifier( "testentity", true ) );
final String upperCaseName = identifierHelper.toMetaDataObjectName( Identifier.toIdentifier("TESTENTITY", true ) );
final String mixedCaseName = identifierHelper.toMetaDataObjectName( Identifier.toIdentifier("TESTentity", true ) );
if ( lowerCaseName.equals( upperCaseName ) ||
lowerCaseName.equals( mixedCaseName ) ||
upperCaseName.equals( mixedCaseName ) ) {
StandardServiceRegistryBuilder.destroy( ssr );
skipTest = true;
}
} }
@After @After
public void tearsDown() { public void tearsDown() {
if(SQLServerDialect.class.isAssignableFrom( Dialect.getDialect().getClass() )) { if ( skipTest ) {
return; return;
} }
new SchemaExport().setHaltOnError( true ) new SchemaExport().setHaltOnError( true )
@ -115,9 +138,11 @@ public class SchemaUpdateTest {
@Test @Test
public void testSchemaUpdateAndValidation() throws Exception { public void testSchemaUpdateAndValidation() throws Exception {
if(SQLServerDialect.class.isAssignableFrom( Dialect.getDialect().getClass() )) { if ( skipTest ) {
SkipLog.reportSkip( "skipping test because quoted names are not case-sensitive." );
return; return;
} }
new SchemaUpdate().setHaltOnError( true ) new SchemaUpdate().setHaltOnError( true )
.execute( EnumSet.of( TargetType.DATABASE ), metadata ); .execute( EnumSet.of( TargetType.DATABASE ), metadata );