HHH-10691 - Fix tests failing when switching to PostgreSQL
HHH-10696 - Add a new CatalogFilterTest
This commit is contained in:
parent
a8deb5f1e0
commit
da347c6d0c
|
@ -16,6 +16,7 @@ import javax.persistence.Id;
|
||||||
import javax.persistence.Lob;
|
import javax.persistence.Lob;
|
||||||
|
|
||||||
import org.hibernate.Session;
|
import org.hibernate.Session;
|
||||||
|
import org.hibernate.engine.jdbc.BlobProxy;
|
||||||
import org.hibernate.jpa.test.BaseEntityManagerFunctionalTestCase;
|
import org.hibernate.jpa.test.BaseEntityManagerFunctionalTestCase;
|
||||||
|
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
@ -49,8 +50,7 @@ public class BlobTest extends BaseEntityManagerFunctionalTestCase {
|
||||||
product.setName( "Mobile phone" );
|
product.setName( "Mobile phone" );
|
||||||
|
|
||||||
session.doWork( connection -> {
|
session.doWork( connection -> {
|
||||||
product.setImage( connection.createBlob() );
|
product.setImage( BlobProxy.generateProxy( image ) );
|
||||||
product.getImage().setBytes( 1, image );
|
|
||||||
} );
|
} );
|
||||||
|
|
||||||
entityManager.persist( product );
|
entityManager.persist( product );
|
||||||
|
|
|
@ -16,6 +16,7 @@ import javax.persistence.Id;
|
||||||
import javax.persistence.Lob;
|
import javax.persistence.Lob;
|
||||||
|
|
||||||
import org.hibernate.Session;
|
import org.hibernate.Session;
|
||||||
|
import org.hibernate.engine.jdbc.ClobProxy;
|
||||||
import org.hibernate.jpa.test.BaseEntityManagerFunctionalTestCase;
|
import org.hibernate.jpa.test.BaseEntityManagerFunctionalTestCase;
|
||||||
|
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
@ -49,8 +50,7 @@ public class ClobTest extends BaseEntityManagerFunctionalTestCase {
|
||||||
product.setName( "Mobile phone" );
|
product.setName( "Mobile phone" );
|
||||||
|
|
||||||
session.doWork( connection -> {
|
session.doWork( connection -> {
|
||||||
product.setWarranty( connection.createClob() );
|
product.setWarranty( ClobProxy.generateProxy( warranty ) );
|
||||||
product.getWarranty().setString( 1, warranty );
|
|
||||||
} );
|
} );
|
||||||
|
|
||||||
entityManager.persist( product );
|
entityManager.persist( product );
|
||||||
|
|
|
@ -11,8 +11,11 @@ import javax.persistence.Id;
|
||||||
import javax.persistence.Lob;
|
import javax.persistence.Lob;
|
||||||
|
|
||||||
import org.hibernate.annotations.Nationalized;
|
import org.hibernate.annotations.Nationalized;
|
||||||
|
import org.hibernate.dialect.MySQL5Dialect;
|
||||||
|
import org.hibernate.dialect.PostgreSQL81Dialect;
|
||||||
import org.hibernate.jpa.test.BaseEntityManagerFunctionalTestCase;
|
import org.hibernate.jpa.test.BaseEntityManagerFunctionalTestCase;
|
||||||
|
|
||||||
|
import org.hibernate.testing.SkipForDialect;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
import static org.hibernate.userguide.util.TransactionUtil.doInJPA;
|
import static org.hibernate.userguide.util.TransactionUtil.doInJPA;
|
||||||
|
@ -21,6 +24,13 @@ import static org.junit.Assert.assertArrayEquals;
|
||||||
/**
|
/**
|
||||||
* @author Vlad Mihalcea
|
* @author Vlad Mihalcea
|
||||||
*/
|
*/
|
||||||
|
@SkipForDialect(
|
||||||
|
value = {
|
||||||
|
PostgreSQL81Dialect.class,
|
||||||
|
MySQL5Dialect.class
|
||||||
|
},
|
||||||
|
comment = "@see https://hibernate.atlassian.net/browse/HHH-10693 and https://hibernate.atlassian.net/browse/HHH-10695"
|
||||||
|
)
|
||||||
public class NClobCharArrayTest extends BaseEntityManagerFunctionalTestCase {
|
public class NClobCharArrayTest extends BaseEntityManagerFunctionalTestCase {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -11,8 +11,11 @@ import javax.persistence.Id;
|
||||||
import javax.persistence.Lob;
|
import javax.persistence.Lob;
|
||||||
|
|
||||||
import org.hibernate.annotations.Nationalized;
|
import org.hibernate.annotations.Nationalized;
|
||||||
|
import org.hibernate.dialect.MySQL5Dialect;
|
||||||
|
import org.hibernate.dialect.PostgreSQL81Dialect;
|
||||||
import org.hibernate.jpa.test.BaseEntityManagerFunctionalTestCase;
|
import org.hibernate.jpa.test.BaseEntityManagerFunctionalTestCase;
|
||||||
|
|
||||||
|
import org.hibernate.testing.SkipForDialect;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
import static org.hibernate.userguide.util.TransactionUtil.doInJPA;
|
import static org.hibernate.userguide.util.TransactionUtil.doInJPA;
|
||||||
|
@ -21,6 +24,13 @@ import static org.junit.Assert.assertEquals;
|
||||||
/**
|
/**
|
||||||
* @author Vlad Mihalcea
|
* @author Vlad Mihalcea
|
||||||
*/
|
*/
|
||||||
|
@SkipForDialect(
|
||||||
|
value = {
|
||||||
|
PostgreSQL81Dialect.class,
|
||||||
|
MySQL5Dialect.class
|
||||||
|
},
|
||||||
|
comment = "@see https://hibernate.atlassian.net/browse/HHH-10693 and https://hibernate.atlassian.net/browse/HHH-10695"
|
||||||
|
)
|
||||||
public class NClobStringTest extends BaseEntityManagerFunctionalTestCase {
|
public class NClobStringTest extends BaseEntityManagerFunctionalTestCase {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -17,8 +17,11 @@ import javax.persistence.Lob;
|
||||||
|
|
||||||
import org.hibernate.Session;
|
import org.hibernate.Session;
|
||||||
import org.hibernate.annotations.Nationalized;
|
import org.hibernate.annotations.Nationalized;
|
||||||
|
import org.hibernate.dialect.MySQL5Dialect;
|
||||||
|
import org.hibernate.dialect.PostgreSQL81Dialect;
|
||||||
import org.hibernate.jpa.test.BaseEntityManagerFunctionalTestCase;
|
import org.hibernate.jpa.test.BaseEntityManagerFunctionalTestCase;
|
||||||
|
|
||||||
|
import org.hibernate.testing.SkipForDialect;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
import static org.hibernate.userguide.util.TransactionUtil.doInJPA;
|
import static org.hibernate.userguide.util.TransactionUtil.doInJPA;
|
||||||
|
@ -28,6 +31,13 @@ import static org.junit.Assert.fail;
|
||||||
/**
|
/**
|
||||||
* @author Vlad Mihalcea
|
* @author Vlad Mihalcea
|
||||||
*/
|
*/
|
||||||
|
@SkipForDialect(
|
||||||
|
value = {
|
||||||
|
PostgreSQL81Dialect.class,
|
||||||
|
MySQL5Dialect.class
|
||||||
|
},
|
||||||
|
comment = "@see https://hibernate.atlassian.net/browse/HHH-10693 and https://hibernate.atlassian.net/browse/HHH-10695"
|
||||||
|
)
|
||||||
public class NClobTest extends BaseEntityManagerFunctionalTestCase {
|
public class NClobTest extends BaseEntityManagerFunctionalTestCase {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -10,8 +10,10 @@ import javax.persistence.Entity;
|
||||||
import javax.persistence.Id;
|
import javax.persistence.Id;
|
||||||
|
|
||||||
import org.hibernate.annotations.Nationalized;
|
import org.hibernate.annotations.Nationalized;
|
||||||
|
import org.hibernate.dialect.PostgreSQL81Dialect;
|
||||||
import org.hibernate.jpa.test.BaseEntityManagerFunctionalTestCase;
|
import org.hibernate.jpa.test.BaseEntityManagerFunctionalTestCase;
|
||||||
|
|
||||||
|
import org.hibernate.testing.SkipForDialect;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
import static org.hibernate.userguide.util.TransactionUtil.doInJPA;
|
import static org.hibernate.userguide.util.TransactionUtil.doInJPA;
|
||||||
|
@ -20,6 +22,12 @@ import static org.junit.Assert.assertEquals;
|
||||||
/**
|
/**
|
||||||
* @author Vlad Mihalcea
|
* @author Vlad Mihalcea
|
||||||
*/
|
*/
|
||||||
|
@SkipForDialect(
|
||||||
|
value = {
|
||||||
|
PostgreSQL81Dialect.class
|
||||||
|
},
|
||||||
|
comment = "@see https://hibernate.atlassian.net/browse/HHH-10693"
|
||||||
|
)
|
||||||
public class NationalizedTest extends BaseEntityManagerFunctionalTestCase {
|
public class NationalizedTest extends BaseEntityManagerFunctionalTestCase {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -7,10 +7,14 @@
|
||||||
package org.hibernate.userguide.multitenancy;
|
package org.hibernate.userguide.multitenancy;
|
||||||
|
|
||||||
import org.hibernate.MultiTenancyStrategy;
|
import org.hibernate.MultiTenancyStrategy;
|
||||||
|
import org.hibernate.dialect.H2Dialect;
|
||||||
|
|
||||||
|
import org.hibernate.testing.RequiresDialect;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author Vlad Mihalcea
|
* @author Vlad Mihalcea
|
||||||
*/
|
*/
|
||||||
|
@RequiresDialect( value = H2Dialect.class)
|
||||||
public class DatabaseMultiTenancyTest extends AbstractMultiTenancyTest {
|
public class DatabaseMultiTenancyTest extends AbstractMultiTenancyTest {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -7,10 +7,14 @@
|
||||||
package org.hibernate.userguide.multitenancy;
|
package org.hibernate.userguide.multitenancy;
|
||||||
|
|
||||||
import org.hibernate.MultiTenancyStrategy;
|
import org.hibernate.MultiTenancyStrategy;
|
||||||
|
import org.hibernate.dialect.H2Dialect;
|
||||||
|
|
||||||
|
import org.hibernate.testing.RequiresDialect;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author Vlad Mihalcea
|
* @author Vlad Mihalcea
|
||||||
*/
|
*/
|
||||||
|
@RequiresDialect( value = H2Dialect.class)
|
||||||
public class SchemaMultiTenancyTest extends AbstractMultiTenancyTest {
|
public class SchemaMultiTenancyTest extends AbstractMultiTenancyTest {
|
||||||
|
|
||||||
public static final String SCHEMA_TOKEN = ";INIT=CREATE SCHEMA IF NOT EXISTS %1$s\\;SET SCHEMA %1$s";
|
public static final String SCHEMA_TOKEN = ";INIT=CREATE SCHEMA IF NOT EXISTS %1$s\\;SET SCHEMA %1$s";
|
||||||
|
|
|
@ -34,9 +34,14 @@ public class PersisterClassProviderTest extends BaseUnitTestCase {
|
||||||
.applySettings( cfg.getProperties() )
|
.applySettings( cfg.getProperties() )
|
||||||
.build();
|
.build();
|
||||||
//no exception as the GoofyPersisterClassProvider is not set
|
//no exception as the GoofyPersisterClassProvider is not set
|
||||||
SessionFactory sessionFactory = cfg.buildSessionFactory( serviceRegistry );
|
SessionFactory sessionFactory;
|
||||||
sessionFactory.close();
|
try {
|
||||||
StandardServiceRegistryBuilder.destroy( serviceRegistry );
|
sessionFactory = cfg.buildSessionFactory( serviceRegistry );
|
||||||
|
sessionFactory.close();
|
||||||
|
}
|
||||||
|
finally {
|
||||||
|
StandardServiceRegistryBuilder.destroy( serviceRegistry );
|
||||||
|
}
|
||||||
|
|
||||||
serviceRegistry = new StandardServiceRegistryBuilder()
|
serviceRegistry = new StandardServiceRegistryBuilder()
|
||||||
.applySettings( cfg.getProperties() )
|
.applySettings( cfg.getProperties() )
|
||||||
|
|
|
@ -22,6 +22,7 @@ import org.hibernate.cfg.AvailableSettings;
|
||||||
import org.hibernate.dialect.Dialect;
|
import org.hibernate.dialect.Dialect;
|
||||||
import org.hibernate.dialect.H2Dialect;
|
import org.hibernate.dialect.H2Dialect;
|
||||||
import org.hibernate.dialect.MySQL5Dialect;
|
import org.hibernate.dialect.MySQL5Dialect;
|
||||||
|
import org.hibernate.dialect.PostgreSQL81Dialect;
|
||||||
import org.hibernate.dialect.PostgreSQL94Dialect;
|
import org.hibernate.dialect.PostgreSQL94Dialect;
|
||||||
import org.hibernate.mapping.PersistentClass;
|
import org.hibernate.mapping.PersistentClass;
|
||||||
import org.hibernate.tool.schema.Action;
|
import org.hibernate.tool.schema.Action;
|
||||||
|
@ -29,6 +30,7 @@ import org.hibernate.type.PostgresUUIDType;
|
||||||
import org.hibernate.type.Type;
|
import org.hibernate.type.Type;
|
||||||
import org.hibernate.type.UUIDBinaryType;
|
import org.hibernate.type.UUIDBinaryType;
|
||||||
|
|
||||||
|
import org.hibernate.testing.SkipForDialect;
|
||||||
import org.hibernate.testing.TestForIssue;
|
import org.hibernate.testing.TestForIssue;
|
||||||
import org.hibernate.testing.junit4.BaseUnitTestCase;
|
import org.hibernate.testing.junit4.BaseUnitTestCase;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
@ -40,6 +42,7 @@ import static org.junit.Assert.assertThat;
|
||||||
* @author Steve Ebersole
|
* @author Steve Ebersole
|
||||||
*/
|
*/
|
||||||
public class UUIDBasedIdInterpretationTest extends BaseUnitTestCase {
|
public class UUIDBasedIdInterpretationTest extends BaseUnitTestCase {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@TestForIssue( jiraKey = "HHH-10564")
|
@TestForIssue( jiraKey = "HHH-10564")
|
||||||
public void testH2() {
|
public void testH2() {
|
||||||
|
@ -100,6 +103,7 @@ public class UUIDBasedIdInterpretationTest extends BaseUnitTestCase {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@TestForIssue( jiraKey = "HHH-10564")
|
@TestForIssue( jiraKey = "HHH-10564")
|
||||||
|
@SkipForDialect(PostgreSQL81Dialect.class)
|
||||||
public void testBinaryRuntimeUsage() {
|
public void testBinaryRuntimeUsage() {
|
||||||
StandardServiceRegistry ssr = buildStandardServiceRegistry( H2Dialect.class, true );
|
StandardServiceRegistry ssr = buildStandardServiceRegistry( H2Dialect.class, true );
|
||||||
try {
|
try {
|
||||||
|
|
|
@ -0,0 +1,242 @@
|
||||||
|
package org.hibernate.test.schemafilter;
|
||||||
|
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.HashSet;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.Set;
|
||||||
|
import javax.persistence.Entity;
|
||||||
|
import javax.persistence.Id;
|
||||||
|
|
||||||
|
import org.hibernate.boot.Metadata;
|
||||||
|
import org.hibernate.boot.MetadataSources;
|
||||||
|
import org.hibernate.boot.model.naming.Identifier;
|
||||||
|
import org.hibernate.boot.model.relational.Namespace;
|
||||||
|
import org.hibernate.boot.model.relational.Sequence;
|
||||||
|
import org.hibernate.cfg.AvailableSettings;
|
||||||
|
import org.hibernate.cfg.Environment;
|
||||||
|
import org.hibernate.dialect.SQLServerDialect;
|
||||||
|
import org.hibernate.mapping.Table;
|
||||||
|
import org.hibernate.service.ServiceRegistry;
|
||||||
|
import org.hibernate.tool.schema.internal.DefaultSchemaFilter;
|
||||||
|
import org.hibernate.tool.schema.internal.SchemaCreatorImpl;
|
||||||
|
import org.hibernate.tool.schema.internal.SchemaDropperImpl;
|
||||||
|
import org.hibernate.tool.schema.spi.SchemaFilter;
|
||||||
|
|
||||||
|
import org.hibernate.testing.DialectChecks;
|
||||||
|
import org.hibernate.testing.RequiresDialectFeature;
|
||||||
|
import org.hibernate.testing.ServiceRegistryBuilder;
|
||||||
|
import org.hibernate.testing.junit4.BaseUnitTestCase;
|
||||||
|
import org.junit.Assert;
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
|
import org.hamcrest.BaseMatcher;
|
||||||
|
import org.hamcrest.Description;
|
||||||
|
|
||||||
|
import static org.hibernate.test.schemafilter.RecordingTarget.Category.TABLE_CREATE;
|
||||||
|
import static org.hibernate.test.schemafilter.RecordingTarget.Category.TABLE_DROP;
|
||||||
|
|
||||||
|
@SuppressWarnings({"rawtypes", "unchecked"})
|
||||||
|
@RequiresDialectFeature( value = {DialectChecks.SupportCatalogCreation.class})
|
||||||
|
public class CatalogFilterTest extends BaseUnitTestCase {
|
||||||
|
|
||||||
|
private final ServiceRegistry serviceRegistry;
|
||||||
|
private final Metadata metadata;
|
||||||
|
|
||||||
|
public CatalogFilterTest() {
|
||||||
|
Map settings = new HashMap();
|
||||||
|
settings.putAll( Environment.getProperties() );
|
||||||
|
settings.put( AvailableSettings.DIALECT, SQLServerDialect.class.getName() );
|
||||||
|
settings.put( AvailableSettings.FORMAT_SQL, false );
|
||||||
|
|
||||||
|
this.serviceRegistry = ServiceRegistryBuilder.buildServiceRegistry( settings );
|
||||||
|
|
||||||
|
MetadataSources ms = new MetadataSources( serviceRegistry );
|
||||||
|
ms.addAnnotatedClass( CatalogNoneEntity0.class );
|
||||||
|
ms.addAnnotatedClass( Catalog1Entity1.class );
|
||||||
|
ms.addAnnotatedClass( Catalog1Entity2.class );
|
||||||
|
ms.addAnnotatedClass( Catalog2Entity3.class );
|
||||||
|
ms.addAnnotatedClass( Catalog2Entity4.class );
|
||||||
|
this.metadata = ms.buildMetadata();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void createCatalog_unfiltered() {
|
||||||
|
RecordingTarget target = doCreation( new DefaultSchemaFilter() );
|
||||||
|
|
||||||
|
Assert.assertThat( target.getActions( TABLE_CREATE ), containsExactly(
|
||||||
|
"the_entity_0",
|
||||||
|
"the_catalog_1.the_entity_1",
|
||||||
|
"the_catalog_1.the_entity_2",
|
||||||
|
"the_catalog_2.the_entity_3",
|
||||||
|
"the_catalog_2.the_entity_4"
|
||||||
|
) );
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void createCatalog_filtered() {
|
||||||
|
RecordingTarget target = doCreation( new TestSchemaFilter() );
|
||||||
|
|
||||||
|
Assert.assertThat(
|
||||||
|
target.getActions( TABLE_CREATE ),
|
||||||
|
containsExactly( "the_entity_0", "the_catalog_1.the_entity_1" )
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void dropCatalog_unfiltered() {
|
||||||
|
RecordingTarget target = doDrop( new DefaultSchemaFilter() );
|
||||||
|
|
||||||
|
Assert.assertThat( target.getActions( TABLE_DROP ), containsExactly(
|
||||||
|
"the_entity_0",
|
||||||
|
"the_catalog_1.the_entity_1",
|
||||||
|
"the_catalog_1.the_entity_2",
|
||||||
|
"the_catalog_2.the_entity_3",
|
||||||
|
"the_catalog_2.the_entity_4"
|
||||||
|
) );
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void dropCatalog_filtered() {
|
||||||
|
RecordingTarget target = doDrop( new TestSchemaFilter() );
|
||||||
|
|
||||||
|
Assert.assertThat(
|
||||||
|
target.getActions( TABLE_DROP ),
|
||||||
|
containsExactly( "the_entity_0", "the_catalog_1.the_entity_1" )
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
private RecordingTarget doCreation(SchemaFilter filter) {
|
||||||
|
RecordingTarget target = new RecordingTarget();
|
||||||
|
new SchemaCreatorImpl( serviceRegistry, filter ).doCreation( metadata, true, target );
|
||||||
|
return target;
|
||||||
|
}
|
||||||
|
|
||||||
|
private RecordingTarget doDrop(SchemaFilter filter) {
|
||||||
|
RecordingTarget target = new RecordingTarget();
|
||||||
|
new SchemaDropperImpl( serviceRegistry, filter ).doDrop( metadata, true, target );
|
||||||
|
return target;
|
||||||
|
}
|
||||||
|
|
||||||
|
private BaseMatcher<Set<String>> containsExactly(Object... expected) {
|
||||||
|
return containsExactly( new HashSet( Arrays.asList( expected ) ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
private BaseMatcher<Set<String>> containsExactly(final Set expected) {
|
||||||
|
return new BaseMatcher<Set<String>>() {
|
||||||
|
@Override
|
||||||
|
public boolean matches(Object item) {
|
||||||
|
Set set = (Set) item;
|
||||||
|
return set.size() == expected.size()
|
||||||
|
&& set.containsAll( expected );
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void describeTo(Description description) {
|
||||||
|
description.appendText( "Is set containing exactly " + expected );
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
private static class TestSchemaFilter implements SchemaFilter {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean includeNamespace(Namespace namespace) {
|
||||||
|
// exclude schema "the_catalog_2"
|
||||||
|
Identifier identifier = namespace.getName().getCatalog();
|
||||||
|
return identifier == null || !"the_catalog_2".equals( identifier.getText() );
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean includeTable(Table table) {
|
||||||
|
// exclude table "the_entity_2"
|
||||||
|
return !"the_entity_2".equals( table.getName() );
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean includeSequence(Sequence sequence) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Entity
|
||||||
|
@javax.persistence.Table(name = "the_entity_1", catalog = "the_catalog_1")
|
||||||
|
public static class Catalog1Entity1 {
|
||||||
|
|
||||||
|
@Id
|
||||||
|
private long id;
|
||||||
|
|
||||||
|
public long getId() {
|
||||||
|
return id;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setId( long id ) {
|
||||||
|
this.id = id;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Entity
|
||||||
|
@javax.persistence.Table(name = "the_entity_2", catalog = "the_catalog_1")
|
||||||
|
public static class Catalog1Entity2 {
|
||||||
|
|
||||||
|
@Id
|
||||||
|
private long id;
|
||||||
|
|
||||||
|
public long getId() {
|
||||||
|
return id;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setId( long id ) {
|
||||||
|
this.id = id;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Entity
|
||||||
|
@javax.persistence.Table(name = "the_entity_3", catalog = "the_catalog_2")
|
||||||
|
public static class Catalog2Entity3 {
|
||||||
|
|
||||||
|
@Id
|
||||||
|
private long id;
|
||||||
|
|
||||||
|
public long getId() {
|
||||||
|
return id;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setId( long id ) {
|
||||||
|
this.id = id;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Entity
|
||||||
|
@javax.persistence.Table(name = "the_entity_4", catalog = "the_catalog_2")
|
||||||
|
public static class Catalog2Entity4 {
|
||||||
|
|
||||||
|
@Id
|
||||||
|
private long id;
|
||||||
|
|
||||||
|
public long getId() {
|
||||||
|
return id;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setId( long id ) {
|
||||||
|
this.id = id;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Entity
|
||||||
|
@javax.persistence.Table(name = "the_entity_0")
|
||||||
|
public static class CatalogNoneEntity0 {
|
||||||
|
|
||||||
|
@Id
|
||||||
|
private long id;
|
||||||
|
|
||||||
|
public long getId() {
|
||||||
|
return id;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setId( long id ) {
|
||||||
|
this.id = id;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,21 +0,0 @@
|
||||||
package org.hibernate.test.schemafilter;
|
|
||||||
|
|
||||||
import javax.persistence.Entity;
|
|
||||||
import javax.persistence.Id;
|
|
||||||
import javax.persistence.Table;
|
|
||||||
|
|
||||||
@Entity
|
|
||||||
@Table(name = "the_entity_1", schema = "the_schema_1")
|
|
||||||
public class Schema1Entity1 {
|
|
||||||
|
|
||||||
@Id
|
|
||||||
private long id;
|
|
||||||
|
|
||||||
public long getId() {
|
|
||||||
return id;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setId( long id ) {
|
|
||||||
this.id = id;
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,21 +0,0 @@
|
||||||
package org.hibernate.test.schemafilter;
|
|
||||||
|
|
||||||
import javax.persistence.Entity;
|
|
||||||
import javax.persistence.Id;
|
|
||||||
import javax.persistence.Table;
|
|
||||||
|
|
||||||
@Entity
|
|
||||||
@Table(name = "the_entity_2", schema = "the_schema_1")
|
|
||||||
public class Schema1Entity2 {
|
|
||||||
|
|
||||||
@Id
|
|
||||||
private long id;
|
|
||||||
|
|
||||||
public long getId() {
|
|
||||||
return id;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setId( long id ) {
|
|
||||||
this.id = id;
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,21 +0,0 @@
|
||||||
package org.hibernate.test.schemafilter;
|
|
||||||
|
|
||||||
import javax.persistence.Entity;
|
|
||||||
import javax.persistence.Id;
|
|
||||||
import javax.persistence.Table;
|
|
||||||
|
|
||||||
@Entity
|
|
||||||
@Table(name = "the_entity_3", schema = "the_schema_2")
|
|
||||||
public class Schema2Entity3 {
|
|
||||||
|
|
||||||
@Id
|
|
||||||
private long id;
|
|
||||||
|
|
||||||
public long getId() {
|
|
||||||
return id;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setId( long id ) {
|
|
||||||
this.id = id;
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,21 +0,0 @@
|
||||||
package org.hibernate.test.schemafilter;
|
|
||||||
|
|
||||||
import javax.persistence.Entity;
|
|
||||||
import javax.persistence.Id;
|
|
||||||
import javax.persistence.Table;
|
|
||||||
|
|
||||||
@Entity
|
|
||||||
@Table(name = "the_entity_4", schema = "the_schema_2")
|
|
||||||
public class Schema2Entity4 {
|
|
||||||
|
|
||||||
@Id
|
|
||||||
private long id;
|
|
||||||
|
|
||||||
public long getId() {
|
|
||||||
return id;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setId( long id ) {
|
|
||||||
this.id = id;
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -6,6 +6,9 @@ import java.util.HashSet;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
|
||||||
|
import javax.persistence.Entity;
|
||||||
|
import javax.persistence.Id;
|
||||||
|
|
||||||
import org.hibernate.boot.Metadata;
|
import org.hibernate.boot.Metadata;
|
||||||
import org.hibernate.boot.MetadataSources;
|
import org.hibernate.boot.MetadataSources;
|
||||||
import org.hibernate.boot.model.naming.Identifier;
|
import org.hibernate.boot.model.naming.Identifier;
|
||||||
|
@ -21,6 +24,8 @@ import org.hibernate.tool.schema.internal.SchemaCreatorImpl;
|
||||||
import org.hibernate.tool.schema.internal.SchemaDropperImpl;
|
import org.hibernate.tool.schema.internal.SchemaDropperImpl;
|
||||||
import org.hibernate.tool.schema.spi.SchemaFilter;
|
import org.hibernate.tool.schema.spi.SchemaFilter;
|
||||||
|
|
||||||
|
import org.hibernate.testing.DialectChecks;
|
||||||
|
import org.hibernate.testing.RequiresDialectFeature;
|
||||||
import org.hibernate.testing.ServiceRegistryBuilder;
|
import org.hibernate.testing.ServiceRegistryBuilder;
|
||||||
import org.hibernate.testing.TestForIssue;
|
import org.hibernate.testing.TestForIssue;
|
||||||
import org.hibernate.testing.junit4.BaseUnitTestCase;
|
import org.hibernate.testing.junit4.BaseUnitTestCase;
|
||||||
|
@ -37,6 +42,7 @@ import static org.hibernate.test.schemafilter.RecordingTarget.Category.TABLE_DRO
|
||||||
|
|
||||||
@TestForIssue(jiraKey = "HHH-9876")
|
@TestForIssue(jiraKey = "HHH-9876")
|
||||||
@SuppressWarnings({"rawtypes", "unchecked"})
|
@SuppressWarnings({"rawtypes", "unchecked"})
|
||||||
|
@RequiresDialectFeature( value = {DialectChecks.SupportSchemaCreation.class})
|
||||||
public class SchemaFilterTest extends BaseUnitTestCase {
|
public class SchemaFilterTest extends BaseUnitTestCase {
|
||||||
|
|
||||||
private final ServiceRegistry serviceRegistry;
|
private final ServiceRegistry serviceRegistry;
|
||||||
|
@ -164,4 +170,85 @@ public class SchemaFilterTest extends BaseUnitTestCase {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Entity
|
||||||
|
@javax.persistence.Table(name = "the_entity_1", schema = "the_schema_1")
|
||||||
|
public static class Schema1Entity1 {
|
||||||
|
|
||||||
|
@Id
|
||||||
|
private long id;
|
||||||
|
|
||||||
|
public long getId() {
|
||||||
|
return id;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setId( long id ) {
|
||||||
|
this.id = id;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Entity
|
||||||
|
@javax.persistence.Table(name = "the_entity_2", schema = "the_schema_1")
|
||||||
|
public static class Schema1Entity2 {
|
||||||
|
|
||||||
|
@Id
|
||||||
|
private long id;
|
||||||
|
|
||||||
|
public long getId() {
|
||||||
|
return id;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setId( long id ) {
|
||||||
|
this.id = id;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Entity
|
||||||
|
@javax.persistence.Table(name = "the_entity_3", schema = "the_schema_2")
|
||||||
|
public static class Schema2Entity3 {
|
||||||
|
|
||||||
|
@Id
|
||||||
|
private long id;
|
||||||
|
|
||||||
|
public long getId() {
|
||||||
|
return id;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setId( long id ) {
|
||||||
|
this.id = id;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Entity
|
||||||
|
@javax.persistence.Table(name = "the_entity_4", schema = "the_schema_2")
|
||||||
|
public static class Schema2Entity4 {
|
||||||
|
|
||||||
|
@Id
|
||||||
|
private long id;
|
||||||
|
|
||||||
|
public long getId() {
|
||||||
|
return id;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setId( long id ) {
|
||||||
|
this.id = id;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Entity
|
||||||
|
@javax.persistence.Table(name = "the_entity_0")
|
||||||
|
public static class SchemaNoneEntity0 {
|
||||||
|
|
||||||
|
@Id
|
||||||
|
private long id;
|
||||||
|
|
||||||
|
public long getId() {
|
||||||
|
return id;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setId( long id ) {
|
||||||
|
this.id = id;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,22 +0,0 @@
|
||||||
package org.hibernate.test.schemafilter;
|
|
||||||
|
|
||||||
import javax.persistence.Entity;
|
|
||||||
import javax.persistence.Id;
|
|
||||||
import javax.persistence.Table;
|
|
||||||
|
|
||||||
@Entity
|
|
||||||
@Table(name = "the_entity_0")
|
|
||||||
public class SchemaNoneEntity0 {
|
|
||||||
|
|
||||||
@Id
|
|
||||||
private long id;
|
|
||||||
|
|
||||||
public long getId() {
|
|
||||||
return id;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setId( long id ) {
|
|
||||||
this.id = id;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
|
@ -3,6 +3,7 @@ package org.hibernate.test.schemaupdate;
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.nio.file.Files;
|
import java.nio.file.Files;
|
||||||
import java.util.EnumSet;
|
import java.util.EnumSet;
|
||||||
|
import java.util.regex.Pattern;
|
||||||
import javax.persistence.Entity;
|
import javax.persistence.Entity;
|
||||||
import javax.persistence.Id;
|
import javax.persistence.Id;
|
||||||
import javax.persistence.Table;
|
import javax.persistence.Table;
|
||||||
|
@ -12,7 +13,6 @@ 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.Environment;
|
import org.hibernate.cfg.Environment;
|
||||||
|
|
||||||
import org.hibernate.dialect.H2Dialect;
|
import org.hibernate.dialect.H2Dialect;
|
||||||
import org.hibernate.tool.hbm2ddl.SchemaUpdate;
|
import org.hibernate.tool.hbm2ddl.SchemaUpdate;
|
||||||
import org.hibernate.tool.schema.TargetType;
|
import org.hibernate.tool.schema.TargetType;
|
||||||
|
@ -30,10 +30,10 @@ import org.junit.Test;
|
||||||
public class SchemaUpdateFormatterTest {
|
public class SchemaUpdateFormatterTest {
|
||||||
|
|
||||||
private static final String AFTER_FORMAT =
|
private static final String AFTER_FORMAT =
|
||||||
"\n create table test_entity (\n" +
|
"\n\\s+create table test_entity \\(\n" +
|
||||||
" field varchar(255) not null,\n" +
|
"\\s+field varchar\\(255\\) not null,\n" +
|
||||||
" primary key (field)\n" +
|
"\\s+primary key \\(field\\)\n" +
|
||||||
" );\n";
|
"\\s+\\).*?;\n";
|
||||||
private static final String DELIMITER = ";";
|
private static final String DELIMITER = ";";
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@ -63,7 +63,7 @@ public class SchemaUpdateFormatterTest {
|
||||||
//On Windows, \r\n would become \n\n, so we eliminate duplicates
|
//On Windows, \r\n would become \n\n, so we eliminate duplicates
|
||||||
outputContent = outputContent.replaceAll( "\n\n", "\n");
|
outputContent = outputContent.replaceAll( "\n\n", "\n");
|
||||||
|
|
||||||
Assert.assertEquals( AFTER_FORMAT, outputContent );
|
Assert.assertTrue( Pattern.compile( AFTER_FORMAT ).matcher( outputContent ).matches() );
|
||||||
}
|
}
|
||||||
finally {
|
finally {
|
||||||
StandardServiceRegistryBuilder.destroy( ssr );
|
StandardServiceRegistryBuilder.destroy( ssr );
|
||||||
|
|
|
@ -49,6 +49,8 @@ public class SchemaUpdateWithFunctionIndexTest extends BaseNonConfigCoreFunction
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void setUp() {
|
public void setUp() {
|
||||||
|
dropFunctionIndex();
|
||||||
|
dropTable();
|
||||||
createTable();
|
createTable();
|
||||||
createFunctionIndex();
|
createFunctionIndex();
|
||||||
serviceRegistry = new StandardServiceRegistryBuilder()
|
serviceRegistry = new StandardServiceRegistryBuilder()
|
||||||
|
@ -78,15 +80,13 @@ public class SchemaUpdateWithFunctionIndexTest extends BaseNonConfigCoreFunction
|
||||||
session.close();
|
session.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
@After
|
private void dropTable() {
|
||||||
public void tearDown() {
|
Session session = openSession();
|
||||||
dropFunctionIndex();
|
Transaction transaction = session.beginTransaction();
|
||||||
System.out.println( "********* Starting SchemaExport (drop) for TEAR-DOWN *************************" );
|
Query query = session.createSQLQuery( "DROP TABLE IF EXISTS MyEntity;" );
|
||||||
new SchemaExport().drop( EnumSet.of( TargetType.DATABASE, TargetType.SCRIPT ), metadata );
|
query.executeUpdate();
|
||||||
System.out.println( "********* Completed SchemaExport (drop) for TEAR-DOWN *************************" );
|
transaction.commit();
|
||||||
|
session.close();
|
||||||
StandardServiceRegistryBuilder.destroy( serviceRegistry );
|
|
||||||
serviceRegistry = null;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void dropFunctionIndex() {
|
private void dropFunctionIndex() {
|
||||||
|
@ -98,6 +98,14 @@ public class SchemaUpdateWithFunctionIndexTest extends BaseNonConfigCoreFunction
|
||||||
session.close();
|
session.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@After
|
||||||
|
public void tearDown() {
|
||||||
|
dropFunctionIndex();
|
||||||
|
dropTable();
|
||||||
|
new SchemaExport().drop( EnumSet.of( TargetType.DATABASE, TargetType.STDOUT ), metadata );
|
||||||
|
StandardServiceRegistryBuilder.destroy( serviceRegistry );
|
||||||
|
}
|
||||||
|
|
||||||
@Entity
|
@Entity
|
||||||
@Table(name = "MyEntity", indexes = @Index(columnList = "otherInfo"))
|
@Table(name = "MyEntity", indexes = @Index(columnList = "otherInfo"))
|
||||||
public static class MyEntity {
|
public static class MyEntity {
|
||||||
|
|
|
@ -6,6 +6,7 @@
|
||||||
*/
|
*/
|
||||||
package org.hibernate.test.schemaupdate;
|
package org.hibernate.test.schemaupdate;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
import java.util.EnumSet;
|
import java.util.EnumSet;
|
||||||
import javax.persistence.Entity;
|
import javax.persistence.Entity;
|
||||||
import javax.persistence.Id;
|
import javax.persistence.Id;
|
||||||
|
@ -38,16 +39,17 @@ import org.junit.Test;
|
||||||
@TestForIssue(jiraKey = "HHH-1872")
|
@TestForIssue(jiraKey = "HHH-1872")
|
||||||
@RequiresDialect(PostgreSQL81Dialect.class)
|
@RequiresDialect(PostgreSQL81Dialect.class)
|
||||||
public class SchemaUpdateWithViewsTest extends BaseNonConfigCoreFunctionalTestCase {
|
public class SchemaUpdateWithViewsTest extends BaseNonConfigCoreFunctionalTestCase {
|
||||||
|
|
||||||
protected ServiceRegistry serviceRegistry;
|
protected ServiceRegistry serviceRegistry;
|
||||||
protected MetadataImplementor metadata;
|
protected MetadataImplementor metadata;
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testUpdateSchema() {
|
public void testUpdateSchema() {
|
||||||
new SchemaUpdate().execute( EnumSet.of( TargetType.SCRIPT, TargetType.DATABASE ), metadata );
|
new SchemaUpdate().execute( EnumSet.of( TargetType.DATABASE, TargetType.STDOUT ), metadata );
|
||||||
}
|
}
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void setUp() {
|
public void setUp() throws IOException {
|
||||||
createViewWithSameNameOfEntityTable();
|
createViewWithSameNameOfEntityTable();
|
||||||
serviceRegistry = new StandardServiceRegistryBuilder()
|
serviceRegistry = new StandardServiceRegistryBuilder()
|
||||||
.applySetting( Environment.GLOBALLY_QUOTED_IDENTIFIERS, "false" )
|
.applySetting( Environment.GLOBALLY_QUOTED_IDENTIFIERS, "false" )
|
||||||
|
@ -56,12 +58,13 @@ public class SchemaUpdateWithViewsTest extends BaseNonConfigCoreFunctionalTestCa
|
||||||
metadata = (MetadataImplementor) new MetadataSources( serviceRegistry )
|
metadata = (MetadataImplementor) new MetadataSources( serviceRegistry )
|
||||||
.addAnnotatedClass( MyEntity.class )
|
.addAnnotatedClass( MyEntity.class )
|
||||||
.buildMetadata();
|
.buildMetadata();
|
||||||
|
metadata.validate();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void createViewWithSameNameOfEntityTable() {
|
private void createViewWithSameNameOfEntityTable() {
|
||||||
Session session = openSession();
|
Session session = openSession();
|
||||||
Transaction transaction = session.beginTransaction();
|
Transaction transaction = session.beginTransaction();
|
||||||
Query query = session.createSQLQuery( "CREATE VIEW MyEntity AS SELECT 'Hello World' " );
|
Query query = session.createSQLQuery( "CREATE OR REPLACE VIEW MyEntity AS SELECT 'Hello World' " );
|
||||||
query.executeUpdate();
|
query.executeUpdate();
|
||||||
transaction.commit();
|
transaction.commit();
|
||||||
session.close();
|
session.close();
|
||||||
|
@ -81,7 +84,7 @@ public class SchemaUpdateWithViewsTest extends BaseNonConfigCoreFunctionalTestCa
|
||||||
private void dropView() {
|
private void dropView() {
|
||||||
Session session = openSession();
|
Session session = openSession();
|
||||||
Transaction transaction = session.beginTransaction();
|
Transaction transaction = session.beginTransaction();
|
||||||
Query query = session.createSQLQuery( "DROP VIEW MyEntity " );
|
Query query = session.createSQLQuery( "DROP VIEW IF EXISTS MyEntity " );
|
||||||
query.executeUpdate();
|
query.executeUpdate();
|
||||||
transaction.commit();
|
transaction.commit();
|
||||||
session.close();
|
session.close();
|
||||||
|
|
|
@ -31,7 +31,6 @@ import org.hibernate.tool.schema.internal.ExceptionHandlerLoggedImpl;
|
||||||
import org.hibernate.tool.schema.internal.HibernateSchemaManagementTool;
|
import org.hibernate.tool.schema.internal.HibernateSchemaManagementTool;
|
||||||
import org.hibernate.tool.schema.internal.SchemaDropperImpl;
|
import org.hibernate.tool.schema.internal.SchemaDropperImpl;
|
||||||
import org.hibernate.tool.schema.internal.SchemaMigratorImpl;
|
import org.hibernate.tool.schema.internal.SchemaMigratorImpl;
|
||||||
import org.hibernate.test.tool.schema.TargetDatabaseImpl;
|
|
||||||
import org.hibernate.tool.schema.internal.exec.GenerationTarget;
|
import org.hibernate.tool.schema.internal.exec.GenerationTarget;
|
||||||
import org.hibernate.tool.schema.internal.exec.GenerationTargetToStdout;
|
import org.hibernate.tool.schema.internal.exec.GenerationTargetToStdout;
|
||||||
import org.hibernate.tool.schema.spi.ExceptionHandler;
|
import org.hibernate.tool.schema.spi.ExceptionHandler;
|
||||||
|
@ -42,6 +41,7 @@ import org.hibernate.tool.schema.spi.SourceDescriptor;
|
||||||
|
|
||||||
import org.hibernate.testing.TestForIssue;
|
import org.hibernate.testing.TestForIssue;
|
||||||
import org.hibernate.testing.junit4.BaseUnitTestCase;
|
import org.hibernate.testing.junit4.BaseUnitTestCase;
|
||||||
|
import org.hibernate.test.tool.schema.TargetDatabaseImpl;
|
||||||
import org.junit.After;
|
import org.junit.After;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
@ -87,7 +87,7 @@ public class CrossSchemaForeignKeyGenerationTest extends BaseUnitTestCase {
|
||||||
final List<String> sqlLines = Files.readAllLines( output.toPath(), Charset.defaultCharset() );
|
final List<String> sqlLines = Files.readAllLines( output.toPath(), Charset.defaultCharset() );
|
||||||
assertThat(
|
assertThat(
|
||||||
"Expected alter table SCHEMA1.Child add constraint but is : " + sqlLines.get( 4 ),
|
"Expected alter table SCHEMA1.Child add constraint but is : " + sqlLines.get( 4 ),
|
||||||
sqlLines.get( 4 ).startsWith( "alter table " ),
|
sqlLines.get( sqlLines.size() - 1 ).startsWith( "alter table " ),
|
||||||
is( true )
|
is( true )
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
|
@ -16,6 +16,7 @@ import java.time.OffsetTime;
|
||||||
import java.time.ZonedDateTime;
|
import java.time.ZonedDateTime;
|
||||||
import java.time.temporal.ChronoUnit;
|
import java.time.temporal.ChronoUnit;
|
||||||
import java.util.Iterator;
|
import java.util.Iterator;
|
||||||
|
import javax.persistence.Column;
|
||||||
import javax.persistence.Entity;
|
import javax.persistence.Entity;
|
||||||
import javax.persistence.Id;
|
import javax.persistence.Id;
|
||||||
import javax.persistence.Table;
|
import javax.persistence.Table;
|
||||||
|
@ -92,14 +93,32 @@ public class Java8DateTimeTests extends BaseNonConfigCoreFunctionalTestCase {
|
||||||
@Entity(name = "TheEntity")
|
@Entity(name = "TheEntity")
|
||||||
@Table(name="the_entity")
|
@Table(name="the_entity")
|
||||||
public static class TheEntity {
|
public static class TheEntity {
|
||||||
|
|
||||||
|
@Id
|
||||||
private Integer id;
|
private Integer id;
|
||||||
|
|
||||||
|
@Column(name = "local_date_time")
|
||||||
private LocalDateTime localDateTime = LocalDateTime.now();
|
private LocalDateTime localDateTime = LocalDateTime.now();
|
||||||
|
|
||||||
|
@Column(name = "local_date")
|
||||||
private LocalDate localDate = LocalDate.now();
|
private LocalDate localDate = LocalDate.now();
|
||||||
|
|
||||||
|
@Column(name = "local_time")
|
||||||
private LocalTime localTime = LocalTime.now();
|
private LocalTime localTime = LocalTime.now();
|
||||||
|
|
||||||
|
@Column(name = "instant_value")
|
||||||
private Instant instant = Instant.now();
|
private Instant instant = Instant.now();
|
||||||
|
|
||||||
|
@Column(name = "zoned_date_time")
|
||||||
private ZonedDateTime zonedDateTime = ZonedDateTime.now();
|
private ZonedDateTime zonedDateTime = ZonedDateTime.now();
|
||||||
|
|
||||||
|
@Column(name = "offset_date_time")
|
||||||
private OffsetDateTime offsetDateTime = OffsetDateTime.now();
|
private OffsetDateTime offsetDateTime = OffsetDateTime.now();
|
||||||
|
|
||||||
|
@Column(name = "offset_time")
|
||||||
private OffsetTime offsetTime = OffsetTime.now();
|
private OffsetTime offsetTime = OffsetTime.now();
|
||||||
|
|
||||||
|
@Column(name = "duration_value")
|
||||||
private Duration duration = Duration.of( 20, ChronoUnit.DAYS );
|
private Duration duration = Duration.of( 20, ChronoUnit.DAYS );
|
||||||
|
|
||||||
public TheEntity() {
|
public TheEntity() {
|
||||||
|
@ -109,7 +128,6 @@ public class Java8DateTimeTests extends BaseNonConfigCoreFunctionalTestCase {
|
||||||
this.id = id;
|
this.id = id;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Id
|
|
||||||
public Integer getId() {
|
public Integer getId() {
|
||||||
return id;
|
return id;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue