mirror of
				https://github.com/django/django.git
				synced 2025-10-29 08:36:09 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			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__)
 |