mirror of
				https://github.com/django/django.git
				synced 2025-10-24 22:26:08 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			92 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			92 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| """
 | |
| This module has the mock object definitions used to hold reference geometry
 | |
| for the GEOS and GDAL tests.
 | |
| """
 | |
| import json
 | |
| import os
 | |
| 
 | |
| from django.utils.functional import cached_property
 | |
| 
 | |
| # Path where reference test data is located.
 | |
| TEST_DATA = os.path.join(os.path.dirname(__file__), 'data')
 | |
| 
 | |
| 
 | |
| def tuplize(seq):
 | |
|     "Turn all nested sequences to tuples in given sequence."
 | |
|     if isinstance(seq, (list, tuple)):
 | |
|         return tuple(tuplize(i) for i in seq)
 | |
|     return seq
 | |
| 
 | |
| 
 | |
| def strconvert(d):
 | |
|     "Converts all keys in dictionary to str type."
 | |
|     return {str(k): v for k, v in d.items()}
 | |
| 
 | |
| 
 | |
| def get_ds_file(name, ext):
 | |
|     return os.path.join(TEST_DATA,
 | |
|                         name,
 | |
|                         name + '.%s' % ext
 | |
|                         )
 | |
| 
 | |
| 
 | |
| class TestObj:
 | |
|     """
 | |
|     Base testing object, turns keyword args into attributes.
 | |
|     """
 | |
|     def __init__(self, **kwargs):
 | |
|         for key, value in kwargs.items():
 | |
|             setattr(self, key, value)
 | |
| 
 | |
| 
 | |
| class TestDS(TestObj):
 | |
|     """
 | |
|     Object for testing GDAL data sources.
 | |
|     """
 | |
|     def __init__(self, name, *, ext='shp', **kwargs):
 | |
|         # Shapefile is default extension, unless specified otherwise.
 | |
|         self.ds = get_ds_file(name, ext)
 | |
|         super().__init__(**kwargs)
 | |
| 
 | |
| 
 | |
| class TestGeom(TestObj):
 | |
|     """
 | |
|     Testing object used for wrapping reference geometry data
 | |
|     in GEOS/GDAL tests.
 | |
|     """
 | |
|     def __init__(self, *, coords=None, centroid=None, ext_ring_cs=None, **kwargs):
 | |
|         # Converting lists to tuples of certain keyword args
 | |
|         # so coordinate test cases will match (JSON has no
 | |
|         # concept of tuple).
 | |
|         if coords:
 | |
|             self.coords = tuplize(coords)
 | |
|         if centroid:
 | |
|             self.centroid = tuple(centroid)
 | |
|         if ext_ring_cs:
 | |
|             ext_ring_cs = tuplize(ext_ring_cs)
 | |
|         self.ext_ring_cs = ext_ring_cs
 | |
| 
 | |
|         super().__init__(**kwargs)
 | |
| 
 | |
| 
 | |
| class TestGeomSet:
 | |
|     """
 | |
|     Each attribute of this object is a list of `TestGeom` instances.
 | |
|     """
 | |
|     def __init__(self, **kwargs):
 | |
|         for key, value in kwargs.items():
 | |
|             setattr(self, key, [TestGeom(**strconvert(kw)) for kw in value])
 | |
| 
 | |
| 
 | |
| class TestDataMixin:
 | |
|     """
 | |
|     Mixin used for GEOS/GDAL test cases that defines a `geometries`
 | |
|     property, which returns and/or loads the reference geometry data.
 | |
|     """
 | |
|     @cached_property
 | |
|     def geometries(self):
 | |
|         # Load up the test geometry data from fixture into global.
 | |
|         with open(os.path.join(TEST_DATA, 'geometries.json')) as f:
 | |
|             geometries = json.load(f)
 | |
|         return TestGeomSet(**strconvert(geometries))
 |