tests.py 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. from __future__ import unicode_literals
  2. from unittest import skipUnless
  3. from django.contrib.gis.geos import HAS_GEOS
  4. from django.contrib.gis.tests.utils import HAS_SPATIAL_DB
  5. from django.test import TestCase
  6. if HAS_GEOS and HAS_SPATIAL_DB:
  7. from django.contrib.gis import admin
  8. from django.contrib.gis.geos import Point
  9. from .models import City
  10. @skipUnless(HAS_GEOS and HAS_SPATIAL_DB, "Geos and spatial db are required.")
  11. class GeoAdminTest(TestCase):
  12. urls = 'django.contrib.gis.tests.geoadmin.urls'
  13. def test_ensure_geographic_media(self):
  14. geoadmin = admin.site._registry[City]
  15. admin_js = geoadmin.media.render_js()
  16. self.assertTrue(any(geoadmin.openlayers_url in js for js in admin_js))
  17. def test_olmap_OSM_rendering(self):
  18. geoadmin = admin.site._registry[City]
  19. result = geoadmin.get_map_widget(City._meta.get_field('point'))(
  20. ).render('point', Point(-79.460734, 40.18476))
  21. self.assertIn(
  22. """geodjango_point.layers.base = new OpenLayers.Layer.OSM("OpenStreetMap (Mapnik)");""",
  23. result)
  24. def test_olmap_WMS_rendering(self):
  25. geoadmin = admin.GeoModelAdmin(City, admin.site)
  26. result = geoadmin.get_map_widget(City._meta.get_field('point'))(
  27. ).render('point', Point(-79.460734, 40.18476))
  28. self.assertIn(
  29. """geodjango_point.layers.base = new OpenLayers.Layer.WMS("OpenLayers WMS", "http://vmap0.tiles.osgeo.org/wms/vmap0", {layers: \'basic\', format: 'image/jpeg'});""",
  30. result)
  31. def test_olwidget_has_changed(self):
  32. """
  33. Check that changes are accurately noticed by OpenLayersWidget.
  34. """
  35. geoadmin = admin.site._registry[City]
  36. form = geoadmin.get_changelist_form(None)()
  37. has_changed = form.fields['point']._has_changed
  38. initial = Point(13.4197458572965953, 52.5194108501149799, srid=4326)
  39. data_same = "SRID=3857;POINT(1493879.2754093995 6894592.019687599)"
  40. data_almost_same = "SRID=3857;POINT(1493879.2754093990 6894592.019687590)"
  41. data_changed = "SRID=3857;POINT(1493884.0527237 6894593.8111804)"
  42. self.assertTrue(has_changed(None, data_changed))
  43. self.assertTrue(has_changed(initial, ""))
  44. self.assertFalse(has_changed(None, ""))
  45. self.assertFalse(has_changed(initial, data_same))
  46. self.assertFalse(has_changed(initial, data_almost_same))
  47. self.assertTrue(has_changed(initial, data_changed))