test_driver.py 1.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. import unittest
  2. from django.contrib.gis.gdal import HAS_GDAL
  3. if HAS_GDAL:
  4. from django.contrib.gis.gdal import Driver, GDALException
  5. valid_drivers = (
  6. # vector
  7. 'ESRI Shapefile', 'MapInfo File', 'TIGER', 'S57', 'DGN', 'Memory', 'CSV',
  8. 'GML', 'KML',
  9. # raster
  10. 'GTiff', 'JPEG', 'MEM', 'PNG',
  11. )
  12. invalid_drivers = ('Foo baz', 'clucka', 'ESRI Shp', 'ESRI rast')
  13. aliases = {
  14. 'eSrI': 'ESRI Shapefile',
  15. 'TigER/linE': 'TIGER',
  16. 'SHAPE': 'ESRI Shapefile',
  17. 'sHp': 'ESRI Shapefile',
  18. 'tiFf': 'GTiff',
  19. 'tIf': 'GTiff',
  20. 'jPEg': 'JPEG',
  21. 'jpG': 'JPEG',
  22. }
  23. @unittest.skipUnless(HAS_GDAL, "GDAL is required")
  24. class DriverTest(unittest.TestCase):
  25. def test01_valid_driver(self):
  26. "Testing valid GDAL/OGR Data Source Drivers."
  27. for d in valid_drivers:
  28. dr = Driver(d)
  29. self.assertEqual(d, str(dr))
  30. def test02_invalid_driver(self):
  31. "Testing invalid GDAL/OGR Data Source Drivers."
  32. for i in invalid_drivers:
  33. self.assertRaises(GDALException, Driver, i)
  34. def test03_aliases(self):
  35. "Testing driver aliases."
  36. for alias, full_name in aliases.items():
  37. dr = Driver(alias)
  38. self.assertEqual(full_name, str(dr))