89 lines
2.5 KiB
Python
89 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)
|
|
self.ext_ring_cs = ext_ring_cs and tuplize(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))
|