HHH-10345 - HHH-3422 still a problem with oracle

(cherry picked from commit 90f4fd9d55)
This commit is contained in:
Steve Ebersole 2016-01-26 16:35:04 -06:00 committed by Gail Badner
parent d23eee23e5
commit 8af779ae62
1 changed files with 131 additions and 0 deletions

View File

@ -0,0 +1,131 @@
/*
* 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.type;
import java.sql.Blob;
import java.sql.Clob;
import javax.persistence.Entity;
import javax.persistence.Id;
import javax.persistence.Lob;
import org.hibernate.boot.MetadataSources;
import org.hibernate.boot.registry.StandardServiceRegistry;
import org.hibernate.boot.registry.StandardServiceRegistryBuilder;
import org.hibernate.boot.spi.MetadataImplementor;
import org.hibernate.cfg.AvailableSettings;
import org.hibernate.dialect.Dialect;
import org.hibernate.dialect.Oracle10gDialect;
import org.hibernate.dialect.Oracle12cDialect;
import org.hibernate.dialect.Oracle8iDialect;
import org.hibernate.dialect.Oracle9iDialect;
import org.hibernate.engine.jdbc.env.internal.JdbcEnvironmentInitiator;
import org.hibernate.engine.jdbc.env.spi.JdbcEnvironment;
import org.hibernate.mapping.PersistentClass;
import org.hibernate.type.BinaryType;
import org.hibernate.type.BlobType;
import org.hibernate.type.CharArrayType;
import org.hibernate.type.ClobType;
import org.hibernate.type.MaterializedBlobType;
import org.hibernate.type.MaterializedClobType;
import org.hibernate.type.PrimitiveCharacterArrayClobType;
import org.hibernate.type.Type;
import org.hibernate.testing.junit4.BaseUnitTestCase;
import org.junit.Test;
import static org.hamcrest.CoreMatchers.instanceOf;
import static org.junit.Assert.assertThat;
/**
* A test asserting LONG/LONGRAW versus CLOB/BLOB resolution for various Oracle Dialects
*
* @author Steve Ebersole
*/
public class OracleLongLobTypeTest extends BaseUnitTestCase {
@Test
public void testOracle8() {
check( Oracle8iDialect.class, Primitives.class, BinaryType.class, CharArrayType.class );
check( Oracle8iDialect.class, LobPrimitives.class, MaterializedBlobType.class, PrimitiveCharacterArrayClobType.class );
check( Oracle8iDialect.class, LobLocators.class, BlobType.class, ClobType.class );
}
@Test
public void testOracle9() {
check( Oracle9iDialect.class, Primitives.class, BinaryType.class, CharArrayType.class );
check( Oracle9iDialect.class, LobPrimitives.class, MaterializedBlobType.class, PrimitiveCharacterArrayClobType.class );
check( Oracle9iDialect.class, LobLocators.class, BlobType.class, ClobType.class );
}
@Test
public void testOracle10() {
check( Oracle10gDialect.class, Primitives.class, BinaryType.class, CharArrayType.class );
check( Oracle10gDialect.class, LobPrimitives.class, MaterializedBlobType.class, PrimitiveCharacterArrayClobType.class );
check( Oracle10gDialect.class, LobLocators.class, BlobType.class, ClobType.class );
}
@Test
public void testOracle12() {
check( Oracle12cDialect.class, Primitives.class, BinaryType.class, CharArrayType.class );
check( Oracle12cDialect.class, LobPrimitives.class, MaterializedBlobType.class, PrimitiveCharacterArrayClobType.class );
check( Oracle12cDialect.class, LobLocators.class, BlobType.class, ClobType.class );
}
private void check(
Class<? extends Dialect> dialectClass,
Class entityClass,
Class<? extends Type> binaryTypeClass,
Class<? extends Type> charTypeClass) {
StandardServiceRegistry ssr = new StandardServiceRegistryBuilder()
.applySetting( AvailableSettings.DIALECT, dialectClass.getName() )
.applySetting( "hibernate.temp.use_jdbc_metadata_defaults", false )
.build();
try {
final MetadataImplementor mappings = (MetadataImplementor) new MetadataSources( ssr )
.addAnnotatedClass( entityClass )
.buildMetadata();
mappings.validate();
final PersistentClass entityBinding = mappings.getEntityBinding( entityClass.getName() );
assertThat( entityBinding.getProperty( "binaryData" ).getType(), instanceOf( binaryTypeClass ) );
assertThat( entityBinding.getProperty( "characterData" ).getType(), instanceOf( charTypeClass ) );
}
finally {
StandardServiceRegistryBuilder.destroy( ssr );
}
}
@Entity
public static class Primitives {
@Id
public Integer id;
public byte[] binaryData;
public char[] characterData;
}
@Entity
public static class LobPrimitives {
@Id
public Integer id;
@Lob
public byte[] binaryData;
@Lob
public char[] characterData;
}
@Entity
public static class LobLocators {
@Id
public Integer id;
@Lob
public Blob binaryData;
@Lob
public Clob characterData;
}
}