tests.py 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  1. from django.contrib.gis import admin
  2. from django.contrib.gis.geos import Point
  3. from django.test import SimpleTestCase, ignore_warnings, override_settings
  4. from django.utils.deprecation import RemovedInDjango50Warning
  5. from .admin import UnmodifiableAdmin
  6. from .models import City, site
  7. @ignore_warnings(category=RemovedInDjango50Warning)
  8. @override_settings(ROOT_URLCONF='django.contrib.gis.tests.geoadmin.urls')
  9. class GeoAdminTest(SimpleTestCase):
  10. def test_ensure_geographic_media(self):
  11. geoadmin = site._registry[City]
  12. admin_js = geoadmin.media.render_js()
  13. self.assertTrue(any(geoadmin.openlayers_url in js for js in admin_js))
  14. def test_olmap_OSM_rendering(self):
  15. delete_all_btn = """<a href="javascript:geodjango_point.clearFeatures()">Delete all Features</a>"""
  16. original_geoadmin = site._registry[City]
  17. params = original_geoadmin.get_map_widget(City._meta.get_field('point')).params
  18. result = original_geoadmin.get_map_widget(City._meta.get_field('point'))(
  19. ).render('point', Point(-79.460734, 40.18476), params)
  20. self.assertIn(
  21. """geodjango_point.layers.base = new OpenLayers.Layer.OSM("OpenStreetMap (Mapnik)");""",
  22. result)
  23. self.assertIn(delete_all_btn, result)
  24. site.unregister(City)
  25. site.register(City, UnmodifiableAdmin)
  26. try:
  27. geoadmin = site._registry[City]
  28. params = geoadmin.get_map_widget(City._meta.get_field('point')).params
  29. result = geoadmin.get_map_widget(City._meta.get_field('point'))(
  30. ).render('point', Point(-79.460734, 40.18476), params)
  31. self.assertNotIn(delete_all_btn, result)
  32. finally:
  33. site.unregister(City)
  34. site.register(City, original_geoadmin.__class__)
  35. def test_olmap_WMS_rendering(self):
  36. geoadmin = admin.GeoModelAdmin(City, site)
  37. result = geoadmin.get_map_widget(City._meta.get_field('point'))(
  38. ).render('point', Point(-79.460734, 40.18476))
  39. self.assertIn(
  40. """geodjango_point.layers.base = new OpenLayers.Layer.WMS("OpenLayers WMS", """
  41. """"http://vmap0.tiles.osgeo.org/wms/vmap0", {layers: 'basic', format: 'image/jpeg'});""",
  42. result)
  43. def test_olwidget_has_changed(self):
  44. """
  45. Changes are accurately noticed by OpenLayersWidget.
  46. """
  47. geoadmin = site._registry[City]
  48. form = geoadmin.get_changelist_form(None)()
  49. has_changed = form.fields['point'].has_changed
  50. initial = Point(13.4197458572965953, 52.5194108501149799, srid=4326)
  51. data_same = "SRID=3857;POINT(1493879.2754093995 6894592.019687599)"
  52. data_almost_same = "SRID=3857;POINT(1493879.2754093990 6894592.019687590)"
  53. data_changed = "SRID=3857;POINT(1493884.0527237 6894593.8111804)"
  54. self.assertTrue(has_changed(None, data_changed))
  55. self.assertTrue(has_changed(initial, ""))
  56. self.assertFalse(has_changed(None, ""))
  57. self.assertFalse(has_changed(initial, data_same))
  58. self.assertFalse(has_changed(initial, data_almost_same))
  59. self.assertTrue(has_changed(initial, data_changed))
  60. def test_olwidget_empty_string(self):
  61. geoadmin = site._registry[City]
  62. form = geoadmin.get_changelist_form(None)({'point': ''})
  63. with self.assertNoLogs('django.contrib.gis', 'ERROR'):
  64. output = str(form['point'])
  65. self.assertInHTML(
  66. '<textarea id="id_point" class="vWKTField required" cols="150"'
  67. ' rows="10" name="point"></textarea>',
  68. output
  69. )
  70. def test_olwidget_invalid_string(self):
  71. geoadmin = site._registry[City]
  72. form = geoadmin.get_changelist_form(None)({'point': 'INVALID()'})
  73. with self.assertLogs('django.contrib.gis', 'ERROR') as cm:
  74. output = str(form['point'])
  75. self.assertInHTML(
  76. '<textarea id="id_point" class="vWKTField required" cols="150"'
  77. ' rows="10" name="point"></textarea>',
  78. output
  79. )
  80. self.assertEqual(len(cm.records), 1)
  81. self.assertEqual(
  82. cm.records[0].getMessage(),
  83. "Error creating geometry from value 'INVALID()' (String input "
  84. "unrecognized as WKT EWKT, and HEXEWKB.)"
  85. )
  86. class DeprecationTests(SimpleTestCase):
  87. def test_warning(self):
  88. class DeprecatedOSMGeoAdmin(admin.OSMGeoAdmin):
  89. pass
  90. class DeprecatedGeoModelAdmin(admin.GeoModelAdmin):
  91. pass
  92. msg = (
  93. 'django.contrib.gis.admin.GeoModelAdmin and OSMGeoAdmin are '
  94. 'deprecated in favor of django.contrib.admin.ModelAdmin and '
  95. 'django.contrib.gis.admin.GISModelAdmin.'
  96. )
  97. with self.assertRaisesMessage(RemovedInDjango50Warning, msg):
  98. DeprecatedOSMGeoAdmin(City, site)
  99. with self.assertRaisesMessage(RemovedInDjango50Warning, msg):
  100. DeprecatedGeoModelAdmin(City, site)