HHH-6511 Refactors spatial integration tests.
Spatial integration tests are now more in line with the Hibernate Core integration tests.
This commit is contained in:
parent
f114ca2944
commit
50a648ed32
|
@ -27,11 +27,13 @@ package org.hibernate.spatial.integration;
|
||||||
|
|
||||||
import com.vividsolutions.jts.geom.Geometry;
|
import com.vividsolutions.jts.geom.Geometry;
|
||||||
import com.vividsolutions.jts.io.ParseException;
|
import com.vividsolutions.jts.io.ParseException;
|
||||||
|
import org.hibernate.spatial.testing.EWKTReader;
|
||||||
|
import org.hibernate.spatial.testing.TestDataElement;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Test class used in unit testing.
|
* Test class used in unit testing.
|
||||||
*/
|
*/
|
||||||
public class GeomEntity implements TestFeature {
|
public class GeomEntity {
|
||||||
|
|
||||||
private Integer id;
|
private Integer id;
|
||||||
|
|
||||||
|
|
|
@ -1,22 +0,0 @@
|
||||||
package org.hibernate.spatial.integration;
|
|
||||||
|
|
||||||
import com.vividsolutions.jts.geom.Geometry;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Interface for persistent entities in
|
|
||||||
* integration tests.
|
|
||||||
*
|
|
||||||
* @author Karel Maesen, Geovise BVBA
|
|
||||||
* creation-date: Oct 2, 2010
|
|
||||||
*/
|
|
||||||
public interface TestFeature {
|
|
||||||
|
|
||||||
public Integer getId();
|
|
||||||
|
|
||||||
public void setId(Integer id);
|
|
||||||
|
|
||||||
public Geometry getGeom();
|
|
||||||
|
|
||||||
public void setGeom(Geometry geom);
|
|
||||||
|
|
||||||
}
|
|
|
@ -29,8 +29,9 @@ import com.vividsolutions.jts.geom.Geometry;
|
||||||
import org.hibernate.Query;
|
import org.hibernate.Query;
|
||||||
import org.hibernate.Session;
|
import org.hibernate.Session;
|
||||||
import org.hibernate.Transaction;
|
import org.hibernate.Transaction;
|
||||||
import org.hibernate.spatial.SpatialDialect;
|
|
||||||
import org.hibernate.spatial.SpatialFunction;
|
import org.hibernate.spatial.SpatialFunction;
|
||||||
|
import org.hibernate.spatial.testing.SpatialDialectMatcher;
|
||||||
|
import org.hibernate.spatial.testing.SpatialFunctionalTestCase;
|
||||||
import org.hibernate.testing.Skip;
|
import org.hibernate.testing.Skip;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
|
@ -48,49 +49,11 @@ public class TestSpatialFunctions extends SpatialFunctionalTestCase {
|
||||||
|
|
||||||
private static Logger LOGGER = LoggerFactory.getLogger( TestSpatialFunctions.class );
|
private static Logger LOGGER = LoggerFactory.getLogger( TestSpatialFunctions.class );
|
||||||
|
|
||||||
public void prepareTest() {
|
|
||||||
super.prepareTest();
|
|
||||||
insertTestData();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
protected Logger getLogger() {
|
protected Logger getLogger() {
|
||||||
return LOGGER;
|
return LOGGER;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testSpatialFunctions() throws Exception {
|
|
||||||
if (! (getDialect() instanceof SpatialDialect)) return;
|
|
||||||
dimension();
|
|
||||||
astext();
|
|
||||||
asbinary();
|
|
||||||
geometrytype();
|
|
||||||
srid();
|
|
||||||
issimple();
|
|
||||||
isempty();
|
|
||||||
boundary();
|
|
||||||
envelope();
|
|
||||||
within();
|
|
||||||
equals();
|
|
||||||
crosses();
|
|
||||||
contains();
|
|
||||||
disjoint();
|
|
||||||
intersects();
|
|
||||||
overlaps();
|
|
||||||
touches();
|
|
||||||
relate();
|
|
||||||
distance();
|
|
||||||
buffer();
|
|
||||||
convexhull();
|
|
||||||
intersection();
|
|
||||||
difference();
|
|
||||||
symdifference();
|
|
||||||
geomunion();
|
|
||||||
dwithin();
|
|
||||||
transform();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
public void dimension() throws SQLException {
|
public void dimension() throws SQLException {
|
||||||
if ( !isSupportedByDialect( SpatialFunction.dimension ) ) {
|
if ( !isSupportedByDialect( SpatialFunction.dimension ) ) {
|
||||||
return;
|
return;
|
||||||
|
@ -100,6 +63,7 @@ public class TestSpatialFunctions extends SpatialFunctionalTestCase {
|
||||||
retrieveHQLResultsAndCompare( dbexpected, hql );
|
retrieveHQLResultsAndCompare( dbexpected, hql );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void astext() throws SQLException {
|
public void astext() throws SQLException {
|
||||||
if ( !isSupportedByDialect( SpatialFunction.astext ) ) {
|
if ( !isSupportedByDialect( SpatialFunction.astext ) ) {
|
||||||
return;
|
return;
|
||||||
|
@ -109,6 +73,7 @@ public class TestSpatialFunctions extends SpatialFunctionalTestCase {
|
||||||
retrieveHQLResultsAndCompare( dbexpected, hql );
|
retrieveHQLResultsAndCompare( dbexpected, hql );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void asbinary() throws SQLException {
|
public void asbinary() throws SQLException {
|
||||||
if ( !isSupportedByDialect( SpatialFunction.asbinary ) ) {
|
if ( !isSupportedByDialect( SpatialFunction.asbinary ) ) {
|
||||||
return;
|
return;
|
||||||
|
@ -118,7 +83,7 @@ public class TestSpatialFunctions extends SpatialFunctionalTestCase {
|
||||||
retrieveHQLResultsAndCompare( dbexpected, hql );
|
retrieveHQLResultsAndCompare( dbexpected, hql );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void geometrytype() throws SQLException {
|
public void geometrytype() throws SQLException {
|
||||||
if ( !isSupportedByDialect( SpatialFunction.geometrytype ) ) {
|
if ( !isSupportedByDialect( SpatialFunction.geometrytype ) ) {
|
||||||
return;
|
return;
|
||||||
|
@ -128,6 +93,7 @@ public class TestSpatialFunctions extends SpatialFunctionalTestCase {
|
||||||
retrieveHQLResultsAndCompare( dbexpected, hql );
|
retrieveHQLResultsAndCompare( dbexpected, hql );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void srid() throws SQLException {
|
public void srid() throws SQLException {
|
||||||
if ( !isSupportedByDialect( SpatialFunction.srid ) ) {
|
if ( !isSupportedByDialect( SpatialFunction.srid ) ) {
|
||||||
return;
|
return;
|
||||||
|
@ -137,6 +103,7 @@ public class TestSpatialFunctions extends SpatialFunctionalTestCase {
|
||||||
retrieveHQLResultsAndCompare( dbexpected, hql );
|
retrieveHQLResultsAndCompare( dbexpected, hql );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void issimple() throws SQLException {
|
public void issimple() throws SQLException {
|
||||||
if ( !isSupportedByDialect( SpatialFunction.issimple ) ) {
|
if ( !isSupportedByDialect( SpatialFunction.issimple ) ) {
|
||||||
return;
|
return;
|
||||||
|
@ -146,6 +113,7 @@ public class TestSpatialFunctions extends SpatialFunctionalTestCase {
|
||||||
retrieveHQLResultsAndCompare( dbexpected, hql );
|
retrieveHQLResultsAndCompare( dbexpected, hql );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void isempty() throws SQLException {
|
public void isempty() throws SQLException {
|
||||||
if ( !isSupportedByDialect( SpatialFunction.isempty ) ) {
|
if ( !isSupportedByDialect( SpatialFunction.isempty ) ) {
|
||||||
return;
|
return;
|
||||||
|
@ -155,7 +123,7 @@ public class TestSpatialFunctions extends SpatialFunctionalTestCase {
|
||||||
retrieveHQLResultsAndCompare( dbexpected, hql );
|
retrieveHQLResultsAndCompare( dbexpected, hql );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void boundary() throws SQLException {
|
public void boundary() throws SQLException {
|
||||||
if ( !isSupportedByDialect( SpatialFunction.boundary ) ) {
|
if ( !isSupportedByDialect( SpatialFunction.boundary ) ) {
|
||||||
return;
|
return;
|
||||||
|
@ -165,7 +133,7 @@ public class TestSpatialFunctions extends SpatialFunctionalTestCase {
|
||||||
retrieveHQLResultsAndCompare( dbexpected, hql );
|
retrieveHQLResultsAndCompare( dbexpected, hql );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void envelope() throws SQLException {
|
public void envelope() throws SQLException {
|
||||||
if ( !isSupportedByDialect( SpatialFunction.envelope ) ) {
|
if ( !isSupportedByDialect( SpatialFunction.envelope ) ) {
|
||||||
return;
|
return;
|
||||||
|
@ -175,6 +143,7 @@ public class TestSpatialFunctions extends SpatialFunctionalTestCase {
|
||||||
retrieveHQLResultsAndCompare( dbexpected, hql );
|
retrieveHQLResultsAndCompare( dbexpected, hql );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void within() throws SQLException {
|
public void within() throws SQLException {
|
||||||
if ( !isSupportedByDialect( SpatialFunction.within ) ) {
|
if ( !isSupportedByDialect( SpatialFunction.within ) ) {
|
||||||
return;
|
return;
|
||||||
|
@ -185,6 +154,7 @@ public class TestSpatialFunctions extends SpatialFunctionalTestCase {
|
||||||
retrieveHQLResultsAndCompare( dbexpected, hql, params );
|
retrieveHQLResultsAndCompare( dbexpected, hql, params );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void equals() throws SQLException {
|
public void equals() throws SQLException {
|
||||||
if ( !isSupportedByDialect( SpatialFunction.equals ) ) {
|
if ( !isSupportedByDialect( SpatialFunction.equals ) ) {
|
||||||
return;
|
return;
|
||||||
|
@ -195,6 +165,7 @@ public class TestSpatialFunctions extends SpatialFunctionalTestCase {
|
||||||
retrieveHQLResultsAndCompare( dbexpected, hql, params );
|
retrieveHQLResultsAndCompare( dbexpected, hql, params );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void crosses() throws SQLException {
|
public void crosses() throws SQLException {
|
||||||
if ( !isSupportedByDialect( SpatialFunction.crosses ) ) {
|
if ( !isSupportedByDialect( SpatialFunction.crosses ) ) {
|
||||||
return;
|
return;
|
||||||
|
@ -206,6 +177,7 @@ public class TestSpatialFunctions extends SpatialFunctionalTestCase {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void contains() throws SQLException {
|
public void contains() throws SQLException {
|
||||||
if ( !isSupportedByDialect( SpatialFunction.contains ) ) {
|
if ( !isSupportedByDialect( SpatialFunction.contains ) ) {
|
||||||
return;
|
return;
|
||||||
|
@ -217,6 +189,7 @@ public class TestSpatialFunctions extends SpatialFunctionalTestCase {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Test
|
||||||
public void disjoint() throws SQLException {
|
public void disjoint() throws SQLException {
|
||||||
if ( !isSupportedByDialect( SpatialFunction.disjoint ) ) {
|
if ( !isSupportedByDialect( SpatialFunction.disjoint ) ) {
|
||||||
return;
|
return;
|
||||||
|
@ -227,6 +200,7 @@ public class TestSpatialFunctions extends SpatialFunctionalTestCase {
|
||||||
retrieveHQLResultsAndCompare( dbexpected, hql, params );
|
retrieveHQLResultsAndCompare( dbexpected, hql, params );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void intersects() throws SQLException {
|
public void intersects() throws SQLException {
|
||||||
if ( !isSupportedByDialect( SpatialFunction.intersects ) ) {
|
if ( !isSupportedByDialect( SpatialFunction.intersects ) ) {
|
||||||
return;
|
return;
|
||||||
|
@ -237,6 +211,7 @@ public class TestSpatialFunctions extends SpatialFunctionalTestCase {
|
||||||
retrieveHQLResultsAndCompare( dbexpected, hql, params );
|
retrieveHQLResultsAndCompare( dbexpected, hql, params );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void overlaps() throws SQLException {
|
public void overlaps() throws SQLException {
|
||||||
if ( !isSupportedByDialect( SpatialFunction.overlaps ) ) {
|
if ( !isSupportedByDialect( SpatialFunction.overlaps ) ) {
|
||||||
return;
|
return;
|
||||||
|
@ -247,6 +222,7 @@ public class TestSpatialFunctions extends SpatialFunctionalTestCase {
|
||||||
retrieveHQLResultsAndCompare( dbexpected, hql, params );
|
retrieveHQLResultsAndCompare( dbexpected, hql, params );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void touches() throws SQLException {
|
public void touches() throws SQLException {
|
||||||
if ( !isSupportedByDialect( SpatialFunction.touches ) ) {
|
if ( !isSupportedByDialect( SpatialFunction.touches ) ) {
|
||||||
return;
|
return;
|
||||||
|
@ -257,6 +233,7 @@ public class TestSpatialFunctions extends SpatialFunctionalTestCase {
|
||||||
retrieveHQLResultsAndCompare( dbexpected, hql, params );
|
retrieveHQLResultsAndCompare( dbexpected, hql, params );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void relate() throws SQLException {
|
public void relate() throws SQLException {
|
||||||
if ( !isSupportedByDialect( SpatialFunction.relate ) ) {
|
if ( !isSupportedByDialect( SpatialFunction.relate ) ) {
|
||||||
return;
|
return;
|
||||||
|
@ -278,6 +255,7 @@ public class TestSpatialFunctions extends SpatialFunctionalTestCase {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void distance() throws SQLException {
|
public void distance() throws SQLException {
|
||||||
if ( !isSupportedByDialect( SpatialFunction.distance ) ) {
|
if ( !isSupportedByDialect( SpatialFunction.distance ) ) {
|
||||||
return;
|
return;
|
||||||
|
@ -288,6 +266,7 @@ public class TestSpatialFunctions extends SpatialFunctionalTestCase {
|
||||||
retrieveHQLResultsAndCompare( dbexpected, hql, params );
|
retrieveHQLResultsAndCompare( dbexpected, hql, params );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void buffer() throws SQLException {
|
public void buffer() throws SQLException {
|
||||||
if ( !isSupportedByDialect( SpatialFunction.buffer ) ) {
|
if ( !isSupportedByDialect( SpatialFunction.buffer ) ) {
|
||||||
return;
|
return;
|
||||||
|
@ -299,6 +278,7 @@ public class TestSpatialFunctions extends SpatialFunctionalTestCase {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void convexhull() throws SQLException {
|
public void convexhull() throws SQLException {
|
||||||
if ( !isSupportedByDialect( SpatialFunction.convexhull ) ) {
|
if ( !isSupportedByDialect( SpatialFunction.convexhull ) ) {
|
||||||
return;
|
return;
|
||||||
|
@ -310,6 +290,7 @@ public class TestSpatialFunctions extends SpatialFunctionalTestCase {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void intersection() throws SQLException {
|
public void intersection() throws SQLException {
|
||||||
if ( !isSupportedByDialect( SpatialFunction.intersection ) ) {
|
if ( !isSupportedByDialect( SpatialFunction.intersection ) ) {
|
||||||
return;
|
return;
|
||||||
|
@ -320,6 +301,7 @@ public class TestSpatialFunctions extends SpatialFunctionalTestCase {
|
||||||
retrieveHQLResultsAndCompare( dbexpected, hql, params );
|
retrieveHQLResultsAndCompare( dbexpected, hql, params );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void difference() throws SQLException {
|
public void difference() throws SQLException {
|
||||||
if ( !isSupportedByDialect( SpatialFunction.difference ) ) {
|
if ( !isSupportedByDialect( SpatialFunction.difference ) ) {
|
||||||
return;
|
return;
|
||||||
|
@ -330,6 +312,7 @@ public class TestSpatialFunctions extends SpatialFunctionalTestCase {
|
||||||
retrieveHQLResultsAndCompare( dbexpected, hql, params );
|
retrieveHQLResultsAndCompare( dbexpected, hql, params );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void symdifference() throws SQLException {
|
public void symdifference() throws SQLException {
|
||||||
if ( !isSupportedByDialect( SpatialFunction.symdifference ) ) {
|
if ( !isSupportedByDialect( SpatialFunction.symdifference ) ) {
|
||||||
return;
|
return;
|
||||||
|
@ -340,6 +323,7 @@ public class TestSpatialFunctions extends SpatialFunctionalTestCase {
|
||||||
retrieveHQLResultsAndCompare( dbexpected, hql, params );
|
retrieveHQLResultsAndCompare( dbexpected, hql, params );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void geomunion() throws SQLException {
|
public void geomunion() throws SQLException {
|
||||||
if ( !isSupportedByDialect( SpatialFunction.geomunion ) ) {
|
if ( !isSupportedByDialect( SpatialFunction.geomunion ) ) {
|
||||||
return;
|
return;
|
||||||
|
@ -350,6 +334,7 @@ public class TestSpatialFunctions extends SpatialFunctionalTestCase {
|
||||||
retrieveHQLResultsAndCompare( dbexpected, hql, params );
|
retrieveHQLResultsAndCompare( dbexpected, hql, params );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void dwithin() throws SQLException {
|
public void dwithin() throws SQLException {
|
||||||
if ( !isSupportedByDialect( SpatialFunction.dwithin ) ) {
|
if ( !isSupportedByDialect( SpatialFunction.dwithin ) ) {
|
||||||
return;
|
return;
|
||||||
|
@ -365,6 +350,7 @@ public class TestSpatialFunctions extends SpatialFunctionalTestCase {
|
||||||
retrieveHQLResultsAndCompare( dbexpected, hql, params );
|
retrieveHQLResultsAndCompare( dbexpected, hql, params );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void transform() throws SQLException {
|
public void transform() throws SQLException {
|
||||||
if ( !isSupportedByDialect( SpatialFunction.transform ) ) {
|
if ( !isSupportedByDialect( SpatialFunction.transform ) ) {
|
||||||
return;
|
return;
|
||||||
|
|
|
@ -29,9 +29,10 @@ import org.hibernate.Criteria;
|
||||||
import org.hibernate.Session;
|
import org.hibernate.Session;
|
||||||
import org.hibernate.Transaction;
|
import org.hibernate.Transaction;
|
||||||
import org.hibernate.criterion.Criterion;
|
import org.hibernate.criterion.Criterion;
|
||||||
import org.hibernate.spatial.SpatialDialect;
|
|
||||||
import org.hibernate.spatial.SpatialFunction;
|
import org.hibernate.spatial.SpatialFunction;
|
||||||
import org.hibernate.spatial.criterion.SpatialRestrictions;
|
import org.hibernate.spatial.criterion.SpatialRestrictions;
|
||||||
|
import org.hibernate.spatial.testing.SpatialDialectMatcher;
|
||||||
|
import org.hibernate.spatial.testing.SpatialFunctionalTestCase;
|
||||||
import org.hibernate.testing.Skip;
|
import org.hibernate.testing.Skip;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
|
@ -49,39 +50,11 @@ public class TestSpatialRestrictions extends SpatialFunctionalTestCase {
|
||||||
|
|
||||||
private static Logger LOGGER = LoggerFactory.getLogger( TestSpatialRestrictions.class );
|
private static Logger LOGGER = LoggerFactory.getLogger( TestSpatialRestrictions.class );
|
||||||
|
|
||||||
|
|
||||||
public void prepareTest() {
|
|
||||||
super.prepareTest();
|
|
||||||
try {
|
|
||||||
dataSourceUtils.insertTestData( testData );
|
|
||||||
}
|
|
||||||
catch ( SQLException e ) {
|
|
||||||
throw new RuntimeException( e );
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
protected Logger getLogger() {
|
protected Logger getLogger() {
|
||||||
return LOGGER;
|
return LOGGER;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testRestrictions() throws Exception {
|
|
||||||
if (! (getDialect() instanceof SpatialDialect)) return;
|
|
||||||
within();
|
|
||||||
filter();
|
|
||||||
contains();
|
|
||||||
crosses();
|
|
||||||
touches();
|
|
||||||
disjoint();
|
|
||||||
eq();
|
|
||||||
intersects();
|
|
||||||
overlaps();
|
|
||||||
dwithin();
|
|
||||||
havingSRID();
|
|
||||||
isEmpty();
|
|
||||||
isNotEmpty();
|
|
||||||
}
|
|
||||||
|
|
||||||
public void within() throws SQLException {
|
public void within() throws SQLException {
|
||||||
if ( !isSupportedByDialect( SpatialFunction.within ) ) {
|
if ( !isSupportedByDialect( SpatialFunction.within ) ) {
|
||||||
return;
|
return;
|
||||||
|
@ -91,6 +64,7 @@ public class TestSpatialRestrictions extends SpatialFunctionalTestCase {
|
||||||
retrieveAndCompare( dbexpected, spatialCriterion );
|
retrieveAndCompare( dbexpected, spatialCriterion );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void filter() throws SQLException {
|
public void filter() throws SQLException {
|
||||||
if ( !dialectSupportsFiltering() ) {
|
if ( !dialectSupportsFiltering() ) {
|
||||||
return;
|
return;
|
||||||
|
@ -100,6 +74,7 @@ public class TestSpatialRestrictions extends SpatialFunctionalTestCase {
|
||||||
retrieveAndCompare( dbexpected, spatialCriterion );
|
retrieveAndCompare( dbexpected, spatialCriterion );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void contains() throws SQLException {
|
public void contains() throws SQLException {
|
||||||
if ( !isSupportedByDialect( SpatialFunction.contains ) ) {
|
if ( !isSupportedByDialect( SpatialFunction.contains ) ) {
|
||||||
return;
|
return;
|
||||||
|
@ -109,6 +84,7 @@ public class TestSpatialRestrictions extends SpatialFunctionalTestCase {
|
||||||
retrieveAndCompare( dbexpected, spatialCriterion );
|
retrieveAndCompare( dbexpected, spatialCriterion );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void crosses() throws SQLException {
|
public void crosses() throws SQLException {
|
||||||
if ( !isSupportedByDialect( SpatialFunction.crosses ) ) {
|
if ( !isSupportedByDialect( SpatialFunction.crosses ) ) {
|
||||||
return;
|
return;
|
||||||
|
@ -118,6 +94,7 @@ public class TestSpatialRestrictions extends SpatialFunctionalTestCase {
|
||||||
retrieveAndCompare( dbexpected, spatialCriterion );
|
retrieveAndCompare( dbexpected, spatialCriterion );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void touches() throws SQLException {
|
public void touches() throws SQLException {
|
||||||
if ( !isSupportedByDialect( SpatialFunction.touches ) ) {
|
if ( !isSupportedByDialect( SpatialFunction.touches ) ) {
|
||||||
return;
|
return;
|
||||||
|
@ -127,6 +104,7 @@ public class TestSpatialRestrictions extends SpatialFunctionalTestCase {
|
||||||
retrieveAndCompare( dbexpected, spatialCriterion );
|
retrieveAndCompare( dbexpected, spatialCriterion );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void disjoint() throws SQLException {
|
public void disjoint() throws SQLException {
|
||||||
if ( !isSupportedByDialect( SpatialFunction.disjoint ) ) {
|
if ( !isSupportedByDialect( SpatialFunction.disjoint ) ) {
|
||||||
return;
|
return;
|
||||||
|
@ -136,6 +114,7 @@ public class TestSpatialRestrictions extends SpatialFunctionalTestCase {
|
||||||
retrieveAndCompare( dbexpected, spatialCriterion );
|
retrieveAndCompare( dbexpected, spatialCriterion );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void eq() throws SQLException {
|
public void eq() throws SQLException {
|
||||||
if ( !isSupportedByDialect( SpatialFunction.equals ) ) {
|
if ( !isSupportedByDialect( SpatialFunction.equals ) ) {
|
||||||
return;
|
return;
|
||||||
|
@ -145,6 +124,7 @@ public class TestSpatialRestrictions extends SpatialFunctionalTestCase {
|
||||||
retrieveAndCompare( dbexpected, spatialCriterion );
|
retrieveAndCompare( dbexpected, spatialCriterion );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void intersects() throws SQLException {
|
public void intersects() throws SQLException {
|
||||||
if ( !isSupportedByDialect( SpatialFunction.intersects ) ) {
|
if ( !isSupportedByDialect( SpatialFunction.intersects ) ) {
|
||||||
return;
|
return;
|
||||||
|
@ -154,6 +134,7 @@ public class TestSpatialRestrictions extends SpatialFunctionalTestCase {
|
||||||
retrieveAndCompare( dbexpected, spatialCriterion );
|
retrieveAndCompare( dbexpected, spatialCriterion );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void overlaps() throws SQLException {
|
public void overlaps() throws SQLException {
|
||||||
if ( !isSupportedByDialect( SpatialFunction.overlaps ) ) {
|
if ( !isSupportedByDialect( SpatialFunction.overlaps ) ) {
|
||||||
return;
|
return;
|
||||||
|
@ -163,6 +144,7 @@ public class TestSpatialRestrictions extends SpatialFunctionalTestCase {
|
||||||
retrieveAndCompare( dbexpected, spatialCriterion );
|
retrieveAndCompare( dbexpected, spatialCriterion );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void dwithin() throws SQLException {
|
public void dwithin() throws SQLException {
|
||||||
if ( !isSupportedByDialect( SpatialFunction.dwithin ) ) {
|
if ( !isSupportedByDialect( SpatialFunction.dwithin ) ) {
|
||||||
return;
|
return;
|
||||||
|
@ -176,6 +158,7 @@ public class TestSpatialRestrictions extends SpatialFunctionalTestCase {
|
||||||
retrieveAndCompare( dbexpected, spatialCriterion );
|
retrieveAndCompare( dbexpected, spatialCriterion );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void isEmpty() throws SQLException {
|
public void isEmpty() throws SQLException {
|
||||||
if ( !isSupportedByDialect( SpatialFunction.isempty ) ) {
|
if ( !isSupportedByDialect( SpatialFunction.isempty ) ) {
|
||||||
return;
|
return;
|
||||||
|
@ -185,6 +168,7 @@ public class TestSpatialRestrictions extends SpatialFunctionalTestCase {
|
||||||
retrieveAndCompare( dbexpected, spatialCriterion );
|
retrieveAndCompare( dbexpected, spatialCriterion );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void isNotEmpty() throws SQLException {
|
public void isNotEmpty() throws SQLException {
|
||||||
if ( !isSupportedByDialect( SpatialFunction.isempty ) ) {
|
if ( !isSupportedByDialect( SpatialFunction.isempty ) ) {
|
||||||
return;
|
return;
|
||||||
|
@ -194,7 +178,7 @@ public class TestSpatialRestrictions extends SpatialFunctionalTestCase {
|
||||||
retrieveAndCompare( dbexpected, spatialCriterion );
|
retrieveAndCompare( dbexpected, spatialCriterion );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void havingSRID() throws SQLException {
|
public void havingSRID() throws SQLException {
|
||||||
if ( !isSupportedByDialect( SpatialFunction.srid ) ) {
|
if ( !isSupportedByDialect( SpatialFunction.srid ) ) {
|
||||||
return;
|
return;
|
||||||
|
|
|
@ -30,7 +30,9 @@ import com.vividsolutions.jts.io.ParseException;
|
||||||
import org.hibernate.Criteria;
|
import org.hibernate.Criteria;
|
||||||
import org.hibernate.Session;
|
import org.hibernate.Session;
|
||||||
import org.hibernate.Transaction;
|
import org.hibernate.Transaction;
|
||||||
import org.hibernate.spatial.SpatialDialect;
|
import org.hibernate.spatial.testing.SpatialDialectMatcher;
|
||||||
|
import org.hibernate.spatial.testing.SpatialFunctionalTestCase;
|
||||||
|
import org.hibernate.spatial.testing.TestDataElement;
|
||||||
import org.hibernate.testing.Skip;
|
import org.hibernate.testing.Skip;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
|
@ -48,30 +50,30 @@ import static org.junit.Assert.assertTrue;
|
||||||
* This testsuite-suite class verifies whether the <code>Geometry</code>s retrieved
|
* This testsuite-suite class verifies whether the <code>Geometry</code>s retrieved
|
||||||
* are equal to the <code>Geometry</code>s stored.
|
* are equal to the <code>Geometry</code>s stored.
|
||||||
*/
|
*/
|
||||||
@Skip(condition = SpatialDialectMatcher.class,message = "No Spatial Dialect")
|
@Skip(condition = SpatialDialectMatcher.class, message = "No Spatial Dialect")
|
||||||
public class TestStoreRetrieve extends SpatialFunctionalTestCase {
|
public class TestStoreRetrieve extends SpatialFunctionalTestCase {
|
||||||
|
|
||||||
private static Logger LOGGER = LoggerFactory.getLogger( TestStoreRetrieve.class );
|
private static Logger LOGGER = LoggerFactory.getLogger(TestStoreRetrieve.class);
|
||||||
|
|
||||||
|
|
||||||
protected Logger getLogger() {
|
protected Logger getLogger() {
|
||||||
return LOGGER;
|
return LOGGER;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void prepareTest(){
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testStoreRetrieve() throws ParseException {
|
public void testAfterStoreRetrievingEqualObject() throws ParseException {
|
||||||
if (! (getDialect() instanceof SpatialDialect)) return;
|
|
||||||
Map<Integer, GeomEntity> stored = new HashMap<Integer, GeomEntity>();
|
Map<Integer, GeomEntity> stored = new HashMap<Integer, GeomEntity>();
|
||||||
//check whether we retrieve exactly what we store
|
//check whether we retrieve exactly what we store
|
||||||
storeTestObjects( stored );
|
storeTestObjects(stored);
|
||||||
retrieveAndCompare( stored );
|
retrieveAndCompare(stored);
|
||||||
|
}
|
||||||
|
|
||||||
deleteAllTestEntities();
|
@Test
|
||||||
|
public void testStoringNullGeometries() {
|
||||||
//check if we can store null-geometries
|
|
||||||
storeNullGeometry();
|
storeNullGeometry();
|
||||||
//check if we can retrieve null-geometries
|
|
||||||
retrieveNullGeometry();
|
retrieveNullGeometry();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -82,32 +84,30 @@ public class TestStoreRetrieve extends SpatialFunctionalTestCase {
|
||||||
try {
|
try {
|
||||||
session = openSession();
|
session = openSession();
|
||||||
tx = session.beginTransaction();
|
tx = session.beginTransaction();
|
||||||
for ( GeomEntity storedEntity : stored.values() ) {
|
for (GeomEntity storedEntity : stored.values()) {
|
||||||
id = storedEntity.getId();
|
id = storedEntity.getId();
|
||||||
GeomEntity retrievedEntity = (GeomEntity) session.get( GeomEntity.class, id );
|
GeomEntity retrievedEntity = (GeomEntity) session.get(GeomEntity.class, id);
|
||||||
Geometry retrievedGeometry = retrievedEntity.getGeom();
|
Geometry retrievedGeometry = retrievedEntity.getGeom();
|
||||||
Geometry storedGeometry = storedEntity.getGeom();
|
Geometry storedGeometry = storedEntity.getGeom();
|
||||||
String msg = createFailureMessage( storedEntity.getId(), storedGeometry, retrievedGeometry );
|
String msg = createFailureMessage(storedEntity.getId(), storedGeometry, retrievedGeometry);
|
||||||
assertTrue( msg, geometryEquality.test( storedGeometry, retrievedGeometry ) );
|
assertTrue(msg, geometryEquality.test(storedGeometry, retrievedGeometry));
|
||||||
}
|
}
|
||||||
tx.commit();
|
tx.commit();
|
||||||
}
|
} catch (Exception e) {
|
||||||
catch ( Exception e ) {
|
if (tx != null) {
|
||||||
if ( tx != null ) {
|
|
||||||
tx.rollback();
|
tx.rollback();
|
||||||
}
|
}
|
||||||
throw new RuntimeException( String.format( "Failure on case: %d", id ), e );
|
throw new RuntimeException(String.format("Failure on case: %d", id), e);
|
||||||
}
|
} finally {
|
||||||
finally {
|
if (session != null) {
|
||||||
if ( session != null ) {
|
|
||||||
session.close();
|
session.close();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private String createFailureMessage(int id, Geometry storedGeometry, Geometry retrievedGeometry) {
|
private String createFailureMessage(int id, Geometry storedGeometry, Geometry retrievedGeometry) {
|
||||||
String expectedText = ( storedGeometry != null ? storedGeometry.toText() : "NULL" );
|
String expectedText = (storedGeometry != null ? storedGeometry.toText() : "NULL");
|
||||||
String retrievedText = ( retrievedGeometry != null ? retrievedGeometry.toText() : "NULL" );
|
String retrievedText = (retrievedGeometry != null ? retrievedGeometry.toText() : "NULL");
|
||||||
return String.format(
|
return String.format(
|
||||||
"Equality testsuite-suite failed for %d.\nExpected: %s\nReceived:%s",
|
"Equality testsuite-suite failed for %d.\nExpected: %s\nReceived:%s",
|
||||||
id,
|
id,
|
||||||
|
@ -124,23 +124,21 @@ public class TestStoreRetrieve extends SpatialFunctionalTestCase {
|
||||||
session = openSession();
|
session = openSession();
|
||||||
// Every testsuite-suite instance is committed seperately
|
// Every testsuite-suite instance is committed seperately
|
||||||
// to improve feedback in case of failure
|
// to improve feedback in case of failure
|
||||||
for ( TestDataElement element : testData ) {
|
for (TestDataElement element : testData) {
|
||||||
id = element.id;
|
id = element.id;
|
||||||
tx = session.beginTransaction();
|
tx = session.beginTransaction();
|
||||||
GeomEntity entity = GeomEntity.createFrom( element );
|
GeomEntity entity = GeomEntity.createFrom(element);
|
||||||
stored.put( entity.getId(), entity );
|
stored.put(entity.getId(), entity);
|
||||||
session.save( entity );
|
session.save(entity);
|
||||||
tx.commit();
|
tx.commit();
|
||||||
}
|
}
|
||||||
}
|
} catch (Exception e) {
|
||||||
catch ( Exception e ) {
|
if (tx != null) {
|
||||||
if ( tx != null ) {
|
|
||||||
tx.rollback();
|
tx.rollback();
|
||||||
}
|
}
|
||||||
throw new RuntimeException( "Failed storing testsuite-suite object with id:" + id, e );
|
throw new RuntimeException("Failed storing testsuite-suite object with id:" + id, e);
|
||||||
}
|
} finally {
|
||||||
finally {
|
if (session != null) {
|
||||||
if ( session != null ) {
|
|
||||||
session.close();
|
session.close();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -154,50 +152,43 @@ public class TestStoreRetrieve extends SpatialFunctionalTestCase {
|
||||||
session = openSession();
|
session = openSession();
|
||||||
tx = session.beginTransaction();
|
tx = session.beginTransaction();
|
||||||
entity = new GeomEntity();
|
entity = new GeomEntity();
|
||||||
entity.setId( 1 );
|
entity.setId(1);
|
||||||
entity.setType( "NULL OBJECT" );
|
entity.setType("NULL OBJECT");
|
||||||
session.save( entity );
|
session.save(entity);
|
||||||
tx.commit();
|
tx.commit();
|
||||||
}
|
} catch (Exception e) {
|
||||||
catch ( Exception e ) {
|
if (tx != null) {
|
||||||
if ( tx != null ) {
|
|
||||||
tx.rollback();
|
tx.rollback();
|
||||||
}
|
}
|
||||||
throw new RuntimeException( "Failed storing testsuite-suite object with id:" + entity.getId(), e );
|
throw new RuntimeException("Failed storing testsuite-suite object with id:" + entity.getId(), e);
|
||||||
}
|
} finally {
|
||||||
finally {
|
if (session != null) {
|
||||||
if ( session != null ) {
|
|
||||||
session.close();
|
session.close();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
private void retrieveNullGeometry() {
|
private void retrieveNullGeometry() {
|
||||||
Transaction tx = null;
|
Transaction tx = null;
|
||||||
Session session = null;
|
Session session = null;
|
||||||
try {
|
try {
|
||||||
session = openSession();
|
session = openSession();
|
||||||
tx = session.beginTransaction();
|
tx = session.beginTransaction();
|
||||||
Criteria criteria = session.createCriteria( GeomEntity.class );
|
Criteria criteria = session.createCriteria(GeomEntity.class);
|
||||||
List<GeomEntity> retrieved = criteria.list();
|
List<GeomEntity> retrieved = criteria.list();
|
||||||
assertEquals( "Expected exactly one result", 1, retrieved.size() );
|
assertEquals("Expected exactly one result", 1, retrieved.size());
|
||||||
GeomEntity entity = retrieved.get( 0 );
|
GeomEntity entity = retrieved.get(0);
|
||||||
assertNull( entity.getGeom() );
|
assertNull(entity.getGeom());
|
||||||
tx.commit();
|
tx.commit();
|
||||||
}
|
} catch (Exception e) {
|
||||||
catch ( Exception e ) {
|
if (tx != null) {
|
||||||
if ( tx != null ) {
|
|
||||||
tx.rollback();
|
tx.rollback();
|
||||||
}
|
}
|
||||||
throw new RuntimeException( e );
|
throw new RuntimeException(e);
|
||||||
}
|
} finally {
|
||||||
finally {
|
if (session != null) {
|
||||||
if ( session != null ) {
|
|
||||||
session.close();
|
session.close();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
|
@ -1,65 +0,0 @@
|
||||||
package org.hibernate.spatial.integration;
|
|
||||||
|
|
||||||
import org.hibernate.dialect.Dialect;
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @author Karel Maesen, Geovise BVBA
|
|
||||||
* creation-date: Sep 30, 2010
|
|
||||||
*/
|
|
||||||
public class TestSupportFactories {
|
|
||||||
|
|
||||||
private static TestSupportFactories instance = new TestSupportFactories();
|
|
||||||
|
|
||||||
public static TestSupportFactories instance() {
|
|
||||||
return instance;
|
|
||||||
}
|
|
||||||
|
|
||||||
private TestSupportFactories() {
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
public TestSupport getTestSupportFactory(Dialect dialect)
|
|
||||||
throws ClassNotFoundException, InstantiationException, IllegalAccessException {
|
|
||||||
if ( dialect == null ) {
|
|
||||||
throw new IllegalArgumentException( "Dialect argument is required." );
|
|
||||||
}
|
|
||||||
String testSupportFactoryClassName = getSupportFactoryClassName( dialect );
|
|
||||||
return instantiate( testSupportFactoryClassName );
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
private TestSupport instantiate(String testSupportFactoryClassName)
|
|
||||||
throws ClassNotFoundException, IllegalAccessException, InstantiationException {
|
|
||||||
ClassLoader cloader = getClassLoader();
|
|
||||||
Class<TestSupport> cl = (Class<TestSupport>) ( cloader.loadClass( testSupportFactoryClassName ) );
|
|
||||||
return cl.newInstance();
|
|
||||||
}
|
|
||||||
|
|
||||||
private ClassLoader getClassLoader() {
|
|
||||||
return this.getClass().getClassLoader();
|
|
||||||
}
|
|
||||||
|
|
||||||
private static String getSupportFactoryClassName(Dialect dialect) {
|
|
||||||
String canonicalName = dialect.getClass().getCanonicalName();
|
|
||||||
if ( "org.hibernate.spatial.dialect.postgis.PostgisDialect".equals( canonicalName ) ) {
|
|
||||||
return "org.hibernate.spatial.integration.dialects.postgis.PostgisTestSupport";
|
|
||||||
}
|
|
||||||
// if ("org.hibernate.spatial.geodb.GeoDBDialect".equals(canonicalName)) {
|
|
||||||
// return "org.hibernate.spatial.geodb.GeoDBSupport";
|
|
||||||
// }
|
|
||||||
if ("org.hibernate.spatial.dialect.sqlserver.SqlServer2008SpatialDialect".equals(canonicalName)) {
|
|
||||||
return "org.hibernate.spatial.integration.dialects.sqlserver.SQLServerTestSupport";
|
|
||||||
}
|
|
||||||
// if ("org.hibernatespatial.mysql.MySQLSpatialDialect".equals(canonicalName) ||
|
|
||||||
// "org.hibernatespatial.mysql.MySQLSpatialInnoDBDialect".equals(canonicalName)) {
|
|
||||||
// return "org.hibernatespatial.mysql.MySQLTestSupport";
|
|
||||||
// }
|
|
||||||
if ( "org.hibernate.spatial.dialect.oracle.OracleSpatial10gDialect".equals( canonicalName ) ) {
|
|
||||||
return "org.hibernate.spatial.integration.dialects.oracle.OracleSDOTestSupport";
|
|
||||||
}
|
|
||||||
throw new IllegalArgumentException( "Dialect not known in test suite" );
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
|
@ -23,15 +23,7 @@
|
||||||
* For more information, visit: http://www.hibernatespatial.org/
|
* For more information, visit: http://www.hibernatespatial.org/
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package org.hibernate.spatial.integration;
|
package org.hibernate.spatial.testing;
|
||||||
|
|
||||||
import java.sql.Blob;
|
|
||||||
import java.sql.Connection;
|
|
||||||
import java.sql.PreparedStatement;
|
|
||||||
import java.sql.ResultSet;
|
|
||||||
import java.sql.SQLException;
|
|
||||||
import java.util.HashMap;
|
|
||||||
import java.util.Map;
|
|
||||||
|
|
||||||
import com.vividsolutions.jts.geom.Geometry;
|
import com.vividsolutions.jts.geom.Geometry;
|
||||||
import com.vividsolutions.jts.geom.Point;
|
import com.vividsolutions.jts.geom.Point;
|
||||||
|
@ -41,9 +33,13 @@ import com.vividsolutions.jts.io.WKTReader;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
|
import java.sql.*;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* An <code>AbstractExpectationsFactory</code> provides the expected
|
* An <code>AbstractExpectationsFactory</code> provides the expected
|
||||||
* values to be used in the unit tests of the spatial functions
|
* values to be used in the integration tests of the spatial functions
|
||||||
* provided by specific providers.
|
* provided by specific providers.
|
||||||
* <p/>
|
* <p/>
|
||||||
* The expected values are returned as a map of (identifier, expected value) pairs.
|
* The expected values are returned as a map of (identifier, expected value) pairs.
|
|
@ -23,7 +23,7 @@
|
||||||
* For more information, visit: http://www.hibernate.spatial.org/
|
* For more information, visit: http://www.hibernate.spatial.org/
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package org.hibernate.spatial.integration;
|
package org.hibernate.spatial.testing;
|
||||||
|
|
||||||
import com.vividsolutions.jts.geom.Geometry;
|
import com.vividsolutions.jts.geom.Geometry;
|
||||||
import com.vividsolutions.jts.io.ParseException;
|
import com.vividsolutions.jts.io.ParseException;
|
|
@ -39,7 +39,7 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
package org.hibernate.spatial.integration;
|
package org.hibernate.spatial.testing;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.Reader;
|
import java.io.Reader;
|
|
@ -23,7 +23,7 @@
|
||||||
* For more information, visit: http://www.hibernatespatial.org/
|
* For more information, visit: http://www.hibernatespatial.org/
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package org.hibernate.spatial.integration;
|
package org.hibernate.spatial.testing;
|
||||||
|
|
||||||
import com.vividsolutions.jts.geom.Coordinate;
|
import com.vividsolutions.jts.geom.Coordinate;
|
||||||
import com.vividsolutions.jts.geom.Geometry;
|
import com.vividsolutions.jts.geom.Geometry;
|
|
@ -23,7 +23,7 @@
|
||||||
* For more information, visit: http://www.hibernatespatial.org/
|
* For more information, visit: http://www.hibernatespatial.org/
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package org.hibernate.spatial.integration;
|
package org.hibernate.spatial.testing;
|
||||||
|
|
||||||
import java.sql.Connection;
|
import java.sql.Connection;
|
||||||
import java.sql.PreparedStatement;
|
import java.sql.PreparedStatement;
|
|
@ -23,7 +23,7 @@
|
||||||
* For more information, visit: http://www.hibernatespatial.org/
|
* For more information, visit: http://www.hibernatespatial.org/
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package org.hibernate.spatial.integration;
|
package org.hibernate.spatial.testing;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <code>SQLExpressoinTemplate</code>s generate database-specific
|
* <code>SQLExpressoinTemplate</code>s generate database-specific
|
|
@ -1,4 +1,4 @@
|
||||||
package org.hibernate.spatial.integration;
|
package org.hibernate.spatial.testing;
|
||||||
|
|
||||||
import org.hibernate.dialect.Dialect;
|
import org.hibernate.dialect.Dialect;
|
||||||
import org.hibernate.spatial.SpatialDialect;
|
import org.hibernate.spatial.SpatialDialect;
|
|
@ -1,4 +1,4 @@
|
||||||
package org.hibernate.spatial.integration;
|
package org.hibernate.spatial.testing;
|
||||||
|
|
||||||
import com.vividsolutions.jts.geom.Geometry;
|
import com.vividsolutions.jts.geom.Geometry;
|
||||||
import org.hibernate.Query;
|
import org.hibernate.Query;
|
||||||
|
@ -7,10 +7,10 @@ import org.hibernate.Transaction;
|
||||||
import org.hibernate.cfg.Configuration;
|
import org.hibernate.cfg.Configuration;
|
||||||
import org.hibernate.spatial.SpatialDialect;
|
import org.hibernate.spatial.SpatialDialect;
|
||||||
import org.hibernate.spatial.SpatialFunction;
|
import org.hibernate.spatial.SpatialFunction;
|
||||||
|
import org.hibernate.testing.AfterClassOnce;
|
||||||
import org.hibernate.testing.junit4.BaseCoreFunctionalTestCase;
|
import org.hibernate.testing.junit4.BaseCoreFunctionalTestCase;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
|
|
||||||
import java.sql.Connection;
|
|
||||||
import java.sql.SQLException;
|
import java.sql.SQLException;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
@ -28,7 +28,10 @@ public abstract class SpatialFunctionalTestCase extends BaseCoreFunctionalTestCa
|
||||||
protected GeometryEquality geometryEquality;
|
protected GeometryEquality geometryEquality;
|
||||||
protected AbstractExpectationsFactory expectationsFactory;
|
protected AbstractExpectationsFactory expectationsFactory;
|
||||||
|
|
||||||
public void insertTestData() {
|
/**
|
||||||
|
* Inserts the test data via a direct route (JDBC).
|
||||||
|
*/
|
||||||
|
public void prepareTest() {
|
||||||
try {
|
try {
|
||||||
dataSourceUtils.insertTestData( testData );
|
dataSourceUtils.insertTestData( testData );
|
||||||
}
|
}
|
||||||
|
@ -37,7 +40,10 @@ public abstract class SpatialFunctionalTestCase extends BaseCoreFunctionalTestCa
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void deleteAllTestEntities() {
|
/**
|
||||||
|
* Removes the test data.
|
||||||
|
*/
|
||||||
|
public void cleanupTest() {
|
||||||
Session session = null;
|
Session session = null;
|
||||||
Transaction tx = null;
|
Transaction tx = null;
|
||||||
try {
|
try {
|
||||||
|
@ -60,14 +66,24 @@ public abstract class SpatialFunctionalTestCase extends BaseCoreFunctionalTestCa
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void prepareTest() {
|
/**
|
||||||
|
* Override to also ensure that the SpatialTestSupport utility is
|
||||||
|
* initialised together with the Hibernate <code>Configuration</code>.
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
protected Configuration constructConfiguration() {
|
||||||
|
Configuration cfg = super.constructConfiguration();
|
||||||
|
initializeSpatialTestSupport(cfg);
|
||||||
|
return cfg;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void initializeSpatialTestSupport(Configuration cfg) {
|
||||||
try {
|
try {
|
||||||
TestSupport tsFactory = TestSupportFactories.instance().getTestSupportFactory( getDialect() );
|
TestSupport support = TestSupportFactories.instance().getTestSupportFactory( getDialect() );
|
||||||
Configuration cfg = configuration();
|
dataSourceUtils = support.createDataSourceUtil( cfg );
|
||||||
dataSourceUtils = tsFactory.createDataSourceUtil( cfg );
|
expectationsFactory = support.createExpectationsFactory( dataSourceUtils );
|
||||||
expectationsFactory = tsFactory.createExpectationsFactory( dataSourceUtils );
|
testData = support.createTestData( this );
|
||||||
testData = tsFactory.createTestData( this );
|
geometryEquality = support.createGeometryEquality();
|
||||||
geometryEquality = tsFactory.createGeometryEquality();
|
|
||||||
dataSourceUtils.afterCreateSchema();
|
dataSourceUtils.afterCreateSchema();
|
||||||
}
|
}
|
||||||
catch ( Exception e ) {
|
catch ( Exception e ) {
|
||||||
|
@ -75,14 +91,15 @@ public abstract class SpatialFunctionalTestCase extends BaseCoreFunctionalTestCa
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void cleanupTest() throws SQLException {
|
/**
|
||||||
|
* Cleans up the dataSourceUtils
|
||||||
|
* @throws SQLException
|
||||||
|
*/
|
||||||
|
@AfterClassOnce
|
||||||
|
public void closeDataSourceUtils() throws SQLException {
|
||||||
dataSourceUtils.close();
|
dataSourceUtils.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
public Connection getConnection() throws SQLException {
|
|
||||||
return dataSourceUtils.getConnection();
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getBaseForMappings() {
|
public String getBaseForMappings() {
|
||||||
return "";
|
return "";
|
||||||
}
|
}
|
||||||
|
@ -174,5 +191,4 @@ public abstract class SpatialFunctionalTestCase extends BaseCoreFunctionalTestCa
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
|
@ -23,7 +23,7 @@
|
||||||
* For more information, visit: http://www.hibernatespatial.org/
|
* For more information, visit: http://www.hibernatespatial.org/
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package org.hibernate.spatial.integration;
|
package org.hibernate.spatial.testing;
|
||||||
|
|
||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
|
@ -23,7 +23,7 @@
|
||||||
* For more information, visit: http://www.hibernatespatial.org/
|
* For more information, visit: http://www.hibernatespatial.org/
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package org.hibernate.spatial.integration;
|
package org.hibernate.spatial.testing;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A <code>TestDataElement</code> captures the information necessary to build a testsuite-suite geometry.
|
* A <code>TestDataElement</code> captures the information necessary to build a testsuite-suite geometry.
|
|
@ -23,7 +23,7 @@
|
||||||
* For more information, visit: http://www.hibernatespatial.org/
|
* For more information, visit: http://www.hibernatespatial.org/
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package org.hibernate.spatial.integration;
|
package org.hibernate.spatial.testing;
|
||||||
|
|
||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
|
@ -1,4 +1,4 @@
|
||||||
package org.hibernate.spatial.integration;
|
package org.hibernate.spatial.testing;
|
||||||
|
|
||||||
import org.hibernate.cfg.Configuration;
|
import org.hibernate.cfg.Configuration;
|
||||||
import org.hibernate.testing.junit4.BaseCoreFunctionalTestCase;
|
import org.hibernate.testing.junit4.BaseCoreFunctionalTestCase;
|
|
@ -0,0 +1,64 @@
|
||||||
|
package org.hibernate.spatial.testing;
|
||||||
|
|
||||||
|
import org.hibernate.dialect.Dialect;
|
||||||
|
import org.hibernate.spatial.testing.dialects.oracle.OracleSDOTestSupport;
|
||||||
|
import org.hibernate.spatial.testing.dialects.postgis.PostgisTestSupport;
|
||||||
|
import org.hibernate.spatial.testing.dialects.sqlserver.SQLServerTestSupport;
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @author Karel Maesen, Geovise BVBA
|
||||||
|
* creation-date: Sep 30, 2010
|
||||||
|
*/
|
||||||
|
public class TestSupportFactories {
|
||||||
|
|
||||||
|
private static TestSupportFactories instance = new TestSupportFactories();
|
||||||
|
|
||||||
|
public static TestSupportFactories instance() {
|
||||||
|
return instance;
|
||||||
|
}
|
||||||
|
|
||||||
|
private TestSupportFactories() {
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public TestSupport getTestSupportFactory(Dialect dialect) throws InstantiationException, IllegalAccessException {
|
||||||
|
if (dialect == null) {
|
||||||
|
throw new IllegalArgumentException("Dialect argument is required.");
|
||||||
|
}
|
||||||
|
Class testSupportFactoryClass = getSupportFactoryClass(dialect);
|
||||||
|
return instantiate(testSupportFactoryClass);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
private TestSupport instantiate(Class<? extends TestSupport> testSupportFactoryClass) throws IllegalAccessException, InstantiationException {
|
||||||
|
return testSupportFactoryClass.newInstance();
|
||||||
|
}
|
||||||
|
|
||||||
|
private ClassLoader getClassLoader() {
|
||||||
|
return this.getClass().getClassLoader();
|
||||||
|
}
|
||||||
|
|
||||||
|
private static Class<? extends TestSupport> getSupportFactoryClass(Dialect dialect) {
|
||||||
|
String canonicalName = dialect.getClass().getCanonicalName();
|
||||||
|
if ("org.hibernate.spatial.dialect.postgis.PostgisDialect".equals(canonicalName)) {
|
||||||
|
return PostgisTestSupport.class;
|
||||||
|
}
|
||||||
|
// if ("org.hibernate.spatial.geodb.GeoDBDialect".equals(canonicalName)) {
|
||||||
|
// return "org.hibernate.spatial.geodb.GeoDBSupport";
|
||||||
|
// }
|
||||||
|
if ("org.hibernate.spatial.dialect.sqlserver.SqlServer2008SpatialDialect".equals(canonicalName)) {
|
||||||
|
return SQLServerTestSupport.class;
|
||||||
|
}
|
||||||
|
// if ("org.hibernatespatial.mysql.MySQLSpatialDialect".equals(canonicalName) ||
|
||||||
|
// "org.hibernatespatial.mysql.MySQLSpatialInnoDBDialect".equals(canonicalName)) {
|
||||||
|
// return "org.hibernatespatial.mysql.MySQLTestSupport";
|
||||||
|
// }
|
||||||
|
if ("org.hibernate.spatial.dialect.oracle.OracleSpatial10gDialect".equals(canonicalName)) {
|
||||||
|
return OracleSDOTestSupport.class;
|
||||||
|
}
|
||||||
|
throw new IllegalArgumentException("Dialect not known in test suite");
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
package org.hibernate.spatial.integration.dialects.oracle;
|
package org.hibernate.spatial.testing.dialects.oracle;
|
||||||
|
|
||||||
import java.sql.Array;
|
import java.sql.Array;
|
||||||
import java.sql.Blob;
|
import java.sql.Blob;
|
|
@ -1,11 +1,11 @@
|
||||||
package org.hibernate.spatial.integration.dialects.oracle;
|
package org.hibernate.spatial.testing.dialects.oracle;
|
||||||
|
|
||||||
import org.hibernate.cfg.Configuration;
|
import org.hibernate.cfg.Configuration;
|
||||||
import org.hibernate.spatial.integration.AbstractExpectationsFactory;
|
import org.hibernate.spatial.testing.DataSourceUtils;
|
||||||
import org.hibernate.spatial.integration.DataSourceUtils;
|
import org.hibernate.spatial.testing.SQLExpressionTemplate;
|
||||||
import org.hibernate.spatial.integration.SQLExpressionTemplate;
|
import org.hibernate.spatial.testing.TestData;
|
||||||
import org.hibernate.spatial.integration.TestData;
|
import org.hibernate.spatial.testing.AbstractExpectationsFactory;
|
||||||
import org.hibernate.spatial.integration.TestSupport;
|
import org.hibernate.spatial.testing.TestSupport;
|
||||||
import org.hibernate.testing.junit4.BaseCoreFunctionalTestCase;
|
import org.hibernate.testing.junit4.BaseCoreFunctionalTestCase;
|
||||||
|
|
||||||
/**
|
/**
|
|
@ -23,12 +23,12 @@
|
||||||
* For more information, visit: http://www.hibernatespatial.org/
|
* For more information, visit: http://www.hibernatespatial.org/
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package org.hibernate.spatial.integration.dialects.oracle;
|
package org.hibernate.spatial.testing.dialects.oracle;
|
||||||
|
|
||||||
import java.sql.SQLException;
|
import java.sql.SQLException;
|
||||||
|
|
||||||
import org.hibernate.spatial.integration.DataSourceUtils;
|
import org.hibernate.spatial.testing.DataSourceUtils;
|
||||||
import org.hibernate.spatial.integration.SQLExpressionTemplate;
|
import org.hibernate.spatial.testing.SQLExpressionTemplate;
|
||||||
|
|
||||||
|
|
||||||
public class SDODataSourceUtils extends DataSourceUtils {
|
public class SDODataSourceUtils extends DataSourceUtils {
|
|
@ -23,15 +23,15 @@
|
||||||
* For more information, visit: http://www.hibernatespatial.org/
|
* For more information, visit: http://www.hibernatespatial.org/
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package org.hibernate.spatial.integration.dialects.oracle;
|
package org.hibernate.spatial.testing.dialects.oracle;
|
||||||
|
|
||||||
import com.vividsolutions.jts.geom.Geometry;
|
import com.vividsolutions.jts.geom.Geometry;
|
||||||
import com.vividsolutions.jts.geom.Point;
|
import com.vividsolutions.jts.geom.Point;
|
||||||
|
|
||||||
import org.hibernate.spatial.dialect.oracle.SDOGeometryValueExtractor;
|
import org.hibernate.spatial.dialect.oracle.SDOGeometryValueExtractor;
|
||||||
import org.hibernate.spatial.integration.AbstractExpectationsFactory;
|
import org.hibernate.spatial.testing.NativeSQLStatement;
|
||||||
import org.hibernate.spatial.integration.DataSourceUtils;
|
import org.hibernate.spatial.testing.AbstractExpectationsFactory;
|
||||||
import org.hibernate.spatial.integration.NativeSQLStatement;
|
import org.hibernate.spatial.testing.DataSourceUtils;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Expectations factory for Oracle 10g (SDOGeometry).
|
* Expectations factory for Oracle 10g (SDOGeometry).
|
|
@ -23,10 +23,10 @@
|
||||||
* For more information, visit: http://www.hibernatespatial.org/
|
* For more information, visit: http://www.hibernatespatial.org/
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package org.hibernate.spatial.integration.dialects.oracle;
|
package org.hibernate.spatial.testing.dialects.oracle;
|
||||||
|
|
||||||
import org.hibernate.spatial.integration.SQLExpressionTemplate;
|
import org.hibernate.spatial.testing.SQLExpressionTemplate;
|
||||||
import org.hibernate.spatial.integration.TestDataElement;
|
import org.hibernate.spatial.testing.TestDataElement;
|
||||||
|
|
||||||
public class SDOGeometryExpressionTemplate implements SQLExpressionTemplate {
|
public class SDOGeometryExpressionTemplate implements SQLExpressionTemplate {
|
||||||
|
|
|
@ -23,10 +23,10 @@
|
||||||
* For more information, visit: http://www.hibernatespatial.org/
|
* For more information, visit: http://www.hibernatespatial.org/
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package org.hibernate.spatial.integration.dialects.oracle;
|
package org.hibernate.spatial.testing.dialects.oracle;
|
||||||
|
|
||||||
|
|
||||||
import org.hibernate.spatial.integration.TestDataElement;
|
import org.hibernate.spatial.testing.TestDataElement;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A specialised subclass for SDOGeometry test objects
|
* A specialised subclass for SDOGeometry test objects
|
|
@ -23,14 +23,14 @@
|
||||||
* For more information, visit: http://www.hibernatespatial.org/
|
* For more information, visit: http://www.hibernatespatial.org/
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package org.hibernate.spatial.integration.dialects.oracle;
|
package org.hibernate.spatial.testing.dialects.oracle;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
import org.dom4j.Element;
|
import org.dom4j.Element;
|
||||||
|
|
||||||
import org.hibernate.spatial.integration.TestDataElement;
|
import org.hibernate.spatial.testing.TestDataElement;
|
||||||
import org.hibernate.spatial.integration.TestDataReader;
|
import org.hibernate.spatial.testing.TestDataReader;
|
||||||
|
|
||||||
|
|
||||||
public class SDOTestDataReader extends TestDataReader {
|
public class SDOTestDataReader extends TestDataReader {
|
|
@ -23,15 +23,15 @@
|
||||||
* For more information, visit: http://www.hibernatespatial.org/
|
* For more information, visit: http://www.hibernatespatial.org/
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package org.hibernate.spatial.integration.dialects.postgis;
|
package org.hibernate.spatial.testing.dialects.postgis;
|
||||||
|
|
||||||
import com.vividsolutions.jts.geom.Geometry;
|
import com.vividsolutions.jts.geom.Geometry;
|
||||||
import com.vividsolutions.jts.geom.Point;
|
import com.vividsolutions.jts.geom.Point;
|
||||||
|
|
||||||
import org.hibernate.spatial.dialect.postgis.PGGeometryValueExtractor;
|
import org.hibernate.spatial.dialect.postgis.PGGeometryValueExtractor;
|
||||||
import org.hibernate.spatial.integration.AbstractExpectationsFactory;
|
import org.hibernate.spatial.testing.NativeSQLStatement;
|
||||||
import org.hibernate.spatial.integration.DataSourceUtils;
|
import org.hibernate.spatial.testing.AbstractExpectationsFactory;
|
||||||
import org.hibernate.spatial.integration.NativeSQLStatement;
|
import org.hibernate.spatial.testing.DataSourceUtils;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This class provides the expected return values to the testsuite-suite classes in this package.
|
* This class provides the expected return values to the testsuite-suite classes in this package.
|
|
@ -23,10 +23,10 @@
|
||||||
* For more information, visit: http://www.hibernatespatial.org/
|
* For more information, visit: http://www.hibernatespatial.org/
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package org.hibernate.spatial.integration.dialects.postgis;
|
package org.hibernate.spatial.testing.dialects.postgis;
|
||||||
|
|
||||||
import org.hibernate.spatial.integration.SQLExpressionTemplate;
|
import org.hibernate.spatial.testing.SQLExpressionTemplate;
|
||||||
import org.hibernate.spatial.integration.TestDataElement;
|
import org.hibernate.spatial.testing.TestDataElement;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The template for postgis insert SQL
|
* The template for postgis insert SQL
|
|
@ -1,11 +1,11 @@
|
||||||
package org.hibernate.spatial.integration.dialects.postgis;
|
package org.hibernate.spatial.testing.dialects.postgis;
|
||||||
|
|
||||||
|
|
||||||
import org.hibernate.spatial.integration.AbstractExpectationsFactory;
|
import org.hibernate.spatial.testing.DataSourceUtils;
|
||||||
import org.hibernate.spatial.integration.DataSourceUtils;
|
import org.hibernate.spatial.testing.SQLExpressionTemplate;
|
||||||
import org.hibernate.spatial.integration.SQLExpressionTemplate;
|
import org.hibernate.spatial.testing.TestData;
|
||||||
import org.hibernate.spatial.integration.TestData;
|
import org.hibernate.spatial.testing.AbstractExpectationsFactory;
|
||||||
import org.hibernate.spatial.integration.TestSupport;
|
import org.hibernate.spatial.testing.TestSupport;
|
||||||
import org.hibernate.testing.junit4.BaseCoreFunctionalTestCase;
|
import org.hibernate.testing.junit4.BaseCoreFunctionalTestCase;
|
||||||
|
|
||||||
/**
|
/**
|
|
@ -23,10 +23,10 @@
|
||||||
* For more information, visit: http://www.hibernatespatial.org/
|
* For more information, visit: http://www.hibernatespatial.org/
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package org.hibernate.spatial.integration.dialects.sqlserver;
|
package org.hibernate.spatial.testing.dialects.sqlserver;
|
||||||
|
|
||||||
import org.hibernate.spatial.integration.SQLExpressionTemplate;
|
import org.hibernate.spatial.testing.SQLExpressionTemplate;
|
||||||
import org.hibernate.spatial.integration.TestDataElement;
|
import org.hibernate.spatial.testing.TestDataElement;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author Karel Maesen, Geovise BVBA
|
* @author Karel Maesen, Geovise BVBA
|
|
@ -1,9 +1,9 @@
|
||||||
package org.hibernate.spatial.integration.dialects.sqlserver;
|
package org.hibernate.spatial.testing.dialects.sqlserver;
|
||||||
|
|
||||||
import org.hibernate.spatial.integration.DataSourceUtils;
|
import org.hibernate.spatial.testing.SQLExpressionTemplate;
|
||||||
import org.hibernate.spatial.integration.SQLExpressionTemplate;
|
import org.hibernate.spatial.testing.TestData;
|
||||||
import org.hibernate.spatial.integration.TestData;
|
import org.hibernate.spatial.testing.DataSourceUtils;
|
||||||
import org.hibernate.spatial.integration.TestSupport;
|
import org.hibernate.spatial.testing.TestSupport;
|
||||||
import org.hibernate.testing.junit4.BaseCoreFunctionalTestCase;
|
import org.hibernate.testing.junit4.BaseCoreFunctionalTestCase;
|
||||||
|
|
||||||
/**
|
/**
|
|
@ -23,15 +23,15 @@
|
||||||
* For more information, visit: http://www.hibernatespatial.org/
|
* For more information, visit: http://www.hibernatespatial.org/
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package org.hibernate.spatial.integration.dialects.sqlserver;
|
package org.hibernate.spatial.testing.dialects.sqlserver;
|
||||||
|
|
||||||
import com.vividsolutions.jts.geom.Geometry;
|
import com.vividsolutions.jts.geom.Geometry;
|
||||||
import com.vividsolutions.jts.geom.Point;
|
import com.vividsolutions.jts.geom.Point;
|
||||||
|
|
||||||
import org.hibernate.spatial.dialect.sqlserver.convertors.Decoders;
|
import org.hibernate.spatial.dialect.sqlserver.convertors.Decoders;
|
||||||
import org.hibernate.spatial.integration.AbstractExpectationsFactory;
|
import org.hibernate.spatial.testing.NativeSQLStatement;
|
||||||
import org.hibernate.spatial.integration.DataSourceUtils;
|
import org.hibernate.spatial.testing.AbstractExpectationsFactory;
|
||||||
import org.hibernate.spatial.integration.NativeSQLStatement;
|
import org.hibernate.spatial.testing.DataSourceUtils;
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
|
@ -22,7 +22,7 @@
|
||||||
*
|
*
|
||||||
* For more information, visit: http://www.hibernatespatial.org/
|
* For more information, visit: http://www.hibernatespatial.org/
|
||||||
*/
|
*/
|
||||||
package org.hibernate.spatial.integration.dialects.sqlserver.convertors;
|
package org.hibernate.spatial.testing.dialects.sqlserver.convertors;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author Karel Maesen, Geovise BVBA.
|
* @author Karel Maesen, Geovise BVBA.
|
||||||
|
@ -33,12 +33,12 @@ import com.vividsolutions.jts.geom.Geometry;
|
||||||
import org.hibernate.spatial.dialect.sqlserver.convertors.Decoders;
|
import org.hibernate.spatial.dialect.sqlserver.convertors.Decoders;
|
||||||
import org.hibernate.spatial.dialect.sqlserver.convertors.Encoders;
|
import org.hibernate.spatial.dialect.sqlserver.convertors.Encoders;
|
||||||
import org.hibernate.spatial.dialect.sqlserver.convertors.OpenGisType;
|
import org.hibernate.spatial.dialect.sqlserver.convertors.OpenGisType;
|
||||||
import org.hibernate.spatial.integration.DataSourceUtils;
|
import org.hibernate.spatial.testing.DataSourceUtils;
|
||||||
import org.hibernate.spatial.integration.SpatialFunctionalTestCase;
|
import org.hibernate.spatial.testing.TestData;
|
||||||
import org.hibernate.spatial.integration.TestData;
|
import org.hibernate.spatial.testing.dialects.sqlserver.SQLServerExpressionTemplate;
|
||||||
import org.hibernate.spatial.integration.TestSupport;
|
import org.hibernate.spatial.testing.dialects.sqlserver.SQLServerTestSupport;
|
||||||
import org.hibernate.spatial.integration.dialects.sqlserver.SQLServerExpressionTemplate;
|
import org.hibernate.spatial.testing.SpatialFunctionalTestCase;
|
||||||
import org.hibernate.spatial.integration.dialects.sqlserver.SQLServerTestSupport;
|
import org.hibernate.spatial.testing.TestSupport;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
|
@ -23,7 +23,7 @@
|
||||||
* For more information, visit: http://www.hibernatespatial.org/
|
* For more information, visit: http://www.hibernatespatial.org/
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package org.hibernate.spatial.integration.dialects.sqlserver.convertors;
|
package org.hibernate.spatial.testing.dialects.sqlserver.convertors;
|
||||||
|
|
||||||
import org.hibernate.spatial.dialect.sqlserver.SqlServer2008SpatialDialect;
|
import org.hibernate.spatial.dialect.sqlserver.SqlServer2008SpatialDialect;
|
||||||
import org.hibernate.spatial.dialect.sqlserver.convertors.OpenGisType;
|
import org.hibernate.spatial.dialect.sqlserver.convertors.OpenGisType;
|
|
@ -23,7 +23,7 @@
|
||||||
* For more information, visit: http://www.hibernatespatial.org/
|
* For more information, visit: http://www.hibernatespatial.org/
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package org.hibernate.spatial.integration.dialects.sqlserver.convertors;
|
package org.hibernate.spatial.testing.dialects.sqlserver.convertors;
|
||||||
|
|
||||||
import com.vividsolutions.jts.geom.Coordinate;
|
import com.vividsolutions.jts.geom.Coordinate;
|
||||||
import com.vividsolutions.jts.geom.LineString;
|
import com.vividsolutions.jts.geom.LineString;
|
|
@ -23,7 +23,7 @@
|
||||||
* For more information, visit: http://www.hibernatespatial.org/
|
* For more information, visit: http://www.hibernatespatial.org/
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package org.hibernate.spatial.integration.dialects.sqlserver.convertors;
|
package org.hibernate.spatial.testing.dialects.sqlserver.convertors;
|
||||||
|
|
||||||
import org.hibernate.spatial.dialect.sqlserver.SqlServer2008SpatialDialect;
|
import org.hibernate.spatial.dialect.sqlserver.SqlServer2008SpatialDialect;
|
||||||
import org.hibernate.spatial.dialect.sqlserver.convertors.OpenGisType;
|
import org.hibernate.spatial.dialect.sqlserver.convertors.OpenGisType;
|
|
@ -23,7 +23,7 @@
|
||||||
* For more information, visit: http://www.hibernatespatial.org/
|
* For more information, visit: http://www.hibernatespatial.org/
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package org.hibernate.spatial.integration.dialects.sqlserver.convertors;
|
package org.hibernate.spatial.testing.dialects.sqlserver.convertors;
|
||||||
|
|
||||||
import org.hibernate.spatial.dialect.sqlserver.SqlServer2008SpatialDialect;
|
import org.hibernate.spatial.dialect.sqlserver.SqlServer2008SpatialDialect;
|
||||||
import org.hibernate.spatial.dialect.sqlserver.convertors.OpenGisType;
|
import org.hibernate.spatial.dialect.sqlserver.convertors.OpenGisType;
|
|
@ -23,7 +23,7 @@
|
||||||
* For more information, visit: http://www.hibernatespatial.org/
|
* For more information, visit: http://www.hibernatespatial.org/
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package org.hibernate.spatial.integration.dialects.sqlserver.convertors;
|
package org.hibernate.spatial.testing.dialects.sqlserver.convertors;
|
||||||
|
|
||||||
import org.hibernate.spatial.dialect.sqlserver.SqlServer2008SpatialDialect;
|
import org.hibernate.spatial.dialect.sqlserver.SqlServer2008SpatialDialect;
|
||||||
import org.hibernate.spatial.dialect.sqlserver.convertors.OpenGisType;
|
import org.hibernate.spatial.dialect.sqlserver.convertors.OpenGisType;
|
|
@ -23,7 +23,7 @@
|
||||||
* For more information, visit: http://www.hibernatespatial.org/
|
* For more information, visit: http://www.hibernatespatial.org/
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package org.hibernate.spatial.integration.dialects.sqlserver.convertors;
|
package org.hibernate.spatial.testing.dialects.sqlserver.convertors;
|
||||||
|
|
||||||
import com.vividsolutions.jts.geom.Coordinate;
|
import com.vividsolutions.jts.geom.Coordinate;
|
||||||
import com.vividsolutions.jts.geom.Point;
|
import com.vividsolutions.jts.geom.Point;
|
|
@ -23,7 +23,7 @@
|
||||||
* For more information, visit: http://www.hibernatespatial.org/
|
* For more information, visit: http://www.hibernatespatial.org/
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package org.hibernate.spatial.integration.dialects.sqlserver.convertors;
|
package org.hibernate.spatial.testing.dialects.sqlserver.convertors;
|
||||||
|
|
||||||
import org.hibernate.spatial.dialect.sqlserver.SqlServer2008SpatialDialect;
|
import org.hibernate.spatial.dialect.sqlserver.SqlServer2008SpatialDialect;
|
||||||
import org.hibernate.spatial.dialect.sqlserver.convertors.OpenGisType;
|
import org.hibernate.spatial.dialect.sqlserver.convertors.OpenGisType;
|
|
@ -1,42 +0,0 @@
|
||||||
<?xml version="1.0"?>
|
|
||||||
<!--
|
|
||||||
~ $Id: GeomEntity.hbm.xml 242 2010-09-22 20:40:07Z maesenka $
|
|
||||||
~
|
|
||||||
~ This file is part of Hibernate Spatial, an extension to the
|
|
||||||
~ hibernate ORM solution for geographic data.
|
|
||||||
~
|
|
||||||
~ Copyright © 2007-2010 Geovise BVBA
|
|
||||||
~
|
|
||||||
~ This library is free software; you can redistribute it and/or
|
|
||||||
~ modify it under the terms of the GNU Lesser General Public
|
|
||||||
~ License as published by the Free Software Foundation; either
|
|
||||||
~ version 2.1 of the License, or (at your option) any later version.
|
|
||||||
~
|
|
||||||
~ This library is distributed in the hope that it will be useful,
|
|
||||||
~ but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
~ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
||||||
~ Lesser General Public License for more details.
|
|
||||||
~
|
|
||||||
~ You should have received a copy of the GNU Lesser General Public
|
|
||||||
~ License along with this library; if not, write to the Free Software
|
|
||||||
~ Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
||||||
~
|
|
||||||
~ For more information, visit: http://www.hibernatespatial.org/
|
|
||||||
-->
|
|
||||||
|
|
||||||
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
|
|
||||||
" http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
|
|
||||||
|
|
||||||
<hibernate-mapping>
|
|
||||||
<class name="org.hibernate.spatial.integration.GeomEntity" table="GEOMTEST">
|
|
||||||
<id name="id" type="integer">
|
|
||||||
<generator class="assigned"/>
|
|
||||||
</id>
|
|
||||||
<property name="type" type="string">
|
|
||||||
<column name="type" length="50"/>
|
|
||||||
</property>
|
|
||||||
<property name="geom" type="org.hibernate.spatial.GeometryType">
|
|
||||||
<column name="geom"/>
|
|
||||||
</property>
|
|
||||||
</class>
|
|
||||||
</hibernate-mapping>
|
|
|
@ -1,9 +0,0 @@
|
||||||
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
|
|
||||||
log4j.appender.stdout.Target=System.out
|
|
||||||
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
|
|
||||||
log4j.appender.stdout.layout.ConversionPattern=%d{ABSOLUTE} %5p %c{1}:%L - %m%n
|
|
||||||
|
|
||||||
|
|
||||||
log4j.rootLogger=info, stdout
|
|
||||||
|
|
||||||
log4j.logger.org.hibernate.spatial=debug
|
|
|
@ -24,31 +24,31 @@
|
||||||
|
|
||||||
# Default unit/integration test config.
|
# Default unit/integration test config.
|
||||||
|
|
||||||
hibernate.dialect org.hibernate.dialect.H2Dialect
|
#hibernate.dialect org.hibernate.dialect.H2Dialect
|
||||||
hibernate.connection.driver_class org.h2.Driver
|
#hibernate.connection.driver_class org.h2.Driver
|
||||||
hibernate.connection.url jdbc:h2:mem:db1;DB_CLOSE_DELAY=-1;MVCC=TRUE
|
#hibernate.connection.url jdbc:h2:mem:db1;DB_CLOSE_DELAY=-1;MVCC=TRUE
|
||||||
hibernate.connection.username sa
|
#hibernate.connection.username sa
|
||||||
|
#
|
||||||
hibernate.connection.pool_size 5
|
#hibernate.connection.pool_size 5
|
||||||
|
#
|
||||||
hibernate.show_sql false
|
#hibernate.show_sql false
|
||||||
|
#
|
||||||
hibernate.max_fetch_depth 5
|
#hibernate.max_fetch_depth 5
|
||||||
|
#
|
||||||
hibernate.cache.region_prefix hibernate.test
|
#hibernate.cache.region_prefix hibernate.test
|
||||||
hibernate.cache.region.factory_class org.hibernate.testing.cache.CachingRegionFactory
|
#hibernate.cache.region.factory_class org.hibernate.testing.cache.CachingRegionFactory
|
||||||
|
#
|
||||||
# NOTE: hibernate.jdbc.batch_versioned_data should be set to false when testing with Oracle
|
## NOTE: hibernate.jdbc.batch_versioned_data should be set to false when testing with Oracle
|
||||||
hibernate.jdbc.batch_versioned_data true
|
#hibernate.jdbc.batch_versioned_data true
|
||||||
|
|
||||||
|
|
||||||
## Configs for spatial databases (used during testin on local dev environment).
|
## Configs for spatial databases (used during testing on local dev environment).
|
||||||
|
|
||||||
#hibernate.dialect org.hibernate.spatial.dialect.postgis.PostgisDialect
|
hibernate.dialect org.hibernate.spatial.dialect.postgis.PostgisDialect
|
||||||
#hibernate.connection.driver_class org.postgresql.Driver
|
hibernate.connection.driver_class org.postgresql.Driver
|
||||||
#hibernate.connection.url jdbc:postgresql://localhost:5432:hibbrtru
|
hibernate.connection.url jdbc:postgresql://localhost:5432:hibbrtru
|
||||||
#hibernate.connection.username hibbrtru
|
hibernate.connection.username hibbrtru
|
||||||
#hibernate.connection.password hibbrtru
|
hibernate.connection.password hibbrtru
|
||||||
|
|
||||||
#hibernate.dialect org.hibernate.spatial.dialect.oracle.OracleSpatial10gDialect
|
#hibernate.dialect org.hibernate.spatial.dialect.oracle.OracleSpatial10gDialect
|
||||||
#hibernate.connection.driver_class oracle.jdbc.driver.OracleDriver
|
#hibernate.connection.driver_class oracle.jdbc.driver.OracleDriver
|
||||||
|
|
Loading…
Reference in New Issue