Replaced HAS_SPATIALREFSYS by a database feature

This commit is contained in:
Claude Paroz 2014-08-19 18:11:10 +02:00
parent c7fa27d702
commit 46c7707e50
5 changed files with 9 additions and 13 deletions

View File

@ -11,6 +11,7 @@ from django.utils.encoding import python_2_unicode_compatible
class BaseSpatialFeatures(object): class BaseSpatialFeatures(object):
gis_enabled = True gis_enabled = True
has_spatialrefsys_table = True
class BaseSpatialOperations(object): class BaseSpatialOperations(object):

View File

@ -9,7 +9,7 @@ from django.contrib.gis.db.backends.mysql.operations import MySQLOperations
class DatabaseFeatures(BaseSpatialFeatures, MySQLDatabaseFeatures): class DatabaseFeatures(BaseSpatialFeatures, MySQLDatabaseFeatures):
pass has_spatialrefsys_table = False
class DatabaseWrapper(MySQLDatabaseWrapper): class DatabaseWrapper(MySQLDatabaseWrapper):

View File

@ -1,9 +1,10 @@
import unittest import unittest
from django.contrib.gis.gdal import HAS_GDAL from django.contrib.gis.gdal import HAS_GDAL
from django.contrib.gis.tests.utils import (no_mysql, oracle, postgis, from django.contrib.gis.tests.utils import (oracle, postgis, spatialite,
spatialite, HAS_SPATIALREFSYS, SpatialRefSys) SpatialRefSys)
from django.db import connection from django.db import connection
from django.test import skipUnlessDBFeature
from django.utils import six from django.utils import six
@ -34,11 +35,10 @@ test_srs = ({'srid': 4326,
) )
@unittest.skipUnless(HAS_GDAL and HAS_SPATIALREFSYS, @unittest.skipUnless(HAS_GDAL, "SpatialRefSysTest needs gdal support")
"SpatialRefSysTest needs gdal support and a spatial database") @skipUnlessDBFeature("has_spatialrefsys_table")
class SpatialRefSysTest(unittest.TestCase): class SpatialRefSysTest(unittest.TestCase):
@no_mysql
def test_retrieve(self): def test_retrieve(self):
""" """
Test retrieval of SpatialRefSys model objects. Test retrieval of SpatialRefSys model objects.
@ -61,7 +61,6 @@ class SpatialRefSysTest(unittest.TestCase):
self.assertTrue(srs.wkt.startswith(sd['srtext'])) self.assertTrue(srs.wkt.startswith(sd['srtext']))
six.assertRegex(self, srs.proj4text, sd['proj4_re']) six.assertRegex(self, srs.proj4text, sd['proj4_re'])
@no_mysql
def test_osr(self): def test_osr(self):
""" """
Test getting OSR objects from SpatialRefSys model objects. Test getting OSR objects from SpatialRefSys model objects.
@ -85,7 +84,6 @@ class SpatialRefSysTest(unittest.TestCase):
if not spatialite or connection.ops.spatial_version[0] >= 4: if not spatialite or connection.ops.spatial_version[0] >= 4:
self.assertTrue(srs.wkt.startswith(sd['srtext'])) self.assertTrue(srs.wkt.startswith(sd['srtext']))
@no_mysql
def test_ellipsoid(self): def test_ellipsoid(self):
""" """
Test the ellipsoid property. Test the ellipsoid property.
@ -102,7 +100,6 @@ class SpatialRefSysTest(unittest.TestCase):
for i in range(3): for i in range(3):
self.assertAlmostEqual(ellps1[i], ellps2[i], prec[i]) self.assertAlmostEqual(ellps1[i], ellps2[i], prec[i])
@no_mysql
def test_add_entry(self): def test_add_entry(self):
""" """
Test adding a new entry in the SpatialRefSys model using the Test adding a new entry in the SpatialRefSys model using the

View File

@ -39,7 +39,6 @@ postgis = _default_db == 'postgis'
mysql = _default_db == 'mysql' mysql = _default_db == 'mysql'
spatialite = _default_db == 'spatialite' spatialite = _default_db == 'spatialite'
HAS_SPATIALREFSYS = True
if oracle and 'gis' in settings.DATABASES[DEFAULT_DB_ALIAS]['ENGINE']: if oracle and 'gis' in settings.DATABASES[DEFAULT_DB_ALIAS]['ENGINE']:
from django.contrib.gis.db.backends.oracle.models import OracleSpatialRefSys as SpatialRefSys from django.contrib.gis.db.backends.oracle.models import OracleSpatialRefSys as SpatialRefSys
elif postgis: elif postgis:
@ -47,5 +46,4 @@ elif postgis:
elif spatialite: elif spatialite:
from django.contrib.gis.db.backends.spatialite.models import SpatialiteSpatialRefSys as SpatialRefSys from django.contrib.gis.db.backends.spatialite.models import SpatialiteSpatialRefSys as SpatialRefSys
else: else:
HAS_SPATIALREFSYS = False
SpatialRefSys = None SpatialRefSys = None

View File

@ -980,7 +980,7 @@ def skipIfDBFeature(feature):
""" """
Skip a test if a database has the named feature Skip a test if a database has the named feature
""" """
return _deferredSkip(lambda: getattr(connection.features, feature), return _deferredSkip(lambda: getattr(connection.features, feature, False),
"Database has feature %s" % feature) "Database has feature %s" % feature)
@ -988,7 +988,7 @@ def skipUnlessDBFeature(feature):
""" """
Skip a test unless a database has the named feature Skip a test unless a database has the named feature
""" """
return _deferredSkip(lambda: not getattr(connection.features, feature), return _deferredSkip(lambda: not getattr(connection.features, feature, False),
"Database doesn't support feature %s" % feature) "Database doesn't support feature %s" % feature)