/* * Copyright (c) 2016 Vivid Solutions. * * All rights reserved. This program and the accompanying materials * are made available under the terms of the Eclipse Public License v1.0 * and Eclipse Distribution License v. 1.0 which accompanies this distribution. * The Eclipse Public License is available at http://www.eclipse.org/legal/epl-v10.html * and the Eclipse Distribution License is available at * * http://www.eclipse.org/org/documents/edl-v10.php. */ package org.locationtech.jts.io.oracle; import java.util.ArrayList; import java.util.List; import org.locationtech.jts.geom.Coordinate; import org.locationtech.jts.geom.Geometry; import org.locationtech.jts.geom.GeometryCollection; import org.locationtech.jts.geom.GeometryFactory; import org.locationtech.jts.geom.LineString; import org.locationtech.jts.geom.Point; import org.locationtech.jts.io.ParseException; import org.locationtech.jts.io.WKTReader; import org.locationtech.jts.io.oracle.OraGeom; import org.locationtech.jts.io.oracle.OraReader; /** * Tests {@link OraReader} without requiring an Oracle connection. * * @author mbdavis * */ public class OraReaderCreateTest extends BaseOraTestCase { public static void main(String[] args) { junit.textui.TestRunner.run(OraReaderCreateTest.class); } WKTReader wktRdr = new WKTReader(); public OraReaderCreateTest(String arg){ super(arg); } //TODO: tests for ETYPE=POLYGON (mixture of holes and shells //TODO: tests with mixed ETYPE=POLYGON & POLYGON_EXTERIOR public void testXY_Point() throws Exception { OraGeom oraGeom = MDSYS.SDO_GEOMETRY(2001,NULL,NULL,MDSYS.SDO_ELEM_INFO_ARRAY(1,1,1),MDSYS.SDO_ORDINATE_ARRAY(50,50)); checkValue(oraGeom, "POINT (50 50)"); } public void testXYM_Point() throws Exception { OraGeom oraGeom = MDSYS.SDO_GEOMETRY(3301,NULL,NULL,MDSYS.SDO_ELEM_INFO_ARRAY(1,1,1), MDSYS.SDO_ORDINATE_ARRAY(50,50,100)); checkValue(oraGeom, 3, "POINT (50 50 100)"); } public void testXYZM_Point() throws Exception { OraGeom oraGeom = MDSYS.SDO_GEOMETRY(4001,NULL,NULL,MDSYS.SDO_ELEM_INFO_ARRAY(1,1,1), MDSYS.SDO_ORDINATE_ARRAY(50,50,100,200)); checkValue(oraGeom, 3, "POINT (50 50 100)"); } public void testXYZ_PointType() throws Exception { OraGeom oraGeom = MDSYS.SDO_GEOMETRY(3001,NULL, MDSYS.SDO_POINT_TYPE(50,50,100),NULL,NULL); checkValue(oraGeom, "POINT (50 50 100)"); } public void testXY_OrientedPoint() throws Exception { OraGeom oraGeom = MDSYS.SDO_GEOMETRY(2001,NULL,NULL,MDSYS.SDO_ELEM_INFO_ARRAY(1,1,1, 3,1,0),MDSYS.SDO_ORDINATE_ARRAY(12,14, 0.3,0.2)); checkValue(oraGeom, "POINT (12 14)"); } public void testXYZ_OrientedPoint() throws Exception { OraGeom oraGeom = MDSYS.SDO_GEOMETRY(2001,NULL,NULL,MDSYS.SDO_ELEM_INFO_ARRAY(1,1,1, 3,1,0),MDSYS.SDO_ORDINATE_ARRAY(12,14, 0.3,0.2)); checkValue(oraGeom, "POINT (12 14)"); } public void testXY_MultiPoint_MultiElem() throws Exception { OraGeom oraGeom = MDSYS.SDO_GEOMETRY(2005,32639,NULL,MDSYS.SDO_ELEM_INFO_ARRAY(1,1,1,3,1,1),MDSYS.SDO_ORDINATE_ARRAY(548810.5,3956383.4, 548766.8,3956415.9)); checkValue(oraGeom, "MULTIPOINT ((548810.5 3956383.4), (548766.8 3956415.9))"); } public void testXYM_MultiPoint_MultiElem() throws Exception { OraGeom oraGeom = MDSYS.SDO_GEOMETRY(3005,8307,NULL,MDSYS.SDO_ELEM_INFO_ARRAY(1,1,1,4,1,1), MDSYS.SDO_ORDINATE_ARRAY(1,1,99, 2,2,99)); checkValue(oraGeom, "MULTIPOINT ((1 1), (2 2))"); } public void testXYZ_MultiPoint() throws Exception { OraGeom oraGeom = MDSYS.SDO_GEOMETRY(3005,NULL,NULL,MDSYS.SDO_ELEM_INFO_ARRAY(1,1,2), MDSYS.SDO_ORDINATE_ARRAY(50,50,5, 100,200,300)); checkValue(oraGeom, "MULTIPOINT ((50 50 5), (100 200 300))"); } public void testXY_LineString() throws Exception { OraGeom oraGeom = MDSYS.SDO_GEOMETRY(2002,NULL,NULL,MDSYS.SDO_ELEM_INFO_ARRAY(1,2,1), MDSYS.SDO_ORDINATE_ARRAY(0,0,50,50)); checkValue(oraGeom, "LINESTRING (0 0, 50 50)"); } public void testXYZ_LineString() throws Exception { OraGeom oraGeom = MDSYS.SDO_GEOMETRY(3002,NULL,NULL,MDSYS.SDO_ELEM_INFO_ARRAY(1,2,1), MDSYS.SDO_ORDINATE_ARRAY(0,0,0,50,50,100)); checkValue(oraGeom, "LINESTRING (0 0 0, 50 50 100)"); } public void testXYM_LineString() throws Exception { OraGeom oraGeom = MDSYS.SDO_GEOMETRY(3302,NULL,NULL,MDSYS.SDO_ELEM_INFO_ARRAY(1, 2, 1), MDSYS.SDO_ORDINATE_ARRAY(1, 1, 20, 2, 2, 30)); checkValue(oraGeom, "LINESTRING (1 1, 2 2)"); } public void testXYZM_LineString() throws Exception { OraGeom oraGeom = MDSYS.SDO_GEOMETRY(4402,8307,NULL,MDSYS.SDO_ELEM_INFO_ARRAY(1,2,1), MDSYS.SDO_ORDINATE_ARRAY(0,0,2,3,50,50,100,200)); checkValue(oraGeom, "LINESTRING (0 0, 50 50)"); } public void testXYMZ_LineString() throws Exception { OraGeom oraGeom = MDSYS.SDO_GEOMETRY(4302,8307,NULL,MDSYS.SDO_ELEM_INFO_ARRAY(1,2,1), MDSYS.SDO_ORDINATE_ARRAY(0,0,2,3,50,50,100,200)); checkValue(oraGeom, "LINESTRING (0 0, 50 50)"); } public void testXYZ_MultiLineString() throws Exception { OraGeom oraGeom = MDSYS.SDO_GEOMETRY(3006,8307,NULL,MDSYS.SDO_ELEM_INFO_ARRAY(1,2,1,7,2,1), MDSYS.SDO_ORDINATE_ARRAY(0,0,2,50,50,100,10,10,12,150,150,110)); checkValue(oraGeom, "MULTILINESTRING ((0 0, 50 50), (10 10, 150 150))"); } public void testXYM_MultiLineString() throws Exception { OraGeom oraGeom = MDSYS.SDO_GEOMETRY(3306,8307,NULL,MDSYS.SDO_ELEM_INFO_ARRAY(1,2,1,7,2,1), MDSYS.SDO_ORDINATE_ARRAY(0,0,2,50,50,100,10,10,12,150,150,110)); checkValue(oraGeom, "MULTILINESTRING ((0 0, 50 50), (10 10, 150 150))"); } public void testXYZM_MultiLineString() throws Exception { OraGeom oraGeom = MDSYS.SDO_GEOMETRY(4406,8307,NULL,MDSYS.SDO_ELEM_INFO_ARRAY(1,2,1,9,2,1), MDSYS.SDO_ORDINATE_ARRAY(0,0,2,3,50,50,100,200,10,10,12,13,150,150,110,210)); checkValue(oraGeom, "MULTILINESTRING ((0 0, 50 50), (10 10, 150 150))"); } public void testXYMZ_MultiLineString() throws Exception { OraGeom oraGeom = MDSYS.SDO_GEOMETRY(4306,8307,NULL,MDSYS.SDO_ELEM_INFO_ARRAY(1,2,1,9,2,1), MDSYS.SDO_ORDINATE_ARRAY(0,0,2,3,50,50,100,200,10,10,12,13,150,150,110,210)); checkValue(oraGeom, "MULTILINESTRING ((0 0, 50 50), (10 10, 150 150))"); } public void testXY_Polygon() throws Exception { OraGeom oraGeom = MDSYS.SDO_GEOMETRY(2003,NULL,NULL,MDSYS.SDO_ELEM_INFO_ARRAY(1,1003,1), MDSYS.SDO_ORDINATE_ARRAY(0,0,50,0,50,50,0,50,0,0)); checkValue(oraGeom, "POLYGON ((0 0, 50 0, 50 50, 0 50, 0 0))"); } public void testXYZ_Polygon() throws Exception { OraGeom oraGeom = MDSYS.SDO_GEOMETRY(3003,NULL,NULL,MDSYS.SDO_ELEM_INFO_ARRAY(1,1003,1), MDSYS.SDO_ORDINATE_ARRAY(0,0,99,50,0,99,50,50,99,0,50,99,0,0,99)); checkValue(oraGeom, "POLYGON ((0 0, 50 0, 50 50, 0 50, 0 0))"); } public void testXYM_Polygon() throws Exception { OraGeom oraGeom = MDSYS.SDO_GEOMETRY(3303,NULL,NULL,MDSYS.SDO_ELEM_INFO_ARRAY(1,1003,1), MDSYS.SDO_ORDINATE_ARRAY(0,0,99,50,0,99,50,50,99,0,50,99,0,0,99)); checkValue(oraGeom, "POLYGON ((0 0, 50 0, 50 50, 0 50, 0 0))"); } public void testXYZ_PolygonWithHole() throws Exception { checkValue( MDSYS.SDO_GEOMETRY(3003, NULL, NULL, MDSYS.SDO_ELEM_INFO_ARRAY(1,1003,1, 28,2003,1), MDSYS.SDO_ORDINATE_ARRAY(2,4,99, 4,3,99, 10,3,99, 13,5,99, 13,9,99, 11,13,99, 5,13,99, 2,11,99, 2,4,99, 7,5,99, 7,10,99, 10,10,99, 10,5,99, 7,5,99 ) ), "POLYGON ((2 4, 4 3, 10 3, 13 5, 13 9, 11 13, 5 13, 2 11, 2 4), (7 5, 7 10, 10 10, 10 5, 7 5))"); } public void testXYM_PolygonWithHole() throws Exception { checkValue( MDSYS.SDO_GEOMETRY(3303, NULL, NULL, MDSYS.SDO_ELEM_INFO_ARRAY(1,1003,1, 28,2003,1), MDSYS.SDO_ORDINATE_ARRAY(2,4,99, 4,3,99, 10,3,99, 13,5,99, 13,9,99, 11,13,99, 5,13,99, 2,11,99, 2,4,99, 7,5,99, 7,10,99, 10,10,99, 10,5,99, 7,5,99 ) ), "POLYGON ((2 4, 4 3, 10 3, 13 5, 13 9, 11 13, 5 13, 2 11, 2 4), (7 5, 7 10, 10 10, 10 5, 7 5))"); } public void testXY_RectangleMultiPolygon() throws Exception { OraGeom oraGeom = MDSYS.SDO_GEOMETRY(2007,NULL,NULL,MDSYS.SDO_ELEM_INFO_ARRAY(1,1003,3,5,2003,3,9,1003,3), MDSYS.SDO_ORDINATE_ARRAY(0,0,50,50,40,40,20,20,60,0,70,10)); checkValue(oraGeom, "MULTIPOLYGON (((0 0, 50 0, 50 50, 0 50, 0 0), (40 40, 20 40, 20 20, 40 20, 40 40)), ((60 0, 70 0, 70 10, 60 10, 60 0)))"); } public void testXY_Rectangle() throws Exception { OraGeom oraGeom = MDSYS.SDO_GEOMETRY(2003,NULL,NULL,MDSYS.SDO_ELEM_INFO_ARRAY(1,1003,3), MDSYS.SDO_ORDINATE_ARRAY(0,0,50,50)); checkValue(oraGeom, "POLYGON ((0 0, 50 0, 50 50, 0 50, 0 0))"); } public void testXY_RectangleHole() throws Exception { OraGeom oraGeom = MDSYS.SDO_GEOMETRY(2003,NULL,NULL,MDSYS.SDO_ELEM_INFO_ARRAY(1,1003,3, 5,2003,3), MDSYS.SDO_ORDINATE_ARRAY(0,0,50,50, 40,40,20,20)); checkValue(oraGeom, "POLYGON ((0 0, 50 0, 50 50, 0 50, 0 0), (40 40, 20 40, 20 20, 40 20, 40 40))"); } //==================================================================================== // Cases from Oracle documentation public void testXY_Point_Doc() throws Exception { checkValue( MDSYS.SDO_GEOMETRY(2001, NULL, MDSYS.SDO_POINT_TYPE(-79, 37, NULL), NULL, NULL), "POINT (-79 37)"); } public void testXY_Rectangle_Doc() throws Exception { checkValue( MDSYS.SDO_GEOMETRY(2003, NULL, NULL, MDSYS.SDO_ELEM_INFO_ARRAY(1,1003,3), MDSYS.SDO_ORDINATE_ARRAY(1,1, 5,7) ), "POLYGON ((1 1, 5 1, 5 7, 1 7, 1 1))"); } public void testXY_PolygonWithHole_Doc() throws Exception { checkValue( MDSYS.SDO_GEOMETRY(2003, NULL, NULL, MDSYS.SDO_ELEM_INFO_ARRAY(1,1003,1, 19,2003,1), MDSYS.SDO_ORDINATE_ARRAY(2,4, 4,3, 10,3, 13,5, 13,9, 11,13, 5,13, 2,11, 2,4, 7,5, 7,10, 10,10, 10,5, 7,5) ), "POLYGON ((2 4, 4 3, 10 3, 13 5, 13 9, 11 13, 5 13, 2 11, 2 4), (7 5, 7 10, 10 10, 10 5, 7 5))"); } public void testXY_GeometryCollection_Doc() throws Exception { checkValue( MDSYS.SDO_GEOMETRY(2004, NULL, NULL, MDSYS.SDO_ELEM_INFO_ARRAY(1,1,1, 3,2,1, 7,1003,1, 17,1003,1, 25,2003,1), MDSYS.SDO_ORDINATE_ARRAY( 1,1, 1,2, 2,1, 2,2, 3,2, 3,3, 2,3, 2,2, 5,1, 9,5, 5,5, 5,1, 5,3, 6,4, 6,3, 5,3 ) ), "GEOMETRYCOLLECTION (POINT (1 1), LINESTRING (1 2, 2 1), POLYGON ((2 2, 3 2, 3 3, 2 3, 2 2)), POLYGON ((5 1, 9 5, 5 5, 5 1), (5 3, 6 4, 6 3, 5 3)))"); } public void testXYM_GeometryCollection_Doc() throws Exception { checkValue( MDSYS.SDO_GEOMETRY(3304, NULL, NULL, MDSYS.SDO_ELEM_INFO_ARRAY(1,1,1, 4,2,1, 10,1003,1, 25,1003,1, 37,2003,1), MDSYS.SDO_ORDINATE_ARRAY( 1,1,99, 1,2,99, 2,1,99, 2,2,99, 3,2,99, 3,3,99, 2,3,99, 2,2,99, 5,1,99, 9,5,99, 5,5,99, 5,1,99, 5,3,99, 6,4,99, 6,3,99, 5,3,99 ) ), "GEOMETRYCOLLECTION (POINT (1 1), LINESTRING (1 2, 2 1), POLYGON ((2 2, 3 2, 3 3, 2 3, 2 2)), POLYGON ((5 1, 9 5, 5 5, 5 1), (5 3, 6 4, 6 3, 5 3)))"); } //==================================================================================== // Cases from GeoTools public void testXY_LineString_GT() throws Exception { checkValue( MDSYS.SDO_GEOMETRY(2002, NULL, NULL, MDSYS.SDO_ELEM_INFO_ARRAY(1,2,1), MDSYS.SDO_ORDINATE_ARRAY(1,2, 2,1, 3,1, 4,2, 4,7)), "LINESTRING (1 2, 2 1, 3 1, 4 2, 4 7)"); } public void testXY_MultiLineString_GT() throws Exception { checkValue( MDSYS.SDO_GEOMETRY(2006, NULL, NULL, MDSYS.SDO_ELEM_INFO_ARRAY(1,2,1,11,2,1), MDSYS.SDO_ORDINATE_ARRAY(1,2, 2,1, 3,1, 4,2, 4,7, 2,7, 4,7, 5,7)), "MULTILINESTRING ((1 2, 2 1, 3 1, 4 2, 4 7), (2 7, 4 7, 5 7))"); } public void testXY_Triangle_GT() throws Exception { checkValue(MDSYS.SDO_GEOMETRY(2003, NULL, NULL, MDSYS.SDO_ELEM_INFO_ARRAY(1,1003,1), MDSYS.SDO_ORDINATE_ARRAY(9,5, 13,5, 11,8, 9,5)), "POLYGON ((9 5, 13 5, 11 8, 9 5))"); } public void testXY_MultiPolygon_GT() throws Exception { checkValue( MDSYS.SDO_GEOMETRY(2007, NULL, NULL, MDSYS.SDO_ELEM_INFO_ARRAY(1,1003,1, 11,1003,1), MDSYS.SDO_ORDINATE_ARRAY(2,3, 7,3, 7,9, 2,9, 2,3, 9,5, 13,5, 11,5, 9,5) ), "MULTIPOLYGON (((2 3, 7 3, 7 9, 2 9, 2 3)), ((9 5, 13 5, 11 5, 9 5)))"); } public void testXYZ_MultiPolygon() throws Exception { checkValue( MDSYS.SDO_GEOMETRY(3007, NULL, NULL, MDSYS.SDO_ELEM_INFO_ARRAY(1,1003,1, 16,1003,1), MDSYS.SDO_ORDINATE_ARRAY(2,3,99, 7,3,99, 7,9,99, 2,9,99, 2,3,99, 9,5,99, 13,5,99, 11,5,99, 9,5,99 ) ), "MULTIPOLYGON (((2 3, 7 3, 7 9, 2 9, 2 3)), ((9 5, 13 5, 11 5, 9 5)))"); } public void testXYM_MultiPolygon() throws Exception { checkValue( MDSYS.SDO_GEOMETRY(3307, NULL, NULL, MDSYS.SDO_ELEM_INFO_ARRAY(1,1003,1, 16,1003,1), MDSYS.SDO_ORDINATE_ARRAY(2,3,99, 7,3,99, 7,9,99, 2,9,99, 2,3,99, 9,5,99, 13,5,99, 11,5,99, 9,5,99 ) ), "MULTIPOLYGON (((2 3, 7 3, 7 9, 2 9, 2 3)), ((9 5, 13 5, 11 5, 9 5)))"); } public void testXYZM_MultiPolygon() throws Exception { checkValue( MDSYS.SDO_GEOMETRY(4307, NULL, NULL, MDSYS.SDO_ELEM_INFO_ARRAY(1,1003,1, 21,1003,1), MDSYS.SDO_ORDINATE_ARRAY(2,3,99,88, 7,3,99,88, 7,9,99,88, 2,9,99,88, 2,3,99,88, 9,5,99,88, 13,5,99,88, 11,5,99,88, 9,5,99,88 ) ), "MULTIPOLYGON (((2 3, 7 3, 7 9, 2 9, 2 3)), ((9 5, 13 5, 11 5, 9 5)))"); } public void testXY_MultiPolygonHole_GT() throws Exception { checkValue( MDSYS.SDO_GEOMETRY(2007, NULL, NULL, MDSYS.SDO_ELEM_INFO_ARRAY(1,1003,1,11,2003,1,19,1003,1), MDSYS.SDO_ORDINATE_ARRAY(2,3, 7,3, 7,9, 2,9, 2,3, 3,4, 3,8, 6,8, 3,4, 9,5, 13,5, 11,8, 9,5) ), "MULTIPOLYGON (((2 3, 7 3, 7 9, 2 9, 2 3), (3 4, 3 8, 6 8, 3 4)), ((9 5, 13 5, 11 8, 9 5)))"); } //==================================================================================== // Unsupported Geometry types public void testFAIL_CompoundPolygon() throws Exception { OraGeom oraGeom = MDSYS.SDO_GEOMETRY(2003,NULL,NULL,MDSYS.SDO_ELEM_INFO_ARRAY(1,1005,2, 1,2,1, 5,2,2),MDSYS.SDO_ORDINATE_ARRAY(6,10, 10,1, 14,10, 10,14, 6,10)); checkFailure(oraGeom, "CURVEPOLYGON ((-10.355339059327378 25.0, 25.0 -10.355339059327378, 60.35533905932738 25.0, 25.0 60.35533905932738, -10.355339059327378 25.0))"); } public void testFAIL_Circle() throws Exception { OraGeom oraGeom = MDSYS.SDO_GEOMETRY(2003,NULL,NULL,MDSYS.SDO_ELEM_INFO_ARRAY(1,1003,4),MDSYS.SDO_ORDINATE_ARRAY(0,0,50,0,50,50)); checkFailure(oraGeom, "CURVEPOLYGON ((-10.355339059327378 25.0, 25.0 -10.355339059327378, 60.35533905932738 25.0, 25.0 60.35533905932738, -10.355339059327378 25.0))"); } public void testFAIL_SolidPolygonXY() throws Exception { OraGeom oraGeom = MDSYS.SDO_GEOMETRY(3008,NULL,NULL,/*SDO_ELEM_INFO_ARRAY*/ new int[] {1,1007,1,1,1006,6,1,1003,3,7,1003,3,13,1003,3,19,1003,3,25,1003,3,31,1003,3}, /*SDO_ORDINATE_ARRAY*/ new double[]{1.0,0.0,-1.0,1.0,1.0,1.0,1.0,0.0,1.0,0.0,0.0,-1.0,0.0,1.0,1.0,0.0,0.0,-1.0,0.0,1.0,-1.0,1.0,1.0,1.0,0.0,0.0,1.0,1.0,1.0,1.0,1.0,1.0,-1.0,0.0,0.0,-1.0}); checkFailure(oraGeom, "ERROR"); } public void testFAIL_MultiSolidPolygonXY() throws Exception { OraGeom oraGeom = MDSYS.SDO_GEOMETRY(3009,NULL,NULL,MDSYS.SDO_ELEM_INFO_ARRAY(1,1007,3,7,1007,3),MDSYS.SDO_ORDINATE_ARRAY(-2.0,1.0,3.0,-3.0,-1.0,0.0,0.0,0.0,0.0,1.0,1.0,1.0)); checkFailure(oraGeom, "ERROR"); } public void testFAIL_CompoundPolygonXY() throws Exception { OraGeom oraGeom = MDSYS.SDO_GEOMETRY(2003,NULL,NULL,MDSYS.SDO_ELEM_INFO_ARRAY(1,1005,2, 1,2,1, 5,2,2),MDSYS.SDO_ORDINATE_ARRAY(6,10, 10,1, 14,10, 10,14, 6,10)); checkFailure(oraGeom, "ERROR CURVEPOLYGON ((-10.355339059327378 25.0, 25.0 -10.355339059327378, 60.35533905932738 25.0, 25.0 60.35533905932738, -10.355339059327378 25.0))"); } public void testFAIL_CircularLineString() throws Exception { OraGeom oraGeom = MDSYS.SDO_GEOMETRY(2002,NULL,NULL,MDSYS.SDO_ELEM_INFO_ARRAY(1,2,2),MDSYS.SDO_ORDINATE_ARRAY(0,0,50,0,50,50)); checkFailure(oraGeom, "ERROR LINESTRING (0 0, 50 0, 50 50)"); } public void testFAIL_CompoundLineStringXY() throws Exception { OraGeom oraGeom = MDSYS.SDO_GEOMETRY(2002,NULL,NULL,MDSYS.SDO_ELEM_INFO_ARRAY(1,4,2, 1,2,1, 3,2,2),MDSYS.SDO_ORDINATE_ARRAY(10,10, 10,14, 6,10, 14,10)); checkFailure(oraGeom, "ERROR LINESTRING (0 0, 50 0, 50 50)"); } //==================================================================================== public void testRawGeometryCollectionWithPoint() throws Exception { final GeometryFactory geometryFactory = new GeometryFactory(); final OraReader oraReader = new OraReader(geometryFactory); // Geometry type is a 'collection'. final int gType = 2004; // A collection of a 'line' and a 'point'/ // The 'line' is starting at ordinate offset 1. // The 'point' is starting at ordinate offset 5. final int[] elemInfo = new int[] {1, 2, 1, 5, 1, 1}; // 6 ordinates. // 'line' (1, 1, 2, 2). // 'point' (3, 3). final double[] ordinates = new double[] {1, 1, 2, 2, 3, 3}; // Made 'create' method package private to enable test. final Geometry actual = oraReader.read(new OraGeom(gType, 0, elemInfo, ordinates)); // Preparing expected result. final LineString lineString = geometryFactory.createLineString(new Coordinate[] {new Coordinate(1, 1), new Coordinate(2, 2)}); final Point point = geometryFactory.createPoint(new Coordinate(3, 3)); final List<Geometry> geometries = new ArrayList<Geometry>(); geometries.add(lineString); geometries.add(point); final GeometryCollection expected = geometryFactory.createGeometryCollection(GeometryFactory.toGeometryArray(geometries)); assertEquals(expected, actual); } public void testRawLineStringM2() throws Exception { final GeometryFactory geometryFactory = new GeometryFactory(); final OraReader oraReader = new OraReader(geometryFactory); // Geometry type is a 3-dimensional measured line. final int gType = 3302; // The 'line' is starting at ordinate offset 1. final int[] elemInfo = new int[] {1, 2, 1}; final double[] ordinates = new double[] {1, 1, 20, 2, 2, 30}; // Made 'create' method package private to enable test. final Geometry actual = oraReader.read(new OraGeom(gType, 0, elemInfo, ordinates)); // Preparing expected result. final LineString expected = geometryFactory.createLineString(new Coordinate[] {new Coordinate(1, 1), new Coordinate(2, 2)}); assertEquals(expected, actual); } void checkFailure(OraGeom oraGeom, String wkt) { try { checkValue(oraGeom, wkt); } catch (IllegalArgumentException e) { // correct expected result return; } fail("Expected IllegalArgumentException"); } void checkValue(OraGeom oraGeom, String wkt) { checkValue(oraGeom, -1, wkt); } void checkValue(OraGeom oraGeom, int targetDim, String wkt) { final GeometryFactory geometryFactory = new GeometryFactory(); final OraReader oraReader = new OraReader(geometryFactory); if (targetDim > -1) oraReader.setDimension(targetDim); final Geometry actual = oraReader.read(oraGeom); Geometry expected = null; try { expected = wktRdr.read(wkt); } catch (ParseException e) { throw new RuntimeException(e); } boolean isEqual = actual.equalsNorm(expected); if (! isEqual) { System.out.println("Expected " + expected + ", actual " + actual); } assertTrue(isEqual); } }