tests.py 3.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. from __future__ import unicode_literals
  2. from django.contrib.gis.geos import HAS_GEOS
  3. from django.test import TestCase, override_settings, skipUnlessDBFeature
  4. if HAS_GEOS:
  5. from django.contrib.gis import admin
  6. from django.contrib.gis.geos import Point
  7. from .admin import UnmodifiableAdmin
  8. from .models import City
  9. @skipUnlessDBFeature("gis_enabled")
  10. @override_settings(ROOT_URLCONF='django.contrib.gis.tests.geoadmin.urls')
  11. class GeoAdminTest(TestCase):
  12. def test_ensure_geographic_media(self):
  13. geoadmin = admin.site._registry[City]
  14. admin_js = geoadmin.media.render_js()
  15. self.assertTrue(any(geoadmin.openlayers_url in js for js in admin_js))
  16. def test_olmap_OSM_rendering(self):
  17. delete_all_btn = """<a href="javascript:geodjango_point.clearFeatures()">Delete all Features</a>"""
  18. original_geoadmin = admin.site._registry[City]
  19. params = original_geoadmin.get_map_widget(City._meta.get_field('point')).params
  20. result = original_geoadmin.get_map_widget(City._meta.get_field('point'))(
  21. ).render('point', Point(-79.460734, 40.18476), params)
  22. self.assertIn(
  23. """geodjango_point.layers.base = new OpenLayers.Layer.OSM("OpenStreetMap (Mapnik)");""",
  24. result)
  25. self.assertIn(delete_all_btn, result)
  26. admin.site.unregister(City)
  27. admin.site.register(City, UnmodifiableAdmin)
  28. try:
  29. geoadmin = admin.site._registry[City]
  30. params = geoadmin.get_map_widget(City._meta.get_field('point')).params
  31. result = geoadmin.get_map_widget(City._meta.get_field('point'))(
  32. ).render('point', Point(-79.460734, 40.18476), params)
  33. self.assertNotIn(delete_all_btn, result)
  34. finally:
  35. admin.site.unregister(City)
  36. admin.site.register(City, original_geoadmin.__class__)
  37. def test_olmap_WMS_rendering(self):
  38. geoadmin = admin.GeoModelAdmin(City, admin.site)
  39. result = geoadmin.get_map_widget(City._meta.get_field('point'))(
  40. ).render('point', Point(-79.460734, 40.18476))
  41. self.assertIn(
  42. """geodjango_point.layers.base = new OpenLayers.Layer.WMS("OpenLayers WMS", """
  43. """"http://vmap0.tiles.osgeo.org/wms/vmap0", {layers: 'basic', format: 'image/jpeg'});""",
  44. result)
  45. def test_olwidget_has_changed(self):
  46. """
  47. Check that changes are accurately noticed by OpenLayersWidget.
  48. """
  49. geoadmin = admin.site._registry[City]
  50. form = geoadmin.get_changelist_form(None)()
  51. has_changed = form.fields['point'].has_changed
  52. initial = Point(13.4197458572965953, 52.5194108501149799, srid=4326)
  53. data_same = "SRID=3857;POINT(1493879.2754093995 6894592.019687599)"
  54. data_almost_same = "SRID=3857;POINT(1493879.2754093990 6894592.019687590)"
  55. data_changed = "SRID=3857;POINT(1493884.0527237 6894593.8111804)"
  56. self.assertTrue(has_changed(None, data_changed))
  57. self.assertTrue(has_changed(initial, ""))
  58. self.assertFalse(has_changed(None, ""))
  59. self.assertFalse(has_changed(initial, data_same))
  60. self.assertFalse(has_changed(initial, data_almost_same))
  61. self.assertTrue(has_changed(initial, data_changed))