/* This program 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 3 of the License, or (at your option) any later version. This program 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 General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see <http://www.gnu.org/licenses/>. */ package org.opentripplanner.routing.core; import org.opentripplanner.routing.edgetype.PlainStreetEdge; import org.opentripplanner.routing.edgetype.StreetTraversalPermission; import org.opentripplanner.routing.vertextype.IntersectionVertex; import com.vividsolutions.jts.geom.Coordinate; import com.vividsolutions.jts.geom.LineString; import com.vividsolutions.jts.geom.GeometryFactory; import junit.framework.TestCase; public class TestTurns extends TestCase { public void testIntersectionVertex() { GeometryFactory gf = new GeometryFactory(); LineString geometry = gf.createLineString(new Coordinate[] { new Coordinate(-0.10, 0), new Coordinate(0, 0) }); IntersectionVertex v1 = new IntersectionVertex(null, "v1", -0.10, 0); IntersectionVertex v2 = new IntersectionVertex(null, "v2", 0, 0); PlainStreetEdge leftEdge = new PlainStreetEdge(v1, v2, geometry, "morx", 10.0, StreetTraversalPermission.ALL, true); LineString geometry2 = gf.createLineString(new Coordinate[] { new Coordinate(0, 0), new Coordinate(-0.10, 0) }); PlainStreetEdge rightEdge = new PlainStreetEdge(v1, v2, geometry2, "fleem", 10.0, StreetTraversalPermission.ALL, false); assertEquals(180, Math.abs(leftEdge.outAngle - rightEdge.outAngle)); } }