218 lines
5.7 KiB
Python
218 lines
5.7 KiB
Python
# Copyright (c) 2008-2009 Aryeh Leib Taurog, all rights reserved.
|
|
# Modified from original contribution by Aryeh Leib Taurog, which was
|
|
# released under the New BSD license.
|
|
|
|
import unittest
|
|
|
|
from django.contrib.gis.geos import (
|
|
LinearRing,
|
|
LineString,
|
|
MultiPoint,
|
|
Point,
|
|
Polygon,
|
|
fromstr,
|
|
)
|
|
|
|
|
|
def api_get_distance(x):
|
|
return x.distance(Point(-200, -200))
|
|
|
|
|
|
def api_get_buffer(x):
|
|
return x.buffer(10)
|
|
|
|
|
|
def api_get_geom_typeid(x):
|
|
return x.geom_typeid
|
|
|
|
|
|
def api_get_num_coords(x):
|
|
return x.num_coords
|
|
|
|
|
|
def api_get_centroid(x):
|
|
return x.centroid
|
|
|
|
|
|
def api_get_empty(x):
|
|
return x.empty
|
|
|
|
|
|
def api_get_valid(x):
|
|
return x.valid
|
|
|
|
|
|
def api_get_simple(x):
|
|
return x.simple
|
|
|
|
|
|
def api_get_ring(x):
|
|
return x.ring
|
|
|
|
|
|
def api_get_boundary(x):
|
|
return x.boundary
|
|
|
|
|
|
def api_get_convex_hull(x):
|
|
return x.convex_hull
|
|
|
|
|
|
def api_get_extent(x):
|
|
return x.extent
|
|
|
|
|
|
def api_get_area(x):
|
|
return x.area
|
|
|
|
|
|
def api_get_length(x):
|
|
return x.length
|
|
|
|
|
|
geos_function_tests = [
|
|
val
|
|
for name, val in vars().items()
|
|
if hasattr(val, "__call__") and name.startswith("api_get_")
|
|
]
|
|
|
|
|
|
class GEOSMutationTest(unittest.TestCase):
|
|
"""
|
|
Tests Pythonic Mutability of Python GEOS geometry wrappers
|
|
get/set/delitem on a slice, normal list methods
|
|
"""
|
|
|
|
def test00_GEOSIndexException(self):
|
|
"Testing Geometry IndexError"
|
|
p = Point(1, 2)
|
|
for i in range(-2, 2):
|
|
p._checkindex(i)
|
|
with self.assertRaises(IndexError):
|
|
p._checkindex(2)
|
|
with self.assertRaises(IndexError):
|
|
p._checkindex(-3)
|
|
|
|
def test01_PointMutations(self):
|
|
"Testing Point mutations"
|
|
for p in (Point(1, 2, 3), fromstr("POINT (1 2 3)")):
|
|
self.assertEqual(
|
|
p._get_single_external(1), 2.0, "Point _get_single_external"
|
|
)
|
|
|
|
# _set_single
|
|
p._set_single(0, 100)
|
|
self.assertEqual(p.coords, (100.0, 2.0, 3.0), "Point _set_single")
|
|
|
|
# _set_list
|
|
p._set_list(2, (50, 3141))
|
|
self.assertEqual(p.coords, (50.0, 3141.0), "Point _set_list")
|
|
|
|
def test02_PointExceptions(self):
|
|
"Testing Point exceptions"
|
|
with self.assertRaises(TypeError):
|
|
Point(range(1))
|
|
with self.assertRaises(TypeError):
|
|
Point(range(4))
|
|
|
|
def test03_PointApi(self):
|
|
"Testing Point API"
|
|
q = Point(4, 5, 3)
|
|
for p in (Point(1, 2, 3), fromstr("POINT (1 2 3)")):
|
|
p[0:2] = [4, 5]
|
|
for f in geos_function_tests:
|
|
self.assertEqual(f(q), f(p), "Point " + f.__name__)
|
|
|
|
def test04_LineStringMutations(self):
|
|
"Testing LineString mutations"
|
|
for ls in (
|
|
LineString((1, 0), (4, 1), (6, -1)),
|
|
fromstr("LINESTRING (1 0,4 1,6 -1)"),
|
|
):
|
|
self.assertEqual(
|
|
ls._get_single_external(1),
|
|
(4.0, 1.0),
|
|
"LineString _get_single_external",
|
|
)
|
|
|
|
# _set_single
|
|
ls._set_single(0, (-50, 25))
|
|
self.assertEqual(
|
|
ls.coords,
|
|
((-50.0, 25.0), (4.0, 1.0), (6.0, -1.0)),
|
|
"LineString _set_single",
|
|
)
|
|
|
|
# _set_list
|
|
ls._set_list(2, ((-50.0, 25.0), (6.0, -1.0)))
|
|
self.assertEqual(
|
|
ls.coords, ((-50.0, 25.0), (6.0, -1.0)), "LineString _set_list"
|
|
)
|
|
|
|
lsa = LineString(ls.coords)
|
|
for f in geos_function_tests:
|
|
self.assertEqual(f(lsa), f(ls), "LineString " + f.__name__)
|
|
|
|
def test05_Polygon(self):
|
|
"Testing Polygon mutations"
|
|
for pg in (
|
|
Polygon(
|
|
((1, 0), (4, 1), (6, -1), (8, 10), (1, 0)),
|
|
((5, 4), (6, 4), (6, 3), (5, 4)),
|
|
),
|
|
fromstr("POLYGON ((1 0,4 1,6 -1,8 10,1 0),(5 4,6 4,6 3,5 4))"),
|
|
):
|
|
self.assertEqual(
|
|
pg._get_single_external(0),
|
|
LinearRing((1, 0), (4, 1), (6, -1), (8, 10), (1, 0)),
|
|
"Polygon _get_single_external(0)",
|
|
)
|
|
self.assertEqual(
|
|
pg._get_single_external(1),
|
|
LinearRing((5, 4), (6, 4), (6, 3), (5, 4)),
|
|
"Polygon _get_single_external(1)",
|
|
)
|
|
|
|
# _set_list
|
|
pg._set_list(
|
|
2,
|
|
(
|
|
((1, 2), (10, 0), (12, 9), (-1, 15), (1, 2)),
|
|
((4, 2), (5, 2), (5, 3), (4, 2)),
|
|
),
|
|
)
|
|
self.assertEqual(
|
|
pg.coords,
|
|
(
|
|
((1.0, 2.0), (10.0, 0.0), (12.0, 9.0), (-1.0, 15.0), (1.0, 2.0)),
|
|
((4.0, 2.0), (5.0, 2.0), (5.0, 3.0), (4.0, 2.0)),
|
|
),
|
|
"Polygon _set_list",
|
|
)
|
|
|
|
lsa = Polygon(*pg.coords)
|
|
for f in geos_function_tests:
|
|
self.assertEqual(f(lsa), f(pg), "Polygon " + f.__name__)
|
|
|
|
def test06_Collection(self):
|
|
"Testing Collection mutations"
|
|
points = (
|
|
MultiPoint(*map(Point, ((3, 4), (-1, 2), (5, -4), (2, 8)))),
|
|
fromstr("MULTIPOINT (3 4,-1 2,5 -4,2 8)"),
|
|
)
|
|
for mp in points:
|
|
self.assertEqual(
|
|
mp._get_single_external(2),
|
|
Point(5, -4),
|
|
"Collection _get_single_external",
|
|
)
|
|
|
|
mp._set_list(3, map(Point, ((5, 5), (3, -2), (8, 1))))
|
|
self.assertEqual(
|
|
mp.coords, ((5.0, 5.0), (3.0, -2.0), (8.0, 1.0)), "Collection _set_list"
|
|
)
|
|
|
|
lsa = MultiPoint(*map(Point, ((5, 5), (3, -2), (8, 1))))
|
|
for f in geos_function_tests:
|
|
self.assertEqual(f(lsa), f(mp), "MultiPoint " + f.__name__)
|